module Sequel::Plugins::StaticCache::ClassMethods

Attributes

cache[R]

A frozen ruby hash holding all of the model's frozen instances, keyed by frozen primary key.

Public Instance Methods

all() click to toggle source

An array of all of the model's frozen instances, without issuing a database query.

# File lib/sequel/plugins/static_cache.rb, line 56
def all
  if @static_cache_frozen
    @all.dup
  else
    map{|o| o}
  end
end
cache_get_pk(pk) click to toggle source

Return the frozen object with the given pk, or nil if no such object exists in the cache, without issuing a database query.

# File lib/sequel/plugins/static_cache.rb, line 75
def cache_get_pk(pk)
  static_cache_object(cache[pk])
end
count(*a, &block) click to toggle source

Get the number of records in the cache, without issuing a database query.

Calls superclass method
# File lib/sequel/plugins/static_cache.rb, line 65
def count(*a, &block)
  if a.empty? && !block
    @all.size
  else
    super
  end
end
each() { |static_cache_object(o)| ... } click to toggle source

Yield each of the model's frozen instances to the block, without issuing a database query.

# File lib/sequel/plugins/static_cache.rb, line 81
def each(&block)
  if @static_cache_frozen
    @all.each(&block)
  else
    @all.each{|o| yield(static_cache_object(o))}
  end
end
map(column=nil) { |static_cache_object(o)| ... } click to toggle source

Use the cache instead of a query to get the results.

# File lib/sequel/plugins/static_cache.rb, line 90
def map(column=nil, &block)
  if column
    raise(Error, "Cannot provide both column and block to map") if block
    if column.is_a?(Array)
      @all.map{|r| r.values.values_at(*column)}
    else
      @all.map{|r| r[column]}
    end
  elsif @static_cache_frozen
    @all.map(&block)
  elsif block
    @all.map{|o| yield(static_cache_object(o))}
  else
    all.map
  end
end
static_cache_allow_modifications?() click to toggle source

Ask whether modifications to this class are allowed.

# File lib/sequel/plugins/static_cache.rb, line 169
def static_cache_allow_modifications?
  !@static_cache_frozen
end
to_hash(key_column = nil, value_column = nil) click to toggle source

Use the cache instead of a query to get the results.

# File lib/sequel/plugins/static_cache.rb, line 111
def to_hash(key_column = nil, value_column = nil)
if key_column.nil? && value_column.nil?
  if @static_cache_frozen
    return cache.dup
  else
    key_column = primary_key
  end
end

h = {}
if value_column
  if value_column.is_a?(Array)
    if key_column.is_a?(Array)
      @all.each{|r| h[r.values.values_at(*key_column)] = r.values.values_at(*value_column)}
    else
      @all.each{|r| h[r[key_column]] = r.values.values_at(*value_column)}
    end
  else
    if key_column.is_a?(Array)
      @all.each{|r| h[r.values.values_at(*key_column)] = r[value_column]}
    else
      @all.each{|r| h[r[key_column]] = r[value_column]}
    end
  end
elsif key_column.is_a?(Array)
  @all.each{|r| h[r.values.values_at(*key_column)] = static_cache_object(r)}
else
  @all.each{|r| h[r[key_column]] = static_cache_object(r)}
end
h
end
to_hash_groups(key_column, value_column = nil) click to toggle source

Use the cache instead of a query to get the results

# File lib/sequel/plugins/static_cache.rb, line 144
def to_hash_groups(key_column, value_column = nil)
  h = {}
  if value_column
    if value_column.is_a?(Array)
      if key_column.is_a?(Array)
        @all.each{|r| (h[r.values.values_at(*key_column)] ||= []) << r.values.values_at(*value_column)}
      else
        @all.each{|r| (h[r[key_column]] ||= []) << r.values.values_at(*value_column)}
      end
    else
      if key_column.is_a?(Array)
        @all.each{|r| (h[r.values.values_at(*key_column)] ||= []) << r[value_column]}
      else
        @all.each{|r| (h[r[key_column]] ||= []) << r[value_column]}
      end
    end
  elsif key_column.is_a?(Array)
    @all.each{|r| (h[r.values.values_at(*key_column)] ||= []) << static_cache_object(r)}
  else
    @all.each{|r| (h[r[key_column]] ||= []) << static_cache_object(r)}
  end
  h
end

Private Instance Methods

load_cache() click to toggle source

Reload the cache for this model by retrieving all of the instances in the dataset freezing them, and populating the cached array and hash.

# File lib/sequel/plugins/static_cache.rb, line 183
def load_cache
  a = dataset.all
  h = {}
  a.each do |o|
    o.errors.freeze
    h[o.pk.freeze] = o.freeze
  end
  @all = a.freeze
  @cache = h.freeze
end
primary_key_lookup(pk) click to toggle source

Return the frozen object with the given pk, or nil if no such object exists in the cache, without issuing a database query.

# File lib/sequel/plugins/static_cache.rb, line 177
def primary_key_lookup(pk)
  static_cache_object(cache[pk])
end
static_cache_object(o) click to toggle source

If :frozen=>false is not used, just return the argument. Otherwise, create a new instance with the arguments values if the argument is not nil.

# File lib/sequel/plugins/static_cache.rb, line 197
def static_cache_object(o)
  if @static_cache_frozen
    o
  elsif o
    call(o.values.dup)
  end
end