@skillpet/circuit 0.5.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/README.md +131 -0
- package/dist/circuit.bundle.js +31103 -0
- package/dist/circuit.bundle.js.map +7 -0
- package/dist/circuit.bundle.min.js +273 -0
- package/dist/circuit.bundle.min.js.map +7 -0
- package/dist/circuit.esm.js +31069 -0
- package/dist/circuit.esm.js.map +7 -0
- package/dist/config.d.ts +26 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +23 -0
- package/dist/config.js.map +1 -0
- package/dist/container.d.ts +32 -0
- package/dist/container.d.ts.map +1 -0
- package/dist/container.js +101 -0
- package/dist/container.js.map +1 -0
- package/dist/drawing-gradient.d.ts +13 -0
- package/dist/drawing-gradient.d.ts.map +1 -0
- package/dist/drawing-gradient.js +39 -0
- package/dist/drawing-gradient.js.map +1 -0
- package/dist/drawing-stack.d.ts +16 -0
- package/dist/drawing-stack.d.ts.map +1 -0
- package/dist/drawing-stack.js +32 -0
- package/dist/drawing-stack.js.map +1 -0
- package/dist/drawing-transition.d.ts +34 -0
- package/dist/drawing-transition.d.ts.map +1 -0
- package/dist/drawing-transition.js +181 -0
- package/dist/drawing-transition.js.map +1 -0
- package/dist/drawing.d.ts +117 -0
- package/dist/drawing.d.ts.map +1 -0
- package/dist/drawing.js +337 -0
- package/dist/drawing.js.map +1 -0
- package/dist/element-label.d.ts +54 -0
- package/dist/element-label.d.ts.map +1 -0
- package/dist/element-label.js +377 -0
- package/dist/element-label.js.map +1 -0
- package/dist/element-style.d.ts +34 -0
- package/dist/element-style.d.ts.map +1 -0
- package/dist/element-style.js +51 -0
- package/dist/element-style.js.map +1 -0
- package/dist/element.d.ts +114 -0
- package/dist/element.d.ts.map +1 -0
- package/dist/element.js +514 -0
- package/dist/element.js.map +1 -0
- package/dist/element2term.d.ts +25 -0
- package/dist/element2term.d.ts.map +1 -0
- package/dist/element2term.js +245 -0
- package/dist/element2term.js.map +1 -0
- package/dist/elements/cables.d.ts +22 -0
- package/dist/elements/cables.d.ts.map +1 -0
- package/dist/elements/cables.js +100 -0
- package/dist/elements/cables.js.map +1 -0
- package/dist/elements/capacitor.d.ts +23 -0
- package/dist/elements/capacitor.d.ts.map +1 -0
- package/dist/elements/capacitor.js +93 -0
- package/dist/elements/capacitor.js.map +1 -0
- package/dist/elements/compound.d.ts +41 -0
- package/dist/elements/compound.d.ts.map +1 -0
- package/dist/elements/compound.js +266 -0
- package/dist/elements/compound.js.map +1 -0
- package/dist/elements/connectors.d.ts +81 -0
- package/dist/elements/connectors.d.ts.map +1 -0
- package/dist/elements/connectors.js +578 -0
- package/dist/elements/connectors.js.map +1 -0
- package/dist/elements/crystal.d.ts +8 -0
- package/dist/elements/crystal.d.ts.map +1 -0
- package/dist/elements/crystal.js +31 -0
- package/dist/elements/crystal.js.map +1 -0
- package/dist/elements/diode-more.d.ts +36 -0
- package/dist/elements/diode-more.d.ts.map +1 -0
- package/dist/elements/diode-more.js +233 -0
- package/dist/elements/diode-more.js.map +1 -0
- package/dist/elements/diode.d.ts +14 -0
- package/dist/elements/diode.d.ts.map +1 -0
- package/dist/elements/diode.js +58 -0
- package/dist/elements/diode.js.map +1 -0
- package/dist/elements/element-compound.d.ts +16 -0
- package/dist/elements/element-compound.d.ts.map +1 -0
- package/dist/elements/element-compound.js +68 -0
- package/dist/elements/element-compound.js.map +1 -0
- package/dist/elements/element-drawing.d.ts +10 -0
- package/dist/elements/element-drawing.d.ts.map +1 -0
- package/dist/elements/element-drawing.js +16 -0
- package/dist/elements/element-drawing.js.map +1 -0
- package/dist/elements/ground.d.ts +6 -0
- package/dist/elements/ground.d.ts.map +1 -0
- package/dist/elements/ground.js +30 -0
- package/dist/elements/ground.js.map +1 -0
- package/dist/elements/ic.d.ts +169 -0
- package/dist/elements/ic.d.ts.map +1 -0
- package/dist/elements/ic.js +816 -0
- package/dist/elements/ic.js.map +1 -0
- package/dist/elements/image.d.ts +9 -0
- package/dist/elements/image.d.ts.map +1 -0
- package/dist/elements/image.js +27 -0
- package/dist/elements/image.js.map +1 -0
- package/dist/elements/inductor.d.ts +15 -0
- package/dist/elements/inductor.d.ts.map +1 -0
- package/dist/elements/inductor.js +111 -0
- package/dist/elements/inductor.js.map +1 -0
- package/dist/elements/line.d.ts +8 -0
- package/dist/elements/line.d.ts.map +1 -0
- package/dist/elements/line.js +14 -0
- package/dist/elements/line.js.map +1 -0
- package/dist/elements/lines-arc-labels.d.ts +223 -0
- package/dist/elements/lines-arc-labels.d.ts.map +1 -0
- package/dist/elements/lines-arc-labels.js +822 -0
- package/dist/elements/lines-arc-labels.js.map +1 -0
- package/dist/elements/lines-elements.d.ts +89 -0
- package/dist/elements/lines-elements.d.ts.map +1 -0
- package/dist/elements/lines-elements.js +271 -0
- package/dist/elements/lines-elements.js.map +1 -0
- package/dist/elements/misc-elements.d.ts +25 -0
- package/dist/elements/misc-elements.d.ts.map +1 -0
- package/dist/elements/misc-elements.js +160 -0
- package/dist/elements/misc-elements.js.map +1 -0
- package/dist/elements/oneterm.d.ts +29 -0
- package/dist/elements/oneterm.d.ts.map +1 -0
- package/dist/elements/oneterm.js +163 -0
- package/dist/elements/oneterm.js.map +1 -0
- package/dist/elements/opamp.d.ts +11 -0
- package/dist/elements/opamp.d.ts.map +1 -0
- package/dist/elements/opamp.js +72 -0
- package/dist/elements/opamp.js.map +1 -0
- package/dist/elements/outlets.d.ts +39 -0
- package/dist/elements/outlets.d.ts.map +1 -0
- package/dist/elements/outlets.js +285 -0
- package/dist/elements/outlets.js.map +1 -0
- package/dist/elements/resistor-more.d.ts +42 -0
- package/dist/elements/resistor-more.d.ts.map +1 -0
- package/dist/elements/resistor-more.js +171 -0
- package/dist/elements/resistor-more.js.map +1 -0
- package/dist/elements/resistor.d.ts +6 -0
- package/dist/elements/resistor.d.ts.map +1 -0
- package/dist/elements/resistor.js +22 -0
- package/dist/elements/resistor.js.map +1 -0
- package/dist/elements/source-v.d.ts +3 -0
- package/dist/elements/source-v.d.ts.map +1 -0
- package/dist/elements/source-v.js +3 -0
- package/dist/elements/source-v.js.map +1 -0
- package/dist/elements/sources.d.ts +111 -0
- package/dist/elements/sources.d.ts.map +1 -0
- package/dist/elements/sources.js +519 -0
- package/dist/elements/sources.js.map +1 -0
- package/dist/elements/switches.d.ts +66 -0
- package/dist/elements/switches.d.ts.map +1 -0
- package/dist/elements/switches.js +328 -0
- package/dist/elements/switches.js.map +1 -0
- package/dist/elements/transformer.d.ts +17 -0
- package/dist/elements/transformer.d.ts.map +1 -0
- package/dist/elements/transformer.js +184 -0
- package/dist/elements/transformer.js.map +1 -0
- package/dist/elements/transistors.d.ts +197 -0
- package/dist/elements/transistors.d.ts.map +1 -0
- package/dist/elements/transistors.js +1009 -0
- package/dist/elements/transistors.js.map +1 -0
- package/dist/elements/tubes.d.ts +70 -0
- package/dist/elements/tubes.d.ts.map +1 -0
- package/dist/elements/tubes.js +386 -0
- package/dist/elements/tubes.js.map +1 -0
- package/dist/elements/twoports.d.ts +47 -0
- package/dist/elements/twoports.d.ts.map +1 -0
- package/dist/elements/twoports.js +231 -0
- package/dist/elements/twoports.js.map +1 -0
- package/dist/elements/twoterm-extras.d.ts +50 -0
- package/dist/elements/twoterm-extras.d.ts.map +1 -0
- package/dist/elements/twoterm-extras.js +243 -0
- package/dist/elements/twoterm-extras.js.map +1 -0
- package/dist/elements/twoterm.d.ts +4 -0
- package/dist/elements/twoterm.d.ts.map +1 -0
- package/dist/elements/twoterm.js +4 -0
- package/dist/elements/twoterm.js.map +1 -0
- package/dist/geometry/point.d.ts +28 -0
- package/dist/geometry/point.d.ts.map +1 -0
- package/dist/geometry/point.js +99 -0
- package/dist/geometry/point.js.map +1 -0
- package/dist/geometry/roundcorners.d.ts +7 -0
- package/dist/geometry/roundcorners.d.ts.map +1 -0
- package/dist/geometry/roundcorners.js +64 -0
- package/dist/geometry/roundcorners.js.map +1 -0
- package/dist/geometry/transform.d.ts +14 -0
- package/dist/geometry/transform.d.ts.map +1 -0
- package/dist/geometry/transform.js +33 -0
- package/dist/geometry/transform.js.map +1 -0
- package/dist/geometry/util.d.ts +12 -0
- package/dist/geometry/util.d.ts.map +1 -0
- package/dist/geometry/util.js +36 -0
- package/dist/geometry/util.js.map +1 -0
- package/dist/index.cjs +31456 -0
- package/dist/index.cjs.map +7 -0
- package/dist/index.d.ts +77 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +68 -0
- package/dist/index.js.map +1 -0
- package/dist/json/anchor-ref.d.ts +5 -0
- package/dist/json/anchor-ref.d.ts.map +1 -0
- package/dist/json/anchor-ref.js +35 -0
- package/dist/json/anchor-ref.js.map +1 -0
- package/dist/json/mount.d.ts +60 -0
- package/dist/json/mount.d.ts.map +1 -0
- package/dist/json/mount.js +369 -0
- package/dist/json/mount.js.map +1 -0
- package/dist/json/registry.d.ts +7 -0
- package/dist/json/registry.d.ts.map +1 -0
- package/dist/json/registry.js +323 -0
- package/dist/json/registry.js.map +1 -0
- package/dist/json/render.d.ts +59 -0
- package/dist/json/render.d.ts.map +1 -0
- package/dist/json/render.js +113 -0
- package/dist/json/render.js.map +1 -0
- package/dist/json/theme.d.ts +18 -0
- package/dist/json/theme.d.ts.map +1 -0
- package/dist/json/theme.js +57 -0
- package/dist/json/theme.js.map +1 -0
- package/dist/json/types.d.ts +42 -0
- package/dist/json/types.d.ts.map +1 -0
- package/dist/json/types.js +2 -0
- package/dist/json/types.js.map +1 -0
- package/dist/json/validate.d.ts +11 -0
- package/dist/json/validate.d.ts.map +1 -0
- package/dist/json/validate.js +77 -0
- package/dist/json/validate.js.map +1 -0
- package/dist/label-hint.d.ts +11 -0
- package/dist/label-hint.d.ts.map +1 -0
- package/dist/label-hint.js +2 -0
- package/dist/label-hint.js.map +1 -0
- package/dist/logic/and.d.ts +13 -0
- package/dist/logic/and.d.ts.map +1 -0
- package/dist/logic/and.js +63 -0
- package/dist/logic/and.js.map +1 -0
- package/dist/logic/bitfield.d.ts +32 -0
- package/dist/logic/bitfield.d.ts.map +1 -0
- package/dist/logic/bitfield.js +271 -0
- package/dist/logic/bitfield.js.map +1 -0
- package/dist/logic/buffer.d.ts +11 -0
- package/dist/logic/buffer.d.ts.map +1 -0
- package/dist/logic/buffer.js +46 -0
- package/dist/logic/buffer.js.map +1 -0
- package/dist/logic/extras.d.ts +36 -0
- package/dist/logic/extras.d.ts.map +1 -0
- package/dist/logic/extras.js +211 -0
- package/dist/logic/extras.js.map +1 -0
- package/dist/logic/kmap.d.ts +16 -0
- package/dist/logic/kmap.d.ts.map +1 -0
- package/dist/logic/kmap.js +163 -0
- package/dist/logic/kmap.js.map +1 -0
- package/dist/logic/or.d.ts +18 -0
- package/dist/logic/or.d.ts.map +1 -0
- package/dist/logic/or.js +117 -0
- package/dist/logic/or.js.map +1 -0
- package/dist/logic/timing.d.ts +44 -0
- package/dist/logic/timing.d.ts.map +1 -0
- package/dist/logic/timing.js +791 -0
- package/dist/logic/timing.js.map +1 -0
- package/dist/logic/tristate.d.ts +11 -0
- package/dist/logic/tristate.d.ts.map +1 -0
- package/dist/logic/tristate.js +48 -0
- package/dist/logic/tristate.js.map +1 -0
- package/dist/math-render.d.ts +9 -0
- package/dist/math-render.d.ts.map +1 -0
- package/dist/math-render.js +53 -0
- package/dist/math-render.js.map +1 -0
- package/dist/package-api.d.ts +20 -0
- package/dist/package-api.d.ts.map +1 -0
- package/dist/package-api.js +75 -0
- package/dist/package-api.js.map +1 -0
- package/dist/params.d.ts +6 -0
- package/dist/params.d.ts.map +1 -0
- package/dist/params.js +35 -0
- package/dist/params.js.map +1 -0
- package/dist/react/index.d.ts +22 -0
- package/dist/react/index.d.ts.map +1 -0
- package/dist/react/index.js +52 -0
- package/dist/react/index.js.map +1 -0
- package/dist/schemdraw-ts.bundle.js +30448 -0
- package/dist/schemdraw-ts.bundle.js.map +7 -0
- package/dist/segment.d.ts +267 -0
- package/dist/segment.d.ts.map +1 -0
- package/dist/segment.js +844 -0
- package/dist/segment.js.map +1 -0
- package/dist/style.d.ts +18 -0
- package/dist/style.d.ts.map +1 -0
- package/dist/style.js +230 -0
- package/dist/style.js.map +1 -0
- package/dist/subsystems/dsp.d.ts +65 -0
- package/dist/subsystems/dsp.d.ts.map +1 -0
- package/dist/subsystems/dsp.js +267 -0
- package/dist/subsystems/dsp.js.map +1 -0
- package/dist/subsystems/flow.d.ts +92 -0
- package/dist/subsystems/flow.d.ts.map +1 -0
- package/dist/subsystems/flow.js +315 -0
- package/dist/subsystems/flow.js.map +1 -0
- package/dist/subsystems/index.d.ts +22 -0
- package/dist/subsystems/index.d.ts.map +1 -0
- package/dist/subsystems/index.js +22 -0
- package/dist/subsystems/index.js.map +1 -0
- package/dist/subsystems/parsing.d.ts +41 -0
- package/dist/subsystems/parsing.d.ts.map +1 -0
- package/dist/subsystems/parsing.js +456 -0
- package/dist/subsystems/parsing.js.map +1 -0
- package/dist/subsystems/pictorial.d.ts +73 -0
- package/dist/subsystems/pictorial.d.ts.map +1 -0
- package/dist/subsystems/pictorial.js +469 -0
- package/dist/subsystems/pictorial.js.map +1 -0
- package/dist/svg/constants.d.ts +5 -0
- package/dist/svg/constants.d.ts.map +1 -0
- package/dist/svg/constants.js +5 -0
- package/dist/svg/constants.js.map +1 -0
- package/dist/svg/figure.d.ts +157 -0
- package/dist/svg/figure.d.ts.map +1 -0
- package/dist/svg/figure.js +634 -0
- package/dist/svg/figure.js.map +1 -0
- package/dist/svg/fmt.d.ts +2 -0
- package/dist/svg/fmt.d.ts.map +1 -0
- package/dist/svg/fmt.js +7 -0
- package/dist/svg/fmt.js.map +1 -0
- package/dist/svg/svg-style.d.ts +15 -0
- package/dist/svg/svg-style.d.ts.map +1 -0
- package/dist/svg/svg-style.js +46 -0
- package/dist/svg/svg-style.js.map +1 -0
- package/dist/types.d.ts +39 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +21 -0
- package/dist/types.js.map +1 -0
- package/dist/version.d.ts +3 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +3 -0
- package/dist/version.js.map +1 -0
- package/dist/vue/index.d.ts +43 -0
- package/dist/vue/index.d.ts.map +1 -0
- package/dist/vue/index.js +55 -0
- package/dist/vue/index.js.map +1 -0
- package/package.json +71 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
export type XY = readonly [number, number] | Point;
|
|
2
|
+
export declare class Point {
|
|
3
|
+
readonly x: number;
|
|
4
|
+
readonly y: number;
|
|
5
|
+
constructor(x: number, y: number);
|
|
6
|
+
static fromXY(xy: readonly [number, number]): Point;
|
|
7
|
+
add(other: XY): Point;
|
|
8
|
+
sub(other: XY): Point;
|
|
9
|
+
/** Scalar − this (Python `__rsub__` for scalar). */
|
|
10
|
+
subFromScalar(s: number): Point;
|
|
11
|
+
mul(other: Point | number): Point;
|
|
12
|
+
div(other: Point | number): Point;
|
|
13
|
+
neg(): Point;
|
|
14
|
+
rotate(angle: number, center?: XY): Point;
|
|
15
|
+
mirrorx(centerx?: number): Point;
|
|
16
|
+
flip(): Point;
|
|
17
|
+
toTuple(): [number, number];
|
|
18
|
+
}
|
|
19
|
+
export declare function point(x: number, y: number): Point;
|
|
20
|
+
/** Python `util.rotate(xy, angle, center)`. */
|
|
21
|
+
export declare function rotate(xy: XY, angle: number, center?: XY): Point;
|
|
22
|
+
export declare function mirrorx(xy: XY, centerx?: number): Point;
|
|
23
|
+
export declare function flip(xy: XY): Point;
|
|
24
|
+
export declare function delta(a: XY, b: XY): Point;
|
|
25
|
+
export declare function angle(a: XY, b: XY): number;
|
|
26
|
+
export declare function dist(a: XY, b: XY): number;
|
|
27
|
+
export { linspace } from "./util.js";
|
|
28
|
+
//# sourceMappingURL=point.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"point.d.ts","sourceRoot":"","sources":["../../src/geometry/point.ts"],"names":[],"mappings":"AAYA,MAAM,MAAM,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC;AAMnD,qBAAa,KAAK;IAChB,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC;gBAEP,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM;IAKhC,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,KAAK;IAInD,GAAG,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK;IAKrB,GAAG,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK;IAKrB,oDAAoD;IACpD,aAAa,CAAC,CAAC,EAAE,MAAM,GAAG,KAAK;IAI/B,GAAG,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK;IAOjC,GAAG,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK;IAOjC,GAAG,IAAI,KAAK;IAIZ,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,GAAE,EAAW,GAAG,KAAK;IAMjD,OAAO,CAAC,OAAO,GAAE,MAAU,GAAG,KAAK;IAKnC,IAAI,IAAI,KAAK;IAKb,OAAO,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;CAG5B;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,KAAK,CAEjD;AAED,+CAA+C;AAC/C,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,GAAE,EAAW,GAAG,KAAK,CAKxE;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,GAAE,MAAU,GAAG,KAAK,CAI1D;AAED,wBAAgB,IAAI,CAAC,EAAE,EAAE,EAAE,GAAG,KAAK,CAIlC;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,GAAG,KAAK,CAKzC;AAED,wBAAgB,KAAK,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,GAAG,MAAM,CAI1C;AAED,wBAAgB,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,GAAG,MAAM,CAIzC;AAED,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Point in drawing coordinates — aligned with Python `schemdraw/util.py` · `Point`.
|
|
3
|
+
*/
|
|
4
|
+
import { angleXY, deltaXY, distXY, flipXY, mirrorxXY, rotateXY, } from "./util.js";
|
|
5
|
+
function coords(p) {
|
|
6
|
+
return p instanceof Point ? p : { x: p[0], y: p[1] };
|
|
7
|
+
}
|
|
8
|
+
export class Point {
|
|
9
|
+
x;
|
|
10
|
+
y;
|
|
11
|
+
constructor(x, y) {
|
|
12
|
+
this.x = x;
|
|
13
|
+
this.y = y;
|
|
14
|
+
}
|
|
15
|
+
static fromXY(xy) {
|
|
16
|
+
return new Point(xy[0], xy[1]);
|
|
17
|
+
}
|
|
18
|
+
add(other) {
|
|
19
|
+
const o = coords(other);
|
|
20
|
+
return new Point(this.x + o.x, this.y + o.y);
|
|
21
|
+
}
|
|
22
|
+
sub(other) {
|
|
23
|
+
const o = coords(other);
|
|
24
|
+
return new Point(this.x - o.x, this.y - o.y);
|
|
25
|
+
}
|
|
26
|
+
/** Scalar − this (Python `__rsub__` for scalar). */
|
|
27
|
+
subFromScalar(s) {
|
|
28
|
+
return new Point(s - this.x, s - this.y);
|
|
29
|
+
}
|
|
30
|
+
mul(other) {
|
|
31
|
+
if (typeof other === "number") {
|
|
32
|
+
return new Point(this.x * other, this.y * other);
|
|
33
|
+
}
|
|
34
|
+
return new Point(this.x * other.x, this.y * other.y);
|
|
35
|
+
}
|
|
36
|
+
div(other) {
|
|
37
|
+
if (typeof other === "number") {
|
|
38
|
+
return new Point(this.x / other, this.y / other);
|
|
39
|
+
}
|
|
40
|
+
return new Point(this.x / other.x, this.y / other.y);
|
|
41
|
+
}
|
|
42
|
+
neg() {
|
|
43
|
+
return new Point(-this.x, -this.y);
|
|
44
|
+
}
|
|
45
|
+
rotate(angle, center = [0, 0]) {
|
|
46
|
+
const c = coords(center);
|
|
47
|
+
const [nx, ny] = rotateXY(this.x, this.y, angle, c.x, c.y);
|
|
48
|
+
return new Point(nx, ny);
|
|
49
|
+
}
|
|
50
|
+
mirrorx(centerx = 0) {
|
|
51
|
+
const [nx, ny] = mirrorxXY(this.x, this.y, centerx);
|
|
52
|
+
return new Point(nx, ny);
|
|
53
|
+
}
|
|
54
|
+
flip() {
|
|
55
|
+
const [nx, ny] = flipXY(this.x, this.y);
|
|
56
|
+
return new Point(nx, ny);
|
|
57
|
+
}
|
|
58
|
+
toTuple() {
|
|
59
|
+
return [this.x, this.y];
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
export function point(x, y) {
|
|
63
|
+
return new Point(x, y);
|
|
64
|
+
}
|
|
65
|
+
/** Python `util.rotate(xy, angle, center)`. */
|
|
66
|
+
export function rotate(xy, angle, center = [0, 0]) {
|
|
67
|
+
const p = coords(xy);
|
|
68
|
+
const c = coords(center);
|
|
69
|
+
const [nx, ny] = rotateXY(p.x, p.y, angle, c.x, c.y);
|
|
70
|
+
return new Point(nx, ny);
|
|
71
|
+
}
|
|
72
|
+
export function mirrorx(xy, centerx = 0) {
|
|
73
|
+
const p = coords(xy);
|
|
74
|
+
const [nx, ny] = mirrorxXY(p.x, p.y, centerx);
|
|
75
|
+
return new Point(nx, ny);
|
|
76
|
+
}
|
|
77
|
+
export function flip(xy) {
|
|
78
|
+
const p = coords(xy);
|
|
79
|
+
const [nx, ny] = flipXY(p.x, p.y);
|
|
80
|
+
return new Point(nx, ny);
|
|
81
|
+
}
|
|
82
|
+
export function delta(a, b) {
|
|
83
|
+
const pa = coords(a);
|
|
84
|
+
const pb = coords(b);
|
|
85
|
+
const [dx, dy] = deltaXY(pa.x, pa.y, pb.x, pb.y);
|
|
86
|
+
return new Point(dx, dy);
|
|
87
|
+
}
|
|
88
|
+
export function angle(a, b) {
|
|
89
|
+
const pa = coords(a);
|
|
90
|
+
const pb = coords(b);
|
|
91
|
+
return angleXY(pa.x, pa.y, pb.x, pb.y);
|
|
92
|
+
}
|
|
93
|
+
export function dist(a, b) {
|
|
94
|
+
const pa = coords(a);
|
|
95
|
+
const pb = coords(b);
|
|
96
|
+
return distXY(pa.x, pa.y, pb.x, pb.y);
|
|
97
|
+
}
|
|
98
|
+
export { linspace } from "./util.js";
|
|
99
|
+
//# sourceMappingURL=point.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"point.js","sourceRoot":"","sources":["../../src/geometry/point.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rounded polygon corners — ported from Python `segments.roundcorners`.
|
|
3
|
+
*/
|
|
4
|
+
import { Point, type XY } from "./point.js";
|
|
5
|
+
/** Convex polygon corner rounding (subset; matches Python for typical boxes). */
|
|
6
|
+
export declare function roundCorners(verts: XY[], radius: number): Point[];
|
|
7
|
+
//# sourceMappingURL=roundcorners.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"roundcorners.d.ts","sourceRoot":"","sources":["../../src/geometry/roundcorners.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,MAAM,YAAY,CAAC;AAO5C,iFAAiF;AACjF,wBAAgB,YAAY,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,GAAG,KAAK,EAAE,CAsEjE"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rounded polygon corners — ported from Python `segments.roundcorners`.
|
|
3
|
+
*/
|
|
4
|
+
import { Point } from "./point.js";
|
|
5
|
+
import { linspace } from "./util.js";
|
|
6
|
+
function coords(p) {
|
|
7
|
+
return p instanceof Point ? p : { x: p[0], y: p[1] };
|
|
8
|
+
}
|
|
9
|
+
/** Convex polygon corner rounding (subset; matches Python for typical boxes). */
|
|
10
|
+
export function roundCorners(verts, radius) {
|
|
11
|
+
const n = verts.length;
|
|
12
|
+
if (n < 3 || radius <= 0) {
|
|
13
|
+
return verts.map((v) => {
|
|
14
|
+
const c = coords(v);
|
|
15
|
+
return new Point(c.x, c.y);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
const poly = [];
|
|
19
|
+
for (let v = n - 1; v >= 0; v--) {
|
|
20
|
+
const p1 = coords(verts[v]);
|
|
21
|
+
const p2 = coords(verts[(v - 1 + n) % n]);
|
|
22
|
+
const p3 = coords(verts[(v - 2 + n) % n]);
|
|
23
|
+
const dx1 = p2.x - p1.x;
|
|
24
|
+
const dy1 = p2.y - p1.y;
|
|
25
|
+
const dx2 = p2.x - p3.x;
|
|
26
|
+
const dy2 = p2.y - p3.y;
|
|
27
|
+
const angle = (Math.atan2(dy1, dx1) - Math.atan2(dy2, dx2)) / 2;
|
|
28
|
+
const tan = Math.abs(Math.tan(angle));
|
|
29
|
+
let segment = radius / tan;
|
|
30
|
+
const getlength = (x, y) => Math.hypot(x, y);
|
|
31
|
+
const getproportionpoint = (point, seg, length, dx, dy) => {
|
|
32
|
+
const factor = seg / length;
|
|
33
|
+
return [point.x - dx * factor, point.y - dy * factor];
|
|
34
|
+
};
|
|
35
|
+
const length1 = getlength(dx1, dy1);
|
|
36
|
+
const length2 = getlength(dx2, dy2);
|
|
37
|
+
let length = Math.min(length1, length2);
|
|
38
|
+
if (segment > length) {
|
|
39
|
+
segment = length;
|
|
40
|
+
radius = length * tan;
|
|
41
|
+
}
|
|
42
|
+
const p1cross = getproportionpoint(p2, segment, length1, dx1, dy1);
|
|
43
|
+
const p2cross = getproportionpoint(p2, segment, length2, dx2, dy2);
|
|
44
|
+
const dx = p2.x * 2 - p1cross[0] - p2cross[0];
|
|
45
|
+
const dy = p2.y * 2 - p1cross[1] - p2cross[1];
|
|
46
|
+
const L = getlength(dx, dy);
|
|
47
|
+
const d = getlength(segment, radius);
|
|
48
|
+
const circlepoint = getproportionpoint(p2, d, L, dx, dy);
|
|
49
|
+
let startangle = Math.atan2(p1cross[1] - circlepoint[1], p1cross[0] - circlepoint[0]);
|
|
50
|
+
let endangle = Math.atan2(p2cross[1] - circlepoint[1], p2cross[0] - circlepoint[0]);
|
|
51
|
+
while (endangle < startangle) {
|
|
52
|
+
endangle += 2 * Math.PI;
|
|
53
|
+
}
|
|
54
|
+
const ph = linspace(startangle, endangle, 100);
|
|
55
|
+
for (const i of ph) {
|
|
56
|
+
poly.push(new Point(circlepoint[0] + Math.cos(i) * radius, circlepoint[1] + Math.sin(i) * radius));
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (poly.length > 0) {
|
|
60
|
+
poly.push(poly[0]);
|
|
61
|
+
}
|
|
62
|
+
return poly;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=roundcorners.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"roundcorners.js","sourceRoot":"","sources":["../../src/geometry/roundcorners.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Affine transform — aligned with Python `schemdraw/transform.py`.
|
|
3
|
+
*/
|
|
4
|
+
import { Point, type XY } from "./point.js";
|
|
5
|
+
export declare class Transform {
|
|
6
|
+
readonly theta: number;
|
|
7
|
+
readonly shift: Point;
|
|
8
|
+
readonly localshift: Point;
|
|
9
|
+
readonly zoom: Point;
|
|
10
|
+
constructor(theta: number, globalshift: XY, localshift?: XY, zoom?: XY | number);
|
|
11
|
+
transform(pt: XY): Point;
|
|
12
|
+
transformArray(pts: readonly XY[]): Point[];
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=transform.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../../src/geometry/transform.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,MAAM,YAAY,CAAC;AAa5C,qBAAa,SAAS;IACpB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC;IACtB,QAAQ,CAAC,UAAU,EAAE,KAAK,CAAC;IAC3B,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC;gBAGnB,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,EAAE,EACf,UAAU,GAAE,EAAW,EACvB,IAAI,GAAE,EAAE,GAAG,MAAe;IAQ5B,SAAS,CAAC,EAAE,EAAE,EAAE,GAAG,KAAK;IAKxB,cAAc,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,GAAG,KAAK,EAAE;CAG5C"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Affine transform — aligned with Python `schemdraw/transform.py`.
|
|
3
|
+
*/
|
|
4
|
+
import { Point } from "./point.js";
|
|
5
|
+
function asPoint(xy) {
|
|
6
|
+
return xy instanceof Point ? xy : Point.fromXY([xy[0], xy[1]]);
|
|
7
|
+
}
|
|
8
|
+
function asZoom(zoom) {
|
|
9
|
+
if (typeof zoom === "number") {
|
|
10
|
+
return new Point(zoom, zoom);
|
|
11
|
+
}
|
|
12
|
+
return asPoint(zoom);
|
|
13
|
+
}
|
|
14
|
+
export class Transform {
|
|
15
|
+
theta;
|
|
16
|
+
shift;
|
|
17
|
+
localshift;
|
|
18
|
+
zoom;
|
|
19
|
+
constructor(theta, globalshift, localshift = [0, 0], zoom = [1, 1]) {
|
|
20
|
+
this.theta = theta;
|
|
21
|
+
this.shift = asPoint(globalshift);
|
|
22
|
+
this.localshift = asPoint(localshift);
|
|
23
|
+
this.zoom = asZoom(zoom);
|
|
24
|
+
}
|
|
25
|
+
transform(pt) {
|
|
26
|
+
const p = asPoint(pt);
|
|
27
|
+
return p.add(this.localshift).mul(this.zoom).rotate(this.theta).add(this.shift);
|
|
28
|
+
}
|
|
29
|
+
transformArray(pts) {
|
|
30
|
+
return pts.map((p) => this.transform(p));
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=transform.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transform.js","sourceRoot":"","sources":["../../src/geometry/transform.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,KAAK,EAAW,MAAM,YAAY,CAAC;AAE5C,SAAS,OAAO,CAAC,EAAM;IACrB,OAAO,EAAE,YAAY,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACjE,CAAC;AAED,SAAS,MAAM,CAAC,IAAiB;IAC/B,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;QAC7B,OAAO,IAAI,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC/B,CAAC;IACD,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC;AACvB,CAAC;AAED,MAAM,OAAO,SAAS;IACX,KAAK,CAAS;IACd,KAAK,CAAQ;IACb,UAAU,CAAQ;IAClB,IAAI,CAAQ;IAErB,YACE,KAAa,EACb,WAAe,EACf,aAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,EACvB,OAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;QAE1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;QAClC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;QACtC,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,SAAS,CAAC,EAAM;QACd,MAAM,CAAC,GAAG,OAAO,CAAC,EAAE,CAAC,CAAC;QACtB,OAAO,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClF,CAAC;IAED,cAAc,CAAC,GAAkB;QAC/B,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Numeric geometry — aligned with Python `schemdraw/util.py` (no `Point` import; avoids circular deps).
|
|
3
|
+
*/
|
|
4
|
+
export declare function linspace(start: number, stop: number, num?: number): number[];
|
|
5
|
+
/** Rotate `(x,y)` by `angleDeg` CCW about `(cx,cy)`. */
|
|
6
|
+
export declare function rotateXY(x: number, y: number, angleDeg: number, cx: number, cy: number): [number, number];
|
|
7
|
+
export declare function mirrorxXY(x: number, y: number, centerx: number): [number, number];
|
|
8
|
+
export declare function flipXY(x: number, y: number): [number, number];
|
|
9
|
+
export declare function deltaXY(ax: number, ay: number, bx: number, by: number): [number, number];
|
|
10
|
+
export declare function angleXY(ax: number, ay: number, bx: number, by: number): number;
|
|
11
|
+
export declare function distXY(ax: number, ay: number, bx: number, by: number): number;
|
|
12
|
+
//# sourceMappingURL=util.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../src/geometry/util.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,GAAE,MAAW,GAAG,MAAM,EAAE,CAMhF;AAED,wDAAwD;AACxD,wBAAgB,QAAQ,CACtB,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,MAAM,EACV,EAAE,EAAE,MAAM,GACT,CAAC,MAAM,EAAE,MAAM,CAAC,CAQlB;AAED,wBAAgB,SAAS,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAEjF;AAED,wBAAgB,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAE7D;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAExF;AAED,wBAAgB,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAE9E;AAED,wBAAgB,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,MAAM,CAE7E"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Numeric geometry — aligned with Python `schemdraw/util.py` (no `Point` import; avoids circular deps).
|
|
3
|
+
*/
|
|
4
|
+
export function linspace(start, stop, num = 50) {
|
|
5
|
+
if (num < 2) {
|
|
6
|
+
return [start];
|
|
7
|
+
}
|
|
8
|
+
const step = (stop - start) / (num - 1);
|
|
9
|
+
return Array.from({ length: num }, (_, i) => start + step * i);
|
|
10
|
+
}
|
|
11
|
+
/** Rotate `(x,y)` by `angleDeg` CCW about `(cx,cy)`. */
|
|
12
|
+
export function rotateXY(x, y, angleDeg, cx, cy) {
|
|
13
|
+
const co = Math.cos((angleDeg * Math.PI) / 180);
|
|
14
|
+
const so = Math.sin((angleDeg * Math.PI) / 180);
|
|
15
|
+
const bx = x - cx;
|
|
16
|
+
const by = y - cy;
|
|
17
|
+
const rx = bx * co - by * so;
|
|
18
|
+
const ry = bx * so + by * co;
|
|
19
|
+
return [rx + cx, ry + cy];
|
|
20
|
+
}
|
|
21
|
+
export function mirrorxXY(x, y, centerx) {
|
|
22
|
+
return [-(x - centerx) + centerx, y];
|
|
23
|
+
}
|
|
24
|
+
export function flipXY(x, y) {
|
|
25
|
+
return [x, -y];
|
|
26
|
+
}
|
|
27
|
+
export function deltaXY(ax, ay, bx, by) {
|
|
28
|
+
return [bx - ax, by - ay];
|
|
29
|
+
}
|
|
30
|
+
export function angleXY(ax, ay, bx, by) {
|
|
31
|
+
return (Math.atan2(by - ay, bx - ax) * 180) / Math.PI;
|
|
32
|
+
}
|
|
33
|
+
export function distXY(ax, ay, bx, by) {
|
|
34
|
+
return Math.hypot(bx - ax, by - ay);
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/geometry/util.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,UAAU,QAAQ,CAAC,KAAa,EAAE,IAAY,EAAE,MAAc,EAAE;IACpE,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;QACZ,OAAO,CAAC,KAAK,CAAC,CAAC;IACjB,CAAC;IACD,MAAM,IAAI,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;IACxC,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC;AACjE,CAAC;AAED,wDAAwD;AACxD,MAAM,UAAU,QAAQ,CACtB,CAAS,EACT,CAAS,EACT,QAAgB,EAChB,EAAU,EACV,EAAU;IAEV,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC;IAChD,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC;IAChD,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;IAClB,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC;IAClB,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;IAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;IAC7B,OAAO,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,CAAS,EAAE,CAAS,EAAE,OAAe;IAC7D,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,GAAG,OAAO,EAAE,CAAC,CAAC,CAAC;AACvC,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,CAAS,EAAE,CAAS;IACzC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU;IACpE,OAAO,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU;IACpE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU;IACnE,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;AACtC,CAAC"}
|