Sha256: 165d2eb21c4101a58aac85162c8635ef048191dcef35f02fc4598ff974337a06

Contents?: true

Size: 764 Bytes

Versions: 73

Compression:

Stored size: 764 Bytes

Contents

unless Array.method_defined? :bsearch
  class Array
    def bsearch
      return to_enum(__method__) unless block_given?
      from = 0
      to   = size - 1
      satisfied = nil
      while from <= to do
        midpoint = (from + to).div(2)
        result = yield(cur = self[midpoint])
        case result
        when Numeric
          return cur if result == 0
          result = result < 0
        when true
          satisfied = cur
        when nil, false
          # nothing to do
        else
          raise TypeError, "wrong argument type #{result.class} (must be numeric, true, false or nil)"
        end

        if result
          to = midpoint - 1
        else
          from = midpoint + 1
        end
      end
      satisfied
    end
  end
end

Version data entries

73 entries across 73 versions & 5 rubygems

Version Path
honeybadger-4.5.3 vendor/bundle/ruby/2.6.0/gems/backports-3.15.0/lib/backports/2.0.0/array/bsearch.rb
backports-3.15.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.14.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.13.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.12.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.11.4 lib/backports/2.0.0/array/bsearch.rb
backports-3.11.3 lib/backports/2.0.0/array/bsearch.rb
backports-3.11.2 lib/backports/2.0.0/array/bsearch.rb
backports-3.11.1 lib/backports/2.0.0/array/bsearch.rb
backports-3.11.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.10.3 lib/backports/2.0.0/array/bsearch.rb
backports-3.10.2 lib/backports/2.0.0/array/bsearch.rb
backports-3.10.1 lib/backports/2.0.0/array/bsearch.rb
backports-3.10.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.9.1 lib/backports/2.0.0/array/bsearch.rb
backports-3.9.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.8.0 lib/backports/2.0.0/array/bsearch.rb
backports-3.7.0 lib/backports/2.0.0/array/bsearch.rb
mdg-1.0.1 vendor/bundle/ruby/2.3.0/gems/backports-3.6.8/lib/backports/2.0.0/array/bsearch.rb
backports-3.6.8 lib/backports/2.0.0/array/bsearch.rb