Class: ObjectSpace::WeakKeyMap

Inherits:
Object
  • Object
show all
Defined in:
lib/weak_key_map/impl.rb

Instance Method Summary collapse

Constructor Details

#initializeWeakKeyMap

Returns a new instance of WeakKeyMap.



7
8
9
10
# File 'lib/weak_key_map/impl.rb', line 7

def initialize
  @map = {}
  @refs = {}
end

Instance Method Details

#[](key) ⇒ Object



12
13
14
15
16
17
18
19
20
21
22
# File 'lib/weak_key_map/impl.rb', line 12

def [](key)
  hash = key.hash
  ref = @refs[hash]
  return nil unless ref
  return @map[hash] if ref.weakref_alive?

  @map.delete(hash)
  @refs.delete(hash)

  nil
end

#[]=(key, value) ⇒ Object



24
25
26
27
28
29
30
31
32
33
# File 'lib/weak_key_map/impl.rb', line 24

def []=(key, value)
  case key
  when true, false, nil, Integer, Float, Symbol
    raise ArgumentError, "WeakKeyMap keys must be garbage collectable"
  end

  hash = key.hash
  @refs[hash] = WeakRef.new(key)
  @map[hash] = value
end

#clearObject



39
40
41
42
43
# File 'lib/weak_key_map/impl.rb', line 39

def clear
  @map.clear
  @refs.clear
  self
end

#delete(key, &block) ⇒ Object



45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/weak_key_map/impl.rb', line 45

def delete(key, &block)
  hash = key.hash
  retval = nil

  if @refs.key?(hash)
    retval = @map[hash]
  end

  if block_given?
    retval = yield key
  end

  @refs.delete(hash)
  @map.delete(hash)

  retval
end

#getkey(key) ⇒ Object



63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'lib/weak_key_map/impl.rb', line 63

def getkey(key)
  hash = key.hash

  if @refs.key?(hash)
    ref = @refs[hash]

    begin
      return ref.__getobj__
    rescue WeakRef::RefError
      @refs.delete(hash)
      @map.delete(hash)
    end
  end

  nil
end

#inspectObject



35
36
37
# File 'lib/weak_key_map/impl.rb', line 35

def inspect
  "#<#{self.class}:0x#{(object_id << 1).to_s(16).rjust(14, '0')} size=#{@map.size}>"
end

#key?(key) ⇒ Boolean

Returns:

  • (Boolean)


80
81
82
83
84
85
86
87
88
89
90
91
92
# File 'lib/weak_key_map/impl.rb', line 80

def key?(key)
  hash = key.hash

  if @refs.key?(hash)
    ref = @refs[hash]
    return true if ref.weakref_alive?

    @refs.delete(hash)
    @map.delete(hash)
  end

  false
end

#sizeObject Also known as: length



94
95
96
# File 'lib/weak_key_map/impl.rb', line 94

def size
  @refs.size
end