diff options
author | Daniel Silverstone <dsilvers@digital-scurf.org> | 2019-05-05 21:53:08 +0100 |
---|---|---|
committer | Daniel Silverstone <dsilvers@digital-scurf.org> | 2019-05-05 22:17:10 +0100 |
commit | 8b4ec11b8958b7b7893d2b0f6aad20b2ddc3599f (patch) | |
tree | d7cf6aee20d37e59f7f7b747621d3fd9c6b8a3dc /content/handlers/javascript/duktape/dukky.c | |
parent | 8474c5d4c0b59e74e2ef001b5033b78d7a99fcad (diff) | |
download | netsurf-8b4ec11b8958b7b7893d2b0f6aad20b2ddc3599f.tar.gz netsurf-8b4ec11b8958b7b7893d2b0f6aad20b2ddc3599f.tar.bz2 |
Dukky: Change from specifically named generics
Instead of specifically having to extract each generic by name,
such as makeListProxy, instead support the entire generics table
and use `dukky_push_generics()` to gain access to it.
Signed-off-by: Daniel Silverstone <dsilvers@digital-scurf.org>
Diffstat (limited to 'content/handlers/javascript/duktape/dukky.c')
-rw-r--r-- | content/handlers/javascript/duktape/dukky.c | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/content/handlers/javascript/duktape/dukky.c b/content/handlers/javascript/duktape/dukky.c index 8af3165b6..d1bd4ec49 100644 --- a/content/handlers/javascript/duktape/dukky.c +++ b/content/handlers/javascript/duktape/dukky.c @@ -48,7 +48,7 @@ #define HANDLER_LISTENER_MAGIC MAGIC(HANDLER_LISTENER_MAP) #define HANDLER_MAGIC MAGIC(HANDLER_MAP) #define EVENT_LISTENER_JS_MAGIC MAGIC(EVENT_LISTENER_JS_MAP) -#define LIST_PROXY_MAGIC MAGIC(LIST_PROXY) +#define GENERICS_MAGIC MAGIC(GENERICS_TABLE) static duk_ret_t dukky_populate_object(duk_context *ctx, void *udata) { @@ -663,11 +663,7 @@ jsobject *js_newcompartment(jscontext *ctx, void *win_priv, void *doc_priv) /* ..., Win */ duk_get_prop_string(CTX, -1, "NetSurf"); /* ..., Win, NetSurf */ - duk_get_prop_string(CTX, -1, "makeListProxy"); - /* ..., Win, NetSurf, MLP */ - duk_put_global_string(CTX, LIST_PROXY_MAGIC); - /* ..., Win, NetSurf */ - duk_pop(CTX); + duk_put_global_string(CTX, GENERICS_MAGIC); /* ..., Win */ duk_del_prop_string(CTX, -1, "NetSurf"); duk_pop(CTX); @@ -754,6 +750,17 @@ duk_int_t dukky_pcall(duk_context *ctx, duk_size_t argc, bool reset_timeout) } +void dukky_push_generics(duk_context *ctx, const char *generic) +{ + /* ... */ + duk_get_global_string(ctx, GENERICS_MAGIC); + /* ..., generics */ + duk_get_prop_string(ctx, -1, generic); + /* ..., generics, generic */ + duk_remove(ctx, -2); + /* ..., generic */ +} + bool js_exec(jscontext *ctx, const char *txt, size_t txtlen, const char *name) { assert(ctx); |