aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/cli/scripts/npm-native-packages/npm-native-packages.js
diff options
context:
space:
mode:
Diffstat (limited to 'cli/scripts/npm-native-packages/npm-native-packages.js')
-rw-r--r--cli/scripts/npm-native-packages/npm-native-packages.js57
1 files changed, 57 insertions, 0 deletions
diff --git a/cli/scripts/npm-native-packages/npm-native-packages.js b/cli/scripts/npm-native-packages/npm-native-packages.js
new file mode 100644
index 0000000..06ab67f
--- /dev/null
+++ b/cli/scripts/npm-native-packages/npm-native-packages.js
@@ -0,0 +1,57 @@
+#!/usr/bin/env node
+
+const fs = require("fs");
+const path = require("path");
+
+// Map to node os and arch names.
+const nodeOsLookup = {
+ darwin: "darwin",
+ linux: "linux",
+ windows: "win32",
+};
+
+const nodeArchLookup = {
+ amd64: "x64",
+ arm64: "arm64",
+};
+
+const humanizedArchLookup = {
+ amd64: "64",
+ arm64: "arm64",
+};
+
+const template = require("./template/template.package.json");
+const os = process.argv[2];
+const arch = process.argv[3];
+const version = process.argv[4];
+
+template.name = `turbo-${os}-${humanizedArchLookup[arch]}`;
+template.description = `The ${os}-${humanizedArchLookup[arch]} binary for turbo, a monorepo build system.`;
+template.os = [nodeOsLookup[os]];
+template.cpu = [nodeArchLookup[arch]];
+template.version = version;
+
+const outputPath = path.join(__dirname, "build", template.name);
+fs.rmSync(outputPath, { recursive: true, force: true });
+fs.mkdirSync(path.join(outputPath, "bin"), { recursive: true });
+
+if (os === "windows") {
+ fs.copyFileSync(
+ path.join(__dirname, "template", "bin", "turbo"),
+ path.join(outputPath, "bin", "turbo")
+ );
+}
+fs.copyFileSync(
+ path.join(__dirname, "template", "README.md"),
+ path.join(outputPath, "README.md")
+);
+fs.writeFileSync(
+ path.join(outputPath, "package.json"),
+ JSON.stringify(template, null, 2)
+);
+
+const goBin = os === "windows" ? "go-turbo.exe" : "go-turbo";
+fs.copyFileSync(
+ path.join(__dirname, "..", "..", `dist-${os}-${arch}`, goBin),
+ path.join(outputPath, "bin", goBin)
+);