class BSON::Int64
Represents a $maxKey type, which compares less than any other value in the specification.
@see bsonspec.org/#/specification
@since 2.0.0
Constants
- BSON_TYPE
A boolean is type 0x08 in the
BSON
spec.@since 2.0.0
- PACK
Constant for the int 64 pack directive.
@since 2.0.0
Public Class Methods
Deserialize an Integer
from BSON
.
@param [ ByteBuffer
] buffer The byte buffer.
@return [ Integer
] The decoded Integer
.
@see bsonspec.org/#/specification
@since 2.0.0
# File lib/bson/int64.rb, line 44 def self.from_bson(buffer) buffer.get_int64 end
@param [ Integer
] integer The 64-bit integer.
@see bsonspec.org/#/specification
@since 4.2.0
# File lib/bson/int64.rb, line 55 def initialize(integer) out_of_range! unless integer.bson_int64? @integer = integer.freeze end
Public Instance Methods
Append the integer as encoded BSON
to a ByteBuffer
.
@example Encoded the integer and append to a ByteBuffer
.
int64.to_bson
@return [ BSON::ByteBuffer
] The buffer with the encoded integer.
@see bsonspec.org/#/specification
@since 4.2.0
# File lib/bson/int64.rb, line 70 def to_bson(buffer = ByteBuffer.new, validating_keys = Config.validating_keys?) buffer.put_int64(@integer) end
Convert the integer to a BSON
string key.
@example Convert the integer to a BSON
key string.
int.to_bson_key
@param [ true, false ] validating_keys If BSON
should validate the key.
@return [ String
] The string key.
@since 4.2.0
# File lib/bson/int64.rb, line 84 def to_bson_key(validating_keys = Config.validating_keys?) @integer.to_bson_key(validating_keys) end
Private Instance Methods
# File lib/bson/int64.rb, line 90 def out_of_range! raise RangeError.new("#{self} is not a valid 8 byte integer value.") end