diff options
author | 2023-01-23 15:08:27 -0800 | |
---|---|---|
committer | 2023-01-23 15:09:18 -0800 | |
commit | aa456805ddc9fd44152d73888ecb8733b60f34b9 (patch) | |
tree | a171dc0871fa39ecfbc5444e4173a77ff2453a1d /src/bun.js/bindings/napi.cpp | |
parent | efd33c398f2bf16ef865b5b04df4d40b13ed24a4 (diff) | |
download | bun-aa456805ddc9fd44152d73888ecb8733b60f34b9.tar.gz bun-aa456805ddc9fd44152d73888ecb8733b60f34b9.tar.zst bun-aa456805ddc9fd44152d73888ecb8733b60f34b9.zip |
[napi] Handle missing description in `napi_create_symbol`
Diffstat (limited to 'src/bun.js/bindings/napi.cpp')
-rw-r--r-- | src/bun.js/bindings/napi.cpp | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/bun.js/bindings/napi.cpp b/src/bun.js/bindings/napi.cpp index 24541755f..db70ad1ca 100644 --- a/src/bun.js/bindings/napi.cpp +++ b/src/bun.js/bindings/napi.cpp @@ -1602,6 +1602,37 @@ extern "C" napi_status napi_create_bigint_words(napi_env env, return napi_ok; } +extern "C" napi_status napi_create_symbol(napi_env env, napi_value description, + napi_value* result) +{ + Zig::GlobalObject* globalObject = toJS(env); + JSC::VM& vm = globalObject->vm(); + + if (UNLIKELY(result == nullptr || globalObject == nullptr)) { + return napi_invalid_arg; + } + + JSC::JSValue descriptionValue = toJS(description); + if (descriptionValue && !descriptionValue.isUndefinedOrNull()) { + if (!descriptionValue.isString()) { + return napi_string_expected; + } + + JSC::JSString* descriptionString = descriptionValue.toStringOrNull(globalObject); + if (UNLIKELY(!descriptionString)) { + return napi_generic_failure; + } + + if (descriptionString->length() > 0) { + *result = toNapi(JSC::Symbol::createWithDescription(vm, descriptionString->value(globalObject))); + return napi_ok; + } + } + + *result = toNapi(JSC::Symbol::create(vm)); + return napi_ok; +} + extern "C" napi_status napi_call_function(napi_env env, napi_value recv_napi, napi_value func_napi, size_t argc, const napi_value* argv, |