diff options
author | 2023-08-14 20:28:18 -0700 | |
---|---|---|
committer | 2023-08-14 20:28:18 -0700 | |
commit | 47450ed12ccfe1d76ca527ea95f602e6ba089dce (patch) | |
tree | 368c60eef582b23bfda36c90c98605904aea9bb8 /src/js/_codegen | |
parent | eab7b4c3ea3c42eb391293f4cfa7f8e01a6b43ac (diff) | |
download | bun-47450ed12ccfe1d76ca527ea95f602e6ba089dce.tar.gz bun-47450ed12ccfe1d76ca527ea95f602e6ba089dce.tar.zst bun-47450ed12ccfe1d76ca527ea95f602e6ba089dce.zip |
Make builtins' source origin use a valid url (#4152)
* Make source origin use a valid url
* disable minifyWhiteSpace
* the change
Diffstat (limited to 'src/js/_codegen')
-rw-r--r-- | src/js/_codegen/build-modules.ts | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/src/js/_codegen/build-modules.ts b/src/js/_codegen/build-modules.ts index f18bee033..63e61d60a 100644 --- a/src/js/_codegen/build-modules.ts +++ b/src/js/_codegen/build-modules.ts @@ -136,7 +136,8 @@ mark("Preprocess modules"); const config = ({ platform, debug }: { platform: string; debug?: boolean }) => ({ entrypoints: bundledEntryPoints, - minify: { syntax: true, whitespace: !debug }, + // Whitespace and identifiers are not minified to give better error messages when an error happens in our builtins + minify: { syntax: true, whitespace: false }, root: TMP, define: { IS_BUN_DEVELOPMENT: String(!!debug), @@ -250,7 +251,8 @@ fs.writeFileSync( // This code slice is used in InternalModuleRegistry.cpp. It defines the loading function for modules. fs.writeFileSync( path.join(BASE, "out/InternalModuleRegistry+createInternalModuleById.h"), - `JSValue InternalModuleRegistry::createInternalModuleById(JSGlobalObject* globalObject, VM& vm, Field id) + `// clang-format off +JSValue InternalModuleRegistry::createInternalModuleById(JSGlobalObject* globalObject, VM& vm, Field id) { switch (id) { // JS internal modules @@ -259,7 +261,9 @@ fs.writeFileSync( return `case Field::${idToEnumName(id)}: { INTERNAL_MODULE_REGISTRY_GENERATE(globalObject, vm, "${idToPublicSpecifierOrEnumName(id)}"_s, ${JSON.stringify( id.replace(/\.[mc]?[tj]s$/, ".js"), - )}_s, InternalModuleRegistryConstants::${idToEnumName(id)}Code); + )}_s, InternalModuleRegistryConstants::${idToEnumName(id)}Code, "builtin://${id + .replace(/\.[mc]?[tj]s$/, "") + .replace(/[^a-zA-Z0-9]+/g, "/")}"_s); }`; }) .join("\n ")} @@ -272,12 +276,13 @@ fs.writeFileSync( // It inlines all the strings for the module IDs. fs.writeFileSync( path.join(BASE, "out/InternalModuleRegistryConstants.h"), - `#pragma once + `// clang-format off +#pragma once - namespace Bun { - namespace InternalModuleRegistryConstants { +namespace Bun { +namespace InternalModuleRegistryConstants { - #if __APPLE__ +#if __APPLE__ ${moduleList .map( (id, n) => @@ -308,10 +313,10 @@ static constexpr ASCIILiteral ${idToEnumName(id)}Code = ${fmtCPPString(bundledOu `, ) .join("\n")} - #endif +#endif - } - }`, +} +}`, ); // This is a generated enum for zig code (exports.zig) |