@itwin/core-geometry 4.3.0-dev.37 → 4.3.0-dev.39

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.
Files changed (451) hide show
  1. package/lib/cjs/Constant.js.map +1 -1
  2. package/lib/cjs/Geometry.d.ts +14 -2
  3. package/lib/cjs/Geometry.d.ts.map +1 -1
  4. package/lib/cjs/Geometry.js +14 -2
  5. package/lib/cjs/Geometry.js.map +1 -1
  6. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  7. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  8. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  9. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  10. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  11. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  12. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  13. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  14. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  15. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  16. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  17. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  18. package/lib/cjs/bspline/SurfaceLocationDetail.js.map +1 -1
  19. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  20. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  21. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  22. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  23. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  24. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  25. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  26. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  27. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  28. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  29. package/lib/cjs/core-geometry.js.map +1 -1
  30. package/lib/cjs/curve/Arc3d.js.map +1 -1
  31. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  32. package/lib/cjs/curve/CoordinateXYZ.js.map +1 -1
  33. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  34. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  35. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  36. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  37. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  38. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  39. package/lib/cjs/curve/CurveOps.js.map +1 -1
  40. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  41. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  42. package/lib/cjs/curve/CurveTypes.js.map +1 -1
  43. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  44. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  45. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  46. package/lib/cjs/curve/LineString3d.js.map +1 -1
  47. package/lib/cjs/curve/Loop.js.map +1 -1
  48. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  49. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  50. package/lib/cjs/curve/Path.js.map +1 -1
  51. package/lib/cjs/curve/PointString3d.js.map +1 -1
  52. package/lib/cjs/curve/ProxyCurve.js.map +1 -1
  53. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  54. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  55. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  56. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  57. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  58. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  59. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  60. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  61. package/lib/cjs/curve/RegionOps.js.map +1 -1
  62. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  63. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  64. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  65. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  66. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  67. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  68. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  69. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  70. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  71. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  72. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  73. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  74. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  75. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  76. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  77. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  78. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  79. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  80. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  81. package/lib/cjs/curve/internalContexts/SumLengthsContext.js.map +1 -1
  82. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  83. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  84. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  85. package/lib/cjs/curve/spiral/CubicEvaluator.js.map +1 -1
  86. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  87. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  88. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  89. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  90. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  91. package/lib/cjs/curve/spiral/NormalizedTransition.js.map +1 -1
  92. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  93. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  94. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  95. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  96. package/lib/cjs/geometry3d/Angle.d.ts +0 -1
  97. package/lib/cjs/geometry3d/Angle.d.ts.map +1 -1
  98. package/lib/cjs/geometry3d/Angle.js +0 -1
  99. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  100. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  101. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  102. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  103. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  104. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  105. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  106. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  107. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  108. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  109. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  110. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  111. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  112. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  113. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  114. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  115. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  116. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  117. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  118. package/lib/cjs/geometry3d/Plane3d.js.map +1 -1
  119. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  120. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  121. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  122. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  123. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  124. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  125. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  126. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  127. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  128. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  129. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  130. package/lib/cjs/geometry3d/Range.js.map +1 -1
  131. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  132. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  133. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  134. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  135. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  136. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  137. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  138. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  139. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  140. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  141. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  142. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  143. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  144. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  145. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  146. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  147. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  148. package/lib/cjs/numerics/Complex.js.map +1 -1
  149. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  150. package/lib/cjs/numerics/Newton.js.map +1 -1
  151. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  152. package/lib/cjs/numerics/PolarData.js.map +1 -1
  153. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  154. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  155. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  156. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  157. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  158. package/lib/cjs/numerics/UsageSums.js.map +1 -1
  159. package/lib/cjs/polyface/AuxData.js.map +1 -1
  160. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  161. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  162. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  163. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  164. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  165. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  166. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  167. package/lib/cjs/polyface/Polyface.js.map +1 -1
  168. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  169. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  170. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  171. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  172. package/lib/cjs/polyface/RangeLengthData.js.map +1 -1
  173. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  174. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  175. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  176. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  177. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  178. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  179. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  180. package/lib/cjs/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  181. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  182. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  183. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  184. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  185. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  186. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  187. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  188. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  189. package/lib/cjs/serialization/GeometrySamples.js.map +1 -1
  190. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  191. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  192. package/lib/cjs/solid/Box.js.map +1 -1
  193. package/lib/cjs/solid/Cone.js.map +1 -1
  194. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  195. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  196. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  197. package/lib/cjs/solid/SolidPrimitive.js.map +1 -1
  198. package/lib/cjs/solid/Sphere.js.map +1 -1
  199. package/lib/cjs/solid/SweepContour.js.map +1 -1
  200. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  201. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  202. package/lib/cjs/topology/Graph.d.ts +399 -366
  203. package/lib/cjs/topology/Graph.d.ts.map +1 -1
  204. package/lib/cjs/topology/Graph.js +531 -464
  205. package/lib/cjs/topology/Graph.js.map +1 -1
  206. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  207. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  208. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  209. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  210. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  211. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  212. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  213. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  214. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  215. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  216. package/lib/cjs/topology/MaskManager.d.ts +8 -9
  217. package/lib/cjs/topology/MaskManager.d.ts.map +1 -1
  218. package/lib/cjs/topology/MaskManager.js +11 -12
  219. package/lib/cjs/topology/MaskManager.js.map +1 -1
  220. package/lib/cjs/topology/Merging.js.map +1 -1
  221. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  222. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  223. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  224. package/lib/cjs/topology/Triangulation.js.map +1 -1
  225. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  226. package/lib/esm/Constant.js.map +1 -1
  227. package/lib/esm/Geometry.d.ts +14 -2
  228. package/lib/esm/Geometry.d.ts.map +1 -1
  229. package/lib/esm/Geometry.js +14 -2
  230. package/lib/esm/Geometry.js.map +1 -1
  231. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  232. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  233. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  234. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  235. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  236. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  237. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  238. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  239. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  240. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  241. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  242. package/lib/esm/bspline/KnotVector.js.map +1 -1
  243. package/lib/esm/bspline/SurfaceLocationDetail.js.map +1 -1
  244. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  245. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  246. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  247. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  248. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  249. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  250. package/lib/esm/clipping/ClipVector.js.map +1 -1
  251. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  252. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  253. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  254. package/lib/esm/core-geometry.js.map +1 -1
  255. package/lib/esm/curve/Arc3d.js.map +1 -1
  256. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  257. package/lib/esm/curve/CoordinateXYZ.js.map +1 -1
  258. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  259. package/lib/esm/curve/CurveCollection.js.map +1 -1
  260. package/lib/esm/curve/CurveCurve.js.map +1 -1
  261. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  262. package/lib/esm/curve/CurveFactory.js.map +1 -1
  263. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  264. package/lib/esm/curve/CurveOps.js.map +1 -1
  265. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  266. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  267. package/lib/esm/curve/CurveTypes.js.map +1 -1
  268. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  269. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  270. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  271. package/lib/esm/curve/LineString3d.js.map +1 -1
  272. package/lib/esm/curve/Loop.js.map +1 -1
  273. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  274. package/lib/esm/curve/ParityRegion.js.map +1 -1
  275. package/lib/esm/curve/Path.js.map +1 -1
  276. package/lib/esm/curve/PointString3d.js.map +1 -1
  277. package/lib/esm/curve/ProxyCurve.js.map +1 -1
  278. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  279. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  280. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  281. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  282. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  283. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  284. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  285. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  286. package/lib/esm/curve/RegionOps.js.map +1 -1
  287. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  288. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  289. package/lib/esm/curve/UnionRegion.js.map +1 -1
  290. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  291. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  292. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  293. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  294. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  295. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  296. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  297. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  298. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  299. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  300. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  301. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  302. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  303. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  304. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  305. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  306. package/lib/esm/curve/internalContexts/SumLengthsContext.js.map +1 -1
  307. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  308. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  309. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  310. package/lib/esm/curve/spiral/CubicEvaluator.js.map +1 -1
  311. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  312. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  313. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  314. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  315. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  316. package/lib/esm/curve/spiral/NormalizedTransition.js.map +1 -1
  317. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  318. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  319. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  320. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  321. package/lib/esm/geometry3d/Angle.d.ts +0 -1
  322. package/lib/esm/geometry3d/Angle.d.ts.map +1 -1
  323. package/lib/esm/geometry3d/Angle.js +0 -1
  324. package/lib/esm/geometry3d/Angle.js.map +1 -1
  325. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  326. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  327. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  328. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  329. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  330. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  331. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  332. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  333. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  334. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  335. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  336. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  337. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  338. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  339. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  340. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  341. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  342. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  343. package/lib/esm/geometry3d/Plane3d.js.map +1 -1
  344. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  345. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  346. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  347. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  348. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  349. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  350. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  351. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  352. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  353. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  354. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  355. package/lib/esm/geometry3d/Range.js.map +1 -1
  356. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  357. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  358. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  359. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  360. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  361. package/lib/esm/geometry3d/Transform.js.map +1 -1
  362. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  363. package/lib/esm/geometry3d/XYZProps.js.map +1 -1
  364. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  365. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  366. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  367. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  368. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  369. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  370. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  371. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  372. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  373. package/lib/esm/numerics/Complex.js.map +1 -1
  374. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  375. package/lib/esm/numerics/Newton.js.map +1 -1
  376. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  377. package/lib/esm/numerics/PolarData.js.map +1 -1
  378. package/lib/esm/numerics/Polynomials.js.map +1 -1
  379. package/lib/esm/numerics/Quadrature.js.map +1 -1
  380. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  381. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  382. package/lib/esm/numerics/UnionFind.js.map +1 -1
  383. package/lib/esm/numerics/UsageSums.js.map +1 -1
  384. package/lib/esm/polyface/AuxData.js.map +1 -1
  385. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  386. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  387. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  388. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  389. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  390. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  391. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  392. package/lib/esm/polyface/Polyface.js.map +1 -1
  393. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  394. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  395. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  396. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  397. package/lib/esm/polyface/RangeLengthData.js.map +1 -1
  398. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  399. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  400. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  401. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  402. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  403. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  404. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  405. package/lib/esm/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  406. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  407. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  408. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  409. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  410. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  411. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  412. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  413. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  414. package/lib/esm/serialization/GeometrySamples.js.map +1 -1
  415. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  416. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  417. package/lib/esm/solid/Box.js.map +1 -1
  418. package/lib/esm/solid/Cone.js.map +1 -1
  419. package/lib/esm/solid/LinearSweep.js.map +1 -1
  420. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  421. package/lib/esm/solid/RuledSweep.js.map +1 -1
  422. package/lib/esm/solid/SolidPrimitive.js.map +1 -1
  423. package/lib/esm/solid/Sphere.js.map +1 -1
  424. package/lib/esm/solid/SweepContour.js.map +1 -1
  425. package/lib/esm/solid/TorusPipe.js.map +1 -1
  426. package/lib/esm/topology/ChainMerge.js.map +1 -1
  427. package/lib/esm/topology/Graph.d.ts +399 -366
  428. package/lib/esm/topology/Graph.d.ts.map +1 -1
  429. package/lib/esm/topology/Graph.js +531 -464
  430. package/lib/esm/topology/Graph.js.map +1 -1
  431. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  432. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  433. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  434. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  435. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  436. package/lib/esm/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  437. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  438. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  439. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  440. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  441. package/lib/esm/topology/MaskManager.d.ts +8 -9
  442. package/lib/esm/topology/MaskManager.d.ts.map +1 -1
  443. package/lib/esm/topology/MaskManager.js +11 -12
  444. package/lib/esm/topology/MaskManager.js.map +1 -1
  445. package/lib/esm/topology/Merging.js.map +1 -1
  446. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  447. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  448. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  449. package/lib/esm/topology/Triangulation.js.map +1 -1
  450. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  451. package/package.json +3 -3
@@ -1 +1 @@
1
- {"version":3,"file":"XYParitySearchContext.js","sourceRoot":"","sources":["../../../src/topology/XYParitySearchContext.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Topology\r\n */\r\n\r\n/**\r\n * * XYParitySearchContext is an internal class for callers that can feed points (without extracting to array structures)\r\n * * Most will be via static methods which handle a specific data source.\r\n * * PolygonOps.classifyPointInPolygon (x,y,points: XAndY[])\r\n * * HalfEdgeGraphSearch.pointInOrOnFaceXY (halfEdgeOnFace, x, y)\r\n * Use pattern:\r\n * * Caller must be able walk around polygon producing x,y coordinates (possibly transformed from actual polygon)\r\n * * Caller announce edges to tryStartEdge until finding one acceptable to the search.\r\n * * Caller then passes additional points up to and including both x0,y0 and x1, y1 of the accepted start edge.\r\n * Call sequence is:\r\n * `context = new XYParitySearchContext`\r\n * `repeat { acquire edge (x0,y0) (x1,y1)} until context.tryStartEdge (x0,y0,x1,y1);`\r\n * `for each (x,y) beginning AFTER x1,y1 and ending with (x1,y1) context.advance (x,y)`\r\n * `return context.classifyCounts ();`\r\n */\r\nexport class XYParitySearchContext {\r\n public xTest: number;\r\n public yTest: number;\r\n public u0: number; // local coordinates of recent point with nonzero v. Usually \"second last point\" but points can be skipped if y1 is zero\r\n public v0: number;\r\n public u1: number; // local coordinates of most recent point\r\n public v1: number;\r\n public numLeftCrossing: number;\r\n public numRightCrossing: number;\r\n public numHit: number;\r\n /**\r\n * Create a new searcher for specified test point.\r\n * @param xTest x coordinate of test point\r\n * @param yTest y coordinate of test point\r\n */\r\n public constructor(xTest: number, yTest: number) {\r\n this.xTest = xTest;\r\n this.yTest = yTest;\r\n this.u0 = this.v0 = this.u1 = this.v1 = 0; // Not valid for search -- caller must satisfy tryStartEdge !!!\r\n this.numLeftCrossing = this.numRightCrossing = 0;\r\n this.numHit = 0;\r\n }\r\n /**\r\n * test if x,y is a safe first coordinate to start the search.\r\n * * safe start must have non-zero y so that final point test (return to x0,y0) does not need look back for exact crossing logic.\r\n * @param x\r\n * @param y\r\n */\r\n public tryStartEdge(x0: number, y0: number, x1: number, y1: number): boolean {\r\n if (y0 !== this.yTest) {\r\n this.u0 = x0 - this.xTest;\r\n this.v0 = y0 - this.yTest;\r\n this.u1 = x1 - this.xTest;\r\n this.v1 = y1 - this.yTest;\r\n return true;\r\n }\r\n return false;\r\n }\r\n /** Return true if parity accumulation proceeded normally.\r\n * Return false if interrupted for exact hit.\r\n */\r\n public advance(x: number, y: number): boolean {\r\n const u = x - this.xTest;\r\n const v = y - this.yTest;\r\n const p = v * this.v1;\r\n if (p > 0) {\r\n // The common case -- skittering along above or below the x axis . . .\r\n this.u0 = this.u1;\r\n this.v0 = this.v1;\r\n this.u1 = u;\r\n this.v1 = v;\r\n return true;\r\n }\r\n if (p < 0) {\r\n // crossing within (u1,v1) to (u,v)\r\n // both v values are nonzero and of opposite sign, so this division is safe . . .\r\n const fraction = -this.v1 / (v - this.v1);\r\n const uCross = this.u1 + fraction * (u - this.u1);\r\n if (uCross === 0.0) {\r\n this.numHit++;\r\n return false;\r\n }\r\n if (uCross > 0)\r\n this.numRightCrossing++;\r\n else\r\n this.numLeftCrossing++;\r\n this.u0 = this.u1;\r\n this.v0 = this.v1;\r\n this.u1 = u;\r\n this.v1 = v;\r\n return true;\r\n }\r\n // hard stuff -- one or more exact hits . . .\r\n if (v === 0.0) {\r\n if (this.v1 === 0.0) {\r\n // uh oh -- moving along x axis. Does it pass through xTest:\r\n if (u * this.u1 <= 0.0) {\r\n this.numHit++;\r\n return false;\r\n }\r\n // quietly moving along the scan line, both xy and x1y1 to same side of test point ...\r\n // u0 and u1 remain unchanged !!!\r\n this.u1 = u;\r\n this.v1 = v;\r\n return true;\r\n }\r\n // just moved onto the scan line ...\r\n this.u0 = this.u1;\r\n this.v0 = this.v1;\r\n this.u1 = u;\r\n this.v1 = v;\r\n return true;\r\n }\r\n // fall out with v1 = 0\r\n // both v0 and v are nonzero.\r\n // any along-0 v values that have passed through are on the same side of xTest, so u1 determines crossing\r\n const q = this.v0 * v;\r\n if (this.u1 > 0) {\r\n if (q < 0)\r\n this.numRightCrossing++;\r\n } else {\r\n if (q < 0)\r\n this.numLeftCrossing++;\r\n }\r\n this.u0 = this.u1;\r\n this.v0 = this.v1;\r\n this.u1 = u;\r\n this.v1 = v;\r\n return true;\r\n }\r\n /**\r\n * Return classification as ON, IN, or OUT according to hit and crossing counts.\r\n * * Any nonzero hit count is ON\r\n * * Otherwise IN if left crossing count is odd.\r\n * @return 0 if ON, 1 if IN, -1 if OUT\r\n */\r\n public classifyCounts(): number | undefined {\r\n if (this.numHit > 0)\r\n return 0;\r\n const parity = this.numLeftCrossing & 0x01;\r\n return (parity === 1) ? 1 : -1;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"XYParitySearchContext.js","sourceRoot":"","sources":["../../../src/topology/XYParitySearchContext.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\n/** @packageDocumentation\n * @module Topology\n */\n\n/**\n * * XYParitySearchContext is an internal class for callers that can feed points (without extracting to array structures)\n * * Most will be via static methods which handle a specific data source.\n * * PolygonOps.classifyPointInPolygon (x,y,points: XAndY[])\n * * HalfEdgeGraphSearch.pointInOrOnFaceXY (halfEdgeOnFace, x, y)\n * Use pattern:\n * * Caller must be able walk around polygon producing x,y coordinates (possibly transformed from actual polygon)\n * * Caller announce edges to tryStartEdge until finding one acceptable to the search.\n * * Caller then passes additional points up to and including both x0,y0 and x1, y1 of the accepted start edge.\n * Call sequence is:\n * `context = new XYParitySearchContext`\n * `repeat { acquire edge (x0,y0) (x1,y1)} until context.tryStartEdge (x0,y0,x1,y1);`\n * `for each (x,y) beginning AFTER x1,y1 and ending with (x1,y1) context.advance (x,y)`\n * `return context.classifyCounts ();`\n */\nexport class XYParitySearchContext {\n public xTest: number;\n public yTest: number;\n public u0: number; // local coordinates of recent point with nonzero v. Usually \"second last point\" but points can be skipped if y1 is zero\n public v0: number;\n public u1: number; // local coordinates of most recent point\n public v1: number;\n public numLeftCrossing: number;\n public numRightCrossing: number;\n public numHit: number;\n /**\n * Create a new searcher for specified test point.\n * @param xTest x coordinate of test point\n * @param yTest y coordinate of test point\n */\n public constructor(xTest: number, yTest: number) {\n this.xTest = xTest;\n this.yTest = yTest;\n this.u0 = this.v0 = this.u1 = this.v1 = 0; // Not valid for search -- caller must satisfy tryStartEdge !!!\n this.numLeftCrossing = this.numRightCrossing = 0;\n this.numHit = 0;\n }\n /**\n * test if x,y is a safe first coordinate to start the search.\n * * safe start must have non-zero y so that final point test (return to x0,y0) does not need look back for exact crossing logic.\n * @param x\n * @param y\n */\n public tryStartEdge(x0: number, y0: number, x1: number, y1: number): boolean {\n if (y0 !== this.yTest) {\n this.u0 = x0 - this.xTest;\n this.v0 = y0 - this.yTest;\n this.u1 = x1 - this.xTest;\n this.v1 = y1 - this.yTest;\n return true;\n }\n return false;\n }\n /** Return true if parity accumulation proceeded normally.\n * Return false if interrupted for exact hit.\n */\n public advance(x: number, y: number): boolean {\n const u = x - this.xTest;\n const v = y - this.yTest;\n const p = v * this.v1;\n if (p > 0) {\n // The common case -- skittering along above or below the x axis . . .\n this.u0 = this.u1;\n this.v0 = this.v1;\n this.u1 = u;\n this.v1 = v;\n return true;\n }\n if (p < 0) {\n // crossing within (u1,v1) to (u,v)\n // both v values are nonzero and of opposite sign, so this division is safe . . .\n const fraction = -this.v1 / (v - this.v1);\n const uCross = this.u1 + fraction * (u - this.u1);\n if (uCross === 0.0) {\n this.numHit++;\n return false;\n }\n if (uCross > 0)\n this.numRightCrossing++;\n else\n this.numLeftCrossing++;\n this.u0 = this.u1;\n this.v0 = this.v1;\n this.u1 = u;\n this.v1 = v;\n return true;\n }\n // hard stuff -- one or more exact hits . . .\n if (v === 0.0) {\n if (this.v1 === 0.0) {\n // uh oh -- moving along x axis. Does it pass through xTest:\n if (u * this.u1 <= 0.0) {\n this.numHit++;\n return false;\n }\n // quietly moving along the scan line, both xy and x1y1 to same side of test point ...\n // u0 and u1 remain unchanged !!!\n this.u1 = u;\n this.v1 = v;\n return true;\n }\n // just moved onto the scan line ...\n this.u0 = this.u1;\n this.v0 = this.v1;\n this.u1 = u;\n this.v1 = v;\n return true;\n }\n // fall out with v1 = 0\n // both v0 and v are nonzero.\n // any along-0 v values that have passed through are on the same side of xTest, so u1 determines crossing\n const q = this.v0 * v;\n if (this.u1 > 0) {\n if (q < 0)\n this.numRightCrossing++;\n } else {\n if (q < 0)\n this.numLeftCrossing++;\n }\n this.u0 = this.u1;\n this.v0 = this.v1;\n this.u1 = u;\n this.v1 = v;\n return true;\n }\n /**\n * Return classification as ON, IN, or OUT according to hit and crossing counts.\n * * Any nonzero hit count is ON\n * * Otherwise IN if left crossing count is odd.\n * @return 0 if ON, 1 if IN, -1 if OUT\n */\n public classifyCounts(): number | undefined {\n if (this.numHit > 0)\n return 0;\n const parity = this.numLeftCrossing & 0x01;\n return (parity === 1) ? 1 : -1;\n }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@itwin/core-geometry",
3
- "version": "4.3.0-dev.37",
3
+ "version": "4.3.0-dev.39",
4
4
  "description": "iTwin.js Core Geometry library",
5
5
  "main": "lib/cjs/core-geometry.js",
6
6
  "module": "lib/esm/core-geometry.js",
@@ -34,11 +34,11 @@
34
34
  "nyc": "^15.1.0",
35
35
  "rimraf": "^3.0.2",
36
36
  "typescript": "~5.0.2",
37
- "@itwin/build-tools": "4.3.0-dev.37"
37
+ "@itwin/build-tools": "4.3.0-dev.39"
38
38
  },
39
39
  "dependencies": {
40
40
  "flatbuffers": "~1.12.0",
41
- "@itwin/core-bentley": "4.3.0-dev.37"
41
+ "@itwin/core-bentley": "4.3.0-dev.39"
42
42
  },
43
43
  "nyc": {
44
44
  "extends": "./node_modules/@itwin/build-tools/.nycrc",