Sha256: 17772075d2a346824d5d31d3a41bf35084cb3627f8941f127de18acb6b1515e0
Contents?: true
Size: 1.49 KB
Versions: 2
Compression:
Stored size: 1.49 KB
Contents
# frozen_string_literal: true module DeadEnd # Multiple lines form a singular CodeBlock # # Source code is made of multiple CodeBlocks. # # Example: # # code_block.to_s # => # # def foo # # puts "foo" # # end # # code_block.valid? # => true # code_block.in_valid? # => false # # class CodeBlock attr_reader :lines def initialize(lines: []) @lines = Array(lines) end def visible_lines @lines.select(&:visible?).select(&:not_empty?) end def mark_invisible @lines.map(&:mark_invisible) end def is_end? to_s.strip == "end" end def hidden? @lines.all?(&:hidden?) end def starts_at @starts_at ||= @lines.first&.line_number end def ends_at @ends_at ||= @lines.last&.line_number end # This is used for frontier ordering, we are searching from # the largest indentation to the smallest. This allows us to # populate an array with multiple code blocks then call `sort!` # on it without having to specify the sorting criteria def <=>(other) out = self.current_indent <=> other.current_indent return out if out != 0 # Stable sort self.starts_at <=> other.starts_at end def current_indent @current_indent ||= lines.select(&:not_empty?).map(&:indent).min || 0 end def invalid? !valid? end def valid? DeadEnd.valid?(self.to_s) end def to_s @lines.join end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
dead_end-1.0.1 | lib/dead_end/code_block.rb |
dead_end-1.0.0 | lib/dead_end/code_block.rb |