Sha256: 4d11981175e7ccbe5b1cc598bd1f800cff532e323c93edc3a163e05c04ee2960

Contents?: true

Size: 1.58 KB

Versions: 20

Compression:

Stored size: 1.58 KB

Contents

# encoding: utf-8

module TTY
  class Prompt
    # A class responsible for string comparison
    class Distance
      # Calculate the optimal string alignment distance
      #
      # @api public
      def distance(first, second)
        distances = []
        rows      = first.to_s.length
        cols      = second.to_s.length

        0.upto(rows) do |index|
          distances << [index] + [0] * cols
        end
        distances[0] = 0.upto(cols).to_a

        1.upto(rows) do |first_index|
          1.upto(cols) do |second_index|
            first_char  = first[first_index - 1]
            second_char = second[second_index - 1]
            cost        = first_char == second_char ? 0 : 1

            distances[first_index][second_index] = [
              distances[first_index - 1][second_index], # deletion
              distances[first_index][second_index - 1],     # insertion
              distances[first_index - 1][second_index - 1]  # substitution
            ].min + cost

            if first_index > 1 && second_index > 1
              first_previous_char = first[first_index - 2]
              second_previous_char = second[second_index - 2]
              if first_char == second_previous_char && second_char == first_previous_char
                distances[first_index][second_index] = [
                  distances[first_index][second_index],
                  distances[first_index - 2][second_index - 2] + 1 # transposition
                ].min
              end
            end

          end
        end
        distances[rows][cols]
      end
    end # Distance
  end # Prompt
end # TTY

Version data entries

20 entries across 20 versions & 2 rubygems

Version Path
tty-prompt-0.15.0 lib/tty/prompt/distance.rb
tty-prompt-0.14.0 lib/tty/prompt/distance.rb
tty-prompt-0.13.2 lib/tty/prompt/distance.rb
tty-prompt-0.13.1 lib/tty/prompt/distance.rb
tty-prompt-0.13.0 lib/tty/prompt/distance.rb
austb-tty-prompt-0.13.0 lib/tty/prompt/distance.rb
tty-prompt-0.12.0 lib/tty/prompt/distance.rb
tty-prompt-0.11.0 lib/tty/prompt/distance.rb
tty-prompt-0.10.1 lib/tty/prompt/distance.rb
tty-prompt-0.10.0 lib/tty/prompt/distance.rb
tty-prompt-0.9.0 lib/tty/prompt/distance.rb
tty-prompt-0.8.0 lib/tty/prompt/distance.rb
tty-prompt-0.7.1 lib/tty/prompt/distance.rb
tty-prompt-0.7.0 lib/tty/prompt/distance.rb
tty-prompt-0.6.0 lib/tty/prompt/distance.rb
tty-prompt-0.5.0 lib/tty/prompt/distance.rb
tty-prompt-0.4.0 lib/tty/prompt/distance.rb
tty-prompt-0.3.0 lib/tty/prompt/distance.rb
tty-prompt-0.2.0 lib/tty/prompt/distance.rb
tty-prompt-0.1.0 lib/tty/prompt/distance.rb