Class: ActionController::Caching::Fragments::UnthreadedFileStore

Inherits:
Object
  • Object
show all
Defined in:
lib/action_controller/caching.rb

Overview

:nodoc:

Direct Known Subclasses

FileStore

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(cache_path) ⇒ UnthreadedFileStore

Returns a new instance of UnthreadedFileStore.



407
408
409
# File 'lib/action_controller/caching.rb', line 407

def initialize(cache_path)
  @cache_path = cache_path
end

Instance Attribute Details

#cache_pathObject (readonly)

Returns the value of attribute cache_path.



405
406
407
# File 'lib/action_controller/caching.rb', line 405

def cache_path
  @cache_path
end

Instance Method Details

#delete(name, options) ⇒ Object

:nodoc:



422
423
424
425
426
# File 'lib/action_controller/caching.rb', line 422

def delete(name, options) #:nodoc:
  File.delete(real_file_path(name))
rescue SystemCallError => e
  # If there's no cache, then there's nothing to complain about
end

#delete_matched(matcher, options) ⇒ Object

:nodoc:



428
429
430
431
432
433
434
435
436
437
438
# File 'lib/action_controller/caching.rb', line 428

def delete_matched(matcher, options) #:nodoc:
  search_dir(@cache_path) do |f|
    if f =~ matcher
      begin
        File.delete(f)
      rescue Object => e
        # If there's no cache, then there's nothing to complain about
      end
    end
  end
end

#read(name, options = nil) ⇒ Object

:nodoc:



418
419
420
# File 'lib/action_controller/caching.rb', line 418

def read(name, options = nil) #:nodoc:
  File.open(real_file_path(name), 'rb') { |f| f.read } rescue nil
end

#write(name, value, options = nil) ⇒ Object

:nodoc:



411
412
413
414
415
416
# File 'lib/action_controller/caching.rb', line 411

def write(name, value, options = nil) #:nodoc:
  ensure_cache_path(File.dirname(real_file_path(name)))
  File.open(real_file_path(name), "wb+") { |f| f.write(value) }
rescue => e
  Base.logger.error "Couldn't create cache directory: #{name} (#{e.message})" if Base.logger
end