structured-outputs 0.1.0-beta.2 → 0.1.0-beta.20
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +77 -6
- package/esm/ResponseFormat.js +33 -5
- package/esm/ResponseFormat.js.map +1 -1
- package/esm/Tool.js +17 -0
- package/esm/Tool.js.map +1 -0
- package/esm/_dnt.polyfills.js +16 -0
- package/esm/_dnt.polyfills.js.map +1 -0
- package/esm/_dnt.shims.js +58 -0
- package/esm/_dnt.shims.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/almost_equals.js +47 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/almost_equals.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/array_includes.js +47 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/array_includes.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/assert.js +23 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/assert.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/assertion_error.js +31 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/assertion_error.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/equal.js +184 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/equal.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/equals.js +46 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/equals.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/exists.js +28 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/exists.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/fail.js +21 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/fail.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/false.js +23 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/false.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/greater.js +30 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/greater.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/greater_or_equal.js +30 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/greater_or_equal.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/instance_of.js +53 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/instance_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/is_error.js +54 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/is_error.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/less.js +29 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/less.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/less_or_equal.js +30 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/less_or_equal.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/match.js +27 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/match.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/mod.js +46 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/mod.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_equals.js +33 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_equals.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_instance_of.js +30 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_instance_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_match.js +27 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_match.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_strict_equals.js +33 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/not_strict_equals.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/object_match.js +160 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/object_match.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/rejects.js +54 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/rejects.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/strict_equals.js +58 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/strict_equals.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/string_includes.js +27 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/string_includes.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/throws.js +45 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/throws.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/unimplemented.js +21 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/unimplemented.js.map +1 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/unreachable.js +21 -0
- package/esm/deps/jsr.io/@std/assert/1.0.8/unreachable.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.js +19 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/_utils.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.js +51 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.js +45 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/associate_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.js +41 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/associate_with.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.js +51 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/chunk.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.js +96 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/deep_merge.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.js +28 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/distinct.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.js +39 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/distinct_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.js +33 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/drop_last_while.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.js +34 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/drop_while.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.js +43 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_entries.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.js +46 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_keys.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.js +46 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/filter_values.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.js +45 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/find_single.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.js +42 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.js +39 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/includes_value.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.js +36 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/intersect.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/invert.js +29 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/invert.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.js +46 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/invert_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.js +59 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/join_to_string.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.js +47 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_entries.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.js +42 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_keys.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.js +43 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.js +13 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/map_values.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.js +15 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.js +17 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.js +41 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/max_with.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.js +15 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.js +17 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.js +37 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/min_with.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/mod.js +75 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/mod.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/omit.js +29 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/omit.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/partition.js +16 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/partition.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.js +54 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/partition_entries.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.js +58 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/permutations.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/pick.js +33 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/pick.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.js +40 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/reduce_groups.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.js +32 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/running_reduce.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sample.js +35 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sample.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.js +57 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sliding_windows.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.js +30 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sort_by.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.js +37 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/sum_of.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.js +34 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/take_last_while.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.js +39 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/take_while.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/union.js +34 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/union.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.js +46 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/unzip.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.js +28 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/without_all.js.map +1 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/zip.js +43 -0
- package/esm/deps/jsr.io/@std/collections/1.0.9/zip.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.js +111 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/diff.js +277 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/diff.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.js +180 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/format.js +38 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/format.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/styles.js +208 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/styles.js.map +1 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/types.js +3 -0
- package/esm/deps/jsr.io/@std/internal/1.0.5/types.js.map +1 -0
- package/esm/mod.js +3 -10
- package/esm/mod.js.map +1 -1
- package/esm/types/Ref.js +11 -0
- package/esm/types/Ref.js.map +1 -0
- package/esm/types/RootTy.js +19 -0
- package/esm/types/RootTy.js.map +1 -0
- package/esm/types/Ty.js +17 -0
- package/esm/types/Ty.js.map +1 -0
- package/esm/types/array.js +9 -0
- package/esm/types/array.js.map +1 -0
- package/esm/types/constant.js +8 -0
- package/esm/types/constant.js.map +1 -0
- package/esm/types/constantUnion.js +25 -0
- package/esm/types/constantUnion.js.map +1 -0
- package/esm/types/leaves.js +18 -0
- package/esm/types/leaves.js.map +1 -0
- package/esm/types/mod.js +11 -0
- package/esm/types/mod.js.map +1 -0
- package/esm/{object.js → types/object.js} +4 -4
- package/esm/types/object.js.map +1 -0
- package/esm/types/std/Option.js +9 -0
- package/esm/types/std/Option.js.map +1 -0
- package/esm/types/std/Wrapper.js +5 -0
- package/esm/types/std/Wrapper.js.map +1 -0
- package/esm/types/std/mod.js +3 -0
- package/esm/types/std/mod.js.map +1 -0
- package/esm/types/taggedUnion.js +20 -0
- package/esm/types/taggedUnion.js.map +1 -0
- package/esm/util/phantoms.js +4 -0
- package/esm/util/phantoms.js.map +1 -0
- package/esm/util/recombineTaggedTemplateArgs.js +4 -0
- package/esm/util/recombineTaggedTemplateArgs.js.map +1 -0
- package/package.json +10 -7
- package/src/ResponseFormat.ts +76 -25
- package/src/Tool.ts +38 -0
- package/src/_dnt.polyfills.ts +27 -0
- package/src/_dnt.shims.ts +60 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/almost_equals.ts +55 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/array_includes.ts +57 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/assert.ts +23 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/assertion_error.ts +31 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/equal.ts +210 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/equals.ts +52 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/exists.ts +31 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/fail.ts +21 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/false.ts +26 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/greater.ts +30 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/greater_or_equal.ts +36 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/instance_of.ts +64 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/is_error.ts +65 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/less.ts +29 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/less_or_equal.ts +36 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/match.ts +30 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/mod.ts +47 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/not_equals.ts +36 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/not_instance_of.ts +33 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/not_match.ts +30 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/not_strict_equals.ts +42 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/object_match.ts +202 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/rejects.ts +123 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/strict_equals.ts +67 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/string_includes.ts +30 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/throws.ts +111 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/unimplemented.ts +21 -0
- package/src/deps/jsr.io/@std/assert/1.0.8/unreachable.ts +21 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/_utils.ts +26 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.ts +62 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/associate_by.ts +50 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/associate_with.ts +46 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/chunk.ts +56 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/deep_merge.ts +578 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/distinct.ts +29 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/distinct_by.ts +42 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/drop_last_while.ts +36 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/drop_while.ts +39 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/filter_entries.ts +48 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/filter_keys.ts +51 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/filter_values.ts +51 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/find_single.ts +48 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.ts +47 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/includes_value.ts +45 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/intersect.ts +35 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/invert.ts +38 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/invert_by.ts +56 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/join_to_string.ts +109 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/map_entries.ts +53 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/map_keys.ts +47 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.ts +49 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/map_values.ts +96 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/max_by.ts +153 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/max_of.ts +90 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/max_with.ts +46 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/min_by.ts +151 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/min_of.ts +90 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/min_with.ts +42 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/mod.ts +76 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/omit.ts +34 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/partition.ts +85 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/partition_entries.ts +58 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/permutations.ts +66 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/pick.ts +34 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/reduce_groups.ts +45 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/running_reduce.ts +38 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/sample.ts +36 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/sliding_windows.ts +86 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/sort_by.ts +219 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/sum_of.ts +42 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/take_last_while.ts +37 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/take_while.ts +44 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/union.ts +36 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/unzip.ts +50 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/without_all.ts +28 -0
- package/src/deps/jsr.io/@std/collections/1.0.9/zip.ts +49 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/build_message.ts +134 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/diff.ts +317 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/diff_str.ts +204 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/format.ts +39 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/styles.ts +233 -0
- package/src/deps/jsr.io/@std/internal/1.0.5/types.ts +18 -0
- package/src/mod.ts +3 -18
- package/src/types/Ref.ts +16 -0
- package/src/types/RootTy.ts +40 -0
- package/src/types/Ty.ts +57 -0
- package/src/types/array.ts +9 -0
- package/src/types/constant.ts +8 -0
- package/src/types/constantUnion.ts +27 -0
- package/src/types/leaves.ts +21 -0
- package/src/types/mod.ts +10 -0
- package/src/types/object.ts +15 -0
- package/src/types/std/Option.ts +15 -0
- package/src/types/std/Wrapper.ts +8 -0
- package/src/types/std/mod.ts +2 -0
- package/src/types/taggedUnion.ts +28 -0
- package/src/util/phantoms.ts +3 -0
- package/src/util/recombineTaggedTemplateArgs.ts +6 -0
- package/types/ResponseFormat.d.ts +26 -0
- package/types/ResponseFormat.d.ts.map +1 -0
- package/types/Tool.d.ts +13 -0
- package/types/Tool.d.ts.map +1 -0
- package/types/_dnt.polyfills.d.ts +12 -0
- package/types/_dnt.polyfills.d.ts.map +1 -0
- package/types/_dnt.shims.d.ts +2 -0
- package/types/_dnt.shims.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/almost_equals.d.ts +29 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/almost_equals.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/array_includes.d.ts +24 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/array_includes.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/assert.d.ts +16 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/assert.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/assertion_error.d.ts +26 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/assertion_error.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/equal.d.ts +17 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/equal.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/equals.d.ts +22 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/equals.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/exists.d.ts +18 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/exists.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/fail.d.ts +15 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/fail.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/false.d.ts +18 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/false.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/greater.d.ts +20 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/greater.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/greater_or_equal.d.ts +20 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/greater_or_equal.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/instance_of.d.ts +23 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/instance_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/is_error.d.ts +25 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/is_error.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/less.d.ts +19 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/less.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/less_or_equal.d.ts +20 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/less_or_equal.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/match.d.ts +18 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/match.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/mod.d.ts +44 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/mod.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_equals.d.ts +21 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_equals.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_instance_of.d.ts +20 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_instance_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_match.d.ts +18 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_match.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_strict_equals.d.ts +23 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/not_strict_equals.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/object_match.d.ts +28 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/object_match.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/rejects.d.ts +42 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/rejects.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/strict_equals.d.ts +24 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/strict_equals.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/string_includes.d.ts +18 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/string_includes.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/throws.d.ts +45 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/throws.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/unimplemented.d.ts +15 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/unimplemented.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/unreachable.d.ts +15 -0
- package/types/deps/jsr.io/@std/assert/1.0.8/unreachable.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/_utils.d.ts +6 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/_utils.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.d.ts +41 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/aggregate_groups.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/associate_by.d.ts +37 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/associate_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/associate_with.d.ts +33 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/associate_with.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/chunk.d.ts +38 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/chunk.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/deep_merge.d.ts +322 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/deep_merge.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/distinct.d.ts +23 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/distinct.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/distinct_by.d.ts +26 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/distinct_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/drop_last_while.d.ts +26 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/drop_last_while.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/drop_while.d.ts +25 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/drop_while.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_entries.d.ts +32 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_entries.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_keys.d.ts +36 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_keys.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_values.d.ts +35 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/filter_values.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/find_single.d.ts +31 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/find_single.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.d.ts +32 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/first_not_nullish_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/includes_value.d.ts +29 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/includes_value.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/intersect.d.ts +25 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/intersect.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/invert.d.ts +29 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/invert.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/invert_by.d.ts +34 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/invert_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/join_to_string.d.ts +75 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/join_to_string.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_entries.d.ts +37 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_entries.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_keys.d.ts +33 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_keys.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.d.ts +32 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_not_nullish.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_values.d.ts +71 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/map_values.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_by.d.ts +117 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_of.d.ts +61 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_with.d.ts +29 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/max_with.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_by.d.ts +115 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_of.d.ts +61 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_with.d.ts +25 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/min_with.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/mod.d.ts +73 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/mod.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/omit.d.ts +24 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/omit.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/partition.d.ts +60 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/partition.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/partition_entries.d.ts +39 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/partition_entries.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/permutations.d.ts +27 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/permutations.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/pick.d.ts +25 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/pick.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/reduce_groups.d.ts +35 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/reduce_groups.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/running_reduce.d.ts +27 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/running_reduce.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sample.d.ts +24 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sample.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sliding_windows.d.ts +66 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sliding_windows.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sort_by.d.ts +161 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sort_by.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sum_of.d.ts +29 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/sum_of.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/take_last_while.d.ts +27 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/take_last_while.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/take_while.d.ts +30 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/take_while.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/union.d.ts +24 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/union.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/unzip.d.ts +32 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/unzip.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/without_all.d.ts +23 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/without_all.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/zip.d.ts +34 -0
- package/types/deps/jsr.io/@std/collections/1.0.9/zip.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts +82 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/diff.d.ts +140 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/diff.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts +99 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/format.d.ts +2 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/format.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/styles.d.ts +159 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/styles.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/types.d.ts +16 -0
- package/types/deps/jsr.io/@std/internal/1.0.5/types.d.ts.map +1 -0
- package/types/mod.d.ts +5 -0
- package/types/mod.d.ts.map +1 -0
- package/types/types/Ref.d.ts +4 -0
- package/types/types/Ref.d.ts.map +1 -0
- package/types/types/RootTy.d.ts +8 -0
- package/types/types/RootTy.d.ts.map +1 -0
- package/types/types/Ty.d.ts +27 -0
- package/types/types/Ty.d.ts.map +1 -0
- package/types/types/array.d.ts +3 -0
- package/types/types/array.d.ts.map +1 -0
- package/types/types/constant.d.ts +3 -0
- package/types/types/constant.d.ts.map +1 -0
- package/types/types/constantUnion.d.ts +3 -0
- package/types/types/constantUnion.d.ts.map +1 -0
- package/types/types/leaves.d.ts +6 -0
- package/types/types/leaves.d.ts.map +1 -0
- package/types/types/mod.d.ts +11 -0
- package/types/types/mod.d.ts.map +1 -0
- package/types/types/object.d.ts +6 -0
- package/types/types/object.d.ts.map +1 -0
- package/types/types/std/Option.d.ts +7 -0
- package/types/types/std/Option.d.ts.map +1 -0
- package/types/types/std/Wrapper.d.ts +7 -0
- package/types/types/std/Wrapper.d.ts.map +1 -0
- package/types/types/std/mod.d.ts +3 -0
- package/types/types/std/mod.d.ts.map +1 -0
- package/types/types/taggedUnion.d.ts +8 -0
- package/types/types/taggedUnion.d.ts.map +1 -0
- package/types/util/phantoms.d.ts +2 -0
- package/types/util/phantoms.d.ts.map +1 -0
- package/types/util/recombineTaggedTemplateArgs.d.ts +2 -0
- package/types/util/recombineTaggedTemplateArgs.d.ts.map +1 -0
- package/esm/F.d.ts +0 -13
- package/esm/F.d.ts.map +0 -1
- package/esm/F.js +0 -10
- package/esm/F.js.map +0 -1
- package/esm/ResponseFormat.d.ts +0 -14
- package/esm/ResponseFormat.d.ts.map +0 -1
- package/esm/_base.d.ts +0 -13
- package/esm/_base.d.ts.map +0 -1
- package/esm/_base.js +0 -40
- package/esm/_base.js.map +0 -1
- package/esm/array.d.ts +0 -4
- package/esm/array.d.ts.map +0 -1
- package/esm/array.js +0 -9
- package/esm/array.js.map +0 -1
- package/esm/common.d.ts +0 -6
- package/esm/common.d.ts.map +0 -1
- package/esm/common.js +0 -2
- package/esm/common.js.map +0 -1
- package/esm/literal.d.ts +0 -4
- package/esm/literal.d.ts.map +0 -1
- package/esm/literal.js +0 -8
- package/esm/literal.js.map +0 -1
- package/esm/mod.d.ts +0 -16
- package/esm/mod.d.ts.map +0 -1
- package/esm/number.d.ts +0 -4
- package/esm/number.d.ts.map +0 -1
- package/esm/number.js +0 -8
- package/esm/number.js.map +0 -1
- package/esm/object.d.ts +0 -7
- package/esm/object.d.ts.map +0 -1
- package/esm/object.js.map +0 -1
- package/esm/schema.d.ts +0 -4
- package/esm/schema.d.ts.map +0 -1
- package/esm/schema.js +0 -9
- package/esm/schema.js.map +0 -1
- package/esm/string.d.ts +0 -4
- package/esm/string.d.ts.map +0 -1
- package/esm/string.js +0 -8
- package/esm/string.js.map +0 -1
- package/esm/union.d.ts +0 -6
- package/esm/union.d.ts.map +0 -1
- package/esm/union.js +0 -8
- package/esm/union.js.map +0 -1
- package/src/F.ts +0 -27
- package/src/_base.ts +0 -25
- package/src/array.ts +0 -11
- package/src/common.ts +0 -6
- package/src/literal.ts +0 -10
- package/src/number.ts +0 -10
- package/src/object.ts +0 -17
- package/src/schema.ts +0 -10
- package/src/string.ts +0 -10
- package/src/union.ts +0 -12
@@ -0,0 +1,317 @@
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2
|
+
// This module is browser compatible.
|
3
|
+
|
4
|
+
import type { DiffResult, DiffType } from "./types.js";
|
5
|
+
|
6
|
+
/** Represents the farthest point in the diff algorithm. */
|
7
|
+
export interface FarthestPoint {
|
8
|
+
/** The y-coordinate of the point. */
|
9
|
+
y: number;
|
10
|
+
/** The id of the point. */
|
11
|
+
id: number;
|
12
|
+
}
|
13
|
+
|
14
|
+
const REMOVED = 1;
|
15
|
+
const COMMON = 2;
|
16
|
+
const ADDED = 3;
|
17
|
+
|
18
|
+
/**
|
19
|
+
* Creates an array of common elements between two arrays.
|
20
|
+
*
|
21
|
+
* @typeParam T The type of elements in the arrays.
|
22
|
+
*
|
23
|
+
* @param A The first array.
|
24
|
+
* @param B The second array.
|
25
|
+
*
|
26
|
+
* @returns An array containing the common elements between the two arrays.
|
27
|
+
*
|
28
|
+
* @example Usage
|
29
|
+
* ```ts
|
30
|
+
* import { createCommon } from "@std/internal/diff";
|
31
|
+
* import { assertEquals } from "@std/assert";
|
32
|
+
*
|
33
|
+
* const a = [1, 2, 3];
|
34
|
+
* const b = [1, 2, 4];
|
35
|
+
*
|
36
|
+
* assertEquals(createCommon(a, b), [1, 2]);
|
37
|
+
* ```
|
38
|
+
*/
|
39
|
+
export function createCommon<T>(A: T[], B: T[]): T[] {
|
40
|
+
const common: T[] = [];
|
41
|
+
if (A.length === 0 || B.length === 0) return [];
|
42
|
+
for (let i = 0; i < Math.min(A.length, B.length); i += 1) {
|
43
|
+
const a = A[i];
|
44
|
+
const b = B[i];
|
45
|
+
if (a !== undefined && a === b) {
|
46
|
+
common.push(a);
|
47
|
+
} else {
|
48
|
+
return common;
|
49
|
+
}
|
50
|
+
}
|
51
|
+
return common;
|
52
|
+
}
|
53
|
+
|
54
|
+
/**
|
55
|
+
* Asserts that the value is a {@linkcode FarthestPoint}.
|
56
|
+
* If not, an error is thrown.
|
57
|
+
*
|
58
|
+
* @param value The value to check.
|
59
|
+
*
|
60
|
+
* @returns A void value that returns once the assertion completes.
|
61
|
+
*
|
62
|
+
* @example Usage
|
63
|
+
* ```ts
|
64
|
+
* import { assertFp } from "@std/internal/diff";
|
65
|
+
* import { assertThrows } from "@std/assert";
|
66
|
+
*
|
67
|
+
* assertFp({ y: 0, id: 0 });
|
68
|
+
* assertThrows(() => assertFp({ id: 0 }));
|
69
|
+
* assertThrows(() => assertFp({ y: 0 }));
|
70
|
+
* assertThrows(() => assertFp(undefined));
|
71
|
+
* ```
|
72
|
+
*/
|
73
|
+
export function assertFp(value: unknown): asserts value is FarthestPoint {
|
74
|
+
if (
|
75
|
+
value == null ||
|
76
|
+
typeof value !== "object" ||
|
77
|
+
typeof (value as FarthestPoint)?.y !== "number" ||
|
78
|
+
typeof (value as FarthestPoint)?.id !== "number"
|
79
|
+
) {
|
80
|
+
throw new Error(
|
81
|
+
`Unexpected value, expected 'FarthestPoint': received ${typeof value}`,
|
82
|
+
);
|
83
|
+
}
|
84
|
+
}
|
85
|
+
|
86
|
+
/**
|
87
|
+
* Creates an array of backtraced differences.
|
88
|
+
*
|
89
|
+
* @typeParam T The type of elements in the arrays.
|
90
|
+
*
|
91
|
+
* @param A The first array.
|
92
|
+
* @param B The second array.
|
93
|
+
* @param current The current {@linkcode FarthestPoint}.
|
94
|
+
* @param swapped Boolean indicating if the arrays are swapped.
|
95
|
+
* @param routes The routes array.
|
96
|
+
* @param diffTypesPtrOffset The offset of the diff types in the routes array.
|
97
|
+
*
|
98
|
+
* @returns An array of backtraced differences.
|
99
|
+
*
|
100
|
+
* @example Usage
|
101
|
+
* ```ts
|
102
|
+
* import { backTrace } from "@std/internal/diff";
|
103
|
+
* import { assertEquals } from "@std/assert";
|
104
|
+
*
|
105
|
+
* assertEquals(
|
106
|
+
* backTrace([], [], { y: 0, id: 0 }, false, new Uint32Array(0), 0),
|
107
|
+
* [],
|
108
|
+
* );
|
109
|
+
* ```
|
110
|
+
*/
|
111
|
+
export function backTrace<T>(
|
112
|
+
A: T[],
|
113
|
+
B: T[],
|
114
|
+
current: FarthestPoint,
|
115
|
+
swapped: boolean,
|
116
|
+
routes: Uint32Array,
|
117
|
+
diffTypesPtrOffset: number,
|
118
|
+
): Array<{
|
119
|
+
type: DiffType;
|
120
|
+
value: T;
|
121
|
+
}> {
|
122
|
+
const M = A.length;
|
123
|
+
const N = B.length;
|
124
|
+
const result: { type: DiffType; value: T }[] = [];
|
125
|
+
let a = M - 1;
|
126
|
+
let b = N - 1;
|
127
|
+
let j = routes[current.id];
|
128
|
+
let type = routes[current.id + diffTypesPtrOffset];
|
129
|
+
while (true) {
|
130
|
+
if (!j && !type) break;
|
131
|
+
const prev = j!;
|
132
|
+
if (type === REMOVED) {
|
133
|
+
result.unshift({
|
134
|
+
type: swapped ? "removed" : "added",
|
135
|
+
value: B[b]!,
|
136
|
+
});
|
137
|
+
b -= 1;
|
138
|
+
} else if (type === ADDED) {
|
139
|
+
result.unshift({
|
140
|
+
type: swapped ? "added" : "removed",
|
141
|
+
value: A[a]!,
|
142
|
+
});
|
143
|
+
a -= 1;
|
144
|
+
} else {
|
145
|
+
result.unshift({ type: "common", value: A[a]! });
|
146
|
+
a -= 1;
|
147
|
+
b -= 1;
|
148
|
+
}
|
149
|
+
j = routes[prev];
|
150
|
+
type = routes[prev + diffTypesPtrOffset];
|
151
|
+
}
|
152
|
+
return result;
|
153
|
+
}
|
154
|
+
|
155
|
+
/**
|
156
|
+
* Creates a {@linkcode FarthestPoint}.
|
157
|
+
*
|
158
|
+
* @param k The current index.
|
159
|
+
* @param M The length of the first array.
|
160
|
+
* @param routes The routes array.
|
161
|
+
* @param diffTypesPtrOffset The offset of the diff types in the routes array.
|
162
|
+
* @param ptr The current pointer.
|
163
|
+
* @param slide The slide {@linkcode FarthestPoint}.
|
164
|
+
* @param down The down {@linkcode FarthestPoint}.
|
165
|
+
*
|
166
|
+
* @returns A {@linkcode FarthestPoint}.
|
167
|
+
*
|
168
|
+
* @example Usage
|
169
|
+
* ```ts
|
170
|
+
* import { createFp } from "@std/internal/diff";
|
171
|
+
* import { assertEquals } from "@std/assert";
|
172
|
+
*
|
173
|
+
* assertEquals(
|
174
|
+
* createFp(
|
175
|
+
* 0,
|
176
|
+
* 0,
|
177
|
+
* new Uint32Array(0),
|
178
|
+
* 0,
|
179
|
+
* 0,
|
180
|
+
* { y: -1, id: 0 },
|
181
|
+
* { y: 0, id: 0 },
|
182
|
+
* ),
|
183
|
+
* { y: -1, id: 1 },
|
184
|
+
* );
|
185
|
+
* ```
|
186
|
+
*/
|
187
|
+
export function createFp(
|
188
|
+
k: number,
|
189
|
+
M: number,
|
190
|
+
routes: Uint32Array,
|
191
|
+
diffTypesPtrOffset: number,
|
192
|
+
ptr: number,
|
193
|
+
slide?: FarthestPoint,
|
194
|
+
down?: FarthestPoint,
|
195
|
+
): FarthestPoint {
|
196
|
+
if (slide && slide.y === -1 && down && down.y === -1) {
|
197
|
+
return { y: 0, id: 0 };
|
198
|
+
}
|
199
|
+
const isAdding = (down?.y === -1) ||
|
200
|
+
k === M ||
|
201
|
+
(slide?.y ?? 0) > (down?.y ?? 0) + 1;
|
202
|
+
if (slide && isAdding) {
|
203
|
+
const prev = slide.id;
|
204
|
+
ptr++;
|
205
|
+
routes[ptr] = prev;
|
206
|
+
routes[ptr + diffTypesPtrOffset] = ADDED;
|
207
|
+
return { y: slide.y, id: ptr };
|
208
|
+
}
|
209
|
+
if (down && !isAdding) {
|
210
|
+
const prev = down.id;
|
211
|
+
ptr++;
|
212
|
+
routes[ptr] = prev;
|
213
|
+
routes[ptr + diffTypesPtrOffset] = REMOVED;
|
214
|
+
return { y: down.y + 1, id: ptr };
|
215
|
+
}
|
216
|
+
throw new Error("Unexpected missing FarthestPoint");
|
217
|
+
}
|
218
|
+
|
219
|
+
/**
|
220
|
+
* Renders the differences between the actual and expected values.
|
221
|
+
*
|
222
|
+
* @typeParam T The type of elements in the arrays.
|
223
|
+
*
|
224
|
+
* @param A Actual value
|
225
|
+
* @param B Expected value
|
226
|
+
*
|
227
|
+
* @returns An array of differences between the actual and expected values.
|
228
|
+
*
|
229
|
+
* @example Usage
|
230
|
+
* ```ts
|
231
|
+
* import { diff } from "@std/internal/diff";
|
232
|
+
* import { assertEquals } from "@std/assert";
|
233
|
+
*
|
234
|
+
* const a = [1, 2, 3];
|
235
|
+
* const b = [1, 2, 4];
|
236
|
+
*
|
237
|
+
* assertEquals(diff(a, b), [
|
238
|
+
* { type: "common", value: 1 },
|
239
|
+
* { type: "common", value: 2 },
|
240
|
+
* { type: "removed", value: 3 },
|
241
|
+
* { type: "added", value: 4 },
|
242
|
+
* ]);
|
243
|
+
* ```
|
244
|
+
*/
|
245
|
+
export function diff<T>(A: T[], B: T[]): DiffResult<T>[] {
|
246
|
+
const prefixCommon = createCommon(A, B);
|
247
|
+
A = A.slice(prefixCommon.length);
|
248
|
+
B = B.slice(prefixCommon.length);
|
249
|
+
const swapped = B.length > A.length;
|
250
|
+
[A, B] = swapped ? [B, A] : [A, B];
|
251
|
+
const M = A.length;
|
252
|
+
const N = B.length;
|
253
|
+
if (!M && !N && !prefixCommon.length) return [];
|
254
|
+
if (!N) {
|
255
|
+
return [
|
256
|
+
...prefixCommon.map((value) => ({ type: "common", value })),
|
257
|
+
...A.map((value) => ({ type: swapped ? "added" : "removed", value })),
|
258
|
+
] as DiffResult<T>[];
|
259
|
+
}
|
260
|
+
const offset = N;
|
261
|
+
const delta = M - N;
|
262
|
+
const length = M + N + 1;
|
263
|
+
const fp: FarthestPoint[] = Array.from({ length }, () => ({ y: -1, id: -1 }));
|
264
|
+
|
265
|
+
/**
|
266
|
+
* Note: this buffer is used to save memory and improve performance. The first
|
267
|
+
* half is used to save route and the last half is used to save diff type.
|
268
|
+
*/
|
269
|
+
const routes = new Uint32Array((M * N + length + 1) * 2);
|
270
|
+
const diffTypesPtrOffset = routes.length / 2;
|
271
|
+
let ptr = 0;
|
272
|
+
|
273
|
+
function snake<T>(
|
274
|
+
k: number,
|
275
|
+
A: T[],
|
276
|
+
B: T[],
|
277
|
+
slide?: FarthestPoint,
|
278
|
+
down?: FarthestPoint,
|
279
|
+
): FarthestPoint {
|
280
|
+
const M = A.length;
|
281
|
+
const N = B.length;
|
282
|
+
const fp = createFp(k, M, routes, diffTypesPtrOffset, ptr, slide, down);
|
283
|
+
ptr = fp.id;
|
284
|
+
while (fp.y + k < M && fp.y < N && A[fp.y + k] === B[fp.y]) {
|
285
|
+
const prev = fp.id;
|
286
|
+
ptr++;
|
287
|
+
fp.id = ptr;
|
288
|
+
fp.y += 1;
|
289
|
+
routes[ptr] = prev;
|
290
|
+
routes[ptr + diffTypesPtrOffset] = COMMON;
|
291
|
+
}
|
292
|
+
return fp;
|
293
|
+
}
|
294
|
+
|
295
|
+
let currentFp = fp[delta + offset];
|
296
|
+
assertFp(currentFp);
|
297
|
+
let p = -1;
|
298
|
+
while (currentFp.y < N) {
|
299
|
+
p = p + 1;
|
300
|
+
for (let k = -p; k < delta; ++k) {
|
301
|
+
const index = k + offset;
|
302
|
+
fp[index] = snake(k, A, B, fp[index - 1], fp[index + 1]);
|
303
|
+
}
|
304
|
+
for (let k = delta + p; k > delta; --k) {
|
305
|
+
const index = k + offset;
|
306
|
+
fp[index] = snake(k, A, B, fp[index - 1], fp[index + 1]);
|
307
|
+
}
|
308
|
+
const index = delta + offset;
|
309
|
+
fp[delta + offset] = snake(delta, A, B, fp[index - 1], fp[index + 1]);
|
310
|
+
currentFp = fp[delta + offset];
|
311
|
+
assertFp(currentFp);
|
312
|
+
}
|
313
|
+
return [
|
314
|
+
...prefixCommon.map((value) => ({ type: "common", value })),
|
315
|
+
...backTrace(A, B, currentFp, swapped, routes, diffTypesPtrOffset),
|
316
|
+
] as DiffResult<T>[];
|
317
|
+
}
|
@@ -0,0 +1,204 @@
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2
|
+
import type { DiffResult } from "./types.js";
|
3
|
+
import { diff } from "./diff.js";
|
4
|
+
|
5
|
+
/**
|
6
|
+
* Unescape invisible characters.
|
7
|
+
*
|
8
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String#escape_sequences}
|
9
|
+
*
|
10
|
+
* @param string String to unescape.
|
11
|
+
*
|
12
|
+
* @returns Unescaped string.
|
13
|
+
*
|
14
|
+
* @example Usage
|
15
|
+
* ```ts
|
16
|
+
* import { unescape } from "@std/internal/diff-str";
|
17
|
+
* import { assertEquals } from "@std/assert";
|
18
|
+
*
|
19
|
+
* assertEquals(unescape("Hello\nWorld"), "Hello\\n\nWorld");
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
export function unescape(string: string): string {
|
23
|
+
return string
|
24
|
+
.replaceAll("\b", "\\b")
|
25
|
+
.replaceAll("\f", "\\f")
|
26
|
+
.replaceAll("\t", "\\t")
|
27
|
+
.replaceAll("\v", "\\v")
|
28
|
+
// This does not remove line breaks
|
29
|
+
.replaceAll(
|
30
|
+
/\r\n|\r|\n/g,
|
31
|
+
(str) => str === "\r" ? "\\r" : str === "\n" ? "\\n\n" : "\\r\\n\r\n",
|
32
|
+
);
|
33
|
+
}
|
34
|
+
|
35
|
+
const WHITESPACE_SYMBOLS = /([^\S\r\n]+|[()[\]{}'"\r\n]|\b)/;
|
36
|
+
|
37
|
+
/**
|
38
|
+
* Tokenizes a string into an array of tokens.
|
39
|
+
*
|
40
|
+
* @param string The string to tokenize.
|
41
|
+
* @param wordDiff If true, performs word-based tokenization. Default is false.
|
42
|
+
*
|
43
|
+
* @returns An array of tokens.
|
44
|
+
*
|
45
|
+
* @example Usage
|
46
|
+
* ```ts
|
47
|
+
* import { tokenize } from "@std/internal/diff-str";
|
48
|
+
* import { assertEquals } from "@std/assert";
|
49
|
+
*
|
50
|
+
* assertEquals(tokenize("Hello\nWorld"), ["Hello\n", "World"]);
|
51
|
+
* ```
|
52
|
+
*/
|
53
|
+
export function tokenize(string: string, wordDiff = false): string[] {
|
54
|
+
if (wordDiff) {
|
55
|
+
return string
|
56
|
+
.split(WHITESPACE_SYMBOLS)
|
57
|
+
.filter((token) => token);
|
58
|
+
}
|
59
|
+
const tokens: string[] = [];
|
60
|
+
const lines = string.split(/(\n|\r\n)/).filter((line) => line);
|
61
|
+
|
62
|
+
for (const [i, line] of lines.entries()) {
|
63
|
+
if (i % 2) {
|
64
|
+
tokens[tokens.length - 1] += line;
|
65
|
+
} else {
|
66
|
+
tokens.push(line);
|
67
|
+
}
|
68
|
+
}
|
69
|
+
return tokens;
|
70
|
+
}
|
71
|
+
|
72
|
+
/**
|
73
|
+
* Create details by filtering relevant word-diff for current line and merge
|
74
|
+
* "space-diff" if surrounded by word-diff for cleaner displays.
|
75
|
+
*
|
76
|
+
* @param line Current line
|
77
|
+
* @param tokens Word-diff tokens
|
78
|
+
*
|
79
|
+
* @returns Array of diff results.
|
80
|
+
*
|
81
|
+
* @example Usage
|
82
|
+
* ```ts
|
83
|
+
* import { createDetails } from "@std/internal/diff-str";
|
84
|
+
* import { assertEquals } from "@std/assert";
|
85
|
+
*
|
86
|
+
* const tokens = [
|
87
|
+
* { type: "added", value: "a" },
|
88
|
+
* { type: "removed", value: "b" },
|
89
|
+
* { type: "common", value: "c" },
|
90
|
+
* ] as const;
|
91
|
+
* assertEquals(
|
92
|
+
* createDetails({ type: "added", value: "a" }, [...tokens]),
|
93
|
+
* [{ type: "added", value: "a" }, { type: "common", value: "c" }]
|
94
|
+
* );
|
95
|
+
* ```
|
96
|
+
*/
|
97
|
+
export function createDetails(
|
98
|
+
line: DiffResult<string>,
|
99
|
+
tokens: DiffResult<string>[],
|
100
|
+
): DiffResult<string>[] {
|
101
|
+
return tokens.filter(({ type }) => type === line.type || type === "common")
|
102
|
+
.map((result, i, t) => {
|
103
|
+
const token = t[i - 1];
|
104
|
+
if (
|
105
|
+
(result.type === "common") && token &&
|
106
|
+
(token.type === t[i + 1]?.type) && /\s+/.test(result.value)
|
107
|
+
) {
|
108
|
+
return {
|
109
|
+
...result,
|
110
|
+
type: token.type,
|
111
|
+
};
|
112
|
+
}
|
113
|
+
return result;
|
114
|
+
});
|
115
|
+
}
|
116
|
+
|
117
|
+
const NON_WHITESPACE_REGEXP = /\S/;
|
118
|
+
|
119
|
+
/**
|
120
|
+
* Renders the differences between the actual and expected strings. Partially
|
121
|
+
* inspired from {@link https://github.com/kpdecker/jsdiff}.
|
122
|
+
*
|
123
|
+
* @param A Actual string
|
124
|
+
* @param B Expected string
|
125
|
+
*
|
126
|
+
* @returns Array of diff results.
|
127
|
+
*
|
128
|
+
* @example Usage
|
129
|
+
* ```ts
|
130
|
+
* import { diffStr } from "@std/internal/diff-str";
|
131
|
+
* import { assertEquals } from "@std/assert";
|
132
|
+
*
|
133
|
+
* assertEquals(diffStr("Hello!", "Hello"), [
|
134
|
+
* {
|
135
|
+
* type: "removed",
|
136
|
+
* value: "Hello!\n",
|
137
|
+
* details: [
|
138
|
+
* { type: "common", value: "Hello" },
|
139
|
+
* { type: "removed", value: "!" },
|
140
|
+
* { type: "common", value: "\n" }
|
141
|
+
* ]
|
142
|
+
* },
|
143
|
+
* {
|
144
|
+
* type: "added",
|
145
|
+
* value: "Hello\n",
|
146
|
+
* details: [
|
147
|
+
* { type: "common", value: "Hello" },
|
148
|
+
* { type: "common", value: "\n" }
|
149
|
+
* ]
|
150
|
+
* }
|
151
|
+
* ]);
|
152
|
+
* ```
|
153
|
+
*/
|
154
|
+
export function diffStr(A: string, B: string): DiffResult<string>[] {
|
155
|
+
// Compute multi-line diff
|
156
|
+
const diffResult = diff(
|
157
|
+
tokenize(`${unescape(A)}\n`),
|
158
|
+
tokenize(`${unescape(B)}\n`),
|
159
|
+
);
|
160
|
+
|
161
|
+
const added = [];
|
162
|
+
const removed = [];
|
163
|
+
for (const result of diffResult) {
|
164
|
+
if (result.type === "added") {
|
165
|
+
added.push(result);
|
166
|
+
}
|
167
|
+
if (result.type === "removed") {
|
168
|
+
removed.push(result);
|
169
|
+
}
|
170
|
+
}
|
171
|
+
|
172
|
+
// Compute word-diff
|
173
|
+
const hasMoreRemovedLines = added.length < removed.length;
|
174
|
+
const aLines = hasMoreRemovedLines ? added : removed;
|
175
|
+
const bLines = hasMoreRemovedLines ? removed : added;
|
176
|
+
for (const a of aLines) {
|
177
|
+
let tokens = [] as Array<DiffResult<string>>;
|
178
|
+
let b: undefined | DiffResult<string>;
|
179
|
+
// Search another diff line with at least one common token
|
180
|
+
while (bLines.length) {
|
181
|
+
b = bLines.shift();
|
182
|
+
const tokenized = [
|
183
|
+
tokenize(a.value, true),
|
184
|
+
tokenize(b!.value, true),
|
185
|
+
] as [string[], string[]];
|
186
|
+
if (hasMoreRemovedLines) tokenized.reverse();
|
187
|
+
tokens = diff(tokenized[0], tokenized[1]);
|
188
|
+
if (
|
189
|
+
tokens.some(({ type, value }) =>
|
190
|
+
type === "common" && NON_WHITESPACE_REGEXP.test(value)
|
191
|
+
)
|
192
|
+
) {
|
193
|
+
break;
|
194
|
+
}
|
195
|
+
}
|
196
|
+
// Register word-diff details
|
197
|
+
a.details = createDetails(a, tokens);
|
198
|
+
if (b) {
|
199
|
+
b.details = createDetails(b, tokens);
|
200
|
+
}
|
201
|
+
}
|
202
|
+
|
203
|
+
return diffResult;
|
204
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
2
|
+
// This module is browser compatible.
|
3
|
+
|
4
|
+
/**
|
5
|
+
* Converts the input into a string. Objects, Sets and Maps are sorted so as to
|
6
|
+
* make tests less flaky.
|
7
|
+
*
|
8
|
+
* @param v Value to be formatted
|
9
|
+
*
|
10
|
+
* @returns The formatted string
|
11
|
+
*
|
12
|
+
* @example Usage
|
13
|
+
* ```ts
|
14
|
+
* import { format } from "@std/internal/format";
|
15
|
+
* import { assertEquals } from "@std/assert";
|
16
|
+
*
|
17
|
+
* assertEquals(format({ a: 1, b: 2 }), "{\n a: 1,\n b: 2,\n}");
|
18
|
+
* assertEquals(format(new Set([1, 2])), "Set(2) {\n 1,\n 2,\n}");
|
19
|
+
* assertEquals(format(new Map([[1, 2]])), "Map(1) {\n 1 => 2,\n}");
|
20
|
+
* ```
|
21
|
+
*/
|
22
|
+
import * as dntShim from "../../../../../_dnt.shims.js";
|
23
|
+
|
24
|
+
export function format(v: unknown): string {
|
25
|
+
// deno-lint-ignore no-explicit-any
|
26
|
+
const { Deno } = dntShim.dntGlobalThis as any;
|
27
|
+
return typeof Deno?.inspect === "function"
|
28
|
+
? Deno.inspect(v, {
|
29
|
+
depth: Infinity,
|
30
|
+
sorted: true,
|
31
|
+
trailingComma: true,
|
32
|
+
compact: false,
|
33
|
+
iterableLimit: Infinity,
|
34
|
+
// getters should be true in assertEquals.
|
35
|
+
getters: true,
|
36
|
+
strAbbreviateSize: Infinity,
|
37
|
+
})
|
38
|
+
: `"${String(v).replace(/(?=["\\])/g, "\\")}"`;
|
39
|
+
}
|