# frozen_string_literal: true # rubocop:todo all # Copyright (C) 2009-2020 MongoDB Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. module BSON # Represents int64 type. # # @see http://bsonspec.org/#/specification # # @since 2.0.0 class Int64 include JSON # A boolean is type 0x08 in the BSON spec. # # @since 2.0.0 BSON_TYPE = ::String.new(18.chr, encoding: BINARY).freeze # Constant for the int 64 pack directive. # # @since 2.0.0 PACK = "q<" # Deserialize an Integer from BSON. # # @param [ ByteBuffer ] buffer The byte buffer. # # @option options [ nil | :bson ] :mode Decoding mode to use. # # @return [ Integer | BSON::Int64 ] The decoded Integer. # # @see http://bsonspec.org/#/specification # # @since 2.0.0 def self.from_bson(buffer, **options) value = buffer.get_int64 if options[:mode] == :bson new(value) else value end end # Instantiate a BSON Int64. # # @param [ Integer ] value The 64-bit integer. # # @see http://bsonspec.org/#/specification # # @since 4.2.0 def initialize(value) if value.is_a?(self.class) @value = value.value return end unless value.bson_int64? raise RangeError.new("#{value} cannot be stored in 64 bits") end @value = value.freeze end # Returns the value of this Int64. # # @return [ Integer ] The integer value. attr_reader :value # 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 http://bsonspec.org/#/specification # # @since 4.2.0 def to_bson(buffer = ByteBuffer.new) buffer.put_int64(value) end # Convert the integer to a BSON string key. # # @example Convert the integer to a BSON key string. # int.to_bson_key # # @return [ String ] The string key. # # @since 4.2.0 def to_bson_key value end # Check equality of the int64 with another object. # # @param [ Object ] other The object to check against. # # @return [ true, false ] If the objects are equal. # # @since 4.4.0 def ==(other) return false unless other.is_a?(Int64) value == other.value end alias :eql? :== alias :=== :== # Return a string representation of the Int64 for use in # application-level JSON serialization. This method is intentionally # different from #as_extended_json. # # @example Get the Int64 as a JSON-serializable object. # int64.as_json # # @return [ Integer ] The Int64 as an Integer. def as_json(**options) value end # Converts this object to a representation directly serializable to # Extended JSON (https://github.com/mongodb/specifications/blob/master/source/extended-json/extended-json.md). # # This method returns the integer value if relaxed representation is # requested, otherwise a $numberLong hash. # # @option opts [ nil | :relaxed | :legacy ] :mode Serialization mode # (default is canonical extended JSON) # # @return [ Hash | Integer ] The extended json representation. def as_extended_json(**options) if options[:mode] == :relaxed || options[:mode] == :legacy value else {'$numberLong' => value.to_s} end end # Register this type when the module is loaded. # # @since 2.0.0 Registry.register(BSON_TYPE, self) end end