Class: Hoodie::Stash::Cache

Inherits:
Object show all
Defined in:
lib/hoodie/stash.rb

Overview

Key/value cache store

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(params = {}) ⇒ Cache

Initializes a new empty store



56
57
58
59
# File 'lib/hoodie/stash.rb', line 56

def initialize(params = {})
  params = { store: params } unless params.is_a? Hash
  @store = params.fetch(:store) { Hoodie::DEFAULT_STORE.new }
end

Instance Attribute Details

#:store(: store) ⇒ Stash::DiskStore (readonly)

Returns location of Stash::DiskStore store.

Returns:

  • (Stash::DiskStore)

    location of Stash::DiskStore store.



52
# File 'lib/hoodie/stash.rb', line 52

attr_reader :store

#storeObject (readonly)

Returns the value of attribute store.



52
53
54
# File 'lib/hoodie/stash.rb', line 52

def store
  @store
end

Instance Method Details

#[](key = nil) ⇒ Hash, ...

Retrieves the value for a given key, if nothing is set, returns KeyError

Parameters:

  • key (Symbol, String) (defaults to: nil)

    representing the key

Returns:

Raises:

  • (KeyError)

    if no such key found



82
83
84
85
86
# File 'lib/hoodie/stash.rb', line 82

def [](key = nil)
  key ||= Stash.caller_name
  fail KeyError, 'Key not cached' unless include? key.to_sym
  @store[key.to_sym]
end

#cache(key = nil, &code) ⇒ Hash, ...

Retrieves the value for a given key, if nothing is set, run the code, cache the result, and return it

Parameters:

  • key (Symbol, String) (defaults to: nil)

    representing the key

  • block (&block)

    that returns the value to set (optional)

Returns:



96
97
98
99
# File 'lib/hoodie/stash.rb', line 96

def cache(key = nil, &code)
  key ||= Stash.caller_name
  @store[key.to_sym] ||= code.call
end

#clear!(key = nil) ⇒ Object

Clear the whole stash store or the value of a key

clear.

Parameters:

  • key (Symbol, String) (defaults to: nil)

    (optional) representing the key to

Returns:

  • nothing.



68
69
70
71
# File 'lib/hoodie/stash.rb', line 68

def clear!(key = nil)
  key = key.to_sym unless key.nil?
  @store.clear! key
end

#include?(key = nil) ⇒ Boolean

return a boolean indicating presence of the given key in the store

Parameters:

  • key (Symbol, String) (defaults to: nil)

    a string or symbol representing the key

Returns:

  • (Boolean)


115
116
117
118
# File 'lib/hoodie/stash.rb', line 115

def include?(key = nil)
  key ||= Stash.caller_name
  @store.include? key.to_sym
end

#sizeFixnum

return the size of the store as an integer

Returns:

  • (Fixnum)


105
106
107
# File 'lib/hoodie/stash.rb', line 105

def size
  @store.size
end