@highstate/cli 0.7.4 → 0.7.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/highstate.manifest.json +5 -0
- package/dist/main.js +147 -82
- package/dist/main.js.map +1 -0
- package/package.json +6 -6
- package/src/commands/build.ts +41 -7
- package/src/shared/bin-transformer.ts +23 -0
- package/src/shared/index.ts +1 -0
package/dist/main.js
CHANGED
@@ -1,25 +1,24 @@
|
|
1
1
|
#!/usr/bin/env node
|
2
|
-
import { Command, UsageError, Option, Cli, Builtins } from 'clipanion';
|
3
|
-
import { readPackageJSON, resolvePackageJSON } from 'pkg-types';
|
4
|
-
import { addDevDependency } from 'nypm';
|
5
|
-
import { LogLevels, consola } from 'consola';
|
6
|
-
import { colorize } from 'consola/utils';
|
7
|
-
import { getPort } from 'get-port-please';
|
8
|
-
import { PassThrough } from 'node:stream';
|
9
|
-
import pino, { levels } from 'pino';
|
10
|
-
import { readFile, writeFile } from 'node:fs/promises';
|
11
|
-
import { parseAsync } from 'oxc-parser';
|
12
|
-
import { walk } from 'oxc-walker';
|
13
|
-
import { resolve, dirname, relative } from 'node:path';
|
14
|
-
import { pathToFileURL, fileURLToPath } from 'node:url';
|
15
|
-
import { sha256 } from 'crypto-hash';
|
16
|
-
import { resolve as resolve$1 } from 'import-meta-resolve';
|
17
|
-
import { pipe, mapValues, mapKeys } from 'remeda';
|
18
|
-
import { build } from 'tsup';
|
19
2
|
|
20
|
-
|
3
|
+
// src/main.ts
|
4
|
+
import { Builtins, Cli } from "clipanion";
|
21
5
|
|
22
|
-
|
6
|
+
// package.json
|
7
|
+
var version = "0.7.7";
|
8
|
+
|
9
|
+
// src/commands/designer.ts
|
10
|
+
import { Command, UsageError } from "clipanion";
|
11
|
+
import { readPackageJSON as readPackageJSON2 } from "pkg-types";
|
12
|
+
import { addDevDependency } from "nypm";
|
13
|
+
import { consola as consola2 } from "consola";
|
14
|
+
import { colorize } from "consola/utils";
|
15
|
+
import { getPort } from "get-port-please";
|
16
|
+
|
17
|
+
// src/shared/logger.ts
|
18
|
+
import { PassThrough } from "node:stream";
|
19
|
+
import pino, { levels } from "pino";
|
20
|
+
import { consola, LogLevels } from "consola";
|
21
|
+
var logger = pino(
|
23
22
|
{
|
24
23
|
name: "highstate-cli",
|
25
24
|
level: process.env.LOG_LEVEL ?? "info"
|
@@ -60,12 +59,13 @@ function createConsolaStream() {
|
|
60
59
|
return stream;
|
61
60
|
}
|
62
61
|
|
63
|
-
|
62
|
+
// src/shared/services.ts
|
63
|
+
var services;
|
64
64
|
function getBackendServices() {
|
65
65
|
if (services) {
|
66
66
|
return services;
|
67
67
|
}
|
68
|
-
services = import(
|
68
|
+
services = import("@highstate/backend").then(({ getSharedServices }) => {
|
69
69
|
return getSharedServices({
|
70
70
|
services: {
|
71
71
|
logger: logger.child({}, { msgPrefix: "[backend] " })
|
@@ -75,18 +75,24 @@ function getBackendServices() {
|
|
75
75
|
return services;
|
76
76
|
}
|
77
77
|
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
78
|
+
// src/shared/schema-transformer.ts
|
79
|
+
import { readFile } from "node:fs/promises";
|
80
|
+
import { parseAsync } from "oxc-parser";
|
81
|
+
import { walk } from "oxc-walker";
|
82
|
+
|
83
|
+
// ../../node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs
|
84
|
+
var comma = ",".charCodeAt(0);
|
85
|
+
var semicolon = ";".charCodeAt(0);
|
86
|
+
var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
87
|
+
var intToChar = new Uint8Array(64);
|
88
|
+
var charToInt = new Uint8Array(128);
|
83
89
|
for (let i = 0; i < chars.length; i++) {
|
84
90
|
const c = chars.charCodeAt(i);
|
85
91
|
intToChar[i] = c;
|
86
92
|
charToInt[c] = i;
|
87
93
|
}
|
88
|
-
function encodeInteger(builder, num,
|
89
|
-
let delta = num -
|
94
|
+
function encodeInteger(builder, num, relative2) {
|
95
|
+
let delta = num - relative2;
|
90
96
|
delta = delta < 0 ? -delta << 1 | 1 : delta << 1;
|
91
97
|
do {
|
92
98
|
let clamped = delta & 31;
|
@@ -97,8 +103,8 @@ function encodeInteger(builder, num, relative) {
|
|
97
103
|
} while (delta > 0);
|
98
104
|
return num;
|
99
105
|
}
|
100
|
-
|
101
|
-
|
106
|
+
var bufLength = 1024 * 16;
|
107
|
+
var td = typeof TextDecoder !== "undefined" ? /* @__PURE__ */ new TextDecoder() : typeof Buffer !== "undefined" ? {
|
102
108
|
decode(buf) {
|
103
109
|
const out = Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength);
|
104
110
|
return out.toString();
|
@@ -112,7 +118,7 @@ const td = typeof TextDecoder !== "undefined" ? /* @__PURE__ */ new TextDecoder(
|
|
112
118
|
return out;
|
113
119
|
}
|
114
120
|
};
|
115
|
-
|
121
|
+
var StringWriter = class {
|
116
122
|
constructor() {
|
117
123
|
this.pos = 0;
|
118
124
|
this.out = "";
|
@@ -130,7 +136,7 @@ class StringWriter {
|
|
130
136
|
const { buffer, out, pos } = this;
|
131
137
|
return pos > 0 ? out + td.decode(buffer.subarray(0, pos)) : out;
|
132
138
|
}
|
133
|
-
}
|
139
|
+
};
|
134
140
|
function encode(decoded) {
|
135
141
|
const writer = new StringWriter();
|
136
142
|
let sourcesIndex = 0;
|
@@ -162,9 +168,10 @@ function encode(decoded) {
|
|
162
168
|
return writer.flush();
|
163
169
|
}
|
164
170
|
|
165
|
-
|
171
|
+
// ../../node_modules/magic-string/dist/magic-string.es.mjs
|
172
|
+
var BitSet = class _BitSet {
|
166
173
|
constructor(arg) {
|
167
|
-
this.bits = arg instanceof
|
174
|
+
this.bits = arg instanceof _BitSet ? arg.bits.slice() : [];
|
168
175
|
}
|
169
176
|
add(n2) {
|
170
177
|
this.bits[n2 >> 5] |= 1 << (n2 & 31);
|
@@ -172,8 +179,8 @@ class BitSet {
|
|
172
179
|
has(n2) {
|
173
180
|
return !!(this.bits[n2 >> 5] & 1 << (n2 & 31));
|
174
181
|
}
|
175
|
-
}
|
176
|
-
|
182
|
+
};
|
183
|
+
var Chunk = class _Chunk {
|
177
184
|
constructor(start, end, content) {
|
178
185
|
this.start = start;
|
179
186
|
this.end = end;
|
@@ -195,7 +202,7 @@ class Chunk {
|
|
195
202
|
this.intro = this.intro + content;
|
196
203
|
}
|
197
204
|
clone() {
|
198
|
-
const chunk = new
|
205
|
+
const chunk = new _Chunk(this.start, this.end, this.original);
|
199
206
|
chunk.intro = this.intro;
|
200
207
|
chunk.outro = this.outro;
|
201
208
|
chunk.content = this.content;
|
@@ -250,7 +257,7 @@ class Chunk {
|
|
250
257
|
const originalBefore = this.original.slice(0, sliceIndex);
|
251
258
|
const originalAfter = this.original.slice(sliceIndex);
|
252
259
|
this.original = originalBefore;
|
253
|
-
const newChunk = new
|
260
|
+
const newChunk = new _Chunk(index, this.end, originalAfter);
|
254
261
|
newChunk.outro = this.outro;
|
255
262
|
this.outro = "";
|
256
263
|
this.end = index;
|
@@ -306,7 +313,7 @@ class Chunk {
|
|
306
313
|
if (this.outro.length) return true;
|
307
314
|
}
|
308
315
|
}
|
309
|
-
}
|
316
|
+
};
|
310
317
|
function getBtoa() {
|
311
318
|
if (typeof globalThis !== "undefined" && typeof globalThis.btoa === "function") {
|
312
319
|
return (str) => globalThis.btoa(unescape(encodeURIComponent(str)));
|
@@ -318,8 +325,8 @@ function getBtoa() {
|
|
318
325
|
};
|
319
326
|
}
|
320
327
|
}
|
321
|
-
|
322
|
-
|
328
|
+
var btoa = /* @__PURE__ */ getBtoa();
|
329
|
+
var SourceMap = class {
|
323
330
|
constructor(properties) {
|
324
331
|
this.version = 3;
|
325
332
|
this.file = properties.file;
|
@@ -340,7 +347,7 @@ class SourceMap {
|
|
340
347
|
toUrl() {
|
341
348
|
return "data:application/json;charset=utf-8;base64," + btoa(this.toString());
|
342
349
|
}
|
343
|
-
}
|
350
|
+
};
|
344
351
|
function guessIndent(code) {
|
345
352
|
const lines = code.split("\n");
|
346
353
|
const tabbed = lines.filter((line) => /^\t+/.test(line));
|
@@ -371,7 +378,7 @@ function getRelativePath(from, to) {
|
|
371
378
|
}
|
372
379
|
return fromParts.concat(toParts).join("/");
|
373
380
|
}
|
374
|
-
|
381
|
+
var toString = Object.prototype.toString;
|
375
382
|
function isObject(thing) {
|
376
383
|
return toString.call(thing) === "[object Object]";
|
377
384
|
}
|
@@ -398,8 +405,8 @@ function getLocator(source) {
|
|
398
405
|
return { line, column };
|
399
406
|
};
|
400
407
|
}
|
401
|
-
|
402
|
-
|
408
|
+
var wordRegex = /\w/;
|
409
|
+
var Mappings = class {
|
403
410
|
constructor(hires) {
|
404
411
|
this.hires = hires;
|
405
412
|
this.generatedCodeLine = 0;
|
@@ -487,14 +494,14 @@ class Mappings {
|
|
487
494
|
}
|
488
495
|
this.generatedCodeColumn += lines[lines.length - 1].length;
|
489
496
|
}
|
490
|
-
}
|
491
|
-
|
492
|
-
|
497
|
+
};
|
498
|
+
var n = "\n";
|
499
|
+
var warned = {
|
493
500
|
insertLeft: false,
|
494
501
|
insertRight: false,
|
495
502
|
storeName: false
|
496
503
|
};
|
497
|
-
|
504
|
+
var MagicString = class _MagicString {
|
498
505
|
constructor(string, options = {}) {
|
499
506
|
const chunk = new Chunk(0, string.length, string);
|
500
507
|
Object.defineProperties(this, {
|
@@ -550,7 +557,7 @@ class MagicString {
|
|
550
557
|
return this;
|
551
558
|
}
|
552
559
|
clone() {
|
553
|
-
const cloned = new
|
560
|
+
const cloned = new _MagicString(this.original, { filename: this.filename, offset: this.offset });
|
554
561
|
let originalChunk = this.firstChunk;
|
555
562
|
let clonedChunk = cloned.firstChunk = cloned.lastSearchedChunk = originalChunk.clone();
|
556
563
|
while (originalChunk) {
|
@@ -1135,12 +1142,13 @@ class MagicString {
|
|
1135
1142
|
}
|
1136
1143
|
return this._replaceRegexp(searchValue, replacement);
|
1137
1144
|
}
|
1138
|
-
}
|
1145
|
+
};
|
1139
1146
|
|
1140
|
-
|
1147
|
+
// src/shared/schema-transformer.ts
|
1148
|
+
var schemaTransformerPlugin = {
|
1141
1149
|
name: "schema-transformer",
|
1142
|
-
setup(
|
1143
|
-
|
1150
|
+
setup(build2) {
|
1151
|
+
build2.onLoad({ filter: /src\/.*\.ts$/ }, async (args) => {
|
1144
1152
|
const content = await readFile(args.path, "utf-8");
|
1145
1153
|
return {
|
1146
1154
|
contents: await applySchemaTransformations(content),
|
@@ -1184,11 +1192,18 @@ function cleanJsdoc(str) {
|
|
1184
1192
|
return str.replace(/^\s*\*/gm, "").replace("@schema", "").replace(/\\/g, "\\\\").replace(/`/g, "\\`").replace(/\${/g, "\\${").trim();
|
1185
1193
|
}
|
1186
1194
|
|
1187
|
-
|
1188
|
-
|
1195
|
+
// src/shared/source-hash-calculator.ts
|
1196
|
+
import { dirname, relative, resolve } from "node:path";
|
1197
|
+
import { readFile as readFile2, writeFile } from "node:fs/promises";
|
1198
|
+
import { fileURLToPath, pathToFileURL } from "node:url";
|
1199
|
+
import { readPackageJSON, resolvePackageJSON } from "pkg-types";
|
1200
|
+
import { sha256 } from "crypto-hash";
|
1201
|
+
import { resolve as importMetaResolve } from "import-meta-resolve";
|
1202
|
+
var SourceHashCalculator = class {
|
1203
|
+
constructor(packageJsonPath, packageJson, logger2) {
|
1189
1204
|
this.packageJsonPath = packageJsonPath;
|
1190
1205
|
this.packageJson = packageJson;
|
1191
|
-
this.logger =
|
1206
|
+
this.logger = logger2;
|
1192
1207
|
}
|
1193
1208
|
dependencyHashes = /* @__PURE__ */ new Map();
|
1194
1209
|
fileHashes = /* @__PURE__ */ new Map();
|
@@ -1223,7 +1238,7 @@ class SourceHashCalculator {
|
|
1223
1238
|
return hash;
|
1224
1239
|
}
|
1225
1240
|
async calculateFileHash(fullPath) {
|
1226
|
-
const content = await
|
1241
|
+
const content = await readFile2(fullPath, "utf8");
|
1227
1242
|
const fileDeps = this.parseDependencies(fullPath, content);
|
1228
1243
|
const hashes = await Promise.all([
|
1229
1244
|
sha256(content),
|
@@ -1249,7 +1264,7 @@ class SourceHashCalculator {
|
|
1249
1264
|
let resolvedUrl;
|
1250
1265
|
try {
|
1251
1266
|
const baseUrl = pathToFileURL(dirname(this.packageJsonPath));
|
1252
|
-
resolvedUrl =
|
1267
|
+
resolvedUrl = importMetaResolve(dependency.package, baseUrl.toString());
|
1253
1268
|
} catch (error) {
|
1254
1269
|
this.logger.error(`failed to resolve package "%s"`, dependency.package);
|
1255
1270
|
throw error;
|
@@ -1277,7 +1292,7 @@ class SourceHashCalculator {
|
|
1277
1292
|
);
|
1278
1293
|
let manifest;
|
1279
1294
|
try {
|
1280
|
-
const manifestContent = await
|
1295
|
+
const manifestContent = await readFile2(highstateManifestPath, "utf8");
|
1281
1296
|
manifest = JSON.parse(manifestContent);
|
1282
1297
|
} catch (error) {
|
1283
1298
|
this.logger.debug(
|
@@ -1325,20 +1340,43 @@ class SourceHashCalculator {
|
|
1325
1340
|
id: `npm:${npmPackage}`,
|
1326
1341
|
package: npmPackage
|
1327
1342
|
});
|
1328
|
-
} else
|
1343
|
+
} else if (nodeBuiltin) {
|
1344
|
+
}
|
1329
1345
|
}
|
1330
1346
|
return dependencies;
|
1331
1347
|
}
|
1348
|
+
};
|
1349
|
+
|
1350
|
+
// src/shared/bin-transformer.ts
|
1351
|
+
import { readFile as readFile3 } from "node:fs/promises";
|
1352
|
+
function createBinTransformerPlugin(sourceFilePaths) {
|
1353
|
+
const filter = new RegExp(`(${sourceFilePaths.join("|")})$`);
|
1354
|
+
logger.debug("created bin transformer plugin with filter: %s", filter);
|
1355
|
+
return {
|
1356
|
+
name: "bin-transformer",
|
1357
|
+
setup(build2) {
|
1358
|
+
build2.onLoad({ filter }, async (args) => {
|
1359
|
+
const content = await readFile3(args.path, "utf-8");
|
1360
|
+
return {
|
1361
|
+
contents: `#!/usr/bin/env node
|
1362
|
+
|
1363
|
+
${content}`,
|
1364
|
+
loader: "ts"
|
1365
|
+
};
|
1366
|
+
});
|
1367
|
+
}
|
1368
|
+
};
|
1332
1369
|
}
|
1333
1370
|
|
1334
|
-
|
1371
|
+
// src/commands/designer.ts
|
1372
|
+
var DesignerCommand = class extends Command {
|
1335
1373
|
static paths = [["designer"]];
|
1336
1374
|
static usage = Command.Usage({
|
1337
1375
|
category: "Designer",
|
1338
1376
|
description: "Starts the Highstate designer in the current project."
|
1339
1377
|
});
|
1340
1378
|
async execute() {
|
1341
|
-
const packageJson = await
|
1379
|
+
const packageJson = await readPackageJSON2();
|
1342
1380
|
if (!packageJson.devDependencies?.["@highstate/cli"]) {
|
1343
1381
|
throw new UsageError(
|
1344
1382
|
"This project is not a Highstate project.\n@highstate/cli must be installed as a devDependency."
|
@@ -1354,17 +1392,17 @@ class DesignerCommand extends Command {
|
|
1354
1392
|
const port = await getPort();
|
1355
1393
|
process.env.NITRO_PORT = port.toString();
|
1356
1394
|
process.env.NITRO_HOST = "0.0.0.0";
|
1357
|
-
await new Promise((
|
1395
|
+
await new Promise((resolve2) => {
|
1358
1396
|
console.log = (message) => {
|
1359
1397
|
if (message.startsWith("Listening on")) {
|
1360
|
-
|
1398
|
+
resolve2();
|
1361
1399
|
}
|
1362
1400
|
};
|
1363
1401
|
const path = "@highstate/designer/.output/server/index.mjs";
|
1364
1402
|
void import(path);
|
1365
1403
|
});
|
1366
1404
|
console.log = oldConsoleLog;
|
1367
|
-
|
1405
|
+
consola2.log(
|
1368
1406
|
[
|
1369
1407
|
"\n ",
|
1370
1408
|
colorize("bold", colorize("cyanBright", "Highstate Designer")),
|
@@ -1376,33 +1414,48 @@ class DesignerCommand extends Command {
|
|
1376
1414
|
);
|
1377
1415
|
process.on("SIGINT", () => {
|
1378
1416
|
process.stdout.write("\r");
|
1379
|
-
|
1417
|
+
consola2.info("shutting down highstate designer...");
|
1380
1418
|
setTimeout(() => process.exit(0), 1e3);
|
1381
1419
|
});
|
1382
1420
|
}
|
1383
|
-
}
|
1421
|
+
};
|
1384
1422
|
|
1385
|
-
|
1423
|
+
// src/commands/build.ts
|
1424
|
+
import { Command as Command2, Option } from "clipanion";
|
1425
|
+
import { readPackageJSON as readPackageJSON3, resolvePackageJSON as resolvePackageJSON2 } from "pkg-types";
|
1426
|
+
import { mapKeys, mapValues, pipe } from "remeda";
|
1427
|
+
import { build } from "tsup";
|
1428
|
+
var BuildCommand = class extends Command2 {
|
1386
1429
|
static paths = [["build"]];
|
1387
|
-
static usage =
|
1430
|
+
static usage = Command2.Usage({
|
1388
1431
|
category: "Builder",
|
1389
1432
|
description: "Builds the Highstate library or unit package."
|
1390
1433
|
});
|
1391
1434
|
watch = Option.Boolean("--watch", false);
|
1392
1435
|
library = Option.Boolean("--library", false);
|
1393
1436
|
async execute() {
|
1394
|
-
const packageJson = await
|
1437
|
+
const packageJson = await readPackageJSON3();
|
1395
1438
|
const exports = packageJson.exports;
|
1396
|
-
|
1397
|
-
|
1439
|
+
let bin = packageJson.bin;
|
1440
|
+
if (!packageJson.name) {
|
1441
|
+
throw new Error("package.json must have a name field");
|
1442
|
+
}
|
1443
|
+
if (!exports && !bin) {
|
1444
|
+
logger.warn("no exports or bin found in package.json");
|
1398
1445
|
return;
|
1399
1446
|
}
|
1400
|
-
if (typeof exports !== "object" || Array.isArray(exports)) {
|
1447
|
+
if (exports !== void 0 && (typeof exports !== "object" || Array.isArray(exports))) {
|
1401
1448
|
throw new Error("Exports field in package.json must be an object");
|
1402
1449
|
}
|
1450
|
+
if (bin !== void 0 && typeof bin !== "object") {
|
1451
|
+
bin = { [packageJson.name]: bin };
|
1452
|
+
}
|
1403
1453
|
const entry = pipe(
|
1404
|
-
|
1405
|
-
|
1454
|
+
{
|
1455
|
+
...mapValues(exports ?? {}, (value) => ({ value, isBin: false })),
|
1456
|
+
...mapValues(bin ?? {}, (value) => ({ value, isBin: true }))
|
1457
|
+
},
|
1458
|
+
mapValues(({ value, isBin }, key) => {
|
1406
1459
|
let distPath;
|
1407
1460
|
if (typeof value === "string") {
|
1408
1461
|
distPath = value;
|
@@ -1431,11 +1484,20 @@ class BuildCommand extends Command {
|
|
1431
1484
|
return {
|
1432
1485
|
entryPoint: `./src/${targetName}.ts`,
|
1433
1486
|
targetName,
|
1434
|
-
distPath
|
1487
|
+
distPath,
|
1488
|
+
isBin
|
1435
1489
|
};
|
1436
1490
|
}),
|
1437
1491
|
mapKeys((_, value) => value.targetName)
|
1438
1492
|
);
|
1493
|
+
const esbuildPlugins = [];
|
1494
|
+
const binSourceFilePaths = Object.values(entry).filter((value) => value.isBin).map((value) => value.entryPoint.slice(2));
|
1495
|
+
if (this.library) {
|
1496
|
+
esbuildPlugins.push(schemaTransformerPlugin);
|
1497
|
+
}
|
1498
|
+
if (binSourceFilePaths.length > 0) {
|
1499
|
+
esbuildPlugins.push(createBinTransformerPlugin(binSourceFilePaths));
|
1500
|
+
}
|
1439
1501
|
await build({
|
1440
1502
|
entry: mapValues(entry, (value) => value.entryPoint),
|
1441
1503
|
outDir: "dist",
|
@@ -1445,10 +1507,11 @@ class BuildCommand extends Command {
|
|
1445
1507
|
format: "esm",
|
1446
1508
|
target: "esnext",
|
1447
1509
|
external: ["@pulumi/pulumi"],
|
1448
|
-
esbuildPlugins
|
1510
|
+
esbuildPlugins,
|
1511
|
+
silent: ["warn", "error", "fatal"].includes(logger.level)
|
1449
1512
|
});
|
1450
|
-
const packageJsonPath = await
|
1451
|
-
const upToDatePackageJson = await
|
1513
|
+
const packageJsonPath = await resolvePackageJSON2();
|
1514
|
+
const upToDatePackageJson = await readPackageJSON3();
|
1452
1515
|
const sourceHashCalculator = new SourceHashCalculator(
|
1453
1516
|
packageJsonPath,
|
1454
1517
|
upToDatePackageJson,
|
@@ -1457,9 +1520,10 @@ class BuildCommand extends Command {
|
|
1457
1520
|
const distPaths = Object.values(entry).map((value) => value.distPath);
|
1458
1521
|
await sourceHashCalculator.writeHighstateManifest("./dist", distPaths);
|
1459
1522
|
}
|
1460
|
-
}
|
1523
|
+
};
|
1461
1524
|
|
1462
|
-
|
1525
|
+
// src/main.ts
|
1526
|
+
var cli = new Cli({
|
1463
1527
|
binaryName: "highstate",
|
1464
1528
|
binaryLabel: "Highstate",
|
1465
1529
|
binaryVersion: version
|
@@ -1469,3 +1533,4 @@ cli.register(DesignerCommand);
|
|
1469
1533
|
cli.register(Builtins.HelpCommand);
|
1470
1534
|
cli.register(Builtins.VersionCommand);
|
1471
1535
|
await cli.runExit(process.argv.slice(2));
|
1536
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"sources":["../src/main.ts","../package.json","../src/commands/designer.ts","../src/shared/logger.ts","../src/shared/services.ts","../src/shared/schema-transformer.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/vlq.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/strings.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/scopes.ts","../../../node_modules/@jridgewell/sourcemap-codec/src/sourcemap-codec.ts","../../../node_modules/magic-string/src/BitSet.js","../../../node_modules/magic-string/src/Chunk.js","../../../node_modules/magic-string/src/SourceMap.js","../../../node_modules/magic-string/src/utils/guessIndent.js","../../../node_modules/magic-string/src/utils/getRelativePath.js","../../../node_modules/magic-string/src/utils/isObject.js","../../../node_modules/magic-string/src/utils/getLocator.js","../../../node_modules/magic-string/src/utils/Mappings.js","../../../node_modules/magic-string/src/MagicString.js","../../../node_modules/magic-string/src/Bundle.js","../src/shared/source-hash-calculator.ts","../src/shared/bin-transformer.ts","../src/commands/build.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { Builtins, Cli } from \"clipanion\"\nimport { version } from \"../package.json\"\nimport { DesignerCommand } from \"./commands/designer\"\nimport { BuildCommand } from \"./commands/build\"\n\nconst cli = new Cli({\n binaryName: \"highstate\",\n binaryLabel: \"Highstate\",\n binaryVersion: version,\n})\n\ncli.register(BuildCommand)\ncli.register(DesignerCommand)\ncli.register(Builtins.HelpCommand)\ncli.register(Builtins.VersionCommand)\n\nawait cli.runExit(process.argv.slice(2))\n","{\n \"name\": \"@highstate/cli\",\n \"version\": \"0.7.7\",\n \"description\": \"The CLI for the Highstate project.\",\n \"type\": \"module\",\n \"files\": [\n \"assets\",\n \"dist\",\n \"src\"\n ],\n \"bin\": {\n \"highstate\": \"./dist/main.js\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"scripts\": {\n \"build\": \"highstate build\"\n },\n \"dependencies\": {\n \"@highstate/backend\": \"workspace:^0.7.6\",\n \"clipanion\": \"^4.0.0-rc.4\",\n \"consola\": \"^3.4.0\",\n \"crypto-hash\": \"^3.1.0\",\n \"get-port-please\": \"^3.1.2\",\n \"import-meta-resolve\": \"^4.1.0\",\n \"nypm\": \"^0.4.1\",\n \"oxc-parser\": \"^0.63.0\",\n \"oxc-walker\": \"^0.2.4\",\n \"pino\": \"^9.6.0\",\n \"pkg-types\": \"^1.2.1\",\n \"remeda\": \"^2.21.2\",\n \"tsup\": \"^8.4.0\"\n },\n \"devDependencies\": {\n \"highstate-cli-bootstrap\": \"npm:@highstate/cli@0.7.6\"\n }\n}\n","import { Command, UsageError } from \"clipanion\"\nimport { readPackageJSON } from \"pkg-types\"\nimport { addDevDependency } from \"nypm\"\nimport { consola } from \"consola\"\nimport { colorize } from \"consola/utils\"\nimport { getPort } from \"get-port-please\"\nimport { getBackendServices, logger } from \"../shared\"\n\nexport class DesignerCommand extends Command {\n static paths = [[\"designer\"]]\n\n static usage = Command.Usage({\n category: \"Designer\",\n description: \"Starts the Highstate designer in the current project.\",\n })\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n if (!packageJson.devDependencies?.[\"@highstate/cli\"]) {\n throw new UsageError(\n \"This project is not a Highstate project.\\n@highstate/cli must be installed as a devDependency.\",\n )\n }\n\n if (!packageJson.devDependencies?.[\"@highstate/designer\"]) {\n logger.info(\"Installing @highstate/designer...\")\n\n await addDevDependency([\"@highstate/designer\", \"classic-level\"])\n }\n\n logger.info(\"starting highstate designer...\")\n\n await getBackendServices()\n\n const oldConsoleLog = console.log\n\n const port = await getPort()\n\n process.env.NITRO_PORT = port.toString()\n process.env.NITRO_HOST = \"0.0.0.0\"\n\n await new Promise<void>(resolve => {\n console.log = (message: string) => {\n if (message.startsWith(\"Listening on\")) {\n resolve()\n }\n }\n\n const path = \"@highstate/designer/.output/server/index.mjs\"\n void import(path)\n })\n\n console.log = oldConsoleLog\n\n consola.log(\n [\n \"\\n \",\n colorize(\"bold\", colorize(\"cyanBright\", \"Highstate Designer\")),\n \"\\n \",\n colorize(\"greenBright\", \"➜ Local: \"),\n colorize(\"underline\", colorize(\"cyanBright\", `http://localhost:${port}`)),\n \"\\n\",\n ].join(\"\"),\n )\n\n process.on(\"SIGINT\", () => {\n process.stdout.write(\"\\r\")\n consola.info(\"shutting down highstate designer...\")\n\n setTimeout(() => process.exit(0), 1000)\n })\n }\n}\n","import { PassThrough } from \"node:stream\"\nimport pino, { levels } from \"pino\"\nimport { consola, LogLevels } from \"consola\"\n\nexport const logger = pino(\n {\n name: \"highstate-cli\",\n level: process.env.LOG_LEVEL ?? \"info\",\n },\n createConsolaStream(),\n)\n\nconsola.level = LogLevels[(process.env.LOG_LEVEL as keyof typeof LogLevels) ?? \"info\"]\n\nfunction createConsolaStream() {\n const stream = new PassThrough()\n\n stream.on(\"data\", data => {\n const { level, msg, error } = JSON.parse(String(data)) as {\n msg: string\n level: number\n error?: unknown\n }\n\n const levelLabel = levels.labels[level]\n\n switch (levelLabel) {\n case \"info\":\n consola.info(msg)\n break\n case \"warn\":\n consola.warn(msg)\n break\n case \"error\":\n if (error) {\n consola.error(msg, error)\n } else {\n consola.error(msg)\n }\n break\n case \"debug\":\n consola.debug(msg)\n break\n case \"fatal\":\n consola.fatal(msg)\n break\n case \"trace\":\n consola.trace(msg)\n break\n }\n })\n\n return stream\n}\n","import type { Services } from \"@highstate/backend\"\nimport { logger } from \"./logger\"\n\nlet services: Promise<Services> | undefined\n\nexport function getBackendServices() {\n if (services) {\n return services\n }\n\n services = import(\"@highstate/backend\").then(({ getSharedServices }) => {\n return getSharedServices({\n services: {\n logger: logger.child({}, { msgPrefix: \"[backend] \" }),\n },\n })\n })\n\n return services\n}\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { parseAsync, type Comment } from \"oxc-parser\"\nimport { walk, type Node } from \"oxc-walker\"\nimport MagicString from \"magic-string\"\n\nexport const schemaTransformerPlugin: Plugin = {\n name: \"schema-transformer\",\n setup(build) {\n build.onLoad({ filter: /src\\/.*\\.ts$/ }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: await applySchemaTransformations(content),\n loader: \"ts\",\n }\n })\n },\n}\n\nexport async function applySchemaTransformations(content: string): Promise<string> {\n const magicString = new MagicString(content)\n const { program, comments } = await parseAsync(\"file.ts\", content)\n\n walk(program, {\n enter(node) {\n if (node.type !== \"Property\" || node.key.type !== \"Identifier\") {\n return\n }\n\n const jsdoc = comments.find(comment => isLeadingComment(content, node, comment))\n if (!jsdoc || !jsdoc.value.includes(\"@schema\")) {\n return\n }\n\n magicString.update(\n node.value.start,\n node.value.end,\n `{\n ...${content.substring(node.value.start, node.value.end)},\n description: \\`${cleanJsdoc(jsdoc.value)}\\`,\n}`,\n )\n },\n })\n\n return magicString.toString()\n}\n\nfunction isLeadingComment(content: string, node: Node, comment: Comment) {\n if (comment.end > node.start) {\n return false\n }\n\n const contentRange = content.substring(comment.end, node.start)\n\n return contentRange.trim().length === 0\n}\n\nfunction cleanJsdoc(str: string) {\n return (\n str\n // remove leading asterisks\n .replace(/^\\s*\\*/gm, \"\")\n\n // remove @schema tag\n .replace(\"@schema\", \"\")\n\n // escape backticks and dollar signs\n .replace(/\\\\/g, \"\\\\\\\\\")\n .replace(/`/g, \"\\\\`\")\n .replace(/\\${/g, \"\\\\${\")\n .trim()\n )\n}\n","import type { StringReader, StringWriter } from './strings';\n\nexport const comma = ','.charCodeAt(0);\nexport const semicolon = ';'.charCodeAt(0);\n\nconst chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nconst intToChar = new Uint8Array(64); // 64 possible chars.\nconst charToInt = new Uint8Array(128); // z is 122 in ASCII\n\nfor (let i = 0; i < chars.length; i++) {\n const c = chars.charCodeAt(i);\n intToChar[i] = c;\n charToInt[c] = i;\n}\n\nexport function decodeInteger(reader: StringReader, relative: number): number {\n let value = 0;\n let shift = 0;\n let integer = 0;\n\n do {\n const c = reader.next();\n integer = charToInt[c];\n value |= (integer & 31) << shift;\n shift += 5;\n } while (integer & 32);\n\n const shouldNegate = value & 1;\n value >>>= 1;\n\n if (shouldNegate) {\n value = -0x80000000 | -value;\n }\n\n return relative + value;\n}\n\nexport function encodeInteger(builder: StringWriter, num: number, relative: number): number {\n let delta = num - relative;\n\n delta = delta < 0 ? (-delta << 1) | 1 : delta << 1;\n do {\n let clamped = delta & 0b011111;\n delta >>>= 5;\n if (delta > 0) clamped |= 0b100000;\n builder.write(intToChar[clamped]);\n } while (delta > 0);\n\n return num;\n}\n\nexport function hasMoreVlq(reader: StringReader, max: number) {\n if (reader.pos >= max) return false;\n return reader.peek() !== comma;\n}\n","const bufLength = 1024 * 16;\n\n// Provide a fallback for older environments.\nconst td =\n typeof TextDecoder !== 'undefined'\n ? /* #__PURE__ */ new TextDecoder()\n : typeof Buffer !== 'undefined'\n ? {\n decode(buf: Uint8Array): string {\n const out = Buffer.from(buf.buffer, buf.byteOffset, buf.byteLength);\n return out.toString();\n },\n }\n : {\n decode(buf: Uint8Array): string {\n let out = '';\n for (let i = 0; i < buf.length; i++) {\n out += String.fromCharCode(buf[i]);\n }\n return out;\n },\n };\n\nexport class StringWriter {\n pos = 0;\n private out = '';\n private buffer = new Uint8Array(bufLength);\n\n write(v: number): void {\n const { buffer } = this;\n buffer[this.pos++] = v;\n if (this.pos === bufLength) {\n this.out += td.decode(buffer);\n this.pos = 0;\n }\n }\n\n flush(): string {\n const { buffer, out, pos } = this;\n return pos > 0 ? out + td.decode(buffer.subarray(0, pos)) : out;\n }\n}\n\nexport class StringReader {\n pos = 0;\n private declare buffer: string;\n\n constructor(buffer: string) {\n this.buffer = buffer;\n }\n\n next(): number {\n return this.buffer.charCodeAt(this.pos++);\n }\n\n peek(): number {\n return this.buffer.charCodeAt(this.pos);\n }\n\n indexOf(char: string): number {\n const { buffer, pos } = this;\n const idx = buffer.indexOf(char, pos);\n return idx === -1 ? buffer.length : idx;\n }\n}\n","import { StringReader, StringWriter } from './strings';\nimport { comma, decodeInteger, encodeInteger, hasMoreVlq, semicolon } from './vlq';\n\nconst EMPTY: any[] = [];\n\ntype Line = number;\ntype Column = number;\ntype Kind = number;\ntype Name = number;\ntype Var = number;\ntype SourcesIndex = number;\ntype ScopesIndex = number;\n\ntype Mix<A, B, O> = (A & O) | (B & O);\n\nexport type OriginalScope = Mix<\n [Line, Column, Line, Column, Kind],\n [Line, Column, Line, Column, Kind, Name],\n { vars: Var[] }\n>;\n\nexport type GeneratedRange = Mix<\n [Line, Column, Line, Column],\n [Line, Column, Line, Column, SourcesIndex, ScopesIndex],\n {\n callsite: CallSite | null;\n bindings: Binding[];\n isScope: boolean;\n }\n>;\nexport type CallSite = [SourcesIndex, Line, Column];\ntype Binding = BindingExpressionRange[];\nexport type BindingExpressionRange = [Name] | [Name, Line, Column];\n\nexport function decodeOriginalScopes(input: string): OriginalScope[] {\n const { length } = input;\n const reader = new StringReader(input);\n const scopes: OriginalScope[] = [];\n const stack: OriginalScope[] = [];\n let line = 0;\n\n for (; reader.pos < length; reader.pos++) {\n line = decodeInteger(reader, line);\n const column = decodeInteger(reader, 0);\n\n if (!hasMoreVlq(reader, length)) {\n const last = stack.pop()!;\n last[2] = line;\n last[3] = column;\n continue;\n }\n\n const kind = decodeInteger(reader, 0);\n const fields = decodeInteger(reader, 0);\n const hasName = fields & 0b0001;\n\n const scope: OriginalScope = (\n hasName ? [line, column, 0, 0, kind, decodeInteger(reader, 0)] : [line, column, 0, 0, kind]\n ) as OriginalScope;\n\n let vars: Var[] = EMPTY;\n if (hasMoreVlq(reader, length)) {\n vars = [];\n do {\n const varsIndex = decodeInteger(reader, 0);\n vars.push(varsIndex);\n } while (hasMoreVlq(reader, length));\n }\n scope.vars = vars;\n\n scopes.push(scope);\n stack.push(scope);\n }\n\n return scopes;\n}\n\nexport function encodeOriginalScopes(scopes: OriginalScope[]): string {\n const writer = new StringWriter();\n\n for (let i = 0; i < scopes.length; ) {\n i = _encodeOriginalScopes(scopes, i, writer, [0]);\n }\n\n return writer.flush();\n}\n\nfunction _encodeOriginalScopes(\n scopes: OriginalScope[],\n index: number,\n writer: StringWriter,\n state: [\n number, // GenColumn\n ],\n): number {\n const scope = scopes[index];\n const { 0: startLine, 1: startColumn, 2: endLine, 3: endColumn, 4: kind, vars } = scope;\n\n if (index > 0) writer.write(comma);\n\n state[0] = encodeInteger(writer, startLine, state[0]);\n encodeInteger(writer, startColumn, 0);\n encodeInteger(writer, kind, 0);\n\n const fields = scope.length === 6 ? 0b0001 : 0;\n encodeInteger(writer, fields, 0);\n if (scope.length === 6) encodeInteger(writer, scope[5], 0);\n\n for (const v of vars) {\n encodeInteger(writer, v, 0);\n }\n\n for (index++; index < scopes.length; ) {\n const next = scopes[index];\n const { 0: l, 1: c } = next;\n if (l > endLine || (l === endLine && c >= endColumn)) {\n break;\n }\n index = _encodeOriginalScopes(scopes, index, writer, state);\n }\n\n writer.write(comma);\n state[0] = encodeInteger(writer, endLine, state[0]);\n encodeInteger(writer, endColumn, 0);\n\n return index;\n}\n\nexport function decodeGeneratedRanges(input: string): GeneratedRange[] {\n const { length } = input;\n const reader = new StringReader(input);\n const ranges: GeneratedRange[] = [];\n const stack: GeneratedRange[] = [];\n\n let genLine = 0;\n let definitionSourcesIndex = 0;\n let definitionScopeIndex = 0;\n let callsiteSourcesIndex = 0;\n let callsiteLine = 0;\n let callsiteColumn = 0;\n let bindingLine = 0;\n let bindingColumn = 0;\n\n do {\n const semi = reader.indexOf(';');\n let genColumn = 0;\n\n for (; reader.pos < semi; reader.pos++) {\n genColumn = decodeInteger(reader, genColumn);\n\n if (!hasMoreVlq(reader, semi)) {\n const last = stack.pop()!;\n last[2] = genLine;\n last[3] = genColumn;\n continue;\n }\n\n const fields = decodeInteger(reader, 0);\n const hasDefinition = fields & 0b0001;\n const hasCallsite = fields & 0b0010;\n const hasScope = fields & 0b0100;\n\n let callsite: CallSite | null = null;\n let bindings: Binding[] = EMPTY;\n let range: GeneratedRange;\n if (hasDefinition) {\n const defSourcesIndex = decodeInteger(reader, definitionSourcesIndex);\n definitionScopeIndex = decodeInteger(\n reader,\n definitionSourcesIndex === defSourcesIndex ? definitionScopeIndex : 0,\n );\n\n definitionSourcesIndex = defSourcesIndex;\n range = [genLine, genColumn, 0, 0, defSourcesIndex, definitionScopeIndex] as GeneratedRange;\n } else {\n range = [genLine, genColumn, 0, 0] as GeneratedRange;\n }\n\n range.isScope = !!hasScope;\n\n if (hasCallsite) {\n const prevCsi = callsiteSourcesIndex;\n const prevLine = callsiteLine;\n callsiteSourcesIndex = decodeInteger(reader, callsiteSourcesIndex);\n const sameSource = prevCsi === callsiteSourcesIndex;\n callsiteLine = decodeInteger(reader, sameSource ? callsiteLine : 0);\n callsiteColumn = decodeInteger(\n reader,\n sameSource && prevLine === callsiteLine ? callsiteColumn : 0,\n );\n\n callsite = [callsiteSourcesIndex, callsiteLine, callsiteColumn];\n }\n range.callsite = callsite;\n\n if (hasMoreVlq(reader, semi)) {\n bindings = [];\n do {\n bindingLine = genLine;\n bindingColumn = genColumn;\n const expressionsCount = decodeInteger(reader, 0);\n let expressionRanges: BindingExpressionRange[];\n if (expressionsCount < -1) {\n expressionRanges = [[decodeInteger(reader, 0)]];\n for (let i = -1; i > expressionsCount; i--) {\n const prevBl = bindingLine;\n bindingLine = decodeInteger(reader, bindingLine);\n bindingColumn = decodeInteger(reader, bindingLine === prevBl ? bindingColumn : 0);\n const expression = decodeInteger(reader, 0);\n expressionRanges.push([expression, bindingLine, bindingColumn]);\n }\n } else {\n expressionRanges = [[expressionsCount]];\n }\n bindings.push(expressionRanges);\n } while (hasMoreVlq(reader, semi));\n }\n range.bindings = bindings;\n\n ranges.push(range);\n stack.push(range);\n }\n\n genLine++;\n reader.pos = semi + 1;\n } while (reader.pos < length);\n\n return ranges;\n}\n\nexport function encodeGeneratedRanges(ranges: GeneratedRange[]): string {\n if (ranges.length === 0) return '';\n\n const writer = new StringWriter();\n\n for (let i = 0; i < ranges.length; ) {\n i = _encodeGeneratedRanges(ranges, i, writer, [0, 0, 0, 0, 0, 0, 0]);\n }\n\n return writer.flush();\n}\n\nfunction _encodeGeneratedRanges(\n ranges: GeneratedRange[],\n index: number,\n writer: StringWriter,\n state: [\n number, // GenLine\n number, // GenColumn\n number, // DefSourcesIndex\n number, // DefScopesIndex\n number, // CallSourcesIndex\n number, // CallLine\n number, // CallColumn\n ],\n): number {\n const range = ranges[index];\n const {\n 0: startLine,\n 1: startColumn,\n 2: endLine,\n 3: endColumn,\n isScope,\n callsite,\n bindings,\n } = range;\n\n if (state[0] < startLine) {\n catchupLine(writer, state[0], startLine);\n state[0] = startLine;\n state[1] = 0;\n } else if (index > 0) {\n writer.write(comma);\n }\n\n state[1] = encodeInteger(writer, range[1], state[1]);\n\n const fields =\n (range.length === 6 ? 0b0001 : 0) | (callsite ? 0b0010 : 0) | (isScope ? 0b0100 : 0);\n encodeInteger(writer, fields, 0);\n\n if (range.length === 6) {\n const { 4: sourcesIndex, 5: scopesIndex } = range;\n if (sourcesIndex !== state[2]) {\n state[3] = 0;\n }\n state[2] = encodeInteger(writer, sourcesIndex, state[2]);\n state[3] = encodeInteger(writer, scopesIndex, state[3]);\n }\n\n if (callsite) {\n const { 0: sourcesIndex, 1: callLine, 2: callColumn } = range.callsite!;\n if (sourcesIndex !== state[4]) {\n state[5] = 0;\n state[6] = 0;\n } else if (callLine !== state[5]) {\n state[6] = 0;\n }\n state[4] = encodeInteger(writer, sourcesIndex, state[4]);\n state[5] = encodeInteger(writer, callLine, state[5]);\n state[6] = encodeInteger(writer, callColumn, state[6]);\n }\n\n if (bindings) {\n for (const binding of bindings) {\n if (binding.length > 1) encodeInteger(writer, -binding.length, 0);\n const expression = binding[0][0];\n encodeInteger(writer, expression, 0);\n let bindingStartLine = startLine;\n let bindingStartColumn = startColumn;\n for (let i = 1; i < binding.length; i++) {\n const expRange = binding[i];\n bindingStartLine = encodeInteger(writer, expRange[1]!, bindingStartLine);\n bindingStartColumn = encodeInteger(writer, expRange[2]!, bindingStartColumn);\n encodeInteger(writer, expRange[0]!, 0);\n }\n }\n }\n\n for (index++; index < ranges.length; ) {\n const next = ranges[index];\n const { 0: l, 1: c } = next;\n if (l > endLine || (l === endLine && c >= endColumn)) {\n break;\n }\n index = _encodeGeneratedRanges(ranges, index, writer, state);\n }\n\n if (state[0] < endLine) {\n catchupLine(writer, state[0], endLine);\n state[0] = endLine;\n state[1] = 0;\n } else {\n writer.write(comma);\n }\n state[1] = encodeInteger(writer, endColumn, state[1]);\n\n return index;\n}\n\nfunction catchupLine(writer: StringWriter, lastLine: number, line: number) {\n do {\n writer.write(semicolon);\n } while (++lastLine < line);\n}\n","import { comma, decodeInteger, encodeInteger, hasMoreVlq, semicolon } from './vlq';\nimport { StringWriter, StringReader } from './strings';\n\nexport {\n decodeOriginalScopes,\n encodeOriginalScopes,\n decodeGeneratedRanges,\n encodeGeneratedRanges,\n} from './scopes';\nexport type { OriginalScope, GeneratedRange, CallSite, BindingExpressionRange } from './scopes';\n\nexport type SourceMapSegment =\n | [number]\n | [number, number, number, number]\n | [number, number, number, number, number];\nexport type SourceMapLine = SourceMapSegment[];\nexport type SourceMapMappings = SourceMapLine[];\n\nexport function decode(mappings: string): SourceMapMappings {\n const { length } = mappings;\n const reader = new StringReader(mappings);\n const decoded: SourceMapMappings = [];\n let genColumn = 0;\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n\n do {\n const semi = reader.indexOf(';');\n const line: SourceMapLine = [];\n let sorted = true;\n let lastCol = 0;\n genColumn = 0;\n\n while (reader.pos < semi) {\n let seg: SourceMapSegment;\n\n genColumn = decodeInteger(reader, genColumn);\n if (genColumn < lastCol) sorted = false;\n lastCol = genColumn;\n\n if (hasMoreVlq(reader, semi)) {\n sourcesIndex = decodeInteger(reader, sourcesIndex);\n sourceLine = decodeInteger(reader, sourceLine);\n sourceColumn = decodeInteger(reader, sourceColumn);\n\n if (hasMoreVlq(reader, semi)) {\n namesIndex = decodeInteger(reader, namesIndex);\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn, namesIndex];\n } else {\n seg = [genColumn, sourcesIndex, sourceLine, sourceColumn];\n }\n } else {\n seg = [genColumn];\n }\n\n line.push(seg);\n reader.pos++;\n }\n\n if (!sorted) sort(line);\n decoded.push(line);\n reader.pos = semi + 1;\n } while (reader.pos <= length);\n\n return decoded;\n}\n\nfunction sort(line: SourceMapSegment[]) {\n line.sort(sortComparator);\n}\n\nfunction sortComparator(a: SourceMapSegment, b: SourceMapSegment): number {\n return a[0] - b[0];\n}\n\nexport function encode(decoded: SourceMapMappings): string;\nexport function encode(decoded: Readonly<SourceMapMappings>): string;\nexport function encode(decoded: Readonly<SourceMapMappings>): string {\n const writer = new StringWriter();\n let sourcesIndex = 0;\n let sourceLine = 0;\n let sourceColumn = 0;\n let namesIndex = 0;\n\n for (let i = 0; i < decoded.length; i++) {\n const line = decoded[i];\n if (i > 0) writer.write(semicolon);\n if (line.length === 0) continue;\n\n let genColumn = 0;\n\n for (let j = 0; j < line.length; j++) {\n const segment = line[j];\n if (j > 0) writer.write(comma);\n\n genColumn = encodeInteger(writer, segment[0], genColumn);\n\n if (segment.length === 1) continue;\n sourcesIndex = encodeInteger(writer, segment[1], sourcesIndex);\n sourceLine = encodeInteger(writer, segment[2], sourceLine);\n sourceColumn = encodeInteger(writer, segment[3], sourceColumn);\n\n if (segment.length === 4) continue;\n namesIndex = encodeInteger(writer, segment[4], namesIndex);\n }\n }\n\n return writer.flush();\n}\n","export default class BitSet {\n\tconstructor(arg) {\n\t\tthis.bits = arg instanceof BitSet ? arg.bits.slice() : [];\n\t}\n\n\tadd(n) {\n\t\tthis.bits[n >> 5] |= 1 << (n & 31);\n\t}\n\n\thas(n) {\n\t\treturn !!(this.bits[n >> 5] & (1 << (n & 31)));\n\t}\n}\n","export default class Chunk {\n\tconstructor(start, end, content) {\n\t\tthis.start = start;\n\t\tthis.end = end;\n\t\tthis.original = content;\n\n\t\tthis.intro = '';\n\t\tthis.outro = '';\n\n\t\tthis.content = content;\n\t\tthis.storeName = false;\n\t\tthis.edited = false;\n\n\t\tif (DEBUG) {\n\t\t\t// we make these non-enumerable, for sanity while debugging\n\t\t\tObject.defineProperties(this, {\n\t\t\t\tprevious: { writable: true, value: null },\n\t\t\t\tnext: { writable: true, value: null },\n\t\t\t});\n\t\t} else {\n\t\t\tthis.previous = null;\n\t\t\tthis.next = null;\n\t\t}\n\t}\n\n\tappendLeft(content) {\n\t\tthis.outro += content;\n\t}\n\n\tappendRight(content) {\n\t\tthis.intro = this.intro + content;\n\t}\n\n\tclone() {\n\t\tconst chunk = new Chunk(this.start, this.end, this.original);\n\n\t\tchunk.intro = this.intro;\n\t\tchunk.outro = this.outro;\n\t\tchunk.content = this.content;\n\t\tchunk.storeName = this.storeName;\n\t\tchunk.edited = this.edited;\n\n\t\treturn chunk;\n\t}\n\n\tcontains(index) {\n\t\treturn this.start < index && index < this.end;\n\t}\n\n\teachNext(fn) {\n\t\tlet chunk = this;\n\t\twhile (chunk) {\n\t\t\tfn(chunk);\n\t\t\tchunk = chunk.next;\n\t\t}\n\t}\n\n\teachPrevious(fn) {\n\t\tlet chunk = this;\n\t\twhile (chunk) {\n\t\t\tfn(chunk);\n\t\t\tchunk = chunk.previous;\n\t\t}\n\t}\n\n\tedit(content, storeName, contentOnly) {\n\t\tthis.content = content;\n\t\tif (!contentOnly) {\n\t\t\tthis.intro = '';\n\t\t\tthis.outro = '';\n\t\t}\n\t\tthis.storeName = storeName;\n\n\t\tthis.edited = true;\n\n\t\treturn this;\n\t}\n\n\tprependLeft(content) {\n\t\tthis.outro = content + this.outro;\n\t}\n\n\tprependRight(content) {\n\t\tthis.intro = content + this.intro;\n\t}\n\n\treset() {\n\t\tthis.intro = '';\n\t\tthis.outro = '';\n\t\tif (this.edited) {\n\t\t\tthis.content = this.original;\n\t\t\tthis.storeName = false;\n\t\t\tthis.edited = false;\n\t\t}\n\t}\n\n\tsplit(index) {\n\t\tconst sliceIndex = index - this.start;\n\n\t\tconst originalBefore = this.original.slice(0, sliceIndex);\n\t\tconst originalAfter = this.original.slice(sliceIndex);\n\n\t\tthis.original = originalBefore;\n\n\t\tconst newChunk = new Chunk(index, this.end, originalAfter);\n\t\tnewChunk.outro = this.outro;\n\t\tthis.outro = '';\n\n\t\tthis.end = index;\n\n\t\tif (this.edited) {\n\t\t\t// after split we should save the edit content record into the correct chunk\n\t\t\t// to make sure sourcemap correct\n\t\t\t// For example:\n\t\t\t// ' test'.trim()\n\t\t\t// split -> ' ' + 'test'\n\t\t\t// ✔️ edit -> '' + 'test'\n\t\t\t// ✖️ edit -> 'test' + ''\n\t\t\t// TODO is this block necessary?...\n\t\t\tnewChunk.edit('', false);\n\t\t\tthis.content = '';\n\t\t} else {\n\t\t\tthis.content = originalBefore;\n\t\t}\n\n\t\tnewChunk.next = this.next;\n\t\tif (newChunk.next) newChunk.next.previous = newChunk;\n\t\tnewChunk.previous = this;\n\t\tthis.next = newChunk;\n\n\t\treturn newChunk;\n\t}\n\n\ttoString() {\n\t\treturn this.intro + this.content + this.outro;\n\t}\n\n\ttrimEnd(rx) {\n\t\tthis.outro = this.outro.replace(rx, '');\n\t\tif (this.outro.length) return true;\n\n\t\tconst trimmed = this.content.replace(rx, '');\n\n\t\tif (trimmed.length) {\n\t\t\tif (trimmed !== this.content) {\n\t\t\t\tthis.split(this.start + trimmed.length).edit('', undefined, true);\n\t\t\t\tif (this.edited) {\n\t\t\t\t\t// save the change, if it has been edited\n\t\t\t\t\tthis.edit(trimmed, this.storeName, true);\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} else {\n\t\t\tthis.edit('', undefined, true);\n\n\t\t\tthis.intro = this.intro.replace(rx, '');\n\t\t\tif (this.intro.length) return true;\n\t\t}\n\t}\n\n\ttrimStart(rx) {\n\t\tthis.intro = this.intro.replace(rx, '');\n\t\tif (this.intro.length) return true;\n\n\t\tconst trimmed = this.content.replace(rx, '');\n\n\t\tif (trimmed.length) {\n\t\t\tif (trimmed !== this.content) {\n\t\t\t\tconst newChunk = this.split(this.end - trimmed.length);\n\t\t\t\tif (this.edited) {\n\t\t\t\t\t// save the change, if it has been edited\n\t\t\t\t\tnewChunk.edit(trimmed, this.storeName, true);\n\t\t\t\t}\n\t\t\t\tthis.edit('', undefined, true);\n\t\t\t}\n\t\t\treturn true;\n\t\t} else {\n\t\t\tthis.edit('', undefined, true);\n\n\t\t\tthis.outro = this.outro.replace(rx, '');\n\t\t\tif (this.outro.length) return true;\n\t\t}\n\t}\n}\n","import { encode } from '@jridgewell/sourcemap-codec';\n\nfunction getBtoa() {\n\tif (typeof globalThis !== 'undefined' && typeof globalThis.btoa === 'function') {\n\t\treturn (str) => globalThis.btoa(unescape(encodeURIComponent(str)));\n\t} else if (typeof Buffer === 'function') {\n\t\treturn (str) => Buffer.from(str, 'utf-8').toString('base64');\n\t} else {\n\t\treturn () => {\n\t\t\tthrow new Error('Unsupported environment: `window.btoa` or `Buffer` should be supported.');\n\t\t};\n\t}\n}\n\nconst btoa = /*#__PURE__*/ getBtoa();\n\nexport default class SourceMap {\n\tconstructor(properties) {\n\t\tthis.version = 3;\n\t\tthis.file = properties.file;\n\t\tthis.sources = properties.sources;\n\t\tthis.sourcesContent = properties.sourcesContent;\n\t\tthis.names = properties.names;\n\t\tthis.mappings = encode(properties.mappings);\n\t\tif (typeof properties.x_google_ignoreList !== 'undefined') {\n\t\t\tthis.x_google_ignoreList = properties.x_google_ignoreList;\n\t\t}\n\t\tif (typeof properties.debugId !== 'undefined') {\n\t\t\tthis.debugId = properties.debugId;\n\t\t}\n\t}\n\n\ttoString() {\n\t\treturn JSON.stringify(this);\n\t}\n\n\ttoUrl() {\n\t\treturn 'data:application/json;charset=utf-8;base64,' + btoa(this.toString());\n\t}\n}\n","export default function guessIndent(code) {\n\tconst lines = code.split('\\n');\n\n\tconst tabbed = lines.filter((line) => /^\\t+/.test(line));\n\tconst spaced = lines.filter((line) => /^ {2,}/.test(line));\n\n\tif (tabbed.length === 0 && spaced.length === 0) {\n\t\treturn null;\n\t}\n\n\t// More lines tabbed than spaced? Assume tabs, and\n\t// default to tabs in the case of a tie (or nothing\n\t// to go on)\n\tif (tabbed.length >= spaced.length) {\n\t\treturn '\\t';\n\t}\n\n\t// Otherwise, we need to guess the multiple\n\tconst min = spaced.reduce((previous, current) => {\n\t\tconst numSpaces = /^ +/.exec(current)[0].length;\n\t\treturn Math.min(numSpaces, previous);\n\t}, Infinity);\n\n\treturn new Array(min + 1).join(' ');\n}\n","export default function getRelativePath(from, to) {\n\tconst fromParts = from.split(/[/\\\\]/);\n\tconst toParts = to.split(/[/\\\\]/);\n\n\tfromParts.pop(); // get dirname\n\n\twhile (fromParts[0] === toParts[0]) {\n\t\tfromParts.shift();\n\t\ttoParts.shift();\n\t}\n\n\tif (fromParts.length) {\n\t\tlet i = fromParts.length;\n\t\twhile (i--) fromParts[i] = '..';\n\t}\n\n\treturn fromParts.concat(toParts).join('/');\n}\n","const toString = Object.prototype.toString;\n\nexport default function isObject(thing) {\n\treturn toString.call(thing) === '[object Object]';\n}\n","export default function getLocator(source) {\n\tconst originalLines = source.split('\\n');\n\tconst lineOffsets = [];\n\n\tfor (let i = 0, pos = 0; i < originalLines.length; i++) {\n\t\tlineOffsets.push(pos);\n\t\tpos += originalLines[i].length + 1;\n\t}\n\n\treturn function locate(index) {\n\t\tlet i = 0;\n\t\tlet j = lineOffsets.length;\n\t\twhile (i < j) {\n\t\t\tconst m = (i + j) >> 1;\n\t\t\tif (index < lineOffsets[m]) {\n\t\t\t\tj = m;\n\t\t\t} else {\n\t\t\t\ti = m + 1;\n\t\t\t}\n\t\t}\n\t\tconst line = i - 1;\n\t\tconst column = index - lineOffsets[line];\n\t\treturn { line, column };\n\t};\n}\n","const wordRegex = /\\w/;\n\nexport default class Mappings {\n\tconstructor(hires) {\n\t\tthis.hires = hires;\n\t\tthis.generatedCodeLine = 0;\n\t\tthis.generatedCodeColumn = 0;\n\t\tthis.raw = [];\n\t\tthis.rawSegments = this.raw[this.generatedCodeLine] = [];\n\t\tthis.pending = null;\n\t}\n\n\taddEdit(sourceIndex, content, loc, nameIndex) {\n\t\tif (content.length) {\n\t\t\tconst contentLengthMinusOne = content.length - 1;\n\t\t\tlet contentLineEnd = content.indexOf('\\n', 0);\n\t\t\tlet previousContentLineEnd = -1;\n\t\t\t// Loop through each line in the content and add a segment, but stop if the last line is empty,\n\t\t\t// else code afterwards would fill one line too many\n\t\t\twhile (contentLineEnd >= 0 && contentLengthMinusOne > contentLineEnd) {\n\t\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\t\t\t\tif (nameIndex >= 0) {\n\t\t\t\t\tsegment.push(nameIndex);\n\t\t\t\t}\n\t\t\t\tthis.rawSegments.push(segment);\n\n\t\t\t\tthis.generatedCodeLine += 1;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t\tthis.generatedCodeColumn = 0;\n\n\t\t\t\tpreviousContentLineEnd = contentLineEnd;\n\t\t\t\tcontentLineEnd = content.indexOf('\\n', contentLineEnd + 1);\n\t\t\t}\n\n\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\t\t\tif (nameIndex >= 0) {\n\t\t\t\tsegment.push(nameIndex);\n\t\t\t}\n\t\t\tthis.rawSegments.push(segment);\n\n\t\t\tthis.advance(content.slice(previousContentLineEnd + 1));\n\t\t} else if (this.pending) {\n\t\t\tthis.rawSegments.push(this.pending);\n\t\t\tthis.advance(content);\n\t\t}\n\n\t\tthis.pending = null;\n\t}\n\n\taddUneditedChunk(sourceIndex, chunk, original, loc, sourcemapLocations) {\n\t\tlet originalCharIndex = chunk.start;\n\t\tlet first = true;\n\t\t// when iterating each char, check if it's in a word boundary\n\t\tlet charInHiresBoundary = false;\n\n\t\twhile (originalCharIndex < chunk.end) {\n\t\t\tif (original[originalCharIndex] === '\\n') {\n\t\t\t\tloc.line += 1;\n\t\t\t\tloc.column = 0;\n\t\t\t\tthis.generatedCodeLine += 1;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t\tthis.generatedCodeColumn = 0;\n\t\t\t\tfirst = true;\n\t\t\t\tcharInHiresBoundary = false;\n\t\t\t} else {\n\t\t\t\tif (this.hires || first || sourcemapLocations.has(originalCharIndex)) {\n\t\t\t\t\tconst segment = [this.generatedCodeColumn, sourceIndex, loc.line, loc.column];\n\n\t\t\t\t\tif (this.hires === 'boundary') {\n\t\t\t\t\t\t// in hires \"boundary\", group segments per word boundary than per char\n\t\t\t\t\t\tif (wordRegex.test(original[originalCharIndex])) {\n\t\t\t\t\t\t\t// for first char in the boundary found, start the boundary by pushing a segment\n\t\t\t\t\t\t\tif (!charInHiresBoundary) {\n\t\t\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t\t\t\tcharInHiresBoundary = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// for non-word char, end the boundary by pushing a segment\n\t\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t\t\tcharInHiresBoundary = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.rawSegments.push(segment);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tloc.column += 1;\n\t\t\t\tthis.generatedCodeColumn += 1;\n\t\t\t\tfirst = false;\n\t\t\t}\n\n\t\t\toriginalCharIndex += 1;\n\t\t}\n\n\t\tthis.pending = null;\n\t}\n\n\tadvance(str) {\n\t\tif (!str) return;\n\n\t\tconst lines = str.split('\\n');\n\n\t\tif (lines.length > 1) {\n\t\t\tfor (let i = 0; i < lines.length - 1; i++) {\n\t\t\t\tthis.generatedCodeLine++;\n\t\t\t\tthis.raw[this.generatedCodeLine] = this.rawSegments = [];\n\t\t\t}\n\t\t\tthis.generatedCodeColumn = 0;\n\t\t}\n\n\t\tthis.generatedCodeColumn += lines[lines.length - 1].length;\n\t}\n}\n","import BitSet from './BitSet.js';\nimport Chunk from './Chunk.js';\nimport SourceMap from './SourceMap.js';\nimport guessIndent from './utils/guessIndent.js';\nimport getRelativePath from './utils/getRelativePath.js';\nimport isObject from './utils/isObject.js';\nimport getLocator from './utils/getLocator.js';\nimport Mappings from './utils/Mappings.js';\nimport Stats from './utils/Stats.js';\n\nconst n = '\\n';\n\nconst warned = {\n\tinsertLeft: false,\n\tinsertRight: false,\n\tstoreName: false,\n};\n\nexport default class MagicString {\n\tconstructor(string, options = {}) {\n\t\tconst chunk = new Chunk(0, string.length, string);\n\n\t\tObject.defineProperties(this, {\n\t\t\toriginal: { writable: true, value: string },\n\t\t\toutro: { writable: true, value: '' },\n\t\t\tintro: { writable: true, value: '' },\n\t\t\tfirstChunk: { writable: true, value: chunk },\n\t\t\tlastChunk: { writable: true, value: chunk },\n\t\t\tlastSearchedChunk: { writable: true, value: chunk },\n\t\t\tbyStart: { writable: true, value: {} },\n\t\t\tbyEnd: { writable: true, value: {} },\n\t\t\tfilename: { writable: true, value: options.filename },\n\t\t\tindentExclusionRanges: { writable: true, value: options.indentExclusionRanges },\n\t\t\tsourcemapLocations: { writable: true, value: new BitSet() },\n\t\t\tstoredNames: { writable: true, value: {} },\n\t\t\tindentStr: { writable: true, value: undefined },\n\t\t\tignoreList: { writable: true, value: options.ignoreList },\n\t\t\toffset: { writable: true, value: options.offset || 0 },\n\t\t});\n\n\t\tif (DEBUG) {\n\t\t\tObject.defineProperty(this, 'stats', { value: new Stats() });\n\t\t}\n\n\t\tthis.byStart[0] = chunk;\n\t\tthis.byEnd[string.length] = chunk;\n\t}\n\n\taddSourcemapLocation(char) {\n\t\tthis.sourcemapLocations.add(char);\n\t}\n\n\tappend(content) {\n\t\tif (typeof content !== 'string') throw new TypeError('outro content must be a string');\n\n\t\tthis.outro += content;\n\t\treturn this;\n\t}\n\n\tappendLeft(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tif (DEBUG) this.stats.time('appendLeft');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byEnd[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.appendLeft(content);\n\t\t} else {\n\t\t\tthis.intro += content;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('appendLeft');\n\t\treturn this;\n\t}\n\n\tappendRight(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tif (DEBUG) this.stats.time('appendRight');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byStart[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.appendRight(content);\n\t\t} else {\n\t\t\tthis.outro += content;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('appendRight');\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst cloned = new MagicString(this.original, { filename: this.filename, offset: this.offset });\n\n\t\tlet originalChunk = this.firstChunk;\n\t\tlet clonedChunk = (cloned.firstChunk = cloned.lastSearchedChunk = originalChunk.clone());\n\n\t\twhile (originalChunk) {\n\t\t\tcloned.byStart[clonedChunk.start] = clonedChunk;\n\t\t\tcloned.byEnd[clonedChunk.end] = clonedChunk;\n\n\t\t\tconst nextOriginalChunk = originalChunk.next;\n\t\t\tconst nextClonedChunk = nextOriginalChunk && nextOriginalChunk.clone();\n\n\t\t\tif (nextClonedChunk) {\n\t\t\t\tclonedChunk.next = nextClonedChunk;\n\t\t\t\tnextClonedChunk.previous = clonedChunk;\n\n\t\t\t\tclonedChunk = nextClonedChunk;\n\t\t\t}\n\n\t\t\toriginalChunk = nextOriginalChunk;\n\t\t}\n\n\t\tcloned.lastChunk = clonedChunk;\n\n\t\tif (this.indentExclusionRanges) {\n\t\t\tcloned.indentExclusionRanges = this.indentExclusionRanges.slice();\n\t\t}\n\n\t\tcloned.sourcemapLocations = new BitSet(this.sourcemapLocations);\n\n\t\tcloned.intro = this.intro;\n\t\tcloned.outro = this.outro;\n\n\t\treturn cloned;\n\t}\n\n\tgenerateDecodedMap(options) {\n\t\toptions = options || {};\n\n\t\tconst sourceIndex = 0;\n\t\tconst names = Object.keys(this.storedNames);\n\t\tconst mappings = new Mappings(options.hires);\n\n\t\tconst locate = getLocator(this.original);\n\n\t\tif (this.intro) {\n\t\t\tmappings.advance(this.intro);\n\t\t}\n\n\t\tthis.firstChunk.eachNext((chunk) => {\n\t\t\tconst loc = locate(chunk.start);\n\n\t\t\tif (chunk.intro.length) mappings.advance(chunk.intro);\n\n\t\t\tif (chunk.edited) {\n\t\t\t\tmappings.addEdit(\n\t\t\t\t\tsourceIndex,\n\t\t\t\t\tchunk.content,\n\t\t\t\t\tloc,\n\t\t\t\t\tchunk.storeName ? names.indexOf(chunk.original) : -1,\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tmappings.addUneditedChunk(sourceIndex, chunk, this.original, loc, this.sourcemapLocations);\n\t\t\t}\n\n\t\t\tif (chunk.outro.length) mappings.advance(chunk.outro);\n\t\t});\n\n\t\treturn {\n\t\t\tfile: options.file ? options.file.split(/[/\\\\]/).pop() : undefined,\n\t\t\tsources: [\n\t\t\t\toptions.source ? getRelativePath(options.file || '', options.source) : options.file || '',\n\t\t\t],\n\t\t\tsourcesContent: options.includeContent ? [this.original] : undefined,\n\t\t\tnames,\n\t\t\tmappings: mappings.raw,\n\t\t\tx_google_ignoreList: this.ignoreList ? [sourceIndex] : undefined,\n\t\t};\n\t}\n\n\tgenerateMap(options) {\n\t\treturn new SourceMap(this.generateDecodedMap(options));\n\t}\n\n\t_ensureindentStr() {\n\t\tif (this.indentStr === undefined) {\n\t\t\tthis.indentStr = guessIndent(this.original);\n\t\t}\n\t}\n\n\t_getRawIndentString() {\n\t\tthis._ensureindentStr();\n\t\treturn this.indentStr;\n\t}\n\n\tgetIndentString() {\n\t\tthis._ensureindentStr();\n\t\treturn this.indentStr === null ? '\\t' : this.indentStr;\n\t}\n\n\tindent(indentStr, options) {\n\t\tconst pattern = /^[^\\r\\n]/gm;\n\n\t\tif (isObject(indentStr)) {\n\t\t\toptions = indentStr;\n\t\t\tindentStr = undefined;\n\t\t}\n\n\t\tif (indentStr === undefined) {\n\t\t\tthis._ensureindentStr();\n\t\t\tindentStr = this.indentStr || '\\t';\n\t\t}\n\n\t\tif (indentStr === '') return this; // noop\n\n\t\toptions = options || {};\n\n\t\t// Process exclusion ranges\n\t\tconst isExcluded = {};\n\n\t\tif (options.exclude) {\n\t\t\tconst exclusions =\n\t\t\t\ttypeof options.exclude[0] === 'number' ? [options.exclude] : options.exclude;\n\t\t\texclusions.forEach((exclusion) => {\n\t\t\t\tfor (let i = exclusion[0]; i < exclusion[1]; i += 1) {\n\t\t\t\t\tisExcluded[i] = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tlet shouldIndentNextCharacter = options.indentStart !== false;\n\t\tconst replacer = (match) => {\n\t\t\tif (shouldIndentNextCharacter) return `${indentStr}${match}`;\n\t\t\tshouldIndentNextCharacter = true;\n\t\t\treturn match;\n\t\t};\n\n\t\tthis.intro = this.intro.replace(pattern, replacer);\n\n\t\tlet charIndex = 0;\n\t\tlet chunk = this.firstChunk;\n\n\t\twhile (chunk) {\n\t\t\tconst end = chunk.end;\n\n\t\t\tif (chunk.edited) {\n\t\t\t\tif (!isExcluded[charIndex]) {\n\t\t\t\t\tchunk.content = chunk.content.replace(pattern, replacer);\n\n\t\t\t\t\tif (chunk.content.length) {\n\t\t\t\t\t\tshouldIndentNextCharacter = chunk.content[chunk.content.length - 1] === '\\n';\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcharIndex = chunk.start;\n\n\t\t\t\twhile (charIndex < end) {\n\t\t\t\t\tif (!isExcluded[charIndex]) {\n\t\t\t\t\t\tconst char = this.original[charIndex];\n\n\t\t\t\t\t\tif (char === '\\n') {\n\t\t\t\t\t\t\tshouldIndentNextCharacter = true;\n\t\t\t\t\t\t} else if (char !== '\\r' && shouldIndentNextCharacter) {\n\t\t\t\t\t\t\tshouldIndentNextCharacter = false;\n\n\t\t\t\t\t\t\tif (charIndex === chunk.start) {\n\t\t\t\t\t\t\t\tchunk.prependRight(indentStr);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis._splitChunk(chunk, charIndex);\n\t\t\t\t\t\t\t\tchunk = chunk.next;\n\t\t\t\t\t\t\t\tchunk.prependRight(indentStr);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tcharIndex += 1;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tcharIndex = chunk.end;\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\tthis.outro = this.outro.replace(pattern, replacer);\n\n\t\treturn this;\n\t}\n\n\tinsert() {\n\t\tthrow new Error(\n\t\t\t'magicString.insert(...) is deprecated. Use prependRight(...) or appendLeft(...)',\n\t\t);\n\t}\n\n\tinsertLeft(index, content) {\n\t\tif (!warned.insertLeft) {\n\t\t\tconsole.warn(\n\t\t\t\t'magicString.insertLeft(...) is deprecated. Use magicString.appendLeft(...) instead',\n\t\t\t);\n\t\t\twarned.insertLeft = true;\n\t\t}\n\n\t\treturn this.appendLeft(index, content);\n\t}\n\n\tinsertRight(index, content) {\n\t\tif (!warned.insertRight) {\n\t\t\tconsole.warn(\n\t\t\t\t'magicString.insertRight(...) is deprecated. Use magicString.prependRight(...) instead',\n\t\t\t);\n\t\t\twarned.insertRight = true;\n\t\t}\n\n\t\treturn this.prependRight(index, content);\n\t}\n\n\tmove(start, end, index) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\t\tindex = index + this.offset;\n\n\t\tif (index >= start && index <= end) throw new Error('Cannot move a selection inside itself');\n\n\t\tif (DEBUG) this.stats.time('move');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\t\tthis._split(index);\n\n\t\tconst first = this.byStart[start];\n\t\tconst last = this.byEnd[end];\n\n\t\tconst oldLeft = first.previous;\n\t\tconst oldRight = last.next;\n\n\t\tconst newRight = this.byStart[index];\n\t\tif (!newRight && last === this.lastChunk) return this;\n\t\tconst newLeft = newRight ? newRight.previous : this.lastChunk;\n\n\t\tif (oldLeft) oldLeft.next = oldRight;\n\t\tif (oldRight) oldRight.previous = oldLeft;\n\n\t\tif (newLeft) newLeft.next = first;\n\t\tif (newRight) newRight.previous = last;\n\n\t\tif (!first.previous) this.firstChunk = last.next;\n\t\tif (!last.next) {\n\t\t\tthis.lastChunk = first.previous;\n\t\t\tthis.lastChunk.next = null;\n\t\t}\n\n\t\tfirst.previous = newLeft;\n\t\tlast.next = newRight || null;\n\n\t\tif (!newLeft) this.firstChunk = first;\n\t\tif (!newRight) this.lastChunk = last;\n\n\t\tif (DEBUG) this.stats.timeEnd('move');\n\t\treturn this;\n\t}\n\n\toverwrite(start, end, content, options) {\n\t\toptions = options || {};\n\t\treturn this.update(start, end, content, { ...options, overwrite: !options.contentOnly });\n\t}\n\n\tupdate(start, end, content, options) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('replacement content must be a string');\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (end > this.original.length) throw new Error('end is out of bounds');\n\t\tif (start === end)\n\t\t\tthrow new Error(\n\t\t\t\t'Cannot overwrite a zero-length range – use appendLeft or prependRight instead',\n\t\t\t);\n\n\t\tif (DEBUG) this.stats.time('overwrite');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tif (options === true) {\n\t\t\tif (!warned.storeName) {\n\t\t\t\tconsole.warn(\n\t\t\t\t\t'The final argument to magicString.overwrite(...) should be an options object. See https://github.com/rich-harris/magic-string',\n\t\t\t\t);\n\t\t\t\twarned.storeName = true;\n\t\t\t}\n\n\t\t\toptions = { storeName: true };\n\t\t}\n\t\tconst storeName = options !== undefined ? options.storeName : false;\n\t\tconst overwrite = options !== undefined ? options.overwrite : false;\n\n\t\tif (storeName) {\n\t\t\tconst original = this.original.slice(start, end);\n\t\t\tObject.defineProperty(this.storedNames, original, {\n\t\t\t\twritable: true,\n\t\t\t\tvalue: true,\n\t\t\t\tenumerable: true,\n\t\t\t});\n\t\t}\n\n\t\tconst first = this.byStart[start];\n\t\tconst last = this.byEnd[end];\n\n\t\tif (first) {\n\t\t\tlet chunk = first;\n\t\t\twhile (chunk !== last) {\n\t\t\t\tif (chunk.next !== this.byStart[chunk.end]) {\n\t\t\t\t\tthrow new Error('Cannot overwrite across a split point');\n\t\t\t\t}\n\t\t\t\tchunk = chunk.next;\n\t\t\t\tchunk.edit('', false);\n\t\t\t}\n\n\t\t\tfirst.edit(content, storeName, !overwrite);\n\t\t} else {\n\t\t\t// must be inserting at the end\n\t\t\tconst newChunk = new Chunk(start, end, '').edit(content, storeName);\n\n\t\t\t// TODO last chunk in the array may not be the last chunk, if it's moved...\n\t\t\tlast.next = newChunk;\n\t\t\tnewChunk.previous = last;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('overwrite');\n\t\treturn this;\n\t}\n\n\tprepend(content) {\n\t\tif (typeof content !== 'string') throw new TypeError('outro content must be a string');\n\n\t\tthis.intro = content + this.intro;\n\t\treturn this;\n\t}\n\n\tprependLeft(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tif (DEBUG) this.stats.time('insertRight');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byEnd[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.prependLeft(content);\n\t\t} else {\n\t\t\tthis.intro = content + this.intro;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('insertRight');\n\t\treturn this;\n\t}\n\n\tprependRight(index, content) {\n\t\tindex = index + this.offset;\n\n\t\tif (typeof content !== 'string') throw new TypeError('inserted content must be a string');\n\n\t\tif (DEBUG) this.stats.time('insertRight');\n\n\t\tthis._split(index);\n\n\t\tconst chunk = this.byStart[index];\n\n\t\tif (chunk) {\n\t\t\tchunk.prependRight(content);\n\t\t} else {\n\t\t\tthis.outro = content + this.outro;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('insertRight');\n\t\treturn this;\n\t}\n\n\tremove(start, end) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (start === end) return this;\n\n\t\tif (start < 0 || end > this.original.length) throw new Error('Character is out of bounds');\n\t\tif (start > end) throw new Error('end must be greater than start');\n\n\t\tif (DEBUG) this.stats.time('remove');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tlet chunk = this.byStart[start];\n\n\t\twhile (chunk) {\n\t\t\tchunk.intro = '';\n\t\t\tchunk.outro = '';\n\t\t\tchunk.edit('');\n\n\t\t\tchunk = end > chunk.end ? this.byStart[chunk.end] : null;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('remove');\n\t\treturn this;\n\t}\n\n\treset(start, end) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tif (start === end) return this;\n\n\t\tif (start < 0 || end > this.original.length) throw new Error('Character is out of bounds');\n\t\tif (start > end) throw new Error('end must be greater than start');\n\n\t\tif (DEBUG) this.stats.time('reset');\n\n\t\tthis._split(start);\n\t\tthis._split(end);\n\n\t\tlet chunk = this.byStart[start];\n\n\t\twhile (chunk) {\n\t\t\tchunk.reset();\n\n\t\t\tchunk = end > chunk.end ? this.byStart[chunk.end] : null;\n\t\t}\n\n\t\tif (DEBUG) this.stats.timeEnd('reset');\n\t\treturn this;\n\t}\n\n\tlastChar() {\n\t\tif (this.outro.length) return this.outro[this.outro.length - 1];\n\t\tlet chunk = this.lastChunk;\n\t\tdo {\n\t\t\tif (chunk.outro.length) return chunk.outro[chunk.outro.length - 1];\n\t\t\tif (chunk.content.length) return chunk.content[chunk.content.length - 1];\n\t\t\tif (chunk.intro.length) return chunk.intro[chunk.intro.length - 1];\n\t\t} while ((chunk = chunk.previous));\n\t\tif (this.intro.length) return this.intro[this.intro.length - 1];\n\t\treturn '';\n\t}\n\n\tlastLine() {\n\t\tlet lineIndex = this.outro.lastIndexOf(n);\n\t\tif (lineIndex !== -1) return this.outro.substr(lineIndex + 1);\n\t\tlet lineStr = this.outro;\n\t\tlet chunk = this.lastChunk;\n\t\tdo {\n\t\t\tif (chunk.outro.length > 0) {\n\t\t\t\tlineIndex = chunk.outro.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.outro.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.outro + lineStr;\n\t\t\t}\n\n\t\t\tif (chunk.content.length > 0) {\n\t\t\t\tlineIndex = chunk.content.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.content.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.content + lineStr;\n\t\t\t}\n\n\t\t\tif (chunk.intro.length > 0) {\n\t\t\t\tlineIndex = chunk.intro.lastIndexOf(n);\n\t\t\t\tif (lineIndex !== -1) return chunk.intro.substr(lineIndex + 1) + lineStr;\n\t\t\t\tlineStr = chunk.intro + lineStr;\n\t\t\t}\n\t\t} while ((chunk = chunk.previous));\n\t\tlineIndex = this.intro.lastIndexOf(n);\n\t\tif (lineIndex !== -1) return this.intro.substr(lineIndex + 1) + lineStr;\n\t\treturn this.intro + lineStr;\n\t}\n\n\tslice(start = 0, end = this.original.length - this.offset) {\n\t\tstart = start + this.offset;\n\t\tend = end + this.offset;\n\n\t\tif (this.original.length !== 0) {\n\t\t\twhile (start < 0) start += this.original.length;\n\t\t\twhile (end < 0) end += this.original.length;\n\t\t}\n\n\t\tlet result = '';\n\n\t\t// find start chunk\n\t\tlet chunk = this.firstChunk;\n\t\twhile (chunk && (chunk.start > start || chunk.end <= start)) {\n\t\t\t// found end chunk before start\n\t\t\tif (chunk.start < end && chunk.end >= end) {\n\t\t\t\treturn result;\n\t\t\t}\n\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\tif (chunk && chunk.edited && chunk.start !== start)\n\t\t\tthrow new Error(`Cannot use replaced character ${start} as slice start anchor.`);\n\n\t\tconst startChunk = chunk;\n\t\twhile (chunk) {\n\t\t\tif (chunk.intro && (startChunk !== chunk || chunk.start === start)) {\n\t\t\t\tresult += chunk.intro;\n\t\t\t}\n\n\t\t\tconst containsEnd = chunk.start < end && chunk.end >= end;\n\t\t\tif (containsEnd && chunk.edited && chunk.end !== end)\n\t\t\t\tthrow new Error(`Cannot use replaced character ${end} as slice end anchor.`);\n\n\t\t\tconst sliceStart = startChunk === chunk ? start - chunk.start : 0;\n\t\t\tconst sliceEnd = containsEnd ? chunk.content.length + end - chunk.end : chunk.content.length;\n\n\t\t\tresult += chunk.content.slice(sliceStart, sliceEnd);\n\n\t\t\tif (chunk.outro && (!containsEnd || chunk.end === end)) {\n\t\t\t\tresult += chunk.outro;\n\t\t\t}\n\n\t\t\tif (containsEnd) {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t// TODO deprecate this? not really very useful\n\tsnip(start, end) {\n\t\tconst clone = this.clone();\n\t\tclone.remove(0, start);\n\t\tclone.remove(end, clone.original.length);\n\n\t\treturn clone;\n\t}\n\n\t_split(index) {\n\t\tif (this.byStart[index] || this.byEnd[index]) return;\n\n\t\tif (DEBUG) this.stats.time('_split');\n\n\t\tlet chunk = this.lastSearchedChunk;\n\t\tconst searchForward = index > chunk.end;\n\n\t\twhile (chunk) {\n\t\t\tif (chunk.contains(index)) return this._splitChunk(chunk, index);\n\n\t\t\tchunk = searchForward ? this.byStart[chunk.end] : this.byEnd[chunk.start];\n\t\t}\n\t}\n\n\t_splitChunk(chunk, index) {\n\t\tif (chunk.edited && chunk.content.length) {\n\t\t\t// zero-length edited chunks are a special case (overlapping replacements)\n\t\t\tconst loc = getLocator(this.original)(index);\n\t\t\tthrow new Error(\n\t\t\t\t`Cannot split a chunk that has already been edited (${loc.line}:${loc.column} – \"${chunk.original}\")`,\n\t\t\t);\n\t\t}\n\n\t\tconst newChunk = chunk.split(index);\n\n\t\tthis.byEnd[index] = chunk;\n\t\tthis.byStart[index] = newChunk;\n\t\tthis.byEnd[newChunk.end] = newChunk;\n\n\t\tif (chunk === this.lastChunk) this.lastChunk = newChunk;\n\n\t\tthis.lastSearchedChunk = chunk;\n\t\tif (DEBUG) this.stats.timeEnd('_split');\n\t\treturn true;\n\t}\n\n\ttoString() {\n\t\tlet str = this.intro;\n\n\t\tlet chunk = this.firstChunk;\n\t\twhile (chunk) {\n\t\t\tstr += chunk.toString();\n\t\t\tchunk = chunk.next;\n\t\t}\n\n\t\treturn str + this.outro;\n\t}\n\n\tisEmpty() {\n\t\tlet chunk = this.firstChunk;\n\t\tdo {\n\t\t\tif (\n\t\t\t\t(chunk.intro.length && chunk.intro.trim()) ||\n\t\t\t\t(chunk.content.length && chunk.content.trim()) ||\n\t\t\t\t(chunk.outro.length && chunk.outro.trim())\n\t\t\t)\n\t\t\t\treturn false;\n\t\t} while ((chunk = chunk.next));\n\t\treturn true;\n\t}\n\n\tlength() {\n\t\tlet chunk = this.firstChunk;\n\t\tlet length = 0;\n\t\tdo {\n\t\t\tlength += chunk.intro.length + chunk.content.length + chunk.outro.length;\n\t\t} while ((chunk = chunk.next));\n\t\treturn length;\n\t}\n\n\ttrimLines() {\n\t\treturn this.trim('[\\\\r\\\\n]');\n\t}\n\n\ttrim(charType) {\n\t\treturn this.trimStart(charType).trimEnd(charType);\n\t}\n\n\ttrimEndAborted(charType) {\n\t\tconst rx = new RegExp((charType || '\\\\s') + '+$');\n\n\t\tthis.outro = this.outro.replace(rx, '');\n\t\tif (this.outro.length) return true;\n\n\t\tlet chunk = this.lastChunk;\n\n\t\tdo {\n\t\t\tconst end = chunk.end;\n\t\t\tconst aborted = chunk.trimEnd(rx);\n\n\t\t\t// if chunk was trimmed, we have a new lastChunk\n\t\t\tif (chunk.end !== end) {\n\t\t\t\tif (this.lastChunk === chunk) {\n\t\t\t\t\tthis.lastChunk = chunk.next;\n\t\t\t\t}\n\n\t\t\t\tthis.byEnd[chunk.end] = chunk;\n\t\t\t\tthis.byStart[chunk.next.start] = chunk.next;\n\t\t\t\tthis.byEnd[chunk.next.end] = chunk.next;\n\t\t\t}\n\n\t\t\tif (aborted) return true;\n\t\t\tchunk = chunk.previous;\n\t\t} while (chunk);\n\n\t\treturn false;\n\t}\n\n\ttrimEnd(charType) {\n\t\tthis.trimEndAborted(charType);\n\t\treturn this;\n\t}\n\ttrimStartAborted(charType) {\n\t\tconst rx = new RegExp('^' + (charType || '\\\\s') + '+');\n\n\t\tthis.intro = this.intro.replace(rx, '');\n\t\tif (this.intro.length) return true;\n\n\t\tlet chunk = this.firstChunk;\n\n\t\tdo {\n\t\t\tconst end = chunk.end;\n\t\t\tconst aborted = chunk.trimStart(rx);\n\n\t\t\tif (chunk.end !== end) {\n\t\t\t\t// special case...\n\t\t\t\tif (chunk === this.lastChunk) this.lastChunk = chunk.next;\n\n\t\t\t\tthis.byEnd[chunk.end] = chunk;\n\t\t\t\tthis.byStart[chunk.next.start] = chunk.next;\n\t\t\t\tthis.byEnd[chunk.next.end] = chunk.next;\n\t\t\t}\n\n\t\t\tif (aborted) return true;\n\t\t\tchunk = chunk.next;\n\t\t} while (chunk);\n\n\t\treturn false;\n\t}\n\n\ttrimStart(charType) {\n\t\tthis.trimStartAborted(charType);\n\t\treturn this;\n\t}\n\n\thasChanged() {\n\t\treturn this.original !== this.toString();\n\t}\n\n\t_replaceRegexp(searchValue, replacement) {\n\t\tfunction getReplacement(match, str) {\n\t\t\tif (typeof replacement === 'string') {\n\t\t\t\treturn replacement.replace(/\\$(\\$|&|\\d+)/g, (_, i) => {\n\t\t\t\t\t// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace#specifying_a_string_as_a_parameter\n\t\t\t\t\tif (i === '$') return '$';\n\t\t\t\t\tif (i === '&') return match[0];\n\t\t\t\t\tconst num = +i;\n\t\t\t\t\tif (num < match.length) return match[+i];\n\t\t\t\t\treturn `$${i}`;\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\treturn replacement(...match, match.index, str, match.groups);\n\t\t\t}\n\t\t}\n\t\tfunction matchAll(re, str) {\n\t\t\tlet match;\n\t\t\tconst matches = [];\n\t\t\twhile ((match = re.exec(str))) {\n\t\t\t\tmatches.push(match);\n\t\t\t}\n\t\t\treturn matches;\n\t\t}\n\t\tif (searchValue.global) {\n\t\t\tconst matches = matchAll(searchValue, this.original);\n\t\t\tmatches.forEach((match) => {\n\t\t\t\tif (match.index != null) {\n\t\t\t\t\tconst replacement = getReplacement(match, this.original);\n\t\t\t\t\tif (replacement !== match[0]) {\n\t\t\t\t\t\tthis.overwrite(match.index, match.index + match[0].length, replacement);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t} else {\n\t\t\tconst match = this.original.match(searchValue);\n\t\t\tif (match && match.index != null) {\n\t\t\t\tconst replacement = getReplacement(match, this.original);\n\t\t\t\tif (replacement !== match[0]) {\n\t\t\t\t\tthis.overwrite(match.index, match.index + match[0].length, replacement);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn this;\n\t}\n\n\t_replaceString(string, replacement) {\n\t\tconst { original } = this;\n\t\tconst index = original.indexOf(string);\n\n\t\tif (index !== -1) {\n\t\t\tthis.overwrite(index, index + string.length, replacement);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\treplace(searchValue, replacement) {\n\t\tif (typeof searchValue === 'string') {\n\t\t\treturn this._replaceString(searchValue, replacement);\n\t\t}\n\n\t\treturn this._replaceRegexp(searchValue, replacement);\n\t}\n\n\t_replaceAllString(string, replacement) {\n\t\tconst { original } = this;\n\t\tconst stringLength = string.length;\n\t\tfor (\n\t\t\tlet index = original.indexOf(string);\n\t\t\tindex !== -1;\n\t\t\tindex = original.indexOf(string, index + stringLength)\n\t\t) {\n\t\t\tconst previous = original.slice(index, index + stringLength);\n\t\t\tif (previous !== replacement) this.overwrite(index, index + stringLength, replacement);\n\t\t}\n\n\t\treturn this;\n\t}\n\n\treplaceAll(searchValue, replacement) {\n\t\tif (typeof searchValue === 'string') {\n\t\t\treturn this._replaceAllString(searchValue, replacement);\n\t\t}\n\n\t\tif (!searchValue.global) {\n\t\t\tthrow new TypeError(\n\t\t\t\t'MagicString.prototype.replaceAll called with a non-global RegExp argument',\n\t\t\t);\n\t\t}\n\n\t\treturn this._replaceRegexp(searchValue, replacement);\n\t}\n}\n","import MagicString from './MagicString.js';\nimport SourceMap from './SourceMap.js';\nimport getRelativePath from './utils/getRelativePath.js';\nimport isObject from './utils/isObject.js';\nimport getLocator from './utils/getLocator.js';\nimport Mappings from './utils/Mappings.js';\n\nconst hasOwnProp = Object.prototype.hasOwnProperty;\n\nexport default class Bundle {\n\tconstructor(options = {}) {\n\t\tthis.intro = options.intro || '';\n\t\tthis.separator = options.separator !== undefined ? options.separator : '\\n';\n\t\tthis.sources = [];\n\t\tthis.uniqueSources = [];\n\t\tthis.uniqueSourceIndexByFilename = {};\n\t}\n\n\taddSource(source) {\n\t\tif (source instanceof MagicString) {\n\t\t\treturn this.addSource({\n\t\t\t\tcontent: source,\n\t\t\t\tfilename: source.filename,\n\t\t\t\tseparator: this.separator,\n\t\t\t});\n\t\t}\n\n\t\tif (!isObject(source) || !source.content) {\n\t\t\tthrow new Error(\n\t\t\t\t'bundle.addSource() takes an object with a `content` property, which should be an instance of MagicString, and an optional `filename`',\n\t\t\t);\n\t\t}\n\n\t\t['filename', 'ignoreList', 'indentExclusionRanges', 'separator'].forEach((option) => {\n\t\t\tif (!hasOwnProp.call(source, option)) source[option] = source.content[option];\n\t\t});\n\n\t\tif (source.separator === undefined) {\n\t\t\t// TODO there's a bunch of this sort of thing, needs cleaning up\n\t\t\tsource.separator = this.separator;\n\t\t}\n\n\t\tif (source.filename) {\n\t\t\tif (!hasOwnProp.call(this.uniqueSourceIndexByFilename, source.filename)) {\n\t\t\t\tthis.uniqueSourceIndexByFilename[source.filename] = this.uniqueSources.length;\n\t\t\t\tthis.uniqueSources.push({ filename: source.filename, content: source.content.original });\n\t\t\t} else {\n\t\t\t\tconst uniqueSource = this.uniqueSources[this.uniqueSourceIndexByFilename[source.filename]];\n\t\t\t\tif (source.content.original !== uniqueSource.content) {\n\t\t\t\t\tthrow new Error(`Illegal source: same filename (${source.filename}), different contents`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.sources.push(source);\n\t\treturn this;\n\t}\n\n\tappend(str, options) {\n\t\tthis.addSource({\n\t\t\tcontent: new MagicString(str),\n\t\t\tseparator: (options && options.separator) || '',\n\t\t});\n\n\t\treturn this;\n\t}\n\n\tclone() {\n\t\tconst bundle = new Bundle({\n\t\t\tintro: this.intro,\n\t\t\tseparator: this.separator,\n\t\t});\n\n\t\tthis.sources.forEach((source) => {\n\t\t\tbundle.addSource({\n\t\t\t\tfilename: source.filename,\n\t\t\t\tcontent: source.content.clone(),\n\t\t\t\tseparator: source.separator,\n\t\t\t});\n\t\t});\n\n\t\treturn bundle;\n\t}\n\n\tgenerateDecodedMap(options = {}) {\n\t\tconst names = [];\n\t\tlet x_google_ignoreList = undefined;\n\t\tthis.sources.forEach((source) => {\n\t\t\tObject.keys(source.content.storedNames).forEach((name) => {\n\t\t\t\tif (!~names.indexOf(name)) names.push(name);\n\t\t\t});\n\t\t});\n\n\t\tconst mappings = new Mappings(options.hires);\n\n\t\tif (this.intro) {\n\t\t\tmappings.advance(this.intro);\n\t\t}\n\n\t\tthis.sources.forEach((source, i) => {\n\t\t\tif (i > 0) {\n\t\t\t\tmappings.advance(this.separator);\n\t\t\t}\n\n\t\t\tconst sourceIndex = source.filename ? this.uniqueSourceIndexByFilename[source.filename] : -1;\n\t\t\tconst magicString = source.content;\n\t\t\tconst locate = getLocator(magicString.original);\n\n\t\t\tif (magicString.intro) {\n\t\t\t\tmappings.advance(magicString.intro);\n\t\t\t}\n\n\t\t\tmagicString.firstChunk.eachNext((chunk) => {\n\t\t\t\tconst loc = locate(chunk.start);\n\n\t\t\t\tif (chunk.intro.length) mappings.advance(chunk.intro);\n\n\t\t\t\tif (source.filename) {\n\t\t\t\t\tif (chunk.edited) {\n\t\t\t\t\t\tmappings.addEdit(\n\t\t\t\t\t\t\tsourceIndex,\n\t\t\t\t\t\t\tchunk.content,\n\t\t\t\t\t\t\tloc,\n\t\t\t\t\t\t\tchunk.storeName ? names.indexOf(chunk.original) : -1,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tmappings.addUneditedChunk(\n\t\t\t\t\t\t\tsourceIndex,\n\t\t\t\t\t\t\tchunk,\n\t\t\t\t\t\t\tmagicString.original,\n\t\t\t\t\t\t\tloc,\n\t\t\t\t\t\t\tmagicString.sourcemapLocations,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tmappings.advance(chunk.content);\n\t\t\t\t}\n\n\t\t\t\tif (chunk.outro.length) mappings.advance(chunk.outro);\n\t\t\t});\n\n\t\t\tif (magicString.outro) {\n\t\t\t\tmappings.advance(magicString.outro);\n\t\t\t}\n\n\t\t\tif (source.ignoreList && sourceIndex !== -1) {\n\t\t\t\tif (x_google_ignoreList === undefined) {\n\t\t\t\t\tx_google_ignoreList = [];\n\t\t\t\t}\n\t\t\t\tx_google_ignoreList.push(sourceIndex);\n\t\t\t}\n\t\t});\n\n\t\treturn {\n\t\t\tfile: options.file ? options.file.split(/[/\\\\]/).pop() : undefined,\n\t\t\tsources: this.uniqueSources.map((source) => {\n\t\t\t\treturn options.file ? getRelativePath(options.file, source.filename) : source.filename;\n\t\t\t}),\n\t\t\tsourcesContent: this.uniqueSources.map((source) => {\n\t\t\t\treturn options.includeContent ? source.content : null;\n\t\t\t}),\n\t\t\tnames,\n\t\t\tmappings: mappings.raw,\n\t\t\tx_google_ignoreList,\n\t\t};\n\t}\n\n\tgenerateMap(options) {\n\t\treturn new SourceMap(this.generateDecodedMap(options));\n\t}\n\n\tgetIndentString() {\n\t\tconst indentStringCounts = {};\n\n\t\tthis.sources.forEach((source) => {\n\t\t\tconst indentStr = source.content._getRawIndentString();\n\n\t\t\tif (indentStr === null) return;\n\n\t\t\tif (!indentStringCounts[indentStr]) indentStringCounts[indentStr] = 0;\n\t\t\tindentStringCounts[indentStr] += 1;\n\t\t});\n\n\t\treturn (\n\t\t\tObject.keys(indentStringCounts).sort((a, b) => {\n\t\t\t\treturn indentStringCounts[a] - indentStringCounts[b];\n\t\t\t})[0] || '\\t'\n\t\t);\n\t}\n\n\tindent(indentStr) {\n\t\tif (!arguments.length) {\n\t\t\tindentStr = this.getIndentString();\n\t\t}\n\n\t\tif (indentStr === '') return this; // noop\n\n\t\tlet trailingNewline = !this.intro || this.intro.slice(-1) === '\\n';\n\n\t\tthis.sources.forEach((source, i) => {\n\t\t\tconst separator = source.separator !== undefined ? source.separator : this.separator;\n\t\t\tconst indentStart = trailingNewline || (i > 0 && /\\r?\\n$/.test(separator));\n\n\t\t\tsource.content.indent(indentStr, {\n\t\t\t\texclude: source.indentExclusionRanges,\n\t\t\t\tindentStart, //: trailingNewline || /\\r?\\n$/.test( separator ) //true///\\r?\\n/.test( separator )\n\t\t\t});\n\n\t\t\ttrailingNewline = source.content.lastChar() === '\\n';\n\t\t});\n\n\t\tif (this.intro) {\n\t\t\tthis.intro =\n\t\t\t\tindentStr +\n\t\t\t\tthis.intro.replace(/^[^\\n]/gm, (match, index) => {\n\t\t\t\t\treturn index > 0 ? indentStr + match : match;\n\t\t\t\t});\n\t\t}\n\n\t\treturn this;\n\t}\n\n\tprepend(str) {\n\t\tthis.intro = str + this.intro;\n\t\treturn this;\n\t}\n\n\ttoString() {\n\t\tconst body = this.sources\n\t\t\t.map((source, i) => {\n\t\t\t\tconst separator = source.separator !== undefined ? source.separator : this.separator;\n\t\t\t\tconst str = (i > 0 ? separator : '') + source.content.toString();\n\n\t\t\t\treturn str;\n\t\t\t})\n\t\t\t.join('');\n\n\t\treturn this.intro + body;\n\t}\n\n\tisEmpty() {\n\t\tif (this.intro.length && this.intro.trim()) return false;\n\t\tif (this.sources.some((source) => !source.content.isEmpty())) return false;\n\t\treturn true;\n\t}\n\n\tlength() {\n\t\treturn this.sources.reduce(\n\t\t\t(length, source) => length + source.content.length(),\n\t\t\tthis.intro.length,\n\t\t);\n\t}\n\n\ttrimLines() {\n\t\treturn this.trim('[\\\\r\\\\n]');\n\t}\n\n\ttrim(charType) {\n\t\treturn this.trimStart(charType).trimEnd(charType);\n\t}\n\n\ttrimStart(charType) {\n\t\tconst rx = new RegExp('^' + (charType || '\\\\s') + '+');\n\t\tthis.intro = this.intro.replace(rx, '');\n\n\t\tif (!this.intro) {\n\t\t\tlet source;\n\t\t\tlet i = 0;\n\n\t\t\tdo {\n\t\t\t\tsource = this.sources[i++];\n\t\t\t\tif (!source) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} while (!source.content.trimStartAborted(charType));\n\t\t}\n\n\t\treturn this;\n\t}\n\n\ttrimEnd(charType) {\n\t\tconst rx = new RegExp((charType || '\\\\s') + '+$');\n\n\t\tlet source;\n\t\tlet i = this.sources.length - 1;\n\n\t\tdo {\n\t\t\tsource = this.sources[i--];\n\t\t\tif (!source) {\n\t\t\t\tthis.intro = this.intro.replace(rx, '');\n\t\t\t\tbreak;\n\t\t\t}\n\t\t} while (!source.content.trimEndAborted(charType));\n\n\t\treturn this;\n\t}\n}\n","import type { Logger } from \"pino\"\nimport { dirname, relative, resolve } from \"node:path\"\nimport { readFile, writeFile } from \"node:fs/promises\"\nimport { fileURLToPath, pathToFileURL } from \"node:url\"\nimport { readPackageJSON, resolvePackageJSON, type PackageJson } from \"pkg-types\"\nimport { sha256 } from \"crypto-hash\"\nimport { resolve as importMetaResolve } from \"import-meta-resolve\"\n\nexport type HighstateManifestJson = {\n sourceHashes?: Record<string, string>\n}\n\ntype FileDependency =\n | {\n type: \"relative\"\n id: string\n fullPath: string\n }\n | {\n type: \"npm\"\n id: string\n package: string\n }\n\nexport class SourceHashCalculator {\n private readonly dependencyHashes = new Map<string, Promise<string>>()\n private readonly fileHashes = new Map<string, Promise<string>>()\n\n constructor(\n private readonly packageJsonPath: string,\n private readonly packageJson: PackageJson,\n private readonly logger: Logger,\n ) {}\n\n async writeHighstateManifest(distBasePath: string, distPaths: string[]): Promise<void> {\n const promises: Promise<{ distPath: string; hash: string }>[] = []\n\n for (const distPath of distPaths) {\n const fullPath = resolve(distPath)\n\n promises.push(\n this.getFileHash(fullPath).then(hash => ({\n distPath,\n hash,\n })),\n )\n }\n\n const manifest: HighstateManifestJson = {\n sourceHashes: {},\n }\n\n const hashes = await Promise.all(promises)\n for (const { distPath, hash } of hashes) {\n manifest.sourceHashes![distPath] = hash\n }\n\n const manifestPath = resolve(distBasePath, \"highstate.manifest.json\")\n await writeFile(manifestPath, JSON.stringify(manifest, null, 2), \"utf8\")\n }\n\n private async getFileHash(fullPath: string): Promise<string> {\n const existingHash = this.fileHashes.get(fullPath)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateFileHash(fullPath)\n this.fileHashes.set(fullPath, hash)\n\n return hash\n }\n\n private async calculateFileHash(fullPath: string): Promise<string> {\n const content = await readFile(fullPath, \"utf8\")\n const fileDeps = this.parseDependencies(fullPath, content)\n\n const hashes = await Promise.all([\n sha256(content),\n ...fileDeps.map(dep => this.getDependencyHash(dep)),\n ])\n\n return await sha256(hashes.join(\"\"))\n }\n\n getDependencyHash(dependency: FileDependency): Promise<string> {\n const existingHash = this.dependencyHashes.get(dependency.id)\n if (existingHash) {\n return existingHash\n }\n\n const hash = this.calculateDependencyHash(dependency)\n this.dependencyHashes.set(dependency.id, hash)\n\n return hash\n }\n\n private async calculateDependencyHash(dependency: FileDependency): Promise<string> {\n switch (dependency.type) {\n case \"relative\": {\n return await this.getFileHash(dependency.fullPath)\n }\n case \"npm\": {\n let resolvedUrl\n try {\n const baseUrl = pathToFileURL(dirname(this.packageJsonPath))\n\n resolvedUrl = importMetaResolve(dependency.package, baseUrl.toString())\n } catch (error) {\n this.logger.error(`failed to resolve package \"%s\"`, dependency.package)\n throw error\n }\n\n if (resolvedUrl.startsWith(\"node:\")) {\n throw new Error(`\"${dependency.package}\" imported without \"node:\" prefix`)\n }\n\n const resolvedPath = fileURLToPath(resolvedUrl)\n\n const [depPackageJsonPath, depPackageJson] = await this.getPackageJson(resolvedPath)\n const packageName = depPackageJson.name!\n\n this.logger.debug(\n `resolved package.json for \"%s\": \"%s\"`,\n dependency.package,\n depPackageJsonPath,\n )\n\n if (\n !this.packageJson.dependencies?.[packageName] &&\n !this.packageJson.peerDependencies?.[packageName]\n ) {\n this.logger.warn(`package \"%s\" is not listed in package.json dependencies`, packageName)\n }\n\n let relativePath = relative(dirname(depPackageJsonPath), resolvedPath)\n relativePath = relativePath.startsWith(\".\") ? relativePath : `./${relativePath}`\n\n const highstateManifestPath = resolve(\n dirname(depPackageJsonPath),\n \"dist\",\n \"highstate.manifest.json\",\n )\n\n let manifest: HighstateManifestJson | undefined\n try {\n const manifestContent = await readFile(highstateManifestPath, \"utf8\")\n manifest = JSON.parse(manifestContent) as HighstateManifestJson\n } catch (error) {\n this.logger.debug(\n { error },\n `failed to read highstate manifest for package \"%s\"`,\n packageName,\n )\n }\n\n const sourceHash = manifest?.sourceHashes?.[relativePath]\n\n if (sourceHash) {\n this.logger.debug(`resolved source hash for package \"%s\"`, packageName)\n return sourceHash\n }\n\n // use the package version as a fallback hash\n // this case will be applied for most npm packages\n this.logger.debug(`using package version as a fallback hash for \"%s\"`, packageName)\n return depPackageJson.version ?? \"0.0.0\"\n }\n }\n }\n\n private async getPackageJson(basePath: string): Promise<[string, PackageJson]> {\n while (true) {\n const packageJson = await readPackageJSON(basePath)\n if (packageJson.name) {\n const packageJsonPath = await resolvePackageJSON(basePath)\n\n return [packageJsonPath, packageJson]\n }\n\n basePath = resolve(dirname(basePath), \"..\")\n }\n }\n\n private parseDependencies(filePath: string, content: string): FileDependency[] {\n type DependencyMatch = {\n relativePath?: string\n nodeBuiltin?: string\n npmPackage?: string\n }\n\n const dependencyRegex =\n /^[ \\t]*import[\\s\\S]*?\\bfrom\\s*[\"']((?<relativePath>\\.\\.?\\/[^\"']+)|(?<nodeBuiltin>node:[^\"']+)|(?<npmPackage>[^\"']+))[\"']/gm\n\n const matches = content.matchAll(dependencyRegex)\n const dependencies: FileDependency[] = []\n\n for (const match of matches) {\n const { nodeBuiltin, npmPackage, relativePath } = match.groups as DependencyMatch\n\n if (relativePath) {\n const fullPath = resolve(dirname(filePath), relativePath)\n\n dependencies.push({\n type: \"relative\",\n id: `relative:${fullPath}`,\n fullPath,\n })\n } else if (npmPackage) {\n dependencies.push({\n type: \"npm\",\n id: `npm:${npmPackage}`,\n package: npmPackage,\n })\n } else if (nodeBuiltin) {\n // ignore node built-in modules\n }\n }\n\n return dependencies\n }\n}\n","import type { Plugin } from \"esbuild\"\nimport { readFile } from \"node:fs/promises\"\nimport { logger } from \"./logger\"\n\nexport function createBinTransformerPlugin(sourceFilePaths: string[]): Plugin {\n const filter = new RegExp(`(${sourceFilePaths.join(\"|\")})$`)\n\n logger.debug(\"created bin transformer plugin with filter: %s\", filter)\n\n return {\n name: \"bin-transformer\",\n setup(build) {\n build.onLoad({ filter }, async args => {\n const content = await readFile(args.path, \"utf-8\")\n\n return {\n contents: `#!/usr/bin/env node\\n\\n${content}`,\n loader: \"ts\",\n }\n })\n },\n }\n}\n","import type { Plugin } from \"esbuild\"\nimport { Command, Option } from \"clipanion\"\nimport { readPackageJSON, resolvePackageJSON } from \"pkg-types\"\nimport { mapKeys, mapValues, pipe } from \"remeda\"\nimport { build } from \"tsup\"\nimport {\n createBinTransformerPlugin,\n logger,\n schemaTransformerPlugin,\n SourceHashCalculator,\n} from \"../shared\"\n\nexport class BuildCommand extends Command {\n static paths = [[\"build\"]]\n\n static usage = Command.Usage({\n category: \"Builder\",\n description: \"Builds the Highstate library or unit package.\",\n })\n\n watch = Option.Boolean(\"--watch\", false)\n library = Option.Boolean(\"--library\", false)\n\n async execute(): Promise<void> {\n const packageJson = await readPackageJSON()\n const exports = packageJson.exports\n let bin = packageJson.bin\n\n if (!packageJson.name) {\n throw new Error(\"package.json must have a name field\")\n }\n\n if (!exports && !bin) {\n logger.warn(\"no exports or bin found in package.json\")\n return\n }\n\n if (exports !== undefined && (typeof exports !== \"object\" || Array.isArray(exports))) {\n throw new Error(\"Exports field in package.json must be an object\")\n }\n\n if (bin !== undefined && typeof bin !== \"object\") {\n bin = { [packageJson.name]: bin }\n }\n\n const entry = pipe(\n {\n ...mapValues(exports ?? {}, value => ({ value, isBin: false })),\n ...mapValues(bin ?? {}, value => ({ value, isBin: true })),\n },\n mapValues(({ value, isBin }, key) => {\n let distPath\n\n if (typeof value === \"string\") {\n distPath = value\n } else if (typeof value === \"object\" && !Array.isArray(value)) {\n if (!value.default) {\n throw new Error(`Export \"${key}\" must have a default field in package.json`)\n }\n\n if (typeof value.default !== \"string\") {\n throw new Error(`Export \"${key}\" default field must be a string in package.json`)\n }\n\n distPath = value.default\n } else {\n throw new Error(`Export \"${key}\" must be a string or an object in package.json`)\n }\n\n if (!distPath.startsWith(\"./dist/\")) {\n throw new Error(\n `The default value of export \"${key}\" must start with \"./dist/\" in package.json, got \"${distPath}\"`,\n )\n }\n\n if (!distPath.endsWith(\".js\")) {\n throw new Error(\n `The default value of export \"${key}\" must end with \".js\" in package.json, got \"${distPath}\"`,\n )\n }\n\n const targetName = distPath.slice(7).slice(0, -3)\n\n return {\n entryPoint: `./src/${targetName}.ts`,\n targetName,\n distPath,\n isBin,\n }\n }),\n mapKeys((_, value) => value.targetName),\n )\n\n const esbuildPlugins: Plugin[] = []\n\n const binSourceFilePaths = Object.values(entry)\n .filter(value => value.isBin)\n .map(value => value.entryPoint.slice(2)) // remove \"./\"\n\n if (this.library) {\n esbuildPlugins.push(schemaTransformerPlugin)\n }\n\n if (binSourceFilePaths.length > 0) {\n esbuildPlugins.push(createBinTransformerPlugin(binSourceFilePaths))\n }\n\n await build({\n entry: mapValues(entry, value => value.entryPoint),\n outDir: \"dist\",\n watch: this.watch,\n sourcemap: true,\n clean: true,\n format: \"esm\",\n target: \"esnext\",\n external: [\"@pulumi/pulumi\"],\n esbuildPlugins,\n silent: [\"warn\", \"error\", \"fatal\"].includes(logger.level),\n })\n\n const packageJsonPath = await resolvePackageJSON()\n const upToDatePackageJson = await readPackageJSON()\n\n const sourceHashCalculator = new SourceHashCalculator(\n packageJsonPath,\n upToDatePackageJson,\n logger,\n )\n const distPaths = Object.values(entry).map(value => value.distPath)\n\n await sourceHashCalculator.writeHighstateManifest(\"./dist\", distPaths)\n }\n}\n"],"mappings":"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","names":["readPackageJSON","consola","relative","n","segment","replacement","build","readFile","logger","readFile","build","readFile","readPackageJSON","resolve","consola","Command","readPackageJSON","resolvePackageJSON","Command","readPackageJSON","resolvePackageJSON"]}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@highstate/cli",
|
3
|
-
"version": "0.7.
|
3
|
+
"version": "0.7.8",
|
4
4
|
"description": "The CLI for the Highstate project.",
|
5
5
|
"type": "module",
|
6
6
|
"files": [
|
@@ -9,16 +9,16 @@
|
|
9
9
|
"src"
|
10
10
|
],
|
11
11
|
"bin": {
|
12
|
-
"highstate": "dist/main.js"
|
12
|
+
"highstate": "./dist/main.js"
|
13
13
|
},
|
14
14
|
"publishConfig": {
|
15
15
|
"access": "public"
|
16
16
|
},
|
17
17
|
"scripts": {
|
18
|
-
"build": "
|
18
|
+
"build": "highstate build"
|
19
19
|
},
|
20
20
|
"dependencies": {
|
21
|
-
"@highstate/backend": "^0.7.
|
21
|
+
"@highstate/backend": "^0.7.8",
|
22
22
|
"clipanion": "^4.0.0-rc.4",
|
23
23
|
"consola": "^3.4.0",
|
24
24
|
"crypto-hash": "^3.1.0",
|
@@ -33,7 +33,7 @@
|
|
33
33
|
"tsup": "^8.4.0"
|
34
34
|
},
|
35
35
|
"devDependencies": {
|
36
|
-
"
|
36
|
+
"highstate-cli-bootstrap": "npm:@highstate/cli@0.7.6"
|
37
37
|
},
|
38
|
-
"gitHead": "
|
38
|
+
"gitHead": "c74d82b9eb6e6dc0103a51fb0c840ee3ca295a67"
|
39
39
|
}
|
package/src/commands/build.ts
CHANGED
@@ -1,8 +1,14 @@
|
|
1
|
+
import type { Plugin } from "esbuild"
|
1
2
|
import { Command, Option } from "clipanion"
|
2
3
|
import { readPackageJSON, resolvePackageJSON } from "pkg-types"
|
3
4
|
import { mapKeys, mapValues, pipe } from "remeda"
|
4
5
|
import { build } from "tsup"
|
5
|
-
import {
|
6
|
+
import {
|
7
|
+
createBinTransformerPlugin,
|
8
|
+
logger,
|
9
|
+
schemaTransformerPlugin,
|
10
|
+
SourceHashCalculator,
|
11
|
+
} from "../shared"
|
6
12
|
|
7
13
|
export class BuildCommand extends Command {
|
8
14
|
static paths = [["build"]]
|
@@ -18,19 +24,31 @@ export class BuildCommand extends Command {
|
|
18
24
|
async execute(): Promise<void> {
|
19
25
|
const packageJson = await readPackageJSON()
|
20
26
|
const exports = packageJson.exports
|
27
|
+
let bin = packageJson.bin
|
21
28
|
|
22
|
-
if (!
|
23
|
-
|
29
|
+
if (!packageJson.name) {
|
30
|
+
throw new Error("package.json must have a name field")
|
31
|
+
}
|
32
|
+
|
33
|
+
if (!exports && !bin) {
|
34
|
+
logger.warn("no exports or bin found in package.json")
|
24
35
|
return
|
25
36
|
}
|
26
37
|
|
27
|
-
if (typeof exports !== "object" || Array.isArray(exports)) {
|
38
|
+
if (exports !== undefined && (typeof exports !== "object" || Array.isArray(exports))) {
|
28
39
|
throw new Error("Exports field in package.json must be an object")
|
29
40
|
}
|
30
41
|
|
42
|
+
if (bin !== undefined && typeof bin !== "object") {
|
43
|
+
bin = { [packageJson.name]: bin }
|
44
|
+
}
|
45
|
+
|
31
46
|
const entry = pipe(
|
32
|
-
|
33
|
-
|
47
|
+
{
|
48
|
+
...mapValues(exports ?? {}, value => ({ value, isBin: false })),
|
49
|
+
...mapValues(bin ?? {}, value => ({ value, isBin: true })),
|
50
|
+
},
|
51
|
+
mapValues(({ value, isBin }, key) => {
|
34
52
|
let distPath
|
35
53
|
|
36
54
|
if (typeof value === "string") {
|
@@ -67,11 +85,26 @@ export class BuildCommand extends Command {
|
|
67
85
|
entryPoint: `./src/${targetName}.ts`,
|
68
86
|
targetName,
|
69
87
|
distPath,
|
88
|
+
isBin,
|
70
89
|
}
|
71
90
|
}),
|
72
91
|
mapKeys((_, value) => value.targetName),
|
73
92
|
)
|
74
93
|
|
94
|
+
const esbuildPlugins: Plugin[] = []
|
95
|
+
|
96
|
+
const binSourceFilePaths = Object.values(entry)
|
97
|
+
.filter(value => value.isBin)
|
98
|
+
.map(value => value.entryPoint.slice(2)) // remove "./"
|
99
|
+
|
100
|
+
if (this.library) {
|
101
|
+
esbuildPlugins.push(schemaTransformerPlugin)
|
102
|
+
}
|
103
|
+
|
104
|
+
if (binSourceFilePaths.length > 0) {
|
105
|
+
esbuildPlugins.push(createBinTransformerPlugin(binSourceFilePaths))
|
106
|
+
}
|
107
|
+
|
75
108
|
await build({
|
76
109
|
entry: mapValues(entry, value => value.entryPoint),
|
77
110
|
outDir: "dist",
|
@@ -81,7 +114,8 @@ export class BuildCommand extends Command {
|
|
81
114
|
format: "esm",
|
82
115
|
target: "esnext",
|
83
116
|
external: ["@pulumi/pulumi"],
|
84
|
-
esbuildPlugins
|
117
|
+
esbuildPlugins,
|
118
|
+
silent: ["warn", "error", "fatal"].includes(logger.level),
|
85
119
|
})
|
86
120
|
|
87
121
|
const packageJsonPath = await resolvePackageJSON()
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import type { Plugin } from "esbuild"
|
2
|
+
import { readFile } from "node:fs/promises"
|
3
|
+
import { logger } from "./logger"
|
4
|
+
|
5
|
+
export function createBinTransformerPlugin(sourceFilePaths: string[]): Plugin {
|
6
|
+
const filter = new RegExp(`(${sourceFilePaths.join("|")})$`)
|
7
|
+
|
8
|
+
logger.debug("created bin transformer plugin with filter: %s", filter)
|
9
|
+
|
10
|
+
return {
|
11
|
+
name: "bin-transformer",
|
12
|
+
setup(build) {
|
13
|
+
build.onLoad({ filter }, async args => {
|
14
|
+
const content = await readFile(args.path, "utf-8")
|
15
|
+
|
16
|
+
return {
|
17
|
+
contents: `#!/usr/bin/env node\n\n${content}`,
|
18
|
+
loader: "ts",
|
19
|
+
}
|
20
|
+
})
|
21
|
+
},
|
22
|
+
}
|
23
|
+
}
|
package/src/shared/index.ts
CHANGED