Sha256: e29d7d985f63aae1490266379c60745b0ef006db75ef77a0682f43fbeae92c85

Contents?: true

Size: 1.39 KB

Versions: 22

Compression:

Stored size: 1.39 KB

Contents

# frozen_string_literal: true

# Copyright 2014-2020 Aerospike, Inc.
#
# Portions may be licensed to Aerospike, Inc. under one or more contributor
# license agreements.
#
# 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 Aerospike

  private

  class Partition # :nodoc:
    UNPACK_FORMAT = 'l<'

    attr_reader :namespace, :partition_id

    def initialize(namespace, partition_id)
      @namespace = namespace
      @partition_id = partition_id

      self
    end

    def self.new_by_key(key)
      Partition.new(
        key.namespace,
        (key.digest[0..3].unpack(UNPACK_FORMAT)[0] & 0xFFFF) % Node::PARTITIONS
      )
    end

    def to_s
      "#{@namespace}:#{partition_id}"
    end

    def ==(other)
      other && other.is_a?(Partition) && @partition_id == other.partition_id &&
        @namespace == other.namespace
    end
    alias eql? ==

    def hash
      to_s.hash
    end

  end # class

end # module

Version data entries

22 entries across 22 versions & 1 rubygems

Version Path
aerospike-4.1.0 lib/aerospike/cluster/partition.rb
aerospike-4.0.0 lib/aerospike/cluster/partition.rb
aerospike-3.0.0 lib/aerospike/cluster/partition.rb
aerospike-2.29.0 lib/aerospike/cluster/partition.rb
aerospike-2.28.0 lib/aerospike/cluster/partition.rb
aerospike-2.27.0 lib/aerospike/cluster/partition.rb
aerospike-2.26.0 lib/aerospike/cluster/partition.rb
aerospike-2.25.0 lib/aerospike/cluster/partition.rb
aerospike-2.24.0 lib/aerospike/cluster/partition.rb
aerospike-2.23.0 lib/aerospike/cluster/partition.rb
aerospike-2.22.0 lib/aerospike/cluster/partition.rb
aerospike-2.21.1 lib/aerospike/cluster/partition.rb
aerospike-2.21.0 lib/aerospike/cluster/partition.rb
aerospike-2.20.1 lib/aerospike/cluster/partition.rb
aerospike-2.20.0 lib/aerospike/cluster/partition.rb
aerospike-2.19.0 lib/aerospike/cluster/partition.rb
aerospike-2.18.0 lib/aerospike/cluster/partition.rb
aerospike-2.17.0 lib/aerospike/cluster/partition.rb
aerospike-2.16.0 lib/aerospike/cluster/partition.rb
aerospike-2.15.0 lib/aerospike/cluster/partition.rb