@woosh/meep-engine 2.110.14 → 2.111.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/meep.cjs +442 -370
- package/build/meep.min.js +1 -1
- package/build/meep.module.js +442 -370
- package/editor/tools/v2/BlenderCameraOrientationGizmo.js +4 -2
- package/package.json +4 -2
- package/src/core/events/signal/Signal.d.ts.map +1 -1
- package/src/core/events/signal/Signal.js +289 -255
- package/src/core/events/signal/SignalHandler.d.ts +7 -2
- package/src/core/events/signal/SignalHandler.d.ts.map +1 -1
- package/src/core/events/signal/SignalHandler.js +12 -6
- package/src/core/events/signal/signal_handler_list_find.d.ts +8 -0
- package/src/core/events/signal/signal_handler_list_find.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_find.js +23 -0
- package/src/core/events/signal/signal_handler_list_last.d.ts +7 -0
- package/src/core/events/signal/signal_handler_list_last.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_last.js +14 -0
- package/src/core/events/signal/signal_handler_list_validate.d.ts +8 -0
- package/src/core/events/signal/signal_handler_list_validate.d.ts.map +1 -0
- package/src/core/events/signal/signal_handler_list_validate.js +29 -0
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.d.ts +2 -3
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.d.ts.map +1 -1
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescription.js +3 -3
- package/src/engine/graphics/ecs/camera/Camera.d.ts.map +1 -1
- package/src/engine/graphics/ecs/camera/Camera.js +2 -2
- package/src/engine/graphics/ecs/camera/CameraSystem.d.ts.map +1 -1
- package/src/engine/graphics/ecs/camera/CameraSystem.js +10 -2
- package/src/engine/graphics/ecs/camera/quaternion_invert_orientation.d.ts +7 -0
- package/src/engine/graphics/ecs/camera/quaternion_invert_orientation.d.ts.map +1 -0
- package/src/engine/graphics/ecs/camera/{InvertQuaternionOrientation.js → quaternion_invert_orientation.js} +6 -5
- package/editor/actions/concrete/ModifyPatchSampler2DAction.spec.js +0 -30
- package/src/core/IdPool.spec.js +0 -29
- package/src/core/UUID.spec.js +0 -8
- package/src/core/binary/32BitEncoder.spec.js +0 -11
- package/src/core/binary/Base64.spec.js +0 -14
- package/src/core/binary/BinaryBuffer.spec.js +0 -324
- package/src/core/binary/BitSet.spec.js +0 -468
- package/src/core/binary/EncodingBinaryBuffer.spec.js +0 -16
- package/src/core/binary/align_32.spec.js +0 -11
- package/src/core/binary/align_4.spec.js +0 -20
- package/src/core/binary/data_view/DataViewStructAccessor.spec.js +0 -20
- package/src/core/binary/de_interleave_2_bits.spec.js +0 -21
- package/src/core/binary/dec2hex.spec.js +0 -13
- package/src/core/binary/hex2dec.spec.js +0 -22
- package/src/core/binary/int32_to_binary_string.spec.js +0 -9
- package/src/core/binary/operations/bitCount.spec.js +0 -19
- package/src/core/binary/operations/ceilPowerOfTwo.spec.js +0 -17
- package/src/core/binary/reverse_bits_uint32.spec.js +0 -18
- package/src/core/binary/split_by_2.spec.js +0 -22
- package/src/core/binary/split_by_3.spec.js +0 -22
- package/src/core/binary/uint8_to_float.spec.js +0 -7
- package/src/core/bvh2/binary/2/BinaryUint32BVH.spec.js +0 -136
- package/src/core/bvh2/bvh3/BVH.spec.js +0 -361
- package/src/core/bvh2/bvh3/BvhClient.spec.js +0 -51
- package/src/core/bvh2/bvh3/ebvh_build_for_geometry_morton.spec.js +0 -60
- package/src/core/bvh2/bvh3/query/bvh_query_leaves_generic.spec.js +0 -22
- package/src/core/bvh2/bvh3/query/bvh_query_leaves_ray.spec.js +0 -64
- package/src/core/bvh2/bvh3/query/bvh_query_user_data_generic.spec.js +0 -29
- package/src/core/bvh2/bvh3/query/bvh_query_user_data_nearest_to_point.spec.js +0 -209
- package/src/core/bvh2/bvh3/query/compute_tight_near_far_clipping_planes.spec.js +0 -41
- package/src/core/cache/Cache.spec.js +0 -277
- package/src/core/cache/FrequencySketch.spec.js +0 -5
- package/src/core/cache/LoadingCache.spec.js +0 -120
- package/src/core/codegen/LineBuilder.spec.js +0 -41
- package/src/core/collection/CuckooFilter.spec.js +0 -111
- package/src/core/collection/RingBuffer.spec.js +0 -59
- package/src/core/collection/Stack.spec.js +0 -63
- package/src/core/collection/array/arrayPickBestElement.spec.js +0 -7
- package/src/core/collection/array/arraySetSortingDiff.spec.js +0 -74
- package/src/core/collection/array/array_contains_duplicates.spec.js +0 -14
- package/src/core/collection/array/array_copy.spec.js +0 -19
- package/src/core/collection/array/array_deduplicate.spec.js +0 -11
- package/src/core/collection/array/array_get_index_in_range.spec.js +0 -16
- package/src/core/collection/array/array_remove_first.spec.js +0 -39
- package/src/core/collection/array/array_shuffle.spec.js +0 -27
- package/src/core/collection/array/binarySearchHighIndex.spec.js +0 -51
- package/src/core/collection/array/isArrayEqual.spec.js +0 -25
- package/src/core/collection/array/typed/is_typed_array_equals.spec.js +0 -71
- package/src/core/collection/array/weightedRandomFromArray.spec.js +0 -22
- package/src/core/collection/heap/BinaryHeap.spec.js +0 -137
- package/src/core/collection/heap/Uint32Heap.spec.js +0 -172
- package/src/core/collection/list/List.spec.js +0 -438
- package/src/core/collection/list/ListForwarder.spec.js +0 -101
- package/src/core/collection/map/HashMap.spec.js +0 -291
- package/src/core/collection/queue/Deque.spec.js +0 -276
- package/src/core/collection/set/HashSet.spec.js +0 -39
- package/src/core/collection/set/compute_set_difference.spec.js +0 -45
- package/src/core/collection/set/compute_set_intersection.spec.js +0 -45
- package/src/core/collection/table/RowFirstTable.spec.js +0 -323
- package/src/core/collection/table/RowFirstTableSpec.spec.js +0 -49
- package/src/core/collection/table/bind/TableRecord.spec.js +0 -27
- package/src/core/color/Color.spec.js +0 -174
- package/src/core/color/YCbCr/YCbCr.spec.js +0 -16
- package/src/core/color/hex/hex2rgb.spec.js +0 -10
- package/src/core/color/hex/rgb2hex.spec.js +0 -13
- package/src/core/color/hsv/hsv2rgb.spec.js +0 -43
- package/src/core/color/kelvin/kelvin_to_rgb.spec.js +0 -61
- package/src/core/color/kelvin/rgb_to_kelvin.spec.js +0 -15
- package/src/core/color/oklab/Okhsv.spec.js +0 -17
- package/src/core/color/oklab/XYZ.spec.js +0 -17
- package/src/core/color/oklab/oklab_to_xyz.spec.js +0 -31
- package/src/core/color/oklab/xyz_to_oklab.spec.js +0 -31
- package/src/core/color/parse_color.spec.js +0 -18
- package/src/core/color/sRGB/sRGB.spec.js +0 -16
- package/src/core/color/xyz/XYZ.spec.js +0 -16
- package/src/core/events/signal/Signal.spec.js +0 -253
- package/src/core/events/signal/SignalBinding.spec.js +0 -58
- package/src/core/fsm/simple/SimpleStateMachine.spec.js +0 -107
- package/src/core/fsm/simple/SimpleStateMachineDescription.spec.js +0 -103
- package/src/core/function/extractFunctionBody.spec.js +0 -15
- package/src/core/geom/2d/Rectangle.spec.js +0 -62
- package/src/core/geom/2d/aabb/AABB2.spec.js +0 -153
- package/src/core/geom/2d/aabb/aabb2_compute_center_from_multiple.spec.js +0 -11
- package/src/core/geom/2d/aabb/aabb2_compute_overlap.spec.js +0 -56
- package/src/core/geom/2d/aabb/aabb2_contains.spec.js +0 -40
- package/src/core/geom/2d/aabb/aabb2_distance_to_point.spec.js +0 -17
- package/src/core/geom/2d/aabb/aabb2_intersects_ray.spec.js +0 -28
- package/src/core/geom/2d/aabb/aabb2_signed_distance_sqr_to_point.spec.js +0 -40
- package/src/core/geom/2d/bvh/BVH2D.spec.js +0 -359
- package/src/core/geom/2d/bvh/bvh2d_query_all_data_by_circle.spec.js +0 -89
- package/src/core/geom/2d/circle/circle_compute_circle_intersection.spec.js +0 -79
- package/src/core/geom/2d/compute_polygon_area_2d.spec.js +0 -10
- package/src/core/geom/2d/compute_triangle_area_2d.spec.js +0 -9
- package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.spec.js +0 -33
- package/src/core/geom/2d/convex-hull/convex_hull_monotone_2d.spec.js +0 -33
- package/src/core/geom/2d/hash-grid/SpatialHashGrid.spec.js +0 -254
- package/src/core/geom/2d/hash-grid/shg_query_elements_circle.spec.js +0 -85
- package/src/core/geom/2d/hash-grid/shg_query_elements_line.spec.js +0 -102
- package/src/core/geom/2d/quad-tree/QuadTreeNode.spec.js +0 -235
- package/src/core/geom/2d/quad-tree/qt_match_data_by_circle.spec.js +0 -86
- package/src/core/geom/2d/quad-tree-binary/QuadTree.spec.js +0 -53
- package/src/core/geom/2d/r-tree/StaticR2Tree.spec.js +0 -62
- package/src/core/geom/2d/spline_bezier2_2d.spec.js +0 -16
- package/src/core/geom/2d/uv_map_circle_to_square.spec.js +0 -28
- package/src/core/geom/2d/uv_map_square_to_circle.spec.js +0 -30
- package/src/core/geom/3d/SurfacePoint3.spec.js +0 -116
- package/src/core/geom/3d/aabb/AABB3.spec.js +0 -257
- package/src/core/geom/3d/aabb/aabb3_array_intersects_point.spec.js +0 -48
- package/src/core/geom/3d/aabb/aabb3_build_corners.spec.js +0 -27
- package/src/core/geom/3d/aabb/aabb3_compute_distance_above_plane_max.spec.js +0 -8
- package/src/core/geom/3d/aabb/aabb3_compute_plane_side.spec.js +0 -25
- package/src/core/geom/3d/aabb/aabb3_corner_edge_mapping.spec.js +0 -39
- package/src/core/geom/3d/aabb/aabb3_edge_corner_mapping.spec.js +0 -32
- package/src/core/geom/3d/aabb/aabb3_expand_array.spec.js +0 -16
- package/src/core/geom/3d/aabb/aabb3_from_v3_array.spec.js +0 -32
- package/src/core/geom/3d/aabb/aabb3_intersects_aabb3.spec.js +0 -115
- package/src/core/geom/3d/aabb/aabb3_intersects_ray.spec.js +0 -161
- package/src/core/geom/3d/aabb/aabb3_matrix4_project.spec.js +0 -54
- package/src/core/geom/3d/aabb/aabb3_raycast.spec.js +0 -37
- package/src/core/geom/3d/aabb/aabb3_score_boxes_SAH.spec.js +0 -14
- package/src/core/geom/3d/cone/computeConePlaneSide.spec.js +0 -13
- package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.spec.js +0 -95
- package/src/core/geom/3d/line/line3_compute_nearest_point_to_point.spec.js +0 -61
- package/src/core/geom/3d/mat4/MATRIX_4_IDENTITY.spec.js +0 -10
- package/src/core/geom/3d/mat4/m4_multiply.spec.js +0 -34
- package/src/core/geom/3d/mat4/m4_multiply_alphatensor.spec.js +0 -35
- package/src/core/geom/3d/morton/v3_morton_encode_transformed.spec.js +0 -20
- package/src/core/geom/3d/normal/hemioct/unit_hemioct.spec.js +0 -41
- package/src/core/geom/3d/normal/octahedron/encoding.spec.js +0 -54
- package/src/core/geom/3d/plane/plane3_projectPoint.spec.js +0 -54
- package/src/core/geom/3d/plane/plane3_slerp.spec.js +0 -209
- package/src/core/geom/3d/ray/ray3_array_compose.spec.js +0 -14
- package/src/core/geom/3d/shape/TransformedShape3D.spec.js +0 -55
- package/src/core/geom/3d/shape/UnitCubeShape3D.spec.js +0 -42
- package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.spec.js +0 -53
- package/src/core/geom/3d/sphere/harmonics/sh3_vector_accumulate.spec.js +0 -27
- package/src/core/geom/3d/sphere/sphere_intersects_point.spec.js +0 -134
- package/src/core/geom/3d/sphere/sphere_intersects_ray.spec.js +0 -60
- package/src/core/geom/3d/sphere/sphere_radius_sqr_from_v3_array_transformed.spec.js +0 -8
- package/src/core/geom/3d/tetrahedra/TetrahedralMesh.spec.js +0 -233
- package/src/core/geom/3d/tetrahedra/compute_bounding_simplex_3d.spec.js +0 -66
- package/src/core/geom/3d/tetrahedra/delaunay/compute_delaunay_tetrahedral_mesh.spec.js +0 -36
- package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_build_from_grid.spec.js +0 -61
- package/src/core/geom/3d/tetrahedra/delaunay/tetrahedral_mesh_compute_sub_determinant.spec.js +0 -30
- package/src/core/geom/3d/tetrahedra/tetrahedron_compute_signed_volume.spec.js +0 -24
- package/src/core/geom/3d/tetrahedra/tetrahedron_contains_point.spec.js +0 -66
- package/src/core/geom/3d/topology/simplify/collapseEdge.spec.js +0 -24
- package/src/core/geom/3d/topology/struct/TopoEdge.spec.js +0 -52
- package/src/core/geom/3d/topology/struct/TopoVertex.spec.js +0 -128
- package/src/core/geom/3d/topology/struct/binary/BinaryElementPool.spec.js +0 -36
- package/src/core/geom/3d/topology/struct/binary/BinaryTopology.spec.js +0 -16
- package/src/core/geom/3d/topology/struct/binary/io/bt_index_geometry_to_topology.spec.js +0 -84
- package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_has_vertex.spec.js +0 -15
- package/src/core/geom/3d/topology/struct/binary/query/bt_mesh_edge_other_vertex.spec.js +0 -16
- package/src/core/geom/3d/triangle/computeTriangleClosestPointToPointBarycentric.spec.js +0 -100
- package/src/core/geom/3d/triangle/computeTriangleRayIntersection.spec.js +0 -25
- package/src/core/geom/3d/triangle/computeTriangleRayIntersectionBarycentric.spec.js +0 -26
- package/src/core/geom/3d/v3_compute_triangle_normal.spec.js +0 -46
- package/src/core/geom/ConicRay.spec.js +0 -24
- package/src/core/geom/Quaternion.spec.js +0 -429
- package/src/core/geom/Vector1.spec.js +0 -74
- package/src/core/geom/Vector2.spec.js +0 -295
- package/src/core/geom/Vector3.spec.js +0 -285
- package/src/core/geom/Vector4.spec.js +0 -11
- package/src/core/geom/normalize_angle_rad.spec.js +0 -45
- package/src/core/geom/packing/computeBoundingSphereOfSpheres.spec.js +0 -24
- package/src/core/geom/packing/max-rect/MaxRectanglesPacker.spec.js +0 -60
- package/src/core/geom/packing/miniball/Miniball.spec.js +0 -35
- package/src/core/geom/packing/miniball/Subspan.spec.js +0 -51
- package/src/core/geom/random/randomPointOnBox.spec.js +0 -57
- package/src/core/geom/vec/vector_normalize.spec.js +0 -15
- package/src/core/geom/vec3/v3_angle_cos_between.spec.js +0 -124
- package/src/core/geom/vec3/v3_displace_in_direction.spec.js +0 -80
- package/src/core/geom/vec3/v3_distance_above_plane.spec.js +0 -40
- package/src/core/graph/Edge.spec.js +0 -85
- package/src/core/graph/SquareMatrix.spec.js +0 -102
- package/src/core/graph/coloring/colorizeGraphGreedy.spec.js +0 -26
- package/src/core/graph/convert_graph_to_dot_string.spec.js +0 -28
- package/src/core/graph/eigen/matrix_eigenvalues_in_place.spec.js +0 -57
- package/src/core/graph/graph_k_means_cluster.spec.js +0 -23
- package/src/core/graph/mn_graph_coarsen.spec.js +0 -45
- package/src/core/graph/v2/Graph.spec.js +0 -364
- package/src/core/json/resolvePath.spec.js +0 -14
- package/src/core/lang/reactive/compileReactiveExpression.spec.js +0 -169
- package/src/core/math/bessel_j0.spec.js +0 -43
- package/src/core/math/clamp.spec.js +0 -15
- package/src/core/math/computeGreatestCommonDivisor.spec.js +0 -9
- package/src/core/math/computeIsoscelesTriangleApexAngle.spec.js +0 -6
- package/src/core/math/computeWholeDivisorLow.spec.js +0 -9
- package/src/core/math/copysign.spec.js +0 -13
- package/src/core/math/epsilonEquals.spec.js +0 -17
- package/src/core/math/factorial.spec.js +0 -9
- package/src/core/math/fract.spec.js +0 -11
- package/src/core/math/hash/computeHashFloatArray.spec.js +0 -11
- package/src/core/math/hash/computeObjectHash.spec.js +0 -42
- package/src/core/math/hash/murmur3_32.spec.js +0 -8
- package/src/core/math/hash/squirrel3.spec.js +0 -16
- package/src/core/math/iabs.spec.js +0 -9
- package/src/core/math/interval/NumericInterval.spec.js +0 -89
- package/src/core/math/interval/isValueBetween.spec.js +0 -11
- package/src/core/math/interval/isValueBetweenInclusive.spec.js +0 -16
- package/src/core/math/interval/overlap1D.spec.js +0 -10
- package/src/core/math/inverseLerp.spec.js +0 -13
- package/src/core/math/isPowerOfTwo.spec.js +0 -9
- package/src/core/math/isqrt.spec.js +0 -9
- package/src/core/math/lerp.spec.js +0 -15
- package/src/core/math/linalg/solve_linear_system.spec.js +0 -70
- package/src/core/math/max.spec.js +0 -25
- package/src/core/math/max2.spec.js +0 -13
- package/src/core/math/max3.spec.js +0 -29
- package/src/core/math/min2.spec.js +0 -37
- package/src/core/math/min3.spec.js +0 -29
- package/src/core/math/newton_solver_1d.spec.js +0 -9
- package/src/core/math/nextOdd.spec.js +0 -9
- package/src/core/math/noise/create_simplex_noise_2d.spec.js +0 -21
- package/src/core/math/noise/sdnoise.spec.js +0 -87
- package/src/core/math/physics/irradiance/interpolate_irradiance_linear.spec.js +0 -20
- package/src/core/math/physics/irradiance/interpolate_irradiance_lograrithmic.spec.js +0 -18
- package/src/core/math/physics/irradiance/interpolate_irradiance_smith.spec.js +0 -20
- package/src/core/math/pingpong.spec.js +0 -11
- package/src/core/math/random/MersenneTwister.spec.js +0 -19
- package/src/core/math/random/randomFloatBetween.spec.js +0 -9
- package/src/core/math/random/randomGaussian.spec.js +0 -9
- package/src/core/math/random/randomIntegerBetween.spec.js +0 -8
- package/src/core/math/random/roundFair.spec.js +0 -12
- package/src/core/math/random/seededRandomMersenneTwister.spec.js +0 -10
- package/src/core/math/random/seededRandom_Mulberry32.spec.js +0 -19
- package/src/core/math/remap.spec.js +0 -15
- package/src/core/math/sign.spec.js +0 -13
- package/src/core/math/smoothStep.spec.js +0 -16
- package/src/core/math/smootherStep.spec.js +0 -16
- package/src/core/math/solveQuadratic.spec.js +0 -18
- package/src/core/math/spline/cubicCurve.spec.js +0 -13
- package/src/core/math/spline/makeCubicCurve.spec.js +0 -9
- package/src/core/math/spline/spline_bezier2.spec.js +0 -13
- package/src/core/math/spline/spline_bezier3_bounds.spec.js +0 -37
- package/src/core/math/spline/spline_hermite3.spec.js +0 -18
- package/src/core/math/spline/spline_hermite3_bounds.spec.js +0 -37
- package/src/core/math/statistics/computeSampleSize_Cochran.spec.js +0 -12
- package/src/core/math/statistics/computeStatisticalMean.spec.js +0 -9
- package/src/core/math/statistics/computeStatisticalPartialMedian.spec.js +0 -13
- package/src/core/math/statistics/computeStatisticalPercentile.spec.js +0 -11
- package/src/core/math/statistics/computeStatisticalVariance.spec.js +0 -10
- package/src/core/math/statistics/halton_sequence.spec.js +0 -40
- package/src/core/math/statistics/radical_inverse_VdC_base_2.spec.js +0 -9
- package/src/core/math/statistics/softmax.spec.js +0 -9
- package/src/core/model/BooleanVector3.spec.js +0 -51
- package/src/core/model/BoundedValue.spec.js +0 -17
- package/src/core/model/ModuleRegistry.spec.js +0 -31
- package/src/core/model/ObservedBoolean.spec.js +0 -81
- package/src/core/model/ObservedInteger.spec.js +0 -51
- package/src/core/model/node-graph/Connection.spec.js +0 -33
- package/src/core/model/node-graph/NodeGraph.spec.js +0 -107
- package/src/core/model/node-graph/node/NodeDescription.spec.js +0 -81
- package/src/core/model/node-graph/node/NodeInstance.spec.js +0 -82
- package/src/core/model/node-graph/node/NodeInstancePortReference.spec.js +0 -109
- package/src/core/model/node-graph/node/NodeRegistry.spec.js +0 -123
- package/src/core/model/node-graph/node/Port.spec.js +0 -102
- package/src/core/model/node-graph/type/DataType.spec.js +0 -47
- package/src/core/model/node-graph/type/ParametricDataType.spec.js +0 -63
- package/src/core/model/node-graph/visual/PortVisualData.spec.js +0 -16
- package/src/core/model/object/ObjectPoolFactory.spec.js +0 -54
- package/src/core/model/object/objectDeepEquals.spec.js +0 -54
- package/src/core/model/object/write_property.spec.js +0 -26
- package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.spec.js +0 -158
- package/src/core/model/reactive/js/compileReactiveToJS.spec.js +0 -14
- package/src/core/model/reactive/model/logic/ReactiveAnd.spec.js +0 -51
- package/src/core/model/reactive/model/logic/ReactiveOr.spec.js +0 -53
- package/src/core/model/reactive/model/terminal/ReactiveReference.spec.js +0 -26
- package/src/core/model/reactive/trigger/BlackboardTrigger.spec.js +0 -24
- package/src/core/model/reactive/trigger/ReactiveTrigger.spec.js +0 -5
- package/src/core/model/stat/LinearModifier.spec.js +0 -96
- package/src/core/model/stat/Stat.spec.js +0 -111
- package/src/core/parser/simple/readHexToken.spec.js +0 -21
- package/src/core/parser/simple/readIdentifierToken.spec.js +0 -32
- package/src/core/parser/simple/readNumberToken.spec.js +0 -17
- package/src/core/parser/simple/readReferenceToken.spec.js +0 -18
- package/src/core/parser/simple/readStringToken.spec.js +0 -57
- package/src/core/parser/simple/readUnsignedIntegerToken.spec.js +0 -6
- package/src/core/path/computeFileExtension.spec.js +0 -13
- package/src/core/path/computePathBase.spec.js +0 -13
- package/src/core/path/computePathDirectory.spec.js +0 -8
- package/src/core/primitives/array/computeStridedIntegerArrayHash.spec.js +0 -28
- package/src/core/primitives/numbers/computeHashFloat.spec.js +0 -14
- package/src/core/primitives/numbers/number_compare_ascending.spec.js +0 -9
- package/src/core/primitives/numbers/number_compare_descending.spec.js +0 -9
- package/src/core/primitives/numbers/number_format_by_thousands.spec.js +0 -12
- package/src/core/primitives/numbers/number_pretty_print.spec.js +0 -19
- package/src/core/primitives/strings/compareStrings.spec.js +0 -12
- package/src/core/primitives/strings/computeStringHash.spec.js +0 -20
- package/src/core/primitives/strings/insert_after.spec.js +0 -16
- package/src/core/primitives/strings/insert_before.spec.js +0 -16
- package/src/core/primitives/strings/string_capitalize.spec.js +0 -13
- package/src/core/primitives/strings/string_compute_common_prefix.spec.js +0 -23
- package/src/core/primitives/strings/string_format_camel_to_kebab.spec.js +0 -8
- package/src/core/primitives/strings/string_jaro_winkler.spec.js +0 -39
- package/src/core/primitives/strings/string_strip_trailing.spec.js +0 -27
- package/src/core/process/PromiseWatcher.spec.js +0 -69
- package/src/core/process/executor/ConcurrentExecutor.spec.js +0 -135
- package/src/core/process/task/util/actionTask.spec.js +0 -14
- package/src/core/process/task/util/countTask.spec.js +0 -18
- package/src/core/process/undo/ActionProcessor.spec.js +0 -64
- package/src/engine/Clock.spec.js +0 -26
- package/src/engine/Engine.spec.js +0 -15
- package/src/engine/achievements/Achievement.spec.js +0 -21
- package/src/engine/animation/curve/AnimationCurve.spec.js +0 -248
- package/src/engine/animation/curve/Keyframe.spec.js +0 -42
- package/src/engine/animation/curve/animation_curve_optimize.spec.js +0 -50
- package/src/engine/animation/curve/compression/downsample_float_array_curve_by_error.spec.js +0 -47
- package/src/engine/animation/curve/compression/sample_animation_curve_to_float_array.spec.js +0 -29
- package/src/engine/animation/keyed2/AnimationTrackPlayback.spec.js +0 -94
- package/src/engine/asset/AssetDescription.spec.js +0 -27
- package/src/engine/asset/AssetManager.spec.js +0 -50
- package/src/engine/asset/loaders/image/png/PNG.spec.js +0 -5
- package/src/engine/asset/loaders/image/png/PNGReader.spec.js +0 -5
- package/src/engine/asset/loaders/image/png/crc.spec.js +0 -15
- package/src/engine/control/ControlContext.spec.js +0 -81
- package/src/engine/ecs/Entity.spec.js +0 -188
- package/src/engine/ecs/EntityBlueprint.spec.js +0 -52
- package/src/engine/ecs/EntityComponentDataset.spec.js +0 -895
- package/src/engine/ecs/EntityManager.spec.js +0 -210
- package/src/engine/ecs/EntityObserver.spec.js +0 -184
- package/src/engine/ecs/animation/Animation.spec.js +0 -22
- package/src/engine/ecs/animation/AnimationClip.spec.js +0 -5
- package/src/engine/ecs/components/Tag.spec.js +0 -47
- package/src/engine/ecs/dynamic_actions/rules/DynamicRuleDescriptionTable.spec.js +0 -126
- package/src/engine/ecs/fow/FogOfWar.spec.js +0 -13
- package/src/engine/ecs/guid/UUID.spec.js +0 -100
- package/src/engine/ecs/guid/UUIDSerializationAdapter.spec.js +0 -21
- package/src/engine/ecs/parent/EntityNode.spec.js +0 -104
- package/src/engine/ecs/renderable/Renderable.spec.js +0 -10
- package/src/engine/ecs/storage/binary/BinarySerializationRegistry.spec.js +0 -139
- package/src/engine/ecs/storage/binary/collection/BinaryCollectionSerialization.spec.js +0 -259
- package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter.spec.js +0 -59
- package/src/engine/ecs/storage/binary/object/BinaryObjectSerializationAdapter2.spec.js +0 -123
- package/src/engine/ecs/terrain/ecs/Terrain.spec.js +0 -5
- package/src/engine/ecs/terrain/ecs/cling/ClingToTerrainSystem.spec.js +0 -38
- package/src/engine/ecs/terrain/overlay/TerrainOverlay.spec.js +0 -6
- package/src/engine/ecs/terrain/tiles/TerrainTile.spec.js +0 -25
- package/src/engine/ecs/tooltip/TooltipComponent.spec.js +0 -47
- package/src/engine/ecs/transform/Transform.spec.js +0 -310
- package/src/engine/ecs/transform/TransformSerializationAdapter.spec.js +0 -28
- package/src/engine/ecs/transform-attachment/TransformAttachment.spec.js +0 -103
- package/src/engine/graphics/ecs/animation/animator/graph/AnimationGraph.spec.js +0 -5
- package/src/engine/graphics/ecs/animation/animator/graph/definition/AnimationGraphDefinition.spec.js +0 -5
- package/src/engine/graphics/ecs/camera/InvertQuaternionOrientation.d.ts +0 -7
- package/src/engine/graphics/ecs/camera/InvertQuaternionOrientation.d.ts.map +0 -1
- package/src/engine/graphics/ecs/camera/topdown/TopDownCameraController.spec.js +0 -94
- package/src/engine/graphics/ecs/decal/v2/Decal.spec.js +0 -5
- package/src/engine/graphics/ecs/mesh-v2/ShadedGeometry.spec.js +0 -19
- package/src/engine/graphics/ecs/mesh-v2/aggregate/SGMesh.spec.js +0 -5
- package/src/engine/graphics/ecs/mesh-v2/render/adapters/SGCacheKey.spec.js +0 -79
- package/src/engine/graphics/ecs/path/tube/TubePathStyle.spec.js +0 -5
- package/src/engine/graphics/ecs/path/tube/build/build_geometry_catmullrom.spec.js +0 -32
- package/src/engine/graphics/geometry/MikkT/MikkTSpace.spec.js +0 -28
- package/src/engine/graphics/geometry/bvh/buffered/bvh32_from_unindexed_geometry.spec.js +0 -22
- package/src/engine/graphics/particles/particular/engine/MovingBoundingBox.spec.js +0 -70
- package/src/engine/graphics/particles/particular/engine/emitter/ParticleEmitter.spec.js +0 -47
- package/src/engine/graphics/particles/particular/engine/emitter/ParticleLayer.spec.js +0 -100
- package/src/engine/graphics/particles/particular/engine/emitter/ParticlePool.spec.js +0 -225
- package/src/engine/graphics/particles/particular/engine/parameter/ParameterLookupTable.spec.js +0 -215
- package/src/engine/graphics/particles/particular/engine/parameter/ParameterSet.spec.js +0 -75
- package/src/engine/graphics/particles/particular/group/ParticleGroup.spec.js +0 -270
- package/src/engine/graphics/render/buffer/slot/parameter/ProgramValueSlotParameter.spec.js +0 -21
- package/src/engine/graphics/render/forward_plus/LightManager.spec.js +0 -94
- package/src/engine/graphics/render/forward_plus/cluster/write_cluster_planes.spec.js +0 -79
- package/src/engine/graphics/render/visibility/IncrementalDeltaSet.spec.js +0 -102
- package/src/engine/graphics/texture/atlas/CachingTextureAtlas.spec.js +0 -78
- package/src/engine/graphics/texture/atlas/TextureAtlas.spec.js +0 -319
- package/src/engine/graphics/texture/sampler/HarmonicDiffusionGrid.spec.js +0 -99
- package/src/engine/graphics/texture/sampler/Sampler2D.spec.js +0 -224
- package/src/engine/graphics/texture/sampler/copy_Sampler2D_channel_data.spec.js +0 -90
- package/src/engine/graphics/texture/sampler/distance/computeSignedDistanceField_NaiveFlood.spec.js +0 -183
- package/src/engine/graphics/texture/sampler/distance/computeUnsignedDistanceField.spec.js +0 -183
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale.spec.js +0 -73
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_lanczos.spec.js +0 -31
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_linear.spec.js +0 -44
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_down_mipmap.spec.js +0 -13
- package/src/engine/graphics/texture/sampler/resize/sampler2d_scale_up_linear.spec.js +0 -14
- package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_max.spec.js +0 -40
- package/src/engine/graphics/texture/sampler/sampler2d_channel_compute_min_indices.spec.js +0 -15
- package/src/engine/graphics/texture/sampler/sampler2d_copy_with_margins.spec.js +0 -31
- package/src/engine/graphics/texture/sampler/sampler2d_to_data_url.spec.js +0 -10
- package/src/engine/graphics/texture/sampler/sampler2d_to_uint8_RGBA.spec.js +0 -52
- package/src/engine/graphics/texture/sampler/serialization/TextureBinaryBufferSerializer.spec.js +0 -38
- package/src/engine/graphics/three/expand_aabb_by_transformed_three_object.spec.js +0 -108
- package/src/engine/graphics/trail/x/RibbonX.spec.js +0 -5
- package/src/engine/grid/obstacle/GridObstacle.spec.js +0 -175
- package/src/engine/input/devices/InputDeviceSwitch.spec.js +0 -5
- package/src/engine/input/devices/KeyboardDevice.spec.js +0 -12
- package/src/engine/input/devices/PointerDevice.spec.js +0 -12
- package/src/engine/intelligence/behavior/Behavior.spec.js +0 -15
- package/src/engine/intelligence/behavior/SelectorBehavior.spec.js +0 -18
- package/src/engine/intelligence/behavior/behavior_to_dot.spec.js +0 -25
- package/src/engine/intelligence/behavior/composite/ParallelBehavior.spec.js +0 -166
- package/src/engine/intelligence/behavior/composite/SequenceBehavior.spec.js +0 -17
- package/src/engine/intelligence/behavior/decorator/RepeatBehavior.spec.js +0 -32
- package/src/engine/intelligence/behavior/ecs/BehaviorSystem.spec.js +0 -75
- package/src/engine/intelligence/behavior/util/ConditionBehavior.spec.js +0 -24
- package/src/engine/intelligence/blackboard/Blackboard.spec.js +0 -111
- package/src/engine/intelligence/blackboard/BlackboardSerializationAdapter.spec.js +0 -30
- package/src/engine/intelligence/blackboard/make_blackboard_proxy.spec.js +0 -23
- package/src/engine/intelligence/mcts/MonteCarlo.spec.js +0 -244
- package/src/engine/intelligence/mcts/StateNode.spec.js +0 -49
- package/src/engine/intelligence/optimization/RandomOptimizer.spec.js +0 -57
- package/src/engine/intelligence/resource/ResourceAllocationSolver.spec.js +0 -104
- package/src/engine/intelligence/resource/StrategicResourceAllocator.spec.js +0 -46
- package/src/engine/knowledge/database/StaticKnowledgeDataTable.spec.js +0 -26
- package/src/engine/knowledge/database/StaticKnowledgeDatabase.spec.js +0 -23
- package/src/engine/navigation/ecs/components/Path.spec.js +0 -195
- package/src/engine/navigation/ecs/path_following/PathFollower.spec.js +0 -27
- package/src/engine/navigation/grid/find_path_on_grid_astar.spec.js +0 -87
- package/src/engine/notify/NotificationLog.spec.js +0 -17
- package/src/engine/options/Option.spec.js +0 -69
- package/src/engine/options/OptionGroup.spec.js +0 -61
- package/src/engine/physics/gjk/expanding_polytope_algorithm.spec.js +0 -46
- package/src/engine/physics/inverse_kinematics/fabrik/fabrik3d_solve_primitive.spec.js +0 -43
- package/src/engine/plugin/EnginePlugin.spec.js +0 -5
- package/src/engine/reference/v2/Reference.spec.js +0 -44
- package/src/engine/scene/Scene.spec.js +0 -20
- package/src/engine/scene/SceneManager.spec.js +0 -131
- package/src/engine/sound/ecs/emitter/SoundEmitterSerializationAdapter.spec.js +0 -49
- package/src/engine/ui/tiles2d/TileGrid.spec.js +0 -20
- package/src/engine/ui/tiles2d/computeTileGridMove.spec.js +0 -54
- package/src/generation/automata/CaveGeneratorCellularAutomata.spec.js +0 -12
- package/src/generation/filtering/numeric/complex/CellFilterAngleToNormal.spec.js +0 -30
- package/src/generation/filtering/numeric/complex/CellFilterGaussianBlur.spec.js +0 -17
- package/src/generation/filtering/numeric/process/computeCellFilterGradient.spec.js +0 -288
- package/src/generation/grid/GridData.spec.js +0 -46
- package/src/generation/markers/actions/probability/MarkerNodeActionSelectWeighted.spec.js +0 -116
- package/src/generation/markers/transform/MarkerNodeTransformerYRotateByFilterGradient.spec.js +0 -106
- package/src/generation/placement/action/GridCellActionPlaceTags.spec.js +0 -21
- package/src/generation/rules/CellMatcherLayerBitMaskTest.spec.js +0 -22
- package/src/generation/rules/cell/GridPatternMatcher.spec.js +0 -285
- package/src/generation/theme/ThemeEngine.spec.js +0 -7
- package/src/view/tooltip/gml/TooltipParser.spec.js +0 -142
|
@@ -1,17 +1,8 @@
|
|
|
1
1
|
import { assert } from "../../assert.js";
|
|
2
|
-
import {
|
|
3
|
-
import { findSignalHandlerIndexByHandle } from "./findSignalHandlerIndexByHandle.js";
|
|
4
|
-
import { findSignalHandlerIndexByHandleAndContext } from "./findSignalHandlerIndexByHandleAndContext.js";
|
|
2
|
+
import { signal_handler_list_find } from "./signal_handler_list_find.js";
|
|
5
3
|
import { SignalFlags } from "./SignalFlags.js";
|
|
6
4
|
import { SignalHandler, SignalHandlerFlags } from "./SignalHandler.js";
|
|
7
5
|
|
|
8
|
-
/**
|
|
9
|
-
* Common dispatch stack
|
|
10
|
-
* @readonly
|
|
11
|
-
* @type {SignalHandler[]}
|
|
12
|
-
*/
|
|
13
|
-
const dispatch_stack = [];
|
|
14
|
-
let dispatch_stack_top = 0;
|
|
15
6
|
|
|
16
7
|
/**
|
|
17
8
|
* Signal is a type of event bus. You can subscribe to events using {@link add} method and dispatch using sendN method where N is the number of arguments you wish to pass
|
|
@@ -20,10 +11,11 @@ let dispatch_stack_top = 0;
|
|
|
20
11
|
*/
|
|
21
12
|
export class Signal {
|
|
22
13
|
/**
|
|
14
|
+
* Map is used to speed up lookup when removing handlers in case of large number of listeners.
|
|
23
15
|
* @private
|
|
24
|
-
* @type {SignalHandler
|
|
16
|
+
* @type {Map<function,SignalHandler>}
|
|
25
17
|
*/
|
|
26
|
-
handlers =
|
|
18
|
+
handlers = new Map();
|
|
27
19
|
|
|
28
20
|
/**
|
|
29
21
|
* Internal flag bitmask
|
|
@@ -100,9 +92,15 @@ export class Signal {
|
|
|
100
92
|
contains(handler, thisArg) {
|
|
101
93
|
const handlers = this.handlers;
|
|
102
94
|
|
|
103
|
-
const
|
|
95
|
+
const sh = handlers.get(handler);
|
|
96
|
+
|
|
97
|
+
if (sh === undefined) {
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
104
100
|
|
|
105
|
-
|
|
101
|
+
const existing = signal_handler_list_find(sh, handler, thisArg);
|
|
102
|
+
|
|
103
|
+
return existing !== null;
|
|
106
104
|
}
|
|
107
105
|
|
|
108
106
|
mute() {
|
|
@@ -118,7 +116,7 @@ export class Signal {
|
|
|
118
116
|
* @returns {boolean}
|
|
119
117
|
*/
|
|
120
118
|
hasHandlers() {
|
|
121
|
-
return this.handlers.
|
|
119
|
+
return this.handlers.size > 0;
|
|
122
120
|
}
|
|
123
121
|
|
|
124
122
|
/**
|
|
@@ -133,7 +131,7 @@ export class Signal {
|
|
|
133
131
|
|
|
134
132
|
handler.setFlag(SignalHandlerFlags.RemoveAfterExecution);
|
|
135
133
|
|
|
136
|
-
this
|
|
134
|
+
this.#add_handler(handler);
|
|
137
135
|
}
|
|
138
136
|
|
|
139
137
|
/**
|
|
@@ -144,15 +142,36 @@ export class Signal {
|
|
|
144
142
|
add(h, context) {
|
|
145
143
|
assert.isFunction(h, "handler");
|
|
146
144
|
|
|
147
|
-
// if (!ENV_PRODUCTION) {
|
|
148
|
-
// if (this.handlers.length + 1 === 100) {
|
|
149
|
-
// console.error(`Number of handlers has is 100 now, possible leak detected`);
|
|
150
|
-
// }
|
|
151
|
-
// }
|
|
152
|
-
|
|
153
145
|
const handler = new SignalHandler(h, context);
|
|
154
146
|
|
|
155
|
-
this
|
|
147
|
+
this.#add_handler(handler);
|
|
148
|
+
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
/**
|
|
152
|
+
*
|
|
153
|
+
* @param {SignalHandler} handler
|
|
154
|
+
*/
|
|
155
|
+
#add_handler(handler) {
|
|
156
|
+
|
|
157
|
+
const f = handler.handle;
|
|
158
|
+
const first = this.handlers.get(f);
|
|
159
|
+
|
|
160
|
+
if (first === undefined) {
|
|
161
|
+
this.handlers.set(f, handler);
|
|
162
|
+
} else {
|
|
163
|
+
|
|
164
|
+
handler.next = first;
|
|
165
|
+
this.handlers.set(f,handler);
|
|
166
|
+
|
|
167
|
+
// const last = signal_handler_list_last(first);
|
|
168
|
+
|
|
169
|
+
// last.next = handler;
|
|
170
|
+
|
|
171
|
+
// assert.ok(signal_handler_list_validate(first, console.error), 'invalid configuration');
|
|
172
|
+
|
|
173
|
+
}
|
|
174
|
+
|
|
156
175
|
}
|
|
157
176
|
|
|
158
177
|
/**
|
|
@@ -164,11 +183,44 @@ export class Signal {
|
|
|
164
183
|
remove(h, thisArg) {
|
|
165
184
|
assert.isFunction(h, "handler");
|
|
166
185
|
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
return
|
|
186
|
+
const first = this.handlers.get(h);
|
|
187
|
+
|
|
188
|
+
if (first === undefined) {
|
|
189
|
+
return false;
|
|
171
190
|
}
|
|
191
|
+
|
|
192
|
+
if (first.handle === h && first.context === thisArg) {
|
|
193
|
+
if (first.next === null) {
|
|
194
|
+
this.handlers.delete(h);
|
|
195
|
+
} else {
|
|
196
|
+
this.handlers.set(h, first.next)
|
|
197
|
+
// assert.ok(signal_handler_list_validate(first.next, console.error), 'invalid configuration');
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
return true;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
let previous = first;
|
|
204
|
+
let n = first.next;
|
|
205
|
+
|
|
206
|
+
while (n !== null) {
|
|
207
|
+
|
|
208
|
+
if (n.handle === h && n.context === thisArg) {
|
|
209
|
+
|
|
210
|
+
previous.next = n.next;
|
|
211
|
+
|
|
212
|
+
// assert.ok(signal_handler_list_validate(first, console.error), 'invalid configuration');
|
|
213
|
+
|
|
214
|
+
return true;
|
|
215
|
+
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
previous = n;
|
|
219
|
+
n = n.next;
|
|
220
|
+
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
return false;
|
|
172
224
|
}
|
|
173
225
|
|
|
174
226
|
/**
|
|
@@ -179,8 +231,58 @@ export class Signal {
|
|
|
179
231
|
* @deprecated
|
|
180
232
|
*/
|
|
181
233
|
removeAll() {
|
|
182
|
-
|
|
183
|
-
|
|
234
|
+
this.handlers.clear();
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
/**
|
|
238
|
+
*
|
|
239
|
+
* @param {SignalHandler} handler
|
|
240
|
+
*/
|
|
241
|
+
#remove_handler_internal(handler) {
|
|
242
|
+
|
|
243
|
+
const first = this.handlers.get(handler.handle);
|
|
244
|
+
|
|
245
|
+
if (first === undefined) {
|
|
246
|
+
// nothing
|
|
247
|
+
return false;
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
// special case for first
|
|
251
|
+
if (first === handler) {
|
|
252
|
+
|
|
253
|
+
if (first.next === null) {
|
|
254
|
+
// was the only one
|
|
255
|
+
this.handlers.delete(handler.handle);
|
|
256
|
+
} else {
|
|
257
|
+
this.handlers.set(handler.handle, first.next);
|
|
258
|
+
// assert.ok(signal_handler_list_validate(first.next, console.error), 'invalid configuration');
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
return true;
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
let previous = first;
|
|
265
|
+
let n = first.next;
|
|
266
|
+
|
|
267
|
+
while (n !== null) {
|
|
268
|
+
|
|
269
|
+
const next = n.next;
|
|
270
|
+
|
|
271
|
+
if (n === handler) {
|
|
272
|
+
previous.next = next;
|
|
273
|
+
|
|
274
|
+
// assert.ok(signal_handler_list_validate(first, console.error), 'invalid configuration');
|
|
275
|
+
|
|
276
|
+
return true;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
previous = n;
|
|
280
|
+
n = next;
|
|
281
|
+
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
// not found
|
|
285
|
+
return false;
|
|
184
286
|
}
|
|
185
287
|
|
|
186
288
|
/**
|
|
@@ -193,10 +295,39 @@ export class Signal {
|
|
|
193
295
|
return;
|
|
194
296
|
}
|
|
195
297
|
|
|
196
|
-
|
|
298
|
+
const handlers = this.handlers;
|
|
299
|
+
|
|
300
|
+
for (const handle of handlers.values()) {
|
|
301
|
+
|
|
302
|
+
let _h = handle;
|
|
303
|
+
|
|
304
|
+
do {
|
|
305
|
+
|
|
306
|
+
const next = _h.next;
|
|
307
|
+
|
|
308
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
309
|
+
//handler should be cut
|
|
310
|
+
this.#remove_handler_internal(_h);
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
const _f = _h.handle;
|
|
314
|
+
|
|
315
|
+
try {
|
|
316
|
+
_f.apply(_h.context, args)
|
|
317
|
+
} catch (e) {
|
|
318
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
_h = next;
|
|
322
|
+
|
|
323
|
+
} while (_h !== null);
|
|
324
|
+
|
|
325
|
+
|
|
326
|
+
}
|
|
197
327
|
|
|
198
328
|
}
|
|
199
329
|
|
|
330
|
+
|
|
200
331
|
/**
|
|
201
332
|
* dispatch without a value.
|
|
202
333
|
* Allows JS engine to optimize for monomorphic call sites
|
|
@@ -209,42 +340,34 @@ export class Signal {
|
|
|
209
340
|
|
|
210
341
|
const handlers = this.handlers;
|
|
211
342
|
|
|
212
|
-
const
|
|
343
|
+
for (const handle of handlers.values()) {
|
|
213
344
|
|
|
214
|
-
|
|
215
|
-
const stack_frame_end = stack_pointer + length;
|
|
216
|
-
dispatch_stack_top = stack_frame_end;
|
|
345
|
+
let _h = handle;
|
|
217
346
|
|
|
218
|
-
|
|
347
|
+
do {
|
|
219
348
|
|
|
220
|
-
|
|
221
|
-
for (i = 0; i < length; i++) {
|
|
222
|
-
//copy to proxy
|
|
223
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
224
|
-
}
|
|
349
|
+
const next = _h.next;
|
|
225
350
|
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
351
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
352
|
+
//handler should be cut
|
|
353
|
+
this.#remove_handler_internal(_h);
|
|
354
|
+
}
|
|
229
355
|
|
|
230
|
-
|
|
231
|
-
//handler should be cut
|
|
232
|
-
const p = handlers.indexOf(h);
|
|
233
|
-
handlers.splice(p, 1);
|
|
234
|
-
}
|
|
356
|
+
const _f = _h.handle;
|
|
235
357
|
|
|
236
|
-
|
|
358
|
+
try {
|
|
359
|
+
_f.call(_h.context)
|
|
360
|
+
} catch (e) {
|
|
361
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
362
|
+
}
|
|
363
|
+
|
|
364
|
+
_h = next;
|
|
365
|
+
|
|
366
|
+
} while (_h !== null);
|
|
237
367
|
|
|
238
|
-
try {
|
|
239
|
-
f.call(h.context)
|
|
240
|
-
} catch (e) {
|
|
241
|
-
console.error("Failed to dispatch handler", f, e);
|
|
242
|
-
}
|
|
243
368
|
|
|
244
369
|
}
|
|
245
370
|
|
|
246
|
-
//drop stack frame
|
|
247
|
-
dispatch_stack_top = stack_pointer;
|
|
248
371
|
}
|
|
249
372
|
|
|
250
373
|
/**
|
|
@@ -260,43 +383,34 @@ export class Signal {
|
|
|
260
383
|
|
|
261
384
|
const handlers = this.handlers;
|
|
262
385
|
|
|
263
|
-
const
|
|
386
|
+
for (const handle of handlers.values()) {
|
|
264
387
|
|
|
265
|
-
|
|
266
|
-
const stack_frame_end = stack_pointer + length;
|
|
267
|
-
dispatch_stack_top = stack_frame_end;
|
|
388
|
+
let _h = handle;
|
|
268
389
|
|
|
390
|
+
do {
|
|
269
391
|
|
|
270
|
-
|
|
392
|
+
const next = _h.next;
|
|
271
393
|
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
}
|
|
394
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
395
|
+
//handler should be cut
|
|
396
|
+
this.#remove_handler_internal(_h);
|
|
397
|
+
}
|
|
277
398
|
|
|
278
|
-
|
|
279
|
-
for (i = stack_frame_end - 1; i >= stack_pointer; i--) {
|
|
280
|
-
h = dispatch_stack[i];
|
|
399
|
+
const _f = _h.handle;
|
|
281
400
|
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
401
|
+
try {
|
|
402
|
+
_f.call(_h.context, arg)
|
|
403
|
+
} catch (e) {
|
|
404
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
405
|
+
}
|
|
287
406
|
|
|
288
|
-
|
|
407
|
+
_h = next;
|
|
408
|
+
|
|
409
|
+
} while (_h !== null);
|
|
289
410
|
|
|
290
|
-
try {
|
|
291
|
-
f.call(h.context, arg)
|
|
292
|
-
} catch (e) {
|
|
293
|
-
console.error("Failed to dispatch handler", f, e);
|
|
294
|
-
}
|
|
295
411
|
|
|
296
412
|
}
|
|
297
413
|
|
|
298
|
-
//drop stack frame
|
|
299
|
-
dispatch_stack_top = stack_pointer;
|
|
300
414
|
}
|
|
301
415
|
|
|
302
416
|
/**
|
|
@@ -312,42 +426,33 @@ export class Signal {
|
|
|
312
426
|
|
|
313
427
|
const handlers = this.handlers;
|
|
314
428
|
|
|
315
|
-
const
|
|
429
|
+
for (const handle of handlers.values()) {
|
|
316
430
|
|
|
317
|
-
|
|
318
|
-
const stack_frame_end = stack_pointer + length;
|
|
319
|
-
dispatch_stack_top = stack_frame_end;
|
|
431
|
+
let _h = handle;
|
|
320
432
|
|
|
321
|
-
|
|
433
|
+
do {
|
|
322
434
|
|
|
323
|
-
|
|
324
|
-
for (i = 0; i < length; i++) {
|
|
325
|
-
//copy to proxy
|
|
326
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
327
|
-
}
|
|
435
|
+
const next = _h.next;
|
|
328
436
|
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
437
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
438
|
+
//handler should be cut
|
|
439
|
+
this.#remove_handler_internal(_h);
|
|
440
|
+
}
|
|
332
441
|
|
|
333
|
-
|
|
334
|
-
//handler should be cut
|
|
335
|
-
const p = handlers.indexOf(h);
|
|
336
|
-
handlers.splice(p, 1);
|
|
337
|
-
}
|
|
442
|
+
const _f = _h.handle;
|
|
338
443
|
|
|
339
|
-
|
|
444
|
+
try {
|
|
445
|
+
_f.call(_h.context, a, b)
|
|
446
|
+
} catch (e) {
|
|
447
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
448
|
+
}
|
|
340
449
|
|
|
341
|
-
|
|
342
|
-
f.call(h.context, a, b)
|
|
343
|
-
} catch (e) {
|
|
344
|
-
console.error("Failed to dispatch handler", f, e);
|
|
345
|
-
}
|
|
450
|
+
_h = next;
|
|
346
451
|
|
|
347
|
-
|
|
452
|
+
} while (_h !== null);
|
|
348
453
|
|
|
349
|
-
|
|
350
|
-
|
|
454
|
+
|
|
455
|
+
}
|
|
351
456
|
}
|
|
352
457
|
|
|
353
458
|
/**
|
|
@@ -362,44 +467,36 @@ export class Signal {
|
|
|
362
467
|
return;
|
|
363
468
|
}
|
|
364
469
|
|
|
470
|
+
|
|
365
471
|
const handlers = this.handlers;
|
|
366
472
|
|
|
367
|
-
const
|
|
473
|
+
for (const handle of handlers.values()) {
|
|
368
474
|
|
|
369
|
-
|
|
370
|
-
const stack_frame_end = stack_pointer + length;
|
|
371
|
-
dispatch_stack_top = stack_frame_end;
|
|
475
|
+
let _h = handle;
|
|
372
476
|
|
|
373
|
-
|
|
477
|
+
do {
|
|
374
478
|
|
|
375
|
-
|
|
376
|
-
for (i = 0; i < length; i++) {
|
|
377
|
-
//copy to proxy
|
|
378
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
379
|
-
}
|
|
479
|
+
const next = _h.next;
|
|
380
480
|
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
481
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
482
|
+
//handler should be cut
|
|
483
|
+
this.#remove_handler_internal(_h);
|
|
484
|
+
}
|
|
384
485
|
|
|
385
|
-
|
|
386
|
-
//handler should be cut
|
|
387
|
-
const p = handlers.indexOf(h);
|
|
388
|
-
handlers.splice(p, 1);
|
|
389
|
-
}
|
|
486
|
+
const _f = _h.handle;
|
|
390
487
|
|
|
391
|
-
|
|
488
|
+
try {
|
|
489
|
+
_f.call(_h.context, a, b, c)
|
|
490
|
+
} catch (e) {
|
|
491
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
492
|
+
}
|
|
392
493
|
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
}
|
|
396
|
-
console.error("Failed to dispatch handler", f, e);
|
|
397
|
-
}
|
|
494
|
+
_h = next;
|
|
495
|
+
|
|
496
|
+
} while (_h !== null);
|
|
398
497
|
|
|
399
|
-
}
|
|
400
498
|
|
|
401
|
-
|
|
402
|
-
dispatch_stack_top = stack_pointer;
|
|
499
|
+
}
|
|
403
500
|
}
|
|
404
501
|
|
|
405
502
|
/**
|
|
@@ -415,44 +512,36 @@ export class Signal {
|
|
|
415
512
|
return;
|
|
416
513
|
}
|
|
417
514
|
|
|
515
|
+
|
|
418
516
|
const handlers = this.handlers;
|
|
419
517
|
|
|
420
|
-
const
|
|
518
|
+
for (const handle of handlers.values()) {
|
|
421
519
|
|
|
422
|
-
|
|
423
|
-
const stack_frame_end = stack_pointer + length;
|
|
424
|
-
dispatch_stack_top = stack_frame_end;
|
|
520
|
+
let _h = handle;
|
|
425
521
|
|
|
426
|
-
|
|
522
|
+
do {
|
|
427
523
|
|
|
428
|
-
|
|
429
|
-
for (i = 0; i < length; i++) {
|
|
430
|
-
//copy to proxy
|
|
431
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
432
|
-
}
|
|
524
|
+
const next = _h.next;
|
|
433
525
|
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
526
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
527
|
+
//handler should be cut
|
|
528
|
+
this.#remove_handler_internal(_h);
|
|
529
|
+
}
|
|
437
530
|
|
|
438
|
-
|
|
439
|
-
//handler should be cut
|
|
440
|
-
const p = handlers.indexOf(h);
|
|
441
|
-
handlers.splice(p, 1);
|
|
442
|
-
}
|
|
531
|
+
const _f = _h.handle;
|
|
443
532
|
|
|
444
|
-
|
|
533
|
+
try {
|
|
534
|
+
_f.call(_h.context, a, b, c, d)
|
|
535
|
+
} catch (e) {
|
|
536
|
+
console.error("Failed to dispatch handler", _f, e);
|
|
537
|
+
}
|
|
445
538
|
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
}
|
|
449
|
-
console.error("Failed to dispatch handler", f, e);
|
|
450
|
-
}
|
|
539
|
+
_h = next;
|
|
540
|
+
|
|
541
|
+
} while (_h !== null);
|
|
451
542
|
|
|
452
|
-
}
|
|
453
543
|
|
|
454
|
-
|
|
455
|
-
dispatch_stack_top = stack_pointer;
|
|
544
|
+
}
|
|
456
545
|
}
|
|
457
546
|
|
|
458
547
|
/**
|
|
@@ -470,44 +559,36 @@ export class Signal {
|
|
|
470
559
|
return;
|
|
471
560
|
}
|
|
472
561
|
|
|
562
|
+
|
|
473
563
|
const handlers = this.handlers;
|
|
474
564
|
|
|
475
|
-
const
|
|
565
|
+
for (const handle of handlers.values()) {
|
|
476
566
|
|
|
477
|
-
|
|
478
|
-
const stack_frame_end = stack_pointer + length;
|
|
479
|
-
dispatch_stack_top = stack_frame_end;
|
|
567
|
+
let _h = handle;
|
|
480
568
|
|
|
481
|
-
|
|
569
|
+
do {
|
|
482
570
|
|
|
483
|
-
|
|
484
|
-
for (i = 0; i < length; i++) {
|
|
485
|
-
//copy to proxy
|
|
486
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
487
|
-
}
|
|
571
|
+
const next = _h.next;
|
|
488
572
|
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
573
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
574
|
+
//handler should be cut
|
|
575
|
+
this.#remove_handler_internal(_h);
|
|
576
|
+
}
|
|
492
577
|
|
|
493
|
-
|
|
494
|
-
//handler should be cut
|
|
495
|
-
const p = handlers.indexOf(h);
|
|
496
|
-
handlers.splice(p, 1);
|
|
497
|
-
}
|
|
578
|
+
const _f = _h.handle;
|
|
498
579
|
|
|
499
|
-
|
|
580
|
+
try {
|
|
581
|
+
_f.call(_h.context, a, b, c, d, e, f)
|
|
582
|
+
} catch (e) {
|
|
583
|
+
console.error("Failed to dispatch handler", f, e);
|
|
584
|
+
}
|
|
500
585
|
|
|
501
|
-
|
|
502
|
-
handle.call(h.context, a, b, c, d, e, f)
|
|
503
|
-
} catch (e) {
|
|
504
|
-
console.error("Failed to dispatch handler", handle, e);
|
|
505
|
-
}
|
|
586
|
+
_h = next;
|
|
506
587
|
|
|
507
|
-
|
|
588
|
+
} while (_h !== null);
|
|
508
589
|
|
|
509
|
-
|
|
510
|
-
|
|
590
|
+
|
|
591
|
+
}
|
|
511
592
|
}
|
|
512
593
|
|
|
513
594
|
/**
|
|
@@ -529,42 +610,33 @@ export class Signal {
|
|
|
529
610
|
|
|
530
611
|
const handlers = this.handlers;
|
|
531
612
|
|
|
532
|
-
const
|
|
613
|
+
for (const handle of handlers.values()) {
|
|
533
614
|
|
|
534
|
-
|
|
535
|
-
const stack_frame_end = stack_pointer + length;
|
|
536
|
-
dispatch_stack_top = stack_frame_end;
|
|
615
|
+
let _h = handle;
|
|
537
616
|
|
|
538
|
-
|
|
617
|
+
do {
|
|
539
618
|
|
|
540
|
-
|
|
541
|
-
for (i = 0; i < length; i++) {
|
|
542
|
-
//copy to proxy
|
|
543
|
-
dispatch_stack[stack_pointer + i] = handlers[length - (i + 1)];
|
|
544
|
-
}
|
|
619
|
+
const next = _h.next;
|
|
545
620
|
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
621
|
+
if (_h.getFlag(SignalHandlerFlags.RemoveAfterExecution)) {
|
|
622
|
+
//handler should be cut
|
|
623
|
+
this.#remove_handler_internal(_h);
|
|
624
|
+
}
|
|
549
625
|
|
|
550
|
-
|
|
551
|
-
//handler should be cut
|
|
552
|
-
const p = handlers.indexOf(handler);
|
|
553
|
-
handlers.splice(p, 1);
|
|
554
|
-
}
|
|
626
|
+
const _f = _h.handle;
|
|
555
627
|
|
|
556
|
-
|
|
628
|
+
try {
|
|
629
|
+
_f.call(_h.context, a, b, c, d, e, f, g, h)
|
|
630
|
+
} catch (e) {
|
|
631
|
+
console.error("Failed to dispatch handler", f, e);
|
|
632
|
+
}
|
|
557
633
|
|
|
558
|
-
|
|
559
|
-
handle.call(handler.context, a, b, c, d, e, f, g, h)
|
|
560
|
-
} catch (e) {
|
|
561
|
-
console.error("Failed to dispatch handler", handle, e);
|
|
562
|
-
}
|
|
634
|
+
_h = next;
|
|
563
635
|
|
|
564
|
-
|
|
636
|
+
} while (_h !== null);
|
|
565
637
|
|
|
566
|
-
|
|
567
|
-
|
|
638
|
+
|
|
639
|
+
}
|
|
568
640
|
}
|
|
569
641
|
|
|
570
642
|
/**
|
|
@@ -593,42 +665,4 @@ export class Signal {
|
|
|
593
665
|
*/
|
|
594
666
|
Signal.prototype.isSignal = true;
|
|
595
667
|
|
|
596
|
-
/**
|
|
597
|
-
*
|
|
598
|
-
* @param {Signal} signal
|
|
599
|
-
* @param {function} h
|
|
600
|
-
* @returns {boolean}
|
|
601
|
-
*/
|
|
602
|
-
function removeHandlerByHandler(signal, h) {
|
|
603
|
-
const handlers = signal.handlers;
|
|
604
|
-
let i = findSignalHandlerIndexByHandle(handlers, h);
|
|
605
|
-
|
|
606
|
-
if (i >= 0) {
|
|
607
|
-
handlers.splice(i, 1);
|
|
608
|
-
return true;
|
|
609
|
-
}
|
|
610
|
-
|
|
611
|
-
return false;
|
|
612
|
-
}
|
|
613
|
-
|
|
614
|
-
/**
|
|
615
|
-
*
|
|
616
|
-
* @param {Signal} signal
|
|
617
|
-
* @param {function} h
|
|
618
|
-
* @param {*} ctx
|
|
619
|
-
* @returns {boolean}
|
|
620
|
-
*/
|
|
621
|
-
function removeHandlerByHandlerAndContext(signal, h, ctx) {
|
|
622
|
-
const handlers = signal.handlers;
|
|
623
|
-
const i = findSignalHandlerIndexByHandleAndContext(handlers, h, ctx);
|
|
624
|
-
|
|
625
|
-
if (i >= 0) {
|
|
626
|
-
handlers.splice(i, 1);
|
|
627
|
-
return true;
|
|
628
|
-
}
|
|
629
|
-
|
|
630
|
-
return false;
|
|
631
|
-
}
|
|
632
|
-
|
|
633
|
-
|
|
634
668
|
export default Signal;
|