diff options
author | bptato <nincsnevem662@gmail.com> | 2023-08-24 22:00:34 +0200 |
---|---|---|
committer | bptato <nincsnevem662@gmail.com> | 2023-08-24 22:08:46 +0200 |
commit | 229f199e4bd3ee17ff368006e6a12448a4e04120 (patch) | |
tree | 496eb16f75d32e94c583b8ff2db1d4797f460b22 | |
parent | d55af421cf48d8b3a922fa3b72130f2b40870dc8 (diff) | |
download | chawan-229f199e4bd3ee17ff368006e6a12448a4e04120.tar.gz |
javascript: misc. refactorings
* Remove some unused properties from objects * Un-extern JSFunctionList * Remove js/javascript dependency from regex (the wrapper functions were rather pointless) * Remove setProperty (only toJS(Table) used it, but there we have to use defineProperty instead.) * Accordingly, use definePropertyCWE in toJS(Table) * Simplify fromJSTable (replace pointer arithmetic with UncheckedArray) * Reduce implicit `result' usage
-rw-r--r-- | src/bindings/quickjs.nim | 4 | ||||
-rw-r--r-- | src/js/javascript.nim | 76 | ||||
-rw-r--r-- | src/js/regex.nim | 5 | ||||
-rw-r--r-- | todo | 1 |
4 files changed, 37 insertions, 49 deletions
diff --git a/src/bindings/quickjs.nim b/src/bindings/quickjs.nim index 8110dc5c..a81bd881 100644 --- a/src/bindings/quickjs.nim +++ b/src/bindings/quickjs.nim @@ -386,7 +386,9 @@ proc JS_SetPropertyFunctionList*(ctx: JSContext, obj: JSValue, tab: ptr JSCFunct proc JS_GetProperty*(ctx: JSContext, this_obj: JSValue, prop: JSAtom): JSValue proc JS_GetPropertyStr*(ctx: JSContext, this_obj: JSValue, prop: cstring): JSValue proc JS_GetPropertyUint32*(ctx: JSContext, this_obj: JSValue, idx: uint32): JSValue -proc JS_GetOwnPropertyNames*(ctx: JSContext, ptab: ptr ptr JSPropertyEnum, plen: ptr uint32, obj: JSValue, flags: cint): cint +proc JS_GetOwnPropertyNames*(ctx: JSContext, + ptab: ptr ptr UncheckedArray[JSPropertyEnum], plen: ptr uint32, + obj: JSValue, flags: cint): cint proc JS_GetOwnProperty*(ctx: JSContext, desc: ptr JSPropertyDescriptor, obj: JSValue, prop: JSAtom): cint proc JS_Call*(ctx: JSContext, func_obj, this_obj: JSValue, argc: cint, argv: ptr JSValue): JSValue diff --git a/src/js/javascript.nim b/src/js/javascript.nim index bedb18e5..e8b34cb1 100644 --- a/src/js/javascript.nim +++ b/src/js/javascript.nim @@ -102,21 +102,19 @@ type # (i.e. to set all unforgeables on the prototype chain, it is enough to set) # `unforgeable[classid]'.) unforgeable: Table[JSClassID, seq[JSCFunctionListEntry]] - funmap: Table[pointer, pointer] gclaz: string sym_refs: array[JSSymbolRefs, JSAtom] str_refs: array[JSStrRefs, JSAtom] Array_prototype_values: JSValue Object_prototype_valueOf*: JSValue err_ctors: array[JSErrorEnum, JSValue] - dummy_ref_proto: JSValue JSRuntimeOpaque* = ref object plist: Table[pointer, pointer] # Nim, JS flist: seq[seq[JSCFunctionListEntry]] fins: Table[JSClassID, proc(val: JSValue)] - JSFunctionList* = openArray[JSCFunctionListEntry] + JSFunctionList = openArray[JSCFunctionListEntry] JSError* = ref object of RootObj e*: JSErrorEnum @@ -229,9 +227,6 @@ proc newJSContext*(rt: JSRuntime): JSContext = JS_SetContextOpaque(ctx, cast[pointer](opaque)) return ctx -proc newJSContextRaw*(rt: JSRuntime): JSContext = - result = JS_NewContextRaw(rt) - func getJSValue(argv: ptr JSValue, i: int): JSValue {.inline.} = cast[ptr UncheckedArray[JSValue]](argv)[i] @@ -369,13 +364,6 @@ func isInstanceOf*(ctx: JSContext, val: JSValue, class: static string): bool = break return found -proc setProperty*(ctx: JSContext, val: JSValue, name: string, prop: JSValue) = - if JS_SetPropertyStr(ctx, val, cstring(name), prop) <= 0: - raise newException(Defect, "Failed to set property string: " & name) - -proc setProperty*(ctx: JSContext, val: JSValue, name: string, fun: JSCFunction, argc: int = 0) = - ctx.setProperty(val, name, ctx.newJSCFunction(name, fun, argc)) - proc defineProperty(ctx: JSContext, this: JSValue, name: string, prop: JSValue, flags = cint(0)) = if JS_DefinePropertyValueStr(ctx, this, cstring(name), prop, flags) <= 0: @@ -764,21 +752,19 @@ proc fromJSSet[T](ctx: JSContext, val: JSValue): Opt[set[T]] = proc fromJSTable[A, B](ctx: JSContext, val: JSValue): Result[Table[A, B], JSError] = - var ptab: ptr JSPropertyEnum + var ptab: ptr UncheckedArray[JSPropertyEnum] var plen: uint32 let flags = cint(JS_GPN_STRING_MASK) if JS_GetOwnPropertyNames(ctx, addr ptab, addr plen, val, flags) == -1: # exception return err() defer: - for i in 0..<plen: - let prop = cast[ptr JSPropertyEnum](cast[int](ptab) + sizeof(ptab[]) * int(i)) - JS_FreeAtom(ctx, prop.atom) + for i in 0 ..< plen: + JS_FreeAtom(ctx, ptab[i].atom) js_free(ctx, ptab) var res = Table[A, B]() - for i in 0..<plen: - let prop = cast[ptr JSPropertyEnum](cast[int](ptab) + sizeof(ptab[]) * int(i)) - let atom = prop.atom + for i in 0 ..< plen: + let atom = ptab[i].atom let k = JS_AtomToValue(ctx, atom) defer: JS_FreeValue(ctx, k) let kn = ?fromJS[A](ctx, k) @@ -821,7 +807,7 @@ macro unpackReturnType(f: typed) = return quote do: void doAssert rv[0].strVal == "Result" let rvv = rv[1] - result = quote do: `rvv` + return quote do: `rvv` macro unpackArg0(f: typed) = var x = f.getRealTypeFun() @@ -829,7 +815,7 @@ macro unpackArg0(f: typed) = let rv = params[1] doAssert rv.kind == nnkIdentDefs let rvv = rv[1] - result = quote do: `rvv` + return quote do: `rvv` proc fromJSFunction[T](ctx: JSContext, val: JSValue): Result[T, JSError] = @@ -1007,7 +993,7 @@ proc toJS[U, V](ctx: JSContext, t: Table[U, V]): JSValue = let obj = JS_NewObject(ctx) if not JS_IsException(obj): for k, v in t: - setProperty(ctx, obj, k, toJS(ctx, v)) + definePropertyCWE(ctx, obj, k, v) return obj proc toJS*(ctx: JSContext, opt: Option): JSValue = @@ -1036,7 +1022,8 @@ proc toJS(ctx: JSContext, s: seq): JSValue = let j = toJS(ctx, s[i]) if JS_IsException(j): return j - if JS_DefinePropertyValueInt64(ctx, a, int64(i), j, JS_PROP_C_W_E or JS_PROP_THROW) < 0: + if JS_DefinePropertyValueInt64(ctx, a, int64(i), j, + JS_PROP_C_W_E or JS_PROP_THROW) < 0: return JS_EXCEPTION return a @@ -1146,8 +1133,6 @@ proc defineConsts*(ctx: JSContext, classid: JSClassID, type JSFuncGenerator = object t: BoundFunctionType - original: NimNode - copied: NimNode thisname: Option[string] funcName: string generics: Table[string, seq[NimNode]] @@ -1578,11 +1563,12 @@ proc newJSProcBody(gen: var JSFuncGenerator, isva: bool): NimNode = ) result.add(gen.jsCallAndRet) -proc newJSProc(gen: var JSFuncGenerator, params: openArray[NimNode], isva = true): NimNode = +proc newJSProc(gen: var JSFuncGenerator, params: openArray[NimNode], + isva = true): NimNode = let jsBody = gen.newJSProcBody(isva) let jsPragmas = newNimNode(nnkPragma).add(ident("cdecl")) - result = newProc(gen.newName, params, jsBody, pragmas = jsPragmas) - gen.res = result + gen.res = newProc(gen.newName, params, jsBody, pragmas = jsPragmas) + return gen.res func getFuncName(fun: NimNode, jsname: string): string = if jsname != "": @@ -1641,7 +1627,6 @@ proc setupGenerator(fun: NimNode, t: BoundFunctionType, funcParams: funcParams, returnType: getReturn(fun), minArgs: funcParams.getMinArgs(), - original: fun, thisname: thisname, errval: getErrVal(t), dielabel: ident("ondie"), @@ -1693,7 +1678,7 @@ macro jsctor*(fun: typed) = gen.makeCtorJSCallAndRet(errstmt) discard gen.newJSProc(getJSParams()) gen.registerConstructor() - result = newStmtList(fun) + return newStmtList(fun) macro jshasprop*(fun: typed) = var gen = setupGenerator(fun, PROPERTY_HAS, thisname = some("obj")) @@ -1712,7 +1697,7 @@ macro jshasprop*(fun: typed) = doAssert false # TODO? let jsProc = gen.newJSProc(getJSHasPropParams(), false) gen.registerFunction() - result = newStmtList(fun, jsProc) + return newStmtList(fun, jsProc) macro jsgetprop*(fun: typed) = var gen = setupGenerator(fun, PROPERTY_GET, thisname = some("obj")) @@ -1736,7 +1721,7 @@ macro jsgetprop*(fun: typed) = return cint(0) let jsProc = gen.newJSProc(getJSGetPropParams(), false) gen.registerFunction() - result = newStmtList(fun, jsProc) + return newStmtList(fun, jsProc) macro jsfgetn(jsname: static string, uf: static bool, fun: typed) = var gen = setupGenerator(fun, GETTER, jsname = jsname, unforgeable = uf) @@ -1752,7 +1737,7 @@ macro jsfgetn(jsname: static string, uf: static bool, fun: typed) = gen.makeJSCallAndRet(nil, quote do: discard) let jsProc = gen.newJSProc(getJSGetterParams(), false) gen.registerFunction() - result = newStmtList(fun, jsProc) + return newStmtList(fun, jsProc) # "Why?" So the compiler doesn't cry. template jsfget*(fun: typed) = @@ -1789,7 +1774,7 @@ macro jsfsetn(jsname: static string, fun: typed) = gen.makeJSCallAndRet(okstmt, errstmt) let jsProc = gen.newJSProc(getJSSetterParams(), false) gen.registerFunction() - result = newStmtList(fun, jsProc) + return newStmtList(fun, jsProc) template jsfset*(fun: typed) = jsfsetn("", fun) @@ -1812,7 +1797,7 @@ macro jsfuncn*(jsname: static string, uf: static bool, fun: typed) = gen.makeJSCallAndRet(okstmt, errstmt) let jsProc = gen.newJSProc(getJSParams()) gen.registerFunction() - result = newStmtList(fun, jsProc) + return newStmtList(fun, jsProc) template jsfunc*(fun: typed) = jsfuncn("", false, fun) @@ -1874,7 +1859,9 @@ proc findPragmas(t: NimNode): JSObjectPragmas = impl = impl[0].getImpl() # stolen from std's macros.customPragmaNode var identDefsStack = newSeq[NimNode](impl[2].len) - for i in 0..<identDefsStack.len: identDefsStack[i] = impl[2][i] + for i in 0 ..< identDefsStack.len: + identDefsStack[i] = impl[2][i] + var pragmas: JSObjectPragmas while identDefsStack.len > 0: var identDefs = identDefsStack.pop() case identDefs.kind @@ -1903,15 +1890,16 @@ proc findPragmas(t: NimNode): JSObjectPragmas = varsym: varName ) case pragmaName - of "jsget": result.jsget.add(op) - of "jsset": result.jsset.add(op) + of "jsget": pragmas.jsget.add(op) + of "jsset": pragmas.jsset.add(op) of "jsufget": # LegacyUnforgeable op.unforgeable = true - result.jsget.add(op) + pragmas.jsget.add(op) of "jsgetset": - result.jsget.add(op) - result.jsset.add(op) - of "jsinclude": result.jsinclude.add(op) + pragmas.jsget.add(op) + pragmas.jsset.add(op) + of "jsinclude": pragmas.jsinclude.add(op) + return pragmas proc nim_finalize_for_js*[T](obj: ptr T) = for rt in runtimes: @@ -2209,7 +2197,7 @@ macro registerType*(ctx: typed, t: typed, parent: JSClassID = 0, proc getMemoryUsage*(rt: JSRuntime): string = var m: JSMemoryUsage JS_ComputeMemoryUsage(rt, addr m) - result = fmt""" + return fmt""" memory allocated: {m.malloc_count} {m.malloc_size} ({float(m.malloc_size)/float(m.malloc_count):.1f}/block) memory used: {m.memory_used_count} {m.memory_used_size} ({float(m.malloc_size-m.memory_used_size)/float(m.memory_used_count):.1f} average slack) atoms: {m.atom_count} {m.atom_size} ({float(m.atom_size)/float(m.atom_count):.1f}/atom) diff --git a/src/js/regex.nim b/src/js/regex.nim index d7371428..157e1fbc 100644 --- a/src/js/regex.nim +++ b/src/js/regex.nim @@ -2,7 +2,6 @@ import bindings/libregexp import bindings/quickjs -import js/javascript import utils/opt import utils/twtstr @@ -30,8 +29,8 @@ type rule: string global: bool -var dummyRuntime = newJSRuntime() -var dummyContext = dummyRuntime.newJSContextRaw() +var dummyRuntime = JS_NewRuntime() +var dummyContext = JS_NewContextRaw(dummyRuntime) when NimMajor >= 2: proc `=destroy`*(regex: Regex) = diff --git a/todo b/todo index bdb1ee84..d3e92ed7 100644 --- a/todo +++ b/todo @@ -63,7 +63,6 @@ external: - save buffer (source, output) - edit buffer (local file, or whatever we downloaded) javascript: -- important: check where to use defineProperty and setProperty - important: callbacks leak memory, I think. fix this (e.g. have a ref JSCallback or something) - add support for JS mixins |