super_diff 0.12.1 → 0.14.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +7 -19
- data/lib/super_diff/active_record/differs/active_record_relation.rb +2 -0
- data/lib/super_diff/active_record/differs.rb +3 -1
- data/lib/super_diff/active_record/inspection_tree_builders/active_record_model.rb +7 -5
- data/lib/super_diff/active_record/inspection_tree_builders/active_record_relation.rb +12 -10
- data/lib/super_diff/active_record/inspection_tree_builders.rb +4 -2
- data/lib/super_diff/active_record/monkey_patches.rb +4 -2
- data/lib/super_diff/active_record/object_inspection.rb +6 -4
- data/lib/super_diff/active_record/operation_tree_builders/active_record_model.rb +3 -1
- data/lib/super_diff/active_record/operation_tree_builders/active_record_relation.rb +3 -1
- data/lib/super_diff/active_record/operation_tree_builders.rb +4 -2
- data/lib/super_diff/active_record/operation_tree_flatteners/active_record_relation.rb +4 -2
- data/lib/super_diff/active_record/operation_tree_flatteners.rb +3 -1
- data/lib/super_diff/active_record/operation_trees/active_record_relation.rb +2 -0
- data/lib/super_diff/active_record/operation_trees.rb +3 -1
- data/lib/super_diff/active_record.rb +10 -8
- data/lib/super_diff/active_support/differs/hash_with_indifferent_access.rb +2 -0
- data/lib/super_diff/active_support/differs.rb +3 -1
- data/lib/super_diff/active_support/inspection_tree_builders/hash_with_indifferent_access.rb +16 -14
- data/lib/super_diff/active_support/inspection_tree_builders/ordered_options.rb +16 -14
- data/lib/super_diff/active_support/inspection_tree_builders.rb +4 -2
- data/lib/super_diff/active_support/object_inspection.rb +6 -4
- data/lib/super_diff/active_support/operation_tree_builders/hash_with_indifferent_access.rb +6 -4
- data/lib/super_diff/active_support/operation_tree_builders.rb +3 -1
- data/lib/super_diff/active_support/operation_tree_flatteners/hash_with_indifferent_access.rb +4 -2
- data/lib/super_diff/active_support/operation_tree_flatteners.rb +3 -1
- data/lib/super_diff/active_support/operation_trees/hash_with_indifferent_access.rb +2 -0
- data/lib/super_diff/active_support/operation_trees.rb +3 -1
- data/lib/super_diff/active_support.rb +8 -6
- data/lib/super_diff/basic/diff_formatters/collection.rb +18 -18
- data/lib/super_diff/basic/diff_formatters/multiline_string.rb +2 -0
- data/lib/super_diff/basic/diff_formatters.rb +4 -2
- data/lib/super_diff/basic/differs/array.rb +2 -0
- data/lib/super_diff/basic/differs/custom_object.rb +3 -1
- data/lib/super_diff/basic/differs/date_like.rb +2 -0
- data/lib/super_diff/basic/differs/default_object.rb +3 -1
- data/lib/super_diff/basic/differs/hash.rb +2 -0
- data/lib/super_diff/basic/differs/multiline_string.rb +2 -0
- data/lib/super_diff/basic/differs/time_like.rb +2 -0
- data/lib/super_diff/basic/differs.rb +11 -9
- data/lib/super_diff/basic/inspection_tree_builders/array.rb +5 -3
- data/lib/super_diff/basic/inspection_tree_builders/custom_object.rb +5 -3
- data/lib/super_diff/basic/inspection_tree_builders/data_object.rb +42 -0
- data/lib/super_diff/basic/inspection_tree_builders/date_like.rb +7 -5
- data/lib/super_diff/basic/inspection_tree_builders/default_object.rb +7 -5
- data/lib/super_diff/basic/inspection_tree_builders/hash.rb +7 -5
- data/lib/super_diff/basic/inspection_tree_builders/primitive.rb +3 -1
- data/lib/super_diff/basic/inspection_tree_builders/range_object.rb +19 -0
- data/lib/super_diff/basic/inspection_tree_builders/time_like.rb +8 -8
- data/lib/super_diff/basic/inspection_tree_builders.rb +18 -8
- data/lib/super_diff/basic/operation_tree_builders/array.rb +6 -4
- data/lib/super_diff/basic/operation_tree_builders/custom_object.rb +3 -1
- data/lib/super_diff/basic/operation_tree_builders/data_object.rb +20 -0
- data/lib/super_diff/basic/operation_tree_builders/date_like.rb +2 -0
- data/lib/super_diff/basic/operation_tree_builders/default_object.rb +32 -31
- data/lib/super_diff/basic/operation_tree_builders/hash.rb +49 -46
- data/lib/super_diff/basic/operation_tree_builders/multiline_string.rb +5 -3
- data/lib/super_diff/basic/operation_tree_builders/time_like.rb +5 -3
- data/lib/super_diff/basic/operation_tree_builders.rb +15 -9
- data/lib/super_diff/basic/operation_tree_flatteners/array.rb +4 -2
- data/lib/super_diff/basic/operation_tree_flatteners/collection.rb +11 -11
- data/lib/super_diff/basic/operation_tree_flatteners/custom_object.rb +5 -3
- data/lib/super_diff/basic/operation_tree_flatteners/default_object.rb +6 -5
- data/lib/super_diff/basic/operation_tree_flatteners/hash.rb +5 -3
- data/lib/super_diff/basic/operation_tree_flatteners/multiline_string.rb +3 -1
- data/lib/super_diff/basic/operation_tree_flatteners.rb +8 -6
- data/lib/super_diff/basic/operation_trees/array.rb +2 -0
- data/lib/super_diff/basic/operation_trees/custom_object.rb +2 -0
- data/lib/super_diff/basic/operation_trees/default_object.rb +6 -4
- data/lib/super_diff/basic/operation_trees/hash.rb +2 -0
- data/lib/super_diff/basic/operation_trees/multiline_string.rb +3 -1
- data/lib/super_diff/basic/operation_trees.rb +9 -7
- data/lib/super_diff/basic.rb +12 -7
- data/lib/super_diff/core/abstract_differ.rb +2 -0
- data/lib/super_diff/core/abstract_inspection_tree_builder.rb +2 -0
- data/lib/super_diff/core/abstract_operation_tree.rb +4 -2
- data/lib/super_diff/core/abstract_operation_tree_builder.rb +15 -18
- data/lib/super_diff/core/abstract_operation_tree_flattener.rb +5 -3
- data/lib/super_diff/core/binary_operation.rb +3 -1
- data/lib/super_diff/core/colorized_document_extensions.rb +2 -0
- data/lib/super_diff/core/configuration.rb +23 -43
- data/lib/super_diff/core/differ_dispatcher.rb +4 -2
- data/lib/super_diff/core/gem_version.rb +2 -0
- data/lib/super_diff/core/helpers.rb +14 -12
- data/lib/super_diff/core/implementation_checks.rb +6 -2
- data/lib/super_diff/core/inspection_tree.rb +38 -38
- data/lib/super_diff/core/inspection_tree_builder_dispatcher.rb +5 -5
- data/lib/super_diff/core/inspection_tree_nodes/as_lines_when_rendering_to_lines.rb +3 -1
- data/lib/super_diff/core/inspection_tree_nodes/as_prefix_when_rendering_to_lines.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/as_prelude_when_rendering_to_lines.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/as_single_line.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/base.rb +9 -9
- data/lib/super_diff/core/inspection_tree_nodes/inspection.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/nesting.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/only_when.rb +5 -1
- data/lib/super_diff/core/inspection_tree_nodes/text.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes/when_empty.rb +3 -1
- data/lib/super_diff/core/inspection_tree_nodes/when_non_empty.rb +3 -1
- data/lib/super_diff/core/inspection_tree_nodes/when_rendering_to_lines.rb +3 -1
- data/lib/super_diff/core/inspection_tree_nodes/when_rendering_to_string.rb +2 -0
- data/lib/super_diff/core/inspection_tree_nodes.rb +16 -14
- data/lib/super_diff/core/line.rb +9 -7
- data/lib/super_diff/core/no_differ_available_error.rb +7 -5
- data/lib/super_diff/core/no_inspection_tree_builder_available_error.rb +5 -3
- data/lib/super_diff/core/no_operation_tree_available_error.rb +4 -2
- data/lib/super_diff/core/no_operation_tree_builder_available_error.rb +7 -5
- data/lib/super_diff/core/operation_tree_builder_dispatcher.rb +3 -3
- data/lib/super_diff/core/operation_tree_finder.rb +8 -8
- data/lib/super_diff/core/prefix_for_next_inspection_tree_node.rb +2 -0
- data/lib/super_diff/core/prelude_for_next_inspection_tree_node.rb +2 -0
- data/lib/super_diff/core/recursion_guard.rb +6 -4
- data/lib/super_diff/core/tiered_lines.rb +2 -0
- data/lib/super_diff/core/tiered_lines_elider.rb +53 -54
- data/lib/super_diff/core/tiered_lines_formatter.rb +6 -4
- data/lib/super_diff/core/unary_operation.rb +2 -0
- data/lib/super_diff/core.rb +31 -29
- data/lib/super_diff/csi/bold_sequence.rb +2 -0
- data/lib/super_diff/csi/color.rb +4 -4
- data/lib/super_diff/csi/color_sequence_block.rb +3 -1
- data/lib/super_diff/csi/colorized_document.rb +7 -9
- data/lib/super_diff/csi/document.rb +15 -18
- data/lib/super_diff/csi/eight_bit_color.rb +32 -37
- data/lib/super_diff/csi/four_bit_color.rb +12 -9
- data/lib/super_diff/csi/reset_sequence.rb +2 -0
- data/lib/super_diff/csi/twenty_four_bit_color.rb +22 -21
- data/lib/super_diff/csi/uncolorized_document.rb +2 -0
- data/lib/super_diff/csi.rb +12 -42
- data/lib/super_diff/differs.rb +6 -4
- data/lib/super_diff/equality_matchers/array.rb +18 -16
- data/lib/super_diff/equality_matchers/base.rb +6 -4
- data/lib/super_diff/equality_matchers/default.rb +5 -3
- data/lib/super_diff/equality_matchers/defaults.rb +3 -1
- data/lib/super_diff/equality_matchers/hash.rb +18 -16
- data/lib/super_diff/equality_matchers/main.rb +3 -1
- data/lib/super_diff/equality_matchers/multiline_string.rb +18 -16
- data/lib/super_diff/equality_matchers/primitive.rb +15 -13
- data/lib/super_diff/equality_matchers/singleline_string.rb +16 -14
- data/lib/super_diff/equality_matchers.rb +11 -9
- data/lib/super_diff/errors.rb +4 -2
- data/lib/super_diff/object_inspection.rb +17 -15
- data/lib/super_diff/operation_tree_builders.rb +6 -4
- data/lib/super_diff/operation_tree_flatteners.rb +6 -4
- data/lib/super_diff/operation_trees.rb +6 -4
- data/lib/super_diff/operations.rb +4 -2
- data/lib/super_diff/rails.rb +4 -2
- data/lib/super_diff/rspec/augmented_matcher.rb +3 -1
- data/lib/super_diff/rspec/differ.rb +16 -7
- data/lib/super_diff/rspec/differs/collection_containing_exactly.rb +2 -0
- data/lib/super_diff/rspec/differs/collection_including.rb +2 -0
- data/lib/super_diff/rspec/differs/hash_including.rb +2 -0
- data/lib/super_diff/rspec/differs/object_having_attributes.rb +2 -0
- data/lib/super_diff/rspec/differs.rb +6 -4
- data/lib/super_diff/rspec/inspection_tree_builders/collection_containing_exactly.rb +12 -10
- data/lib/super_diff/rspec/inspection_tree_builders/collection_including.rb +10 -8
- data/lib/super_diff/rspec/inspection_tree_builders/double.rb +20 -18
- data/lib/super_diff/rspec/inspection_tree_builders/generic_describable_matcher.rb +2 -0
- data/lib/super_diff/rspec/inspection_tree_builders/hash_including.rb +10 -8
- data/lib/super_diff/rspec/inspection_tree_builders/instance_of.rb +2 -0
- data/lib/super_diff/rspec/inspection_tree_builders/kind_of.rb +2 -0
- data/lib/super_diff/rspec/inspection_tree_builders/object_having_attributes.rb +12 -10
- data/lib/super_diff/rspec/inspection_tree_builders/primitive.rb +2 -0
- data/lib/super_diff/rspec/inspection_tree_builders/value_within.rb +6 -4
- data/lib/super_diff/rspec/inspection_tree_builders.rb +12 -10
- data/lib/super_diff/rspec/matcher_text_builders/base.rb +12 -12
- data/lib/super_diff/rspec/matcher_text_builders/be_predicate.rb +19 -17
- data/lib/super_diff/rspec/matcher_text_builders/contain_exactly.rb +3 -1
- data/lib/super_diff/rspec/matcher_text_builders/have_predicate.rb +7 -5
- data/lib/super_diff/rspec/matcher_text_builders/match.rb +6 -4
- data/lib/super_diff/rspec/matcher_text_builders/raise_error.rb +5 -3
- data/lib/super_diff/rspec/matcher_text_builders/respond_to.rb +20 -18
- data/lib/super_diff/rspec/matcher_text_builders.rb +9 -7
- data/lib/super_diff/rspec/matcher_text_template.rb +34 -39
- data/lib/super_diff/rspec/object_inspection.rb +7 -5
- data/lib/super_diff/rspec/operation_tree_builders/collection_containing_exactly.rb +4 -4
- data/lib/super_diff/rspec/operation_tree_builders/collection_including.rb +2 -0
- data/lib/super_diff/rspec/operation_tree_builders/hash_including.rb +2 -0
- data/lib/super_diff/rspec/operation_tree_builders/object_having_attributes.rb +2 -0
- data/lib/super_diff/rspec/operation_tree_builders.rb +6 -4
- data/lib/super_diff/rspec-rails.rb +4 -2
- data/lib/super_diff/rspec.rb +15 -13
- data/lib/super_diff/version.rb +3 -1
- data/lib/super_diff.rb +24 -27
- data/super_diff.gemspec +20 -18
- metadata +15 -182
- data/spec/examples.txt +0 -704
- data/spec/integration/rails/active_record_spec.rb +0 -21
- data/spec/integration/rails/active_support_spec.rb +0 -19
- data/spec/integration/rails/engines_spec.rb +0 -25
- data/spec/integration/rails/hash_with_indifferent_access_spec.rb +0 -21
- data/spec/integration/rspec/be_falsey_matcher_spec.rb +0 -58
- data/spec/integration/rspec/be_matcher_spec.rb +0 -605
- data/spec/integration/rspec/be_nil_matcher_spec.rb +0 -57
- data/spec/integration/rspec/be_predicate_matcher_spec.rb +0 -615
- data/spec/integration/rspec/be_truthy_matcher_spec.rb +0 -62
- data/spec/integration/rspec/contain_exactly_matcher_spec.rb +0 -377
- data/spec/integration/rspec/eq_matcher_spec.rb +0 -1066
- data/spec/integration/rspec/generic_describable_matchers_spec.rb +0 -177
- data/spec/integration/rspec/have_attributes_matcher_spec.rb +0 -443
- data/spec/integration/rspec/have_predicate_matcher_spec.rb +0 -478
- data/spec/integration/rspec/include_matcher_spec.rb +0 -452
- data/spec/integration/rspec/magic_metadata_spec.rb +0 -51
- data/spec/integration/rspec/match_array_matcher_spec.rb +0 -424
- data/spec/integration/rspec/match_matcher_spec.rb +0 -1359
- data/spec/integration/rspec/raise_error_matcher_spec.rb +0 -1488
- data/spec/integration/rspec/respond_to_matcher_spec.rb +0 -999
- data/spec/integration/rspec/third_party_matcher_spec.rb +0 -245
- data/spec/integration/rspec/unhandled_errors_spec.rb +0 -150
- data/spec/internal/log/test.log +0 -0
- data/spec/spec_helper.rb +0 -90
- data/spec/support/colorizer.rb +0 -9
- data/spec/support/command_runner.rb +0 -253
- data/spec/support/helpers.rb +0 -21
- data/spec/support/integration/helpers.rb +0 -124
- data/spec/support/integration/matchers/produce_output_when_run_matcher.rb +0 -104
- data/spec/support/integration/matchers.rb +0 -177
- data/spec/support/integration/test_programs/base.rb +0 -143
- data/spec/support/integration/test_programs/plain.rb +0 -19
- data/spec/support/integration/test_programs/rspec_active_record.rb +0 -20
- data/spec/support/integration/test_programs/rspec_active_support.rb +0 -20
- data/spec/support/integration/test_programs/rspec_rails.rb +0 -20
- data/spec/support/integration/test_programs/rspec_rails_engine.rb +0 -20
- data/spec/support/models/a.rb +0 -11
- data/spec/support/models/active_record/person.rb +0 -28
- data/spec/support/models/active_record/query.rb +0 -15
- data/spec/support/models/active_record/shipping_address.rb +0 -24
- data/spec/support/models/customer.rb +0 -22
- data/spec/support/models/empty_class.rb +0 -6
- data/spec/support/models/item.rb +0 -10
- data/spec/support/models/order.rb +0 -9
- data/spec/support/models/person.rb +0 -20
- data/spec/support/models/player.rb +0 -30
- data/spec/support/models/shipping_address.rb +0 -25
- data/spec/support/shared_examples/active_record.rb +0 -428
- data/spec/support/shared_examples/active_support.rb +0 -188
- data/spec/support/shared_examples/elided_diffs.rb +0 -938
- data/spec/support/shared_examples/hash_with_indifferent_access.rb +0 -749
- data/spec/support/shared_examples/key.rb +0 -123
- data/spec/support/unit/helpers.rb +0 -24
- data/spec/support/unit/matchers/be_deprecated_in_favor_of.rb +0 -39
- data/spec/support/unit/matchers/match_output.rb +0 -40
- data/spec/unit/active_record/object_inspection_spec.rb +0 -289
- data/spec/unit/active_support/object_inspection_spec.rb +0 -170
- data/spec/unit/basic/operation_tree_flatteners/array_spec.rb +0 -637
- data/spec/unit/basic/operation_tree_flatteners/custom_object_spec.rb +0 -685
- data/spec/unit/basic/operation_tree_flatteners/default_object_spec.rb +0 -685
- data/spec/unit/basic/operation_tree_flatteners/hash_spec.rb +0 -671
- data/spec/unit/basic/operation_tree_flatteners/multiline_string_spec.rb +0 -131
- data/spec/unit/core/helpers_spec.rb +0 -68
- data/spec/unit/core/tiered_lines_elider_spec.rb +0 -6328
- data/spec/unit/core/tiered_lines_formatter_spec.rb +0 -131
- data/spec/unit/deprecations_spec.rb +0 -176
- data/spec/unit/equality_matchers/main_spec.rb +0 -1842
- data/spec/unit/rspec/matchers/be_compared_to_spec.rb +0 -23
- data/spec/unit/rspec/matchers/be_falsey_spec.rb +0 -9
- data/spec/unit/rspec/matchers/be_nil_spec.rb +0 -9
- data/spec/unit/rspec/matchers/be_predicate_spec.rb +0 -31
- data/spec/unit/rspec/matchers/be_spec.rb +0 -17
- data/spec/unit/rspec/matchers/be_truthy_spec.rb +0 -9
- data/spec/unit/rspec/matchers/contain_exactly_spec.rb +0 -11
- data/spec/unit/rspec/matchers/eq_spec.rb +0 -9
- data/spec/unit/rspec/matchers/have_attributes_spec.rb +0 -11
- data/spec/unit/rspec/matchers/have_predicate_spec.rb +0 -21
- data/spec/unit/rspec/matchers/include_spec.rb +0 -21
- data/spec/unit/rspec/matchers/match_array_spec.rb +0 -11
- data/spec/unit/rspec/matchers/match_spec.rb +0 -9
- data/spec/unit/rspec/matchers/raise_error_spec.rb +0 -77
- data/spec/unit/rspec/matchers/respond_to_spec.rb +0 -85
- data/spec/unit/rspec/object_inspection/rspec_matcher_spec.rb +0 -91
- data/spec/unit/rspec/object_inspection_spec.rb +0 -471
- data/spec/unit/super_diff_spec.rb +0 -2115
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Core
|
3
5
|
class TieredLinesElider
|
@@ -27,7 +29,7 @@ module SuperDiff
|
|
27
29
|
end
|
28
30
|
|
29
31
|
def boxes_to_elide
|
30
|
-
@
|
32
|
+
@boxes_to_elide ||=
|
31
33
|
panes_to_consider_for_eliding.reduce([]) do |array, pane|
|
32
34
|
array + (find_boxes_to_elide_within(pane) || [])
|
33
35
|
end
|
@@ -38,12 +40,12 @@ module SuperDiff
|
|
38
40
|
end
|
39
41
|
|
40
42
|
def panes
|
41
|
-
@
|
43
|
+
@panes ||=
|
42
44
|
BuildPanes.call(dirty_panes: padded_dirty_panes, lines: lines)
|
43
45
|
end
|
44
46
|
|
45
47
|
def padded_dirty_panes
|
46
|
-
@
|
48
|
+
@padded_dirty_panes ||=
|
47
49
|
combine_congruent_panes(
|
48
50
|
dirty_panes
|
49
51
|
.map(&:padded)
|
@@ -52,33 +54,33 @@ module SuperDiff
|
|
52
54
|
end
|
53
55
|
|
54
56
|
def dirty_panes
|
55
|
-
@
|
57
|
+
@dirty_panes ||=
|
56
58
|
lines
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
end
|
59
|
+
.each_with_index
|
60
|
+
.reject { |line, _index| line.type == :noop }
|
61
|
+
.reduce([]) do |panes, (_, index)|
|
62
|
+
if !panes.empty? && panes.last.range.end == index - 1
|
63
|
+
panes[0..-2] + [panes[-1].extended_to(index)]
|
64
|
+
else
|
65
|
+
panes + [Pane.new(type: :dirty, range: index..index)]
|
65
66
|
end
|
67
|
+
end
|
66
68
|
end
|
67
69
|
|
68
70
|
def with_box_elided(box, lines)
|
69
71
|
box_at_start_of_lines =
|
70
|
-
if lines.first.complete_bookend?
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
72
|
+
box.range.begin == if lines.first.complete_bookend?
|
73
|
+
1
|
74
|
+
else
|
75
|
+
0
|
76
|
+
end
|
75
77
|
|
76
78
|
box_at_end_of_lines =
|
77
|
-
if lines.last.complete_bookend?
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
79
|
+
box.range.end == if lines.last.complete_bookend?
|
80
|
+
lines.size - 2
|
81
|
+
else
|
82
|
+
lines.size - 1
|
83
|
+
end
|
82
84
|
|
83
85
|
if one_dimensional_line_tree? && outermost_box?(box)
|
84
86
|
if box_at_start_of_lines
|
@@ -108,7 +110,7 @@ module SuperDiff
|
|
108
110
|
def all_indentation_levels
|
109
111
|
lines
|
110
112
|
.map(&:indentation_level)
|
111
|
-
.select
|
113
|
+
.select(&:positive?)
|
112
114
|
.uniq
|
113
115
|
end
|
114
116
|
|
@@ -120,11 +122,11 @@ module SuperDiff
|
|
120
122
|
lines[pane.range].reject(&:complete_bookend?).size
|
121
123
|
|
122
124
|
if total_size_before_eliding > maximum
|
123
|
-
if maximum
|
125
|
+
if maximum.positive?
|
124
126
|
set_of_boxes.find do |boxes|
|
125
127
|
total_size_after_eliding =
|
126
128
|
total_size_before_eliding -
|
127
|
-
|
129
|
+
boxes.sum { |box| box.range.size - SIZE_OF_ELISION }
|
128
130
|
total_size_after_eliding <= maximum
|
129
131
|
end
|
130
132
|
else
|
@@ -146,11 +148,11 @@ module SuperDiff
|
|
146
148
|
|
147
149
|
possible_indentation_levels =
|
148
150
|
boxes_within_pane
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
151
|
+
.map(&:indentation_level)
|
152
|
+
.select(&:positive?)
|
153
|
+
.uniq
|
154
|
+
.sort
|
155
|
+
.reverse
|
154
156
|
|
155
157
|
possible_indentation_levels.map do |indentation_level|
|
156
158
|
boxes_within_pane.select do |box|
|
@@ -183,13 +185,12 @@ module SuperDiff
|
|
183
185
|
def combine(spannables, on:)
|
184
186
|
criterion = on
|
185
187
|
spannables.reduce([]) do |combined_spannables, spannable|
|
186
|
-
if
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
)
|
188
|
+
if !combined_spannables.empty? &&
|
189
|
+
spannable.range.begin <=
|
190
|
+
combined_spannables.last.range.end + 1 &&
|
191
|
+
spannable.public_send(criterion) ==
|
192
|
+
combined_spannables.last.public_send(criterion)
|
193
|
+
|
193
194
|
combined_spannables[0..-2] +
|
194
195
|
[combined_spannables[-1].extended_to(spannable.range.end)]
|
195
196
|
else
|
@@ -199,12 +200,12 @@ module SuperDiff
|
|
199
200
|
end
|
200
201
|
|
201
202
|
def boxes
|
202
|
-
@
|
203
|
+
@boxes ||= BuildBoxes.call(lines)
|
203
204
|
end
|
204
205
|
|
205
206
|
def with_start_of_box_elided(box, lines)
|
206
207
|
amount_to_elide =
|
207
|
-
if maximum
|
208
|
+
if maximum.positive?
|
208
209
|
box.range.size - maximum + SIZE_OF_ELISION
|
209
210
|
else
|
210
211
|
box.range.size
|
@@ -220,14 +221,14 @@ module SuperDiff
|
|
220
221
|
|
221
222
|
def with_end_of_box_elided(box, lines)
|
222
223
|
amount_to_elide =
|
223
|
-
if maximum
|
224
|
+
if maximum.positive?
|
224
225
|
box.range.size - maximum + SIZE_OF_ELISION
|
225
226
|
else
|
226
227
|
box.range.size
|
227
228
|
end
|
228
229
|
|
229
230
|
range =
|
230
|
-
if amount_to_elide
|
231
|
+
if amount_to_elide.positive?
|
231
232
|
Range.new(box.range.end - amount_to_elide + 1, box.range.end)
|
232
233
|
else
|
233
234
|
box.range
|
@@ -242,15 +243,14 @@ module SuperDiff
|
|
242
243
|
|
243
244
|
def with_middle_of_box_elided(box, lines)
|
244
245
|
half_of_maximum, remainder =
|
245
|
-
if maximum
|
246
|
+
if maximum.positive?
|
246
247
|
(maximum - SIZE_OF_ELISION).divmod(2)
|
247
248
|
else
|
248
249
|
[0, 0]
|
249
250
|
end
|
250
251
|
|
251
|
-
opening_length
|
252
|
-
|
253
|
-
half_of_maximum + remainder
|
252
|
+
opening_length = half_of_maximum
|
253
|
+
closing_length = half_of_maximum + remainder
|
254
254
|
|
255
255
|
with_subset_of_lines_elided(
|
256
256
|
lines,
|
@@ -290,7 +290,7 @@ module SuperDiff
|
|
290
290
|
private
|
291
291
|
|
292
292
|
def beginning
|
293
|
-
if
|
293
|
+
if dirty_panes.empty? || dirty_panes.first.range.begin.zero?
|
294
294
|
[]
|
295
295
|
else
|
296
296
|
[
|
@@ -324,10 +324,9 @@ module SuperDiff
|
|
324
324
|
end
|
325
325
|
|
326
326
|
def ending
|
327
|
-
if
|
328
|
-
|
329
|
-
|
330
|
-
)
|
327
|
+
if dirty_panes.empty? ||
|
328
|
+
dirty_panes.last.range.end >= lines.size - 1
|
329
|
+
|
331
330
|
[]
|
332
331
|
else
|
333
332
|
[
|
@@ -354,8 +353,8 @@ module SuperDiff
|
|
354
353
|
end
|
355
354
|
|
356
355
|
def capped_to(beginning, ending)
|
357
|
-
new_beginning = range.begin
|
358
|
-
new_ending = range.end
|
356
|
+
new_beginning = [range.begin, beginning].max
|
357
|
+
new_ending = [range.end, ending].min
|
359
358
|
self.class.new(
|
360
359
|
type: type,
|
361
360
|
range: Range.new(new_beginning, new_ending)
|
@@ -452,11 +451,11 @@ module SuperDiff
|
|
452
451
|
end
|
453
452
|
|
454
453
|
def prefix
|
455
|
-
|
454
|
+
''
|
456
455
|
end
|
457
456
|
|
458
457
|
def value
|
459
|
-
|
458
|
+
'# ...'
|
460
459
|
end
|
461
460
|
|
462
461
|
def elided?
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Core
|
3
5
|
class TieredLinesFormatter
|
@@ -29,8 +31,8 @@ module SuperDiff
|
|
29
31
|
class FormattableLine
|
30
32
|
extend AttrExtras.mixin
|
31
33
|
|
32
|
-
INDENTATION_UNIT =
|
33
|
-
ICONS = { delete:
|
34
|
+
INDENTATION_UNIT = ' '
|
35
|
+
ICONS = { delete: '-', insert: '+', elision: ' ', noop: ' ' }.freeze
|
34
36
|
COLORS = {
|
35
37
|
delete: :expected,
|
36
38
|
insert: :actual,
|
@@ -41,7 +43,7 @@ module SuperDiff
|
|
41
43
|
pattr_initialize :line
|
42
44
|
|
43
45
|
def content
|
44
|
-
icon
|
46
|
+
"#{icon} #{indentation}#{line.prefix}#{line.value}#{possible_comma}"
|
45
47
|
end
|
46
48
|
|
47
49
|
def color
|
@@ -69,7 +71,7 @@ module SuperDiff
|
|
69
71
|
end
|
70
72
|
|
71
73
|
def possible_comma
|
72
|
-
line.add_comma? ?
|
74
|
+
line.add_comma? ? ',' : ''
|
73
75
|
end
|
74
76
|
end
|
75
77
|
end
|
data/lib/super_diff/core.rb
CHANGED
@@ -1,69 +1,71 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Core
|
3
|
-
autoload :AbstractDiffer,
|
5
|
+
autoload :AbstractDiffer, 'super_diff/core/abstract_differ'
|
4
6
|
autoload(
|
5
7
|
:AbstractInspectionTreeBuilder,
|
6
|
-
|
8
|
+
'super_diff/core/abstract_inspection_tree_builder'
|
7
9
|
)
|
8
|
-
autoload :AbstractOperationTree,
|
10
|
+
autoload :AbstractOperationTree, 'super_diff/core/abstract_operation_tree'
|
9
11
|
autoload(
|
10
12
|
:AbstractOperationTreeBuilder,
|
11
|
-
|
13
|
+
'super_diff/core/abstract_operation_tree_builder'
|
12
14
|
)
|
13
15
|
autoload(
|
14
16
|
:AbstractOperationTreeFlattener,
|
15
|
-
|
17
|
+
'super_diff/core/abstract_operation_tree_flattener'
|
16
18
|
)
|
17
|
-
autoload :BinaryOperation,
|
19
|
+
autoload :BinaryOperation, 'super_diff/core/binary_operation'
|
18
20
|
autoload(
|
19
21
|
:ColorizedDocumentExtensions,
|
20
|
-
|
22
|
+
'super_diff/core/colorized_document_extensions'
|
21
23
|
)
|
22
|
-
autoload :Configuration,
|
23
|
-
autoload :DifferDispatcher,
|
24
|
-
autoload :GemVersion,
|
25
|
-
autoload :Helpers,
|
26
|
-
autoload :ImplementationChecks,
|
27
|
-
autoload :InspectionTree,
|
24
|
+
autoload :Configuration, 'super_diff/core/configuration'
|
25
|
+
autoload :DifferDispatcher, 'super_diff/core/differ_dispatcher'
|
26
|
+
autoload :GemVersion, 'super_diff/core/gem_version'
|
27
|
+
autoload :Helpers, 'super_diff/core/helpers'
|
28
|
+
autoload :ImplementationChecks, 'super_diff/core/implementation_checks'
|
29
|
+
autoload :InspectionTree, 'super_diff/core/inspection_tree'
|
28
30
|
autoload(
|
29
31
|
:InspectionTreeBuilderDispatcher,
|
30
|
-
|
32
|
+
'super_diff/core/inspection_tree_builder_dispatcher'
|
31
33
|
)
|
32
|
-
autoload :InspectionTreeNodes,
|
33
|
-
autoload :Line,
|
34
|
+
autoload :InspectionTreeNodes, 'super_diff/core/inspection_tree_nodes'
|
35
|
+
autoload :Line, 'super_diff/core/line'
|
34
36
|
autoload(
|
35
37
|
:OperationTreeBuilderDispatcher,
|
36
|
-
|
38
|
+
'super_diff/core/operation_tree_builder_dispatcher'
|
37
39
|
)
|
38
40
|
autoload(
|
39
41
|
:NoDifferAvailableError,
|
40
|
-
|
42
|
+
'super_diff/core/no_differ_available_error'
|
41
43
|
)
|
42
44
|
autoload(
|
43
45
|
:NoInspectionTreeAvailableError,
|
44
|
-
|
46
|
+
'super_diff/core/no_inspection_tree_builder_available_error'
|
45
47
|
)
|
46
48
|
autoload(
|
47
49
|
:NoOperationTreeBuilderAvailableError,
|
48
|
-
|
50
|
+
'super_diff/core/no_operation_tree_builder_available_error'
|
49
51
|
)
|
50
52
|
autoload(
|
51
53
|
:NoOperationTreeAvailableError,
|
52
|
-
|
54
|
+
'super_diff/core/no_operation_tree_available_error'
|
53
55
|
)
|
54
|
-
autoload :OperationTreeFinder,
|
56
|
+
autoload :OperationTreeFinder, 'super_diff/core/operation_tree_finder'
|
55
57
|
autoload(
|
56
58
|
:PrefixForNextInspectionTreeNode,
|
57
|
-
|
59
|
+
'super_diff/core/prefix_for_next_inspection_tree_node'
|
58
60
|
)
|
59
61
|
autoload(
|
60
62
|
:PreludeForNextInspectionTreeNode,
|
61
|
-
|
63
|
+
'super_diff/core/prelude_for_next_inspection_tree_node'
|
62
64
|
)
|
63
|
-
autoload :RecursionGuard,
|
64
|
-
autoload :TieredLines,
|
65
|
-
autoload :TieredLinesElider,
|
66
|
-
autoload :TieredLinesFormatter,
|
67
|
-
autoload :UnaryOperation,
|
65
|
+
autoload :RecursionGuard, 'super_diff/core/recursion_guard'
|
66
|
+
autoload :TieredLines, 'super_diff/core/tiered_lines'
|
67
|
+
autoload :TieredLinesElider, 'super_diff/core/tiered_lines_elider'
|
68
|
+
autoload :TieredLinesFormatter, 'super_diff/core/tiered_lines_formatter'
|
69
|
+
autoload :UnaryOperation, 'super_diff/core/unary_operation'
|
68
70
|
end
|
69
71
|
end
|
data/lib/super_diff/csi/color.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Csi
|
3
5
|
class Color
|
@@ -51,10 +53,8 @@ module SuperDiff
|
|
51
53
|
if %i[foreground background].include?(layer)
|
52
54
|
layer
|
53
55
|
else
|
54
|
-
raise ArgumentError.
|
55
|
-
|
56
|
-
"Layer must be :foreground or :background."
|
57
|
-
)
|
56
|
+
raise ArgumentError, "Invalid layer #{layer.inspect}. " \
|
57
|
+
'Layer must be :foreground or :background.'
|
58
58
|
end
|
59
59
|
end
|
60
60
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Csi
|
3
5
|
class ColorSequenceBlock
|
@@ -14,7 +16,7 @@ module SuperDiff
|
|
14
16
|
def push(color)
|
15
17
|
colors.push(color)
|
16
18
|
end
|
17
|
-
|
19
|
+
alias << push
|
18
20
|
|
19
21
|
def to_s
|
20
22
|
colors.map(&:to_s).join
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Csi
|
3
5
|
class ColorizedDocument < Document
|
@@ -19,9 +21,9 @@ module SuperDiff
|
|
19
21
|
add_part(Csi.reset_sequence)
|
20
22
|
|
21
23
|
color_sequence_to_reopen = color_sequences_open_in_parent.pop
|
22
|
-
|
23
|
-
|
24
|
-
|
24
|
+
return unless color_sequences_open_in_parent.any?
|
25
|
+
|
26
|
+
add_part(color_sequence_to_reopen)
|
25
27
|
end
|
26
28
|
|
27
29
|
def colorize_inline(contents, colors, opts)
|
@@ -54,13 +56,9 @@ module SuperDiff
|
|
54
56
|
ColorSequenceBlock
|
55
57
|
.new(colors)
|
56
58
|
.tap do |sequence|
|
57
|
-
if opts[:fg]
|
58
|
-
sequence << Color.resolve(opts[:fg], layer: :foreground)
|
59
|
-
end
|
59
|
+
sequence << Color.resolve(opts[:fg], layer: :foreground) if opts[:fg]
|
60
60
|
|
61
|
-
if opts[:bg]
|
62
|
-
sequence << Color.resolve(opts[:bg], layer: :background)
|
63
|
-
end
|
61
|
+
sequence << Color.resolve(opts[:bg], layer: :background) if opts[:bg]
|
64
62
|
end
|
65
63
|
end
|
66
64
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module SuperDiff
|
2
4
|
module Csi
|
3
5
|
class Document
|
@@ -14,8 +16,8 @@ module SuperDiff
|
|
14
16
|
parts.each(&block)
|
15
17
|
end
|
16
18
|
|
17
|
-
def bold(
|
18
|
-
colorize(BoldSequence.new,
|
19
|
+
def bold(...)
|
20
|
+
colorize(BoldSequence.new, ...)
|
19
21
|
end
|
20
22
|
|
21
23
|
def colorize(*args, **opts, &block)
|
@@ -23,11 +25,10 @@ module SuperDiff
|
|
23
25
|
args.partition { |arg| arg.is_a?(String) || arg.is_a?(self.class) }
|
24
26
|
|
25
27
|
if colors[0].is_a?(Symbol)
|
26
|
-
if colors[0] == :colorize
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
end
|
28
|
+
raise ArgumentError, "#colorize can't call itself!" if colors[0] == :colorize
|
29
|
+
|
30
|
+
public_send(colors[0], *contents, *colors[1..], **opts, &block)
|
31
|
+
|
31
32
|
elsif !block && colors.empty? && opts.empty?
|
32
33
|
text(*contents)
|
33
34
|
elsif block
|
@@ -35,10 +36,10 @@ module SuperDiff
|
|
35
36
|
elsif contents.any?
|
36
37
|
colorize_inline(contents, colors, opts)
|
37
38
|
else
|
38
|
-
raise ArgumentError,
|
39
|
+
raise ArgumentError, 'Must have something to colorize!'
|
39
40
|
end
|
40
41
|
end
|
41
|
-
|
42
|
+
alias colored colorize
|
42
43
|
|
43
44
|
def text(*contents, **, &block)
|
44
45
|
if block
|
@@ -46,10 +47,10 @@ module SuperDiff
|
|
46
47
|
elsif contents.any?
|
47
48
|
contents.each { |part| add_part(part) }
|
48
49
|
else
|
49
|
-
raise ArgumentError
|
50
|
+
raise ArgumentError, 'Must have something to add to the document!'
|
50
51
|
end
|
51
52
|
end
|
52
|
-
|
53
|
+
alias plain text
|
53
54
|
|
54
55
|
def line(*contents, indent_by: 0, &block)
|
55
56
|
indent(by: indent_by) do
|
@@ -60,9 +61,7 @@ module SuperDiff
|
|
60
61
|
elsif contents.any?
|
61
62
|
text(*contents)
|
62
63
|
else
|
63
|
-
raise ArgumentError
|
64
|
-
"Must have something to add to the document!"
|
65
|
-
)
|
64
|
+
raise ArgumentError, 'Must have something to add to the document!'
|
66
65
|
end
|
67
66
|
end
|
68
67
|
|
@@ -75,7 +74,7 @@ module SuperDiff
|
|
75
74
|
|
76
75
|
def indent(by:, &block)
|
77
76
|
# TODO: This won't work if using `text` manually to add lines
|
78
|
-
indentation_stack << (by.is_a?(String) ? by :
|
77
|
+
indentation_stack << (by.is_a?(String) ? by : ' ' * by)
|
79
78
|
evaluate_block(&block)
|
80
79
|
indentation_stack.pop
|
81
80
|
end
|
@@ -116,13 +115,11 @@ module SuperDiff
|
|
116
115
|
end
|
117
116
|
elsif Csi::Color.exists?(name.to_sym)
|
118
117
|
ColorRequest.new(name: name.to_sym, line: false)
|
119
|
-
else
|
120
|
-
nil
|
121
118
|
end
|
122
119
|
end
|
123
120
|
|
124
121
|
def evaluate_block(&block)
|
125
|
-
if block.arity
|
122
|
+
if block.arity.positive?
|
126
123
|
block.call(self)
|
127
124
|
else
|
128
125
|
instance_eval(&block)
|