Sha256: 6e32634845bf77c582e0008025ba78a703f2fe98df4dbd55ccce176479353ce6

Contents?: true

Size: 1.37 KB

Versions: 15

Compression:

Stored size: 1.37 KB

Contents

module DEBUGGER__
  class AbbrevCommand
    class TrieNode
      def initialize
        @children = {}
        @types = {} # set
      end

      def append c, type
        trie = (@children[c] ||= TrieNode.new)
        trie.add_type type
      end

      def [](c)
        @children[c]
      end

      def add_type type
        @types[type] = true
        self
      end

      def types
        @types.keys
      end

      def type
        if @types.size == 1
          @types.keys.first
        else
          nil
        end
      end

      def candidates
        @children.map{|c, n|
          ss = n.candidates
          ss.empty? ? c :
          ss.map{|s|
            c+s
          }
        }.flatten
      end
    end

    # config: { type: [commands...], ... }
    def initialize config
      @trie = TrieNode.new
      build config
    end

    private def build config
      config.each do |type, commands|
        commands.each do |command|
          trie = @trie
          command.each_char do |c|
            trie = trie.append(c, type)
          end
        end
      end
    end

    def search str, if_none = nil
      trie = @trie
      str.each_char do |c|
        if trie = trie[c]
          return trie.type if trie.type
        else
          return if_none
        end
      end
      yield trie.candidates.map{|s| str + s} if block_given?
      if_none
    end
  end
end

Version data entries

15 entries across 15 versions & 3 rubygems

Version Path
debug-1.10.0 lib/debug/abbrev_command.rb
blacklight-spotlight-3.6.0.beta8 vendor/bundle/ruby/3.2.0/gems/debug-1.9.2/lib/debug/abbrev_command.rb
debug-1.9.2 lib/debug/abbrev_command.rb
debug-1.9.1 lib/debug/abbrev_command.rb
debug-1.9.0 lib/debug/abbrev_command.rb
study_line-0.1.6 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
study_line-0.1.5 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
study_line-0.1.4 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
study_line-0.1.3 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
study_line-0.1.2 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
study_line-0.1.1 vendor/bundle/ruby/3.2.0/gems/debug-1.8.0/lib/debug/abbrev_command.rb
debug-1.8.0 lib/debug/abbrev_command.rb
debug-1.7.2 lib/debug/abbrev_command.rb
debug-1.7.1 lib/debug/abbrev_command.rb
debug-1.7.0 lib/debug/abbrev_command.rb