about summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
authorbptato <nincsnevem662@gmail.com>2024-01-07 17:28:54 +0100
committerbptato <nincsnevem662@gmail.com>2024-01-07 17:28:54 +0100
commit22f127b1124608dc7bcc13165e382bfbaa803764 (patch)
tree109174c002862bf8028b4b941b89028b56de62c1 /src
parent5ef6b29a1a22b6dad19027b2a1193f0f81ce1be2 (diff)
downloadchawan-22f127b1124608dc7bcc13165e382bfbaa803764.tar.gz
tojs: document + remove unused JSCFunction converter
Diffstat (limited to 'src')
-rw-r--r--src/js/tojs.nim48
1 files changed, 41 insertions, 7 deletions
diff --git a/src/js/tojs.nim b/src/js/tojs.nim
index 60e77d77..91b1128e 100644
--- a/src/js/tojs.nim
+++ b/src/js/tojs.nim
@@ -1,6 +1,44 @@
-import options
-import tables
-import unicode
+# Automatic conversion of Nim types to JavaScript types.
+#
+# Every conversion involves copying unless explicitly noted below.
+#
+# * Primitives are converted to their respective JavaScript counterparts.
+# * seq is converted to a JS array. Note: this always copies the seq's contents.
+# * Promise is converted to a JS promise which will be resolved when the Nim
+#   promise is resolved.
+# * enum is converted to its stringifier's output.
+# * JSValue is returned as-is, *without* a DupValue operation.
+# * JSError is converted to a new error object corresponding to the error
+#   it represents.
+# * JSArrayBuffer, JSUint8Array are converted to a JS object without copying
+#   their contents.
+# * NarrowString is converted to a JS narrow string (with copying). For more
+#   information on JS string handling, see js/strings.nim.
+# * Finally, ref object is converted to a JS object whose opaque is the ref
+#   object. (See below.)
+#
+# Note that ref objects can be seamlessly converted to JS objects, despite
+# the fact that they are managed by two separate garbage collectors. This
+# works thanks to a patch in QJS and machine oil. Basically:
+#
+# * Nim objects registered with registerType can be paired with one (1)
+#   JS object each.
+# * This happens on-demand, whenever the Nim object has to be converted into JS.
+# * Once the conversion happened, the JS object will be kept alive until the
+#   Nim object is destroyed, so that JS properties on the JS object are not
+#   lost during a re-conversion.
+# * Similarly, the Nim object is kept alive so long as the JS object is alive.
+# * The patched in can_destroy hook is used to synchronize reference counts
+#   of the two objects; this way, no memory leak occurs.
+#
+# There are also toJSP variants of object converters. These work identically
+# to ref object converters, except the reference count of the closest
+# `ref object' ancestor is incremented/decremented when synchronizing refcounts
+# with the JS object pair.
+
+import std/options
+import std/tables
+import std/unicode
 
 import bindings/quickjs
 import io/promise
@@ -36,7 +74,6 @@ proc toJS*[T, E](ctx: JSContext, promise: Promise[Result[T, E]]): JSValue
 proc toJS*(ctx: JSContext, promise: EmptyPromise): JSValue
 proc toJS*(ctx: JSContext, obj: ref object): JSValue
 proc toJS*(ctx: JSContext, err: JSError): JSValue
-proc toJS*(ctx: JSContext, f: JSCFunction): JSValue
 proc toJS*(ctx: JSContext, abuf: JSArrayBuffer): JSValue
 proc toJS*(ctx: JSContext, u8a: JSUint8Array): JSValue
 proc toJS*(ctx: JSContext, ns: NarrowString): JSValue
@@ -308,9 +345,6 @@ proc toJS*(ctx: JSContext, err: JSError): JSValue =
   JS_FreeValue(ctx, msg)
   return ret
 
-proc toJS*(ctx: JSContext, f: JSCFunction): JSValue =
-  return JS_NewCFunction(ctx, f, cstring"", 0)
-
 proc toJS*(ctx: JSContext, abuf: JSArrayBuffer): JSValue =
   return JS_NewArrayBuffer(ctx, abuf.p, abuf.len, abuf.dealloc, nil, false)