@modular-circuit/transpiler 0.0.76 → 0.0.77
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/build/builder/graph_to_kicad/do_convert_graph_to_kicad_project.js +19 -108
- package/build/builder/graph_to_kicad/index.js +4 -59
- package/build/converter/graph_to_netlist/graph_converter.js +51 -171
- package/build/converter/kicad_sexpr/eeschema/drawing_sheet/sch_default_drawing_sheet.js +1 -1
- package/build/converter/kicad_sexpr/eeschema/printer.js +245 -290
- package/build/converter/link_to_netlist/converter.js +77 -135
- package/build/converter/link_to_netlist/links/converter_base.js +38 -131
- package/build/converter/link_to_netlist/links/converters.js +316 -554
- package/build/converter/netlist_to_kicad/calc_boxes_pos.d.ts +1 -1
- package/build/converter/netlist_to_kicad/calc_boxes_pos.d.ts.map +1 -1
- package/build/converter/netlist_to_kicad/calc_boxes_pos.js +36 -101
- package/build/converter/netlist_to_kicad/layout.js +28 -32
- package/build/converter/netlist_to_kicad/netlist_converter.d.ts +1 -1
- package/build/converter/netlist_to_kicad/netlist_converter.d.ts.map +1 -1
- package/build/converter/netlist_to_kicad/netlist_converter.js +128 -300
- package/build/kicad/constraints/index.js +1 -1
- package/build/kicad/label/net_label.js +2 -2
- package/build/kicad/label/sheet_pin.js +11 -19
- package/build/kicad/project/kicad_prl.js +3 -3
- package/build/kicad/project/kicad_pro.js +4 -4
- package/build/kicad/project/kicad_project_achieve.js +31 -45
- package/build/kicad/project/wildcards_and_files_ext.js +61 -61
- package/build/kicad/sheet/sheet.js +3 -3
- package/build/kicad/symbols/lib_symbol/gnd.js +6 -6
- package/build/kicad/symbols/lib_symbol/vcc.js +7 -7
- package/build/kicad/symbols/sch_symbol/gnd.js +9 -9
- package/build/kicad/symbols/sch_symbol/vcc.js +9 -9
- package/build/kicad/symbols/symbol_utils.js +1 -1
- package/build/kicad/wire/gen_wire.js +4 -4
- package/build/utils/collect_sub_sheets.js +37 -151
- package/build/utils/constraints.js +6 -6
- package/build/utils/filter_null_undefined.js +2 -31
- package/build/utils/string_formatter.js +23 -29
- package/package.json +5 -5
|
@@ -1,115 +1,26 @@
|
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
|
2
|
-
__assign = Object.assign || function(t) {
|
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
-
s = arguments[i];
|
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
-
t[p] = s[p];
|
|
7
|
-
}
|
|
8
|
-
return t;
|
|
9
|
-
};
|
|
10
|
-
return __assign.apply(this, arguments);
|
|
11
|
-
};
|
|
12
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
13
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
14
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
15
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
16
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
17
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
18
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
19
|
-
});
|
|
20
|
-
};
|
|
21
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
23
|
-
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
-
function step(op) {
|
|
26
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
28
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
-
switch (op[0]) {
|
|
31
|
-
case 0: case 1: t = op; break;
|
|
32
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
-
default:
|
|
36
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
-
if (t[2]) _.ops.pop();
|
|
41
|
-
_.trys.pop(); continue;
|
|
42
|
-
}
|
|
43
|
-
op = body.call(thisArg, _);
|
|
44
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
var __values = (this && this.__values) || function(o) {
|
|
49
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
50
|
-
if (m) return m.call(o);
|
|
51
|
-
if (o && typeof o.length === "number") return {
|
|
52
|
-
next: function () {
|
|
53
|
-
if (o && i >= o.length) o = void 0;
|
|
54
|
-
return { value: o && o[i++], done: !o };
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
58
|
-
};
|
|
59
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
60
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
61
|
-
if (!m) return o;
|
|
62
|
-
var i = m.call(o), r, ar = [], e;
|
|
63
|
-
try {
|
|
64
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
65
|
-
}
|
|
66
|
-
catch (error) { e = { error: error }; }
|
|
67
|
-
finally {
|
|
68
|
-
try {
|
|
69
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
70
|
-
}
|
|
71
|
-
finally { if (e) throw e.error; }
|
|
72
|
-
}
|
|
73
|
-
return ar;
|
|
74
|
-
};
|
|
75
1
|
import { MODULAR_CIRCUIT_SCH_EXT } from '@modular-circuit/ir';
|
|
76
2
|
import { GraphConverter, SCHEMATIC_PRINTER, } from '../../converter';
|
|
77
3
|
import { NetListConverter } from '../../converter/netlist_to_kicad';
|
|
78
4
|
import { KiCadProjectAchieve, KiCadSchematicFileExtension } from '../../kicad/project';
|
|
79
5
|
import { collect_sub_sheets } from '../../utils/collect_sub_sheets';
|
|
80
|
-
export function do_convert_graph_to_kicad_project(ctx) {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
console.error("Duplicated sheet file name found ".concat(k));
|
|
99
|
-
}
|
|
100
|
-
sheets[k.replace(MODULAR_CIRCUIT_SCH_EXT, KiCadSchematicFileExtension)] = sexpr_printer.schematic(v);
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
104
|
-
finally {
|
|
105
|
-
try {
|
|
106
|
-
if (_b && !_b.done && (_d = _a.return)) _d.call(_a);
|
|
107
|
-
}
|
|
108
|
-
finally { if (e_1) throw e_1.error; }
|
|
109
|
-
}
|
|
110
|
-
kicad_project = new KiCadProjectAchieve(ctx.project.name, __assign({}, sheets));
|
|
111
|
-
return [2 /*return*/, kicad_project.toZip()];
|
|
112
|
-
}
|
|
113
|
-
});
|
|
6
|
+
export async function do_convert_graph_to_kicad_project(ctx) {
|
|
7
|
+
const { sheets } = await collect_sub_sheets(ctx.project.dependencies, ctx.module_resolver);
|
|
8
|
+
const netlist = new GraphConverter({
|
|
9
|
+
...ctx,
|
|
10
|
+
}).convert_to_netlist();
|
|
11
|
+
const converted_sheets = new NetListConverter({
|
|
12
|
+
...ctx,
|
|
13
|
+
netlist,
|
|
14
|
+
}).convert_to_kicad();
|
|
15
|
+
const sexpr_printer = new SCHEMATIC_PRINTER();
|
|
16
|
+
for (const [k, v] of Object.entries(converted_sheets)) {
|
|
17
|
+
if (k in sheets) {
|
|
18
|
+
console.error(`Duplicated sheet file name found ${k}`);
|
|
19
|
+
}
|
|
20
|
+
sheets[k.replace(MODULAR_CIRCUIT_SCH_EXT, KiCadSchematicFileExtension)] = sexpr_printer.schematic(v);
|
|
21
|
+
}
|
|
22
|
+
const kicad_project = new KiCadProjectAchieve(ctx.project.name, {
|
|
23
|
+
...sheets,
|
|
114
24
|
});
|
|
25
|
+
return kicad_project.toZip();
|
|
115
26
|
}
|
|
@@ -1,63 +1,8 @@
|
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
|
2
|
-
__assign = Object.assign || function(t) {
|
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
-
s = arguments[i];
|
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
-
t[p] = s[p];
|
|
7
|
-
}
|
|
8
|
-
return t;
|
|
9
|
-
};
|
|
10
|
-
return __assign.apply(this, arguments);
|
|
11
|
-
};
|
|
12
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
13
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
14
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
15
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
16
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
17
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
18
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
19
|
-
});
|
|
20
|
-
};
|
|
21
|
-
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
-
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
|
|
23
|
-
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
-
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
-
function step(op) {
|
|
26
|
-
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
-
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
28
|
-
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
-
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
-
switch (op[0]) {
|
|
31
|
-
case 0: case 1: t = op; break;
|
|
32
|
-
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
-
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
-
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
-
default:
|
|
36
|
-
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
-
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
-
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
-
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
-
if (t[2]) _.ops.pop();
|
|
41
|
-
_.trys.pop(); continue;
|
|
42
|
-
}
|
|
43
|
-
op = body.call(thisArg, _);
|
|
44
|
-
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
-
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
1
|
import { build_connection_graph } from '@modular-circuit/perc';
|
|
49
2
|
import { do_convert_graph_to_kicad_project } from './do_convert_graph_to_kicad_project';
|
|
50
|
-
export function convert_graph_to_kicad_project(ctx) {
|
|
51
|
-
return
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
switch (_c.label) {
|
|
55
|
-
case 0:
|
|
56
|
-
_a = do_convert_graph_to_kicad_project;
|
|
57
|
-
_b = [__assign({}, ctx)];
|
|
58
|
-
return [4 /*yield*/, build_connection_graph(__assign(__assign({}, ctx), { dependencies: ctx.project.dependencies }))];
|
|
59
|
-
case 1: return [2 /*return*/, _a.apply(void 0, [__assign.apply(void 0, _b.concat([(_c.sent())]))])];
|
|
60
|
-
}
|
|
61
|
-
});
|
|
3
|
+
export async function convert_graph_to_kicad_project(ctx) {
|
|
4
|
+
return do_convert_graph_to_kicad_project({
|
|
5
|
+
...ctx,
|
|
6
|
+
...(await build_connection_graph({ ...ctx, dependencies: ctx.project.dependencies })),
|
|
62
7
|
});
|
|
63
8
|
}
|
|
@@ -1,192 +1,72 @@
|
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
|
2
|
-
__assign = Object.assign || function(t) {
|
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
-
s = arguments[i];
|
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
-
t[p] = s[p];
|
|
7
|
-
}
|
|
8
|
-
return t;
|
|
9
|
-
};
|
|
10
|
-
return __assign.apply(this, arguments);
|
|
11
|
-
};
|
|
12
|
-
var __values = (this && this.__values) || function(o) {
|
|
13
|
-
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
|
|
14
|
-
if (m) return m.call(o);
|
|
15
|
-
if (o && typeof o.length === "number") return {
|
|
16
|
-
next: function () {
|
|
17
|
-
if (o && i >= o.length) o = void 0;
|
|
18
|
-
return { value: o && o[i++], done: !o };
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
|
|
22
|
-
};
|
|
23
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
24
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
25
|
-
if (!m) return o;
|
|
26
|
-
var i = m.call(o), r, ar = [], e;
|
|
27
|
-
try {
|
|
28
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
29
|
-
}
|
|
30
|
-
catch (error) { e = { error: error }; }
|
|
31
|
-
finally {
|
|
32
|
-
try {
|
|
33
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
34
|
-
}
|
|
35
|
-
finally { if (e) throw e.error; }
|
|
36
|
-
}
|
|
37
|
-
return ar;
|
|
38
|
-
};
|
|
39
1
|
import { ConnectionNodeType, } from '@modular-circuit/electronics-model';
|
|
40
2
|
import { LINK_CONVERTER } from '../link_to_netlist';
|
|
41
|
-
|
|
42
|
-
|
|
3
|
+
export class GraphConverter {
|
|
4
|
+
ctx;
|
|
5
|
+
constructor(ctx) {
|
|
43
6
|
this.ctx = ctx;
|
|
44
7
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
var nl_netlist = {
|
|
8
|
+
convert_to_netlist() {
|
|
9
|
+
let pin_count = 0;
|
|
10
|
+
const nl_netlist = {
|
|
49
11
|
nets: [],
|
|
50
12
|
schematics: {},
|
|
51
13
|
};
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
for (
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
for (var _o = (e_3 = void 0, __values(Object.entries(node.label_shapes))), _p = _o.next(); !_p.done; _p = _o.next()) {
|
|
66
|
-
var _q = __read(_p.value, 2), label_name = _q[0], shape = _q[1];
|
|
67
|
-
var pin_id = "pin-".concat(++pin_count);
|
|
68
|
-
pin_shapes[pin_id] = shape;
|
|
69
|
-
if (!(port_id in pin_map)) {
|
|
70
|
-
pin_map[port_id] = {};
|
|
71
|
-
}
|
|
72
|
-
pin_map[port_id][label_name] = pin_id;
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
76
|
-
finally {
|
|
77
|
-
try {
|
|
78
|
-
if (_p && !_p.done && (_c = _o.return)) _c.call(_o);
|
|
79
|
-
}
|
|
80
|
-
finally { if (e_3) throw e_3.error; }
|
|
81
|
-
}
|
|
14
|
+
const pin_map = {};
|
|
15
|
+
const port_map = new Map();
|
|
16
|
+
const pin_shapes = {};
|
|
17
|
+
for (const sub of this.ctx.connection_graph.subgraphs) {
|
|
18
|
+
for (const node of sub.nodes) {
|
|
19
|
+
if (node.type === ConnectionNodeType.Port) {
|
|
20
|
+
const port_id = node.uuid;
|
|
21
|
+
port_map.set(node.param, port_id);
|
|
22
|
+
for (const [label_name, shape] of Object.entries(node.label_shapes)) {
|
|
23
|
+
const pin_id = `pin-${++pin_count}`;
|
|
24
|
+
pin_shapes[pin_id] = shape;
|
|
25
|
+
if (!(port_id in pin_map)) {
|
|
26
|
+
pin_map[port_id] = {};
|
|
82
27
|
}
|
|
28
|
+
pin_map[port_id][label_name] = pin_id;
|
|
83
29
|
}
|
|
84
30
|
}
|
|
85
|
-
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
86
|
-
finally {
|
|
87
|
-
try {
|
|
88
|
-
if (_m && !_m.done && (_b = _l.return)) _b.call(_l);
|
|
89
|
-
}
|
|
90
|
-
finally { if (e_2) throw e_2.error; }
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
95
|
-
finally {
|
|
96
|
-
try {
|
|
97
|
-
if (_k && !_k.done && (_a = _j.return)) _a.call(_j);
|
|
98
31
|
}
|
|
99
|
-
finally { if (e_1) throw e_1.error; }
|
|
100
32
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
try {
|
|
111
|
-
for (var _u = (e_6 = void 0, __values(sheet.ports)), _v = _u.next(); !_v.done; _v = _u.next()) {
|
|
112
|
-
var port_id = _v.value;
|
|
113
|
-
if (!(port_id in pin_map)) {
|
|
114
|
-
console.error("Port ".concat(port_id, " not found in pin_map"));
|
|
115
|
-
continue;
|
|
116
|
-
}
|
|
117
|
-
try {
|
|
118
|
-
for (var _w = (e_7 = void 0, __values(Object.entries(pin_map[port_id]))), _x = _w.next(); !_x.done; _x = _w.next()) {
|
|
119
|
-
var _y = __read(_x.value, 2), label_name = _y[0], pin_id = _y[1];
|
|
120
|
-
pins.push({
|
|
121
|
-
uuid: pin_id,
|
|
122
|
-
name: label_name,
|
|
123
|
-
shape: pin_shapes[pin_id],
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
catch (e_7_1) { e_7 = { error: e_7_1 }; }
|
|
128
|
-
finally {
|
|
129
|
-
try {
|
|
130
|
-
if (_x && !_x.done && (_g = _w.return)) _g.call(_w);
|
|
131
|
-
}
|
|
132
|
-
finally { if (e_7) throw e_7.error; }
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
catch (e_6_1) { e_6 = { error: e_6_1 }; }
|
|
137
|
-
finally {
|
|
138
|
-
try {
|
|
139
|
-
if (_v && !_v.done && (_f = _u.return)) _f.call(_u);
|
|
140
|
-
}
|
|
141
|
-
finally { if (e_6) throw e_6.error; }
|
|
142
|
-
}
|
|
143
|
-
sheet_symbols.push(__assign(__assign({}, sheet), { pins: pins }));
|
|
33
|
+
for (const [filename, sch] of Object.entries(this.ctx.cg_schematics)) {
|
|
34
|
+
const { uuid, powers, sheets } = sch;
|
|
35
|
+
const sheet_symbols = [];
|
|
36
|
+
for (const sheet of sheets) {
|
|
37
|
+
const pins = [];
|
|
38
|
+
for (const port_id of sheet.ports) {
|
|
39
|
+
if (!(port_id in pin_map)) {
|
|
40
|
+
console.error(`Port ${port_id} not found in pin_map`);
|
|
41
|
+
continue;
|
|
144
42
|
}
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
43
|
+
for (const [label_name, pin_id] of Object.entries(pin_map[port_id])) {
|
|
44
|
+
pins.push({
|
|
45
|
+
uuid: pin_id,
|
|
46
|
+
name: label_name,
|
|
47
|
+
shape: pin_shapes[pin_id],
|
|
48
|
+
});
|
|
150
49
|
}
|
|
151
|
-
finally { if (e_5) throw e_5.error; }
|
|
152
50
|
}
|
|
153
|
-
|
|
154
|
-
uuid: uuid,
|
|
155
|
-
filename: filename,
|
|
156
|
-
powers: powers,
|
|
157
|
-
sheet_symbols: sheet_symbols,
|
|
158
|
-
hiera_labels: [],
|
|
159
|
-
};
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
|
163
|
-
finally {
|
|
164
|
-
try {
|
|
165
|
-
if (_s && !_s.done && (_d = _r.return)) _d.call(_r);
|
|
51
|
+
sheet_symbols.push({ ...sheet, pins });
|
|
166
52
|
}
|
|
167
|
-
|
|
53
|
+
nl_netlist.schematics[filename] = {
|
|
54
|
+
uuid,
|
|
55
|
+
filename,
|
|
56
|
+
powers,
|
|
57
|
+
sheet_symbols,
|
|
58
|
+
hiera_labels: [],
|
|
59
|
+
};
|
|
168
60
|
}
|
|
169
|
-
|
|
170
|
-
pin_map
|
|
171
|
-
nl_netlist
|
|
172
|
-
port_map
|
|
61
|
+
const link_converter = new LINK_CONVERTER({
|
|
62
|
+
pin_map,
|
|
63
|
+
nl_netlist,
|
|
64
|
+
port_map,
|
|
173
65
|
net_names_count: new Map(),
|
|
174
66
|
});
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
var sub = _0.value;
|
|
178
|
-
link_converter.visit_cc(sub);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
catch (e_8_1) { e_8 = { error: e_8_1 }; }
|
|
182
|
-
finally {
|
|
183
|
-
try {
|
|
184
|
-
if (_0 && !_0.done && (_h = _z.return)) _h.call(_z);
|
|
185
|
-
}
|
|
186
|
-
finally { if (e_8) throw e_8.error; }
|
|
67
|
+
for (const sub of this.ctx.connection_graph.subgraphs) {
|
|
68
|
+
link_converter.visit_cc(sub);
|
|
187
69
|
}
|
|
188
70
|
return nl_netlist;
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
}());
|
|
192
|
-
export { GraphConverter };
|
|
71
|
+
}
|
|
72
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export var BASE_64_ENCODED_SCH_DEFAULT_DRAWING_SHEET = '(kicad_wks
	(version 20231118)
	(generator "pl_editor")
	(generator_version "8.0")
	(setup
		(textsize 1.5 1.5)
		(linewidth 0.15)
		(textlinewidth 0.15)
		(left_margin 10)
		(right_margin 10)
		(top_margin 10)
		(bottom_margin 10)
	)
	(rect
		(name "")
		(start 135.669 34.2722)
		(end 2 2.0002)
		(comment "rect around the title block")
	)
	(rect
		(name "")
		(start 0 0 ltcorner)
		(end 0 0)
		(repeat 2)
		(incrx 2)
		(incry 2)
	)
	(line
		(name "")
		(start 50 2 ltcorner)
		(end 50 0 ltcorner)
		(repeat 30)
		(incrx 50)
	)
	(tbtext "1"
		(name "")
		(pos 25 1 ltcorner)
		(font
			(size 1.3 1.3)
		)
		(repeat 100)
		(incrx 50)
	)
	(line
		(name "")
		(start 50 2 lbcorner)
		(end 50 0 lbcorner)
		(repeat 30)
		(incrx 50)
	)
	(tbtext "1"
		(name "")
		(pos 25 1 lbcorner)
		(font
			(size 1.3 1.3)
		)
		(repeat 100)
		(incrx 50)
	)
	(line
		(name "")
		(start 0 50 ltcorner)
		(end 2 50 ltcorner)
		(repeat 30)
		(incry 50)
	)
	(tbtext "A"
		(name "")
		(pos 1 25 ltcorner)
		(font
			(size 1.3 1.3)
		)
		(justify center)
		(repeat 100)
		(incry 50)
	)
	(line
		(name "")
		(start 0 50 rtcorner)
		(end 2 50 rtcorner)
		(repeat 30)
		(incry 50)
	)
	(tbtext "A"
		(name "")
		(pos 1 25 rtcorner)
		(font
			(size 1.3 1.3)
		)
		(justify center)
		(repeat 100)
		(incry 50)
	)
	(line
		(name "")
		(start 135.669 29.192)
		(end 49.309 29.192)
	)
	(line
		(name "")
		(start 135.669 24.112)
		(end 49.309 24.112)
	)
	(line
		(name "")
		(start 135.669 19.032)
		(end 2 19.032)
	)
	(line
		(name "")
		(start 49.309 34.2722)
		(end 49.309 19.0322)
	)
	(tbtext "Document Name:"
		(name "")
		(pos 134.399 31.7322)
		(font
			(face "Arial") bold)
	)
	(tbtext "${TITLE}"
		(name "")
		(pos 116.699 31.7322)
		(font
			(face "Arial")
		)
	)
	(tbtext "Project Name:"
		(name "")
		(pos 134.399 26.6522)
		(font
			(face "Arial") bold)
	)
	(tbtext "${COMMENT3}"
		(name "")
		(pos 119.699 26.6522)
		(font
			(face "Arial")
		)
	)
	(tbtext "Sheet Name:"
		(name "")
		(pos 134.399 21.5722)
		(font
			(face "Arial") bold)
	)
	(tbtext "${FILENAME}"
		(name "")
		(pos 121.099 21.5722)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 135.669 13.952)
		(end 2 13.952)
	)
	(tbtext "Author:"
		(name "")
		(pos 134.399 16.4922)
		(font
			(face "Arial") bold)
	)
	(tbtext "${COMMENT2}"
		(name "")
		(pos 126.199 16.4922)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 135.669 8.872)
		(end 2 8.872)
	)
	(tbtext "Date:"
		(name "")
		(pos 48.039 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${ISSUE_DATE}"
		(name "")
		(pos 42.139 11.4122)
		(font
			(face "Arial")
		)
	)
	(tbtext "Sheet Number:"
		(name "")
		(pos 134.399 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${#} of ${##}"
		(name "")
		(pos 118.699 11.4122)
		(font
			(face "Arial")
		)
	)
	(tbtext "Revision:"
		(name "")
		(pos 87.409 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${REVISION}"
		(name "")
		(pos 77.209 11.4122)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 49.309 13.9522)
		(end 49.309 8.8722)
	)
	(line
		(name "")
		(start 88.679 13.9522)
		(end 88.679 8.8722)
	)
	(tbtext "Modular Circuit Design Studio designs are machine-generated drafts and require verification by qualified specialists. \nBy using these designs, you agree to the eda.cn Terms of Use: ${COMMENT1}"
		(name "")
		(pos 134.399 6.332)
		(font
			(face "Arial")
		)
	)
	(bitmap
		(name "")
		(pos 25.408 26.906)
		(scale 0.7580645161)
		(data "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"
		)
	)
)
';
|
|
1
|
+
export const BASE_64_ENCODED_SCH_DEFAULT_DRAWING_SHEET = '(kicad_wks
	(version 20231118)
	(generator "pl_editor")
	(generator_version "8.0")
	(setup
		(textsize 1.5 1.5)
		(linewidth 0.15)
		(textlinewidth 0.15)
		(left_margin 10)
		(right_margin 10)
		(top_margin 10)
		(bottom_margin 10)
	)
	(rect
		(name "")
		(start 135.669 34.2722)
		(end 2 2.0002)
		(comment "rect around the title block")
	)
	(rect
		(name "")
		(start 0 0 ltcorner)
		(end 0 0)
		(repeat 2)
		(incrx 2)
		(incry 2)
	)
	(line
		(name "")
		(start 50 2 ltcorner)
		(end 50 0 ltcorner)
		(repeat 30)
		(incrx 50)
	)
	(tbtext "1"
		(name "")
		(pos 25 1 ltcorner)
		(font
			(size 1.3 1.3)
		)
		(repeat 100)
		(incrx 50)
	)
	(line
		(name "")
		(start 50 2 lbcorner)
		(end 50 0 lbcorner)
		(repeat 30)
		(incrx 50)
	)
	(tbtext "1"
		(name "")
		(pos 25 1 lbcorner)
		(font
			(size 1.3 1.3)
		)
		(repeat 100)
		(incrx 50)
	)
	(line
		(name "")
		(start 0 50 ltcorner)
		(end 2 50 ltcorner)
		(repeat 30)
		(incry 50)
	)
	(tbtext "A"
		(name "")
		(pos 1 25 ltcorner)
		(font
			(size 1.3 1.3)
		)
		(justify center)
		(repeat 100)
		(incry 50)
	)
	(line
		(name "")
		(start 0 50 rtcorner)
		(end 2 50 rtcorner)
		(repeat 30)
		(incry 50)
	)
	(tbtext "A"
		(name "")
		(pos 1 25 rtcorner)
		(font
			(size 1.3 1.3)
		)
		(justify center)
		(repeat 100)
		(incry 50)
	)
	(line
		(name "")
		(start 135.669 29.192)
		(end 49.309 29.192)
	)
	(line
		(name "")
		(start 135.669 24.112)
		(end 49.309 24.112)
	)
	(line
		(name "")
		(start 135.669 19.032)
		(end 2 19.032)
	)
	(line
		(name "")
		(start 49.309 34.2722)
		(end 49.309 19.0322)
	)
	(tbtext "Document Name:"
		(name "")
		(pos 134.399 31.7322)
		(font
			(face "Arial") bold)
	)
	(tbtext "${TITLE}"
		(name "")
		(pos 116.699 31.7322)
		(font
			(face "Arial")
		)
	)
	(tbtext "Project Name:"
		(name "")
		(pos 134.399 26.6522)
		(font
			(face "Arial") bold)
	)
	(tbtext "${COMMENT3}"
		(name "")
		(pos 119.699 26.6522)
		(font
			(face "Arial")
		)
	)
	(tbtext "Sheet Name:"
		(name "")
		(pos 134.399 21.5722)
		(font
			(face "Arial") bold)
	)
	(tbtext "${FILENAME}"
		(name "")
		(pos 121.099 21.5722)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 135.669 13.952)
		(end 2 13.952)
	)
	(tbtext "Author:"
		(name "")
		(pos 134.399 16.4922)
		(font
			(face "Arial") bold)
	)
	(tbtext "${COMMENT2}"
		(name "")
		(pos 126.199 16.4922)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 135.669 8.872)
		(end 2 8.872)
	)
	(tbtext "Date:"
		(name "")
		(pos 48.039 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${ISSUE_DATE}"
		(name "")
		(pos 42.139 11.4122)
		(font
			(face "Arial")
		)
	)
	(tbtext "Sheet Number:"
		(name "")
		(pos 134.399 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${#} of ${##}"
		(name "")
		(pos 118.699 11.4122)
		(font
			(face "Arial")
		)
	)
	(tbtext "Revision:"
		(name "")
		(pos 87.409 11.4122)
		(font
			(face "Arial") bold)
	)
	(tbtext "${REVISION}"
		(name "")
		(pos 77.209 11.4122)
		(font
			(face "Arial")
		)
	)
	(line
		(name "")
		(start 49.309 13.9522)
		(end 49.309 8.8722)
	)
	(line
		(name "")
		(start 88.679 13.9522)
		(end 88.679 8.8722)
	)
	(tbtext "Modular Circuit Design Studio designs are machine-generated drafts and require verification by qualified specialists. \nBy using these designs, you agree to the eda.cn Terms of Use: ${COMMENT1}"
		(name "")
		(pos 134.399 6.332)
		(font
			(face "Arial")
		)
	)
	(bitmap
		(name "")
		(pos 25.408 26.906)
		(scale 0.7580645161)
		(data "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"
		)
	)
)
';
|