diff options
author | 2022-12-15 17:31:18 -0800 | |
---|---|---|
committer | 2022-12-15 17:31:18 -0800 | |
commit | 3ea983578f4f9ec0544697852e617ddcdb585783 (patch) | |
tree | 2e4c1acf13ffcc590813e308b6cef53f2bca2483 /src/bun.js/bindings/Process.cpp | |
parent | 000a0c9dcac3b4fae73fde60fab4d78a4e15e849 (diff) | |
download | bun-3ea983578f4f9ec0544697852e617ddcdb585783.tar.gz bun-3ea983578f4f9ec0544697852e617ddcdb585783.tar.zst bun-3ea983578f4f9ec0544697852e617ddcdb585783.zip |
[node:process] Implement `process.argv0`, `process.execPath`
Fixes https://github.com/oven-sh/bun/issues/1599
Diffstat (limited to 'src/bun.js/bindings/Process.cpp')
-rw-r--r-- | src/bun.js/bindings/Process.cpp | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/bun.js/bindings/Process.cpp b/src/bun.js/bindings/Process.cpp index a72990ed8..f7110767b 100644 --- a/src/bun.js/bindings/Process.cpp +++ b/src/bun.js/bindings/Process.cpp @@ -495,6 +495,30 @@ JSC_DEFINE_HOST_FUNCTION(Process_functionAbort, (JSGlobalObject * globalObject, __builtin_unreachable(); } +JSC_DEFINE_CUSTOM_GETTER(Process_lazyArgv0Getter, (JSC::JSGlobalObject * globalObject, JSC::EncodedJSValue thisValue, JSC::PropertyName name)) +{ + JSC::JSObject* thisObject = JSValue::decode(thisValue).getObject(); + EncodedJSValue ret = Bun__Process__getArgv0(globalObject); + + if (LIKELY(thisObject)) { + thisObject->putDirect(globalObject->vm(), name, JSValue::decode(ret), 0); + } + + return ret; +} + +JSC_DEFINE_CUSTOM_GETTER(Process_lazyExecPathGetter, (JSC::JSGlobalObject * globalObject, JSC::EncodedJSValue thisValue, JSC::PropertyName name)) +{ + JSC::JSObject* thisObject = JSValue::decode(thisValue).getObject(); + EncodedJSValue ret = Bun__Process__getExecPath(globalObject); + + if (LIKELY(thisObject)) { + thisObject->putDirect(globalObject->vm(), name, JSValue::decode(ret), 0); + } + + return ret; +} + void Process::finishCreation(JSC::VM& vm) { Base::finishCreation(vm); @@ -607,6 +631,12 @@ void Process::finishCreation(JSC::VM& vm) this->putDirectNativeFunction(vm, globalObject, JSC::Identifier::fromString(this->vm(), "abort"_s), 0, Process_functionAbort, ImplementationVisibility::Public, NoIntrinsic, 0); + + this->putDirectCustomAccessor(vm, JSC::PropertyName(JSC::Identifier::fromString(vm, "argv0"_s)), + JSC::CustomGetterSetter::create(vm, Process_lazyArgv0Getter, Process_defaultSetter), 0); + + this->putDirectCustomAccessor(vm, JSC::PropertyName(JSC::Identifier::fromString(vm, "execPath"_s)), + JSC::CustomGetterSetter::create(vm, Process_lazyExecPathGetter, Process_defaultSetter), 0); } const JSC::ClassInfo Process::s_info = { "Process"_s, &Base::s_info, nullptr, nullptr, |