Sha256: 74724687d445c7a3d629b318e42a1d9a10ebaaa9c471b84ca94438dc9701ad39

Contents?: true

Size: 1.45 KB

Versions: 2

Compression:

Stored size: 1.45 KB

Contents

require 'fileutils'

require 'glue/attribute'
require 'nitro/caching/stores'

module Nitro

# Adds support for caching.

module Caching

  # Action caching. Caches a fragment, ie a page part.
  # Use output cachingfor full page caching.

  module Fragments

    @@store = FileStore.new # MemoryStore.new

    def self.store 
      @@store 
    end
    
    def self.store=(store) 
      @@store = store
    end
    
    def self.get(name, options = {})
      return @@store.read(name, options)
    end
    
    def self.put(name, content = nil, options = {})
      @@store.write(name, content, options)
      return content
    end
    
    def self.append_features(base) # :nodoc: 
      super
    end

    private

    def cache(name = nil, options = {}, &block)
      name = @action_name unless name  
      cache_fragment(block, "#{name}#{options}", options)
    end

    def cache_fragment(block, name, options = {})
      unless caching_enabled?
        block.call
        return
      end

      if fragment = Fragments.get(name, options)
        @out << fragment
      else
        pos = @out.length        
        block.call
        Fragments.put(name, @out[pos..-1], options)
      end
    end

    #--
    # gmosx: If you modify the code here, don't forget to modify
    # the same method on the sweeper.
    #++
    
    def expire_fragment(name, options = {})
      Fragments.store.delete(name, options)
    end
  end
  
end

end

# * George Moschovitis  <gm@navel.gr>

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
nitro-0.26.0 lib/nitro/caching/fragments.rb
nitro-0.27.0 lib/nitro/caching/fragments.rb