Class: Jsonc::Merge::MergeResult
- Inherits:
-
Ast::Merge::MergeResultBase
- Object
- Ast::Merge::MergeResultBase
- Jsonc::Merge::MergeResult
- Defined in:
- lib/jsonc/merge/merge_result.rb
Overview
Tracks the result of a merge operation, including the merged content,
decisions made, and statistics.
Inherits decision constants and base functionality from Ast::Merge::MergeResult.
Constant Summary collapse
- DECISION_KEPT_TEMPLATE =
Inherit decision constants from base class
Ast::Merge::MergeResultBase::DECISION_KEPT_TEMPLATE
- DECISION_KEPT_DEST =
Ast::Merge::MergeResultBase::DECISION_KEPT_DEST
- DECISION_MERGED =
Ast::Merge::MergeResultBase::DECISION_MERGED
- DECISION_ADDED =
Ast::Merge::MergeResultBase::DECISION_ADDED
- DECISION_FREEZE_BLOCK =
Ast::Merge::MergeResultBase::DECISION_FREEZE_BLOCK
Instance Attribute Summary collapse
-
#statistics ⇒ Hash
readonly
Statistics about the merge.
Instance Method Summary collapse
-
#add_blank_line(decision: DECISION_MERGED, source: :merged) ⇒ Object
Add a blank line.
-
#add_freeze_block(freeze_node) ⇒ Object
Add content from a freeze block.
-
#add_line(line, decision:, source:, original_line: nil) ⇒ Object
Add a single line to the result.
-
#add_lines(lines, decision:, source:, start_line: nil) ⇒ Object
Add multiple lines to the result.
-
#add_node(node, decision:, source:, analysis:) ⇒ Object
Add content from a node wrapper.
-
#content ⇒ String
Alias for to_json.
-
#initialize(**options) ⇒ MergeResult
constructor
Initialize a new merge result.
-
#line_count ⇒ Integer
Get line count.
-
#to_json ⇒ String
Get the merged content as a JSON string.
-
#to_s ⇒ String
Alias for to_json (used by SmartMerger#merge).
Constructor Details
#initialize(**options) ⇒ MergeResult
Initialize a new merge result
27 28 29 30 31 32 33 34 35 36 |
# File 'lib/jsonc/merge/merge_result.rb', line 27 def initialize(**) super(**) @statistics = { template_lines: 0, dest_lines: 0, merged_lines: 0, freeze_preserved_lines: 0, total_decisions: 0, } end |
Instance Attribute Details
#statistics ⇒ Hash (readonly)
Returns Statistics about the merge.
23 24 25 |
# File 'lib/jsonc/merge/merge_result.rb', line 23 def statistics @statistics end |
Instance Method Details
#add_blank_line(decision: DECISION_MERGED, source: :merged) ⇒ Object
Add a blank line
73 74 75 |
# File 'lib/jsonc/merge/merge_result.rb', line 73 def add_blank_line(decision: DECISION_MERGED, source: :merged) add_line("", decision: decision, source: source) end |
#add_freeze_block(freeze_node) ⇒ Object
Add content from a freeze block
80 81 82 83 84 85 86 87 88 89 |
# File 'lib/jsonc/merge/merge_result.rb', line 80 def add_freeze_block(freeze_node) freeze_node.lines.each_with_index do |line, idx| add_line( line.chomp, decision: DECISION_FREEZE_BLOCK, source: :destination, original_line: freeze_node.start_line + idx, ) end end |
#add_line(line, decision:, source:, original_line: nil) ⇒ Object
Add a single line to the result
44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/jsonc/merge/merge_result.rb', line 44 def add_line(line, decision:, source:, original_line: nil) @lines << { content: line, decision: decision, source: source, original_line: original_line, } track_statistics(decision, source) track_decision(decision, source, line: original_line) end |
#add_lines(lines, decision:, source:, start_line: nil) ⇒ Object
Add multiple lines to the result
62 63 64 65 66 67 |
# File 'lib/jsonc/merge/merge_result.rb', line 62 def add_lines(lines, decision:, source:, start_line: nil) lines.each_with_index do |line, idx| original_line = start_line ? start_line + idx : nil add_line(line, decision: decision, source: source, original_line: original_line) end end |
#add_node(node, decision:, source:, analysis:) ⇒ Object
Add content from a node wrapper
97 98 99 100 101 102 103 104 105 106 |
# File 'lib/jsonc/merge/merge_result.rb', line 97 def add_node(node, decision:, source:, analysis:) return unless node.start_line && node.end_line (node.start_line..node.end_line).each do |line_num| line = analysis.line_at(line_num) next unless line add_line(line.chomp, decision: decision, source: source, original_line: line_num) end end |
#content ⇒ String
Alias for to_json
120 121 122 |
# File 'lib/jsonc/merge/merge_result.rb', line 120 def content to_json end |
#line_count ⇒ Integer
Get line count
132 133 134 |
# File 'lib/jsonc/merge/merge_result.rb', line 132 def line_count @lines.size end |
#to_json ⇒ String
Get the merged content as a JSON string
111 112 113 114 115 116 |
# File 'lib/jsonc/merge/merge_result.rb', line 111 def to_json content = @lines.map { |l| l[:content] }.join("\n") # Ensure trailing newline content += "\n" unless content.end_with?("\n") || content.empty? content end |
#to_s ⇒ String
Alias for to_json (used by SmartMerger#merge)
126 127 128 |
# File 'lib/jsonc/merge/merge_result.rb', line 126 def to_s to_json end |