Sha256: 69779aac5da0d4737202bf344b1655bcf676cbd1ed10fd481fbfb422ef40d9fe

Contents?: true

Size: 607 Bytes

Versions: 38

Compression:

Stored size: 607 Bytes

Contents

unless Integer.method_defined?(:bit_length) || Bignum.method_defined?(:bit_length)
  require 'backports/2.0.0/range/bsearch'
  class Bignum
    def bit_length
      # We use the fact that bignums use the minimum number of "words" necessary
      # where "words" is some number of bytes <= to the size of a fixnum
      # So we have (size - word_size) * 8 < bit_length <= size * 8
      n = 8 * (size - 42.size)
      smaller = self >> n
      if smaller >= 0
        smaller += 1
      else
        smaller = -smaller
      end
      n + (1..8 * 42.size).bsearch{|i| smaller <= (1 << i) }
    end
  end
end

Version data entries

38 entries across 38 versions & 3 rubygems

Version Path
backports-3.25.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.24.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.24.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.23.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.22.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.22.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.21.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.20.2 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.20.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.20.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.19.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.18.2 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.18.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.18.0 lib/backports/2.1.0/bignum/bit_length.rb
files.com-1.0.55 docs/vendor/bundle/ruby/2.5.0/gems/backports-3.12.0/lib/backports/2.1.0/bignum/bit_length.rb
backports-3.17.2 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.17.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.17.0 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.16.1 lib/backports/2.1.0/bignum/bit_length.rb
backports-3.16.0 lib/backports/2.1.0/bignum/bit_length.rb