Files
bun.sh/src/bun.js/bindings/BunInjectedScriptHost.cpp
Jarred Sumner 7485c7c7cb feat: Windows + CMake Build System (#4410)
* Prepare for windows event loop

* More progress

* Update libuv.zig

* wip

* Make compiling each dependency a shell script

* Bump mimalloc

* Add the build scripts

* Update settings.json

* Fix a bunch of compiler warnings

* Remove more warnings

* more warnings

* cmake works

* Update JSSQLStatement.h

* put it in the zig file

* Fix usockets warnings

* Fixup

* Fix one of the compiler errors

* chunk

* draw the rest of the owl

* theres more

* Rename Process -> BunProcess

Works around a Windows issue

* Add musl polyfill for memmem on Windows

* More

* 12 mb

* Fix getenvZ

* fix variosu issues

* Add fast-ish path for bun install on Windows

* Update windows.zig

* Update windows.zig

* Fix build issue

* it works

* hmmm

* Rename file

* Fixups

* Update wtf-bindings.cpp

* Update src/bun.js/bindings/headers-handwritten.h

Co-authored-by: Dylan Conway <35280289+dylan-conway@users.noreply.github.com>

* further!

* more

* Update .gitignore

* hm

* quite a lot of fixes

* Update CMakeLists.txt

* zig fmt

* Many more things are starting to work.

* reb

* regenaret

* Update JSSink.h

* fixup

* fetch works

* Bun.serve() and much of the event loop works now

* Make require() work

* bun install progress

* more things work

* use less std.os

* Fixes

* small fixes

* Bump

* Bummp

* Undo that change

* We have to bump the version of Debian because libarchive has a higher minimum requirement

* ok

* some clenaup

* windows

* Update bun.zig

* fixup

* avoid duplicate symbols

* avoid undefined symbols

* bump

* Remove issue template for install

It's not used, and use the bug issue instead.

* Add types for cp and cpSync

* Add types for watchFile and unwatchFile

* Add bun-types to 'bun fmt' script

* Update nodejs compat docs cp/cpSync/watchFile/unwatchFile (#4525)

* feat(fetch) rejectUnauthorized and checkServerIdentity (#4514)

* enable root certs on fetch

* rebase

* fix lookup

* some fixes and improvements

* fmt

* more fixes

* more fixes

* check detached onHandshake

* fix promise case

* fix cert non-Native

* add fetch tls tests

* more one test

* churn

* Update feature_flags.zig

* Update response.zig

* Revert "avoid undefined symbols"

This reverts commit ca835b726f.

* Revert "avoid duplicate symbols"

This reverts commit 4ac6ca8700.

* Update feature_flags.zig

* Set permissions

* more

* Update mimalloc

* Fix sqlite test failures

* Fix some test failures

* Make sure we remove libusockets is removed

* hm

* [dave]: fix webcrypto crash

* bump

* Update index.ts

* windows zig compiles

* cmake on mac works

* progress

* yay

* bun run build

* fix

* ok

* oops

* asdfasfdafdsafda

* fghjkl

* git ignore

* wow

* Process -> BunProcess

* hmm

* blah

* finalize merge

* now it only has linker errors on mac

* sdfadsf

* g

* getting farther

* sxdcvbnmk,

* adfhjskfjdhkas

* a

* fgh

* update build dot zig

* asdfg

* theoretical -DCANARY flag we can use

* asdf

* cool

* okay

* colorterm

* New build workflow

* Fix script

* Use sudo

* More sudo

* Tweak dependencies

* Another sudo attempt

* Tweak script

* 16.0 -> 16

* Tweak script

* Tweak script

* Tweak script

* Tweak script

* Tweak script

* bun install

* ssh into github actions

* add more to ssh

* Fix postinstal

* Skip llvm

* New dockerfile

* Build

* More changes to Dockerfile

* chaos chaos chaos

* okay

* a

* more cmake nonsense

* add unified sources code (does not work)

* stuff

* prepare for CI builds

* ok

* yay

* yeah

* make this more stable simply by trying again if it fails, 5 times, then lose. it fixes the stability issue i was running into L O L

* messing with ci

* x

* a

* clean dependencies before build

* oops

* this is not going to work but its closer

* not gonna work either

* a

* a

* did i do it

* a

* a

* work around weird fs+Bun.build issues

* properly pass debug flag correctly

* idk im sorry

* lose

* maybe

* run the tests please

* a

* fix zlib script

* a

* hi

* prevent stupid ci issue

* i totally didnt leave in a syntax error on cmakelists

* a

* lol

* relax

* 😭

* a

* SO SILLY

* 😡 one line mistake

* one character diff

* fix linking symbols missing

* work on dependency scripts

* does this work now?

* fix mac build

* a

* bump!

* woops

* add macos baseline build

* .

* fix sqlite and also enable $assert/$debug support in builtin functions

* okay

* oops

* zig upgrade lol

* Merge

* Fix spawn test issue

* Set a timeout

* yeah

* etc

* mi

---------

Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com>
Co-authored-by: Dylan Conway <dylan.conway567@gmail.com>
Co-authored-by: Dylan Conway <35280289+dylan-conway@users.noreply.github.com>
Co-authored-by: Ashcon Partovi <ashcon@partovi.net>
Co-authored-by: Birk Skyum <74932975+birkskyum@users.noreply.github.com>
Co-authored-by: dave caruso <me@paperdave.net>
2023-10-27 01:51:56 -07:00

211 lines
8.0 KiB
C++

#include "root.h"
#include "BunInjectedScriptHost.h"
#include "ZigGeneratedClasses.h"
#include "DOMException.h"
#include "JSDOMException.h"
#include "JSEventListener.h"
#include "JSEventTarget.h"
#include "JSWorker.h"
#include <JavaScriptCore/ObjectConstructor.h>
#include "JSFetchHeaders.h"
#include "JSURLSearchParams.h"
#include "JSDOMFormData.h"
#include <JavaScriptCore/JSCallbackObject.h>
namespace Bun {
using namespace JSC;
using namespace WebCore;
JSValue BunInjectedScriptHost::subtype(JSGlobalObject* exec, JSValue value)
{
VM& vm = exec->vm();
if (
value.inherits<JSDOMException>() || value.inherits<JSResolveMessage>() || value.inherits<JSBuildMessage>())
return jsNontrivialString(vm, "error"_s);
return jsUndefined();
}
static JSObject* constructInternalProperty(VM& vm, JSGlobalObject* exec, const String& name, JSValue value)
{
auto* object = constructEmptyObject(exec);
object->putDirect(vm, Identifier::fromString(vm, "name"_s), jsString(vm, name));
object->putDirect(vm, Identifier::fromString(vm, "value"_s), value);
return object;
}
static JSObject* constructInternalProperty(VM& vm, JSGlobalObject* exec, Identifier name, JSValue value)
{
auto* object = constructEmptyObject(exec);
object->putDirect(vm, Identifier::fromString(vm, "name"_s), JSC::identifierToJSValue(vm, name));
object->putDirect(vm, Identifier::fromString(vm, "value"_s), value);
return object;
}
static JSObject* objectForEventTargetListeners(VM& vm, JSGlobalObject* exec, EventTarget* eventTarget)
{
auto* scriptExecutionContext = eventTarget->scriptExecutionContext();
if (!scriptExecutionContext)
return nullptr;
JSObject* listeners = nullptr;
for (auto& eventType : eventTarget->eventTypes()) {
unsigned listenersForEventIndex = 0;
auto* listenersForEvent = constructEmptyArray(exec, nullptr);
for (auto& eventListener : eventTarget->eventListeners(eventType)) {
if (!is<JSEventListener>(eventListener->callback()))
continue;
auto& jsListener = downcast<JSEventListener>(eventListener->callback());
// if (jsListener.isolatedWorld() != &currentWorld(*exec))
// continue;
auto* jsFunction = jsListener.ensureJSFunction(*scriptExecutionContext);
if (!jsFunction)
continue;
auto* propertiesForListener = constructEmptyObject(exec);
propertiesForListener->putDirect(vm, Identifier::fromString(vm, "callback"_s), jsFunction);
propertiesForListener->putDirect(vm, Identifier::fromString(vm, "capture"_s), jsBoolean(eventListener->useCapture()));
propertiesForListener->putDirect(vm, Identifier::fromString(vm, "passive"_s), jsBoolean(eventListener->isPassive()));
propertiesForListener->putDirect(vm, Identifier::fromString(vm, "once"_s), jsBoolean(eventListener->isOnce()));
listenersForEvent->putDirectIndex(exec, listenersForEventIndex++, propertiesForListener);
}
if (listenersForEventIndex) {
if (!listeners)
listeners = constructEmptyObject(exec);
listeners->putDirect(vm, Identifier::fromString(vm, eventType), listenersForEvent);
}
}
return listeners;
}
static JSValue constructDataProperties(VM& vm, JSGlobalObject* exec, JSArray* array, JSValue value)
{
auto scope = DECLARE_THROW_SCOPE(vm);
if (!value.isObject())
return value;
auto* object = asObject(value);
PropertyNameArray propertyNames(vm, PropertyNameMode::Strings, PrivateSymbolMode::Exclude);
object->getPropertyNames(exec, propertyNames, DontEnumPropertiesMode::Exclude);
RETURN_IF_EXCEPTION(scope, {});
unsigned i = 0;
for (auto& propertyName : propertyNames) {
auto propertyValue = object->getDirect(vm, propertyName);
array->putDirectIndex(exec, i++, constructInternalProperty(vm, exec, propertyName, propertyValue));
RETURN_IF_EXCEPTION(scope, {});
}
RELEASE_AND_RETURN(scope, array);
}
static JSValue constructDataPropertiesSlow(VM& vm, JSGlobalObject* exec, JSArray* array, JSValue value)
{
auto scope = DECLARE_THROW_SCOPE(vm);
if (!value.isObject())
return value;
auto* object = asObject(value);
PropertyNameArray propertyNames(vm, PropertyNameMode::Strings, PrivateSymbolMode::Exclude);
object->getPropertyNames(exec, propertyNames, DontEnumPropertiesMode::Exclude);
RETURN_IF_EXCEPTION(scope, {});
unsigned i = 0;
auto catcher = DECLARE_CATCH_SCOPE(vm);
for (auto& propertyName : propertyNames) {
auto propertyValue = object->get(exec, propertyName);
if (catcher.exception()) {
catcher.clearException();
propertyValue = jsUndefined();
}
array->putDirectIndex(exec, i++, constructInternalProperty(vm, exec, propertyName, propertyValue));
RETURN_IF_EXCEPTION(scope, {});
}
RELEASE_AND_RETURN(scope, array);
}
JSValue BunInjectedScriptHost::getInternalProperties(VM& vm, JSGlobalObject* exec, JSC::JSValue value)
{
auto scope = DECLARE_THROW_SCOPE(vm);
if (auto* worker = JSWorker::toWrapped(vm, value)) {
unsigned index = 0;
auto* array = constructEmptyArray(exec, nullptr);
String name = worker->name();
if (!name.isEmpty())
array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "name"_s, jsString(vm, WTFMove(name))));
array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "terminated"_s, jsBoolean(worker->wasTerminated())));
if (auto* listeners = objectForEventTargetListeners(vm, exec, worker))
array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "listeners"_s, listeners));
RETURN_IF_EXCEPTION(scope, {});
return array;
}
if (value.isCell()) {
JSC::JSCell* cell = value.asCell();
JSC::JSType type = cell->type();
if (type == JSDOMWrapperType) {
if (auto* headers = jsDynamicCast<JSFetchHeaders*>(value)) {
auto* array = constructEmptyArray(exec, nullptr);
unsigned index = 0;
// array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "#inspect"_s, WebCore::getInternalProperties(vm, exec, headers)));
constructDataProperties(vm, exec, array, WebCore::getInternalProperties(vm, exec, headers));
RETURN_IF_EXCEPTION(scope, {});
return array;
}
if (auto* params = jsDynamicCast<JSURLSearchParams*>(value)) {
auto* array = constructEmptyArray(exec, nullptr);
unsigned index = 0;
// array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "#inspect"_s, WebCore::getInternalProperties(vm, exec, params)));
constructDataProperties(vm, exec, array, WebCore::getInternalProperties(vm, exec, params));
RETURN_IF_EXCEPTION(scope, {});
return array;
}
if (auto* formData = jsDynamicCast<JSDOMFormData*>(value)) {
unsigned index = 0;
auto* array = constructEmptyArray(exec, nullptr);
// array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "#inspect"_s, WebCore::getInternalProperties(vm, exec, formData)));
constructDataProperties(vm, exec, array, WebCore::getInternalProperties(vm, exec, formData));
RETURN_IF_EXCEPTION(scope, {});
return array;
}
}
}
if (auto* eventTarget = JSEventTarget::toWrapped(vm, value)) {
unsigned index = 0;
auto* array = constructEmptyArray(exec, nullptr);
if (auto* listeners = objectForEventTargetListeners(vm, exec, eventTarget))
array->putDirectIndex(exec, index++, constructInternalProperty(vm, exec, "listeners"_s, listeners));
RETURN_IF_EXCEPTION(scope, {});
return array;
}
return {};
}
}