diff options
author | bptato <nincsnevem662@gmail.com> | 2024-06-30 20:33:39 +0200 |
---|---|---|
committer | bptato <nincsnevem662@gmail.com> | 2024-06-30 20:33:39 +0200 |
commit | e11b25aa7e29a690dd34bb48dd14642f0b7fad62 (patch) | |
tree | ba9049f7b3c2836f6c96b88e7e56c06c20605b8b | |
parent | ed2d399f716a3a0fb9175857781b0f70b54db032 (diff) | |
download | chawan-e11b25aa7e29a690dd34bb48dd14642f0b7fad62.tar.gz |
promise, container: fix nil derefs
-rw-r--r-- | src/io/promise.nim | 38 | ||||
-rw-r--r-- | src/local/container.nim | 4 |
2 files changed, 25 insertions, 17 deletions
diff --git a/src/io/promise.nim b/src/io/promise.nim index a1a5cfc9..41ccceb4 100644 --- a/src/io/promise.nim +++ b/src/io/promise.nim @@ -221,35 +221,41 @@ proc fromJSEmptyPromise*(ctx: JSContext; val: JSValue): JSResult[EmptyPromise] = return ok(p) proc toJS*(ctx: JSContext; promise: EmptyPromise): JSValue = - var resolving_funcs: array[2, JSValue] - let jsPromise = JS_NewPromiseCapability(ctx, resolving_funcs.toJSValueArray()) + if promise == nil: + return JS_NULL + var resolvingFuncs: array[2, JSValue] + let jsPromise = JS_NewPromiseCapability(ctx, resolvingFuncs.toJSValueArray()) if JS_IsException(jsPromise): return JS_EXCEPTION promise.then(proc() = - let res = JS_Call(ctx, resolving_funcs[0], JS_UNDEFINED, 0, nil) + let res = JS_Call(ctx, resolvingFuncs[0], JS_UNDEFINED, 0, nil) JS_FreeValue(ctx, res) - JS_FreeValue(ctx, resolving_funcs[0]) - JS_FreeValue(ctx, resolving_funcs[1])) + JS_FreeValue(ctx, resolvingFuncs[0]) + JS_FreeValue(ctx, resolvingFuncs[1])) return jsPromise proc toJS*[T](ctx: JSContext; promise: Promise[T]): JSValue = - var resolving_funcs: array[2, JSValue] - let jsPromise = JS_NewPromiseCapability(ctx, resolving_funcs.toJSValueArray()) + if promise == nil: + return JS_NULL + var resolvingFuncs: array[2, JSValue] + let jsPromise = JS_NewPromiseCapability(ctx, resolvingFuncs.toJSValueArray()) if JS_IsException(jsPromise): return JS_EXCEPTION promise.then(proc(x: T) = let x = toJS(ctx, x) - let res = JS_Call(ctx, resolving_funcs[0], JS_UNDEFINED, 1, + let res = JS_Call(ctx, resolvingFuncs[0], JS_UNDEFINED, 1, x.toJSValueArray()) JS_FreeValue(ctx, res) JS_FreeValue(ctx, x) - JS_FreeValue(ctx, resolving_funcs[0]) - JS_FreeValue(ctx, resolving_funcs[1])) + JS_FreeValue(ctx, resolvingFuncs[0]) + JS_FreeValue(ctx, resolvingFuncs[1])) return jsPromise proc toJS*[T, E](ctx: JSContext; promise: Promise[Result[T, E]]): JSValue = - var resolving_funcs: array[2, JSValue] - let jsPromise = JS_NewPromiseCapability(ctx, resolving_funcs.toJSValueArray()) + if promise == nil: + return JS_NULL + var resolvingFuncs: array[2, JSValue] + let jsPromise = JS_NewPromiseCapability(ctx, resolvingFuncs.toJSValueArray()) if JS_IsException(jsPromise): return JS_EXCEPTION promise.then(proc(x: Result[T, E]) = @@ -258,7 +264,7 @@ proc toJS*[T, E](ctx: JSContext; promise: Promise[Result[T, E]]): JSValue = JS_UNDEFINED else: toJS(ctx, x.get) - let res = JS_Call(ctx, resolving_funcs[0], JS_UNDEFINED, 1, + let res = JS_Call(ctx, resolvingFuncs[0], JS_UNDEFINED, 1, x.toJSValueArray()) JS_FreeValue(ctx, res) JS_FreeValue(ctx, x) @@ -267,10 +273,10 @@ proc toJS*[T, E](ctx: JSContext; promise: Promise[Result[T, E]]): JSValue = JS_UNDEFINED else: toJS(ctx, x.error) - let res = JS_Call(ctx, resolving_funcs[1], JS_UNDEFINED, 1, + let res = JS_Call(ctx, resolvingFuncs[1], JS_UNDEFINED, 1, x.toJSValueArray()) JS_FreeValue(ctx, res) JS_FreeValue(ctx, x) - JS_FreeValue(ctx, resolving_funcs[0]) - JS_FreeValue(ctx, resolving_funcs[1])) + JS_FreeValue(ctx, resolvingFuncs[0]) + JS_FreeValue(ctx, resolvingFuncs[1])) return jsPromise diff --git a/src/local/container.nim b/src/local/container.nim index d78f9120..cc1e75e5 100644 --- a/src/local/container.nim +++ b/src/local/container.nim @@ -1602,8 +1602,10 @@ proc cursorToggleSelection(container: Container; n = 1; proc getSelectionText(container: Container; hl: Highlight = nil): Promise[string] {.jsfunc.} = if container.iface == nil: - return + return nil let hl = if hl == nil: container.currentSelection else: hl + if hl == nil: + return nil if hl.t != hltSelect: let p = newPromise[string]() p.resolve("") |