@matter/tools 0.13.0-alpha.0-20250304-d4a7592a4 → 0.13.0-alpha.0-20250307-ebf84a05a

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@matter/tools",
3
- "version": "0.13.0-alpha.0-20250304-d4a7592a4",
3
+ "version": "0.13.0-alpha.0-20250307-ebf84a05a",
4
4
  "description": "Matter.js tooling",
5
5
  "type": "module",
6
6
  "scripts": {
@@ -1,38 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2022-2025 Matter.js Authors
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { Graph } from "./graph.js";
7
- import { Project } from "./project.js";
8
- import { TypescriptContext } from "./typescript/context.js";
9
- export declare enum Target {
10
- clean = "clean",
11
- types = "types",
12
- esm = "esm",
13
- cjs = "cjs"
14
- }
15
- export interface Options {
16
- targets?: Target[];
17
- clean?: boolean;
18
- graph?: Graph;
19
- }
20
- /**
21
- * High-level build coordination.
22
- *
23
- * Warning: This class is intended for command line use and will process.exit if things go wrong.
24
- */
25
- export declare class Builder {
26
- #private;
27
- private options;
28
- unconditional: boolean;
29
- tsContext?: TypescriptContext;
30
- graph?: Graph;
31
- constructor(options?: Options);
32
- get hasClean(): boolean | undefined;
33
- clearClean(): void;
34
- hasTargets(): boolean | undefined;
35
- configure(project: Project): Promise<void>;
36
- build(project: Project): Promise<void>;
37
- }
38
- //# sourceMappingURL=builder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../../../src/building/builder.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAoB,OAAO,EAAE,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAE5D,oBAAY,MAAM;IACd,KAAK,UAAU;IACf,KAAK,UAAU;IACf,GAAG,QAAQ;IACX,GAAG,QAAQ;CACd;AAED,MAAM,WAAW,OAAO;IACpB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC;CACjB;AAED;;;;GAIG;AACH,qBAAa,OAAO;;IAKJ,OAAO,CAAC,OAAO;IAJ3B,aAAa,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,iBAAiB,CAAC;IAC9B,KAAK,CAAC,EAAE,KAAK,CAAC;gBAEM,OAAO,GAAE,OAAY;IAMzC,IAAI,QAAQ,wBAEX;IAED,UAAU;IAIV,UAAU;IAIG,SAAS,CAAC,OAAO,EAAE,OAAO;IAQ1B,KAAK,CAAC,OAAO,EAAE,OAAO;CAsKtC"}
@@ -1,200 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var builder_exports = {};
20
- __export(builder_exports, {
21
- Builder: () => Builder,
22
- Target: () => Target
23
- });
24
- module.exports = __toCommonJS(builder_exports);
25
- var import_node_crypto = require("node:crypto");
26
- var import_error = require("./error.js");
27
- var import_graph = require("./graph.js");
28
- var import_typescript = require("./typescript.js");
29
- /**
30
- * @license
31
- * Copyright 2022-2025 Matter.js Authors
32
- * SPDX-License-Identifier: Apache-2.0
33
- */
34
- var Target = /* @__PURE__ */ ((Target2) => {
35
- Target2["clean"] = "clean";
36
- Target2["types"] = "types";
37
- Target2["esm"] = "esm";
38
- Target2["cjs"] = "cjs";
39
- return Target2;
40
- })(Target || {});
41
- class Builder {
42
- constructor(options = {}) {
43
- this.options = options;
44
- this.graph = options.graph;
45
- this.unconditional = options.clean || options.targets !== void 0 && options.targets?.indexOf("clean" /* clean */) !== -1;
46
- }
47
- unconditional;
48
- tsContext;
49
- graph;
50
- get hasClean() {
51
- return this.options.clean;
52
- }
53
- clearClean() {
54
- delete this.options.clean;
55
- }
56
- hasTargets() {
57
- return this.options.targets && this.options.targets.length > 0;
58
- }
59
- async configure(project) {
60
- if (!project.pkg.hasConfig) {
61
- return;
62
- }
63
- await project.configure();
64
- }
65
- async build(project) {
66
- const progress = project.pkg.start("Building");
67
- try {
68
- await this.#doBuild(project, progress);
69
- } catch (e) {
70
- progress.close();
71
- process.stderr.write(`${e.stack ?? e.message}
72
-
73
- `);
74
- process.exit(1);
75
- }
76
- progress.close();
77
- }
78
- async #doBuild(project, progress) {
79
- const targets = this.#selectTargets(project);
80
- if (targets.has("clean" /* clean */) || this.options.clean) {
81
- await progress.run("Clean", () => project.clean());
82
- }
83
- if (!targets.has("types" /* types */) && !targets.has("esm" /* esm */) && !targets.has("cjs" /* cjs */)) {
84
- return;
85
- }
86
- const info = {};
87
- const config = await project.configure();
88
- await config?.before?.({ project });
89
- const graph = this.graph ?? await import_graph.Graph.forProject(project.pkg.path);
90
- let node;
91
- if (graph) {
92
- node = graph.get(project.pkg.name);
93
- for (const dep of node.dependencies) {
94
- if (dep.info.apiSha !== void 0) {
95
- if (info.dependencyApiShas === void 0) {
96
- info.dependencyApiShas = {};
97
- }
98
- info.dependencyApiShas[dep.pkg.name] = dep.info.apiSha;
99
- }
100
- }
101
- }
102
- if (targets.has("types" /* types */)) {
103
- try {
104
- let context = this.tsContext;
105
- if (context === void 0) {
106
- context = this.tsContext = await (0, import_typescript.createTypescriptContext)(project.pkg.workspace, graph);
107
- }
108
- const refreshCallback = progress.refresh.bind(progress);
109
- if (project.pkg.isLibrary) {
110
- const apiSha = (0, import_node_crypto.createHash)("sha1");
111
- if (node) {
112
- for (const dep of node.dependencies) {
113
- if (dep.info.apiSha !== void 0) {
114
- apiSha.update(dep.info.apiSha);
115
- }
116
- }
117
- }
118
- await progress.run(`Generate ${progress.emphasize("type declarations")}`, async () => {
119
- await context.build(project.pkg, "src", refreshCallback);
120
- await project.hashDeclarations(apiSha);
121
- });
122
- info.apiSha = apiSha.digest("hex");
123
- } else {
124
- await progress.run(
125
- `Validate ${progress.emphasize("types")}`,
126
- () => context.build(project.pkg, "src", refreshCallback, false)
127
- );
128
- }
129
- if (project.pkg.hasTests) {
130
- await progress.run(
131
- `Validate ${progress.emphasize("test types")}`,
132
- () => context.build(project.pkg, "test", refreshCallback)
133
- );
134
- }
135
- } catch (e) {
136
- if (e instanceof import_error.BuildError) {
137
- progress.failure("Terminating due to type errors");
138
- process.stderr.write(`${e.diagnostics}
139
- `);
140
- process.exit(1);
141
- }
142
- throw e;
143
- }
144
- }
145
- const formats = Array();
146
- if (targets.has("esm" /* esm */)) {
147
- formats.push("esm");
148
- }
149
- if (targets.has("cjs" /* cjs */)) {
150
- formats.push("cjs");
151
- }
152
- if (formats.length) {
153
- const groups = [project.pkg.isLibrary ? "library" : "app"];
154
- if (project.pkg.hasTests) {
155
- groups.push("tests");
156
- }
157
- const formatDesc = formats.map(progress.emphasize).join("+");
158
- const groupDesc = groups.map(progress.emphasize).join("+");
159
- await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
160
- for (const format of formats) {
161
- await this.#transpile(project, format);
162
- }
163
- });
164
- }
165
- await config?.after?.({ project });
166
- if (!this.options.targets?.length) {
167
- await project.recordBuildInfo(info);
168
- if (node) {
169
- node.info = info;
170
- }
171
- }
172
- }
173
- async #transpile(project, format) {
174
- await project.buildSource(format);
175
- if (project.pkg.hasTests) {
176
- await project.buildTests(format);
177
- }
178
- }
179
- #selectTargets(project) {
180
- const targets = new Set(this.options.targets);
181
- if (!targets.size) {
182
- targets.add("types" /* types */);
183
- if (project.pkg.supportsEsm) {
184
- targets.add("esm" /* esm */);
185
- }
186
- if (project.pkg.supportsCjs) {
187
- targets.add("cjs" /* cjs */);
188
- }
189
- } else {
190
- if (!project.pkg.supportsEsm) {
191
- targets.delete("esm" /* esm */);
192
- }
193
- if (!project.pkg.supportsCjs) {
194
- targets.delete("cjs" /* cjs */);
195
- }
196
- }
197
- return targets;
198
- }
199
- }
200
- //# sourceMappingURL=builder.js.map
@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/building/builder.ts"],
4
- "mappings": "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",
5
- "names": ["Target"]
6
- }
@@ -1,38 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2022-2025 Matter.js Authors
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { Graph } from "./graph.js";
7
- import { Project } from "./project.js";
8
- import { TypescriptContext } from "./typescript/context.js";
9
- export declare enum Target {
10
- clean = "clean",
11
- types = "types",
12
- esm = "esm",
13
- cjs = "cjs"
14
- }
15
- export interface Options {
16
- targets?: Target[];
17
- clean?: boolean;
18
- graph?: Graph;
19
- }
20
- /**
21
- * High-level build coordination.
22
- *
23
- * Warning: This class is intended for command line use and will process.exit if things go wrong.
24
- */
25
- export declare class Builder {
26
- #private;
27
- private options;
28
- unconditional: boolean;
29
- tsContext?: TypescriptContext;
30
- graph?: Graph;
31
- constructor(options?: Options);
32
- get hasClean(): boolean | undefined;
33
- clearClean(): void;
34
- hasTargets(): boolean | undefined;
35
- configure(project: Project): Promise<void>;
36
- build(project: Project): Promise<void>;
37
- }
38
- //# sourceMappingURL=builder.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../../../src/building/builder.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AACnC,OAAO,EAAoB,OAAO,EAAE,MAAM,cAAc,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAE5D,oBAAY,MAAM;IACd,KAAK,UAAU;IACf,KAAK,UAAU;IACf,GAAG,QAAQ;IACX,GAAG,QAAQ;CACd;AAED,MAAM,WAAW,OAAO;IACpB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,KAAK,CAAC;CACjB;AAED;;;;GAIG;AACH,qBAAa,OAAO;;IAKJ,OAAO,CAAC,OAAO;IAJ3B,aAAa,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,iBAAiB,CAAC;IAC9B,KAAK,CAAC,EAAE,KAAK,CAAC;gBAEM,OAAO,GAAE,OAAY;IAMzC,IAAI,QAAQ,wBAEX;IAED,UAAU;IAIV,UAAU;IAIG,SAAS,CAAC,OAAO,EAAE,OAAO;IAQ1B,KAAK,CAAC,OAAO,EAAE,OAAO;CAsKtC"}
@@ -1,180 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2022-2025 Matter.js Authors
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { createHash } from "node:crypto";
7
- import { BuildError } from "./error.js";
8
- import { Graph } from "./graph.js";
9
- import { createTypescriptContext } from "./typescript.js";
10
- var Target = /* @__PURE__ */ ((Target2) => {
11
- Target2["clean"] = "clean";
12
- Target2["types"] = "types";
13
- Target2["esm"] = "esm";
14
- Target2["cjs"] = "cjs";
15
- return Target2;
16
- })(Target || {});
17
- class Builder {
18
- constructor(options = {}) {
19
- this.options = options;
20
- this.graph = options.graph;
21
- this.unconditional = options.clean || options.targets !== void 0 && options.targets?.indexOf("clean" /* clean */) !== -1;
22
- }
23
- unconditional;
24
- tsContext;
25
- graph;
26
- get hasClean() {
27
- return this.options.clean;
28
- }
29
- clearClean() {
30
- delete this.options.clean;
31
- }
32
- hasTargets() {
33
- return this.options.targets && this.options.targets.length > 0;
34
- }
35
- async configure(project) {
36
- if (!project.pkg.hasConfig) {
37
- return;
38
- }
39
- await project.configure();
40
- }
41
- async build(project) {
42
- const progress = project.pkg.start("Building");
43
- try {
44
- await this.#doBuild(project, progress);
45
- } catch (e) {
46
- progress.close();
47
- process.stderr.write(`${e.stack ?? e.message}
48
-
49
- `);
50
- process.exit(1);
51
- }
52
- progress.close();
53
- }
54
- async #doBuild(project, progress) {
55
- const targets = this.#selectTargets(project);
56
- if (targets.has("clean" /* clean */) || this.options.clean) {
57
- await progress.run("Clean", () => project.clean());
58
- }
59
- if (!targets.has("types" /* types */) && !targets.has("esm" /* esm */) && !targets.has("cjs" /* cjs */)) {
60
- return;
61
- }
62
- const info = {};
63
- const config = await project.configure();
64
- await config?.before?.({ project });
65
- const graph = this.graph ?? await Graph.forProject(project.pkg.path);
66
- let node;
67
- if (graph) {
68
- node = graph.get(project.pkg.name);
69
- for (const dep of node.dependencies) {
70
- if (dep.info.apiSha !== void 0) {
71
- if (info.dependencyApiShas === void 0) {
72
- info.dependencyApiShas = {};
73
- }
74
- info.dependencyApiShas[dep.pkg.name] = dep.info.apiSha;
75
- }
76
- }
77
- }
78
- if (targets.has("types" /* types */)) {
79
- try {
80
- let context = this.tsContext;
81
- if (context === void 0) {
82
- context = this.tsContext = await createTypescriptContext(project.pkg.workspace, graph);
83
- }
84
- const refreshCallback = progress.refresh.bind(progress);
85
- if (project.pkg.isLibrary) {
86
- const apiSha = createHash("sha1");
87
- if (node) {
88
- for (const dep of node.dependencies) {
89
- if (dep.info.apiSha !== void 0) {
90
- apiSha.update(dep.info.apiSha);
91
- }
92
- }
93
- }
94
- await progress.run(`Generate ${progress.emphasize("type declarations")}`, async () => {
95
- await context.build(project.pkg, "src", refreshCallback);
96
- await project.hashDeclarations(apiSha);
97
- });
98
- info.apiSha = apiSha.digest("hex");
99
- } else {
100
- await progress.run(
101
- `Validate ${progress.emphasize("types")}`,
102
- () => context.build(project.pkg, "src", refreshCallback, false)
103
- );
104
- }
105
- if (project.pkg.hasTests) {
106
- await progress.run(
107
- `Validate ${progress.emphasize("test types")}`,
108
- () => context.build(project.pkg, "test", refreshCallback)
109
- );
110
- }
111
- } catch (e) {
112
- if (e instanceof BuildError) {
113
- progress.failure("Terminating due to type errors");
114
- process.stderr.write(`${e.diagnostics}
115
- `);
116
- process.exit(1);
117
- }
118
- throw e;
119
- }
120
- }
121
- const formats = Array();
122
- if (targets.has("esm" /* esm */)) {
123
- formats.push("esm");
124
- }
125
- if (targets.has("cjs" /* cjs */)) {
126
- formats.push("cjs");
127
- }
128
- if (formats.length) {
129
- const groups = [project.pkg.isLibrary ? "library" : "app"];
130
- if (project.pkg.hasTests) {
131
- groups.push("tests");
132
- }
133
- const formatDesc = formats.map(progress.emphasize).join("+");
134
- const groupDesc = groups.map(progress.emphasize).join("+");
135
- await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
136
- for (const format of formats) {
137
- await this.#transpile(project, format);
138
- }
139
- });
140
- }
141
- await config?.after?.({ project });
142
- if (!this.options.targets?.length) {
143
- await project.recordBuildInfo(info);
144
- if (node) {
145
- node.info = info;
146
- }
147
- }
148
- }
149
- async #transpile(project, format) {
150
- await project.buildSource(format);
151
- if (project.pkg.hasTests) {
152
- await project.buildTests(format);
153
- }
154
- }
155
- #selectTargets(project) {
156
- const targets = new Set(this.options.targets);
157
- if (!targets.size) {
158
- targets.add("types" /* types */);
159
- if (project.pkg.supportsEsm) {
160
- targets.add("esm" /* esm */);
161
- }
162
- if (project.pkg.supportsCjs) {
163
- targets.add("cjs" /* cjs */);
164
- }
165
- } else {
166
- if (!project.pkg.supportsEsm) {
167
- targets.delete("esm" /* esm */);
168
- }
169
- if (!project.pkg.supportsCjs) {
170
- targets.delete("cjs" /* cjs */);
171
- }
172
- }
173
- return targets;
174
- }
175
- }
176
- export {
177
- Builder,
178
- Target
179
- };
180
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/building/builder.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2025 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { createHash } from \"node: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.close();\n            process.stderr.write(`${e.stack ?? e.message}\\n\\n`);\n            process.exit(1);\n        }\n\n        progress.close();\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                    // Work-in-progress alternative doc generation implementation\n                    // await progress.run(`Extract ${progress.emphasize(\"api docs\")}`, () =>\n                    //     emitApiDoc(project.pkg, program, progress),\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"]
}

@@ -1,6 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/building/builder.ts"],
4
- "mappings": "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",
5
- "names": ["Target"]
6
- }
@@ -1,230 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2022-2025 Matter.js Authors
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- import { createHash } from "node:crypto";
8
- import { Progress } from "../util/progress.js";
9
- import { BuildError } from "./error.js";
10
- import { Graph } from "./graph.js";
11
- import { BuildInformation, Project } from "./project.js";
12
- import { createTypescriptContext } from "./typescript.js";
13
- import { TypescriptContext } from "./typescript/context.js";
14
-
15
- export enum Target {
16
- clean = "clean",
17
- types = "types",
18
- esm = "esm",
19
- cjs = "cjs",
20
- }
21
-
22
- export interface Options {
23
- targets?: Target[];
24
- clean?: boolean;
25
- graph?: Graph;
26
- }
27
-
28
- /**
29
- * High-level build coordination.
30
- *
31
- * Warning: This class is intended for command line use and will process.exit if things go wrong.
32
- */
33
- export class Builder {
34
- unconditional: boolean;
35
- tsContext?: TypescriptContext;
36
- graph?: Graph;
37
-
38
- constructor(private options: Options = {}) {
39
- this.graph = options.graph;
40
- this.unconditional =
41
- options.clean || (options.targets !== undefined && options.targets?.indexOf(Target.clean) !== -1);
42
- }
43
-
44
- get hasClean() {
45
- return this.options.clean;
46
- }
47
-
48
- clearClean() {
49
- delete this.options.clean;
50
- }
51
-
52
- hasTargets() {
53
- return this.options.targets && this.options.targets.length > 0;
54
- }
55
-
56
- public async configure(project: Project) {
57
- if (!project.pkg.hasConfig) {
58
- return;
59
- }
60
-
61
- await project.configure();
62
- }
63
-
64
- public async build(project: Project) {
65
- const progress = project.pkg.start("Building");
66
-
67
- try {
68
- await this.#doBuild(project, progress);
69
- } catch (e: any) {
70
- progress.close();
71
- process.stderr.write(`${e.stack ?? e.message}\n\n`);
72
- process.exit(1);
73
- }
74
-
75
- progress.close();
76
- }
77
-
78
- async #doBuild(project: Project, progress: Progress) {
79
- const targets = this.#selectTargets(project);
80
-
81
- if (targets.has(Target.clean) || this.options.clean) {
82
- await progress.run("Clean", () => project.clean());
83
- }
84
-
85
- if (!targets.has(Target.types) && !targets.has(Target.esm) && !targets.has(Target.cjs)) {
86
- return;
87
- }
88
-
89
- const info: BuildInformation = {};
90
-
91
- const config = await project.configure();
92
-
93
- await config?.before?.({ project });
94
-
95
- // If available we use graph to access dependency API shas
96
- const graph = this.graph ?? (await Graph.forProject(project.pkg.path));
97
- let node: Graph.Node | undefined;
98
- if (graph) {
99
- node = graph.get(project.pkg.name);
100
- for (const dep of node.dependencies) {
101
- if (dep.info.apiSha !== undefined) {
102
- if (info.dependencyApiShas === undefined) {
103
- info.dependencyApiShas = {};
104
- }
105
- info.dependencyApiShas[dep.pkg.name] = dep.info.apiSha;
106
- }
107
- }
108
- }
109
-
110
- if (targets.has(Target.types)) {
111
- try {
112
- // Obtain or initialize typescript solution builder
113
- let context = this.tsContext;
114
- if (context === undefined) {
115
- context = this.tsContext = await createTypescriptContext(project.pkg.workspace, graph);
116
- }
117
-
118
- const refreshCallback = progress.refresh.bind(progress);
119
-
120
- if (project.pkg.isLibrary) {
121
- const apiSha = createHash("sha1");
122
-
123
- // Our API SHA changes if that of any dependency changes
124
- if (node) {
125
- for (const dep of node.dependencies) {
126
- if (dep.info.apiSha !== undefined) {
127
- apiSha.update(dep.info.apiSha);
128
- }
129
- }
130
- }
131
-
132
- await progress.run(`Generate ${progress.emphasize("type declarations")}`, async () => {
133
- await context.build(project.pkg, "src", refreshCallback);
134
- await project.hashDeclarations(apiSha);
135
- });
136
-
137
- // Work-in-progress alternative doc generation implementation
138
- // await progress.run(`Extract ${progress.emphasize("api docs")}`, () =>
139
- // emitApiDoc(project.pkg, program, progress),
140
- // );
141
-
142
- info.apiSha = apiSha.digest("hex");
143
- } else {
144
- await progress.run(`Validate ${progress.emphasize("types")}`, () =>
145
- context.build(project.pkg, "src", refreshCallback, false),
146
- );
147
- }
148
- if (project.pkg.hasTests) {
149
- await progress.run(`Validate ${progress.emphasize("test types")}`, () =>
150
- context.build(project.pkg, "test", refreshCallback),
151
- );
152
- }
153
- } catch (e) {
154
- if (e instanceof BuildError) {
155
- progress.failure("Terminating due to type errors");
156
- process.stderr.write(`${e.diagnostics}\n`);
157
- process.exit(1);
158
- }
159
- throw e;
160
- }
161
- }
162
-
163
- const formats = Array<"esm" | "cjs">();
164
- if (targets.has(Target.esm)) {
165
- formats.push("esm");
166
- }
167
- if (targets.has(Target.cjs)) {
168
- formats.push("cjs");
169
- }
170
-
171
- if (formats.length) {
172
- const groups = [project.pkg.isLibrary ? "library" : "app"];
173
- if (project.pkg.hasTests) {
174
- groups.push("tests");
175
- }
176
-
177
- const formatDesc = formats.map(progress.emphasize).join("+");
178
- const groupDesc = groups.map(progress.emphasize).join("+");
179
-
180
- await progress.run(`Transpile ${groupDesc} to ${formatDesc}`, async () => {
181
- for (const format of formats) {
182
- await this.#transpile(project, format);
183
- }
184
- });
185
- }
186
-
187
- await config?.after?.({ project });
188
-
189
- // Only update build information when there are no explicit targets so we know it's a full build
190
- if (!this.options.targets?.length) {
191
- await project.recordBuildInfo(info);
192
- if (node) {
193
- node.info = info;
194
- }
195
- }
196
- }
197
-
198
- async #transpile(project: Project, format: "esm" | "cjs") {
199
- await project.buildSource(format);
200
- if (project.pkg.hasTests) {
201
- await project.buildTests(format);
202
- }
203
- }
204
-
205
- #selectTargets(project: Project) {
206
- const targets = new Set<string>(this.options.targets);
207
-
208
- if (!targets.size) {
209
- targets.add(Target.types);
210
-
211
- if (project.pkg.supportsEsm) {
212
- targets.add(Target.esm);
213
- }
214
-
215
- if (project.pkg.supportsCjs) {
216
- targets.add(Target.cjs);
217
- }
218
- } else {
219
- if (!project.pkg.supportsEsm) {
220
- targets.delete(Target.esm);
221
- }
222
-
223
- if (!project.pkg.supportsCjs) {
224
- targets.delete(Target.cjs);
225
- }
226
- }
227
-
228
- return targets;
229
- }
230
- }