@tobisk/pcbs 1.0.0
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/LICENSE.md +21 -0
- package/README.md +186 -0
- package/dist/src/cli/cli.d.ts +6 -0
- package/dist/src/cli/cli.js +87 -0
- package/dist/src/cli/cli.js.map +1 -0
- package/dist/src/cli/codegen.d.ts +25 -0
- package/dist/src/cli/codegen.js +170 -0
- package/dist/src/cli/codegen.js.map +1 -0
- package/dist/src/cli/commands/export.d.ts +13 -0
- package/dist/src/cli/commands/export.js +301 -0
- package/dist/src/cli/commands/export.js.map +1 -0
- package/dist/src/cli/commands/lib.d.ts +10 -0
- package/dist/src/cli/commands/lib.js +158 -0
- package/dist/src/cli/commands/lib.js.map +1 -0
- package/dist/src/cli/commands/parts.d.ts +4 -0
- package/dist/src/cli/commands/parts.js +104 -0
- package/dist/src/cli/commands/parts.js.map +1 -0
- package/dist/src/cli/commands/setup.d.ts +4 -0
- package/dist/src/cli/commands/setup.js +86 -0
- package/dist/src/cli/commands/setup.js.map +1 -0
- package/dist/src/cli/commands/synth.d.ts +4 -0
- package/dist/src/cli/commands/synth.js +75 -0
- package/dist/src/cli/commands/synth.js.map +1 -0
- package/dist/src/cli/commands/types.d.ts +1 -0
- package/dist/src/cli/commands/types.js +140 -0
- package/dist/src/cli/commands/types.js.map +1 -0
- package/dist/src/cli/commands/validate.d.ts +5 -0
- package/dist/src/cli/commands/validate.js +105 -0
- package/dist/src/cli/commands/validate.js.map +1 -0
- package/dist/src/cli/config.d.ts +9 -0
- package/dist/src/cli/config.js +80 -0
- package/dist/src/cli/config.js.map +1 -0
- package/dist/src/cli/env.d.ts +4 -0
- package/dist/src/cli/env.js +166 -0
- package/dist/src/cli/env.js.map +1 -0
- package/dist/src/cli/search-jlc.d.ts +0 -0
- package/dist/src/cli/search-jlc.js +23 -0
- package/dist/src/cli/search-jlc.js.map +1 -0
- package/dist/src/cli/synthesis.d.ts +11 -0
- package/dist/src/cli/synthesis.js +120 -0
- package/dist/src/cli/synthesis.js.map +1 -0
- package/dist/src/cli/utils/bom.d.ts +19 -0
- package/dist/src/cli/utils/bom.js +130 -0
- package/dist/src/cli/utils/bom.js.map +1 -0
- package/dist/src/cli/utils/cpl.d.ts +18 -0
- package/dist/src/cli/utils/cpl.js +101 -0
- package/dist/src/cli/utils/cpl.js.map +1 -0
- package/dist/src/cli/utils.d.ts +11 -0
- package/dist/src/cli/utils.js +136 -0
- package/dist/src/cli/utils.js.map +1 -0
- package/dist/src/generate-kicad-types.d.ts +1 -0
- package/dist/src/generate-kicad-types.js +137 -0
- package/dist/src/generate-kicad-types.js.map +1 -0
- package/dist/src/synth/3d/Kicad3DModel.d.ts +81 -0
- package/dist/src/synth/3d/Kicad3DModel.js +250 -0
- package/dist/src/synth/3d/Kicad3DModel.js.map +1 -0
- package/dist/src/synth/3d/booleans.d.ts +10 -0
- package/dist/src/synth/3d/booleans.js +30 -0
- package/dist/src/synth/3d/booleans.js.map +1 -0
- package/dist/src/synth/3d/fillet.d.ts +14 -0
- package/dist/src/synth/3d/fillet.js +47 -0
- package/dist/src/synth/3d/fillet.js.map +1 -0
- package/dist/src/synth/3d/index.d.ts +7 -0
- package/dist/src/synth/3d/index.js +14 -0
- package/dist/src/synth/3d/index.js.map +1 -0
- package/dist/src/synth/3d/occ-loader.d.ts +5 -0
- package/dist/src/synth/3d/occ-loader.js +77 -0
- package/dist/src/synth/3d/occ-loader.js.map +1 -0
- package/dist/src/synth/3d/occ.d.ts +3 -0
- package/dist/src/synth/3d/occ.js +31 -0
- package/dist/src/synth/3d/occ.js.map +1 -0
- package/dist/src/synth/3d/primitives.d.ts +38 -0
- package/dist/src/synth/3d/primitives.js +58 -0
- package/dist/src/synth/3d/primitives.js.map +1 -0
- package/dist/src/synth/3d/stepWriter.d.ts +7 -0
- package/dist/src/synth/3d/stepWriter.js +72 -0
- package/dist/src/synth/3d/stepWriter.js.map +1 -0
- package/dist/src/synth/3d/transforms.d.ts +18 -0
- package/dist/src/synth/3d/transforms.js +74 -0
- package/dist/src/synth/3d/transforms.js.map +1 -0
- package/dist/src/synth/3d/types.d.ts +54 -0
- package/dist/src/synth/3d/types.js +21 -0
- package/dist/src/synth/3d/types.js.map +1 -0
- package/dist/src/synth/3d/vrmlWriter.d.ts +5 -0
- package/dist/src/synth/3d/vrmlWriter.js +171 -0
- package/dist/src/synth/3d/vrmlWriter.js.map +1 -0
- package/dist/src/synth/Component.d.ts +67 -0
- package/dist/src/synth/Component.js +185 -0
- package/dist/src/synth/Component.js.map +1 -0
- package/dist/src/synth/Composable.d.ts +73 -0
- package/dist/src/synth/Composable.js +128 -0
- package/dist/src/synth/Composable.js.map +1 -0
- package/dist/src/synth/KicadFootprint.d.ts +97 -0
- package/dist/src/synth/KicadFootprint.js +312 -0
- package/dist/src/synth/KicadFootprint.js.map +1 -0
- package/dist/src/synth/KicadLibrary.d.ts +66 -0
- package/dist/src/synth/KicadLibrary.js +162 -0
- package/dist/src/synth/KicadLibrary.js.map +1 -0
- package/dist/src/synth/KicadSymbol.d.ts +71 -0
- package/dist/src/synth/KicadSymbol.js +190 -0
- package/dist/src/synth/KicadSymbol.js.map +1 -0
- package/dist/src/synth/Layout.d.ts +37 -0
- package/dist/src/synth/Layout.js +58 -0
- package/dist/src/synth/Layout.js.map +1 -0
- package/dist/src/synth/Markers.d.ts +35 -0
- package/dist/src/synth/Markers.js +48 -0
- package/dist/src/synth/Markers.js.map +1 -0
- package/dist/src/synth/Module.d.ts +56 -0
- package/dist/src/synth/Module.js +65 -0
- package/dist/src/synth/Module.js.map +1 -0
- package/dist/src/synth/Net.d.ts +23 -0
- package/dist/src/synth/Net.js +95 -0
- package/dist/src/synth/Net.js.map +1 -0
- package/dist/src/synth/Registry.d.ts +36 -0
- package/dist/src/synth/Registry.js +75 -0
- package/dist/src/synth/Registry.js.map +1 -0
- package/dist/src/synth/Schematic.d.ts +36 -0
- package/dist/src/synth/Schematic.js +51 -0
- package/dist/src/synth/Schematic.js.map +1 -0
- package/dist/src/synth/index.d.ts +21 -0
- package/dist/src/synth/index.js +46 -0
- package/dist/src/synth/index.js.map +1 -0
- package/dist/src/synth/kicad-types-placeholder.d.ts +6 -0
- package/dist/src/synth/kicad-types-placeholder.js +7 -0
- package/dist/src/synth/kicad-types-placeholder.js.map +1 -0
- package/dist/src/synth/types.d.ts +111 -0
- package/dist/src/synth/types.js +23 -0
- package/dist/src/synth/types.js.map +1 -0
- package/dist/src/tests/3d-model.test.d.ts +1 -0
- package/dist/src/tests/3d-model.test.js +282 -0
- package/dist/src/tests/3d-model.test.js.map +1 -0
- package/dist/src/tests/codegen.test.d.ts +1 -0
- package/dist/src/tests/codegen.test.js +80 -0
- package/dist/src/tests/codegen.test.js.map +1 -0
- package/dist/src/tests/dmx_node.test.d.ts +1 -0
- package/dist/src/tests/dmx_node.test.js +42 -0
- package/dist/src/tests/dmx_node.test.js.map +1 -0
- package/dist/src/tests/dnc.test.d.ts +1 -0
- package/dist/src/tests/dnc.test.js +100 -0
- package/dist/src/tests/dnc.test.js.map +1 -0
- package/dist/src/tests/kicad-lib.test.d.ts +1 -0
- package/dist/src/tests/kicad-lib.test.js +465 -0
- package/dist/src/tests/kicad-lib.test.js.map +1 -0
- package/dist/src/tests/layout.test.d.ts +1 -0
- package/dist/src/tests/layout.test.js +92 -0
- package/dist/src/tests/layout.test.js.map +1 -0
- package/dist/src/tests/migration.test.d.ts +1 -0
- package/dist/src/tests/migration.test.js +58 -0
- package/dist/src/tests/migration.test.js.map +1 -0
- package/dist/src/tests/net_merging.test.d.ts +1 -0
- package/dist/src/tests/net_merging.test.js +97 -0
- package/dist/src/tests/net_merging.test.js.map +1 -0
- package/dist/src/tests/occ-minimal.test.d.ts +1 -0
- package/dist/src/tests/occ-minimal.test.js +14 -0
- package/dist/src/tests/occ-minimal.test.js.map +1 -0
- package/dist/src/tests/placement.test.d.ts +1 -0
- package/dist/src/tests/placement.test.js +130 -0
- package/dist/src/tests/placement.test.js.map +1 -0
- package/dist/src/tests/synthesis.test.d.ts +1 -0
- package/dist/src/tests/synthesis.test.js +88 -0
- package/dist/src/tests/synthesis.test.js.map +1 -0
- package/dist/src/types/kicad-library.d.ts +6 -0
- package/dist/src/types/kicad-library.js +7 -0
- package/dist/src/types/kicad-library.js.map +1 -0
- package/dist/src/types/kicad-library.ts +61770 -0
- package/package.json +57 -0
- package/scripts/patch-opencascade.ts +18 -0
- package/scripts/wasm-stub.js +1 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const Max3485_1 = require("../../src/lib/Max3485");
|
|
5
|
+
const BuckConverter_1 = require("../../src/lib/BuckConverter");
|
|
6
|
+
const Registry_1 = require("../synth/Registry");
|
|
7
|
+
(0, vitest_1.describe)("Component Migration Verification", () => {
|
|
8
|
+
(0, vitest_1.it)("should correctly instantiate Max3485", () => {
|
|
9
|
+
Registry_1.registry.start();
|
|
10
|
+
const transceiver = new Max3485_1.Max3485({ ref: "U1" });
|
|
11
|
+
(0, vitest_1.expect)(transceiver.ref).toBe("U1");
|
|
12
|
+
(0, vitest_1.expect)(transceiver.symbol).toBe("Interface_UART:MAX3485");
|
|
13
|
+
(0, vitest_1.expect)(transceiver.footprint).toBe("Package_SO:SOIC-8_3.9x4.9mm_P1.27mm");
|
|
14
|
+
(0, vitest_1.expect)(transceiver.partNo).toBe("C18148");
|
|
15
|
+
// Check pins
|
|
16
|
+
(0, vitest_1.expect)(transceiver.pins.RO.name).toBe("1");
|
|
17
|
+
(0, vitest_1.expect)(transceiver.pins.VCC.name).toBe("8");
|
|
18
|
+
(0, vitest_1.expect)(transceiver.pins.GND.name).toBe("5");
|
|
19
|
+
});
|
|
20
|
+
(0, vitest_1.it)("should correctly instantiate BuckConverter with 5V target", () => {
|
|
21
|
+
Registry_1.registry.start();
|
|
22
|
+
const buck = new BuckConverter_1.BuckConverter({ ref: "U2", targetVoltage: 5.0 });
|
|
23
|
+
(0, vitest_1.expect)(buck.ref).toBe("U2");
|
|
24
|
+
// Internal components check
|
|
25
|
+
const vinPin = buck.pins.VIN;
|
|
26
|
+
const vinNet = vinPin.net;
|
|
27
|
+
(0, vitest_1.expect)(vinNet).toBeDefined();
|
|
28
|
+
(0, vitest_1.expect)(vinNet?.name).toBe("U2_VIN");
|
|
29
|
+
// Check feedback resistors for 5V
|
|
30
|
+
// R1 = 3000, R2 = 1000
|
|
31
|
+
const components = Array.from(Registry_1.registry.getComponents());
|
|
32
|
+
const r1 = components.find(c => c.ref === "R_FB1_U2");
|
|
33
|
+
const r2 = components.find(c => c.ref === "R_FB2_U2");
|
|
34
|
+
(0, vitest_1.expect)(r1?.value).toBe("3k");
|
|
35
|
+
(0, vitest_1.expect)(r1?.partNo).toBe("C22965");
|
|
36
|
+
(0, vitest_1.expect)(r2?.value).toBe("1k");
|
|
37
|
+
(0, vitest_1.expect)(r2?.partNo).toBe("C21190");
|
|
38
|
+
});
|
|
39
|
+
(0, vitest_1.it)("should correctly instantiate BuckConverter with 12V target", () => {
|
|
40
|
+
Registry_1.registry.start();
|
|
41
|
+
new BuckConverter_1.BuckConverter({ ref: "U3", targetVoltage: 12.0 });
|
|
42
|
+
const components = Array.from(Registry_1.registry.getComponents());
|
|
43
|
+
const r1 = components.find(c => c.ref === "R_FB1_U3");
|
|
44
|
+
const r2 = components.find(c => c.ref === "R_FB2_U3");
|
|
45
|
+
(0, vitest_1.expect)(r1?.value).toBe("13k");
|
|
46
|
+
(0, vitest_1.expect)(r1?.partNo).toBe("C24857");
|
|
47
|
+
(0, vitest_1.expect)(r2?.value).toBe("1.50k");
|
|
48
|
+
(0, vitest_1.expect)(r2?.partNo).toBe("C22843");
|
|
49
|
+
});
|
|
50
|
+
(0, vitest_1.it)("should work with test points in BuckConverter", () => {
|
|
51
|
+
Registry_1.registry.start();
|
|
52
|
+
new BuckConverter_1.BuckConverter({ ref: "U4", addTestPoints: true });
|
|
53
|
+
const components = Array.from(Registry_1.registry.getComponents());
|
|
54
|
+
(0, vitest_1.expect)(components.some(c => c.ref === "TP_VOUT_U4")).toBe(true);
|
|
55
|
+
(0, vitest_1.expect)(components.some(c => c.ref === "TP_FB_U4")).toBe(true);
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
//# sourceMappingURL=migration.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration.test.js","sourceRoot":"","sources":["../../../src/tests/migration.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const synth_1 = require("../synth");
|
|
5
|
+
const Registry_1 = require("../synth/Registry");
|
|
6
|
+
(0, vitest_1.describe)("Net Merging", () => {
|
|
7
|
+
(0, vitest_1.beforeEach)(() => {
|
|
8
|
+
Registry_1.registry.start();
|
|
9
|
+
});
|
|
10
|
+
(0, vitest_1.it)("should merge two nets when a pin is tied to another net", () => {
|
|
11
|
+
const netA = new synth_1.Net({ name: "NetA" });
|
|
12
|
+
const netB = new synth_1.Net({ name: "NetB" });
|
|
13
|
+
const r1 = new synth_1.Component({
|
|
14
|
+
symbol: "Device:R",
|
|
15
|
+
ref: "R1",
|
|
16
|
+
footprint: "Resistor_SMD:R_0603_1608Metric",
|
|
17
|
+
});
|
|
18
|
+
// Pin 1 starts in NetA
|
|
19
|
+
netA.tie(r1.pins[1]);
|
|
20
|
+
(0, vitest_1.expect)(r1.pins[1].net).toBe(netA);
|
|
21
|
+
(0, vitest_1.expect)(netA.pins).toContain(r1.pins[1]);
|
|
22
|
+
// Now tie Pin 1 to NetB - this should merge NetA into NetB
|
|
23
|
+
netB.tie(r1.pins[1]);
|
|
24
|
+
(0, vitest_1.expect)(r1.pins[1].net).toBe(netB);
|
|
25
|
+
(0, vitest_1.expect)(netB.pins).toContain(r1.pins[1]);
|
|
26
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets()).toContain(netB);
|
|
27
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets()).not.toContain(netA);
|
|
28
|
+
});
|
|
29
|
+
(0, vitest_1.it)("should merge all pins from the old net into the new net", () => {
|
|
30
|
+
const netA = new synth_1.Net({ name: "NetA" });
|
|
31
|
+
const netB = new synth_1.Net({ name: "NetB" });
|
|
32
|
+
const r1 = new synth_1.Component({ symbol: "Device:R", ref: "R1", footprint: "Resistor_SMD:R_0603_1608Metric" });
|
|
33
|
+
const r2 = new synth_1.Component({ symbol: "Device:R", ref: "R2", footprint: "Resistor_SMD:R_0603_1608Metric" });
|
|
34
|
+
netA.tie(r1.pins[1]);
|
|
35
|
+
netA.tie(r1.pins[2]);
|
|
36
|
+
netB.tie(r2.pins[1]);
|
|
37
|
+
// Merge NetA into NetB
|
|
38
|
+
netB.tie(r1.pins[1]);
|
|
39
|
+
(0, vitest_1.expect)(r1.pins[1].net).toBe(netB);
|
|
40
|
+
(0, vitest_1.expect)(r1.pins[2].net).toBe(netB);
|
|
41
|
+
(0, vitest_1.expect)(r2.pins[1].net).toBe(netB);
|
|
42
|
+
(0, vitest_1.expect)(netB.pins.length).toBe(3);
|
|
43
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets().length).toBe(1);
|
|
44
|
+
});
|
|
45
|
+
(0, vitest_1.it)("should handle implicit merging via pin assignment", () => {
|
|
46
|
+
const netA = new synth_1.Net({ name: "NetA" });
|
|
47
|
+
const netB = new synth_1.Net({ name: "NetB" });
|
|
48
|
+
const r1 = new synth_1.Component({ symbol: "Device:R", ref: "R1", footprint: "Resistor_SMD:R_0603_1608Metric" });
|
|
49
|
+
const r2 = new synth_1.Component({ symbol: "Device:R", ref: "R2", footprint: "Resistor_SMD:R_0603_1608Metric" });
|
|
50
|
+
r1.pins[1] = netA;
|
|
51
|
+
r2.pins[1] = netB;
|
|
52
|
+
// This assignment should trigger a merge because both pins have nets
|
|
53
|
+
r1.pins[1] = r2.pins[1];
|
|
54
|
+
// Note: createPinProxy logic for pin=pin assignment:
|
|
55
|
+
// if (otherPin.net) { otherPin.net.tie(pin); }
|
|
56
|
+
// So netB.tie(r1.pins[1]) happens, which merges netA into netB (since netB is "newer" in the assignment target sense? no, netB is otherPin.net)
|
|
57
|
+
(0, vitest_1.expect)(r1.pins[1].net).toBe(netB);
|
|
58
|
+
(0, vitest_1.expect)(r2.pins[1].net).toBe(netB);
|
|
59
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets()).toContain(netB);
|
|
60
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets()).not.toContain(netA);
|
|
61
|
+
});
|
|
62
|
+
(0, vitest_1.it)("should respect DNC rules during merge", () => {
|
|
63
|
+
const netA = new synth_1.Net({ name: "NetA" });
|
|
64
|
+
const r1 = new synth_1.Component({ symbol: "Device:R", ref: "R1", footprint: "Resistor_SMD:R_0603_1608Metric" });
|
|
65
|
+
netA.tie(r1.pins[1]);
|
|
66
|
+
netA.tie(r1.pins[2]); // NetA has 2 functional pins
|
|
67
|
+
const netDnc = new synth_1.Net({ name: "DNC_NET" });
|
|
68
|
+
const dnc = new synth_1.Component({ symbol: "Device:DNC", ref: "D1", footprint: "DNC" });
|
|
69
|
+
netDnc.tie(dnc.pins[1]);
|
|
70
|
+
// Merging a DNC net with a net that have >1 functional pins should fail
|
|
71
|
+
(0, vitest_1.expect)(() => netDnc.tie(r1.pins[1])).toThrow(/Cannot merge nets/);
|
|
72
|
+
});
|
|
73
|
+
(0, vitest_1.it)("should merge correctly in a Composable-like structure (repro user report)", () => {
|
|
74
|
+
// Mimic DmxNode setup
|
|
75
|
+
const vccVin = new synth_1.Net({ name: "+VIN" });
|
|
76
|
+
// Mimic BuckConverter internal setup
|
|
77
|
+
const buckRef = "U4";
|
|
78
|
+
const internalVinNet = new synth_1.Net({ name: `${buckRef}_VIN` });
|
|
79
|
+
const uBuck = new synth_1.Component({ symbol: "Device:L_Small", ref: buckRef, footprint: "Inductor_SMD:L_0603_1608Metric" });
|
|
80
|
+
const cIn = new synth_1.Component({ symbol: "Device:C_Small", ref: `C_IN_${buckRef}`, footprint: "Capacitor_SMD:C_0603_1608Metric" });
|
|
81
|
+
internalVinNet.tie(uBuck.pins[1]);
|
|
82
|
+
internalVinNet.tie(cIn.pins[1]);
|
|
83
|
+
// Mimic barrel jack
|
|
84
|
+
const barrelJack = new synth_1.Component({ symbol: "Connector:Barrel_Jack", ref: "J1", footprint: "Connector_BarrelJack:BarrelJack_Horizontal" });
|
|
85
|
+
barrelJack.pins[1] = vccVin;
|
|
86
|
+
// The "buck.pins.VIN = vccVin" assignment
|
|
87
|
+
const buckVinPin = uBuck.pins[1];
|
|
88
|
+
vccVin.tie(buckVinPin);
|
|
89
|
+
// Assertions
|
|
90
|
+
(0, vitest_1.expect)(uBuck.pins[1].net).toBe(vccVin);
|
|
91
|
+
(0, vitest_1.expect)(cIn.pins[1].net).toBe(vccVin);
|
|
92
|
+
(0, vitest_1.expect)(barrelJack.pins[1].net).toBe(vccVin);
|
|
93
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets().map(n => n.name)).toContain("+VIN");
|
|
94
|
+
(0, vitest_1.expect)(Registry_1.registry.getNets().map(n => n.name)).not.toContain("U4_VIN");
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
//# sourceMappingURL=net_merging.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"net_merging.test.js","sourceRoot":"","sources":["../../../src/tests/net_merging.test.ts"],"names":[],"mappings":";;AAAA,mCAA0D;AAC1D,oCAAoD;AACpD,gDAA6C;AAE7C,IAAA,iBAAQ,EAAC,aAAa,EAAE,GAAG,EAAE;IACzB,IAAA,mBAAU,EAAC,GAAG,EAAE;QACZ,mBAAQ,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,yDAAyD,EAAE,GAAG,EAAE;QAC/D,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAEvC,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC;YACrB,MAAM,EAAE,UAAU;YAClB,GAAG,EAAE,IAAI;YACT,SAAS,EAAE,gCAAgC;SAC9C,CAAC,CAAC;QAEH,uBAAuB;QACvB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAExC,2DAA2D;QAC3D,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAErB,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,yDAAyD,EAAE,GAAG,EAAE;QAC/D,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAEvC,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QACzG,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QAEzG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAErB,uBAAuB;QACvB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAErB,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,mDAAmD,EAAE,GAAG,EAAE;QACzD,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAEvC,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QACzG,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QAEzG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QAClB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QAElB,qEAAqE;QACrE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAExB,qDAAqD;QACrD,+CAA+C;QAC/C,gJAAgJ;QAEhJ,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,uCAAuC,EAAE,GAAG,EAAE;QAC7C,MAAM,IAAI,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QACvC,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QACzG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,6BAA6B;QAEnD,MAAM,MAAM,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAC5C,MAAM,GAAG,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QACjF,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAExB,wEAAwE;QACxE,IAAA,eAAM,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,2EAA2E,EAAE,GAAG,EAAE;QACjF,sBAAsB;QACtB,MAAM,MAAM,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;QAEzC,qCAAqC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC;QACrB,MAAM,cAAc,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,GAAG,OAAO,MAAM,EAAE,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,gCAAgC,EAAE,CAAC,CAAC;QACrH,MAAM,GAAG,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,gBAAgB,EAAE,GAAG,EAAE,QAAQ,OAAO,EAAE,EAAE,SAAS,EAAE,iCAAiC,EAAE,CAAC,CAAC;QAE9H,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAClC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAEhC,oBAAoB;QACpB,MAAM,UAAU,GAAG,IAAI,iBAAS,CAAC,EAAE,MAAM,EAAE,uBAAuB,EAAE,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,4CAA4C,EAAE,CAAC,CAAC;QAC1I,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC;QAE5B,0CAA0C;QAC1C,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAEvB,aAAa;QACb,IAAA,eAAM,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,IAAA,eAAM,EAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrC,IAAA,eAAM,EAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC9D,IAAA,eAAM,EAAC,mBAAQ,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const occ_1 = require("../synth/3d/occ");
|
|
5
|
+
(0, vitest_1.describe)('OpenCascade Minimal', () => {
|
|
6
|
+
(0, vitest_1.it)('should initialize OpenCascade', async () => {
|
|
7
|
+
console.log('Test: Calling initOCC...');
|
|
8
|
+
const OC = await (0, occ_1.initOCC)();
|
|
9
|
+
console.log('Test: initOCC finished');
|
|
10
|
+
(0, vitest_1.expect)(OC).toBeDefined();
|
|
11
|
+
(0, vitest_1.expect)(OC.gp_Pnt).toBeDefined();
|
|
12
|
+
}, 30000);
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=occ-minimal.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"occ-minimal.test.js","sourceRoot":"","sources":["../../../src/tests/occ-minimal.test.ts"],"names":[],"mappings":";;AACA,mCAA8C;AAC9C,yCAA0C;AAE1C,IAAA,iBAAQ,EAAC,qBAAqB,EAAE,GAAG,EAAE;IACjC,IAAA,WAAE,EAAC,+BAA+B,EAAE,KAAK,IAAI,EAAE;QAC3C,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;QACxC,MAAM,EAAE,GAAG,MAAM,IAAA,aAAO,GAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;QACtC,IAAA,eAAM,EAAC,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACzB,IAAA,eAAM,EAAC,EAAE,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC,EAAE,KAAK,CAAC,CAAC;AACd,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const synth_1 = require("../synth");
|
|
5
|
+
(0, vitest_1.describe)("Component and Composable Placement", () => {
|
|
6
|
+
(0, vitest_1.it)("calculates absolute schematic position for a single component", () => {
|
|
7
|
+
const c1 = new synth_1.Component({
|
|
8
|
+
ref: "C1",
|
|
9
|
+
symbol: "Device:C",
|
|
10
|
+
footprint: "Capacitor_SMD:C_0603_1608Metric",
|
|
11
|
+
schematicPosition: { x: 10, y: 20, rotation: 90 },
|
|
12
|
+
});
|
|
13
|
+
const pos = c1.absoluteSchematicPosition;
|
|
14
|
+
(0, vitest_1.expect)(pos.x).toBe(10);
|
|
15
|
+
(0, vitest_1.expect)(pos.y).toBe(20);
|
|
16
|
+
(0, vitest_1.expect)(pos.rotation).toBe(90);
|
|
17
|
+
});
|
|
18
|
+
(0, vitest_1.it)("calculates absolute pcb position for a single component", () => {
|
|
19
|
+
const c1 = new synth_1.Component({
|
|
20
|
+
ref: "C1",
|
|
21
|
+
symbol: "Device:C",
|
|
22
|
+
footprint: "Capacitor_SMD:C_0603_1608Metric",
|
|
23
|
+
pcbPosition: { x: 50, y: 60, rotation: 180, side: "back" },
|
|
24
|
+
});
|
|
25
|
+
const pos = c1.absolutePcbPosition;
|
|
26
|
+
(0, vitest_1.expect)(pos.x).toBe(50);
|
|
27
|
+
(0, vitest_1.expect)(pos.y).toBe(60);
|
|
28
|
+
(0, vitest_1.expect)(pos.rotation).toBe(180);
|
|
29
|
+
(0, vitest_1.expect)(pos.side).toBe("back");
|
|
30
|
+
});
|
|
31
|
+
(0, vitest_1.it)("offsets component position within a Composable", () => {
|
|
32
|
+
class MyComposable extends synth_1.Composable {
|
|
33
|
+
constructor() {
|
|
34
|
+
super({
|
|
35
|
+
ref: "MY",
|
|
36
|
+
schematicPosition: { x: 100, y: 100 },
|
|
37
|
+
pcbPosition: { x: 200, y: 200, side: "back" },
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
defineInterface() {
|
|
41
|
+
this.comp = new synth_1.Component({
|
|
42
|
+
ref: "R1",
|
|
43
|
+
symbol: "Device:R",
|
|
44
|
+
footprint: "Resistor_SMD:R_0603_1608Metric",
|
|
45
|
+
schematicPosition: { x: 10, y: 20, rotation: 45 },
|
|
46
|
+
pcbPosition: { x: 5, y: 5 },
|
|
47
|
+
});
|
|
48
|
+
return {};
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
const my = new MyComposable();
|
|
52
|
+
// Trigger lazy initialization
|
|
53
|
+
my.pins;
|
|
54
|
+
const sPos = my.comp.absoluteSchematicPosition;
|
|
55
|
+
(0, vitest_1.expect)(sPos.x).toBe(110);
|
|
56
|
+
(0, vitest_1.expect)(sPos.y).toBe(120);
|
|
57
|
+
(0, vitest_1.expect)(sPos.rotation).toBe(45);
|
|
58
|
+
const pPos = my.comp.absolutePcbPosition;
|
|
59
|
+
(0, vitest_1.expect)(pPos.x).toBe(205);
|
|
60
|
+
(0, vitest_1.expect)(pPos.y).toBe(205);
|
|
61
|
+
(0, vitest_1.expect)(pPos.side).toBe("back"); // Inherited from parent
|
|
62
|
+
});
|
|
63
|
+
(0, vitest_1.it)("handles nested Composables with recursive offsetting", () => {
|
|
64
|
+
class Inner extends synth_1.Composable {
|
|
65
|
+
constructor() {
|
|
66
|
+
super({
|
|
67
|
+
ref: "INNER",
|
|
68
|
+
schematicPosition: { x: 10, y: 10 },
|
|
69
|
+
pcbPosition: { x: 5, y: 5 },
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
defineInterface() {
|
|
73
|
+
this.comp = new synth_1.Component({
|
|
74
|
+
ref: "C1",
|
|
75
|
+
symbol: "Device:C",
|
|
76
|
+
footprint: "Capacitor_SMD:C_0603_1608Metric",
|
|
77
|
+
schematicPosition: { x: 1, y: 1 },
|
|
78
|
+
pcbPosition: { x: 2, y: 2 },
|
|
79
|
+
});
|
|
80
|
+
return {};
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
class Outer extends synth_1.Composable {
|
|
84
|
+
constructor() {
|
|
85
|
+
super({
|
|
86
|
+
ref: "OUTER",
|
|
87
|
+
schematicPosition: { x: 100, y: 100 },
|
|
88
|
+
pcbPosition: { x: 200, y: 200, side: "back" },
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
defineInterface() {
|
|
92
|
+
this.inner = new Inner();
|
|
93
|
+
// Trigger inner initialization
|
|
94
|
+
this.inner.pins;
|
|
95
|
+
return {};
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
const outer = new Outer();
|
|
99
|
+
outer.pins;
|
|
100
|
+
const sPos = outer.inner.comp.absoluteSchematicPosition;
|
|
101
|
+
(0, vitest_1.expect)(sPos.x).toBe(111); // 100 (outer) + 10 (inner) + 1 (comp)
|
|
102
|
+
(0, vitest_1.expect)(sPos.y).toBe(111);
|
|
103
|
+
const pPos = outer.inner.comp.absolutePcbPosition;
|
|
104
|
+
(0, vitest_1.expect)(pPos.x).toBe(207); // 200 + 5 + 2
|
|
105
|
+
(0, vitest_1.expect)(pPos.side).toBe("back"); // Inherited from outer
|
|
106
|
+
});
|
|
107
|
+
(0, vitest_1.it)("allows overriding inherited PCB side", () => {
|
|
108
|
+
class MyComposable extends synth_1.Composable {
|
|
109
|
+
constructor() {
|
|
110
|
+
super({
|
|
111
|
+
ref: "MY",
|
|
112
|
+
pcbPosition: { x: 0, y: 0, side: "back" },
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
defineInterface() {
|
|
116
|
+
this.comp = new synth_1.Component({
|
|
117
|
+
ref: "R1",
|
|
118
|
+
symbol: "Device:R",
|
|
119
|
+
footprint: "Resistor_SMD:R_0603_1608Metric",
|
|
120
|
+
pcbPosition: { x: 10, y: 10, side: "front" },
|
|
121
|
+
});
|
|
122
|
+
return {};
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const my = new MyComposable();
|
|
126
|
+
my.pins;
|
|
127
|
+
(0, vitest_1.expect)(my.comp.absolutePcbPosition.side).toBe("front");
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
//# sourceMappingURL=placement.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"placement.test.js","sourceRoot":"","sources":["../../../src/tests/placement.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const vitest_1 = require("vitest");
|
|
37
|
+
const fs = __importStar(require("fs"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
const synth_1 = require("../synth");
|
|
40
|
+
const synthesis_1 = require("../cli/synthesis");
|
|
41
|
+
const env_1 = require("../cli/env");
|
|
42
|
+
(0, vitest_1.describe)("Synthesis Integration", () => {
|
|
43
|
+
const TEST_DIR = path.join(__dirname, "temp_synthesis_test");
|
|
44
|
+
(0, vitest_1.beforeAll)(() => {
|
|
45
|
+
(0, env_1.ensurePythonEnv)();
|
|
46
|
+
if (!fs.existsSync(TEST_DIR)) {
|
|
47
|
+
fs.mkdirSync(TEST_DIR, { recursive: true });
|
|
48
|
+
}
|
|
49
|
+
}, 60000);
|
|
50
|
+
(0, vitest_1.afterAll)(() => {
|
|
51
|
+
if (fs.existsSync(TEST_DIR)) {
|
|
52
|
+
fs.rmSync(TEST_DIR, { recursive: true, force: true });
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
(0, vitest_1.it)("successfully generates KiCad files from a schematic", () => {
|
|
56
|
+
class SimpleTestBoard extends synth_1.Schematic {
|
|
57
|
+
constructor() {
|
|
58
|
+
super({ name: "IntegrationTestBoard" });
|
|
59
|
+
}
|
|
60
|
+
generate() {
|
|
61
|
+
const vcc = new synth_1.Net({ name: "VCC", class: "Power" });
|
|
62
|
+
const gnd = new synth_1.Net({ name: "GND", class: "Power" });
|
|
63
|
+
const r1 = new synth_1.Component({
|
|
64
|
+
symbol: "Device:R",
|
|
65
|
+
ref: "R1",
|
|
66
|
+
footprint: "Resistor_SMD:R_0603_1608Metric",
|
|
67
|
+
value: "10k",
|
|
68
|
+
});
|
|
69
|
+
r1.pins[1] = vcc;
|
|
70
|
+
r1.pins[2] = gnd;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
const board = new SimpleTestBoard();
|
|
74
|
+
const snapshot = board._generateWithCapture();
|
|
75
|
+
// Run synthesis
|
|
76
|
+
const result = (0, synthesis_1.runSynthesis)(snapshot, TEST_DIR);
|
|
77
|
+
if (!result.success) {
|
|
78
|
+
console.error("Synthesis output:", result.output);
|
|
79
|
+
}
|
|
80
|
+
(0, vitest_1.expect)(result.success).toBe(true);
|
|
81
|
+
// Verify KiCad files
|
|
82
|
+
// circuit-synth generates IntegrationTestBoard_circuit.kicad_sch or similar
|
|
83
|
+
const files = fs.readdirSync(TEST_DIR);
|
|
84
|
+
(0, vitest_1.expect)(files.some(f => f.endsWith(".kicad_sch"))).toBe(true);
|
|
85
|
+
(0, vitest_1.expect)(files.some(f => f.endsWith(".kicad_pro"))).toBe(true);
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
//# sourceMappingURL=synthesis.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"synthesis.test.js","sourceRoot":"","sources":["../../../src/tests/synthesis.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAAmE;AACnE,uCAAyB;AACzB,2CAA6B;AAC7B,oCAAqD;AAErD,gDAAgD;AAChD,oCAA6C;AAE7C,IAAA,iBAAQ,EAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;IAE7D,IAAA,kBAAS,EAAC,GAAG,EAAE;QACb,IAAA,qBAAe,GAAE,CAAC;QAClB,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC7B,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC,EAAE,KAAK,CAAC,CAAC;IAEV,IAAA,iBAAQ,EAAC,GAAG,EAAE;QACZ,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC5B,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACxD,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,eAAgB,SAAQ,iBAAS;YACrC;gBACE,KAAK,CAAC,EAAE,IAAI,EAAE,sBAAsB,EAAE,CAAC,CAAC;YAC1C,CAAC;YAED,QAAQ;gBACN,MAAM,GAAG,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;gBACrD,MAAM,GAAG,GAAG,IAAI,WAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;gBAErD,MAAM,EAAE,GAAG,IAAI,iBAAS,CAAC;oBACvB,MAAM,EAAE,UAAU;oBAClB,GAAG,EAAE,IAAI;oBACT,SAAS,EAAE,gCAAgC;oBAC3C,KAAK,EAAE,KAAK;iBACb,CAAC,CAAC;gBACH,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBACjB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YACnB,CAAC;SACF;QAED,MAAM,KAAK,GAAG,IAAI,eAAe,EAAE,CAAC;QACpC,MAAM,QAAQ,GAAG,KAAK,CAAC,oBAAoB,EAAE,CAAC;QAE9C,gBAAgB;QAChB,MAAM,MAAM,GAAG,IAAA,wBAAY,EAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEhD,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,OAAO,CAAC,KAAK,CAAC,mBAAmB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QACpD,CAAC;QAED,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAElC,qBAAqB;QACrB,4EAA4E;QAC5E,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAEvC,IAAA,eAAM,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7D,IAAA,eAAM,EAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|