From 0ca42e81f31d31270c44f81d88fff33361817720 Mon Sep 17 00:00:00 2001 From: Jarred Sumner Date: Sat, 3 Sep 2022 03:57:43 -0700 Subject: Plugin API (#1199) * Plugin API * Fix the bugs * Implement `"object"` loader Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> --- src/bun.js/modules/ObjectModule.h | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 src/bun.js/modules/ObjectModule.h (limited to 'src/bun.js/modules/ObjectModule.h') diff --git a/src/bun.js/modules/ObjectModule.h b/src/bun.js/modules/ObjectModule.h new file mode 100644 index 000000000..42ab4dfa5 --- /dev/null +++ b/src/bun.js/modules/ObjectModule.h @@ -0,0 +1,32 @@ +#include "../bindings/ZigGlobalObject.h" +#include "JavaScriptCore/JSGlobalObject.h" + +namespace Zig { +JSC::SyntheticSourceProvider::SyntheticSourceGenerator +generateObjectModuleSourceCode(JSC::JSGlobalObject *globalObject, + JSC::JSObject *object) { + JSC::VM &vm = globalObject->vm(); + + return [strongObject = JSC::Strong(vm, object)]( + JSC::JSGlobalObject *lexicalGlobalObject, + JSC::Identifier moduleKey, Vector &exportNames, + JSC::MarkedArgumentBuffer &exportValues) -> void { + JSC::VM &vm = lexicalGlobalObject->vm(); + GlobalObject *globalObject = + reinterpret_cast(lexicalGlobalObject); + JSC::JSObject *object = strongObject.get(); + + PropertyNameArray properties(vm, PropertyNameMode::Strings, + PrivateSymbolMode::Exclude); + object->getPropertyNames(globalObject, properties, + DontEnumPropertiesMode::Exclude); + + for (auto &entry : properties) { + exportNames.append(entry); + exportValues.append(object->get(globalObject, entry)); + } + strongObject.clear(); + }; +} + +} // namespace Zig \ No newline at end of file -- cgit v1.2.3