Sha256: 0aa3295baeb635e446e0b918c2e79b681f2b3dcba89894c13c56a46a1ee49215

Contents?: true

Size: 1.05 KB

Versions: 2

Compression:

Stored size: 1.05 KB

Contents

module Asynchronic
  module DataStore
    class InMemory

      include Helper

      def self.connect(object_id)
        connections[object_id]
      end

      def self.connections
        @connections ||= {}
      end

      def initialize
        @hash = {}
        @mutex = Mutex.new
        @keys_mutex = Hash.new { |h,k| h[k] = Mutex.new }
        self.class.connections[object_id] = self
      end

      def [](key)
        Marshal.load(hash[key.to_s]) if hash.key? key.to_s
      end

      def []=(key, value)
        mutex.synchronize { hash[key.to_s] = Marshal.dump(value) }
      end

      def delete(key)
        hash.delete key.to_s
      end

      def delete_cascade(key)
        keys.select { |k| k.sections.first == key }
            .each { |k| delete k }
      end

      def keys
        hash.keys.map { |k| Key[k] }
      end

      def synchronize(key, &block)
        keys_mutex[key].synchronize(&block)
      end

      def connection_args
        [object_id]
      end

      private

      attr_reader :hash, :mutex, :keys_mutex

    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
asynchronic-4.0.1 lib/asynchronic/data_store/in_memory.rb
asynchronic-4.0.0 lib/asynchronic/data_store/in_memory.rb