From 2e37c2cee2a36265523962af4f8ff1402dc44d0b Mon Sep 17 00:00:00 2001 From: bptato Date: Sat, 2 Dec 2023 00:53:27 +0100 Subject: js: get rid of getJSValue just use an UncheckedArray in the binding --- src/bindings/quickjs.nim | 3 ++- src/js/javascript.nim | 19 +++++++++---------- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/bindings/quickjs.nim b/src/bindings/quickjs.nim index 01182b90..65d6c679 100644 --- a/src/bindings/quickjs.nim +++ b/src/bindings/quickjs.nim @@ -68,7 +68,8 @@ type JSRuntime* = ptr object JSContext* = ptr object JSModuleDef* = ptr object - JSCFunction* = proc (ctx: JSContext, this_val: JSValue, argc: cint, argv: ptr JSValue): JSValue {.cdecl.} + JSCFunction* = proc (ctx: JSContext, this_val: JSValue, argc: cint, + argv: ptr UncheckedArray[JSValue]): JSValue {.cdecl.} JSCFunctionData* = proc (ctx: JSContext, this_val: JSValue, argc: cint, argv: ptr JSValue, magic: cint, func_data: ptr JSValue): JSValue {.cdecl.} JSGetterFunction* = proc(ctx: JSContext, this_val: JSValue): JSValue {.cdecl.} JSSetterFunction* = proc(ctx: JSContext, this_val: JSValue, val: JSValue): JSValue {.cdecl.} diff --git a/src/js/javascript.nim b/src/js/javascript.nim index 124eab5d..361d9df7 100644 --- a/src/js/javascript.nim +++ b/src/js/javascript.nim @@ -122,9 +122,6 @@ proc newJSContext*(rt: JSRuntime): JSContext = JS_SetContextOpaque(ctx, cast[pointer](opaque)) return ctx -func getJSValue(argv: ptr JSValue, i: int): JSValue {.inline.} = - cast[ptr UncheckedArray[JSValue]](argv)[i] - func getClass*(ctx: JSContext, class: string): JSClassID = # This function *should* never fail. ctx.getOpaque().creg[class] @@ -420,7 +417,7 @@ template getJSParams(): untyped = newIdentDefs(ident("ctx"), quote do: JSContext), newIdentDefs(ident("this"), quote do: JSValue), newIdentDefs(ident("argc"), quote do: cint), - newIdentDefs(ident("argv"), quote do: ptr JSValue) + newIdentDefs(ident("argv"), quote do: ptr UncheckedArray[JSValue]) ] template getJSGetterParams(): untyped = @@ -521,14 +518,14 @@ proc addParam2(gen: var JSFuncGenerator, s, t, val: NimNode, fallback: NimNode = else: let j = gen.j gen.jsFunCallLists[i].add(newLetStmt(s, quote do: - if `j` < argc and not JS_IsUndefined(getJSValue(argv, `j`)): + if `j` < argc and not JS_IsUndefined(argv[`j`]): `stmt` else: `fallback`)) proc addValueParam(gen: var JSFuncGenerator, s, t: NimNode, fallback: NimNode = nil) = let j = gen.j - gen.addParam2(s, t, quote do: getJSValue(argv, `j`), fallback) + gen.addParam2(s, t, quote do: argv[`j`], fallback) proc addUnionParamBranch(gen: var JSFuncGenerator, query, newBranch: NimNode, fallback: NimNode = nil) = let i = gen.i @@ -662,9 +659,10 @@ proc addUnionParam0(gen: var JSFuncGenerator, tt: NimNode, s: NimNode, val: NimN gen.jsFunCallLists.add(branch) gen.newBranchList.setLen(0) -proc addUnionParam(gen: var JSFuncGenerator, tt: NimNode, s: NimNode, fallback: NimNode = nil) = +proc addUnionParam(gen: var JSFuncGenerator, tt: NimNode, s: NimNode, + fallback: NimNode = nil) = let j = gen.j - gen.addUnionParam0(tt, s, quote do: getJSValue(argv, `j`), fallback) + gen.addUnionParam0(tt, s, quote do: argv[`j`], fallback) proc addFixParam(gen: var JSFuncGenerator, name: string) = let s = ident("arg_" & $gen.i) @@ -703,7 +701,7 @@ proc addOptionalParams(gen: var JSFuncGenerator) = ( var valist: seq[`vt`] for i in `j`..