New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@matter/tools

Package Overview
Dependencies
Maintainers
0
Versions
86
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@matter/tools - npm Package Compare versions

Comparing version 0.11.0-alpha.0-20241027-e40e1664f to 0.11.0-alpha.0-20241028-39fc76758

dist/cjs/util/commander.d.ts

45

dist/cjs/building/builder.js
"use strict";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;

@@ -20,10 +18,2 @@ var __export = (target, all) => {

};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);

@@ -36,3 +26,2 @@ var builder_exports = {};

module.exports = __toCommonJS(builder_exports);
var import_ansi_colors = __toESM(require("ansi-colors"), 1);
var import_crypto = require("crypto");

@@ -151,3 +140,4 @@ var import_error = require("./error.js");

progress.failure("Terminating due to type errors");
process.stderr.write(e.diagnostics);
process.stderr.write(`${e.diagnostics}
`);
process.exit(1);

@@ -158,8 +148,22 @@ }

}
const formats = Array();
if (targets.has("esm" /* esm */)) {
await this.#transpile(project, progress, "esm" /* esm */);
formats.push("esm");
}
if (targets.has("cjs" /* cjs */)) {
await this.#transpile(project, progress, "cjs" /* cjs */);
formats.push("cjs");
}
if (formats.length) {
const groups = [project.pkg.isLibrary ? "library" : "app"];
if (project.pkg.hasTests) {
groups.push("tests");
}
const formatDesc = formats.map(progress.emphasize).join("+");
const groupDesc = groups.map(progress.emphasize).join("+");
await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
for (const format of formats) {
await this.#transpile(project, format);
}
});
}
await config?.after?.({ project });

@@ -173,13 +177,6 @@ if (!this.options.targets?.length) {

}
async #transpile(project, progress, format) {
const fmt = format.toUpperCase();
await progress.run(
`Transpile ${progress.emphasize(project.pkg.isLibrary ? "library" : "app")} to ${import_ansi_colors.default.bold(fmt)}`,
() => project.buildSource(format)
);
async #transpile(project, format) {
await project.buildSource(format);
if (project.pkg.hasTests) {
await progress.run(
`Transpile ${progress.emphasize("tests")} to ${import_ansi_colors.default.bold(fmt)}`,
() => project.buildTests(format)
);
await project.buildTests(format);
}

@@ -186,0 +183,0 @@ }

"use strict";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;

@@ -20,10 +18,2 @@ var __export = (target, all) => {

};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);

@@ -35,4 +25,3 @@ var cli_exports = {};

module.exports = __toCommonJS(cli_exports);
var import_yargs = __toESM(require("yargs"), 1);
var import_helpers = require("yargs/helpers");
var import_commander = require("../util/commander.js");
var import_builder = require("./builder.js");

@@ -58,4 +47,26 @@ var import_graph = require("./graph.js");

let mode = 0 /* BuildProject */;
const args = await (0, import_yargs.default)((0, import_helpers.hideBin)(argv)).usage("Builds packages adhering to matter.js standards.").option("prefix", { alias: "p", default: ".", type: "string", describe: "specify build directory" }).option("clean", { alias: "c", default: false, type: "boolean", describe: "clean before build" }).option("workspaces", { alias: "w", default: false, type: "boolean", describe: "build all workspace packages" }).option("dependencies", { alias: "d", default: false, type: "boolean", describe: "build dependencies" }).command("*", "build types and both JS files", () => {
}).command("clean", "remove build and dist directories", () => targets.push(import_builder.Target.clean)).command("types", "build type definitions", () => targets.push(import_builder.Target.types)).command("esm", "build JS (ES6 modules)", () => targets.push(import_builder.Target.esm)).command("cjs", "build JS (CommonJS modules)", () => targets.push(import_builder.Target.cjs)).command("graph", "display the workspace graph", () => mode = 3 /* DisplayGraph */).command("tsconfigs", "sync all tsconfigs with package.json", () => mode = 4 /* SyncTsconfigs */).wrap(Math.min(process.stdout.columns, 80)).strict().argv;
const program = (0, import_commander.commander)("matter-build", "Builds packages adhering to matter.js standards.").option("-p, --prefix <path>", "specify build directory", ".").option("-c, --clean", "clean before build", false).option("-w, --workspaces", "build all workspace packages", false).option("-d, --dependencies", "build dependencies", false);
program.command("build").description("(default) build JS and type definitions").action(() => {
});
program.command("clean").description("remove build and dist directories").action(() => {
targets.push(import_builder.Target.clean);
});
program.command("types").description("build type definitions").action(() => {
targets.push(import_builder.Target.types);
});
program.command("esm").description("build JS (ES6 modules)").action(() => {
targets.push(import_builder.Target.esm);
});
program.command("cjs").description("build JS (CommonJS modules)").action(() => {
targets.push(import_builder.Target.cjs);
});
program.command("graph").description("display the workspace graph").action(() => {
mode = 3 /* DisplayGraph */;
});
program.command("tsconfigs").description("sync all tsconfigs with package.json").action(() => {
mode = 4 /* SyncTsconfigs */;
});
program.action(() => {
});
const args = program.parse(argv).opts();
if (mode === 0 /* BuildProject */) {

@@ -62,0 +73,0 @@ if (args.workspaces) {

@@ -34,3 +34,2 @@ "use strict";

module.exports = __toCommonJS(graph_exports);
var import_map_workspaces = __toESM(require("@npmcli/map-workspaces"), 1);
var import_ansi_colors = __toESM(require("ansi-colors"), 1);

@@ -177,7 +176,7 @@ var import_package = require("../util/package.js");

static async #loadNodes(workspace) {
const workspaces = await (0, import_map_workspaces.default)({ pkg: workspace.json, cwd: workspace.path });
const workspaces = workspace.json.workspaces;
const nodeMap = {};
const allDeps = {};
for (const path of workspaces.values()) {
const pkg = new import_package.Package({ path });
const pkg = new import_package.Package({ path: workspace.resolve(path) });
allDeps[pkg.json.name] = pkg.dependencies;

@@ -184,0 +183,0 @@ nodeMap[pkg.json.name] = {

@@ -27,3 +27,2 @@ "use strict";

var import_promises = require("fs/promises");
var import_glob = require("glob");
var import_os = require("os");

@@ -50,3 +49,5 @@ var import_path = require("path");

if (!this.pkg.hasSrc) {
throw new Error(`Found package ${this.pkg.json.name} but no src directory is present`);
throw new Error(
`Found package ${this.pkg.json.name} but src directory is not present or not referenced in tsconfig.json`
);
}

@@ -146,3 +147,6 @@ }

for (const format of formats) {
await (0, import_promises.cp)(this.pkg.resolve(source), this.pkg.resolve((0, import_path.join)("dist", format, dest)));
await (0, import_promises.cp)(this.pkg.resolve(source), this.pkg.resolve((0, import_path.join)("dist", format, dest)), {
recursive: true,
force: true
});
}

@@ -195,7 +199,7 @@ }

async #targetsOf(indir, outdir, ...extensions) {
indir = this.pkg.resolve(indir).replace(/\\/g, "/");
const inputPrefixLength = this.pkg.resolve(indir).length + 1;
outdir = this.pkg.resolve(outdir).replace(/\\/g, "/");
return (await (0, import_glob.glob)(extensions.map((ext) => `${indir}/**/*.${ext}`))).map((file) => ({
return (await this.pkg.glob(extensions.map((ext) => `${indir}/**/*.${ext}`))).map((file) => ({
in: file,
out: `${outdir}/${file.slice(indir.length + 1)}`
out: `${outdir}/${file.slice(inputPrefixLength)}`
}));

@@ -202,0 +206,0 @@ }

@@ -62,3 +62,3 @@ "use strict";

}
const deps = node.dependencies.map((dep) => dep.pkg.resolve("src")).filter((p) => !p.match(/packages[\\/]tools/));
const deps = node.dependencies.filter((dep) => dep.pkg.isLibrary).map((dep) => dep.pkg.resolve("src")).filter((p) => !p.match(/packages[\\/]tools/));
const desired = [.../* @__PURE__ */ new Set([...deps, ...extraRefs])];

@@ -65,0 +65,0 @@ const newReferences = desired.map((ref) => ({ path: (0, import_path.relative)(path, ref).replace(/\\/g, "/") })).sort((ref1, ref2) => ref1.path.localeCompare(ref2.path));

@@ -6,11 +6,9 @@ /**

*/
import "./testing/global-declarations.js";
export * from "./building/builder.js";
export * from "./building/graph.js";
export * from "./building/project.js";
export * from "./testing/chip.js";
export * from "./testing/mocharc.cjs";
export * from "./util/docker.js";
export * from "./util/commander.js";
export * from "./util/files.js";
export * from "./util/package.js";
export * from "./util/progress.js";
export * from "./util/wtf.js";
//# sourceMappingURL=index.d.ts.map

@@ -18,11 +18,9 @@ "use strict";

module.exports = __toCommonJS(src_exports);
var import_global_declarations = require("./testing/global-declarations.js");
__reExport(src_exports, require("./building/builder.js"), module.exports);
__reExport(src_exports, require("./building/graph.js"), module.exports);
__reExport(src_exports, require("./building/project.js"), module.exports);
__reExport(src_exports, require("./testing/chip.js"), module.exports);
__reExport(src_exports, require("./testing/mocharc.cjs"), module.exports);
__reExport(src_exports, require("./util/docker.js"), module.exports);
__reExport(src_exports, require("./util/commander.js"), module.exports);
__reExport(src_exports, require("./util/files.js"), module.exports);
__reExport(src_exports, require("./util/package.js"), module.exports);
__reExport(src_exports, require("./util/progress.js"), module.exports);
__reExport(src_exports, require("./util/wtf.js"), module.exports);
/**

@@ -29,0 +27,0 @@ * @license

@@ -6,4 +6,6 @@ /**

*/
export * from "./commander.js";
export * from "./errors.js";
export * from "./files.js";
export * from "./package.js";
//# sourceMappingURL=index.d.ts.map

@@ -18,3 +18,5 @@ "use strict";

module.exports = __toCommonJS(util_exports);
__reExport(util_exports, require("./commander.js"), module.exports);
__reExport(util_exports, require("./errors.js"), module.exports);
__reExport(util_exports, require("./files.js"), module.exports);
__reExport(util_exports, require("./package.js"), module.exports);

@@ -21,0 +23,0 @@ /**

@@ -28,5 +28,5 @@ /**

get hasCodegen(): boolean;
resolve(path: string): string;
resolve(...paths: string[]): string;
relative(path: string): string;
glob(pattern: string): Promise<string[]>;
glob(pattern: string | string[]): Promise<string[]>;
start(what: string): Progress;

@@ -43,2 +43,3 @@ lastModified(...paths: string[]): Promise<number>;

resolveExport(name: string, type?: "cjs" | "esm"): string;
findPackage(name: string): Package;
resolveImport(name: string, type?: "cjs" | "esm"): string;

@@ -45,0 +46,0 @@ hasFile(path: string): boolean;

@@ -29,6 +29,5 @@ "use strict";

var import_promises = require("fs/promises");
var import_glob = require("glob");
var import_path = require("path");
var import_files = require("../testing/files.js");
var import_errors = require("./errors.js");
var import_files = require("./files.js");
var import_progress = require("./progress.js");

@@ -90,2 +89,11 @@ var import_tools_path = require("./tools-path.cjs");

this.hasTests = isDirectory(this.resolve("test"));
const refs = (0, import_files.maybeReadJsonSync)(this.resolve("tsconfig.json"))?.references;
if (refs !== void 0) {
if (!refs.find((ref) => this.resolve(ref.path) === this.resolve("src"))) {
this.hasSrc = false;
}
if (!refs.find((ref) => this.resolve(ref.path) === this.resolve("test"))) {
this.hasTests = false;
}
}
this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);

@@ -103,4 +111,4 @@ this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));

}
resolve(path) {
return (0, import_path.resolve)(this.path, path);
resolve(...paths) {
return (0, import_path.resolve)(this.path, ...paths);
}

@@ -111,4 +119,8 @@ relative(path) {

async glob(pattern) {
pattern = this.resolve(pattern).replace(/\\/g, "/");
return await (0, import_glob.glob)(pattern);
if (typeof pattern === "string") {
pattern = this.resolve(pattern).replace(/\\/g, "/");
} else {
pattern = pattern.map((s) => this.resolve(s).replace(/\\/g, "/"));
}
return (0, import_files.globSync)(pattern);
}

@@ -199,11 +211,6 @@ start(what) {

}
resolveImport(name, type = "esm") {
const segments = name.split("/");
let subdir = segments.shift();
if (subdir.startsWith("@") && segments.length) {
subdir = `${subdir}/${segments.shift()}`;
}
findPackage(name) {
let resolveIn = this.path;
while (true) {
if (isDirectory((0, import_path.resolve)(resolveIn, "node_modules", subdir))) {
if (isDirectory((0, import_path.resolve)(resolveIn, "node_modules", name))) {
break;

@@ -213,7 +220,15 @@ }

if (nextResolveIn === resolveIn) {
throw new Error(`Cannot find module ${subdir} from ${this.path}`);
throw new Error(`Cannot find module ${name} from ${this.path}`);
}
resolveIn = nextResolveIn;
}
const pkg = Package.forPath((0, import_path.resolve)(resolveIn, "node_modules", subdir));
return Package.forPath((0, import_path.resolve)(resolveIn, "node_modules", name));
}
resolveImport(name, type = "esm") {
const segments = name.split("/");
let packageName = segments.shift();
if (packageName.startsWith("@") && segments.length) {
packageName = `${packageName}/${segments.shift()}`;
}
const pkg = this.findPackage(packageName);
return pkg.resolveExport(segments.length ? segments.join("/") : ".", type);

@@ -248,4 +263,4 @@ }

e.message = `Error parsing "${this.resolve(path)}": ${e.message}`;
throw e;
}
return JSON.parse(await this.readFile(path));
}

@@ -252,0 +267,0 @@ async writeJson(path, value) {

"use strict";
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;

@@ -20,10 +18,2 @@ var __export = (target, all) => {

};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);

@@ -35,4 +25,3 @@ var cli_exports = {};

module.exports = __toCommonJS(cli_exports);
var import_yargs = __toESM(require("yargs"), 1);
var import_helpers = require("yargs/helpers");
var import_commander = require("../util/commander.js");
var import_package = require("../util/package.js");

@@ -47,4 +36,6 @@ var import_progress = require("../util/progress.js");

async function main(argv = process.argv) {
const args = await (0, import_yargs.default)((0, import_helpers.hideBin)(argv)).command("$0 [ver]", "Manipulate monorepo package versions.").option("prefix", { alias: "p", default: ".", type: "string", describe: "specify monorepo directory" }).option("set", { alias: "s", type: "boolean", describe: "Sets the release version" }).option("apply", { alias: "a", type: "boolean", describe: "Sets package versions to the release version" }).option("tag", { alias: "t", type: "boolean", describe: "Adds git tag for release version" }).wrap(Math.min(process.stdout.columns, 80)).strict().argv;
const version = args.ver;
const program = (0, import_commander.commander)("matter-version", "Manipulate monorepo package versions.").argument("[version]").option("-p, --prefix <prefix>", "specify monorepo directory").option("-s, --set", "sets the release version").option("-a, --apply", "sets package versions to the release version").option("-t, --tag", "adds git tag for release version").parse(argv);
const args = program.opts();
args.version = program.args[0];
const version = args.version;
const pkg = new import_package.Package({ path: args.prefix });

@@ -51,0 +42,0 @@ const versioner = new import_versioner.Versioner(pkg, version);

@@ -6,3 +6,2 @@ /**

*/
import colors from "ansi-colors";
import { createHash } from "crypto";

@@ -116,3 +115,4 @@ import { BuildError } from "./error.js";

progress.failure("Terminating due to type errors");
process.stderr.write(e.diagnostics);
process.stderr.write(`${e.diagnostics}
`);
process.exit(1);

@@ -123,8 +123,22 @@ }

}
const formats = Array();
if (targets.has("esm" /* esm */)) {
await this.#transpile(project, progress, "esm" /* esm */);
formats.push("esm");
}
if (targets.has("cjs" /* cjs */)) {
await this.#transpile(project, progress, "cjs" /* cjs */);
formats.push("cjs");
}
if (formats.length) {
const groups = [project.pkg.isLibrary ? "library" : "app"];
if (project.pkg.hasTests) {
groups.push("tests");
}
const formatDesc = formats.map(progress.emphasize).join("+");
const groupDesc = groups.map(progress.emphasize).join("+");
await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
for (const format of formats) {
await this.#transpile(project, format);
}
});
}
await config?.after?.({ project });

@@ -138,13 +152,6 @@ if (!this.options.targets?.length) {

}
async #transpile(project, progress, format) {
const fmt = format.toUpperCase();
await progress.run(
`Transpile ${progress.emphasize(project.pkg.isLibrary ? "library" : "app")} to ${colors.bold(fmt)}`,
() => project.buildSource(format)
);
async #transpile(project, format) {
await project.buildSource(format);
if (project.pkg.hasTests) {
await progress.run(
`Transpile ${progress.emphasize("tests")} to ${colors.bold(fmt)}`,
() => project.buildTests(format)
);
await project.buildTests(format);
}

@@ -177,2 +184,2 @@ }

};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/builder.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport colors from \"ansi-colors\";\nimport { createHash } from \"crypto\";\nimport { Progress } from \"../util/progress.js\";\nimport { BuildError } from \"./error.js\";\nimport { Graph } from \"./graph.js\";\nimport { BuildInformation, Project } from \"./project.js\";\nimport { createTypescriptContext } from \"./typescript.js\";\nimport { TypescriptContext } from \"./typescript/context.js\";\n\nexport enum Target {\n    clean = \"clean\",\n    types = \"types\",\n    esm = \"esm\",\n    cjs = \"cjs\",\n}\n\nexport interface Options {\n    targets?: Target[];\n    clean?: boolean;\n    graph?: Graph;\n}\n\n/**\n * High-level build coordination.\n *\n * Warning: This class is intended for command line use and will process.exit if things go wrong.\n */\nexport class Builder {\n    unconditional: boolean;\n    tsContext?: TypescriptContext;\n    graph?: Graph;\n\n    constructor(private options: Options = {}) {\n        this.graph = options.graph;\n        this.unconditional =\n            options.clean || (options.targets !== undefined && options.targets?.indexOf(Target.clean) !== -1);\n    }\n\n    get hasClean() {\n        return this.options.clean;\n    }\n\n    clearClean() {\n        delete this.options.clean;\n    }\n\n    hasTargets() {\n        return this.options.targets && this.options.targets.length > 0;\n    }\n\n    public async configure(project: Project) {\n        if (!project.pkg.hasConfig) {\n            return;\n        }\n\n        await project.configure();\n    }\n\n    public async build(project: Project) {\n        const progress = project.pkg.start(\"Building\");\n\n        try {\n            await this.#doBuild(project, progress);\n        } catch (e: any) {\n            progress.shutdown();\n            process.stderr.write(`${e.stack ?? e.message}\\n\\n`);\n            process.exit(1);\n        }\n\n        progress.shutdown();\n    }\n\n    async #doBuild(project: Project, progress: Progress) {\n        const targets = this.#selectTargets(project);\n\n        if (targets.has(Target.clean) || this.options.clean) {\n            await progress.run(\"Clean\", () => project.clean());\n        }\n\n        if (!targets.has(Target.types) && !targets.has(Target.esm) && !targets.has(Target.cjs)) {\n            return;\n        }\n\n        const info: BuildInformation = {};\n\n        const config = await project.configure();\n\n        await config?.before?.({ project });\n\n        // If available we use graph to access dependency API shas\n        const graph = this.graph ?? (await Graph.forProject(project.pkg.path));\n        let node: Graph.Node | undefined;\n        if (graph) {\n            node = graph.get(project.pkg.name);\n            for (const dep of node.dependencies) {\n                if (dep.info.apiSha !== undefined) {\n                    if (info.dependencyApiShas === undefined) {\n                        info.dependencyApiShas = {};\n                    }\n                    info.dependencyApiShas[dep.pkg.name] = dep.info.apiSha;\n                }\n            }\n        }\n\n        if (targets.has(Target.types)) {\n            try {\n                // Obtain or initialize typescript solution builder\n                let context = this.tsContext;\n                if (context === undefined) {\n                    context = this.tsContext = await createTypescriptContext(project.pkg.workspace, graph);\n                }\n\n                const refreshCallback = progress.refresh.bind(progress);\n\n                if (project.pkg.isLibrary) {\n                    const apiSha = createHash(\"sha1\");\n\n                    // Our API SHA changes if that of any dependency changes\n                    if (node) {\n                        for (const dep of node.dependencies) {\n                            if (dep.info.apiSha !== undefined) {\n                                apiSha.update(dep.info.apiSha);\n                            }\n                        }\n                    }\n\n                    await progress.run(`Generate ${progress.emphasize(\"type declarations\")}`, async () => {\n                        await context.build(project.pkg, \"src\", refreshCallback);\n                        await project.hashDeclarations(apiSha);\n                    });\n\n                    info.apiSha = apiSha.digest(\"hex\");\n                } else {\n                    await progress.run(`Validate ${progress.emphasize(\"types\")}`, () =>\n                        context.build(project.pkg, \"src\", refreshCallback, false),\n                    );\n                }\n                if (project.pkg.hasTests) {\n                    await progress.run(`Validate ${progress.emphasize(\"test types\")}`, () =>\n                        context.build(project.pkg, \"test\", refreshCallback),\n                    );\n                }\n            } catch (e) {\n                if (e instanceof BuildError) {\n                    progress.failure(\"Terminating due to type errors\");\n                    process.stderr.write(e.diagnostics);\n                    process.exit(1);\n                }\n                throw e;\n            }\n        }\n\n        if (targets.has(Target.esm)) {\n            await this.#transpile(project, progress, Target.esm);\n        }\n\n        if (targets.has(Target.cjs)) {\n            await this.#transpile(project, progress, Target.cjs);\n        }\n\n        await config?.after?.({ project });\n\n        // Only update build information when there are no explicit targets so we know it's a full build\n        if (!this.options.targets?.length) {\n            await project.recordBuildInfo(info);\n            if (node) {\n                node.info = info;\n            }\n        }\n    }\n\n    async #transpile(project: Project, progress: Progress, format: \"esm\" | \"cjs\") {\n        const fmt = format.toUpperCase();\n        await progress.run(\n            `Transpile ${progress.emphasize(project.pkg.isLibrary ? \"library\" : \"app\")} to ${colors.bold(fmt)}`,\n            () => project.buildSource(format),\n        );\n        if (project.pkg.hasTests) {\n            await progress.run(`Transpile ${progress.emphasize(\"tests\")} to ${colors.bold(fmt)}`, () =>\n                project.buildTests(format),\n            );\n        }\n    }\n\n    #selectTargets(project: Project) {\n        const targets = new Set<string>(this.options.targets);\n\n        if (!targets.size) {\n            targets.add(Target.types);\n\n            if (project.pkg.supportsEsm) {\n                targets.add(Target.esm);\n            }\n\n            if (project.pkg.supportsCjs) {\n                targets.add(Target.cjs);\n            }\n        } else {\n            if (!project.pkg.supportsEsm) {\n                targets.delete(Target.esm);\n            }\n\n            if (!project.pkg.supportsCjs) {\n                targets.delete(Target.cjs);\n            }\n        }\n\n        return targets;\n    }\n}\n"],
  "mappings": "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",
  "names": ["Target"]
}

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/builder.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createHash } from \"crypto\";\nimport { Progress } from \"../util/progress.js\";\nimport { BuildError } from \"./error.js\";\nimport { Graph } from \"./graph.js\";\nimport { BuildInformation, Project } from \"./project.js\";\nimport { createTypescriptContext } from \"./typescript.js\";\nimport { TypescriptContext } from \"./typescript/context.js\";\n\nexport enum Target {\n    clean = \"clean\",\n    types = \"types\",\n    esm = \"esm\",\n    cjs = \"cjs\",\n}\n\nexport interface Options {\n    targets?: Target[];\n    clean?: boolean;\n    graph?: Graph;\n}\n\n/**\n * High-level build coordination.\n *\n * Warning: This class is intended for command line use and will process.exit if things go wrong.\n */\nexport class Builder {\n    unconditional: boolean;\n    tsContext?: TypescriptContext;\n    graph?: Graph;\n\n    constructor(private options: Options = {}) {\n        this.graph = options.graph;\n        this.unconditional =\n            options.clean || (options.targets !== undefined && options.targets?.indexOf(Target.clean) !== -1);\n    }\n\n    get hasClean() {\n        return this.options.clean;\n    }\n\n    clearClean() {\n        delete this.options.clean;\n    }\n\n    hasTargets() {\n        return this.options.targets && this.options.targets.length > 0;\n    }\n\n    public async configure(project: Project) {\n        if (!project.pkg.hasConfig) {\n            return;\n        }\n\n        await project.configure();\n    }\n\n    public async build(project: Project) {\n        const progress = project.pkg.start(\"Building\");\n\n        try {\n            await this.#doBuild(project, progress);\n        } catch (e: any) {\n            progress.shutdown();\n            process.stderr.write(`${e.stack ?? e.message}\\n\\n`);\n            process.exit(1);\n        }\n\n        progress.shutdown();\n    }\n\n    async #doBuild(project: Project, progress: Progress) {\n        const targets = this.#selectTargets(project);\n\n        if (targets.has(Target.clean) || this.options.clean) {\n            await progress.run(\"Clean\", () => project.clean());\n        }\n\n        if (!targets.has(Target.types) && !targets.has(Target.esm) && !targets.has(Target.cjs)) {\n            return;\n        }\n\n        const info: BuildInformation = {};\n\n        const config = await project.configure();\n\n        await config?.before?.({ project });\n\n        // If available we use graph to access dependency API shas\n        const graph = this.graph ?? (await Graph.forProject(project.pkg.path));\n        let node: Graph.Node | undefined;\n        if (graph) {\n            node = graph.get(project.pkg.name);\n            for (const dep of node.dependencies) {\n                if (dep.info.apiSha !== undefined) {\n                    if (info.dependencyApiShas === undefined) {\n                        info.dependencyApiShas = {};\n                    }\n                    info.dependencyApiShas[dep.pkg.name] = dep.info.apiSha;\n                }\n            }\n        }\n\n        if (targets.has(Target.types)) {\n            try {\n                // Obtain or initialize typescript solution builder\n                let context = this.tsContext;\n                if (context === undefined) {\n                    context = this.tsContext = await createTypescriptContext(project.pkg.workspace, graph);\n                }\n\n                const refreshCallback = progress.refresh.bind(progress);\n\n                if (project.pkg.isLibrary) {\n                    const apiSha = createHash(\"sha1\");\n\n                    // Our API SHA changes if that of any dependency changes\n                    if (node) {\n                        for (const dep of node.dependencies) {\n                            if (dep.info.apiSha !== undefined) {\n                                apiSha.update(dep.info.apiSha);\n                            }\n                        }\n                    }\n\n                    await progress.run(`Generate ${progress.emphasize(\"type declarations\")}`, async () => {\n                        await context.build(project.pkg, \"src\", refreshCallback);\n                        await project.hashDeclarations(apiSha);\n                    });\n\n                    info.apiSha = apiSha.digest(\"hex\");\n                } else {\n                    await progress.run(`Validate ${progress.emphasize(\"types\")}`, () =>\n                        context.build(project.pkg, \"src\", refreshCallback, false),\n                    );\n                }\n                if (project.pkg.hasTests) {\n                    await progress.run(`Validate ${progress.emphasize(\"test types\")}`, () =>\n                        context.build(project.pkg, \"test\", refreshCallback),\n                    );\n                }\n            } catch (e) {\n                if (e instanceof BuildError) {\n                    progress.failure(\"Terminating due to type errors\");\n                    process.stderr.write(`${e.diagnostics}\\n`);\n                    process.exit(1);\n                }\n                throw e;\n            }\n        }\n\n        const formats = Array<\"esm\" | \"cjs\">();\n        if (targets.has(Target.esm)) {\n            formats.push(\"esm\");\n        }\n        if (targets.has(Target.cjs)) {\n            formats.push(\"cjs\");\n        }\n\n        if (formats.length) {\n            const groups = [project.pkg.isLibrary ? \"library\" : \"app\"];\n            if (project.pkg.hasTests) {\n                groups.push(\"tests\");\n            }\n\n            const formatDesc = formats.map(progress.emphasize).join(\"+\");\n            const groupDesc = groups.map(progress.emphasize).join(\"+\");\n\n            await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {\n                for (const format of formats) {\n                    await this.#transpile(project, format);\n                }\n            });\n        }\n\n        await config?.after?.({ project });\n\n        // Only update build information when there are no explicit targets so we know it's a full build\n        if (!this.options.targets?.length) {\n            await project.recordBuildInfo(info);\n            if (node) {\n                node.info = info;\n            }\n        }\n    }\n\n    async #transpile(project: Project, format: \"esm\" | \"cjs\") {\n        await project.buildSource(format);\n        if (project.pkg.hasTests) {\n            await project.buildTests(format);\n        }\n    }\n\n    #selectTargets(project: Project) {\n        const targets = new Set<string>(this.options.targets);\n\n        if (!targets.size) {\n            targets.add(Target.types);\n\n            if (project.pkg.supportsEsm) {\n                targets.add(Target.esm);\n            }\n\n            if (project.pkg.supportsCjs) {\n                targets.add(Target.cjs);\n            }\n        } else {\n            if (!project.pkg.supportsEsm) {\n                targets.delete(Target.esm);\n            }\n\n            if (!project.pkg.supportsCjs) {\n                targets.delete(Target.cjs);\n            }\n        }\n\n        return targets;\n    }\n}\n"],
  "mappings": "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",
  "names": ["Target"]
}


@@ -6,4 +6,3 @@ /**

*/
import yargs from "yargs";
import { hideBin } from "yargs/helpers";
import { commander } from "../util/commander.js";
import { Builder, Target } from "./builder.js";

@@ -24,4 +23,26 @@ import { Graph } from "./graph.js";

let mode = 0 /* BuildProject */;
const args = await yargs(hideBin(argv)).usage("Builds packages adhering to matter.js standards.").option("prefix", { alias: "p", default: ".", type: "string", describe: "specify build directory" }).option("clean", { alias: "c", default: false, type: "boolean", describe: "clean before build" }).option("workspaces", { alias: "w", default: false, type: "boolean", describe: "build all workspace packages" }).option("dependencies", { alias: "d", default: false, type: "boolean", describe: "build dependencies" }).command("*", "build types and both JS files", () => {
}).command("clean", "remove build and dist directories", () => targets.push(Target.clean)).command("types", "build type definitions", () => targets.push(Target.types)).command("esm", "build JS (ES6 modules)", () => targets.push(Target.esm)).command("cjs", "build JS (CommonJS modules)", () => targets.push(Target.cjs)).command("graph", "display the workspace graph", () => mode = 3 /* DisplayGraph */).command("tsconfigs", "sync all tsconfigs with package.json", () => mode = 4 /* SyncTsconfigs */).wrap(Math.min(process.stdout.columns, 80)).strict().argv;
const program = commander("matter-build", "Builds packages adhering to matter.js standards.").option("-p, --prefix <path>", "specify build directory", ".").option("-c, --clean", "clean before build", false).option("-w, --workspaces", "build all workspace packages", false).option("-d, --dependencies", "build dependencies", false);
program.command("build").description("(default) build JS and type definitions").action(() => {
});
program.command("clean").description("remove build and dist directories").action(() => {
targets.push(Target.clean);
});
program.command("types").description("build type definitions").action(() => {
targets.push(Target.types);
});
program.command("esm").description("build JS (ES6 modules)").action(() => {
targets.push(Target.esm);
});
program.command("cjs").description("build JS (CommonJS modules)").action(() => {
targets.push(Target.cjs);
});
program.command("graph").description("display the workspace graph").action(() => {
mode = 3 /* DisplayGraph */;
});
program.command("tsconfigs").description("sync all tsconfigs with package.json").action(() => {
mode = 4 /* SyncTsconfigs */;
});
program.action(() => {
});
const args = program.parse(argv).opts();
if (mode === 0 /* BuildProject */) {

@@ -72,2 +93,2 @@ if (args.workspaces) {

};
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2J1aWxkaW5nL2NsaS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IDIwMjItMjAyNCBNYXR0ZXIuanMgQXV0aG9yc1xuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbiAqL1xuXG5pbXBvcnQgeWFyZ3MgZnJvbSBcInlhcmdzXCI7XG5pbXBvcnQgeyBoaWRlQmluIH0gZnJvbSBcInlhcmdzL2hlbHBlcnNcIjtcbmltcG9ydCB7IEJ1aWxkZXIsIFRhcmdldCB9IGZyb20gXCIuL2J1aWxkZXIuanNcIjtcbmltcG9ydCB7IEdyYXBoIH0gZnJvbSBcIi4vZ3JhcGguanNcIjtcbmltcG9ydCB7IFByb2plY3QgfSBmcm9tIFwiLi9wcm9qZWN0LmpzXCI7XG5pbXBvcnQgeyBzeW5jQWxsVHNjb25maWdzIH0gZnJvbSBcIi4vdHNjb25maWcuanNcIjtcblxuZW51bSBNb2RlIHtcbiAgICBCdWlsZFByb2plY3QsXG4gICAgQnVpbGRQcm9qZWN0V2l0aERlcGVuZGVuY2llcyxcbiAgICBCdWlsZFdvcmtzcGFjZSxcbiAgICBEaXNwbGF5R3JhcGgsXG4gICAgU3luY1RzY29uZmlncyxcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1haW4oYXJndiA9IHByb2Nlc3MuYXJndikge1xuICAgIGNvbnN0IHRhcmdldHMgPSBBcnJheTxUYXJnZXQ+KCk7XG4gICAgbGV0IG1vZGUgPSBNb2RlLkJ1aWxkUHJvamVjdDtcblxuICAgIGNvbnN0IGFyZ3MgPSBhd2FpdCB5YXJncyhoaWRlQmluKGFyZ3YpKVxuICAgICAgICAudXNhZ2UoXCJCdWlsZHMgcGFja2FnZXMgYWRoZXJpbmcgdG8gbWF0dGVyLmpzIHN0YW5kYXJkcy5cIilcbiAgICAgICAgLm9wdGlvbihcInByZWZpeFwiLCB7IGFsaWFzOiBcInBcIiwgZGVmYXVsdDogXCIuXCIsIHR5cGU6IFwic3RyaW5nXCIsIGRlc2NyaWJlOiBcInNwZWNpZnkgYnVpbGQgZGlyZWN0b3J5XCIgfSlcbiAgICAgICAgLm9wdGlvbihcImNsZWFuXCIsIHsgYWxpYXM6IFwiY1wiLCBkZWZhdWx0OiBmYWxzZSwgdHlwZTogXCJib29sZWFuXCIsIGRlc2NyaWJlOiBcImNsZWFuIGJlZm9yZSBidWlsZFwiIH0pXG4gICAgICAgIC5vcHRpb24oXCJ3b3Jrc3BhY2VzXCIsIHsgYWxpYXM6IFwid1wiLCBkZWZhdWx0OiBmYWxzZSwgdHlwZTogXCJib29sZWFuXCIsIGRlc2NyaWJlOiBcImJ1aWxkIGFsbCB3b3Jrc3BhY2UgcGFja2FnZXNcIiB9KVxuICAgICAgICAub3B0aW9uKFwiZGVwZW5kZW5jaWVzXCIsIHsgYWxpYXM6IFwiZFwiLCBkZWZhdWx0OiBmYWxzZSwgdHlwZTogXCJib29sZWFuXCIsIGRlc2NyaWJlOiBcImJ1aWxkIGRlcGVuZGVuY2llc1wiIH0pXG4gICAgICAgIC5jb21tYW5kKFwiKlwiLCBcImJ1aWxkIHR5cGVzIGFuZCBib3RoIEpTIGZpbGVzXCIsICgpID0+IHt9KVxuICAgICAgICAuY29tbWFuZChcImNsZWFuXCIsIFwicmVtb3ZlIGJ1aWxkIGFuZCBkaXN0IGRpcmVjdG9yaWVzXCIsICgpID0+IHRhcmdldHMucHVzaChUYXJnZXQuY2xlYW4pKVxuICAgICAgICAuY29tbWFuZChcInR5cGVzXCIsIFwiYnVpbGQgdHlwZSBkZWZpbml0aW9uc1wiLCAoKSA9PiB0YXJnZXRzLnB1c2goVGFyZ2V0LnR5cGVzKSlcbiAgICAgICAgLmNvbW1hbmQoXCJlc21cIiwgXCJidWlsZCBKUyAoRVM2IG1vZHVsZXMpXCIsICgpID0+IHRhcmdldHMucHVzaChUYXJnZXQuZXNtKSlcbiAgICAgICAgLmNvbW1hbmQoXCJjanNcIiwgXCJidWlsZCBKUyAoQ29tbW9uSlMgbW9kdWxlcylcIiwgKCkgPT4gdGFyZ2V0cy5wdXNoKFRhcmdldC5janMpKVxuICAgICAgICAuY29tbWFuZChcImdyYXBoXCIsIFwiZGlzcGxheSB0aGUgd29ya3NwYWNlIGdyYXBoXCIsICgpID0+IChtb2RlID0gTW9kZS5EaXNwbGF5R3JhcGgpKVxuICAgICAgICAuY29tbWFuZChcInRzY29uZmlnc1wiLCBcInN5bmMgYWxsIHRzY29uZmlncyB3aXRoIHBhY2thZ2UuanNvblwiLCAoKSA9PiAobW9kZSA9IE1vZGUuU3luY1RzY29uZmlncykpXG4gICAgICAgIC53cmFwKE1hdGgubWluKHByb2Nlc3Muc3Rkb3V0LmNvbHVtbnMsIDgwKSlcbiAgICAgICAgLnN0cmljdCgpLmFyZ3Y7XG5cbiAgICBpZiAobW9kZSA9PT0gTW9kZS5CdWlsZFByb2plY3QpIHtcbiAgICAgICAgaWYgKGFyZ3Mud29ya3NwYWNlcykge1xuICAgICAgICAgICAgbW9kZSA9IE1vZGUuQnVpbGRXb3Jrc3BhY2U7XG4gICAgICAgIH0gZWxzZSBpZiAoYXJncy5kZXBlbmRlbmNpZXMpIHtcbiAgICAgICAgICAgIG1vZGUgPSBNb2RlLkJ1aWxkUHJvamVjdFdpdGhEZXBlbmRlbmNpZXM7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBmdW5jdGlvbiBidWlsZGVyKGdyYXBoPzogR3JhcGgpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBCdWlsZGVyKHsgLi4uYXJncywgdGFyZ2V0czogWy4uLnRhcmdldHNdLCBncmFwaCB9KTtcbiAgICB9XG5cbiAgICBzd2l0Y2ggKG1vZGUgYXMgTW9kZSkge1xuICAgICAgICBjYXNlIE1vZGUuQnVpbGRQcm9qZWN0OlxuICAgICAgICAgICAgY29uc3QgcHJvamVjdCA9IG5ldyBQcm9qZWN0KGFyZ3MucHJlZml4KTtcbiAgICAgICAgICAgIGF3YWl0IGJ1aWxkZXIoKS5idWlsZChwcm9qZWN0KTtcbiAgICAgICAgICAgIGJyZWFrO1xuXG4gICAgICAgIGNhc2UgTW9kZS5CdWlsZFByb2plY3RXaXRoRGVwZW5kZW5jaWVzOlxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGNvbnN0IGdyYXBoID0gYXdhaXQgR3JhcGguZm9yUHJvamVjdChhcmdzLnByZWZpeCk7XG4gICAgICAgICAgICAgICAgaWYgKGdyYXBoID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3QgYnVpbGQgd2l0aCBkZXBlbmRlbmNpZXMgYmVjYXVzZSAke2FyZ3MucHJlZml4fSBpcyBub3QgaW4gYSB3b3Jrc3BhY2VgKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgYXdhaXQgZ3JhcGguYnVpbGQoYnVpbGRlcihncmFwaCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYnJlYWs7XG5cbiAgICAgICAgY2FzZSBNb2RlLkJ1aWxkV29ya3NwYWNlOlxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGNvbnN0IGdyYXBoID0gYXdhaXQgR3JhcGgubG9hZCgpO1xuICAgICAgICAgICAgICAgIGF3YWl0IHN5bmNBbGxUc2NvbmZpZ3MoZ3JhcGgpO1xuICAgICAgICAgICAgICAgIGF3YWl0IGdyYXBoLmJ1aWxkKGJ1aWxkZXIoZ3JhcGgpKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGJyZWFrO1xuXG4gICAgICAgIGNhc2UgTW9kZS5EaXNwbGF5R3JhcGg6XG4gICAgICAgICAgICAoYXdhaXQgR3JhcGgubG9hZCgpKS5kaXNwbGF5KCk7XG4gICAgICAgICAgICBicmVhaztcblxuICAgICAgICBjYXNlIE1vZGUuU3luY1RzY29uZmlnczpcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBjb25zdCBncmFwaCA9IGF3YWl0IEdyYXBoLmxvYWQoKTtcbiAgICAgICAgICAgICAgICBhd2FpdCBzeW5jQWxsVHNjb25maWdzKGdyYXBoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGJyZWFrO1xuICAgIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFNQSxPQUFPLFdBQVc7QUFDbEIsU0FBUyxlQUFlO0FBQ3hCLFNBQVMsU0FBUyxj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
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2J1aWxkaW5nL2NsaS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IDIwMjItMjAyNCBNYXR0ZXIuanMgQXV0aG9yc1xuICogU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbiAqL1xuXG5pbXBvcnQgeyBjb21tYW5kZXIgfSBmcm9tIFwiLi4vdXRpbC9jb21tYW5kZXIuanNcIjtcbmltcG9ydCB7IEJ1aWxkZXIsIFRhcmdldCB9IGZyb20gXCIuL2J1aWxkZXIuanNcIjtcbmltcG9ydCB7IEdyYXBoIH0gZnJvbSBcIi4vZ3JhcGguanNcIjtcbmltcG9ydCB7IFByb2plY3QgfSBmcm9tIFwiLi9wcm9qZWN0LmpzXCI7XG5pbXBvcnQgeyBzeW5jQWxsVHNjb25maWdzIH0gZnJvbSBcIi4vdHNjb25maWcuanNcIjtcblxuZW51bSBNb2RlIHtcbiAgICBCdWlsZFByb2plY3QsXG4gICAgQnVpbGRQcm9qZWN0V2l0aERlcGVuZGVuY2llcyxcbiAgICBCdWlsZFdvcmtzcGFjZSxcbiAgICBEaXNwbGF5R3JhcGgsXG4gICAgU3luY1RzY29uZmlncyxcbn1cblxuaW50ZXJmYWNlIEFyZ3Mge1xuICAgIHByZWZpeDogc3RyaW5nO1xuICAgIGNsZWFuPzogYm9vbGVhbjtcbiAgICB3b3Jrc3BhY2VzPzogYm9vbGVhbjtcbiAgICBkZXBlbmRlbmNpZXM/OiBib29sZWFuO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWFpbihhcmd2ID0gcHJvY2Vzcy5hcmd2KSB7XG4gICAgY29uc3QgdGFyZ2V0cyA9IEFycmF5PFRhcmdldD4oKTtcbiAgICBsZXQgbW9kZSA9IE1vZGUuQnVpbGRQcm9qZWN0O1xuXG4gICAgY29uc3QgcHJvZ3JhbSA9IGNvbW1hbmRlcihcIm1hdHRlci1idWlsZFwiLCBcIkJ1aWxkcyBwYWNrYWdlcyBhZGhlcmluZyB0byBtYXR0ZXIuanMgc3RhbmRhcmRzLlwiKVxuICAgICAgICAub3B0aW9uKFwiLXAsIC0tcHJlZml4IDxwYXRoPlwiLCBcInNwZWNpZnkgYnVpbGQgZGlyZWN0b3J5XCIsIFwiLlwiKVxuICAgICAgICAub3B0aW9uKFwiLWMsIC0tY2xlYW5cIiwgXCJjbGVhbiBiZWZvcmUgYnVpbGRcIiwgZmFsc2UpXG4gICAgICAgIC5vcHRpb24oXCItdywgLS13b3Jrc3BhY2VzXCIsIFwiYnVpbGQgYWxsIHdvcmtzcGFjZSBwYWNrYWdlc1wiLCBmYWxzZSlcbiAgICAgICAgLm9wdGlvbihcIi1kLCAtLWRlcGVuZGVuY2llc1wiLCBcImJ1aWxkIGRlcGVuZGVuY2llc1wiLCBmYWxzZSk7XG5cbiAgICBwcm9ncmFtXG4gICAgICAgIC5jb21tYW5kKFwiYnVpbGRcIilcbiAgICAgICAgLmRlc2NyaXB0aW9uKFwiKGRlZmF1bHQpIGJ1aWxkIEpTIGFuZCB0eXBlIGRlZmluaXRpb25zXCIpXG4gICAgICAgIC5hY3Rpb24oKCkgPT4ge30pO1xuXG4gICAgcHJvZ3JhbVxuICAgICAgICAuY29tbWFuZChcImNsZWFuXCIpXG4gICAgICAgIC5kZXNjcmlwdGlvbihcInJlbW92ZSBidWlsZCBhbmQgZGlzdCBkaXJlY3Rvcmllc1wiKVxuICAgICAgICAuYWN0aW9uKCgpID0+IHtcbiAgICAgICAgICAgIHRhcmdldHMucHVzaChUYXJnZXQuY2xlYW4pO1xuICAgICAgICB9KTtcblxuICAgIHByb2dyYW1cbiAgICAgICAgLmNvbW1hbmQoXCJ0eXBlc1wiKVxuICAgICAgICAuZGVzY3JpcHRpb24oXCJidWlsZCB0eXBlIGRlZmluaXRpb25zXCIpXG4gICAgICAgIC5hY3Rpb24oKCkgPT4ge1xuICAgICAgICAgICAgdGFyZ2V0cy5wdXNoKFRhcmdldC50eXBlcyk7XG4gICAgICAgIH0pO1xuXG4gICAgcHJvZ3JhbVxuICAgICAgICAuY29tbWFuZChcImVzbVwiKVxuICAgICAgICAuZGVzY3JpcHRpb24oXCJidWlsZCBKUyAoRVM2IG1vZHVsZXMpXCIpXG4gICAgICAgIC5hY3Rpb24oKCkgPT4ge1xuICAgICAgICAgICAgdGFyZ2V0cy5wdXNoKFRhcmdldC5lc20pO1xuICAgICAgICB9KTtcblxuICAgIHByb2dyYW1cbiAgICAgICAgLmNvbW1hbmQoXCJjanNcIilcbiAgICAgICAgLmRlc2NyaXB0aW9uKFwiYnVpbGQgSlMgKENvbW1vbkpTIG1vZHVsZXMpXCIpXG4gICAgICAgIC5hY3Rpb24oKCkgPT4ge1xuICAgICAgICAgICAgdGFyZ2V0cy5wdXNoKFRhcmdldC5janMpO1xuICAgICAgICB9KTtcblxuICAgIHByb2dyYW1cbiAgICAgICAgLmNvbW1hbmQoXCJncmFwaFwiKVxuICAgICAgICAuZGVzY3JpcHRpb24oXCJkaXNwbGF5IHRoZSB3b3Jrc3BhY2UgZ3JhcGhcIilcbiAgICAgICAgLmFjdGlvbigoKSA9PiB7XG4gICAgICAgICAgICBtb2RlID0gTW9kZS5EaXNwbGF5R3JhcGg7XG4gICAgICAgIH0pO1xuXG4gICAgcHJvZ3JhbVxuICAgICAgICAuY29tbWFuZChcInRzY29uZmlnc1wiKVxuICAgICAgICAuZGVzY3JpcHRpb24oXCJzeW5jIGFsbCB0c2NvbmZpZ3Mgd2l0aCBwYWNrYWdlLmpzb25cIilcbiAgICAgICAgLmFjdGlvbigoKSA9PiB7XG4gICAgICAgICAgICBtb2RlID0gTW9kZS5TeW5jVHNjb25maWdzO1xuICAgICAgICB9KTtcblxuICAgIHByb2dyYW0uYWN0aW9uKCgpID0+IHt9KTtcblxuICAgIGNvbnN0IGFyZ3MgPSBwcm9ncmFtLnBhcnNlKGFyZ3YpLm9wdHM8QXJncz4oKTtcblxuICAgIGlmIChtb2RlID09PSBNb2RlLkJ1aWxkUHJvamVjdCkge1xuICAgICAgICBpZiAoYXJncy53b3Jrc3BhY2VzKSB7XG4gICAgICAgICAgICBtb2RlID0gTW9kZS5CdWlsZFdvcmtzcGFjZTtcbiAgICAgICAgfSBlbHNlIGlmIChhcmdzLmRlcGVuZGVuY2llcykge1xuICAgICAgICAgICAgbW9kZSA9IE1vZGUuQnVpbGRQcm9qZWN0V2l0aERlcGVuZGVuY2llcztcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGZ1bmN0aW9uIGJ1aWxkZXIoZ3JhcGg/OiBHcmFwaCkge1xuICAgICAgICByZXR1cm4gbmV3IEJ1aWxkZXIoeyAuLi5hcmdzLCB0YXJnZXRzOiBbLi4udGFyZ2V0c10sIGdyYXBoIH0pO1xuICAgIH1cblxuICAgIHN3aXRjaCAobW9kZSBhcyBNb2RlKSB7XG4gICAgICAgIGNhc2UgTW9kZS5CdWlsZFByb2plY3Q6XG4gICAgICAgICAgICBjb25zdCBwcm9qZWN0ID0gbmV3IFByb2plY3QoYXJncy5wcmVmaXgpO1xuICAgICAgICAgICAgYXdhaXQgYnVpbGRlcigpLmJ1aWxkKHByb2plY3QpO1xuICAgICAgICAgICAgYnJlYWs7XG5cbiAgICAgICAgY2FzZSBNb2RlLkJ1aWxkUHJvamVjdFdpdGhEZXBlbmRlbmNpZXM6XG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgY29uc3QgZ3JhcGggPSBhd2FpdCBHcmFwaC5mb3JQcm9qZWN0KGFyZ3MucHJlZml4KTtcbiAgICAgICAgICAgICAgICBpZiAoZ3JhcGggPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBidWlsZCB3aXRoIGRlcGVuZGVuY2llcyBiZWNhdXNlICR7YXJncy5wcmVmaXh9IGlzIG5vdCBpbiBhIHdvcmtzcGFjZWApO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBhd2FpdCBncmFwaC5idWlsZChidWlsZGVyKGdyYXBoKSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBicmVhaztcblxuICAgICAgICBjYXNlIE1vZGUuQnVpbGRXb3Jrc3BhY2U6XG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgY29uc3QgZ3JhcGggPSBhd2FpdCBHcmFwaC5sb2FkKCk7XG4gICAgICAgICAgICAgICAgYXdhaXQgc3luY0FsbFRzY29uZmlncyhncmFwaCk7XG4gICAgICAgICAgICAgICAgYXdhaXQgZ3JhcGguYnVpbGQoYnVpbGRlcihncmFwaCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYnJlYWs7XG5cbiAgICAgICAgY2FzZSBNb2RlLkRpc3BsYXlHcmFwaDpcbiAgICAgICAgICAgIChhd2FpdCBHcmFwaC5sb2FkKCkpLmRpc3BsYXkoKTtcbiAgICAgICAgICAgIGJyZWFrO1xuXG4gICAgICAgIGNhc2UgTW9kZS5TeW5jVHNjb25maWdzOlxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGNvbnN0IGdyYXBoID0gYXdhaXQgR3JhcGgubG9hZCgpO1xuICAgICAgICAgICAgICAgIGF3YWl0IHN5bmNBbGxUc2NvbmZpZ3MoZ3JhcGgpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgYnJlYWs7XG4gICAgfVxufVxuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU1BLFNBQVMsaUJBQWlCO0FBQzFCLFNBQVMsU0FBUyxjQUFjO0FBQ2hDLFNBQVMsYUFBYTtBQUN0QixTQUFTLGVBQWU7QUFDeEIsU0FBUyx3QkFBd0I7QUFFakMsSUFBSyxPQUFMLGtCQUFLQSxVQUFMO0FBQ0ksRUFBQUEsWUFBQTtBQUNBLEVBQUFBLFlBQUE7QUFDQSxFQUFBQSxZQUFBO0FBQ0EsRUFBQUEsWUFBQTtBQUNBLEVBQUFBLFlBQUE7QUFMQyxTQUFBQTtBQUFBLEdBQUE7QUFlTCxlQUFzQixLQUFLLE9BQU8sUUFBUSxNQUFNO0FBQzVDLFFBQU0sVUFBVSxNQUFjO0FBQzlCLE1BQUksT0FBTztBQUVYLFFBQU0sVUFBVSxVQUFVLGdCQUFnQixrREFBa0QsRUFDdkYsT0FBTyx1QkFBdUIsMkJBQTJCLEdBQUcsRUFDNUQsT0FBTyxlQUFlLHNCQUFzQixLQUFLLEVBQ2pELE9BQU8sb0JBQW9CLGdDQUFnQyxLQUFLLEVBQ2hFLE9BQU8sc0JBQXNCLHNCQUFzQixLQUFLO0FBRTdELFVBQ0ssUUFBUSxPQUFPLEVBQ2YsWUFBWSx5Q0FBeUMsRUFDckQsT0FBTyxNQUFNO0FBQUEsRUFBQyxDQUFDO0FBRXBCLFVBQ0ssUUFBUSxPQUFPLEVBQ2YsWUFBWSxtQ0FBbUMsRUFDL0MsT0FBTyxNQUFNO0FBQ1YsWUFBUSxLQUFLLE9BQU8sS0FBSztBQUFBLEVBQzdCLENBQUM7QUFFTCxVQUNLLFFBQVEsT0FBTyxFQUNmLFlBQVksd0JBQXdCLEVBQ3BDLE9BQU8sTUFBTTtBQUNWLFlBQVEsS0FBSyxPQUFPLEtBQUs7QUFBQSxFQUM3QixDQUFDO0FBRUwsVUFDSyxRQUFRLEtBQUssRUFDYixZQUFZLHdCQUF3QixFQUNwQyxPQUFPLE1BQU07QUFDVixZQUFRLEtBQUssT0FBTyxHQUFHO0FBQUEsRUFDM0IsQ0FBQztBQUVMLFVBQ0ssUUFBUSxLQUFLLEVBQ2IsWUFBWSw2QkFBNkIsRUFDekMsT0FBTyxNQUFNO0FBQ1YsWUFBUSxLQUFLLE9BQU8sR0FBRztBQUFBLEVBQzNCLENBQUM7QUFFTCxVQUNLLFFBQVEsT0FBTyxFQUNmLFlBQVksNkJBQTZCLEVBQ3pDLE9BQU8sTUFBTTtBQUNWLFdBQU87QUFBQSxFQUNYLENBQUM7QUFFTCxVQUNLLFFBQVEsV0FBVyxFQUNuQixZQUFZLHNDQUFzQyxFQUNsRCxPQUFPLE1BQU07QUFDVixXQUFPO0FBQUEsRUFDWCxDQUFDO0FBRUwsVUFBUSxPQUFPLE1BQU07QUFBQSxFQUFDLENBQUM7QUFFdkIsUUFBTSxPQUFPLFFBQVEsTUFBTSxJQUFJLEVBQUUsS0FBVztBQUU1QyxNQUFJLFNBQVMsc0JBQW1CO0FBQzVCLFFBQUksS0FBSyxZQUFZO0FBQ2pCLGFBQU87QUFBQSxJQUNYLFdBQVcsS0FBSyxjQUFjO0FBQzFCLGFBQU87QUFBQSxJQUNYO0FBQUEsRUFDSjtBQUVBLFdBQVMsUUFBUSxPQUFlO0FBQzVCLFdBQU8sSUFBSSxRQUFRLEVBQUUsR0FBRyxNQUFNLFNBQVMsQ0FBQyxHQUFHLE9BQU8sR0FBRyxNQUFNLENBQUM7QUFBQSxFQUNoRTtBQUVBLFVBQVEsTUFBYztBQUFBLElBQ2xCLEtBQUs7QUFDRCxZQUFNLFVBQVUsSUFBSSxRQUFRLEtBQUssTUFBTTtBQUN2QyxZQUFNLFFBQVEsRUFBRSxNQUFNLE9BQU87QUFDN0I7QUFBQSxJQUVKLEtBQUs7QUFDRDtBQUNJLGNBQU0sUUFBUSxNQUFNLE1BQU0sV0FBVyxLQUFLLE1BQU07QUFDaEQsWUFBSSxVQUFVLFFBQVc7QUFDckIsZ0JBQU0sSUFBSSxNQUFNLDBDQUEwQyxLQUFLLE1BQU0sd0JBQXdCO0FBQUEsUUFDakc7QUFDQSxjQUFNLE1BQU0sTUFBTSxRQUFRLEtBQUssQ0FBQztBQUFBLE1BQ3BDO0FBQ0E7QUFBQSxJQUVKLEtBQUs7QUFDRDtBQUNJLGNBQU0sUUFBUSxNQUFNLE1BQU0sS0FBSztBQUMvQixjQUFNLGlCQUFpQixLQUFLO0FBQzVCLGNBQU0sTUFBTSxNQUFNLFFBQVEsS0FBSyxDQUFDO0FBQUEsTUFDcEM7QUFDQTtBQUFBLElBRUosS0FBSztBQUNELE9BQUMsTUFBTSxNQUFNLEtBQUssR0FBRyxRQUFRO0FBQzdCO0FBQUEsSUFFSixLQUFLO0FBQ0Q7QUFDSSxjQUFNLFFBQVEsTUFBTSxNQUFNLEtBQUs7QUFDL0IsY0FBTSxpQkFBaUIsS0FBSztBQUFBLE1BQ2hDO0FBQ0E7QUFBQSxFQUNSO0FBQ0o7IiwKICAibmFtZXMiOiBbIk1vZGUiXQp9Cg==

@@ -6,3 +6,2 @@ /**

*/
import mapWorkspaces from "@npmcli/map-workspaces";
import colors from "ansi-colors";

@@ -144,7 +143,7 @@ import { JsonNotFoundError, Package } from "../util/package.js";

static async #loadNodes(workspace) {
const workspaces = await mapWorkspaces({ pkg: workspace.json, cwd: workspace.path });
const workspaces = workspace.json.workspaces;
const nodeMap = {};
const allDeps = {};
for (const path of workspaces.values()) {
const pkg = new Package({ path });
const pkg = new Package({ path: workspace.resolve(path) });
allDeps[pkg.json.name] = pkg.dependencies;

@@ -193,2 +192,2 @@ nodeMap[pkg.json.name] = {

};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/graph.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport mapWorkspaces from \"@npmcli/map-workspaces\";\nimport colors from \"ansi-colors\";\nimport { JsonNotFoundError, Package } from \"../util/package.js\";\nimport { Progress } from \"../util/progress.js\";\nimport { Builder } from \"./builder.js\";\nimport { InternalBuildError } from \"./error.js\";\nimport { BUILD_INFO_LOCATION, BuildInformation, Project } from \"./project.js\";\n\n/**\n * Graph of dependencies for workspace packages.\n *\n * We use this information to determine which packages are \"dirty\" and need rebuild.  In the future we can also use for\n * parallel build, only tricky part there is showing status.\n */\nexport class Graph {\n    protected constructor(readonly nodes: Graph.Node[]) {}\n\n    get(name: string) {\n        const node = this.nodes.find(node => node.pkg.name === name);\n        if (node === undefined) {\n            throw new Error(`Cannot locate package \"${name}\"`);\n        }\n        return node;\n    }\n\n    static async load(pkg = Package.workspace) {\n        const nodeMap = await this.#loadNodes(pkg.workspace);\n        return await this.#createGraph(Object.values(nodeMap));\n    }\n\n    static async forProject(path: string): Promise<Graph | undefined> {\n        let workspace;\n        try {\n            workspace = Package.workspaceFor(path);\n        } catch (e) {\n            if (e instanceof JsonNotFoundError) {\n                // Project is not in a workspace\n                return;\n            }\n            throw e;\n        }\n\n        const nodeMap = await this.#loadNodes(workspace);\n\n        const rootPkg = new Package({ path: path });\n        const rootNode = nodeMap[rootPkg.json.name];\n        if (!rootNode) {\n            // Project resides under a workspace but is not part of the workspace\n            return;\n        }\n\n        const nodes = new Set<Graph.Node>();\n        function addNode(node: Graph.Node) {\n            if (nodes.has(node)) {\n                return;\n            }\n            nodes.add(node);\n            for (const dependency of node.dependencies) {\n                addNode(dependency);\n            }\n        }\n\n        addNode(rootNode);\n\n        return await this.#createGraph([...nodes]);\n    }\n\n    // TODO - parallelization will be trivial except need to update Progress to support display of multiple simultaneous\n    // tasks\n    async build(builder: Builder, showSkipped = true) {\n        const toBuild = new Set(this.nodes);\n\n        const needsConfig = this.nodes.find(node => node.pkg.hasConfig);\n        if (builder.hasClean || needsConfig) {\n            try {\n                // We clean all packages before engaging typescript because otherwise it seems to get confused\n                if (builder.hasClean) {\n                    builder.clearClean();\n                    for (const node of this.nodes) {\n                        await node.project.clean();\n                        node.info = {};\n                    }\n                }\n\n                // We configure each build before building so that any generated files are in place before we initiate the build\n                for (const node of this.nodes) {\n                    if (!node.pkg.hasConfig) {\n                        continue;\n                    }\n                    await builder.configure(node.project);\n                }\n            } catch (e) {\n                console.error(\"Terminating due to prebuild error:\", e);\n                process.exit(1);\n            }\n        }\n\n        while (toBuild.size) {\n            let node;\n\n            nodes: for (node of toBuild) {\n                for (const dep of node.dependencies) {\n                    if (dep.isDirty) {\n                        continue nodes;\n                    }\n                }\n                break;\n            }\n\n            if (!node) {\n                throw new Error(\"Internal logic error: No unbuilt project has fully built dependencies\");\n            }\n            if (node.isDirty || builder.unconditional) {\n                await builder.build(node.project);\n                node.info.timestamp = new Date().toISOString();\n            } else if (showSkipped) {\n                new Progress().skip(\"Up to date\", node.pkg);\n            }\n\n            toBuild.delete(node);\n        }\n    }\n\n    display() {\n        for (const node of this.nodes) {\n            const progress = node.pkg.start(\"Node\");\n            progress.info(\"path\", node.pkg.path);\n            progress.info(\"modified\", formatTime(node.modifyTime));\n            progress.info(\"built\", formatTime(node.info.timestamp ?? 0));\n            progress.info(\"dirty\", node.isDirty ? colors.dim.red(\"yes\") : colors.dim.green(\"no\"));\n            progress.info(\"dependencies\", node.dependencies.map(formatDep).join(\", \"));\n            progress.shutdown();\n        }\n    }\n\n    static async #createGraph(nodes: Graph.Node[]) {\n        const graph = new Graph(nodes);\n\n        await Promise.all(\n            graph.nodes.map(async node => {\n                if (node.pkg.hasFile(BUILD_INFO_LOCATION)) {\n                    node.info = await node.pkg.readJson(BUILD_INFO_LOCATION);\n                }\n\n                node.modifyTime = await node.pkg.lastModified(\"package.json\", \"src\", \"test\");\n\n                return node;\n            }),\n        );\n\n        const stack = Array<Graph.Node>();\n        function findCircular(node: Graph.Node) {\n            if (stack.indexOf(node) !== -1) {\n                stack.push(node);\n                throw new InternalBuildError(`Circular dependency: ${stack.map(formatDep).join(\" \u25B8 \")}`);\n            }\n            stack.push(node);\n            for (const dep of node.dependencies) {\n                findCircular(dep);\n            }\n            stack.pop();\n        }\n        for (const node of graph.nodes) {\n            findCircular(node);\n        }\n\n        return graph;\n    }\n\n    static async #loadNodes(workspace: Package) {\n        const workspaces = await mapWorkspaces({ pkg: workspace.json, cwd: workspace.path });\n\n        const nodeMap = {} as Record<string, Graph.Node>;\n        const allDeps = {} as Record<string, string[]>;\n        for (const path of workspaces.values()) {\n            const pkg = new Package({ path: path });\n            allDeps[pkg.json.name] = pkg.dependencies;\n            nodeMap[pkg.json.name] = {\n                pkg,\n                project: new Project(pkg),\n                dependencies: [],\n                info: {},\n                modifyTime: 0,\n\n                get buildTime() {\n                    return this.info.timestamp ? new Date(this.info.timestamp).getTime() : 0;\n                },\n\n                get isDirty() {\n                    return (\n                        this.modifyTime > this.buildTime ||\n                        !!this.dependencies.find(\n                            dep =>\n                                dep.isDirty ||\n                                (dep.buildTime > this.buildTime &&\n                                    (dep.info.apiSha === undefined ||\n                                        dep.info.apiSha !== this.info.dependencyApiShas?.[dep.pkg.name])),\n                        )\n                    );\n                },\n            };\n        }\n\n        for (const name in allDeps) {\n            for (const dep of allDeps[name]) {\n                const depNode = nodeMap[dep];\n\n                // Note -- allow nodes to reference themselves, seems to be necessary on tools for use of tsc\n                if (depNode && depNode !== nodeMap[name]) {\n                    nodeMap[name].dependencies.push(depNode);\n                }\n            }\n        }\n\n        return nodeMap;\n    }\n}\n\nexport namespace Graph {\n    export interface Node {\n        pkg: Package;\n        project: Project;\n        dependencies: Node[];\n        buildTime: number;\n        info: BuildInformation;\n        modifyTime: number;\n        isDirty: boolean;\n    }\n}\n\nfunction formatTime(time: number | string) {\n    if (!time) {\n        return colors.dim.red(\"never\");\n    }\n    if (typeof time === \"string\") {\n        time = new Date(time).getTime();\n    }\n    return new Date(time - new Date().getTimezoneOffset()).toISOString().split(\".\")[0].replace(\"T\", \" \");\n}\n\nfunction formatDep(node: Graph.Node) {\n    return node.pkg.name.replace(/^@matter\\//, \"\");\n}\n"],
  "mappings": "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",
  "names": ["node"]
}

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/graph.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport colors from \"ansi-colors\";\nimport { JsonNotFoundError, Package } from \"../util/package.js\";\nimport { Progress } from \"../util/progress.js\";\nimport { Builder } from \"./builder.js\";\nimport { InternalBuildError } from \"./error.js\";\nimport { BUILD_INFO_LOCATION, BuildInformation, Project } from \"./project.js\";\n\n/**\n * Graph of dependencies for workspace packages.\n *\n * We use this information to determine which packages are \"dirty\" and need rebuild.  In the future we can also use for\n * parallel build, only tricky part there is showing status.\n */\nexport class Graph {\n    protected constructor(readonly nodes: Graph.Node[]) {}\n\n    get(name: string) {\n        const node = this.nodes.find(node => node.pkg.name === name);\n        if (node === undefined) {\n            throw new Error(`Cannot locate package \"${name}\"`);\n        }\n        return node;\n    }\n\n    static async load(pkg = Package.workspace) {\n        const nodeMap = await this.#loadNodes(pkg.workspace);\n        return await this.#createGraph(Object.values(nodeMap));\n    }\n\n    static async forProject(path: string): Promise<Graph | undefined> {\n        let workspace;\n        try {\n            workspace = Package.workspaceFor(path);\n        } catch (e) {\n            if (e instanceof JsonNotFoundError) {\n                // Project is not in a workspace\n                return;\n            }\n            throw e;\n        }\n\n        const nodeMap = await this.#loadNodes(workspace);\n\n        const rootPkg = new Package({ path: path });\n        const rootNode = nodeMap[rootPkg.json.name];\n        if (!rootNode) {\n            // Project resides under a workspace but is not part of the workspace\n            return;\n        }\n\n        const nodes = new Set<Graph.Node>();\n        function addNode(node: Graph.Node) {\n            if (nodes.has(node)) {\n                return;\n            }\n            nodes.add(node);\n            for (const dependency of node.dependencies) {\n                addNode(dependency);\n            }\n        }\n\n        addNode(rootNode);\n\n        return await this.#createGraph([...nodes]);\n    }\n\n    // TODO - parallelization will be trivial except need to update Progress to support display of multiple simultaneous\n    // tasks\n    async build(builder: Builder, showSkipped = true) {\n        const toBuild = new Set(this.nodes);\n\n        const needsConfig = this.nodes.find(node => node.pkg.hasConfig);\n        if (builder.hasClean || needsConfig) {\n            try {\n                // We clean all packages before engaging typescript because otherwise it seems to get confused\n                if (builder.hasClean) {\n                    builder.clearClean();\n                    for (const node of this.nodes) {\n                        await node.project.clean();\n                        node.info = {};\n                    }\n                }\n\n                // We configure each build before building so that any generated files are in place before we initiate the build\n                for (const node of this.nodes) {\n                    if (!node.pkg.hasConfig) {\n                        continue;\n                    }\n                    await builder.configure(node.project);\n                }\n            } catch (e) {\n                console.error(\"Terminating due to prebuild error:\", e);\n                process.exit(1);\n            }\n        }\n\n        while (toBuild.size) {\n            let node;\n\n            nodes: for (node of toBuild) {\n                for (const dep of node.dependencies) {\n                    if (dep.isDirty) {\n                        continue nodes;\n                    }\n                }\n                break;\n            }\n\n            if (!node) {\n                throw new Error(\"Internal logic error: No unbuilt project has fully built dependencies\");\n            }\n            if (node.isDirty || builder.unconditional) {\n                await builder.build(node.project);\n                node.info.timestamp = new Date().toISOString();\n            } else if (showSkipped) {\n                new Progress().skip(\"Up to date\", node.pkg);\n            }\n\n            toBuild.delete(node);\n        }\n    }\n\n    display() {\n        for (const node of this.nodes) {\n            const progress = node.pkg.start(\"Node\");\n            progress.info(\"path\", node.pkg.path);\n            progress.info(\"modified\", formatTime(node.modifyTime));\n            progress.info(\"built\", formatTime(node.info.timestamp ?? 0));\n            progress.info(\"dirty\", node.isDirty ? colors.dim.red(\"yes\") : colors.dim.green(\"no\"));\n            progress.info(\"dependencies\", node.dependencies.map(formatDep).join(\", \"));\n            progress.shutdown();\n        }\n    }\n\n    static async #createGraph(nodes: Graph.Node[]) {\n        const graph = new Graph(nodes);\n\n        await Promise.all(\n            graph.nodes.map(async node => {\n                if (node.pkg.hasFile(BUILD_INFO_LOCATION)) {\n                    node.info = await node.pkg.readJson(BUILD_INFO_LOCATION);\n                }\n\n                node.modifyTime = await node.pkg.lastModified(\"package.json\", \"src\", \"test\");\n\n                return node;\n            }),\n        );\n\n        const stack = Array<Graph.Node>();\n        function findCircular(node: Graph.Node) {\n            if (stack.indexOf(node) !== -1) {\n                stack.push(node);\n                throw new InternalBuildError(`Circular dependency: ${stack.map(formatDep).join(\" \u25B8 \")}`);\n            }\n            stack.push(node);\n            for (const dep of node.dependencies) {\n                findCircular(dep);\n            }\n            stack.pop();\n        }\n        for (const node of graph.nodes) {\n            findCircular(node);\n        }\n\n        return graph;\n    }\n\n    static async #loadNodes(workspace: Package) {\n        const workspaces = workspace.json.workspaces;\n\n        const nodeMap = {} as Record<string, Graph.Node>;\n        const allDeps = {} as Record<string, string[]>;\n        for (const path of workspaces.values()) {\n            const pkg = new Package({ path: workspace.resolve(path) });\n            allDeps[pkg.json.name] = pkg.dependencies;\n            nodeMap[pkg.json.name] = {\n                pkg,\n                project: new Project(pkg),\n                dependencies: [],\n                info: {},\n                modifyTime: 0,\n\n                get buildTime() {\n                    return this.info.timestamp ? new Date(this.info.timestamp).getTime() : 0;\n                },\n\n                get isDirty() {\n                    return (\n                        this.modifyTime > this.buildTime ||\n                        !!this.dependencies.find(\n                            dep =>\n                                dep.isDirty ||\n                                (dep.buildTime > this.buildTime &&\n                                    (dep.info.apiSha === undefined ||\n                                        dep.info.apiSha !== this.info.dependencyApiShas?.[dep.pkg.name])),\n                        )\n                    );\n                },\n            };\n        }\n\n        for (const name in allDeps) {\n            for (const dep of allDeps[name]) {\n                const depNode = nodeMap[dep];\n\n                // Note -- allow nodes to reference themselves, seems to be necessary on tools for use of tsc\n                if (depNode && depNode !== nodeMap[name]) {\n                    nodeMap[name].dependencies.push(depNode);\n                }\n            }\n        }\n\n        return nodeMap;\n    }\n}\n\nexport namespace Graph {\n    export interface Node {\n        pkg: Package;\n        project: Project;\n        dependencies: Node[];\n        buildTime: number;\n        info: BuildInformation;\n        modifyTime: number;\n        isDirty: boolean;\n    }\n}\n\nfunction formatTime(time: number | string) {\n    if (!time) {\n        return colors.dim.red(\"never\");\n    }\n    if (typeof time === \"string\") {\n        time = new Date(time).getTime();\n    }\n    return new Date(time - new Date().getTimezoneOffset()).toISOString().split(\".\")[0].replace(\"T\", \" \");\n}\n\nfunction formatDep(node: Graph.Node) {\n    return node.pkg.name.replace(/^@matter\\//, \"\");\n}\n"],
  "mappings": "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",
  "names": ["node"]
}


@@ -8,3 +8,2 @@ /**

import { cp, mkdir, readFile, rm, symlink, writeFile } from "fs/promises";
import { glob } from "glob";
import { platform } from "os";

@@ -26,3 +25,5 @@ import { dirname, join } from "path";

if (!this.pkg.hasSrc) {
throw new Error(`Found package ${this.pkg.json.name} but no src directory is present`);
throw new Error(
`Found package ${this.pkg.json.name} but src directory is not present or not referenced in tsconfig.json`
);
}

@@ -122,3 +123,6 @@ }

for (const format of formats) {
await cp(this.pkg.resolve(source), this.pkg.resolve(join("dist", format, dest)));
await cp(this.pkg.resolve(source), this.pkg.resolve(join("dist", format, dest)), {
recursive: true,
force: true
});
}

@@ -171,7 +175,7 @@ }

async #targetsOf(indir, outdir, ...extensions) {
indir = this.pkg.resolve(indir).replace(/\\/g, "/");
const inputPrefixLength = this.pkg.resolve(indir).length + 1;
outdir = this.pkg.resolve(outdir).replace(/\\/g, "/");
return (await glob(extensions.map((ext) => `${indir}/**/*.${ext}`))).map((file) => ({
return (await this.pkg.glob(extensions.map((ext) => `${indir}/**/*.${ext}`))).map((file) => ({
in: file,
out: `${outdir}/${file.slice(indir.length + 1)}`
out: `${outdir}/${file.slice(inputPrefixLength)}`
}));

@@ -184,2 +188,2 @@ }

};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/project.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Hash } from \"crypto\";\nimport { build as esbuild, Format } from \"esbuild\";\nimport { cp, mkdir, readFile, rm, symlink, writeFile } from \"fs/promises\";\nimport { glob } from \"glob\";\nimport { platform } from \"os\";\nimport { dirname, join } from \"path\";\nimport { ignoreError } from \"../util/errors.js\";\nimport { CONFIG_PATH, Package } from \"../util/package.js\";\n\nexport const BUILD_INFO_LOCATION = \"build/info.json\";\n\nexport interface BuildInformation {\n    /**\n     * Time of last build.  Compared to source files to determine whether build is dirty.\n     */\n    timestamp?: string;\n\n    /**\n     * API signature.  Used by dependents to determine whether they need to rebuild after we do.\n     */\n    apiSha?: string;\n\n    /**\n     * API signature of each dependency.  Compared to apiSha of each dependency during dirty detection.\n     */\n    dependencyApiShas?: Record<string, string>;\n}\n\nexport class Project {\n    pkg: Package;\n    #config?: Project.Config;\n    #configured?: boolean;\n\n    constructor(source: Package | string = \".\") {\n        if (typeof source === \"string\") {\n            this.pkg = new Package({ path: source });\n        } else {\n            this.pkg = source;\n        }\n\n        if (!this.pkg.hasSrc) {\n            throw new Error(`Found package ${this.pkg.json.name} but no src directory is present`);\n        }\n    }\n\n    async buildSource(format: Format) {\n        await this.#build(format, \"src\", `dist/${format}`);\n        await this.#configureFormat(\"dist\", format, true);\n    }\n\n    async buildTests(format: Format) {\n        if (this.pkg.hasDirectory(\"test\")) {\n            await this.#build(format, \"test\", `build/${format}/test`);\n        }\n\n        const src = `dist/${format}`;\n        const dest = `build/${format}/src`;\n\n        try {\n            const destPath = this.pkg.resolve(dest);\n            await mkdir(dirname(destPath), { recursive: true });\n            await ignoreError(\"EEXIST\", async () => await symlink(this.pkg.resolve(src), destPath));\n        } catch (e) {\n            if ((e as any).code === \"EPERM\" && platform() === \"win32\") {\n                // If developer mode is not enabled, we can't create a symlink\n                // on Windows.  Copy instead\n                await cp(this.pkg.resolve(src), this.pkg.resolve(dest), {\n                    recursive: true,\n                    force: true,\n                });\n            } else {\n                throw e;\n            }\n        }\n        await this.#configureFormat(\"build\", format, false);\n    }\n\n    async clean() {\n        for (const dir of [\"build\", \"dist\"]) {\n            await rm(this.pkg.resolve(dir), { recursive: true, force: true });\n        }\n    }\n\n    get hasDeclarations() {\n        return this.pkg.hasDirectory(\"build/types\");\n    }\n\n    async hashDeclarations(apiSha: Hash) {\n        if (!this.pkg.isLibrary) {\n            return;\n        }\n\n        let path;\n        if (this.pkg.supportsEsm) {\n            path = \"esm\";\n        } else if (this.pkg.supportsCjs) {\n            path = \"cjs\";\n        } else {\n            return;\n        }\n\n        const declarations = (await this.pkg.glob(`dist/${path}/**/*.d.ts*`)).sort();\n        for (const file of declarations) {\n            apiSha.update(file);\n            apiSha.update(await readFile(file));\n        }\n    }\n\n    async recordBuildInfo(info: BuildInformation) {\n        await mkdir(this.pkg.resolve(\"build\"), { recursive: true });\n        info.timestamp = new Date().toISOString();\n        await writeFile(this.pkg.resolve(BUILD_INFO_LOCATION), JSON.stringify(info, undefined, 4));\n    }\n\n    async configure() {\n        if (this.#configured) {\n            return this.#config;\n        }\n\n        if (!this.pkg.hasConfig) {\n            return {};\n        }\n\n        const configPath = this.pkg.resolve(CONFIG_PATH);\n\n        const outfile = configPath.replace(/\\\\/g, \"/\").replace(\"/src/\", \"/build/\").replace(/\\.ts$/, \".js\");\n        await esbuild({\n            entryPoints: [configPath],\n            outfile,\n            sourcemap: true,\n        });\n\n        this.#config = (await import(`file://${outfile}`)) as Project.Config | undefined;\n        this.#configured = true;\n\n        if (this.#config?.startup) {\n            await this.#config?.startup({\n                project: this,\n            });\n        }\n\n        return this.#config;\n    }\n\n    /**\n     * Copy files into dist for supported formats.\n     */\n    async copyToDist(source: string, dest: string) {\n        const formats = Array<string>();\n        if (this.pkg.supportsEsm) {\n            formats.push(\"esm\");\n        }\n        if (this.pkg.supportsCjs) {\n            formats.push(\"cjs\");\n        }\n        for (const format of formats) {\n            await cp(this.pkg.resolve(source), this.pkg.resolve(join(\"dist\", format, dest)));\n        }\n    }\n\n    async #build(format: Format, indir: string, outdir: string) {\n        const entryPoints = await this.#targetsOf(indir, outdir, \"ts\", \"js\");\n\n        const configPath = this.pkg.resolve(CONFIG_PATH);\n        for (const entry of entryPoints) {\n            if (entry.in === configPath) {\n                continue;\n            }\n            entry.out = entry.out.replace(/\\.[jt]s$/, \"\");\n        }\n\n        await esbuild({\n            entryPoints,\n            outdir: this.pkg.path,\n            format,\n            sourcemap: true,\n            sourcesContent: false,\n            absWorkingDir: dirname(this.pkg.resolve(indir)),\n\n            // This is necessary to downlevel \"using\"\n            target: \"es2022\",\n\n            logOverride: {\n                \"direct-eval\": \"silent\",\n            },\n        });\n\n        for (const entry of await this.#targetsOf(indir, outdir, \"cjs\", \"mjs\", \"d.cts\", \"d.mts\")) {\n            await cp(entry.in, entry.out);\n        }\n    }\n\n    async #configureFormat(dir: string, format: Format, isDist: boolean) {\n        // Build import map\n        let { imports } = this.pkg.json;\n        if (isDist && typeof imports === \"object\") {\n            imports = { ...imports };\n            for (const key in imports) {\n                const value = imports[key];\n                if (typeof value === \"string\") {\n                    imports[key] = value.replace(/^\\.\\/src\\//, \"./\");\n                }\n            }\n        }\n\n        // Write package.json\n        const path = this.pkg.resolve(`${dir}/${format}/package.json`);\n        const json: Record<string, unknown> = {\n            type: format === \"cjs\" ? \"commonjs\" : \"module\",\n            imports,\n        };\n        await writeFile(path, JSON.stringify(json, undefined, 4));\n    }\n\n    async #targetsOf(indir: string, outdir: string, ...extensions: string[]) {\n        indir = this.pkg.resolve(indir).replace(/\\\\/g, \"/\");\n        outdir = this.pkg.resolve(outdir).replace(/\\\\/g, \"/\");\n\n        return (await glob(extensions.map(ext => `${indir}/**/*.${ext}`))).map(file => ({\n            in: file,\n            out: `${outdir}/${file.slice(indir.length + 1)}`,\n        }));\n    }\n}\n\nexport namespace Project {\n    export interface Context {\n        project: Project;\n    }\n\n    export interface Config {\n        startup?: (context: Context) => Promise<void>;\n        before?: (context: Context) => Promise<void>;\n        after?: (context: Context) => Promise<void>;\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/project.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { Hash } from \"crypto\";\nimport { build as esbuild, Format } from \"esbuild\";\nimport { cp, mkdir, readFile, rm, symlink, writeFile } from \"fs/promises\";\nimport { platform } from \"os\";\nimport { dirname, join } from \"path\";\nimport { ignoreError } from \"../util/errors.js\";\nimport { CONFIG_PATH, Package } from \"../util/package.js\";\n\nexport const BUILD_INFO_LOCATION = \"build/info.json\";\n\nexport interface BuildInformation {\n    /**\n     * Time of last build.  Compared to source files to determine whether build is dirty.\n     */\n    timestamp?: string;\n\n    /**\n     * API signature.  Used by dependents to determine whether they need to rebuild after we do.\n     */\n    apiSha?: string;\n\n    /**\n     * API signature of each dependency.  Compared to apiSha of each dependency during dirty detection.\n     */\n    dependencyApiShas?: Record<string, string>;\n}\n\nexport class Project {\n    pkg: Package;\n    #config?: Project.Config;\n    #configured?: boolean;\n\n    constructor(source: Package | string = \".\") {\n        if (typeof source === \"string\") {\n            this.pkg = new Package({ path: source });\n        } else {\n            this.pkg = source;\n        }\n\n        if (!this.pkg.hasSrc) {\n            throw new Error(\n                `Found package ${this.pkg.json.name} but src directory is not present or not referenced in tsconfig.json`,\n            );\n        }\n    }\n\n    async buildSource(format: Format) {\n        await this.#build(format, \"src\", `dist/${format}`);\n        await this.#configureFormat(\"dist\", format, true);\n    }\n\n    async buildTests(format: Format) {\n        if (this.pkg.hasDirectory(\"test\")) {\n            await this.#build(format, \"test\", `build/${format}/test`);\n        }\n\n        const src = `dist/${format}`;\n        const dest = `build/${format}/src`;\n\n        try {\n            const destPath = this.pkg.resolve(dest);\n            await mkdir(dirname(destPath), { recursive: true });\n            await ignoreError(\"EEXIST\", async () => await symlink(this.pkg.resolve(src), destPath));\n        } catch (e) {\n            if ((e as any).code === \"EPERM\" && platform() === \"win32\") {\n                // If developer mode is not enabled, we can't create a symlink\n                // on Windows.  Copy instead\n                await cp(this.pkg.resolve(src), this.pkg.resolve(dest), {\n                    recursive: true,\n                    force: true,\n                });\n            } else {\n                throw e;\n            }\n        }\n        await this.#configureFormat(\"build\", format, false);\n    }\n\n    async clean() {\n        for (const dir of [\"build\", \"dist\"]) {\n            await rm(this.pkg.resolve(dir), { recursive: true, force: true });\n        }\n    }\n\n    get hasDeclarations() {\n        return this.pkg.hasDirectory(\"build/types\");\n    }\n\n    async hashDeclarations(apiSha: Hash) {\n        if (!this.pkg.isLibrary) {\n            return;\n        }\n\n        let path;\n        if (this.pkg.supportsEsm) {\n            path = \"esm\";\n        } else if (this.pkg.supportsCjs) {\n            path = \"cjs\";\n        } else {\n            return;\n        }\n\n        const declarations = (await this.pkg.glob(`dist/${path}/**/*.d.ts*`)).sort();\n        for (const file of declarations) {\n            apiSha.update(file);\n            apiSha.update(await readFile(file));\n        }\n    }\n\n    async recordBuildInfo(info: BuildInformation) {\n        await mkdir(this.pkg.resolve(\"build\"), { recursive: true });\n        info.timestamp = new Date().toISOString();\n        await writeFile(this.pkg.resolve(BUILD_INFO_LOCATION), JSON.stringify(info, undefined, 4));\n    }\n\n    async configure() {\n        if (this.#configured) {\n            return this.#config;\n        }\n\n        if (!this.pkg.hasConfig) {\n            return {};\n        }\n\n        const configPath = this.pkg.resolve(CONFIG_PATH);\n\n        const outfile = configPath.replace(/\\\\/g, \"/\").replace(\"/src/\", \"/build/\").replace(/\\.ts$/, \".js\");\n        await esbuild({\n            entryPoints: [configPath],\n            outfile,\n            sourcemap: true,\n        });\n\n        this.#config = (await import(`file://${outfile}`)) as Project.Config | undefined;\n        this.#configured = true;\n\n        if (this.#config?.startup) {\n            await this.#config?.startup({\n                project: this,\n            });\n        }\n\n        return this.#config;\n    }\n\n    /**\n     * Copy files into dist for supported formats.\n     */\n    async copyToDist(source: string, dest: string) {\n        const formats = Array<string>();\n        if (this.pkg.supportsEsm) {\n            formats.push(\"esm\");\n        }\n        if (this.pkg.supportsCjs) {\n            formats.push(\"cjs\");\n        }\n        for (const format of formats) {\n            await cp(this.pkg.resolve(source), this.pkg.resolve(join(\"dist\", format, dest)), {\n                recursive: true,\n                force: true,\n            });\n        }\n    }\n\n    async #build(format: Format, indir: string, outdir: string) {\n        const entryPoints = await this.#targetsOf(indir, outdir, \"ts\", \"js\");\n\n        const configPath = this.pkg.resolve(CONFIG_PATH);\n        for (const entry of entryPoints) {\n            if (entry.in === configPath) {\n                continue;\n            }\n            entry.out = entry.out.replace(/\\.[jt]s$/, \"\");\n        }\n\n        await esbuild({\n            entryPoints,\n            outdir: this.pkg.path,\n            format,\n            sourcemap: true,\n            sourcesContent: false,\n            absWorkingDir: dirname(this.pkg.resolve(indir)),\n\n            // This is necessary to downlevel \"using\"\n            target: \"es2022\",\n\n            logOverride: {\n                \"direct-eval\": \"silent\",\n            },\n        });\n\n        for (const entry of await this.#targetsOf(indir, outdir, \"cjs\", \"mjs\", \"d.cts\", \"d.mts\")) {\n            await cp(entry.in, entry.out);\n        }\n    }\n\n    async #configureFormat(dir: string, format: Format, isDist: boolean) {\n        // Build import map\n        let { imports } = this.pkg.json;\n        if (isDist && typeof imports === \"object\") {\n            imports = { ...imports };\n            for (const key in imports) {\n                const value = imports[key];\n                if (typeof value === \"string\") {\n                    imports[key] = value.replace(/^\\.\\/src\\//, \"./\");\n                }\n            }\n        }\n\n        // Write package.json\n        const path = this.pkg.resolve(`${dir}/${format}/package.json`);\n        const json: Record<string, unknown> = {\n            type: format === \"cjs\" ? \"commonjs\" : \"module\",\n            imports,\n        };\n        await writeFile(path, JSON.stringify(json, undefined, 4));\n    }\n\n    async #targetsOf(indir: string, outdir: string, ...extensions: string[]) {\n        const inputPrefixLength = this.pkg.resolve(indir).length + 1;\n        outdir = this.pkg.resolve(outdir).replace(/\\\\/g, \"/\");\n\n        return (await this.pkg.glob(extensions.map(ext => `${indir}/**/*.${ext}`))).map(file => ({\n            in: file,\n            out: `${outdir}/${file.slice(inputPrefixLength)}`,\n        }));\n    }\n}\n\nexport namespace Project {\n    export interface Context {\n        project: Project;\n    }\n\n    export interface Config {\n        startup?: (context: Context) => Promise<void>;\n        before?: (context: Context) => Promise<void>;\n        after?: (context: Context) => Promise<void>;\n    }\n}\n"],
  "mappings": "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",
  "names": []
}


@@ -38,3 +38,3 @@ /**

}
const deps = node.dependencies.map((dep) => dep.pkg.resolve("src")).filter((p) => !p.match(/packages[\\/]tools/));
const deps = node.dependencies.filter((dep) => dep.pkg.isLibrary).map((dep) => dep.pkg.resolve("src")).filter((p) => !p.match(/packages[\\/]tools/));
const desired = [.../* @__PURE__ */ new Set([...deps, ...extraRefs])];

@@ -51,2 +51,2 @@ const newReferences = desired.map((ref) => ({ path: relative(path, ref).replace(/\\/g, "/") })).sort((ref1, ref2) => ref1.path.localeCompare(ref2.path));

};
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2J1aWxkaW5nL3RzY29uZmlnLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCB7IHJlbGF0aXZlLCByZXNvbHZlIH0gZnJvbSBcInBhdGhcIjtcbmltcG9ydCB7IEdyYXBoIH0gZnJvbSBcIi4vZ3JhcGguanNcIjtcblxuLyoqXG4gKiBVbmZvcnR1bmF0ZWx5IHR5cGVzY3JpcHQncyBcInByb2plY3QgcmVmZXJlbmNlc1wiIGFyZSByZWR1bmRhbnQgd2l0aCBwYWNrYWdlLmpzb24gZGVwZW5kZW5jaWVzLiAgV2UgZG9uJ3QgdXNlIHRoZW0gZm9yXG4gKiBidWlsZCBidXQgdGhlcmUgYXJlIHN0aWxsIHNvbWUgYWR2YW50YWdlcyB0byBtYWludGFpbmluZyB0aGVtIHNvIHdlIGp1c3QgZW5zdXJlIHRoZXkncmUgaW4gc3luYyBkdXJpbmcgd29ya3NwYWNlXG4gKiBidWlsZHMuXG4gKlxuICogT25lIGRpc2N1c3Npb24gb24gdGhlIHRvcGljOiBodHRwczovL2dpdGh1Yi5jb20vbWljcm9zb2Z0L1R5cGVTY3JpcHQvaXNzdWVzLzI1Mzc2XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzeW5jQWxsVHNjb25maWdzKGdyYXBoOiBHcmFwaCkge1xuICAgIGNvbnN0IHdvcmtzcGFjZSA9IGdyYXBoLm5vZGVzWzBdLnBrZy53b3Jrc3BhY2U7XG4gICAgY29uc3Qgcm9vdFRzY29uZmlnID0gYXdhaXQgd29ya3NwYWNlLnJlYWRKc29uKFwidHNjb25maWcuanNvblwiKTtcblxuICAgIGNvbnN0IG9yaWdpbmFsUmVmZXJlbmNlcyA9IHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzO1xuICAgIHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzID0gW107XG5cbiAgICBmb3IgKGNvbnN0IG5vZGUgb2YgZ3JhcGgubm9kZXMpIHtcbiAgICAgICAgYXdhaXQgc3luY1BhY2thZ2VUc2NvbmZpZ3MoZ3JhcGgsIG5vZGUpO1xuICAgICAgICByb290VHNjb25maWcucmVmZXJlbmNlcy5wdXNoKHsgcGF0aDogd29ya3NwYWNlLnJlbGF0aXZlKG5vZGUucGtnLnBhdGgpLnJlcGxhY2UoL1xcXFwvZywgXCIvXCIpIH0pO1xuICAgIH1cblxuICAgIGlmIChyZWZlcmVuY2VzQ2hhbmdlZChvcmlnaW5hbFJlZmVyZW5jZXMsIHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzKSkge1xuICAgICAgICBhd2FpdCB3b3Jrc3BhY2Uud3JpdGVKc29uKFwidHNjb25maWcuanNvblwiLCByb290VHNjb25maWcpO1xuICAgIH1cbn1cblxuZnVuY3Rpb24gcmVmZXJlbmNlc0NoYW5nZWQob3JpZ2luYWxSZWZlcmVuY2VzOiB1bmtub3duLCBuZXdSZWZlcmVuY2VzOiB1bmtub3duKSB7XG4gICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KG9yaWdpbmFsUmVmZXJlbmNlcykgIT09IEpTT04uc3RyaW5naWZ5KG5ld1JlZmVyZW5jZXMpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc3luY1BhY2thZ2VUc2NvbmZpZ3MoZ3JhcGg6IEdyYXBoLCBub2RlOiBHcmFwaC5Ob2RlKSB7XG4gICAgYXdhaXQgc3luY1N1YnByb2plY3Qobm9kZSwgXCJzcmNcIik7XG4gICAgYXdhaXQgc3luY1N1YnByb2plY3Qobm9kZSwgXCJ0ZXN0XCIsIG5vZGUucGtnLnJlc29sdmUoXCJzcmNcIiksIGdyYXBoLmdldChcIkBtYXR0ZXIvdG9vbHNcIikucGtnLnJlc29sdmUoXCJzcmNcIikpO1xufVxuXG5hc3luYyBmdW5jdGlvbiBzeW5jU3VicHJvamVjdChub2RlOiBHcmFwaC5Ob2RlLCBwYXRoOiBzdHJpbmcsIC4uLmV4dHJhUmVmczogc3RyaW5nW10pIHtcbiAgICBwYXRoID0gbm9kZS5wa2cucmVzb2x2ZShwYXRoKTtcblxuICAgIGNvbnN0IHRzY29uZmlnUGF0aCA9IHJlc29sdmUocGF0aCwgXCJ0c2NvbmZpZy5qc29uXCIpO1xuICAgIGlmICghbm9kZS5wa2cuaGFzRmlsZSh0c2NvbmZpZ1BhdGgpKSB7XG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB0c2NvbmZpZyA9IGF3YWl0IG5vZGUucGtnLnJlYWRKc29uKHRzY29uZmlnUGF0aCk7XG5cbiAgICBsZXQgcmVmcyA9IHRzY29uZmlnLnJlZnMgYXMgdW5kZWZpbmVkIHwgeyBwYXRoOiBzdHJpbmcgfVtdO1xuXG4gICAgaWYgKHJlZnMgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZWZzID0gW107XG4gICAgfVxuXG4gICAgY29uc3QgZGVwcyA9IG5vZGUuZGVwZW5kZW5jaWVzLm1hcChkZXAgPT4gZGVwLnBrZy5yZXNvbHZlKFwic3JjXCIpKS5maWx0ZXIocCA9PiAhcC5tYXRjaCgvcGFja2FnZXNbXFxcXC9ddG9vbHMvKSk7XG5cbiAgICBjb25zdCBkZXNpcmVkID0gWy4uLm5ldyBTZXQoWy4uLmRlcHMsIC4uLmV4dHJhUmVmc10pXTtcblxuICAgIGNvbnN0IG5ld1JlZmVyZW5jZXMgPSBkZXNpcmVkXG4gICAgICAgIC5tYXAocmVmID0+ICh7IHBhdGg6IHJlbGF0aXZlKHBhdGgsIHJlZikucmVwbGFjZSgvXFxcXC9nLCBcIi9cIikgfSkpXG4gICAgICAgIC5zb3J0KChyZWYxLCByZWYyKSA9PiByZWYxLnBhdGgubG9jYWxlQ29tcGFyZShyZWYyLnBhdGgpKTtcblxuICAgIGlmIChyZWZlcmVuY2VzQ2hhbmdlZCh0c2NvbmZpZy5yZWZlcmVuY2VzLCBuZXdSZWZlcmVuY2VzKSkge1xuICAgICAgICB0c2NvbmZpZy5yZWZlcmVuY2VzID0gbmV3UmVmZXJlbmNlcztcbiAgICAgICAgYXdhaXQgbm9kZS5wa2cud3JpdGVKc29uKHRzY29uZmlnUGF0aCwgdHNjb25maWcpO1xuICAgIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFNQSxTQUFTLFVBQVUsZUFBZTtBQVVsQyxlQUFzQixpQkFBaUIsT0FBYztBQUNqRCxRQUFNLFlBQVksTUFBTSxNQUFNLENBQUMsRUFBRSxJQUFJO0FBQ3JDLFFBQU0sZUFBZSxNQUFNLFVBQVUsU0FBUyxlQUFlO0FBRTdELFFBQU0scUJBQXFCLGFBQWE7QUFDeEMsZUFBYSxhQUFhLENBQUM7QUFFM0IsYUFBVyxRQUFRLE1BQU0sT0FBTztBQUM1QixVQUFNLHFCQUFxQixPQUFPLElBQUk7QUFDdEMsaUJBQWEsV0FBVyxLQUFLLEVBQUUsTUFBTSxVQUFVLFNBQVMsS0FBSyxJQUFJLElBQUksRUFBRSxRQUFRLE9BQU8sR0FBRyxFQUFFLENBQUM7QUFBQSxFQUNoRztBQUVBLE1BQUksa0JBQWtCLG9CQUFvQixhQUFhLFVBQVUsR0FBRztBQUNoRSxVQUFNLFVBQVUsVUFBVSxpQkFBaUIsWUFBWTtBQUFBLEVBQzNEO0FBQ0o7QUFFQSxTQUFTLGtCQUFrQixvQkFBNkIsZUFBd0I7QUFDNUUsU0FBTyxLQUFLLFVBQVUsa0JBQWtCLE1BQU0sS0FBSyxVQUFVLGFBQWE7QUFDOUU7QUFFQSxlQUFzQixxQkFBcUIsT0FBYyxNQUFrQjtBQUN2RSxRQUFNLGVBQWUsTUFBTSxLQUFLO0FBQ2hDLFFBQU0sZUFBZSxNQUFNLFFBQVEsS0FBSyxJQUFJLFFBQVEsS0FBSyxHQUFHLE1BQU0sSUFBSSxlQUFlLEVBQUUsSUFBSSxRQUFRLEtBQUssQ0FBQztBQUM3RztBQUVBLGVBQWUsZUFBZSxNQUFrQixTQUFpQixXQUFxQjtBQUNsRixTQUFPLEtBQUssSUFBSSxRQUFRLElBQUk7QUFFNUIsUUFBTSxlQUFlLFFBQVEsTUFBTSxlQUFlO0FBQ2xELE1BQUksQ0FBQyxLQUFLLElBQUksUUFBUSxZQUFZLEdBQUc7QUFDakM7QUFBQSxFQUNKO0FBRUEsUUFBTSxXQUFXLE1BQU0sS0FBSyxJQUFJLFNBQVMsWUFBWTtBQUVyRCxNQUFJLE9BQU8sU0FBUztBQUVwQixNQUFJLFNBQVMsUUFBVztBQUNwQixXQUFPLENBQUM7QUFBQSxFQUNaO0FBRUEsUUFBTSxPQUFPLEtBQUssYUFBYSxJQUFJLFNBQU8sSUFBSSxJQUFJLFFBQVEsS0FBSyxDQUFDLEVBQUUsT0FBTyxPQUFLLENBQUMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRTVHLFFBQU0sVUFBVSxDQUFDLEdBQUcsb0JBQUksSUFBSSxDQUFDLEdBQUcsTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDO0FBRXBELFFBQU0sZ0JBQWdCLFFBQ2pCLElBQUksVUFBUSxFQUFFLE1BQU0sU0FBUyxNQUFNLEdBQUcsRUFBRSxRQUFRLE9BQU8sR0FBRyxFQUFFLEVBQUUsRUFDOUQsS0FBSyxDQUFDLE1BQU0sU0FBUyxLQUFLLEtBQUssY0FBYyxLQUFLLElBQUksQ0FBQztBQUU1RCxNQUFJLGtCQUFrQixTQUFTLFlBQVksYUFBYSxHQUFHO0FBQ3ZELGFBQVMsYUFBYTtBQUN0QixVQUFNLEtBQUssSUFBSSxVQUFVLGNBQWMsUUFBUTtBQUFBLEVBQ25EO0FBQ0o7IiwKICAibmFtZXMiOiBbXQp9Cg==
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2J1aWxkaW5nL3RzY29uZmlnLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCB7IHJlbGF0aXZlLCByZXNvbHZlIH0gZnJvbSBcInBhdGhcIjtcbmltcG9ydCB7IEdyYXBoIH0gZnJvbSBcIi4vZ3JhcGguanNcIjtcblxuLyoqXG4gKiBVbmZvcnR1bmF0ZWx5IHR5cGVzY3JpcHQncyBcInByb2plY3QgcmVmZXJlbmNlc1wiIGFyZSByZWR1bmRhbnQgd2l0aCBwYWNrYWdlLmpzb24gZGVwZW5kZW5jaWVzLiAgV2UgZG9uJ3QgdXNlIHRoZW0gZm9yXG4gKiBidWlsZCBidXQgdGhlcmUgYXJlIHN0aWxsIHNvbWUgYWR2YW50YWdlcyB0byBtYWludGFpbmluZyB0aGVtIHNvIHdlIGp1c3QgZW5zdXJlIHRoZXkncmUgaW4gc3luYyBkdXJpbmcgd29ya3NwYWNlXG4gKiBidWlsZHMuXG4gKlxuICogT25lIGRpc2N1c3Npb24gb24gdGhlIHRvcGljOiBodHRwczovL2dpdGh1Yi5jb20vbWljcm9zb2Z0L1R5cGVTY3JpcHQvaXNzdWVzLzI1Mzc2XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzeW5jQWxsVHNjb25maWdzKGdyYXBoOiBHcmFwaCkge1xuICAgIGNvbnN0IHdvcmtzcGFjZSA9IGdyYXBoLm5vZGVzWzBdLnBrZy53b3Jrc3BhY2U7XG4gICAgY29uc3Qgcm9vdFRzY29uZmlnID0gYXdhaXQgd29ya3NwYWNlLnJlYWRKc29uKFwidHNjb25maWcuanNvblwiKTtcblxuICAgIGNvbnN0IG9yaWdpbmFsUmVmZXJlbmNlcyA9IHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzO1xuICAgIHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzID0gW107XG5cbiAgICBmb3IgKGNvbnN0IG5vZGUgb2YgZ3JhcGgubm9kZXMpIHtcbiAgICAgICAgYXdhaXQgc3luY1BhY2thZ2VUc2NvbmZpZ3MoZ3JhcGgsIG5vZGUpO1xuICAgICAgICByb290VHNjb25maWcucmVmZXJlbmNlcy5wdXNoKHsgcGF0aDogd29ya3NwYWNlLnJlbGF0aXZlKG5vZGUucGtnLnBhdGgpLnJlcGxhY2UoL1xcXFwvZywgXCIvXCIpIH0pO1xuICAgIH1cblxuICAgIGlmIChyZWZlcmVuY2VzQ2hhbmdlZChvcmlnaW5hbFJlZmVyZW5jZXMsIHJvb3RUc2NvbmZpZy5yZWZlcmVuY2VzKSkge1xuICAgICAgICBhd2FpdCB3b3Jrc3BhY2Uud3JpdGVKc29uKFwidHNjb25maWcuanNvblwiLCByb290VHNjb25maWcpO1xuICAgIH1cbn1cblxuZnVuY3Rpb24gcmVmZXJlbmNlc0NoYW5nZWQob3JpZ2luYWxSZWZlcmVuY2VzOiB1bmtub3duLCBuZXdSZWZlcmVuY2VzOiB1bmtub3duKSB7XG4gICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KG9yaWdpbmFsUmVmZXJlbmNlcykgIT09IEpTT04uc3RyaW5naWZ5KG5ld1JlZmVyZW5jZXMpO1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc3luY1BhY2thZ2VUc2NvbmZpZ3MoZ3JhcGg6IEdyYXBoLCBub2RlOiBHcmFwaC5Ob2RlKSB7XG4gICAgYXdhaXQgc3luY1N1YnByb2plY3Qobm9kZSwgXCJzcmNcIik7XG4gICAgYXdhaXQgc3luY1N1YnByb2plY3Qobm9kZSwgXCJ0ZXN0XCIsIG5vZGUucGtnLnJlc29sdmUoXCJzcmNcIiksIGdyYXBoLmdldChcIkBtYXR0ZXIvdG9vbHNcIikucGtnLnJlc29sdmUoXCJzcmNcIikpO1xufVxuXG5hc3luYyBmdW5jdGlvbiBzeW5jU3VicHJvamVjdChub2RlOiBHcmFwaC5Ob2RlLCBwYXRoOiBzdHJpbmcsIC4uLmV4dHJhUmVmczogc3RyaW5nW10pIHtcbiAgICBwYXRoID0gbm9kZS5wa2cucmVzb2x2ZShwYXRoKTtcblxuICAgIGNvbnN0IHRzY29uZmlnUGF0aCA9IHJlc29sdmUocGF0aCwgXCJ0c2NvbmZpZy5qc29uXCIpO1xuICAgIGlmICghbm9kZS5wa2cuaGFzRmlsZSh0c2NvbmZpZ1BhdGgpKSB7XG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB0c2NvbmZpZyA9IGF3YWl0IG5vZGUucGtnLnJlYWRKc29uKHRzY29uZmlnUGF0aCk7XG5cbiAgICBsZXQgcmVmcyA9IHRzY29uZmlnLnJlZnMgYXMgdW5kZWZpbmVkIHwgeyBwYXRoOiBzdHJpbmcgfVtdO1xuXG4gICAgaWYgKHJlZnMgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZWZzID0gW107XG4gICAgfVxuXG4gICAgY29uc3QgZGVwcyA9IG5vZGUuZGVwZW5kZW5jaWVzXG4gICAgICAgIC5maWx0ZXIoZGVwID0+IGRlcC5wa2cuaXNMaWJyYXJ5KVxuICAgICAgICAubWFwKGRlcCA9PiBkZXAucGtnLnJlc29sdmUoXCJzcmNcIikpXG4gICAgICAgIC5maWx0ZXIocCA9PiAhcC5tYXRjaCgvcGFja2FnZXNbXFxcXC9ddG9vbHMvKSk7XG5cbiAgICBjb25zdCBkZXNpcmVkID0gWy4uLm5ldyBTZXQoWy4uLmRlcHMsIC4uLmV4dHJhUmVmc10pXTtcblxuICAgIGNvbnN0IG5ld1JlZmVyZW5jZXMgPSBkZXNpcmVkXG4gICAgICAgIC5tYXAocmVmID0+ICh7IHBhdGg6IHJlbGF0aXZlKHBhdGgsIHJlZikucmVwbGFjZSgvXFxcXC9nLCBcIi9cIikgfSkpXG4gICAgICAgIC5zb3J0KChyZWYxLCByZWYyKSA9PiByZWYxLnBhdGgubG9jYWxlQ29tcGFyZShyZWYyLnBhdGgpKTtcblxuICAgIGlmIChyZWZlcmVuY2VzQ2hhbmdlZCh0c2NvbmZpZy5yZWZlcmVuY2VzLCBuZXdSZWZlcmVuY2VzKSkge1xuICAgICAgICB0c2NvbmZpZy5yZWZlcmVuY2VzID0gbmV3UmVmZXJlbmNlcztcbiAgICAgICAgYXdhaXQgbm9kZS5wa2cud3JpdGVKc29uKHRzY29uZmlnUGF0aCwgdHNjb25maWcpO1xuICAgIH1cbn1cbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFNQSxTQUFTLFVBQVUsZUFBZTtBQVVsQyxlQUFzQixpQkFBaUIsT0FBYztBQUNqRCxRQUFNLFlBQVksTUFBTSxNQUFNLENBQUMsRUFBRSxJQUFJO0FBQ3JDLFFBQU0sZUFBZSxNQUFNLFVBQVUsU0FBUyxlQUFlO0FBRTdELFFBQU0scUJBQXFCLGFBQWE7QUFDeEMsZUFBYSxhQUFhLENBQUM7QUFFM0IsYUFBVyxRQUFRLE1BQU0sT0FBTztBQUM1QixVQUFNLHFCQUFxQixPQUFPLElBQUk7QUFDdEMsaUJBQWEsV0FBVyxLQUFLLEVBQUUsTUFBTSxVQUFVLFNBQVMsS0FBSyxJQUFJLElBQUksRUFBRSxRQUFRLE9BQU8sR0FBRyxFQUFFLENBQUM7QUFBQSxFQUNoRztBQUVBLE1BQUksa0JBQWtCLG9CQUFvQixhQUFhLFVBQVUsR0FBRztBQUNoRSxVQUFNLFVBQVUsVUFBVSxpQkFBaUIsWUFBWTtBQUFBLEVBQzNEO0FBQ0o7QUFFQSxTQUFTLGtCQUFrQixvQkFBNkIsZUFBd0I7QUFDNUUsU0FBTyxLQUFLLFVBQVUsa0JBQWtCLE1BQU0sS0FBSyxVQUFVLGFBQWE7QUFDOUU7QUFFQSxlQUFzQixxQkFBcUIsT0FBYyxNQUFrQjtBQUN2RSxRQUFNLGVBQWUsTUFBTSxLQUFLO0FBQ2hDLFFBQU0sZUFBZSxNQUFNLFFBQVEsS0FBSyxJQUFJLFFBQVEsS0FBSyxHQUFHLE1BQU0sSUFBSSxlQUFlLEVBQUUsSUFBSSxRQUFRLEtBQUssQ0FBQztBQUM3RztBQUVBLGVBQWUsZUFBZSxNQUFrQixTQUFpQixXQUFxQjtBQUNsRixTQUFPLEtBQUssSUFBSSxRQUFRLElBQUk7QUFFNUIsUUFBTSxlQUFlLFFBQVEsTUFBTSxlQUFlO0FBQ2xELE1BQUksQ0FBQyxLQUFLLElBQUksUUFBUSxZQUFZLEdBQUc7QUFDakM7QUFBQSxFQUNKO0FBRUEsUUFBTSxXQUFXLE1BQU0sS0FBSyxJQUFJLFNBQVMsWUFBWTtBQUVyRCxNQUFJLE9BQU8sU0FBUztBQUVwQixNQUFJLFNBQVMsUUFBVztBQUNwQixXQUFPLENBQUM7QUFBQSxFQUNaO0FBRUEsUUFBTSxPQUFPLEtBQUssYUFDYixPQUFPLFNBQU8sSUFBSSxJQUFJLFNBQVMsRUFDL0IsSUFBSSxTQUFPLElBQUksSUFBSSxRQUFRLEtBQUssQ0FBQyxFQUNqQyxPQUFPLE9BQUssQ0FBQyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFL0MsUUFBTSxVQUFVLENBQUMsR0FBRyxvQkFBSSxJQUFJLENBQUMsR0FBRyxNQUFNLEdBQUcsU0FBUyxDQUFDLENBQUM7QUFFcEQsUUFBTSxnQkFBZ0IsUUFDakIsSUFBSSxVQUFRLEVBQUUsTUFBTSxTQUFTLE1BQU0sR0FBRyxFQUFFLFFBQVEsT0FBTyxHQUFHLEVBQUUsRUFBRSxFQUM5RCxLQUFLLENBQUMsTUFBTSxTQUFTLEtBQUssS0FBSyxjQUFjLEtBQUssSUFBSSxDQUFDO0FBRTVELE1BQUksa0JBQWtCLFNBQVMsWUFBWSxhQUFhLEdBQUc7QUFDdkQsYUFBUyxhQUFhO0FBQ3RCLFVBQU0sS0FBSyxJQUFJLFVBQVUsY0FBYyxRQUFRO0FBQUEsRUFDbkQ7QUFDSjsiLAogICJuYW1lcyI6IFtdCn0K

@@ -6,11 +6,9 @@ /**

*/
import "./testing/global-declarations.js";
export * from "./building/builder.js";
export * from "./building/graph.js";
export * from "./building/project.js";
export * from "./testing/chip.js";
export * from "./testing/mocharc.cjs";
export * from "./util/docker.js";
export * from "./util/commander.js";
export * from "./util/files.js";
export * from "./util/package.js";
export * from "./util/progress.js";
export * from "./util/wtf.js";
//# sourceMappingURL=index.d.ts.map

@@ -6,11 +6,9 @@ /**

*/
import "./testing/global-declarations.js";
export * from "./building/builder.js";
export * from "./building/graph.js";
export * from "./building/project.js";
export * from "./testing/chip.js";
export * from "./testing/mocharc.cjs";
export * from "./util/docker.js";
export * from "./util/commander.js";
export * from "./util/files.js";
export * from "./util/package.js";
export * from "./util/progress.js";
export * from "./util/wtf.js";
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCBcIi4vdGVzdGluZy9nbG9iYWwtZGVjbGFyYXRpb25zLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9idWlsZGluZy9ncmFwaC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYnVpbGRpbmcvcHJvamVjdC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGVzdGluZy9jaGlwLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90ZXN0aW5nL21vY2hhcmMuY2pzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsL2RvY2tlci5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbC9wYWNrYWdlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsL3Byb2dyZXNzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsL3d0Zi5qc1wiO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU1BLE9BQU87QUFDUCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYzsiLAogICJuYW1lcyI6IFtdCn0K
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL2J1aWxkaW5nL2J1aWxkZXIuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2J1aWxkaW5nL2dyYXBoLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9idWlsZGluZy9wcm9qZWN0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsL2NvbW1hbmRlci5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbC9maWxlcy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbC9wYWNrYWdlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsL3Byb2dyZXNzLmpzXCI7XG4iXSwKICAibWFwcGluZ3MiOiAiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBTUEsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYzsiLAogICJuYW1lcyI6IFtdCn0K

@@ -6,4 +6,6 @@ /**

*/
export * from "./commander.js";
export * from "./errors.js";
export * from "./files.js";
export * from "./package.js";
//# sourceMappingURL=index.d.ts.map

@@ -6,4 +6,6 @@ /**

*/
export * from "./commander.js";
export * from "./errors.js";
export * from "./files.js";
export * from "./package.js";
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3V0aWwvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCAyMDIyLTIwMjQgTWF0dGVyLmpzIEF1dGhvcnNcbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG4gKi9cblxuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3JzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9wYWNrYWdlLmpzXCI7XG4iXSwKICAibWFwcGluZ3MiOiAiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBTUEsY0FBYztBQUNkLGNBQWM7IiwKICAibmFtZXMiOiBbXQp9Cg==
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3V0aWwvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCAyMDIyLTIwMjQgTWF0dGVyLmpzIEF1dGhvcnNcbiAqIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG4gKi9cblxuZXhwb3J0ICogZnJvbSBcIi4vY29tbWFuZGVyLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9lcnJvcnMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2ZpbGVzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9wYWNrYWdlLmpzXCI7XG4iXSwKICAibWFwcGluZ3MiOiAiQUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBTUEsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYzsiLAogICJuYW1lcyI6IFtdCn0K

@@ -28,5 +28,5 @@ /**

get hasCodegen(): boolean;
resolve(path: string): string;
resolve(...paths: string[]): string;
relative(path: string): string;
glob(pattern: string): Promise<string[]>;
glob(pattern: string | string[]): Promise<string[]>;
start(what: string): Progress;

@@ -43,2 +43,3 @@ lastModified(...paths: string[]): Promise<number>;

resolveExport(name: string, type?: "cjs" | "esm"): string;
findPackage(name: string): Package;
resolveImport(name: string, type?: "cjs" | "esm"): string;

@@ -45,0 +46,0 @@ hasFile(path: string): boolean;

@@ -8,6 +8,5 @@ /**

import { readdir, readFile, stat, writeFile } from "fs/promises";
import { glob } from "glob";
import { dirname, join, relative, resolve } from "path";
import { maybeStatSync } from "../testing/files.js";
import { ignoreError, ignoreErrorSync } from "./errors.js";
import { globSync, maybeReadJsonSync, maybeStatSync } from "./files.js";
import { Progress } from "./progress.js";

@@ -64,2 +63,11 @@ import { toolsPath } from "./tools-path.cjs";

this.hasTests = isDirectory(this.resolve("test"));
const refs = maybeReadJsonSync(this.resolve("tsconfig.json"))?.references;
if (refs !== void 0) {
if (!refs.find((ref) => this.resolve(ref.path) === this.resolve("src"))) {
this.hasSrc = false;
}
if (!refs.find((ref) => this.resolve(ref.path) === this.resolve("test"))) {
this.hasTests = false;
}
}
this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);

@@ -77,4 +85,4 @@ this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));

}
resolve(path) {
return resolve(this.path, path);
resolve(...paths) {
return resolve(this.path, ...paths);
}

@@ -85,4 +93,8 @@ relative(path) {

async glob(pattern) {
pattern = this.resolve(pattern).replace(/\\/g, "/");
return await glob(pattern);
if (typeof pattern === "string") {
pattern = this.resolve(pattern).replace(/\\/g, "/");
} else {
pattern = pattern.map((s) => this.resolve(s).replace(/\\/g, "/"));
}
return globSync(pattern);
}

@@ -173,11 +185,6 @@ start(what) {

}
resolveImport(name, type = "esm") {
const segments = name.split("/");
let subdir = segments.shift();
if (subdir.startsWith("@") && segments.length) {
subdir = `${subdir}/${segments.shift()}`;
}
findPackage(name) {
let resolveIn = this.path;
while (true) {
if (isDirectory(resolve(resolveIn, "node_modules", subdir))) {
if (isDirectory(resolve(resolveIn, "node_modules", name))) {
break;

@@ -187,7 +194,15 @@ }

if (nextResolveIn === resolveIn) {
throw new Error(`Cannot find module ${subdir} from ${this.path}`);
throw new Error(`Cannot find module ${name} from ${this.path}`);
}
resolveIn = nextResolveIn;
}
const pkg = Package.forPath(resolve(resolveIn, "node_modules", subdir));
return Package.forPath(resolve(resolveIn, "node_modules", name));
}
resolveImport(name, type = "esm") {
const segments = name.split("/");
let packageName = segments.shift();
if (packageName.startsWith("@") && segments.length) {
packageName = `${packageName}/${segments.shift()}`;
}
const pkg = this.findPackage(packageName);
return pkg.resolveExport(segments.length ? segments.join("/") : ".", type);

@@ -222,4 +237,4 @@ }

e.message = `Error parsing "${this.resolve(path)}": ${e.message}`;
throw e;
}
return JSON.parse(await this.readFile(path));
}

@@ -311,2 +326,2 @@ async writeJson(path, value) {

};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/util/package.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { existsSync, readFileSync, statSync } from \"fs\";\nimport { readdir, readFile, stat, writeFile } from \"fs/promises\";\nimport { glob } from \"glob\";\nimport { dirname, join, relative, resolve } from \"path\";\nimport { maybeStatSync } from \"../testing/files.js\";\nimport { ignoreError, ignoreErrorSync } from \"./errors.js\";\nimport { Progress } from \"./progress.js\";\nimport { toolsPath } from \"./tools-path.cjs\";\n\nexport class JsonNotFoundError extends Error {}\n\nexport const CONFIG_PATH = `src/build.config.ts`;\nexport const CODEGEN_PATH = `codegen`;\n\nconst packageForPath = {} as Record<string, Package | undefined | null>;\n\nfunction findJson(filename: string, path: string = \".\", title?: string) {\n    path = resolve(path);\n    while (true) {\n        const json = ignoreErrorSync([\"ENOENT\", \"ENOTDIR\"], () =>\n            JSON.parse(readFileSync(resolve(path, filename)).toString()),\n        );\n        if (json) {\n            if (title === undefined || json.name === title) {\n                return { root: path, json };\n            }\n        }\n        const parent = dirname(path);\n        if (parent === path) {\n            throw new JsonNotFoundError(`Could not locate ${title ?? filename}`);\n        }\n        path = parent;\n    }\n}\n\nfunction isDirectory(path: string) {\n    return !!ignoreErrorSync(\"ENOENT\", () => statSync(path).isDirectory());\n}\n\nexport class Package {\n    path: string;\n    json: PackageJson;\n    supportsEsm: boolean;\n    supportsCjs: boolean;\n    hasSrc: boolean;\n    hasTests: boolean;\n    hasConfig: boolean;\n    isLibrary: boolean;\n    #aliases?: Record<string, string>;\n\n    constructor({\n        path = \".\",\n        name,\n    }: {\n        path?: string;\n        name?: string;\n    } = {}) {\n        const { root, json } = findJson(\"package.json\", path, name);\n        this.path = root;\n        this.json = json;\n\n        const { esm, cjs } = selectFormats(this.json);\n        this.supportsEsm = esm;\n        this.supportsCjs = cjs;\n\n        this.hasSrc = isDirectory(this.resolve(\"src\"));\n        this.hasTests = isDirectory(this.resolve(\"test\"));\n\n        this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);\n\n        this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));\n    }\n\n    get name() {\n        return this.json.name;\n    }\n\n    get exports() {\n        return this.json.exports;\n    }\n\n    get hasCodegen() {\n        return this.hasDirectory(CODEGEN_PATH);\n    }\n\n    resolve(path: string) {\n        return resolve(this.path, path);\n    }\n\n    relative(path: string) {\n        return relative(this.path, path);\n    }\n\n    async glob(pattern: string) {\n        // Glob only understands forward-slash as separator because reasons\n        pattern = this.resolve(pattern).replace(/\\\\/g, \"/\");\n\n        return await glob(pattern);\n    }\n\n    start(what: string) {\n        const progress = new Progress();\n        progress.startup(what, this);\n        return progress;\n    }\n\n    async lastModified(...paths: string[]) {\n        return this.lastModifiedAbsolute(paths.map(p => this.resolve(p)));\n    }\n\n    private async lastModifiedAbsolute(paths: string[]) {\n        let mtime = 0;\n        await Promise.all(\n            paths.map(async p => {\n                const stats = await ignoreError(\"ENOENT\", async () => await stat(p));\n                if (!stats) {\n                    return;\n                }\n\n                let thisMtime;\n                if (stats.isDirectory()) {\n                    const paths = (await readdir(p)).map(p2 => resolve(p, p2));\n                    thisMtime = await this.lastModifiedAbsolute(paths);\n                } else {\n                    thisMtime = stats.mtimeMs;\n                }\n                if (thisMtime > mtime) {\n                    mtime = thisMtime;\n                }\n            }),\n        );\n        return mtime;\n    }\n\n    get dependencies() {\n        let result = Array<string>();\n        for (const type of [\"dependencies\", \"optionalDependencies\", \"devDependencies\", \"peerDependencies\"]) {\n            if (typeof this.json[type] === \"object\" && this.json[type] !== null) {\n                result = [...result, ...Object.keys(this.json[type])];\n            }\n        }\n        return [...new Set(result)];\n    }\n\n    get workspace() {\n        return Package.workspaceFor(this.path);\n    }\n\n    static set workingDir(wd: string) {\n        workingDir = wd;\n    }\n\n    static get workspace() {\n        return this.workspaceFor(workingDir);\n    }\n\n    static workspaceFor(cwd: string) {\n        if (!workspace) {\n            workspace = find(cwd, pkg => Array.isArray(pkg.json.workspaces));\n        }\n        return workspace;\n    }\n\n    static get tools() {\n        if (!tools) {\n            tools = new Package({ path: toolsPath });\n        }\n        return tools;\n    }\n\n    static findExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        return this.workspace.resolveImport(name, type);\n    }\n\n    resolveExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        if (!name.startsWith(\".\")) {\n            name = `./${name}`;\n        }\n        const exportDetail = this.exports?.[name];\n\n        if (exportDetail) {\n            const exp = findExportCondition(exportDetail, type);\n            if (exp) {\n                return this.resolve(exp);\n            }\n        }\n\n        if (name === \".\") {\n            if (type === \"esm\" && this.json.module) {\n                return this.resolve(this.json.module);\n            }\n            if (this.json.main) {\n                return this.resolve(this.json.main);\n            }\n        }\n\n        throw new Error(`Cannot resolve export ${name} in package ${this.name}`);\n    }\n\n    resolveImport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        const segments = name.split(\"/\");\n        let subdir = segments.shift() as string;\n        if (subdir.startsWith(\"@\") && segments.length) {\n            subdir = `${subdir}/${segments.shift()}`;\n        }\n\n        let resolveIn = this.path;\n        while (true) {\n            if (isDirectory(resolve(resolveIn, \"node_modules\", subdir))) {\n                break;\n            }\n            const nextResolveIn = dirname(resolveIn);\n            if (nextResolveIn === resolveIn) {\n                throw new Error(`Cannot find module ${subdir} from ${this.path}`);\n            }\n            resolveIn = nextResolveIn;\n        }\n\n        const pkg = Package.forPath(resolve(resolveIn, \"node_modules\", subdir));\n        return pkg.resolveExport(segments.length ? segments.join(\"/\") : \".\", type);\n    }\n\n    hasFile(path: string) {\n        return !!this.#maybeStat(path)?.isFile();\n    }\n\n    hasDirectory(path: string) {\n        return !!this.#maybeStat(path)?.isDirectory();\n    }\n\n    async readFile(path: string) {\n        return readFile(this.resolve(path), \"utf-8\");\n    }\n\n    readFileSync(path: string) {\n        return readFileSync(this.resolve(path), \"utf-8\");\n    }\n\n    async writeFile(path: string, contents: unknown) {\n        await writeFile(this.resolve(path), `${contents}`);\n    }\n\n    async save() {\n        await this.writeFile(join(this.path, \"package.json\"), JSON.stringify(this.json, undefined, 4));\n    }\n\n    async readJson(path: string) {\n        const text = await this.readFile(path);\n        try {\n            return JSON.parse(text);\n        } catch (e) {\n            if (!(e instanceof Error)) {\n                e = new Error(`${e}`);\n            }\n            (e as Error).message = `Error parsing \"${this.resolve(path)}\": ${(e as Error).message}`;\n        }\n        return JSON.parse(await this.readFile(path));\n    }\n\n    async writeJson(path: string, value: {}) {\n        await this.writeFile(path, JSON.stringify(value, undefined, 4));\n    }\n\n    static maybeForPath(path: string) {\n        function find(path: string): Package | null {\n            let result = packageForPath[path];\n            if (result === undefined) {\n                if (existsSync(join(path, \"package.json\"))) {\n                    result = new Package({ path });\n                } else {\n                    result = find(dirname(path));\n                }\n                packageForPath[path] = result;\n            }\n            return result;\n        }\n\n        const result = find(path);\n\n        return result ?? undefined;\n    }\n\n    static forPath(path: string) {\n        const result = this.maybeForPath(path);\n        if (result !== undefined) {\n            return result;\n        }\n        throw new Error(`Cannot find package.json for \"${path}\"`);\n    }\n\n    get aliases(): Record<string, string> {\n        if (this.#aliases !== undefined) {\n            return this.#aliases;\n        }\n\n        this.#aliases = {\n            ...Package.maybeForPath(dirname(this.path))?.aliases,\n            ...this.json.imports,\n        };\n\n        return this.#aliases;\n    }\n\n    #maybeStat(path: string) {\n        return maybeStatSync(this.resolve(path));\n    }\n}\n\nexport type PackageJson = {\n    name: string;\n    version: string;\n    imports: Record<string, string>;\n    [key: string]: any;\n};\n\nlet workingDir = \".\";\nlet workspace: Package | undefined;\nlet tools: Package | undefined;\n\nfunction find(startDir: string, selector: (pkg: Package) => boolean): Package {\n    let pkg = new Package({ path: startDir });\n    while (!selector(pkg)) {\n        pkg = new Package({ path: dirname(pkg.path) });\n    }\n    return pkg;\n}\n\nfunction selectFormats(json: any) {\n    let esm: boolean, cjs: boolean;\n\n    if (json.type === \"module\") {\n        esm = true;\n        cjs =\n            (json.main !== undefined && json.module !== undefined) ||\n            !!Object.values(json.exports ?? {}).find((exp: any) => exp.require);\n    } else {\n        cjs = true;\n        esm = !!json.module || !!Object.values(json.exports ?? {}).find((exp: any) => exp.import);\n    }\n\n    return { esm, cjs };\n}\n\nfunction findExportCondition(detail: Record<string, any>, type: \"esm\" | \"cjs\"): string | undefined {\n    if (type === \"esm\" && detail.import) {\n        let exp = detail.import;\n        if (exp && typeof exp !== \"string\") {\n            exp = findExportCondition(exp, type);\n        }\n        if (exp) {\n            return exp;\n        }\n    }\n\n    let exp = detail.require ?? detail.node ?? detail.default;\n    if (exp && typeof exp !== \"string\") {\n        exp = findExportCondition(exp, type);\n    }\n\n    if (typeof exp === \"string\") {\n        return exp;\n    }\n}\n"],
  "mappings": "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",
  "names": ["paths", "find", "path", "result", "exp"]
}

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/util/package.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { existsSync, readFileSync, statSync } from \"fs\";\nimport { readdir, readFile, stat, writeFile } from \"fs/promises\";\nimport { dirname, join, relative, resolve } from \"path\";\nimport { ignoreError, ignoreErrorSync } from \"./errors.js\";\nimport { globSync, maybeReadJsonSync, maybeStatSync } from \"./files.js\";\nimport { Progress } from \"./progress.js\";\nimport { toolsPath } from \"./tools-path.cjs\";\n\nexport class JsonNotFoundError extends Error {}\n\nexport const CONFIG_PATH = `src/build.config.ts`;\nexport const CODEGEN_PATH = `codegen`;\n\nconst packageForPath = {} as Record<string, Package | undefined | null>;\n\nfunction findJson(filename: string, path: string = \".\", title?: string) {\n    path = resolve(path);\n    while (true) {\n        const json = ignoreErrorSync([\"ENOENT\", \"ENOTDIR\"], () =>\n            JSON.parse(readFileSync(resolve(path, filename)).toString()),\n        );\n        if (json) {\n            if (title === undefined || json.name === title) {\n                return { root: path, json };\n            }\n        }\n        const parent = dirname(path);\n        if (parent === path) {\n            throw new JsonNotFoundError(`Could not locate ${title ?? filename}`);\n        }\n        path = parent;\n    }\n}\n\nfunction isDirectory(path: string) {\n    return !!ignoreErrorSync(\"ENOENT\", () => statSync(path).isDirectory());\n}\n\nexport class Package {\n    path: string;\n    json: PackageJson;\n    supportsEsm: boolean;\n    supportsCjs: boolean;\n    hasSrc: boolean;\n    hasTests: boolean;\n    hasConfig: boolean;\n    isLibrary: boolean;\n    #aliases?: Record<string, string>;\n\n    constructor({\n        path = \".\",\n        name,\n    }: {\n        path?: string;\n        name?: string;\n    } = {}) {\n        const { root, json } = findJson(\"package.json\", path, name);\n        this.path = root;\n        this.json = json;\n\n        const { esm, cjs } = selectFormats(this.json);\n        this.supportsEsm = esm;\n        this.supportsCjs = cjs;\n\n        this.hasSrc = isDirectory(this.resolve(\"src\"));\n        this.hasTests = isDirectory(this.resolve(\"test\"));\n\n        const refs = maybeReadJsonSync(this.resolve(\"tsconfig.json\"))?.references as undefined | { path: string }[];\n        if (refs !== undefined) {\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"src\"))) {\n                this.hasSrc = false;\n            }\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"test\"))) {\n                this.hasTests = false;\n            }\n        }\n\n        this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);\n\n        this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));\n    }\n\n    get name() {\n        return this.json.name;\n    }\n\n    get exports() {\n        return this.json.exports;\n    }\n\n    get hasCodegen() {\n        return this.hasDirectory(CODEGEN_PATH);\n    }\n\n    resolve(...paths: string[]) {\n        return resolve(this.path, ...paths);\n    }\n\n    relative(path: string) {\n        return relative(this.path, path);\n    }\n\n    async glob(pattern: string | string[]) {\n        // Glob only understands forward-slash as separator because reasons\n        if (typeof pattern === \"string\") {\n            pattern = this.resolve(pattern).replace(/\\\\/g, \"/\");\n        } else {\n            pattern = pattern.map(s => this.resolve(s).replace(/\\\\/g, \"/\"));\n        }\n\n        // Current glob implementation isn't actually async as this is faster and we only walk small directory trees\n        return globSync(pattern);\n    }\n\n    start(what: string) {\n        const progress = new Progress();\n        progress.startup(what, this);\n        return progress;\n    }\n\n    async lastModified(...paths: string[]) {\n        return this.lastModifiedAbsolute(paths.map(p => this.resolve(p)));\n    }\n\n    private async lastModifiedAbsolute(paths: string[]) {\n        let mtime = 0;\n        await Promise.all(\n            paths.map(async p => {\n                const stats = await ignoreError(\"ENOENT\", async () => await stat(p));\n                if (!stats) {\n                    return;\n                }\n\n                let thisMtime;\n                if (stats.isDirectory()) {\n                    const paths = (await readdir(p)).map(p2 => resolve(p, p2));\n                    thisMtime = await this.lastModifiedAbsolute(paths);\n                } else {\n                    thisMtime = stats.mtimeMs;\n                }\n                if (thisMtime > mtime) {\n                    mtime = thisMtime;\n                }\n            }),\n        );\n        return mtime;\n    }\n\n    get dependencies() {\n        let result = Array<string>();\n        for (const type of [\"dependencies\", \"optionalDependencies\", \"devDependencies\", \"peerDependencies\"]) {\n            if (typeof this.json[type] === \"object\" && this.json[type] !== null) {\n                result = [...result, ...Object.keys(this.json[type])];\n            }\n        }\n        return [...new Set(result)];\n    }\n\n    get workspace() {\n        return Package.workspaceFor(this.path);\n    }\n\n    static set workingDir(wd: string) {\n        workingDir = wd;\n    }\n\n    static get workspace() {\n        return this.workspaceFor(workingDir);\n    }\n\n    static workspaceFor(cwd: string) {\n        if (!workspace) {\n            workspace = find(cwd, pkg => Array.isArray(pkg.json.workspaces));\n        }\n        return workspace;\n    }\n\n    static get tools() {\n        if (!tools) {\n            tools = new Package({ path: toolsPath });\n        }\n        return tools;\n    }\n\n    static findExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        return this.workspace.resolveImport(name, type);\n    }\n\n    resolveExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        if (!name.startsWith(\".\")) {\n            name = `./${name}`;\n        }\n        const exportDetail = this.exports?.[name];\n\n        if (exportDetail) {\n            const exp = findExportCondition(exportDetail, type);\n            if (exp) {\n                return this.resolve(exp);\n            }\n        }\n\n        if (name === \".\") {\n            if (type === \"esm\" && this.json.module) {\n                return this.resolve(this.json.module);\n            }\n            if (this.json.main) {\n                return this.resolve(this.json.main);\n            }\n        }\n\n        throw new Error(`Cannot resolve export ${name} in package ${this.name}`);\n    }\n\n    findPackage(name: string) {\n        let resolveIn = this.path;\n        while (true) {\n            if (isDirectory(resolve(resolveIn, \"node_modules\", name))) {\n                break;\n            }\n            const nextResolveIn = dirname(resolveIn);\n            if (nextResolveIn === resolveIn) {\n                throw new Error(`Cannot find module ${name} from ${this.path}`);\n            }\n            resolveIn = nextResolveIn;\n        }\n\n        return Package.forPath(resolve(resolveIn, \"node_modules\", name));\n    }\n\n    resolveImport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        const segments = name.split(\"/\");\n        let packageName = segments.shift() as string;\n        if (packageName.startsWith(\"@\") && segments.length) {\n            packageName = `${packageName}/${segments.shift()}`;\n        }\n\n        const pkg = this.findPackage(packageName);\n\n        return pkg.resolveExport(segments.length ? segments.join(\"/\") : \".\", type);\n    }\n\n    hasFile(path: string) {\n        return !!this.#maybeStat(path)?.isFile();\n    }\n\n    hasDirectory(path: string) {\n        return !!this.#maybeStat(path)?.isDirectory();\n    }\n\n    async readFile(path: string) {\n        return readFile(this.resolve(path), \"utf-8\");\n    }\n\n    readFileSync(path: string) {\n        return readFileSync(this.resolve(path), \"utf-8\");\n    }\n\n    async writeFile(path: string, contents: unknown) {\n        await writeFile(this.resolve(path), `${contents}`);\n    }\n\n    async save() {\n        await this.writeFile(join(this.path, \"package.json\"), JSON.stringify(this.json, undefined, 4));\n    }\n\n    async readJson(path: string) {\n        const text = await this.readFile(path);\n        try {\n            return JSON.parse(text);\n        } catch (e) {\n            if (!(e instanceof Error)) {\n                e = new Error(`${e}`);\n            }\n            (e as Error).message = `Error parsing \"${this.resolve(path)}\": ${(e as Error).message}`;\n            throw e;\n        }\n    }\n\n    async writeJson(path: string, value: {}) {\n        await this.writeFile(path, JSON.stringify(value, undefined, 4));\n    }\n\n    static maybeForPath(path: string) {\n        function find(path: string): Package | null {\n            let result = packageForPath[path];\n            if (result === undefined) {\n                if (existsSync(join(path, \"package.json\"))) {\n                    result = new Package({ path });\n                } else {\n                    result = find(dirname(path));\n                }\n                packageForPath[path] = result;\n            }\n            return result;\n        }\n\n        const result = find(path);\n\n        return result ?? undefined;\n    }\n\n    static forPath(path: string) {\n        const result = this.maybeForPath(path);\n        if (result !== undefined) {\n            return result;\n        }\n        throw new Error(`Cannot find package.json for \"${path}\"`);\n    }\n\n    get aliases(): Record<string, string> {\n        if (this.#aliases !== undefined) {\n            return this.#aliases;\n        }\n\n        this.#aliases = {\n            ...Package.maybeForPath(dirname(this.path))?.aliases,\n            ...this.json.imports,\n        };\n\n        return this.#aliases;\n    }\n\n    #maybeStat(path: string) {\n        return maybeStatSync(this.resolve(path));\n    }\n}\n\nexport type PackageJson = {\n    name: string;\n    version: string;\n    imports: Record<string, string>;\n    [key: string]: any;\n};\n\nlet workingDir = \".\";\nlet workspace: Package | undefined;\nlet tools: Package | undefined;\n\nfunction find(startDir: string, selector: (pkg: Package) => boolean): Package {\n    let pkg = new Package({ path: startDir });\n    while (!selector(pkg)) {\n        pkg = new Package({ path: dirname(pkg.path) });\n    }\n    return pkg;\n}\n\nfunction selectFormats(json: any) {\n    let esm: boolean, cjs: boolean;\n\n    if (json.type === \"module\") {\n        esm = true;\n        cjs =\n            (json.main !== undefined && json.module !== undefined) ||\n            !!Object.values(json.exports ?? {}).find((exp: any) => exp.require);\n    } else {\n        cjs = true;\n        esm = !!json.module || !!Object.values(json.exports ?? {}).find((exp: any) => exp.import);\n    }\n\n    return { esm, cjs };\n}\n\nfunction findExportCondition(detail: Record<string, any>, type: \"esm\" | \"cjs\"): string | undefined {\n    if (type === \"esm\" && detail.import) {\n        let exp = detail.import;\n        if (exp && typeof exp !== \"string\") {\n            exp = findExportCondition(exp, type);\n        }\n        if (exp) {\n            return exp;\n        }\n    }\n\n    let exp = detail.require ?? detail.node ?? detail.default;\n    if (exp && typeof exp !== \"string\") {\n        exp = findExportCondition(exp, type);\n    }\n\n    if (typeof exp === \"string\") {\n        return exp;\n    }\n}\n"],
  "mappings": "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",
  "names": ["paths", "find", "path", "result", "exp"]
}


@@ -6,4 +6,3 @@ /**

*/
import yargs from "yargs";
import { hideBin } from "yargs/helpers";
import { commander } from "../util/commander.js";
import { Package } from "../util/package.js";

@@ -13,4 +12,6 @@ import { Progress } from "../util/progress.js";

async function main(argv = process.argv) {
const args = await yargs(hideBin(argv)).command("$0 [ver]", "Manipulate monorepo package versions.").option("prefix", { alias: "p", default: ".", type: "string", describe: "specify monorepo directory" }).option("set", { alias: "s", type: "boolean", describe: "Sets the release version" }).option("apply", { alias: "a", type: "boolean", describe: "Sets package versions to the release version" }).option("tag", { alias: "t", type: "boolean", describe: "Adds git tag for release version" }).wrap(Math.min(process.stdout.columns, 80)).strict().argv;
const version = args.ver;
const program = commander("matter-version", "Manipulate monorepo package versions.").argument("[version]").option("-p, --prefix <prefix>", "specify monorepo directory").option("-s, --set", "sets the release version").option("-a, --apply", "sets package versions to the release version").option("-t, --tag", "adds git tag for release version").parse(argv);
const args = program.opts();
args.version = program.args[0];
const version = args.version;
const pkg = new Package({ path: args.prefix });

@@ -34,2 +35,2 @@ const versioner = new Versioner(pkg, version);

};
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3ZlcnNpb25pbmcvY2xpLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCB5YXJncyBmcm9tIFwieWFyZ3NcIjtcbmltcG9ydCB7IGhpZGVCaW4gfSBmcm9tIFwieWFyZ3MvaGVscGVyc1wiO1xuaW1wb3J0IHsgUGFja2FnZSB9IGZyb20gXCIuLi91dGlsL3BhY2thZ2UuanNcIjtcbmltcG9ydCB7IFByb2dyZXNzIH0gZnJvbSBcIi4uL3V0aWwvcHJvZ3Jlc3MuanNcIjtcbmltcG9ydCB7IFZlcnNpb25lciB9IGZyb20gXCIuL3ZlcnNpb25lci5qc1wiO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gbWFpbihhcmd2ID0gcHJvY2Vzcy5hcmd2KSB7XG4gICAgY29uc3QgYXJncyA9IGF3YWl0IHlhcmdzKGhpZGVCaW4oYXJndikpXG4gICAgICAgIC5jb21tYW5kKFwiJDAgW3Zlcl1cIiwgXCJNYW5pcHVsYXRlIG1vbm9yZXBvIHBhY2thZ2UgdmVyc2lvbnMuXCIpXG4gICAgICAgIC5vcHRpb24oXCJwcmVmaXhcIiwgeyBhbGlhczogXCJwXCIsIGRlZmF1bHQ6IFwiLlwiLCB0eXBlOiBcInN0cmluZ1wiLCBkZXNjcmliZTogXCJzcGVjaWZ5IG1vbm9yZXBvIGRpcmVjdG9yeVwiIH0pXG4gICAgICAgIC5vcHRpb24oXCJzZXRcIiwgeyBhbGlhczogXCJzXCIsIHR5cGU6IFwiYm9vbGVhblwiLCBkZXNjcmliZTogXCJTZXRzIHRoZSByZWxlYXNlIHZlcnNpb25cIiB9KVxuICAgICAgICAub3B0aW9uKFwiYXBwbHlcIiwgeyBhbGlhczogXCJhXCIsIHR5cGU6IFwiYm9vbGVhblwiLCBkZXNjcmliZTogXCJTZXRzIHBhY2thZ2UgdmVyc2lvbnMgdG8gdGhlIHJlbGVhc2UgdmVyc2lvblwiIH0pXG4gICAgICAgIC5vcHRpb24oXCJ0YWdcIiwgeyBhbGlhczogXCJ0XCIsIHR5cGU6IFwiYm9vbGVhblwiLCBkZXNjcmliZTogXCJBZGRzIGdpdCB0YWcgZm9yIHJlbGVhc2UgdmVyc2lvblwiIH0pXG4gICAgICAgIC53cmFwKE1hdGgubWluKHByb2Nlc3Muc3Rkb3V0LmNvbHVtbnMsIDgwKSlcbiAgICAgICAgLnN0cmljdCgpLmFyZ3Y7XG5cbiAgICBjb25zdCB2ZXJzaW9uID0gYXJncy52ZXIgYXMgc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIGNvbnN0IHBrZyA9IG5ldyBQYWNrYWdlKHsgcGF0aDogYXJncy5wcmVmaXggfSk7XG4gICAgY29uc3QgdmVyc2lvbmVyID0gbmV3IFZlcnNpb25lcihwa2csIHZlcnNpb24pO1xuXG4gICAgY29uc3QgcHJvZ3Jlc3MgPSBuZXcgUHJvZ3Jlc3MoKTtcblxuICAgIHByb2dyZXNzLnN0YXJ0dXAoYFJlbGVhc2UgJHt2ZXJzaW9uZXIudmVyc2lvbn1gLCB2ZXJzaW9uZXIucGtnKTtcbiAgICBpZiAoYXJncy5zZXQpIHtcbiAgICAgICAgYXdhaXQgcHJvZ3Jlc3MucnVuKGBTZXQgdmVyc2lvbiB0byAke3Byb2dyZXNzLmVtcGhhc2l6ZSh2ZXJzaW9uZXIudmVyc2lvbil9YCwgKCkgPT4gdmVyc2lvbmVyLnNldCgpKTtcbiAgICB9XG5cbiAgICBpZiAoYXJncy5hcHBseSkge1xuICAgICAgICBhd2FpdCB2ZXJzaW9uZXIuYXBwbHkocHJvZ3Jlc3MpO1xuICAgIH1cblxuICAgIGlmIChhcmdzLnRhZykge1xuICAgICAgICBhd2FpdCBwcm9ncmVzcy5ydW4oYFRhZ2dpbmcgdmVyc2lvbiAke3Byb2dyZXNzLmVtcGhhc2l6ZSh2ZXJzaW9uZXIudmVyc2lvbil9YCwgKCkgPT4gdmVyc2lvbmVyLnRhZygpKTtcbiAgICB9XG5cbiAgICBwcm9ncmVzcy5zaHV0ZG93bigpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIkFBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQU1BLE9BQU8sV0FBVztBQUNsQixTQUFTLGVBQWU7QUFDeEIsU0FBUyxlQUFlO0FBQ3hCLFNBQVMsZ0JBQWdCO0FBQ3pCLFNBQVMsaUJBQWlCO0FBRTFCLGVBQXNCLEtBQUssT0FBTyxRQUFRLE1BQU07QUFDNUMsUUFBTSxPQUFPLE1BQU0sTUFBTSxRQUFRLElBQUksQ0FBQyxFQUNqQyxRQUFRLFlBQVksdUNBQXVDLEVBQzNELE9BQU8sVUFBVSxFQUFFLE9BQU8sS0FBSyxTQUFTLEtBQUssTUFBTSxVQUFVLFVBQVUsNkJBQTZCLENBQUMsRUFDckcsT0FBTyxPQUFPLEVBQUUsT0FBTyxLQUFLLE1BQU0sV0FBVyxVQUFVLDJCQUEyQixDQUFDLEVBQ25GLE9BQU8sU0FBUyxFQUFFLE9BQU8sS0FBSyxNQUFNLFdBQVcsVUFBVSwrQ0FBK0MsQ0FBQyxFQUN6RyxPQUFPLE9BQU8sRUFBRSxPQUFPLEtBQUssTUFBTSxXQUFXLFVBQVUsbUNBQW1DLENBQUMsRUFDM0YsS0FBSyxLQUFLLElBQUksUUFBUSxPQUFPLFNBQVMsRUFBRSxDQUFDLEVBQ3pDLE9BQU8sRUFBRTtBQUVkLFFBQU0sVUFBVSxLQUFLO0FBQ3JCLFFBQU0sTUFBTSxJQUFJLFFBQVEsRUFBRSxNQUFNLEtBQUssT0FBTyxDQUFDO0FBQzdDLFFBQU0sWUFBWSxJQUFJLFVBQVUsS0FBSyxPQUFPO0FBRTVDLFFBQU0sV0FBVyxJQUFJLFNBQVM7QUFFOUIsV0FBUyxRQUFRLFdBQVcsVUFBVSxPQUFPLElBQUksVUFBVSxHQUFHO0FBQzlELE1BQUksS0FBSyxLQUFLO0FBQ1YsVUFBTSxTQUFTLElBQUksa0JBQWtCLFNBQVMsVUFBVSxVQUFVLE9BQU8sQ0FBQyxJQUFJLE1BQU0sVUFBVSxJQUFJLENBQUM7QUFBQSxFQUN2RztBQUVBLE1BQUksS0FBSyxPQUFPO0FBQ1osVUFBTSxVQUFVLE1BQU0sUUFBUTtBQUFBLEVBQ2xDO0FBRUEsTUFBSSxLQUFLLEtBQUs7QUFDVixVQUFNLFNBQVMsSUFBSSxtQkFBbUIsU0FBUyxVQUFVLFVBQVUsT0FBTyxDQUFDLElBQUksTUFBTSxVQUFVLElBQUksQ0FBQztBQUFBLEVBQ3hHO0FBRUEsV0FBUyxTQUFTO0FBQ3RCOyIsCiAgIm5hbWVzIjogW10KfQo=
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL3ZlcnNpb25pbmcvY2xpLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMi0yMDI0IE1hdHRlci5qcyBBdXRob3JzXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuICovXG5cbmltcG9ydCB7IGNvbW1hbmRlciB9IGZyb20gXCIuLi91dGlsL2NvbW1hbmRlci5qc1wiO1xuaW1wb3J0IHsgUGFja2FnZSB9IGZyb20gXCIuLi91dGlsL3BhY2thZ2UuanNcIjtcbmltcG9ydCB7IFByb2dyZXNzIH0gZnJvbSBcIi4uL3V0aWwvcHJvZ3Jlc3MuanNcIjtcbmltcG9ydCB7IFZlcnNpb25lciB9IGZyb20gXCIuL3ZlcnNpb25lci5qc1wiO1xuXG5pbnRlcmZhY2UgQXJncyB7XG4gICAgdmVyc2lvbj86IHN0cmluZztcbiAgICBwcmVmaXg/OiBzdHJpbmc7XG4gICAgc2V0PzogYm9vbGVhbjtcbiAgICBhcHBseT86IGJvb2xlYW47XG4gICAgdGFnPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIG1haW4oYXJndiA9IHByb2Nlc3MuYXJndikge1xuICAgIGNvbnN0IHByb2dyYW0gPSBjb21tYW5kZXIoXCJtYXR0ZXItdmVyc2lvblwiLCBcIk1hbmlwdWxhdGUgbW9ub3JlcG8gcGFja2FnZSB2ZXJzaW9ucy5cIilcbiAgICAgICAgLmFyZ3VtZW50KFwiW3ZlcnNpb25dXCIpXG4gICAgICAgIC5vcHRpb24oXCItcCwgLS1wcmVmaXggPHByZWZpeD5cIiwgXCJzcGVjaWZ5IG1vbm9yZXBvIGRpcmVjdG9yeVwiKVxuICAgICAgICAub3B0aW9uKFwiLXMsIC0tc2V0XCIsIFwic2V0cyB0aGUgcmVsZWFzZSB2ZXJzaW9uXCIpXG4gICAgICAgIC5vcHRpb24oXCItYSwgLS1hcHBseVwiLCBcInNldHMgcGFja2FnZSB2ZXJzaW9ucyB0byB0aGUgcmVsZWFzZSB2ZXJzaW9uXCIpXG4gICAgICAgIC5vcHRpb24oXCItdCwgLS10YWdcIiwgXCJhZGRzIGdpdCB0YWcgZm9yIHJlbGVhc2UgdmVyc2lvblwiKVxuICAgICAgICAucGFyc2UoYXJndik7XG5cbiAgICBjb25zdCBhcmdzID0gcHJvZ3JhbS5vcHRzPEFyZ3M+KCk7XG4gICAgYXJncy52ZXJzaW9uID0gcHJvZ3JhbS5hcmdzWzBdO1xuXG4gICAgY29uc3QgdmVyc2lvbiA9IGFyZ3MudmVyc2lvbjtcbiAgICBjb25zdCBwa2cgPSBuZXcgUGFja2FnZSh7IHBhdGg6IGFyZ3MucHJlZml4IH0pO1xuICAgIGNvbnN0IHZlcnNpb25lciA9IG5ldyBWZXJzaW9uZXIocGtnLCB2ZXJzaW9uKTtcblxuICAgIGNvbnN0IHByb2dyZXNzID0gbmV3IFByb2dyZXNzKCk7XG5cbiAgICBwcm9ncmVzcy5zdGFydHVwKGBSZWxlYXNlICR7dmVyc2lvbmVyLnZlcnNpb259YCwgdmVyc2lvbmVyLnBrZyk7XG4gICAgaWYgKGFyZ3Muc2V0KSB7XG4gICAgICAgIGF3YWl0IHByb2dyZXNzLnJ1bihgU2V0IHZlcnNpb24gdG8gJHtwcm9ncmVzcy5lbXBoYXNpemUodmVyc2lvbmVyLnZlcnNpb24pfWAsICgpID0+IHZlcnNpb25lci5zZXQoKSk7XG4gICAgfVxuXG4gICAgaWYgKGFyZ3MuYXBwbHkpIHtcbiAgICAgICAgYXdhaXQgdmVyc2lvbmVyLmFwcGx5KHByb2dyZXNzKTtcbiAgICB9XG5cbiAgICBpZiAoYXJncy50YWcpIHtcbiAgICAgICAgYXdhaXQgcHJvZ3Jlc3MucnVuKGBUYWdnaW5nIHZlcnNpb24gJHtwcm9ncmVzcy5lbXBoYXNpemUodmVyc2lvbmVyLnZlcnNpb24pfWAsICgpID0+IHZlcnNpb25lci50YWcoKSk7XG4gICAgfVxuXG4gICAgcHJvZ3Jlc3Muc2h1dGRvd24oKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICJBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFNQSxTQUFTLGlCQUFpQjtBQUMxQixTQUFTLGVBQWU7QUFDeEIsU0FBUyxnQkFBZ0I7QUFDekIsU0FBUyxpQkFBaUI7QUFVMUIsZUFBc0IsS0FBSyxPQUFPLFFBQVEsTUFBTTtBQUM1QyxRQUFNLFVBQVUsVUFBVSxrQkFBa0IsdUNBQXVDLEVBQzlFLFNBQVMsV0FBVyxFQUNwQixPQUFPLHlCQUF5Qiw0QkFBNEIsRUFDNUQsT0FBTyxhQUFhLDBCQUEwQixFQUM5QyxPQUFPLGVBQWUsOENBQThDLEVBQ3BFLE9BQU8sYUFBYSxrQ0FBa0MsRUFDdEQsTUFBTSxJQUFJO0FBRWYsUUFBTSxPQUFPLFFBQVEsS0FBVztBQUNoQyxPQUFLLFVBQVUsUUFBUSxLQUFLLENBQUM7QUFFN0IsUUFBTSxVQUFVLEtBQUs7QUFDckIsUUFBTSxNQUFNLElBQUksUUFBUSxFQUFFLE1BQU0sS0FBSyxPQUFPLENBQUM7QUFDN0MsUUFBTSxZQUFZLElBQUksVUFBVSxLQUFLLE9BQU87QUFFNUMsUUFBTSxXQUFXLElBQUksU0FBUztBQUU5QixXQUFTLFFBQVEsV0FBVyxVQUFVLE9BQU8sSUFBSSxVQUFVLEdBQUc7QUFDOUQsTUFBSSxLQUFLLEtBQUs7QUFDVixVQUFNLFNBQVMsSUFBSSxrQkFBa0IsU0FBUyxVQUFVLFVBQVUsT0FBTyxDQUFDLElBQUksTUFBTSxVQUFVLElBQUksQ0FBQztBQUFBLEVBQ3ZHO0FBRUEsTUFBSSxLQUFLLE9BQU87QUFDWixVQUFNLFVBQVUsTUFBTSxRQUFRO0FBQUEsRUFDbEM7QUFFQSxNQUFJLEtBQUssS0FBSztBQUNWLFVBQU0sU0FBUyxJQUFJLG1CQUFtQixTQUFTLFVBQVUsVUFBVSxPQUFPLENBQUMsSUFBSSxNQUFNLFVBQVUsSUFBSSxDQUFDO0FBQUEsRUFDeEc7QUFFQSxXQUFTLFNBQVM7QUFDdEI7IiwKICAibmFtZXMiOiBbXQp9Cg==
{
"name": "@matter/tools",
"version": "0.11.0-alpha.0-20241027-e40e1664f",
"version": "0.11.0-alpha.0-20241028-39fc76758",
"description": "Matter.js tooling",

@@ -10,3 +10,2 @@ "type": "module",

"build-clean": "node bin/build.js --clean",
"test": "node bin/test.js",
"version": "node bin/version.js"

@@ -16,3 +15,2 @@ },

"matter-build": "bin/build.js",
"matter-test": "bin/test.js",
"matter-run": "bin/run.js",

@@ -50,32 +48,15 @@ "matter-version": "bin/version.js"

"dependencies": {
"@npmcli/map-workspaces": "^4.0.1",
"@types/express": "^4.17.21",
"ansi-colors": "^4.1.3",
"chai": "^4.4.1",
"chai-as-promised": "^7.1.2",
"dockerode": "^4.0.2",
"commander": "^12.1.0",
"esbuild": "^0.24.0",
"express": "^4.19.2",
"glob": "^10.4.5",
"mocha": "^10.7.3",
"playwright": "^1.48.1",
"trace-unhandled": "^2.0.1",
"typescript": "~5.6.2",
"wtfnode": "^0.9.3",
"yargs": "^17.7.2"
"minimatch": "^9.0.5",
"typescript": "~5.6.2"
},
"optionalDependencies": {
"@esbuild/linux-x64": "^0.24.0",
"v8-profiler-next": "^1.10.0"
"@esbuild/linux-x64": "^0.24.0"
},
"devDependencies": {
"@types/chai": "^4.3.16",
"@types/chai-as-promised": "^7.1.8",
"@types/debug": "^4.1.12",
"@types/dockerode": "^3.3.30",
"@types/glob": "^8.1.0",
"@types/mocha": "^10.0.7",
"@types/npmcli__map-workspaces": "^3.0.4",
"@types/wtfnode": "^0.7.3",
"@types/yargs": "^17.0.33"
"@types/commander": "^2.12.5",
"@types/minimatch": "^5.1.2",
"@types/node": "^22.8.1"
},

@@ -82,0 +63,0 @@ "publishConfig": {

# @matter/tools - Matter.js Tooling
This package supports build, test and execution infrastructure for other matter.js packages.
This package supports build and execution infrastructure for other matter.js packages.
> This package supports all Node.js LTS versions starting with 18.x
> Supports all Node.js LTS versions starting with 18.x
## Rational
Matter.js consists of a large number of generated TypeScript files. We support
multiple module formats targeting disparate JavaScript runtimes including Node
and web browsers. We publish a moderate (and growing) number of packages to
NPM. We support Linux, Windows and MacOS.
Matter.js consists of a large number of generated TypeScript files. We support multiple module formats targeting
disparate JavaScript runtimes including Node and web browsers. We publish a moderate (and growing) number of packages
to NPM. We support Linux, Windows and MacOS.
Previously, TSC analysis and test times had become quite slow. A proliferation
of configuration files for TSC and test framework was adding significant
redundancy to the codebase.
Previously, TSC analysis and test times had become quite slow. A proliferation of configuration files for TSC and test
framework was adding significant redundancy to the codebase.
This package standardizes and centralizes configuration for build and test. It
minimizes reliance on TSC and generally does its best to run build and test as
quickly as possible.
This package standardizes and centralizes configuration for build and test. It minimizes reliance on TSC and generally
does its best to run build and test as quickly as possible.
## Dev workflow
Although Matter.js relies on third party tools for build and test, the
interface is command-line oriented and unique to Matter.js. As such it will be
unfamiliar to new developers.
Although Matter.js relies on third party tools for build and test, the interface is command-line oriented and unique to
Matter.js. As such it will be unfamiliar to new developers.
To minimize developer burden, we also maintain traditional `tsconfig.json`
files with project references in each `src/` and `test/`. These files support
traditional IDE and `tsc --watch` workflows and are largely (but not entirely)
ignored by the tooling package.
To minimize developer burden, we also maintain traditional `tsconfig.json` files with project references in each `src/`
and `test/`. These files support traditional IDE and `tsc --watch` workflows and are largely (but not entirely) ignored
by the tooling package.
These files do add configuration overhead but we minimize this with a shared
[tsconfig.base.json](tsconfig.base.json) supplied by this package.
These files do add configuration overhead but we minimize this with a shared [tsconfig.base.json](tsconfig.base.json)
supplied by this package.
We also supply a standard `.mocharc.cjs` in packages with tests. You can use
this with your IDE's Mocha integration for standard testing workflows.
We also supply a standard `.mocharc.cjs` in packages with tests. You can use this with your IDE's Mocha integration for
standard testing workflows.
## Build
We use [TSC](https://www.typescriptlang.org/docs/handbook/compiler-options.html)
to validate TypeScript types and generate declaration files. We
use [esbuild](https://esbuild.github.io/) for transcoding TypeScript to ESM
(ES6 module format) and CJS (CommonJS module format).
We use [TSC](https://www.typescriptlang.org/docs/handbook/compiler-options.html) to validate TypeScript types and
generate declaration files. We use [esbuild](https://esbuild.github.io/) for transcoding TypeScript to ESM (ES6 module
format) and CJS (CommonJS module format).
The [matter-build](./bin/build.js) script orchestrates TSC and esbuild. It
inspects `package.json` for the target module to determine whether to emit
ESM, CJS or both.
The [matter-build](./bin/build.js) script orchestrates TSC and esbuild. It inspects `package.json` for the target
module to determine whether to emit ESM, CJS or both.
Use `matter-build --help` for command line usage. `matter-build --workspaces`
builds all workspace packages that have changed (or depend on other workspace
packages that have changed) since the last build.
Use `matter-build --help` for command line usage. `matter-build --workspaces` builds all workspace packages that have
changed (or depend on other workspace packages that have changed) since the last build.
`matter-build` itself is implemented in TypeScript. It uses `esbuild` to
bootstrap itself in fresh installs.
`matter-build` itself is implemented in TypeScript. It uses `esbuild` to bootstrap itself in fresh installs.
## Test
We run tests using [Mocha](https://mochajs.org/) with
[chai](https://www.chaijs.com/) for assertions. For multi-format modules we
run tests as both CJS and ESM. For packages that support browsers we run tests
in a headless browser using [Playwright](https://playwright.dev/).
The [matter-test](./bin/test.js) scripts orchestrates test execution. Use
`matter-test --help` for command line usage.
By default matter-test inspects `package.json` for the target module to
determine whether to test ESM, CJS or both under Node. Web tests do not run by
default but you can enable them using the `-w` option.
`matter-test` supports
environment variables of the form `MATTER_<OPTION>` for most command line
arguments. This includes `MATTER_SPEC`, `MATTER_PROFILE`, `MATTER_GREP`,
`MATTER_FGREP`, `MATTER_INVERT` and `MATTER_ALL_LOGS`.
Matter.js emits a significant volume of logging during testing. By default,
`matter-test` captures these logs internally and only emits them when
reporting on failed tests.
The test environment orchestrated by this package installs a small number of
Mocks for Matter.js infrastructure singletons.
[global-declarations.ts](src/testing/global-declarations.ts) defines a global
API for these mocks.
## Execution
The final command supplied by the tooling package is [matter-run](bin/run.js).
This command bootstraps tooling, transpiles the target module, and executes
the named JS or TS script.
We facilitate execution via [matter-run](bin/run.js). This command bootstraps tooling, transpiles the target module, and
executes the named JS or TS script.
`matter-run` understands Matter.js `package.json` conventions and
automatically transpiles typescript files in the target package prior to
execution.
`matter-run` understands Matter.js `package.json` conventions and automatically transpiles typescript files in the
target package prior to execution.
`matter-run` accepts a script to run and passes other arguments to the script
verbatim.
`matter-run` accepts a script to run and passes other arguments to the script verbatim.
If you set the environment variable `MATTER_ECHO`, `matter-run` will print the
command line prior to invoking a script.
If you set the environment variable `MATTER_ECHO`, `matter-run` will print the command line prior to invoking a script.

@@ -7,3 +7,2 @@ /**

import colors from "ansi-colors";
import { createHash } from "crypto";

@@ -153,3 +152,3 @@ import { Progress } from "../util/progress.js";

progress.failure("Terminating due to type errors");
process.stderr.write(e.diagnostics);
process.stderr.write(`${e.diagnostics}\n`);
process.exit(1);

@@ -161,10 +160,26 @@ }

const formats = Array<"esm" | "cjs">();
if (targets.has(Target.esm)) {
await this.#transpile(project, progress, Target.esm);
formats.push("esm");
}
if (targets.has(Target.cjs)) {
await this.#transpile(project, progress, Target.cjs);
formats.push("cjs");
}
if (formats.length) {
const groups = [project.pkg.isLibrary ? "library" : "app"];
if (project.pkg.hasTests) {
groups.push("tests");
}
const formatDesc = formats.map(progress.emphasize).join("+");
const groupDesc = groups.map(progress.emphasize).join("+");
await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
for (const format of formats) {
await this.#transpile(project, format);
}
});
}
await config?.after?.({ project });

@@ -181,12 +196,6 @@

async #transpile(project: Project, progress: Progress, format: "esm" | "cjs") {
const fmt = format.toUpperCase();
await progress.run(
`Transpile ${progress.emphasize(project.pkg.isLibrary ? "library" : "app")} to ${colors.bold(fmt)}`,
() => project.buildSource(format),
);
async #transpile(project: Project, format: "esm" | "cjs") {
await project.buildSource(format);
if (project.pkg.hasTests) {
await progress.run(`Transpile ${progress.emphasize("tests")} to ${colors.bold(fmt)}`, () =>
project.buildTests(format),
);
await project.buildTests(format);
}

@@ -193,0 +202,0 @@ }

@@ -7,4 +7,3 @@ /**

import yargs from "yargs";
import { hideBin } from "yargs/helpers";
import { commander } from "../util/commander.js";
import { Builder, Target } from "./builder.js";

@@ -23,2 +22,9 @@ import { Graph } from "./graph.js";

interface Args {
prefix: string;
clean?: boolean;
workspaces?: boolean;
dependencies?: boolean;
}
export async function main(argv = process.argv) {

@@ -28,18 +34,59 @@ const targets = Array<Target>();

const args = await yargs(hideBin(argv))
.usage("Builds packages adhering to matter.js standards.")
.option("prefix", { alias: "p", default: ".", type: "string", describe: "specify build directory" })
.option("clean", { alias: "c", default: false, type: "boolean", describe: "clean before build" })
.option("workspaces", { alias: "w", default: false, type: "boolean", describe: "build all workspace packages" })
.option("dependencies", { alias: "d", default: false, type: "boolean", describe: "build dependencies" })
.command("*", "build types and both JS files", () => {})
.command("clean", "remove build and dist directories", () => targets.push(Target.clean))
.command("types", "build type definitions", () => targets.push(Target.types))
.command("esm", "build JS (ES6 modules)", () => targets.push(Target.esm))
.command("cjs", "build JS (CommonJS modules)", () => targets.push(Target.cjs))
.command("graph", "display the workspace graph", () => (mode = Mode.DisplayGraph))
.command("tsconfigs", "sync all tsconfigs with package.json", () => (mode = Mode.SyncTsconfigs))
.wrap(Math.min(process.stdout.columns, 80))
.strict().argv;
const program = commander("matter-build", "Builds packages adhering to matter.js standards.")
.option("-p, --prefix <path>", "specify build directory", ".")
.option("-c, --clean", "clean before build", false)
.option("-w, --workspaces", "build all workspace packages", false)
.option("-d, --dependencies", "build dependencies", false);
program
.command("build")
.description("(default) build JS and type definitions")
.action(() => {});
program
.command("clean")
.description("remove build and dist directories")
.action(() => {
targets.push(Target.clean);
});
program
.command("types")
.description("build type definitions")
.action(() => {
targets.push(Target.types);
});
program
.command("esm")
.description("build JS (ES6 modules)")
.action(() => {
targets.push(Target.esm);
});
program
.command("cjs")
.description("build JS (CommonJS modules)")
.action(() => {
targets.push(Target.cjs);
});
program
.command("graph")
.description("display the workspace graph")
.action(() => {
mode = Mode.DisplayGraph;
});
program
.command("tsconfigs")
.description("sync all tsconfigs with package.json")
.action(() => {
mode = Mode.SyncTsconfigs;
});
program.action(() => {});
const args = program.parse(argv).opts<Args>();
if (mode === Mode.BuildProject) {

@@ -46,0 +93,0 @@ if (args.workspaces) {

@@ -7,3 +7,2 @@ /**

import mapWorkspaces from "@npmcli/map-workspaces";
import colors from "ansi-colors";

@@ -178,3 +177,3 @@ import { JsonNotFoundError, Package } from "../util/package.js";

static async #loadNodes(workspace: Package) {
const workspaces = await mapWorkspaces({ pkg: workspace.json, cwd: workspace.path });
const workspaces = workspace.json.workspaces;

@@ -184,3 +183,3 @@ const nodeMap = {} as Record<string, Graph.Node>;

for (const path of workspaces.values()) {
const pkg = new Package({ path: path });
const pkg = new Package({ path: workspace.resolve(path) });
allDeps[pkg.json.name] = pkg.dependencies;

@@ -187,0 +186,0 @@ nodeMap[pkg.json.name] = {

@@ -10,3 +10,2 @@ /**

import { cp, mkdir, readFile, rm, symlink, writeFile } from "fs/promises";
import { glob } from "glob";
import { platform } from "os";

@@ -49,3 +48,5 @@ import { dirname, join } from "path";

if (!this.pkg.hasSrc) {
throw new Error(`Found package ${this.pkg.json.name} but no src directory is present`);
throw new Error(
`Found package ${this.pkg.json.name} but src directory is not present or not referenced in tsconfig.json`,
);
}

@@ -165,3 +166,6 @@ }

for (const format of formats) {
await cp(this.pkg.resolve(source), this.pkg.resolve(join("dist", format, dest)));
await cp(this.pkg.resolve(source), this.pkg.resolve(join("dist", format, dest)), {
recursive: true,
force: true,
});
}

@@ -225,8 +229,8 @@ }

async #targetsOf(indir: string, outdir: string, ...extensions: string[]) {
indir = this.pkg.resolve(indir).replace(/\\/g, "/");
const inputPrefixLength = this.pkg.resolve(indir).length + 1;
outdir = this.pkg.resolve(outdir).replace(/\\/g, "/");
return (await glob(extensions.map(ext => `${indir}/**/*.${ext}`))).map(file => ({
return (await this.pkg.glob(extensions.map(ext => `${indir}/**/*.${ext}`))).map(file => ({
in: file,
out: `${outdir}/${file.slice(indir.length + 1)}`,
out: `${outdir}/${file.slice(inputPrefixLength)}`,
}));

@@ -233,0 +237,0 @@ }

@@ -59,3 +59,6 @@ /**

const deps = node.dependencies.map(dep => dep.pkg.resolve("src")).filter(p => !p.match(/packages[\\/]tools/));
const deps = node.dependencies
.filter(dep => dep.pkg.isLibrary)
.map(dep => dep.pkg.resolve("src"))
.filter(p => !p.match(/packages[\\/]tools/));

@@ -62,0 +65,0 @@ const desired = [...new Set([...deps, ...extraRefs])];

@@ -7,10 +7,8 @@ /**

import "./testing/global-declarations.js";
export * from "./building/builder.js";
export * from "./building/graph.js";
export * from "./building/project.js";
export * from "./testing/chip.js";
export * from "./testing/mocharc.cjs";
export * from "./util/docker.js";
export * from "./util/commander.js";
export * from "./util/files.js";
export * from "./util/package.js";
export * from "./util/progress.js";
export * from "./util/wtf.js";

@@ -10,3 +10,2 @@ {

"**/*.ts",
"testing/mocharc.cjs",
"util/tools-path.d.cts"

@@ -13,0 +12,0 @@ ],

@@ -7,3 +7,5 @@ /**

export * from "./commander.js";
export * from "./errors.js";
export * from "./files.js";
export * from "./package.js";

@@ -9,6 +9,5 @@ /**

import { readdir, readFile, stat, writeFile } from "fs/promises";
import { glob } from "glob";
import { dirname, join, relative, resolve } from "path";
import { maybeStatSync } from "../testing/files.js";
import { ignoreError, ignoreErrorSync } from "./errors.js";
import { globSync, maybeReadJsonSync, maybeStatSync } from "./files.js";
import { Progress } from "./progress.js";

@@ -76,2 +75,12 @@ import { toolsPath } from "./tools-path.cjs";

const refs = maybeReadJsonSync(this.resolve("tsconfig.json"))?.references as undefined | { path: string }[];
if (refs !== undefined) {
if (!refs.find(ref => this.resolve(ref.path) === this.resolve("src"))) {
this.hasSrc = false;
}
if (!refs.find(ref => this.resolve(ref.path) === this.resolve("test"))) {
this.hasTests = false;
}
}
this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);

@@ -94,4 +103,4 @@

resolve(path: string) {
return resolve(this.path, path);
resolve(...paths: string[]) {
return resolve(this.path, ...paths);
}

@@ -103,7 +112,12 @@

async glob(pattern: string) {
async glob(pattern: string | string[]) {
// Glob only understands forward-slash as separator because reasons
pattern = this.resolve(pattern).replace(/\\/g, "/");
if (typeof pattern === "string") {
pattern = this.resolve(pattern).replace(/\\/g, "/");
} else {
pattern = pattern.map(s => this.resolve(s).replace(/\\/g, "/"));
}
return await glob(pattern);
// Current glob implementation isn't actually async as this is faster and we only walk small directory trees
return globSync(pattern);
}

@@ -210,12 +224,6 @@

resolveImport(name: string, type: "cjs" | "esm" = "esm") {
const segments = name.split("/");
let subdir = segments.shift() as string;
if (subdir.startsWith("@") && segments.length) {
subdir = `${subdir}/${segments.shift()}`;
}
findPackage(name: string) {
let resolveIn = this.path;
while (true) {
if (isDirectory(resolve(resolveIn, "node_modules", subdir))) {
if (isDirectory(resolve(resolveIn, "node_modules", name))) {
break;

@@ -225,3 +233,3 @@ }

if (nextResolveIn === resolveIn) {
throw new Error(`Cannot find module ${subdir} from ${this.path}`);
throw new Error(`Cannot find module ${name} from ${this.path}`);
}

@@ -231,3 +239,14 @@ resolveIn = nextResolveIn;

const pkg = Package.forPath(resolve(resolveIn, "node_modules", subdir));
return Package.forPath(resolve(resolveIn, "node_modules", name));
}
resolveImport(name: string, type: "cjs" | "esm" = "esm") {
const segments = name.split("/");
let packageName = segments.shift() as string;
if (packageName.startsWith("@") && segments.length) {
packageName = `${packageName}/${segments.shift()}`;
}
const pkg = this.findPackage(packageName);
return pkg.resolveExport(segments.length ? segments.join("/") : ".", type);

@@ -269,4 +288,4 @@ }

(e as Error).message = `Error parsing "${this.resolve(path)}": ${(e as Error).message}`;
throw e;
}
return JSON.parse(await this.readFile(path));
}

@@ -273,0 +292,0 @@

@@ -7,4 +7,3 @@ /**

import yargs from "yargs";
import { hideBin } from "yargs/helpers";
import { commander } from "../util/commander.js";
import { Package } from "../util/package.js";

@@ -14,13 +13,23 @@ import { Progress } from "../util/progress.js";

interface Args {
version?: string;
prefix?: string;
set?: boolean;
apply?: boolean;
tag?: boolean;
}
export async function main(argv = process.argv) {
const args = await yargs(hideBin(argv))
.command("$0 [ver]", "Manipulate monorepo package versions.")
.option("prefix", { alias: "p", default: ".", type: "string", describe: "specify monorepo directory" })
.option("set", { alias: "s", type: "boolean", describe: "Sets the release version" })
.option("apply", { alias: "a", type: "boolean", describe: "Sets package versions to the release version" })
.option("tag", { alias: "t", type: "boolean", describe: "Adds git tag for release version" })
.wrap(Math.min(process.stdout.columns, 80))
.strict().argv;
const program = commander("matter-version", "Manipulate monorepo package versions.")
.argument("[version]")
.option("-p, --prefix <prefix>", "specify monorepo directory")
.option("-s, --set", "sets the release version")
.option("-a, --apply", "sets package versions to the release version")
.option("-t, --tag", "adds git tag for release version")
.parse(argv);
const version = args.ver as string | undefined;
const args = program.opts<Args>();
args.version = program.args[0];
const version = args.version;
const pkg = new Package({ path: args.prefix });

@@ -27,0 +36,0 @@ const versioner = new Versioner(pkg, version);

{
"compilerOptions": { "composite": true },
"files": [],
"references": [{ "path": "src" }, { "path": "test" }]
"references": [{ "path": "src" }]
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc