From 8b4ec11b8958b7b7893d2b0f6aad20b2ddc3599f Mon Sep 17 00:00:00 2001 From: Daniel Silverstone Date: Sun, 5 May 2019 21:53:08 +0100 Subject: 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 --- content/handlers/javascript/duktape/dukky.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) (limited to 'content/handlers/javascript/duktape/dukky.c') 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); -- cgit v1.2.3