aboutsummaryrefslogtreecommitdiff
path: root/src/js/_codegen
diff options
context:
space:
mode:
authorGravatar dave caruso <me@paperdave.net> 2023-08-14 20:28:18 -0700
committerGravatar GitHub <noreply@github.com> 2023-08-14 20:28:18 -0700
commit47450ed12ccfe1d76ca527ea95f602e6ba089dce (patch)
tree368c60eef582b23bfda36c90c98605904aea9bb8 /src/js/_codegen
parenteab7b4c3ea3c42eb391293f4cfa7f8e01a6b43ac (diff)
downloadbun-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.ts25
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)