diff options
Diffstat (limited to 'src/bun.js/bindings/BunString.cpp')
-rw-r--r-- | src/bun.js/bindings/BunString.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/bun.js/bindings/BunString.cpp b/src/bun.js/bindings/BunString.cpp index 5f312a28f..8c5a1e66b 100644 --- a/src/bun.js/bindings/BunString.cpp +++ b/src/bun.js/bindings/BunString.cpp @@ -50,6 +50,11 @@ JSC::JSValue toJS(JSC::JSGlobalObject* globalObject, BunString bunString) return JSValue(JSC::jsEmptyString(globalObject->vm())); } if (bunString.tag == BunStringTag::WTFStringImpl) { +#if BUN_DEBUG + if (bunString.tag == BunStringTag::WTFStringImpl) { + RELEASE_ASSERT(bunString.impl.wtf->refCount() > 0); + } +#endif return JSValue(jsString(globalObject->vm(), String(bunString.impl.wtf))); } @@ -62,6 +67,11 @@ JSC::JSValue toJS(JSC::JSGlobalObject* globalObject, BunString bunString) JSC::JSValue toJS(JSC::JSGlobalObject* globalObject, BunString bunString, size_t length) { +#if BUN_DEBUG + if (bunString.tag == BunStringTag::WTFStringImpl) { + RELEASE_ASSERT(bunString.impl.wtf->refCount() > 0); + } +#endif return jsSubstring(globalObject, jsUndefined(), Bun::toWTFString(bunString), 0, length); } @@ -79,6 +89,9 @@ WTF::String toWTFString(const BunString& bunString) } if (bunString.tag == BunStringTag::WTFStringImpl) { +#if BUN_DEBUG + RELEASE_ASSERT(bunString.impl.wtf->refCount() > 0); +#endif return WTF::String(bunString.impl.wtf); } |