brepjs 15.2.10 → 15.2.12
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/dist/2d.cjs +5 -5
- package/dist/2d.js +5 -5
- package/dist/{blueprint-BqdFeOSN.js → blueprint-BD4KS3uK.js} +5 -5
- package/dist/{blueprint-BkKnM_9w.cjs → blueprint-DRMsvuIW.cjs} +5 -5
- package/dist/{blueprintFns-BRQael6Q.js → blueprintFns-DSSOMAIL.js} +2 -2
- package/dist/{blueprintFns-CH4QAYB4.cjs → blueprintFns-ixcedxQd.cjs} +2 -2
- package/dist/{boolean2D-CwaWKfZD.cjs → boolean2D-BwCW-B30.cjs} +7 -7
- package/dist/{boolean2D-B__OaRTl.js → boolean2D-CWNL216K.js} +7 -7
- package/dist/{booleanFns-Cstp5Ep1.js → booleanFns-B4ZGNOr3.js} +4 -4
- package/dist/{booleanFns-CwHfuxWc.cjs → booleanFns-tCaPENXq.cjs} +4 -4
- package/dist/brepjs.cjs +25 -24
- package/dist/brepjs.js +25 -24
- package/dist/core.cjs +1 -1
- package/dist/core.js +1 -1
- package/dist/{cornerFinder-K7cjTnkP.js → cornerFinder-C1eCd2NO.js} +1 -1
- package/dist/{cornerFinder-DLxiZcyg.cjs → cornerFinder-C606yOAm.cjs} +1 -1
- package/dist/{curveFns-D-0yqVb9.js → curveFns-Cuiu9Khj.js} +1 -1
- package/dist/{curveFns-CQIv_biC.cjs → curveFns-eR4vAVyT.cjs} +1 -1
- package/dist/{drawFns-CgBKN8VG.cjs → drawFns-C4URqqIr.cjs} +11 -11
- package/dist/{drawFns-CMemZ1i4.js → drawFns-Di19TRz_.js} +10 -10
- package/dist/{extrudeFns-CcYOPTFR.js → extrudeFns-B-GeC5JR.js} +21 -14
- package/dist/{extrudeFns-BofhQx0R.cjs → extrudeFns-TGgECRPk.cjs} +21 -14
- package/dist/{faceFns-BQ7czFFV.js → faceFns-Ce2sfezK.js} +1 -1
- package/dist/{faceFns-uX_AVFqu.cjs → faceFns-DP61KiyY.cjs} +1 -1
- package/dist/{helpers-C4r8ovx9.js → helpers-BO5KthLn.js} +5 -5
- package/dist/{helpers-CM63Nn7A.cjs → helpers-Do57l7FZ.cjs} +5 -5
- package/dist/{historyFns-BFuHqN_0.js → historyFns-_ZRHu7mY.js} +4 -4
- package/dist/{historyFns-DkDJpwef.cjs → historyFns-xcghTeWT.cjs} +4 -4
- package/dist/{importFns--VkKJoDs.js → importFns-BJ5uUwpa.js} +2 -2
- package/dist/{importFns--rg42dnv.cjs → importFns-lv_acM3B.cjs} +2 -2
- package/dist/io.cjs +2 -2
- package/dist/io.js +2 -2
- package/dist/kernel/occtWasm/occtWasmAdapter.cjs +1 -1
- package/dist/kernel/occtWasm/occtWasmAdapter.js +1 -1
- package/dist/{measureFns-BxAZf4Mf.cjs → measureFns-Af--KnjE.cjs} +2 -2
- package/dist/{measureFns-D5DbMnQY.js → measureFns-Beh8ggjV.js} +2 -2
- package/dist/measurement.cjs +1 -1
- package/dist/measurement.js +1 -1
- package/dist/{meshFns-BdEOTCwK.cjs → meshFns-D_-6BkQl.cjs} +2 -2
- package/dist/{meshFns-C9DtKU7q.js → meshFns-fHojyH-k.js} +2 -2
- package/dist/{occtWasmAdapter-BRiWV_v0.js → occtWasmAdapter-DLWC3oxC.js} +2 -2
- package/dist/{occtWasmAdapter-CPINzXxh.cjs → occtWasmAdapter-DzzTUzYP.cjs} +2 -2
- package/dist/operations/compoundOpsFns.d.ts.map +1 -1
- package/dist/operations/extrudeFns.d.ts.map +1 -1
- package/dist/operations.cjs +2 -2
- package/dist/operations.js +2 -2
- package/dist/{primitiveFns-D3FvKWK-.cjs → primitiveFns-CYZuu9Il.cjs} +5 -5
- package/dist/{primitiveFns-Bpq2yFqw.js → primitiveFns-DmvY2gVS.js} +5 -5
- package/dist/query.cjs +2 -2
- package/dist/query.js +2 -2
- package/dist/{shapeFns-LgyEtLGl.js → shapeFns-BYOfyHoL.js} +2 -2
- package/dist/{shapeFns-Dz2GNg2y.cjs → shapeFns-wvNG7pAU.cjs} +2 -2
- package/dist/shapeRef.cjs +1 -1
- package/dist/shapeRef.js +1 -1
- package/dist/{shapeRefFns-N0wl6XSn.cjs → shapeRefFns-BSqCvOMZ.cjs} +3 -3
- package/dist/{shapeRefFns-CgnpumqW.js → shapeRefFns-Cd-zuZ_d.js} +3 -3
- package/dist/{shapeTypes-hQK4eaEw.cjs → shapeTypes-0QO9ycMV.cjs} +3 -4
- package/dist/{shapeTypes-B9a2ed1X.js → shapeTypes-Tu03ijIx.js} +3 -4
- package/dist/sketching.cjs +2 -2
- package/dist/sketching.js +2 -2
- package/dist/{solidBuilders-DUl2f7gY.cjs → solidBuilders-BJ5gVhvm.cjs} +2 -2
- package/dist/{solidBuilders-C_-imolZ.js → solidBuilders-CPWknuQG.js} +2 -2
- package/dist/{surfaceBuilders-BY117AaY.js → surfaceBuilders-BDMHU4Ng.js} +2 -2
- package/dist/{surfaceBuilders-D_w11wLr.cjs → surfaceBuilders-Do5jrIrG.cjs} +2 -2
- package/dist/topology.cjs +6 -6
- package/dist/topology.js +6 -6
- package/package.json +14 -14
package/dist/2d.cjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
2
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
3
3
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
4
|
-
const require_faceFns = require("./faceFns-
|
|
5
|
-
const require_boolean2D = require("./boolean2D-
|
|
6
|
-
const require_blueprint = require("./blueprint-
|
|
7
|
-
const require_blueprintFns = require("./blueprintFns-
|
|
4
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
5
|
+
const require_boolean2D = require("./boolean2D-BwCW-B30.cjs");
|
|
6
|
+
const require_blueprint = require("./blueprint-DRMsvuIW.cjs");
|
|
7
|
+
const require_blueprintFns = require("./blueprintFns-ixcedxQd.cjs");
|
|
8
8
|
//#region src/core/curve2dHandle.ts
|
|
9
9
|
/**
|
|
10
10
|
* Wrap a raw kernel 2D curve handle with brand + disposal tracking.
|
package/dist/2d.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { B as createKernelHandle, Z as getKernel2D, a as createEdge } from "./shapeTypes-
|
|
1
|
+
import { B as createKernelHandle, Z as getKernel2D, a as createEdge } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, b as err, d as validationError, t as BrepErrorCode } from "./errors-DboJwVCf.js";
|
|
3
|
-
import { z as kernelCallRaw } from "./faceFns-
|
|
4
|
-
import { _ as Blueprints, a as fuseBlueprints, c as roundedRectangleBlueprint, g as CompoundBlueprint, h as organiseBlueprints, i as cutBlueprints, n as fuse2D, o as intersectBlueprints, r as intersect2D, s as polysidesBlueprint, t as cut2D } from "./boolean2D-
|
|
5
|
-
import { _ as Curve2D, t as Blueprint, y as BoundingBox2d } from "./blueprint-
|
|
6
|
-
import { S as reverseCurve, _ as curve2dIsOnCurve, a as isInside2D, b as curve2dSplitAt, c as scale2D, d as stretch2D, f as toSVGPathD, g as curve2dFirstPoint, h as curve2dDistanceFrom, i as getOrientation2D, l as sketchOnFace2D, m as curve2dBoundingBox, o as mirror2D, p as translate2D, r as getBounds2D, s as rotate2D, t as createBlueprint, u as sketchOnPlane2D, v as curve2dLastPoint, x as curve2dTangentAt, y as curve2dParameter } from "./blueprintFns-
|
|
3
|
+
import { z as kernelCallRaw } from "./faceFns-Ce2sfezK.js";
|
|
4
|
+
import { _ as Blueprints, a as fuseBlueprints, c as roundedRectangleBlueprint, g as CompoundBlueprint, h as organiseBlueprints, i as cutBlueprints, n as fuse2D, o as intersectBlueprints, r as intersect2D, s as polysidesBlueprint, t as cut2D } from "./boolean2D-CWNL216K.js";
|
|
5
|
+
import { _ as Curve2D, t as Blueprint, y as BoundingBox2d } from "./blueprint-BD4KS3uK.js";
|
|
6
|
+
import { S as reverseCurve, _ as curve2dIsOnCurve, a as isInside2D, b as curve2dSplitAt, c as scale2D, d as stretch2D, f as toSVGPathD, g as curve2dFirstPoint, h as curve2dDistanceFrom, i as getOrientation2D, l as sketchOnFace2D, m as curve2dBoundingBox, o as mirror2D, p as translate2D, r as getBounds2D, s as rotate2D, t as createBlueprint, u as sketchOnPlane2D, v as curve2dLastPoint, x as curve2dTangentAt, y as curve2dParameter } from "./blueprintFns-DSSOMAIL.js";
|
|
7
7
|
//#region src/core/curve2dHandle.ts
|
|
8
8
|
/**
|
|
9
9
|
* Wrap a raw kernel 2D curve handle with brand + disposal tracking.
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { G as unregisterFromCleanup, U as registerForCleanup, X as getKernel, Z as getKernel2D, a as createEdge, u as createWire } from "./shapeTypes-
|
|
1
|
+
import { G as unregisterFromCleanup, U as registerForCleanup, X as getKernel, Z as getKernel2D, a as createEdge, u as createWire } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, R as unwrap, b as err, d as validationError, h as bug, n as computationError } from "./errors-DboJwVCf.js";
|
|
3
|
-
import { M as cast, m as uvCoordinates, n as faceCenter, p as uvBounds, r as faceGeomType } from "./faceFns-
|
|
3
|
+
import { M as cast, m as uvCoordinates, n as faceCenter, p as uvBounds, r as faceGeomType } from "./faceFns-Ce2sfezK.js";
|
|
4
4
|
import { r as RAD2DEG, t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
5
5
|
import { r as toVec3 } from "./types--GD-LVc6.js";
|
|
6
6
|
import { r as makePlane } from "./planeOps-sTrM3dcQ.js";
|
|
7
|
-
import { f as getOrientation } from "./curveFns-
|
|
7
|
+
import { f as getOrientation } from "./curveFns-Cuiu9Khj.js";
|
|
8
8
|
import { n as getAtOrThrow, r as lastOrThrow, t as firstOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
9
|
-
import { r as makeFace } from "./surfaceBuilders-
|
|
10
|
-
import { _ as samePoint, b as subtract2d, l as add2d, o as normalize2d, p as distance2d, t as getSingleFace, v as scalarMultiply2d } from "./helpers-
|
|
9
|
+
import { r as makeFace } from "./surfaceBuilders-BDMHU4Ng.js";
|
|
10
|
+
import { _ as samePoint, b as subtract2d, l as add2d, o as normalize2d, p as distance2d, t as getSingleFace, v as scalarMultiply2d } from "./helpers-BO5KthLn.js";
|
|
11
11
|
//#region src/2d/lib/definitions.ts
|
|
12
12
|
/** Type guard that checks whether a value is a `Point2D`. */
|
|
13
13
|
function isPoint2D(point) {
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
1
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
2
2
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
3
|
-
const require_faceFns = require("./faceFns-
|
|
3
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
4
4
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
5
5
|
const require_types = require("./types-gLi9wL0N.cjs");
|
|
6
6
|
const require_planeOps = require("./planeOps-BJOIbn4K.cjs");
|
|
7
|
-
const require_curveFns = require("./curveFns-
|
|
7
|
+
const require_curveFns = require("./curveFns-eR4vAVyT.cjs");
|
|
8
8
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
9
|
-
const require_surfaceBuilders = require("./surfaceBuilders-
|
|
10
|
-
const require_helpers = require("./helpers-
|
|
9
|
+
const require_surfaceBuilders = require("./surfaceBuilders-Do5jrIrG.cjs");
|
|
10
|
+
const require_helpers = require("./helpers-Do57l7FZ.cjs");
|
|
11
11
|
//#region src/2d/lib/definitions.ts
|
|
12
12
|
/** Type guard that checks whether a value is a `Point2D`. */
|
|
13
13
|
function isPoint2D(point) {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { A as ok, b as err, d as validationError, t as BrepErrorCode } from "./errors-DboJwVCf.js";
|
|
2
|
-
import { g as CompoundBlueprint } from "./boolean2D-
|
|
3
|
-
import { t as Blueprint } from "./blueprint-
|
|
2
|
+
import { g as CompoundBlueprint } from "./boolean2D-CWNL216K.js";
|
|
3
|
+
import { t as Blueprint } from "./blueprint-BD4KS3uK.js";
|
|
4
4
|
//#region src/2d/lib/curve2dFns.ts
|
|
5
5
|
/**
|
|
6
6
|
* Return a reversed copy of the curve (non-mutating).
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
2
|
-
const require_boolean2D = require("./boolean2D-
|
|
3
|
-
const require_blueprint = require("./blueprint-
|
|
2
|
+
const require_boolean2D = require("./boolean2D-BwCW-B30.cjs");
|
|
3
|
+
const require_blueprint = require("./blueprint-DRMsvuIW.cjs");
|
|
4
4
|
//#region src/2d/lib/curve2dFns.ts
|
|
5
5
|
/**
|
|
6
6
|
* Return a reversed copy of the curve (non-mutating).
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
1
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
2
2
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
3
|
-
const require_faceFns = require("./faceFns-
|
|
3
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
4
4
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
5
5
|
const require_types = require("./types-gLi9wL0N.cjs");
|
|
6
6
|
const require_vecOps = require("./vecOps-CODplJp3.cjs");
|
|
7
7
|
const require_planeOps = require("./planeOps-BJOIbn4K.cjs");
|
|
8
|
-
const require_curveFns = require("./curveFns-
|
|
8
|
+
const require_curveFns = require("./curveFns-eR4vAVyT.cjs");
|
|
9
9
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
10
|
-
const require_surfaceBuilders = require("./surfaceBuilders-
|
|
11
|
-
const require_helpers = require("./helpers-
|
|
12
|
-
const require_blueprint = require("./blueprint-
|
|
13
|
-
const require_extrudeFns = require("./extrudeFns-
|
|
10
|
+
const require_surfaceBuilders = require("./surfaceBuilders-Do5jrIrG.cjs");
|
|
11
|
+
const require_helpers = require("./helpers-Do57l7FZ.cjs");
|
|
12
|
+
const require_blueprint = require("./blueprint-DRMsvuIW.cjs");
|
|
13
|
+
const require_extrudeFns = require("./extrudeFns-TGgECRPk.cjs");
|
|
14
14
|
//#region node_modules/flatqueue/index.js
|
|
15
15
|
/** @template T */
|
|
16
16
|
var FlatQueue = class {
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { R as DisposalScope, X as getKernel, Y as _usingCtx, Z as getKernel2D, a as createEdge, h as isShape3D, o as createFace, t as castShape, u as createWire } from "./shapeTypes-
|
|
1
|
+
import { R as DisposalScope, X as getKernel, Y as _usingCtx, Z as getKernel2D, a as createEdge, h as isShape3D, o as createFace, t as castShape, u as createWire } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, R as unwrap, T as isOk, b as err, d as validationError, h as bug, i as kernelError, l as typeCastError, n as computationError, s as safeIndex } from "./errors-DboJwVCf.js";
|
|
3
|
-
import { N as downcast, c as normalAt, p as uvBounds, u as pointOnSurface } from "./faceFns-
|
|
3
|
+
import { N as downcast, c as normalAt, p as uvBounds, u as pointOnSurface } from "./faceFns-Ce2sfezK.js";
|
|
4
4
|
import { r as RAD2DEG, t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
5
5
|
import { r as toVec3 } from "./types--GD-LVc6.js";
|
|
6
6
|
import { d as vecNormalize, h as vecScale, r as vecCross } from "./vecOps-B-PCHgyB.js";
|
|
7
7
|
import { n as createPlane } from "./planeOps-sTrM3dcQ.js";
|
|
8
|
-
import { c as curveStartPoint, l as curveTangentAt, r as curveIsClosed } from "./curveFns-
|
|
8
|
+
import { c as curveStartPoint, l as curveTangentAt, r as curveIsClosed } from "./curveFns-Cuiu9Khj.js";
|
|
9
9
|
import { r as lastOrThrow, t as firstOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
10
|
-
import { _ as zip, i as makeNewFaceWithinFace, r as makeFace, s as assembleWire } from "./surfaceBuilders-
|
|
11
|
-
import { _ as samePoint$1, b as subtract2d, d as cartesianToPolar, f as crossProduct2d, g as rotate2d, h as polarToCartesian, l as add2d, m as polarAngle2d, o as normalize2d, p as distance2d, s as PRECISION_INTERSECTION, v as scalarMultiply2d } from "./helpers-
|
|
12
|
-
import { _ as Curve2D, b as removeDuplicatePoints, c as make2dCircle, f as make2dSegmentCurve, h as approximateAsBSpline, m as make2dThreePointArc, n as asSVG, o as make2dArcFromCenter, p as make2dTangentArc, r as viewbox, s as make2dBezierCurve, t as Blueprint, u as make2dEllipseArc, x as isPoint2D, y as BoundingBox2d } from "./blueprint-
|
|
13
|
-
import { c as sweep, i as complexExtrude, l as twistExtrude, r as revolve, t as extrude } from "./extrudeFns-
|
|
10
|
+
import { _ as zip, i as makeNewFaceWithinFace, r as makeFace, s as assembleWire } from "./surfaceBuilders-BDMHU4Ng.js";
|
|
11
|
+
import { _ as samePoint$1, b as subtract2d, d as cartesianToPolar, f as crossProduct2d, g as rotate2d, h as polarToCartesian, l as add2d, m as polarAngle2d, o as normalize2d, p as distance2d, s as PRECISION_INTERSECTION, v as scalarMultiply2d } from "./helpers-BO5KthLn.js";
|
|
12
|
+
import { _ as Curve2D, b as removeDuplicatePoints, c as make2dCircle, f as make2dSegmentCurve, h as approximateAsBSpline, m as make2dThreePointArc, n as asSVG, o as make2dArcFromCenter, p as make2dTangentArc, r as viewbox, s as make2dBezierCurve, t as Blueprint, u as make2dEllipseArc, x as isPoint2D, y as BoundingBox2d } from "./blueprint-BD4KS3uK.js";
|
|
13
|
+
import { c as sweep, i as complexExtrude, l as twistExtrude, r as revolve, t as extrude } from "./extrudeFns-B-GeC5JR.js";
|
|
14
14
|
//#region node_modules/flatqueue/index.js
|
|
15
15
|
/** @template T */
|
|
16
16
|
var FlatQueue = class {
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { X as getKernel, h as isShape3D, t as castShape } from "./shapeTypes-
|
|
1
|
+
import { X as getKernel, h as isShape3D, t as castShape } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, R as unwrap, b as err, d as validationError, i as kernelError, l as typeCastError, t as BrepErrorCode, w as isErr } from "./errors-DboJwVCf.js";
|
|
3
|
-
import { C as getVertices, b as getEdges, w as getWires } from "./faceFns-
|
|
3
|
+
import { C as getVertices, b as getEdges, w as getWires } from "./faceFns-Ce2sfezK.js";
|
|
4
4
|
import { n as HASH_CODE_MAX } from "./constants-csSEYddm.js";
|
|
5
5
|
import { h as vecScale, t as vecAdd } from "./vecOps-B-PCHgyB.js";
|
|
6
6
|
import { o as resolvePlane } from "./planeOps-sTrM3dcQ.js";
|
|
7
|
-
import { _ as propagateAllMetadata, g as collectInputFaceHashes, v as propagateMetadataByHash } from "./shapeFns-
|
|
7
|
+
import { _ as propagateAllMetadata, g as collectInputFaceHashes, v as propagateMetadataByHash } from "./shapeFns-BYOfyHoL.js";
|
|
8
8
|
import { n as getAtOrThrow, t as firstOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
9
|
-
import { r as makeFace } from "./surfaceBuilders-
|
|
9
|
+
import { r as makeFace } from "./surfaceBuilders-BDMHU4Ng.js";
|
|
10
10
|
//#region src/topology/booleanFns.ts
|
|
11
11
|
/**
|
|
12
12
|
* Boolean and compound operations — functional replacements for _3DShape boolean methods.
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
1
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
2
2
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
3
|
-
const require_faceFns = require("./faceFns-
|
|
3
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
4
4
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
5
5
|
const require_vecOps = require("./vecOps-CODplJp3.cjs");
|
|
6
6
|
const require_planeOps = require("./planeOps-BJOIbn4K.cjs");
|
|
7
|
-
const require_shapeFns = require("./shapeFns-
|
|
7
|
+
const require_shapeFns = require("./shapeFns-wvNG7pAU.cjs");
|
|
8
8
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
9
|
-
const require_surfaceBuilders = require("./surfaceBuilders-
|
|
9
|
+
const require_surfaceBuilders = require("./surfaceBuilders-Do5jrIrG.cjs");
|
|
10
10
|
//#region src/topology/booleanFns.ts
|
|
11
11
|
/**
|
|
12
12
|
* Boolean and compound operations — functional replacements for _3DShape boolean methods.
|
package/dist/brepjs.cjs
CHANGED
|
@@ -1,30 +1,30 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_drawFns = require("./drawFns-
|
|
3
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
4
|
-
const require_occtWasmAdapter = require("./occtWasmAdapter-
|
|
2
|
+
const require_drawFns = require("./drawFns-C4URqqIr.cjs");
|
|
3
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
4
|
+
const require_occtWasmAdapter = require("./occtWasmAdapter-DzzTUzYP.cjs");
|
|
5
5
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
6
|
-
const require_faceFns = require("./faceFns-
|
|
6
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
7
7
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
8
8
|
const require_types = require("./types-gLi9wL0N.cjs");
|
|
9
9
|
const require_vecOps = require("./vecOps-CODplJp3.cjs");
|
|
10
10
|
const require_planeOps = require("./planeOps-BJOIbn4K.cjs");
|
|
11
|
-
const require_shapeFns = require("./shapeFns-
|
|
12
|
-
const require_curveFns = require("./curveFns-
|
|
13
|
-
const require_meshFns = require("./meshFns-
|
|
11
|
+
const require_shapeFns = require("./shapeFns-wvNG7pAU.cjs");
|
|
12
|
+
const require_curveFns = require("./curveFns-eR4vAVyT.cjs");
|
|
13
|
+
const require_meshFns = require("./meshFns-D_-6BkQl.cjs");
|
|
14
14
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
15
|
-
const require_surfaceBuilders = require("./surfaceBuilders-
|
|
16
|
-
const require_booleanFns = require("./booleanFns-
|
|
17
|
-
const require_primitiveFns = require("./primitiveFns-
|
|
18
|
-
const require_historyFns = require("./historyFns-
|
|
19
|
-
const require_boolean2D = require("./boolean2D-
|
|
20
|
-
const require_helpers = require("./helpers-
|
|
21
|
-
const require_solidBuilders = require("./solidBuilders-
|
|
22
|
-
const require_measureFns = require("./measureFns-
|
|
23
|
-
const require_cornerFinder = require("./cornerFinder-
|
|
24
|
-
const require_extrudeFns = require("./extrudeFns-
|
|
25
|
-
const require_blueprintFns = require("./blueprintFns-
|
|
26
|
-
const require_importFns = require("./importFns
|
|
27
|
-
const require_shapeRefFns = require("./shapeRefFns-
|
|
15
|
+
const require_surfaceBuilders = require("./surfaceBuilders-Do5jrIrG.cjs");
|
|
16
|
+
const require_booleanFns = require("./booleanFns-tCaPENXq.cjs");
|
|
17
|
+
const require_primitiveFns = require("./primitiveFns-CYZuu9Il.cjs");
|
|
18
|
+
const require_historyFns = require("./historyFns-xcghTeWT.cjs");
|
|
19
|
+
const require_boolean2D = require("./boolean2D-BwCW-B30.cjs");
|
|
20
|
+
const require_helpers = require("./helpers-Do57l7FZ.cjs");
|
|
21
|
+
const require_solidBuilders = require("./solidBuilders-BJ5gVhvm.cjs");
|
|
22
|
+
const require_measureFns = require("./measureFns-Af--KnjE.cjs");
|
|
23
|
+
const require_cornerFinder = require("./cornerFinder-C606yOAm.cjs");
|
|
24
|
+
const require_extrudeFns = require("./extrudeFns-TGgECRPk.cjs");
|
|
25
|
+
const require_blueprintFns = require("./blueprintFns-ixcedxQd.cjs");
|
|
26
|
+
const require_importFns = require("./importFns-lv_acM3B.cjs");
|
|
27
|
+
const require_shapeRefFns = require("./shapeRefFns-BSqCvOMZ.cjs");
|
|
28
28
|
const require_workerHandler = require("./workerHandler-C-3cFcsQ.cjs");
|
|
29
29
|
//#region src/topology/shapeBooleans.ts
|
|
30
30
|
var BOPAlgo_GlueShift = 1;
|
|
@@ -2360,10 +2360,10 @@ function pocket(shape, options) {
|
|
|
2360
2360
|
if (require_errors.isErr(targetResult)) return targetResult;
|
|
2361
2361
|
const targetFace = targetResult.value;
|
|
2362
2362
|
const normal = require_faceFns.normalAt(targetFace);
|
|
2363
|
+
const center = require_faceFns.faceCenter(targetFace);
|
|
2363
2364
|
const faceResult = require_surfaceBuilders.makeFace(toWire(profile));
|
|
2364
2365
|
if (require_errors.isErr(faceResult)) return faceResult;
|
|
2365
|
-
const
|
|
2366
|
-
const toolResult = require_extrudeFns.extrude(faceResult.value, extDir);
|
|
2366
|
+
const toolResult = require_extrudeFns.extrude(require_shapeFns.translate(faceResult.value, center), require_vecOps.vecScale(require_vecOps.vecNormalize(normal), -depth));
|
|
2367
2367
|
if (require_errors.isErr(toolResult)) return toolResult;
|
|
2368
2368
|
return require_booleanFns.cut(s, toolResult.value, { unsafe: true });
|
|
2369
2369
|
}
|
|
@@ -2381,10 +2381,10 @@ function boss(shape, options) {
|
|
|
2381
2381
|
if (require_errors.isErr(targetResult)) return targetResult;
|
|
2382
2382
|
const targetFace = targetResult.value;
|
|
2383
2383
|
const normal = require_faceFns.normalAt(targetFace);
|
|
2384
|
+
const center = require_faceFns.faceCenter(targetFace);
|
|
2384
2385
|
const faceResult = require_surfaceBuilders.makeFace(toWire(profile));
|
|
2385
2386
|
if (require_errors.isErr(faceResult)) return faceResult;
|
|
2386
|
-
const
|
|
2387
|
-
const toolResult = require_extrudeFns.extrude(faceResult.value, extDir);
|
|
2387
|
+
const toolResult = require_extrudeFns.extrude(require_shapeFns.translate(faceResult.value, center), require_vecOps.vecScale(require_vecOps.vecNormalize(normal), height));
|
|
2388
2388
|
if (require_errors.isErr(toolResult)) return toolResult;
|
|
2389
2389
|
return require_booleanFns.fuse(s, toolResult.value, { unsafe: true });
|
|
2390
2390
|
}
|
|
@@ -2401,6 +2401,7 @@ function mirrorJoin(shape, options) {
|
|
|
2401
2401
|
0
|
|
2402
2402
|
];
|
|
2403
2403
|
const planeOrigin = options?.at;
|
|
2404
|
+
if (require_vecOps.vecIsZero(normal)) return require_errors.err(require_errors.validationError("MIRROR_ZERO_NORMAL", "Mirror plane normal cannot be zero"));
|
|
2404
2405
|
return require_booleanFns.fuse(s, require_shapeFns.mirror(s, normal, planeOrigin), { unsafe: true });
|
|
2405
2406
|
}
|
|
2406
2407
|
/**
|
package/dist/brepjs.js
CHANGED
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import { $ as initFromOC, A as planarWire, B as createKernelHandle, C as isOrientedFace, D as manifoldShell, E as isValidSolid, F as as3D, H as isLive, I as is2D, J as withScopeResultAsync, K as withScope, L as is3D, M as getShapeKind, O as orientedFace, P as as2D, Q as init, R as DisposalScope, S as isManifoldShell, T as isPlanarWire, V as getDisposalStats, W as resetDisposalStats, X as getKernel, _ as isSolid, a as createEdge, at as BrepkitAdapter, b as closedWire, c as createSolid, d as isCompound, et as prewarm, f as isEdge, g as isShell, h as isShape3D, i as createCompound, it as supportsProjection, j as validSolid, k as planarFace, l as createVertex, m as isShape1D, n as castShape3D, nt as withKernel, o as createFace, ot as getPerformanceStats, p as isFace, q as withScopeResult, rt as supportsConstraintSketch, s as createShell, st as resetPerformanceStats, t as castShape, tt as registerKernel, u as createWire, v as isVertex, w as isPlanarFace, x as isClosedWire, y as isWire, z as createHandle } from "./shapeTypes-
|
|
2
|
-
import { t as OcctWasmAdapter } from "./occtWasmAdapter-
|
|
1
|
+
import { $ as initFromOC, A as planarWire, B as createKernelHandle, C as isOrientedFace, D as manifoldShell, E as isValidSolid, F as as3D, H as isLive, I as is2D, J as withScopeResultAsync, K as withScope, L as is3D, M as getShapeKind, O as orientedFace, P as as2D, Q as init, R as DisposalScope, S as isManifoldShell, T as isPlanarWire, V as getDisposalStats, W as resetDisposalStats, X as getKernel, _ as isSolid, a as createEdge, at as BrepkitAdapter, b as closedWire, c as createSolid, d as isCompound, et as prewarm, f as isEdge, g as isShell, h as isShape3D, i as createCompound, it as supportsProjection, j as validSolid, k as planarFace, l as createVertex, m as isShape1D, n as castShape3D, nt as withKernel, o as createFace, ot as getPerformanceStats, p as isFace, q as withScopeResult, rt as supportsConstraintSketch, s as createShell, st as resetPerformanceStats, t as castShape, tt as registerKernel, u as createWire, v as isVertex, w as isPlanarFace, x as isClosedWire, y as isWire, z as createHandle } from "./shapeTypes-Tu03ijIx.js";
|
|
2
|
+
import { t as OcctWasmAdapter } from "./occtWasmAdapter-DLWC3oxC.js";
|
|
3
3
|
import { A as ok, B as unwrapOr, C as fromNullable, D as mapBoth, E as map, F as tapErr, H as zip, I as tryCatch, L as tryCatchAsync, M as orElse, N as pipeline, O as mapErr, P as tap, R as unwrap, S as flatten, T as isOk, V as unwrapOrElse, _ as all, a as moduleInitError, b as err, c as sketcherStateError, d as validationError, g as OK, h as bug, i as kernelError, j as or, k as match, l as typeCastError, m as BrepBugError, n as computationError, o as queryError, r as ioError, t as BrepErrorCode, u as unsupportedError, v as andThen, w as isErr, x as flatMap, y as collect, z as unwrapErr } from "./errors-DboJwVCf.js";
|
|
4
|
-
import { A as vertexPosition, B as kernelCallScoped, C as getVertices, D as iterFaces, E as iterEdges, F as isCompSolid, I as iterTopo, L as shapeType, M as cast, N as downcast, O as iterVertices, P as fromBREP, R as kernelCall, T as invalidateShapeCache, a as flipFaceOrientation, b as getEdges, c as normalAt, d as projectPointOnFace, f as removeHolesFromFace, g as getBounds, h as describe$1, i as faceOrientation, j as asTopo, k as iterWires, l as outerWire, m as uvCoordinates, n as faceCenter, o as getSurfaceType, p as uvBounds, r as faceGeomType, s as innerWires, t as classifyPointOnFace, u as pointOnSurface, w as getWires, x as getFaces, y as getCachedSurfaceType, z as kernelCallRaw } from "./faceFns-
|
|
4
|
+
import { A as vertexPosition, B as kernelCallScoped, C as getVertices, D as iterFaces, E as iterEdges, F as isCompSolid, I as iterTopo, L as shapeType, M as cast, N as downcast, O as iterVertices, P as fromBREP, R as kernelCall, T as invalidateShapeCache, a as flipFaceOrientation, b as getEdges, c as normalAt, d as projectPointOnFace, f as removeHolesFromFace, g as getBounds, h as describe$1, i as faceOrientation, j as asTopo, k as iterWires, l as outerWire, m as uvCoordinates, n as faceCenter, o as getSurfaceType, p as uvBounds, r as faceGeomType, s as innerWires, t as classifyPointOnFace, u as pointOnSurface, w as getWires, x as getFaces, y as getCachedSurfaceType, z as kernelCallRaw } from "./faceFns-Ce2sfezK.js";
|
|
5
5
|
import { n as HASH_CODE_MAX, r as RAD2DEG, t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
6
6
|
import { n as toVec2, r as toVec3, t as resolveDirection } from "./types--GD-LVc6.js";
|
|
7
7
|
import { a as vecDot, c as vecLength, d as vecNormalize, f as vecProjectToPlane, g as vecSub, h as vecScale, i as vecDistance, l as vecLengthSq, m as vecRotate, n as vecAngle, o as vecEquals, p as vecRepr, r as vecCross, s as vecIsZero, t as vecAdd, u as vecNegate } from "./vecOps-B-PCHgyB.js";
|
|
8
8
|
import { i as pivotPlane, n as createPlane, o as resolvePlane, r as makePlane, s as translatePlane, t as createNamedPlane } from "./planeOps-sTrM3dcQ.js";
|
|
9
|
-
import { C as findFacesByTag, D as tagFaces, E as setTagMetadata, O as getFaceOrigins, S as getShapeColor, T as getTagMetadata, a as isSameShape, b as colorShape, c as applyMatrix$1, d as resize, f as rotate$1, h as translate$1, i as isEqualShape, k as setShapeOrigin, l as composeTransforms, m as transformCopy$1, n as getHashCode, o as simplify$1, p as scale$1, r as isEmpty$2, s as toBREP$1, t as clone$1, u as mirror$1, w as getFaceTags, x as getFaceColor, y as colorFaces } from "./shapeFns-
|
|
10
|
-
import { a as curveLength, c as curveStartPoint, d as getCurveType, f as getOrientation, i as curveIsPeriodic, l as curveTangentAt, m as offsetWire2D, n as curveEndPoint, o as curvePeriod, p as interpolateCurve, r as curveIsClosed, s as curvePointAt, t as approximateCurve, u as flipOrientation } from "./curveFns-
|
|
11
|
-
import { a as meshEdges$1, c as createMeshCache, i as mesh$1, n as exportSTEP, o as meshMultiLOD, r as exportSTL, s as clearMeshCache, t as exportIGES } from "./meshFns-
|
|
9
|
+
import { C as findFacesByTag, D as tagFaces, E as setTagMetadata, O as getFaceOrigins, S as getShapeColor, T as getTagMetadata, a as isSameShape, b as colorShape, c as applyMatrix$1, d as resize, f as rotate$1, h as translate$1, i as isEqualShape, k as setShapeOrigin, l as composeTransforms, m as transformCopy$1, n as getHashCode, o as simplify$1, p as scale$1, r as isEmpty$2, s as toBREP$1, t as clone$1, u as mirror$1, w as getFaceTags, x as getFaceColor, y as colorFaces } from "./shapeFns-BYOfyHoL.js";
|
|
10
|
+
import { a as curveLength, c as curveStartPoint, d as getCurveType, f as getOrientation, i as curveIsPeriodic, l as curveTangentAt, m as offsetWire2D, n as curveEndPoint, o as curvePeriod, p as interpolateCurve, r as curveIsClosed, s as curvePointAt, t as approximateCurve, u as flipOrientation } from "./curveFns-Cuiu9Khj.js";
|
|
11
|
+
import { a as meshEdges$1, c as createMeshCache, i as mesh$1, n as exportSTEP, o as meshMultiLOD, r as exportSTL, s as clearMeshCache, t as exportIGES } from "./meshFns-fHojyH-k.js";
|
|
12
12
|
import { n as getAtOrThrow, t as firstOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
13
|
-
import { n as fill, r as makeFace } from "./surfaceBuilders-
|
|
14
|
-
import { a as fuseAll, c as sectionToFace$1, i as fuse$1, l as slice$1, n as cut$1, o as intersect$1, r as cutAll, s as section$1, t as booleanPipeline, u as split$1 } from "./booleanFns-
|
|
15
|
-
import { $ as getNurbsSurfaceData, A as fixShape, B as offset$1, C as threePointArc, D as wireLoop, E as wire, F as isValid$1, G as chamferWithEvolution, H as thicken$1, I as solidFromShell, J as fuseWithEvolution, K as cutWithEvolution, L as chamfer$1, M as healFace, N as healSolid, O as autoHeal, P as healWire, Q as getNurbsCurveData, R as draft$1, S as tangentArc, T as vertex, U as variableFillet, V as shell$1, W as positionOnCurve, X as shellWithEvolution, Y as intersectWithEvolution, Z as checkBoolean, _ as polygon, a as circle, at as wiresOfFace, b as sphere, c as cylinder, ct as toGroupedBufferGeometryData, d as ellipsoid, et as adjacentFaces, f as face, g as offsetFace, h as line, i as bsplineApprox, it as verticesOfEdge, j as heal$1, k as fixSelfIntersection, l as ellipse, lt as toLODGeometryData, m as helix, n as bezier, nt as facesOfEdge, o as compound, ot as chamferDistAngle, p as filledFace, q as filletWithEvolution, r as box, rt as sharedEdges, s as cone, st as toBufferGeometryData, t as addHoles, tt as edgesOfFace, u as ellipseArc, ut as toLineGeometryData, v as sewShells, w as torus, x as subFace, y as solid, z as fillet$1 } from "./primitiveFns-
|
|
16
|
-
import { C as walkAssembly, D as exportAssemblySTEP, E as linearPattern, O as createAssembly, S as updateNode, _ as collectShapes, a as findStep, b as findNode, c as registerOperation, d as replayHistory, f as serializeHistory, g as addChild, h as undoLast, i as deserializeHistory, l as registerShape, m as stepsFrom, n as createHistory, o as getShape, p as stepCount, r as createRegistry, s as modifyStep, t as addStep, u as replayFrom, v as countNodes, w as circularPattern, x as removeChild, y as createAssemblyNode } from "./historyFns-
|
|
17
|
-
import { a as fuseBlueprints, c as roundedRectangleBlueprint, f as Sketch, h as organiseBlueprints, i as cutBlueprints, m as loftAll, n as fuse2D, o as intersectBlueprints, p as loft$1, r as intersect2D, s as polysidesBlueprint, t as cut2D } from "./boolean2D-
|
|
18
|
-
import { a as createTypedFinder, i as wireFinder, n as edgeFinder, r as faceFinder, t as getSingleFace } from "./helpers-
|
|
19
|
-
import { $ as sketchFaceOffset, B as drawSingleCircle, C as cameraFromPlane, D as makeProjectedEdges, E as projectEdges, F as drawParametricFunction, G as loadFont, H as drawText, I as drawPointsInterpolation, J as textMetrics, K as sketchText, L as drawPolysides, M as draw, N as drawCircle, O as isProjectionPlane, P as drawEllipse, Q as sketchEllipse, R as drawRectangle, S as drawProjection, T as createCamera, U as fontMetrics, V as drawSingleEllipse, W as getFont, X as polysideInnerRadius, Y as makeBaseBox, Z as sketchCircle, _ as sketchLoft, a as drawingIntersect, b as sketchWires, c as rotateDrawing, d as compoundSketchExtrude, et as sketchHelix, f as compoundSketchFace, g as sketchFace, h as sketchExtrude, i as drawingFuse, it as sketchRoundedRectangle, j as deserializeDrawing, l as scaleDrawing, m as compoundSketchRevolve, n as drawingCut, nt as sketchPolysides, o as drawingToSketchOnPlane, ot as Sketches, p as compoundSketchLoft, q as textBlueprints, r as drawingFillet, rt as sketchRectangle, s as mirrorDrawing, st as CompoundSketch, t as drawingChamfer, tt as sketchParametricFunction, u as translateDrawing, v as sketchRevolve, w as cameraLookAt, x as drawFaceOutline, y as sketchSweep, z as drawRoundedRectangle } from "./drawFns-
|
|
20
|
-
import { r as makeCylinder } from "./solidBuilders-
|
|
21
|
-
import { a as measureDistance, c as measureLinearProps, d as measureVolumeProps, i as measureCurvatureAtMid, l as measureSurfaceProps, n as measureArea, o as measureDistanceProps, r as measureCurvatureAt, s as measureLength, t as createDistanceQuery, u as measureVolume } from "./measureFns-
|
|
22
|
-
import { t as cornerFinder } from "./cornerFinder-
|
|
23
|
-
import { a as guidedSweep, c as sweep, i as complexExtrude, l as twistExtrude, n as extrudeAll, o as multiSectionSweep, r as revolve$1, s as supportExtrude, t as extrude$1 } from "./extrudeFns-
|
|
24
|
-
import { S as reverseCurve, _ as curve2dIsOnCurve, a as isInside2D, b as curve2dSplitAt, c as scale2D, d as stretch2D, f as toSVGPathD, g as curve2dFirstPoint, h as curve2dDistanceFrom, i as getOrientation2D, l as sketchOnFace2D, m as curve2dBoundingBox, n as createCompoundBlueprint, o as mirror2D, p as translate2D, r as getBounds2D, s as rotate2D, t as createBlueprint, u as sketchOnPlane2D, v as curve2dLastPoint, x as curve2dTangentAt, y as curve2dParameter } from "./blueprintFns-
|
|
25
|
-
import { a as importSVG, c as blueprintToDXF, d as exportGltf, f as exportOBJ, i as exportSTEPConfigured, l as exportDXF, n as importSTEP, o as importSVGPathD, r as importSTL, s as exportThreeMF, t as importIGES, u as exportGlb } from "./importFns
|
|
26
|
-
import { a as updateRoles, i as resolveRef, n as captureHint, o as defaultScorer, r as createRef, t as assignRoles } from "./shapeRefFns-
|
|
13
|
+
import { n as fill, r as makeFace } from "./surfaceBuilders-BDMHU4Ng.js";
|
|
14
|
+
import { a as fuseAll, c as sectionToFace$1, i as fuse$1, l as slice$1, n as cut$1, o as intersect$1, r as cutAll, s as section$1, t as booleanPipeline, u as split$1 } from "./booleanFns-B4ZGNOr3.js";
|
|
15
|
+
import { $ as getNurbsSurfaceData, A as fixShape, B as offset$1, C as threePointArc, D as wireLoop, E as wire, F as isValid$1, G as chamferWithEvolution, H as thicken$1, I as solidFromShell, J as fuseWithEvolution, K as cutWithEvolution, L as chamfer$1, M as healFace, N as healSolid, O as autoHeal, P as healWire, Q as getNurbsCurveData, R as draft$1, S as tangentArc, T as vertex, U as variableFillet, V as shell$1, W as positionOnCurve, X as shellWithEvolution, Y as intersectWithEvolution, Z as checkBoolean, _ as polygon, a as circle, at as wiresOfFace, b as sphere, c as cylinder, ct as toGroupedBufferGeometryData, d as ellipsoid, et as adjacentFaces, f as face, g as offsetFace, h as line, i as bsplineApprox, it as verticesOfEdge, j as heal$1, k as fixSelfIntersection, l as ellipse, lt as toLODGeometryData, m as helix, n as bezier, nt as facesOfEdge, o as compound, ot as chamferDistAngle, p as filledFace, q as filletWithEvolution, r as box, rt as sharedEdges, s as cone, st as toBufferGeometryData, t as addHoles, tt as edgesOfFace, u as ellipseArc, ut as toLineGeometryData, v as sewShells, w as torus, x as subFace, y as solid, z as fillet$1 } from "./primitiveFns-DmvY2gVS.js";
|
|
16
|
+
import { C as walkAssembly, D as exportAssemblySTEP, E as linearPattern, O as createAssembly, S as updateNode, _ as collectShapes, a as findStep, b as findNode, c as registerOperation, d as replayHistory, f as serializeHistory, g as addChild, h as undoLast, i as deserializeHistory, l as registerShape, m as stepsFrom, n as createHistory, o as getShape, p as stepCount, r as createRegistry, s as modifyStep, t as addStep, u as replayFrom, v as countNodes, w as circularPattern, x as removeChild, y as createAssemblyNode } from "./historyFns-_ZRHu7mY.js";
|
|
17
|
+
import { a as fuseBlueprints, c as roundedRectangleBlueprint, f as Sketch, h as organiseBlueprints, i as cutBlueprints, m as loftAll, n as fuse2D, o as intersectBlueprints, p as loft$1, r as intersect2D, s as polysidesBlueprint, t as cut2D } from "./boolean2D-CWNL216K.js";
|
|
18
|
+
import { a as createTypedFinder, i as wireFinder, n as edgeFinder, r as faceFinder, t as getSingleFace } from "./helpers-BO5KthLn.js";
|
|
19
|
+
import { $ as sketchFaceOffset, B as drawSingleCircle, C as cameraFromPlane, D as makeProjectedEdges, E as projectEdges, F as drawParametricFunction, G as loadFont, H as drawText, I as drawPointsInterpolation, J as textMetrics, K as sketchText, L as drawPolysides, M as draw, N as drawCircle, O as isProjectionPlane, P as drawEllipse, Q as sketchEllipse, R as drawRectangle, S as drawProjection, T as createCamera, U as fontMetrics, V as drawSingleEllipse, W as getFont, X as polysideInnerRadius, Y as makeBaseBox, Z as sketchCircle, _ as sketchLoft, a as drawingIntersect, b as sketchWires, c as rotateDrawing, d as compoundSketchExtrude, et as sketchHelix, f as compoundSketchFace, g as sketchFace, h as sketchExtrude, i as drawingFuse, it as sketchRoundedRectangle, j as deserializeDrawing, l as scaleDrawing, m as compoundSketchRevolve, n as drawingCut, nt as sketchPolysides, o as drawingToSketchOnPlane, ot as Sketches, p as compoundSketchLoft, q as textBlueprints, r as drawingFillet, rt as sketchRectangle, s as mirrorDrawing, st as CompoundSketch, t as drawingChamfer, tt as sketchParametricFunction, u as translateDrawing, v as sketchRevolve, w as cameraLookAt, x as drawFaceOutline, y as sketchSweep, z as drawRoundedRectangle } from "./drawFns-Di19TRz_.js";
|
|
20
|
+
import { r as makeCylinder } from "./solidBuilders-CPWknuQG.js";
|
|
21
|
+
import { a as measureDistance, c as measureLinearProps, d as measureVolumeProps, i as measureCurvatureAtMid, l as measureSurfaceProps, n as measureArea, o as measureDistanceProps, r as measureCurvatureAt, s as measureLength, t as createDistanceQuery, u as measureVolume } from "./measureFns-Beh8ggjV.js";
|
|
22
|
+
import { t as cornerFinder } from "./cornerFinder-C1eCd2NO.js";
|
|
23
|
+
import { a as guidedSweep, c as sweep, i as complexExtrude, l as twistExtrude, n as extrudeAll, o as multiSectionSweep, r as revolve$1, s as supportExtrude, t as extrude$1 } from "./extrudeFns-B-GeC5JR.js";
|
|
24
|
+
import { S as reverseCurve, _ as curve2dIsOnCurve, a as isInside2D, b as curve2dSplitAt, c as scale2D, d as stretch2D, f as toSVGPathD, g as curve2dFirstPoint, h as curve2dDistanceFrom, i as getOrientation2D, l as sketchOnFace2D, m as curve2dBoundingBox, n as createCompoundBlueprint, o as mirror2D, p as translate2D, r as getBounds2D, s as rotate2D, t as createBlueprint, u as sketchOnPlane2D, v as curve2dLastPoint, x as curve2dTangentAt, y as curve2dParameter } from "./blueprintFns-DSSOMAIL.js";
|
|
25
|
+
import { a as importSVG, c as blueprintToDXF, d as exportGltf, f as exportOBJ, i as exportSTEPConfigured, l as exportDXF, n as importSTEP, o as importSVGPathD, r as importSTL, s as exportThreeMF, t as importIGES, u as exportGlb } from "./importFns-BJ5uUwpa.js";
|
|
26
|
+
import { a as updateRoles, i as resolveRef, n as captureHint, o as defaultScorer, r as createRef, t as assignRoles } from "./shapeRefFns-Cd-zuZ_d.js";
|
|
27
27
|
import { a as createTaskQueue, c as isEmpty$1, d as isDisposeRequest, f as isErrorResponse, h as isSuccessResponse, i as createWorkerClient, l as pendingCount, m as isOperationRequest, n as createWorkerHandler, o as dequeueTask, p as isInitRequest, r as registerHandler, s as enqueueTask, t as createOperationRegistry, u as rejectAll } from "./workerHandler-Dm0_0F8Z.js";
|
|
28
28
|
//#region \0rolldown/runtime.js
|
|
29
29
|
var __defProp = Object.defineProperty;
|
|
@@ -2363,10 +2363,10 @@ function pocket(shape, options) {
|
|
|
2363
2363
|
if (isErr(targetResult)) return targetResult;
|
|
2364
2364
|
const targetFace = targetResult.value;
|
|
2365
2365
|
const normal = normalAt(targetFace);
|
|
2366
|
+
const center = faceCenter(targetFace);
|
|
2366
2367
|
const faceResult = makeFace(toWire(profile));
|
|
2367
2368
|
if (isErr(faceResult)) return faceResult;
|
|
2368
|
-
const
|
|
2369
|
-
const toolResult = extrude$1(faceResult.value, extDir);
|
|
2369
|
+
const toolResult = extrude$1(translate$1(faceResult.value, center), vecScale(vecNormalize(normal), -depth));
|
|
2370
2370
|
if (isErr(toolResult)) return toolResult;
|
|
2371
2371
|
return cut$1(s, toolResult.value, { unsafe: true });
|
|
2372
2372
|
}
|
|
@@ -2384,10 +2384,10 @@ function boss(shape, options) {
|
|
|
2384
2384
|
if (isErr(targetResult)) return targetResult;
|
|
2385
2385
|
const targetFace = targetResult.value;
|
|
2386
2386
|
const normal = normalAt(targetFace);
|
|
2387
|
+
const center = faceCenter(targetFace);
|
|
2387
2388
|
const faceResult = makeFace(toWire(profile));
|
|
2388
2389
|
if (isErr(faceResult)) return faceResult;
|
|
2389
|
-
const
|
|
2390
|
-
const toolResult = extrude$1(faceResult.value, extDir);
|
|
2390
|
+
const toolResult = extrude$1(translate$1(faceResult.value, center), vecScale(vecNormalize(normal), height));
|
|
2391
2391
|
if (isErr(toolResult)) return toolResult;
|
|
2392
2392
|
return fuse$1(s, toolResult.value, { unsafe: true });
|
|
2393
2393
|
}
|
|
@@ -2404,6 +2404,7 @@ function mirrorJoin(shape, options) {
|
|
|
2404
2404
|
0
|
|
2405
2405
|
];
|
|
2406
2406
|
const planeOrigin = options?.at;
|
|
2407
|
+
if (vecIsZero(normal)) return err(validationError("MIRROR_ZERO_NORMAL", "Mirror plane normal cannot be zero"));
|
|
2407
2408
|
return fuse$1(s, mirror$1(s, normal, planeOrigin), { unsafe: true });
|
|
2408
2409
|
}
|
|
2409
2410
|
/**
|
package/dist/core.cjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
2
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
3
3
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
4
4
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
5
5
|
const require_types = require("./types-gLi9wL0N.cjs");
|
package/dist/core.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { B as createKernelHandle, C as isOrientedFace, D as manifoldShell, E as isValidSolid, H as isLive, I as is2D, J as withScopeResultAsync, K as withScope, L as is3D, M as getShapeKind, O as orientedFace, R as DisposalScope, S as isManifoldShell, _ as isSolid, b as closedWire, d as isCompound, f as isEdge, g as isShell, h as isShape3D, j as validSolid, m as isShape1D, p as isFace, q as withScopeResult, t as castShape, v as isVertex, x as isClosedWire, y as isWire, z as createHandle } from "./shapeTypes-
|
|
1
|
+
import { B as createKernelHandle, C as isOrientedFace, D as manifoldShell, E as isValidSolid, H as isLive, I as is2D, J as withScopeResultAsync, K as withScope, L as is3D, M as getShapeKind, O as orientedFace, R as DisposalScope, S as isManifoldShell, _ as isSolid, b as closedWire, d as isCompound, f as isEdge, g as isShell, h as isShape3D, j as validSolid, m as isShape1D, p as isFace, q as withScopeResult, t as castShape, v as isVertex, x as isClosedWire, y as isWire, z as createHandle } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, B as unwrapOr, E as map, I as tryCatch, L as tryCatchAsync, O as mapErr, R as unwrap, T as isOk, V as unwrapOrElse, a as moduleInitError, b as err, c as sketcherStateError, d as validationError, g as OK, h as bug, i as kernelError, k as match, l as typeCastError, m as BrepBugError, n as computationError, o as queryError, r as ioError, u as unsupportedError, v as andThen, w as isErr, x as flatMap, y as collect, z as unwrapErr } from "./errors-DboJwVCf.js";
|
|
3
3
|
import { n as HASH_CODE_MAX, r as RAD2DEG, t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
4
4
|
import { n as toVec2, r as toVec3, t as resolveDirection } from "./types--GD-LVc6.js";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
2
2
|
import { n as getAtOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
3
|
-
import { _ as samePoint, p as distance2d, u as angle2d } from "./helpers-
|
|
3
|
+
import { _ as samePoint, p as distance2d, u as angle2d } from "./helpers-BO5KthLn.js";
|
|
4
4
|
//#region src/query/cornerFinder.ts
|
|
5
5
|
var PI_2 = 2 * Math.PI;
|
|
6
6
|
function positiveHalfAngle(angle) {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
2
2
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
3
|
-
const require_helpers = require("./helpers-
|
|
3
|
+
const require_helpers = require("./helpers-Do57l7FZ.cjs");
|
|
4
4
|
//#region src/query/cornerFinder.ts
|
|
5
5
|
var PI_2 = 2 * Math.PI;
|
|
6
6
|
function positiveHalfAngle(angle) {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { X as getKernel, f as isEdge, t as castShape, y as isWire } from "./shapeTypes-
|
|
1
|
+
import { X as getKernel, f as isEdge, t as castShape, y as isWire } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, b as err, l as typeCastError } from "./errors-DboJwVCf.js";
|
|
3
3
|
//#region src/topology/curveFns.ts
|
|
4
4
|
/**
|
|
@@ -29,24 +29,24 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
29
29
|
enumerable: true
|
|
30
30
|
}) : target, mod));
|
|
31
31
|
//#endregion
|
|
32
|
-
const require_shapeTypes = require("./shapeTypes-
|
|
32
|
+
const require_shapeTypes = require("./shapeTypes-0QO9ycMV.cjs");
|
|
33
33
|
const require_errors = require("./errors-CXRNVCec.cjs");
|
|
34
|
-
const require_faceFns = require("./faceFns-
|
|
34
|
+
const require_faceFns = require("./faceFns-DP61KiyY.cjs");
|
|
35
35
|
const require_constants = require("./constants-BNP_xnBN.cjs");
|
|
36
36
|
const require_types = require("./types-gLi9wL0N.cjs");
|
|
37
37
|
const require_vecOps = require("./vecOps-CODplJp3.cjs");
|
|
38
38
|
const require_planeOps = require("./planeOps-BJOIbn4K.cjs");
|
|
39
|
-
const require_curveFns = require("./curveFns-
|
|
39
|
+
const require_curveFns = require("./curveFns-eR4vAVyT.cjs");
|
|
40
40
|
const require_arrayAccess = require("./arrayAccess-DsnQpdSD.cjs");
|
|
41
|
-
const require_surfaceBuilders = require("./surfaceBuilders-
|
|
42
|
-
const require_boolean2D = require("./boolean2D-
|
|
43
|
-
const require_helpers = require("./helpers-
|
|
44
|
-
const require_blueprint = require("./blueprint-
|
|
45
|
-
const require_solidBuilders = require("./solidBuilders-
|
|
46
|
-
const require_cornerFinder = require("./cornerFinder-
|
|
47
|
-
const require_extrudeFns = require("./extrudeFns-
|
|
41
|
+
const require_surfaceBuilders = require("./surfaceBuilders-Do5jrIrG.cjs");
|
|
42
|
+
const require_boolean2D = require("./boolean2D-BwCW-B30.cjs");
|
|
43
|
+
const require_helpers = require("./helpers-Do57l7FZ.cjs");
|
|
44
|
+
const require_blueprint = require("./blueprint-DRMsvuIW.cjs");
|
|
45
|
+
const require_solidBuilders = require("./solidBuilders-BJ5gVhvm.cjs");
|
|
46
|
+
const require_cornerFinder = require("./cornerFinder-C606yOAm.cjs");
|
|
47
|
+
const require_extrudeFns = require("./extrudeFns-TGgECRPk.cjs");
|
|
48
48
|
let opentype_js = require("opentype.js");
|
|
49
|
-
opentype_js = __toESM(opentype_js);
|
|
49
|
+
opentype_js = __toESM(opentype_js, 1);
|
|
50
50
|
//#region src/2d/lib/stitching.ts
|
|
51
51
|
/**
|
|
52
52
|
* Group a flat list of curves into connected chains by matching endpoints.
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { R as DisposalScope, X as getKernel, Y as _usingCtx, o as createFace, p as isFace, t as castShape, u as createWire } from "./shapeTypes-
|
|
1
|
+
import { R as DisposalScope, X as getKernel, Y as _usingCtx, o as createFace, p as isFace, t as castShape, u as createWire } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, R as unwrap, T as isOk, b as err, d as validationError, h as bug, r as ioError, s as safeIndex, t as BrepErrorCode } from "./errors-DboJwVCf.js";
|
|
3
|
-
import { M as cast, N as downcast, b as getEdges, c as normalAt, l as outerWire, n as faceCenter } from "./faceFns-
|
|
3
|
+
import { M as cast, N as downcast, b as getEdges, c as normalAt, l as outerWire, n as faceCenter } from "./faceFns-Ce2sfezK.js";
|
|
4
4
|
import { t as DEG2RAD } from "./constants-csSEYddm.js";
|
|
5
5
|
import { r as toVec3 } from "./types--GD-LVc6.js";
|
|
6
6
|
import { c as vecLength, d as vecNormalize, g as vecSub, h as vecScale, m as vecRotate, r as vecCross } from "./vecOps-B-PCHgyB.js";
|
|
7
7
|
import { a as planeToWorld, o as resolvePlane } from "./planeOps-sTrM3dcQ.js";
|
|
8
|
-
import { m as offsetWire2D } from "./curveFns-
|
|
8
|
+
import { m as offsetWire2D } from "./curveFns-Cuiu9Khj.js";
|
|
9
9
|
import { n as getAtOrThrow, r as lastOrThrow, t as firstOrThrow } from "./arrayAccess-tCIbjLs5.js";
|
|
10
|
-
import { c as makeBSplineApproximation, d as makeEllipse, p as makeHelix, r as makeFace, s as assembleWire, t as addHolesInFace, u as makeCircle } from "./surfaceBuilders-
|
|
11
|
-
import { S as Flatbush, _ as Blueprints, b as make2dOffset, c as roundedRectangleBlueprint, f as Sketch, g as CompoundBlueprint, h as organiseBlueprints, l as BaseSketcher2d, n as fuse2D, r as intersect2D, s as polysidesBlueprint, t as cut2D, u as BlueprintSketcher, v as chamferCurves, x as intersectCurves, y as filletCurves } from "./boolean2D-
|
|
12
|
-
import { _ as samePoint$1, b as subtract2d, c as PRECISION_OFFSET, l as add2d, y as squareDistance2d } from "./helpers-
|
|
13
|
-
import { _ as Curve2D, a as edgeToCurve, c as make2dCircle, d as make2dInerpolatedBSplineCurve, f as make2dSegmentCurve, g as approximateAsSvgCompatibleCurve, i as curvesAsEdgesOnPlane, l as make2dEllipse, o as make2dArcFromCenter, t as Blueprint, v as deserializeCurve2D, y as BoundingBox2d } from "./blueprint-
|
|
14
|
-
import { o as makeSolid, t as makeCompound } from "./solidBuilders-
|
|
15
|
-
import { t as cornerFinder } from "./cornerFinder-
|
|
16
|
-
import { i as complexExtrude, l as twistExtrude, r as revolve, t as extrude } from "./extrudeFns-
|
|
10
|
+
import { c as makeBSplineApproximation, d as makeEllipse, p as makeHelix, r as makeFace, s as assembleWire, t as addHolesInFace, u as makeCircle } from "./surfaceBuilders-BDMHU4Ng.js";
|
|
11
|
+
import { S as Flatbush, _ as Blueprints, b as make2dOffset, c as roundedRectangleBlueprint, f as Sketch, g as CompoundBlueprint, h as organiseBlueprints, l as BaseSketcher2d, n as fuse2D, r as intersect2D, s as polysidesBlueprint, t as cut2D, u as BlueprintSketcher, v as chamferCurves, x as intersectCurves, y as filletCurves } from "./boolean2D-CWNL216K.js";
|
|
12
|
+
import { _ as samePoint$1, b as subtract2d, c as PRECISION_OFFSET, l as add2d, y as squareDistance2d } from "./helpers-BO5KthLn.js";
|
|
13
|
+
import { _ as Curve2D, a as edgeToCurve, c as make2dCircle, d as make2dInerpolatedBSplineCurve, f as make2dSegmentCurve, g as approximateAsSvgCompatibleCurve, i as curvesAsEdgesOnPlane, l as make2dEllipse, o as make2dArcFromCenter, t as Blueprint, v as deserializeCurve2D, y as BoundingBox2d } from "./blueprint-BD4KS3uK.js";
|
|
14
|
+
import { o as makeSolid, t as makeCompound } from "./solidBuilders-CPWknuQG.js";
|
|
15
|
+
import { t as cornerFinder } from "./cornerFinder-C1eCd2NO.js";
|
|
16
|
+
import { i as complexExtrude, l as twistExtrude, r as revolve, t as extrude } from "./extrudeFns-B-GeC5JR.js";
|
|
17
17
|
import opentype from "opentype.js";
|
|
18
18
|
//#region src/2d/lib/stitching.ts
|
|
19
19
|
/**
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { X as getKernel, c as createSolid, h as isShape3D, t as castShape, y as isWire } from "./shapeTypes-
|
|
1
|
+
import { X as getKernel, c as createSolid, h as isShape3D, t as castShape, y as isWire } from "./shapeTypes-Tu03ijIx.js";
|
|
2
2
|
import { A as ok, b as err, d as validationError, i as kernelError, l as typeCastError, t as BrepErrorCode, w as isErr } from "./errors-DboJwVCf.js";
|
|
3
3
|
import { c as vecLength, d as vecNormalize, t as vecAdd } from "./vecOps-B-PCHgyB.js";
|
|
4
4
|
//#region src/operations/extrudeUtils.ts
|
|
@@ -288,7 +288,7 @@ function guidedSweep(profile, spine, guides, options = {}) {
|
|
|
288
288
|
*/
|
|
289
289
|
function extrude(face, extrusionVec) {
|
|
290
290
|
if (getKernel().isNull(face.wrapped)) return err(validationError(BrepErrorCode.NULL_SHAPE_INPUT, "extrude: face is a null shape"));
|
|
291
|
-
if (vecLength(extrusionVec)
|
|
291
|
+
if (vecLength(extrusionVec) < 1e-10) return err(validationError("EXTRUDE_ZERO_VECTOR", "extrude: extrusion vector has zero length"));
|
|
292
292
|
try {
|
|
293
293
|
const kernel = getKernel();
|
|
294
294
|
const len = vecLength(extrusionVec);
|
|
@@ -321,9 +321,16 @@ function revolve(face, center = [
|
|
|
321
321
|
1
|
|
322
322
|
], angle = 360) {
|
|
323
323
|
if (getKernel().isNull(face.wrapped)) return err(validationError(BrepErrorCode.NULL_SHAPE_INPUT, "revolve: face is a null shape"));
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
324
|
+
try {
|
|
325
|
+
const result = castShape(getKernel().revolveVec(face.wrapped, [...center], [...direction], angle));
|
|
326
|
+
if (!isShape3D(result)) return err(typeCastError("REVOLUTION_NOT_3D", "Revolution did not produce a 3D shape"));
|
|
327
|
+
return ok(result);
|
|
328
|
+
} catch (e) {
|
|
329
|
+
return err(kernelError("REVOLVE_FAILED", "Revolution operation failed", e, {
|
|
330
|
+
operation: "revolve",
|
|
331
|
+
angle
|
|
332
|
+
}));
|
|
333
|
+
}
|
|
327
334
|
}
|
|
328
335
|
/**
|
|
329
336
|
* Batch extrude: build N independent extrusions in a single kernel call.
|
|
@@ -336,24 +343,24 @@ function revolve(face, center = [
|
|
|
336
343
|
function extrudeAll(entries) {
|
|
337
344
|
if (entries.length === 0) return ok([]);
|
|
338
345
|
const kernel = getKernel();
|
|
339
|
-
const kernelEntries =
|
|
346
|
+
const kernelEntries = [];
|
|
347
|
+
for (let i = 0; i < entries.length; i++) {
|
|
348
|
+
const e = entries[i];
|
|
349
|
+
if (!e) continue;
|
|
340
350
|
const vec = typeof e.height === "number" ? [
|
|
341
351
|
0,
|
|
342
352
|
0,
|
|
343
353
|
e.height
|
|
344
354
|
] : e.height;
|
|
345
355
|
const len = vecLength(vec);
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
1
|
|
350
|
-
];
|
|
351
|
-
return {
|
|
356
|
+
if (len < 1e-10) return err(validationError("EXTRUDE_ALL_ZERO_VECTOR", `extrudeAll: entry ${i} has zero-length extrusion vector`));
|
|
357
|
+
const direction = [...vecNormalize(vec)];
|
|
358
|
+
kernelEntries.push({
|
|
352
359
|
face: e.face.wrapped,
|
|
353
360
|
direction,
|
|
354
361
|
length: len
|
|
355
|
-
};
|
|
356
|
-
}
|
|
362
|
+
});
|
|
363
|
+
}
|
|
357
364
|
try {
|
|
358
365
|
return ok((kernel.extrudeBatch?.(kernelEntries) ?? kernelEntries.map((e) => kernel.extrude(e.face, e.direction, e.length))).map((shape) => {
|
|
359
366
|
return createSolid(kernel.downcast(shape, "solid"));
|