aboutsummaryrefslogtreecommitdiff
path: root/src/bun.js/bindings/Process.cpp
diff options
context:
space:
mode:
authorGravatar Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> 2022-12-15 17:31:18 -0800
committerGravatar Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> 2022-12-15 17:31:18 -0800
commit3ea983578f4f9ec0544697852e617ddcdb585783 (patch)
tree2e4c1acf13ffcc590813e308b6cef53f2bca2483 /src/bun.js/bindings/Process.cpp
parent000a0c9dcac3b4fae73fde60fab4d78a4e15e849 (diff)
downloadbun-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.cpp30
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,