Class: Utopia::Session::LazyHash

Inherits:
Object
  • Object
show all
Defined in:
lib/utopia/session/lazy_hash.rb

Overview

A simple hash table which fetches it’s values only when required.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(&block) ⇒ LazyHash

Returns a new instance of LazyHash.



10
11
12
13
14
15
# File 'lib/utopia/session/lazy_hash.rb', line 10

def initialize(&block)
	@changed = false
	@values = nil
	
	@loader = block
end

Instance Attribute Details

#valuesObject (readonly)

Returns the value of attribute values.



17
18
19
# File 'lib/utopia/session/lazy_hash.rb', line 17

def values
  @values
end

Instance Method Details

#[](key) ⇒ Object



19
20
21
# File 'lib/utopia/session/lazy_hash.rb', line 19

def [] key
	load![key]
end

#[]=(key, value) ⇒ Object



23
24
25
26
27
28
29
30
31
32
# File 'lib/utopia/session/lazy_hash.rb', line 23

def []= key, value
	values = load!
	
	if values[key] != value
		values[key] = value
		@changed = true
	end
	
	return value
end

#changed?Boolean

Returns:

  • (Boolean)


46
47
48
# File 'lib/utopia/session/lazy_hash.rb', line 46

def changed?
	@changed
end

#delete(key) ⇒ Object



38
39
40
41
42
43
44
# File 'lib/utopia/session/lazy_hash.rb', line 38

def delete(key)
	load!
	
	@changed = true if @values.include? key
	
	@values.delete(key)
end

#include?(key) ⇒ Boolean

Returns:

  • (Boolean)


34
35
36
# File 'lib/utopia/session/lazy_hash.rb', line 34

def include?(key)
	load!.include?(key)
end

#load!Object



50
51
52
# File 'lib/utopia/session/lazy_hash.rb', line 50

def load!
	@values ||= @loader.call
end

#loaded?Boolean

Returns:

  • (Boolean)


54
55
56
# File 'lib/utopia/session/lazy_hash.rb', line 54

def loaded?
	!@values.nil?
end

#needs_update?(timeout = nil) ⇒ Boolean

Returns:

  • (Boolean)


58
59
60
61
62
63
64
65
66
67
68
69
# File 'lib/utopia/session/lazy_hash.rb', line 58

def needs_update?(timeout = nil)
	# If data has changed, we need update:
	return true if @changed
	
	# We want to be careful here and not call load! which isn't cheap operation.
	if timeout and @values and updated_at = @values[:updated_at]
		# If the last update was too long ago, we need update:
		return true if updated_at < (Time.now - timeout)
	end
	
	return false
end