SILENT KILLERPanel

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


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/did_you_mean

NameTypeSizeLast ModifiedActions
core_ext Directory - -
formatters Directory - -
spell_checkers Directory - -
experimental.rb File 139 bytes April 24 2025 07:53:45.
formatter.rb File 1304 bytes April 24 2025 07:53:45.
jaro_winkler.rb File 1833 bytes April 24 2025 07:53:45.
levenshtein.rb File 1375 bytes April 24 2025 07:53:45.
spell_checker.rb File 1297 bytes April 24 2025 07:53:45.
tree_spell_checker.rb File 2873 bytes April 24 2025 07:53:45.
verbose.rb File 137 bytes April 24 2025 07:53:45.
version.rb File 49 bytes April 24 2025 07:53:45.

Reading File: //opt//alt/ruby32/share/ruby/did_you_mean/levenshtein.rb

module DidYouMean
  module Levenshtein # :nodoc:
    # This code is based directly on the Text gem implementation
    # Copyright (c) 2006-2013 Paul Battley, Michael Neumann, Tim Fletcher.
    #
    # Returns a value representing the "cost" of transforming str1 into str2
    def distance(str1, str2)
      n = str1.length
      m = str2.length
      return m if n.zero?
      return n if m.zero?

      d = (0..m).to_a
      x = nil

      # to avoid duplicating an enumerable object, create it outside of the loop
      str2_codepoints = str2.codepoints

      str1.each_codepoint.with_index(1) do |char1, i|
        j = 0
        while j < m
          cost = (char1 == str2_codepoints[j]) ? 0 : 1
          x = min3(
            d[j+1] + 1, # insertion
            i + 1,      # deletion
            d[j] + cost # substitution
          )
          d[j] = i
          i = x

          j += 1
        end
        d[m] = x
      end

      x
    end
    module_function :distance

    private

    # detects the minimum value out of three arguments. This method is
    # faster than `[a, b, c].min` and puts less GC pressure.
    # See https://github.com/ruby/did_you_mean/pull/1 for a performance
    # benchmark.
    def min3(a, b, c)
      if a < b && a < c
        a
      elsif b < c
        b
      else
        c
      end
    end
    module_function :min3
  end
end

SILENT KILLER Tool