about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--src/js/javascript.nim4
-rw-r--r--src/js/tojs.nim7
2 files changed, 4 insertions, 7 deletions
diff --git a/src/js/javascript.nim b/src/js/javascript.nim
index 44c7ef06..57baff45 100644
--- a/src/js/javascript.nim
+++ b/src/js/javascript.nim
@@ -548,8 +548,6 @@ template fromJS_or_return*(t, ctx, val: untyped): untyped =
   (
     let x = fromJS[t](ctx, val)
     if x.isErr:
-      if x.error == nil:
-        return JS_EXCEPTION
       return toJS(ctx, x.error)
     x.get
   )
@@ -558,8 +556,6 @@ template fromJSP_or_return*(t, ctx, val: untyped): untyped =
   (
     let x = fromJSP[t](ctx, val)
     if x.isErr:
-      if x.error == nil:
-        return JS_EXCEPTION
       return toJS(ctx, x.error)
     x.get
   )
diff --git a/src/js/tojs.nim b/src/js/tojs.nim
index ea6f35f2..bf2af7cc 100644
--- a/src/js/tojs.nim
+++ b/src/js/tojs.nim
@@ -210,9 +210,8 @@ proc toJS[T, E](ctx: JSContext; opt: Result[T, E]): JSValue =
       return JS_UNDEFINED
   else:
     when not (E is void):
-      let res = toJS(ctx, opt.error)
-      if not JS_IsNull(res):
-        return JS_Throw(ctx, res)
+      if opt.error != nil:
+        return JS_Throw(ctx, toJS(ctx, opt.error))
     return JS_EXCEPTION
 
 proc toJS(ctx: JSContext; s: seq): JSValue =
@@ -376,6 +375,8 @@ proc toJS[T, E](ctx: JSContext; promise: Promise[Result[T, E]]): JSValue =
   return jsPromise
 
 proc toJS*(ctx: JSContext; err: JSError): JSValue =
+  if err == nil:
+    return JS_EXCEPTION
   if err.e notin QuickJSErrors:
     return toJSRefObj(ctx, err)
   var msg = toJS(ctx, err.message)