Sha256: deee58fff6969fde7c15d19ce24f9c8003b2b2b6d0b5256ff99b651ff17aeb48

Contents?: true

Size: 1.45 KB

Versions: 3

Compression:

Stored size: 1.45 KB

Contents

module MassiveRecord
  module Wrapper
    class Cell
      SUPPORTED_TYPES = [NilClass, String, Fixnum, Bignum]

      attr_reader :value
      attr_accessor :created_at


      #
      # Packs an integer as a 64-bit signed integer, native endian (int64_t)
      # Reverse it as the byte order in hbase are reversed
      p #
      def self.integer_to_hex_string(int)
        [int].pack('q').reverse
      end

      #
      # Unpacks an string as a 64-bit signed integer, native endian (int64_t)
      # Reverse it before unpack as the byte order in hbase are reversed
      #
      def self.hex_string_to_integer(string)
        string.reverse.unpack("q*").first
      end


      def self.populate_from_tcell(tcell)
        new({
          :value => tcell.value,
          :created_at => Time.at(tcell.timestamp / 1000, (tcell.timestamp % 1000) * 1000)
        })
      end


      def initialize(opts = {})
        self.value = opts[:value]
        self.created_at = opts[:created_at]
      end
    
      def value=(v)
        raise "#{v} was a #{v.class}, but it must be a one of: #{SUPPORTED_TYPES.join(', ')}" unless SUPPORTED_TYPES.include? v.class

        @value = v.duplicable? ? v.dup : v
      end

      def value_to_thrift
        case value
        when String
          value.force_encoding(Encoding::BINARY)
        when Fixnum, Bignum
          self.class.integer_to_hex_string(value)
        when NilClass
          value
        end
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
massive_record-0.2.2 lib/massive_record/wrapper/cell.rb
massive_record-0.2.2.rc2 lib/massive_record/wrapper/cell.rb
massive_record-0.2.2.rc1 lib/massive_record/wrapper/cell.rb