Module: Cachetastic::Cacheable
- Defined in:
- lib/cachetastic/cacheable.rb
Overview
Include this module into an Object to achieve simplistic Object level caching.
Example:
class Person
include Cachetastic::Cacheable
attr_accessor :name
def cachetastic_key
self.name
end
def always_the_same(x, y)
cacher("always_the_same") do
x + y
end
end
end
Defined Under Namespace
Modules: ClassAndInstanceMethods, ClassOnlyMethods
Class Method Summary collapse
-
.included(klass) ⇒ Object
————————–.
Instance Method Summary collapse
-
#cache_self ⇒ Object
Unless the object’s cachetastic_key method returns nil this method will store the object in the cache using the object’s cachetastic_key as the key.
-
#uncache_self ⇒ Object
Unless the object’s cachetastic_key method returns nil this method will delete the object in the cache using the object’s cachetastic_key as the key.
Class Method Details
.included(klass) ⇒ Object
178 179 180 181 182 |
# File 'lib/cachetastic/cacheable.rb', line 178 def self.included(klass) # :nodoc: klass.send(:include, ClassAndInstanceMethods) klass.extend(ClassOnlyMethods) klass.extend(ClassAndInstanceMethods) end |
Instance Method Details
#cache_self ⇒ Object
Unless the object’s cachetastic_key method returns nil this method will store the object in the cache using the object’s cachetastic_key as the key. You MUST create an instance level method called cachetastic_key and have it return a valid key! If you return nil from the cachetastic_key method or you will not be able to use the cache_self and uncache_self methods.
Example:
class Person
include Cachetastic::Cacheable
attr_accessor :name
def cachetastic_key
self.name
end
end
Person.get_from_cache("Mark Bates") # => nil
p = Person.new
p.name = "Mark Bates"
p.cache_self
Person.get_from_cache("Mark Bates") # => "Mark Bates"
146 147 148 |
# File 'lib/cachetastic/cacheable.rb', line 146 def cache_self cache_class.set(self.cachetastic_key, self) unless self.cachetastic_key.nil? end |
#uncache_self ⇒ Object
Unless the object’s cachetastic_key method returns nil this method will delete the object in the cache using the object’s cachetastic_key as the key. You MUST create an instance level method called cachetastic_key and have it return a valid key! If you return nil from the cachetastic_key method or you will not be able to use the cache_self and uncache_self methods.
Example:
class Person
include Cachetastic::Cacheable
attr_accessor :name
def cachetastic_key
self.name
end
end
Person.get_from_cache("Mark Bates") # => nil
p = Person.new
p.name = "Mark Bates"
p.cache_self
Person.get_from_cache("Mark Bates") # => "Mark Bates"
p.uncache_self
Person.get_from_cache("Mark Bates") # => nil
172 173 174 |
# File 'lib/cachetastic/cacheable.rb', line 172 def uncache_self cache_class.delete(self.cachetastic_key) unless self.cachetastic_key.nil? end |