Sha256: f8772ea6c3ec1254d95e8297d9fec3c73345989f71553a54a8a69f2e110be984

Contents?: true

Size: 760 Bytes

Versions: 70

Compression:

Stored size: 760 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
        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
          fail 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

70 entries across 70 versions & 5 rubygems

Version Path
dirwatch-0.0.9 vendor/bundle/ruby/2.5.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.8 vendor/bundle/ruby/2.5.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.6 vendor/bundle/ruby/2.3.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.5 vendor/bundle/ruby/2.3.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.4 vendor/bundle/ruby/2.3.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.3 vendor/bundle/ruby/2.3.0/gems/parser-2.4.0.2/lib/parser/compatibility/ruby1_9.rb
dirwatch-0.0.2 vendor/bundle/ruby/2.3.0/gems/parser-2.4.0.0/lib/parser/compatibility/ruby1_9.rb
parser-2.4.0.2 lib/parser/compatibility/ruby1_9.rb
parser-2.4.0.1 lib/parser/compatibility/ruby1_9.rb
fluent-plugin-detect-memb-exceptions-0.0.2 vendor/bundle/ruby/2.0.0/gems/parser-2.4.0.0/lib/parser/compatibility/ruby1_9.rb
fluent-plugin-detect-memb-exceptions-0.0.1 vendor/bundle/ruby/2.0.0/gems/parser-2.4.0.0/lib/parser/compatibility/ruby1_9.rb
parser-2.4.0.0 lib/parser/compatibility/ruby1_9.rb
parser-2.3.3.1 lib/parser/compatibility/ruby1_9.rb
parser-2.3.3.0 lib/parser/compatibility/ruby1_9.rb
parser-2.3.2.0 lib/parser/compatibility/ruby1_9.rb
parser-2.3.1.4 lib/parser/compatibility/ruby1_9.rb
parser-2.3.1.3 lib/parser/compatibility/ruby1_9.rb
erruby_parser-2.3.1.2 lib/parser/compatibility/ruby1_9.rb
parser-2.3.1.2 lib/parser/compatibility/ruby1_9.rb
parser-2.3.1.1 lib/parser/compatibility/ruby1_9.rb