mirror of
https://github.com/oven-sh/bun
synced 2026-02-14 04:49:06 +00:00
* 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 commitca835b726f. * Revert "avoid duplicate symbols" This reverts commit4ac6ca8700. * 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>
244 lines
8.0 KiB
C++
244 lines
8.0 KiB
C++
#include "root.h"
|
|
|
|
#include "helpers.h"
|
|
|
|
#include "ZigSourceProvider.h"
|
|
|
|
#include <JavaScriptCore/BytecodeCacheError.h>
|
|
#include "ZigGlobalObject.h"
|
|
|
|
#include <JavaScriptCore/Completion.h>
|
|
#include <wtf/Scope.h>
|
|
#include <wtf/text/StringHash.h>
|
|
#include <sys/stat.h>
|
|
|
|
extern "C" void RefString__free(void*, void*, unsigned);
|
|
|
|
namespace Zig {
|
|
|
|
using Base = JSC::SourceProvider;
|
|
using BytecodeCacheGenerator = JSC::BytecodeCacheGenerator;
|
|
using UnlinkedFunctionExecutable = JSC::UnlinkedFunctionExecutable;
|
|
using CachedBytecode = JSC::CachedBytecode;
|
|
using UnlinkedFunctionCodeBlock = JSC::UnlinkedFunctionCodeBlock;
|
|
using SourceCode = JSC::SourceCode;
|
|
using CodeSpecializationKind = JSC::CodeSpecializationKind;
|
|
using SourceOrigin = JSC::SourceOrigin;
|
|
using String = WTF::String;
|
|
using SourceProviderSourceType = JSC::SourceProviderSourceType;
|
|
|
|
static uintptr_t getSourceProviderMapKey(ResolvedSource& resolvedSource)
|
|
{
|
|
switch (resolvedSource.source_code.tag) {
|
|
case BunStringTag::WTFStringImpl: {
|
|
return (uintptr_t)resolvedSource.source_code.impl.wtf->characters8();
|
|
}
|
|
case BunStringTag::StaticZigString:
|
|
case BunStringTag::ZigString: {
|
|
return (uintptr_t)Zig::untag(resolvedSource.source_code.impl.zig.ptr);
|
|
}
|
|
default: {
|
|
return 0;
|
|
}
|
|
}
|
|
}
|
|
|
|
static SourceOrigin toSourceOrigin(const String& sourceURL, bool isBuiltin)
|
|
{
|
|
if (isBuiltin) {
|
|
if (sourceURL.startsWith("node:"_s)) {
|
|
return SourceOrigin(WTF::URL(makeString("builtin://node/", sourceURL.substring(5))));
|
|
} else if (sourceURL.startsWith("bun:"_s)) {
|
|
return SourceOrigin(WTF::URL(makeString("builtin://bun/", sourceURL.substring(4))));
|
|
} else {
|
|
return SourceOrigin(WTF::URL(makeString("builtin://", sourceURL)));
|
|
}
|
|
}
|
|
|
|
return SourceOrigin(WTF::URL::fileURLWithFileSystemPath(sourceURL));
|
|
}
|
|
|
|
void forEachSourceProvider(const WTF::Function<void(JSC::SourceID)>& func)
|
|
{
|
|
// if (sourceProviderMap == nullptr) {
|
|
// return;
|
|
// }
|
|
|
|
// for (auto& pair : *sourceProviderMap) {
|
|
// auto sourceProvider = pair.value;
|
|
// if (sourceProvider) {
|
|
// func(sourceProvider);
|
|
// }
|
|
// }
|
|
}
|
|
extern "C" int ByteRangeMapping__getSourceID(void* mappings, BunString sourceURL);
|
|
extern "C" void* ByteRangeMapping__find(BunString sourceURL);
|
|
void* sourceMappingForSourceURL(const WTF::String& sourceURL)
|
|
{
|
|
return ByteRangeMapping__find(Bun::toString(sourceURL));
|
|
}
|
|
|
|
extern "C" void ByteRangeMapping__generate(BunString sourceURL, BunString code, int sourceID);
|
|
|
|
JSC::SourceID sourceIDForSourceURL(const WTF::String& sourceURL)
|
|
{
|
|
void* mappings = ByteRangeMapping__find(Bun::toString(sourceURL));
|
|
if (!mappings) {
|
|
return 0;
|
|
}
|
|
|
|
return ByteRangeMapping__getSourceID(mappings, Bun::toString(sourceURL));
|
|
}
|
|
|
|
extern "C" bool BunTest__shouldGenerateCodeCoverage(BunString sourceURL);
|
|
|
|
Ref<SourceProvider> SourceProvider::create(Zig::GlobalObject* globalObject, ResolvedSource resolvedSource, JSC::SourceProviderSourceType sourceType, bool isBuiltin)
|
|
{
|
|
|
|
auto stringImpl = Bun::toWTFString(resolvedSource.source_code);
|
|
auto sourceURLString = toStringCopy(resolvedSource.source_url);
|
|
bool isCodeCoverageEnabled = !!globalObject->vm().controlFlowProfiler();
|
|
|
|
bool shouldGenerateCodeCoverage = isCodeCoverageEnabled && !isBuiltin && BunTest__shouldGenerateCodeCoverage(Bun::toString(sourceURLString));
|
|
|
|
auto provider = adoptRef(*new SourceProvider(
|
|
globalObject->isThreadLocalDefaultGlobalObject ? globalObject : nullptr,
|
|
resolvedSource, stringImpl.releaseImpl().releaseNonNull(),
|
|
JSC::SourceTaintedOrigin::Untainted,
|
|
toSourceOrigin(sourceURLString, isBuiltin),
|
|
sourceURLString.impl(), TextPosition(),
|
|
sourceType));
|
|
|
|
if (shouldGenerateCodeCoverage) {
|
|
ByteRangeMapping__generate(Bun::toString(provider->sourceURL()), Bun::toString(provider->source().toStringWithoutCopying()), provider->asID());
|
|
}
|
|
|
|
return provider;
|
|
}
|
|
|
|
unsigned SourceProvider::hash() const
|
|
{
|
|
if (m_hash) {
|
|
return m_hash;
|
|
}
|
|
|
|
return m_source->hash();
|
|
}
|
|
|
|
void SourceProvider::freeSourceCode()
|
|
{
|
|
}
|
|
|
|
void SourceProvider::updateCache(const UnlinkedFunctionExecutable* executable, const SourceCode&,
|
|
CodeSpecializationKind kind,
|
|
const UnlinkedFunctionCodeBlock* codeBlock)
|
|
{
|
|
// if (!m_resolvedSource.bytecodecache_fd || !m_cachedBytecode)
|
|
return;
|
|
|
|
JSC::BytecodeCacheError error;
|
|
RefPtr<JSC::CachedBytecode> cachedBytecode = JSC::encodeFunctionCodeBlock(executable->vm(), codeBlock, error);
|
|
if (cachedBytecode && !error.isValid())
|
|
m_cachedBytecode->addFunctionUpdate(executable, kind, *cachedBytecode);
|
|
}
|
|
|
|
void SourceProvider::cacheBytecode(const BytecodeCacheGenerator& generator)
|
|
{
|
|
// if (!m_resolvedSource.bytecodecache_fd)
|
|
return;
|
|
|
|
if (!m_cachedBytecode)
|
|
m_cachedBytecode = JSC::CachedBytecode::create();
|
|
auto update = generator();
|
|
if (update)
|
|
m_cachedBytecode->addGlobalUpdate(*update);
|
|
}
|
|
void SourceProvider::commitCachedBytecode()
|
|
{
|
|
// if (!m_resolvedSource.bytecodecache_fd || !m_cachedBytecode || !m_cachedBytecode->hasUpdates())
|
|
return;
|
|
|
|
// auto clearBytecode = WTF::makeScopeExit([&] { m_cachedBytecode = nullptr; });
|
|
// const auto fd = m_resolvedSource.bytecodecache_fd;
|
|
|
|
// auto fileSize = FileSystem::fileSize(fd);
|
|
// if (!fileSize)
|
|
// return;
|
|
|
|
// size_t cacheFileSize;
|
|
// if (!WTF::convertSafely(*fileSize, cacheFileSize) || cacheFileSize != m_cachedBytecode->size()) {
|
|
// // The bytecode cache has already been updated
|
|
// return;
|
|
// }
|
|
|
|
// if (!FileSystem::truncateFile(fd, m_cachedBytecode->sizeForUpdate()))
|
|
// return;
|
|
|
|
// m_cachedBytecode->commitUpdates([&](off_t offset, const void* data, size_t size) {
|
|
// long long result = FileSystem::seekFile(fd, offset, FileSystem::FileSeekOrigin::Beginning);
|
|
// ASSERT_UNUSED(result, result != -1);
|
|
// size_t bytesWritten = static_cast<size_t>(FileSystem::writeToFile(fd, data, size));
|
|
// ASSERT_UNUSED(bytesWritten, bytesWritten == size);
|
|
// });
|
|
}
|
|
|
|
bool SourceProvider::isBytecodeCacheEnabled() const
|
|
{
|
|
// return m_resolvedSource.bytecodecache_fd > 0;
|
|
return false;
|
|
}
|
|
|
|
void SourceProvider::readOrGenerateByteCodeCache(JSC::VM& vm, const JSC::SourceCode& sourceCode)
|
|
{
|
|
// auto status = this->readCache(vm, sourceCode);
|
|
// switch (status) {
|
|
// case -1: {
|
|
// m_resolvedSource.bytecodecache_fd = 0;
|
|
// break;
|
|
// }
|
|
// case 0: {
|
|
// JSC::BytecodeCacheError err;
|
|
// m_cachedBytecode = JSC::generateModuleBytecode(vm, sourceCode, m_resolvedSource.bytecodecache_fd, err);
|
|
|
|
// if (err.isValid()) {
|
|
// m_resolvedSource.bytecodecache_fd = 0;
|
|
// m_cachedBytecode = JSC::CachedBytecode::create();
|
|
// }
|
|
// }
|
|
// // TODO: read the bytecode into a JSC::SourceCode object here
|
|
// case 1: {
|
|
// }
|
|
// }
|
|
}
|
|
int SourceProvider::readCache(JSC::VM& vm, const JSC::SourceCode& sourceCode)
|
|
{
|
|
return -1;
|
|
// if (m_resolvedSource.bytecodecache_fd == 0)
|
|
// return -1;
|
|
// if (!FileSystem::isHandleValid(m_resolvedSource.bytecodecache_fd))
|
|
// return -1;
|
|
// const auto fd = m_resolvedSource.bytecodecache_fd;
|
|
|
|
// bool success;
|
|
// FileSystem::MappedFileData mappedFile(fd, FileSystem::MappedFileMode::Shared, success);
|
|
// if (!success)
|
|
// return -1;
|
|
|
|
// const uint8_t* fileData = reinterpret_cast<const uint8_t*>(mappedFile.data());
|
|
// unsigned fileTotalSize = mappedFile.size();
|
|
// if (fileTotalSize == 0)
|
|
// return 0;
|
|
|
|
// Ref<JSC::CachedBytecode> cachedBytecode = JSC::CachedBytecode::create(WTFMove(mappedFile));
|
|
// // auto key = JSC::sourceCodeKeyForSerializedModule(vm, sourceCode);
|
|
// // if (isCachedBytecodeStillValid(vm, cachedBytecode.copyRef(), key,
|
|
// // JSC::SourceCodeType::ModuleType)) {
|
|
// m_cachedBytecode = WTFMove(cachedBytecode);
|
|
// return 1;
|
|
// } else {
|
|
// FileSystem::truncateFile(fd, 0);
|
|
// return 0;
|
|
// }
|
|
}
|
|
}; // namespace Zig
|