cachetastic 1.2.3 → 1.2.7.1
Sign up to get free protection for your applications and to get access to all the features.
- data/README +3 -7
- data/bin/cachetastic_drb_server +18 -3
- data/lib/adapters/cachetastic_adapters_base.rb +2 -1
- data/lib/adapters/cachetastic_adapters_drb.rb +4 -18
- data/lib/adapters/cachetastic_adapters_file.rb +0 -3
- data/lib/adapters/cachetastic_adapters_html_file.rb +119 -0
- data/lib/caches/cachetastic_caches_base.rb +24 -18
- data/lib/caches/cachetastic_caches_mack_session_cache.rb +3 -0
- data/lib/cachetastic.rb +2 -0
- data/lib/cachetastic_logger.rb +1 -1
- data/lib/tasks/rubyforge_config.yml +1 -1
- metadata +13 -111
- data/doc/classes/ActiveRecord/Base.html +0 -227
- data/doc/classes/ActiveRecord/Base.src/M000001.html +0 -25
- data/doc/classes/ActiveRecord/Base.src/M000002.html +0 -18
- data/doc/classes/ActiveRecord/Base.src/M000003.html +0 -18
- data/doc/classes/ActiveRecord/Base.src/M000004.html +0 -18
- data/doc/classes/ActiveRecord/Base.src/M000005.html +0 -18
- data/doc/classes/CGI/Session/CachetasticStore.html +0 -122
- data/doc/classes/Cachetastic/Adapters/Base.html +0 -260
- data/doc/classes/Cachetastic/Adapters/Base.src/M000024.html +0 -24
- data/doc/classes/Cachetastic/Adapters/Base.src/M000025.html +0 -20
- data/doc/classes/Cachetastic/Adapters/Base.src/M000026.html +0 -21
- data/doc/classes/Cachetastic/Adapters/Drb.html +0 -244
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000027.html +0 -22
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000028.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000029.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000030.html +0 -26
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000031.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Drb.src/M000032.html +0 -25
- data/doc/classes/Cachetastic/Adapters/File.html +0 -265
- data/doc/classes/Cachetastic/Adapters/File.src/M000033.html +0 -18
- data/doc/classes/Cachetastic/Adapters/File.src/M000034.html +0 -20
- data/doc/classes/Cachetastic/Adapters/File.src/M000035.html +0 -19
- data/doc/classes/Cachetastic/Adapters/File.src/M000036.html +0 -35
- data/doc/classes/Cachetastic/Adapters/File.src/M000037.html +0 -21
- data/doc/classes/Cachetastic/Adapters/File.src/M000038.html +0 -25
- data/doc/classes/Cachetastic/Adapters/LocalMemory.html +0 -238
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000018.html +0 -18
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000019.html +0 -18
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000020.html +0 -18
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000021.html +0 -26
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000022.html +0 -18
- data/doc/classes/Cachetastic/Adapters/LocalMemory.src/M000023.html +0 -25
- data/doc/classes/Cachetastic/Adapters/Memcache.html +0 -335
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000007.html +0 -19
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000008.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000009.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000010.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000011.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000012.html +0 -18
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000013.html +0 -24
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000014.html +0 -19
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000015.html +0 -20
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000016.html +0 -20
- data/doc/classes/Cachetastic/Adapters/Memcache.src/M000017.html +0 -24
- data/doc/classes/Cachetastic/Caches/Base.html +0 -441
- data/doc/classes/Cachetastic/Caches/Base.src/M000040.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000041.html +0 -43
- data/doc/classes/Cachetastic/Caches/Base.src/M000042.html +0 -23
- data/doc/classes/Cachetastic/Caches/Base.src/M000043.html +0 -20
- data/doc/classes/Cachetastic/Caches/Base.src/M000044.html +0 -19
- data/doc/classes/Cachetastic/Caches/Base.src/M000045.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000046.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000047.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000048.html +0 -23
- data/doc/classes/Cachetastic/Caches/Base.src/M000049.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000050.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000051.html +0 -18
- data/doc/classes/Cachetastic/Caches/Base.src/M000052.html +0 -28
- data/doc/classes/Cachetastic/Caches/Base/RegisteredCaches.html +0 -168
- data/doc/classes/Cachetastic/Caches/Base/RegisteredCaches.src/M000053.html +0 -18
- data/doc/classes/Cachetastic/Caches/PageCache.html +0 -121
- data/doc/classes/Cachetastic/Caches/RailsSessionCache.html +0 -145
- data/doc/classes/Cachetastic/Caches/RailsSessionCache.src/M000039.html +0 -18
- data/doc/classes/Cachetastic/Connection.html +0 -186
- data/doc/classes/Cachetastic/Connection.src/M000054.html +0 -18
- data/doc/classes/Cachetastic/Connection.src/M000055.html +0 -24
- data/doc/classes/Cachetastic/Errors/UnsupportedAdapter.html +0 -137
- data/doc/classes/Cachetastic/Errors/UnsupportedAdapter.src/M000006.html +0 -18
- data/doc/classes/Cachetastic/Logger.html +0 -174
- data/doc/classes/Cachetastic/Logger.src/M000056.html +0 -22
- data/doc/created.rid +0 -1
- data/doc/files/init_rb.html +0 -227
- data/doc/files/lib/adapters/cachetastic_adapters_base_rb.html +0 -139
- data/doc/files/lib/adapters/cachetastic_adapters_drb_rb.html +0 -115
- data/doc/files/lib/adapters/cachetastic_adapters_file_rb.html +0 -121
- data/doc/files/lib/adapters/cachetastic_adapters_local_memory_rb.html +0 -109
- data/doc/files/lib/adapters/cachetastic_adapters_memcache_rb.html +0 -127
- data/doc/files/lib/adapters/cachetastic_adapters_store_object_rb.html +0 -101
- data/doc/files/lib/caches/cachetastic_caches_base_rb.html +0 -108
- data/doc/files/lib/caches/cachetastic_caches_page_cache_rb.html +0 -109
- data/doc/files/lib/caches/cachetastic_caches_rails_session_cache_rb.html +0 -107
- data/doc/files/lib/cachetastic_connection_rb.html +0 -107
- data/doc/files/lib/cachetastic_logger_rb.html +0 -107
- data/doc/files/lib/cachetastic_rb.html +0 -255
- data/doc/files/lib/errors/cachetastic_errors_unsupported_adapter_rb.html +0 -101
- data/doc/files/lib/helpers/cachetastic_helpers_active_record_rb.html +0 -101
- data/doc/files/lib/rails_extensions/cachetastic_active_record_base_rb.html +0 -101
- data/doc/files/lib/rails_extensions/cgi_session_cachetastic_store_rb.html +0 -109
- data/doc/fr_class_index.html +0 -40
- data/doc/fr_file_index.html +0 -43
- data/doc/fr_method_index.html +0 -82
- data/doc/index.html +0 -24
- data/doc/rdoc-style.css +0 -208
data/README
CHANGED
@@ -11,10 +11,9 @@
|
|
11
11
|
debug: true # true | false (default: false)
|
12
12
|
# this is the type of file store to be used for this cache.
|
13
13
|
# more adapters can be developed and plugged in as desired
|
14
|
-
adapter: local_memory # local_memory | memcache | file | drb (default: local_memory)
|
14
|
+
adapter: local_memory # local_memory | memcache | file | drb | html_file (default: local_memory)
|
15
15
|
# this will marshall objects into and out of the store.
|
16
|
-
#
|
17
|
-
marshall_method: none # none | yaml (default: none)
|
16
|
+
marshall_method: none # none | yaml | ruby (default: none)
|
18
17
|
# this sets how long objects will live in the cache before they are auto expired.
|
19
18
|
default_expiry: <%= 24.hours %> # time in seconds (default: 24 hours)
|
20
19
|
# when setting objects into the cache the expiry_swing is +/- to the expiry time.
|
@@ -53,9 +52,6 @@
|
|
53
52
|
# set the servers to be used for memcache
|
54
53
|
servers:
|
55
54
|
- 127.0.0.1:11211 # ip:port used for memcache
|
56
|
-
|
57
|
-
# if using the mongrel_page_cache_handler gem, you can configure it to use cachetastic.
|
58
|
-
page_cache_storage: cachetastic # disk | cachetastic (default: cachetastic)
|
59
55
|
|
60
56
|
# example of how to override options for page cacheing:
|
61
57
|
cachetastic_caches_page_cache_options:
|
@@ -71,7 +67,7 @@ If you want to use Drb and the Cachetastic::Adapters::Drb adapter, you'll have t
|
|
71
67
|
|
72
68
|
$ cachetastic_drb_server # that will start the drb server on the host 127.0.0.1 on the port 61676
|
73
69
|
|
74
|
-
The server takes to command line parameters: -h <host> -p <port>
|
70
|
+
The server takes to command line parameters: -h <host> -p <port> -v <verbose> -rv <really verbose>
|
75
71
|
|
76
72
|
=Examples:
|
77
73
|
|
data/bin/cachetastic_drb_server
CHANGED
@@ -20,6 +20,8 @@ SERVER_OPTIONS = OpenStruct.new
|
|
20
20
|
SERVER_OPTIONS.host = "127.0.0.1"
|
21
21
|
SERVER_OPTIONS.port = "61676"
|
22
22
|
SERVER_OPTIONS.config_file = nil
|
23
|
+
SERVER_OPTIONS.verbose = false
|
24
|
+
SERVER_OPTIONS.really_verbose = false
|
23
25
|
|
24
26
|
opts = OptionParser.new do |opts|
|
25
27
|
|
@@ -35,6 +37,15 @@ opts = OptionParser.new do |opts|
|
|
35
37
|
SERVER_OPTIONS.config_file = v
|
36
38
|
end
|
37
39
|
|
40
|
+
opts.on("-v") do |v|
|
41
|
+
SERVER_OPTIONS.verbose = true
|
42
|
+
end
|
43
|
+
|
44
|
+
opts.on("-rv") do |v|
|
45
|
+
SERVER_OPTIONS.verbose = true
|
46
|
+
SERVER_OPTIONS.really_verbose = true
|
47
|
+
end
|
48
|
+
|
38
49
|
end
|
39
50
|
|
40
51
|
opts.parse!(ARGV)
|
@@ -55,22 +66,26 @@ module Cachetastic
|
|
55
66
|
end # initialize
|
56
67
|
|
57
68
|
def get(ns, key)
|
58
|
-
#
|
69
|
+
puts "get: #{ns}.#{key}" if SERVER_OPTIONS.verbose
|
70
|
+
puts cache_for_namespace(ns).inspect if SERVER_OPTIONS.really_verbose
|
59
71
|
cache_for_namespace(ns).get(key)
|
60
72
|
end
|
61
73
|
|
62
74
|
def set(ns, key, value, expiry = 0)
|
75
|
+
puts "set: #{ns}.#{key}" if SERVER_OPTIONS.verbose
|
63
76
|
cache_for_namespace(ns).set(key, value)
|
64
|
-
|
77
|
+
puts cache_for_namespace(ns).inspect if SERVER_OPTIONS.really_verbose
|
65
78
|
value
|
66
79
|
end
|
67
80
|
|
68
81
|
def delete(ns, key, delay = 0)
|
82
|
+
puts "delete: #{ns}.#{key}" if SERVER_OPTIONS.verbose
|
69
83
|
cache_for_namespace(ns).delete(key, delay = 0)
|
70
|
-
|
84
|
+
puts cache_for_namespace(ns).inspect if SERVER_OPTIONS.really_verbose
|
71
85
|
end
|
72
86
|
|
73
87
|
def expire_all(ns)
|
88
|
+
puts "expire_all: #{ns}" if SERVER_OPTIONS.verbose
|
74
89
|
instance_variable_set("@store_for_#{ns}", Cachetastic::Adapters::LocalMemory.new("store_for_#{ns}"))
|
75
90
|
end
|
76
91
|
|
@@ -30,7 +30,8 @@ class Cachetastic::Adapters::Base
|
|
30
30
|
self.logger.debug(self.name, :options, self.all_options.inspect)
|
31
31
|
end
|
32
32
|
end
|
33
|
-
|
33
|
+
|
34
|
+
# foo bar
|
34
35
|
[:setup, :set, :get, :delete, :expire_all, :stats, "valid?"].each do |meth|
|
35
36
|
define_method(meth) do |*args|
|
36
37
|
raise MethodNotImplemented.new(meth)
|
@@ -18,6 +18,7 @@ class Cachetastic::Adapters::Drb < Cachetastic::Adapters::Base
|
|
18
18
|
end
|
19
19
|
|
20
20
|
def setup
|
21
|
+
self.all_options["marshall_method"] = "ruby"
|
21
22
|
self.drb_store = DRbObject.new_with_uri(self.store_options["host"])
|
22
23
|
end
|
23
24
|
|
@@ -27,30 +28,15 @@ class Cachetastic::Adapters::Drb < Cachetastic::Adapters::Base
|
|
27
28
|
|
28
29
|
# See Cachetastic::Adapters::Base
|
29
30
|
def get(key)
|
30
|
-
|
31
|
-
if so
|
32
|
-
if so.invalid?
|
33
|
-
self.delete(key)
|
34
|
-
return nil
|
35
|
-
end
|
36
|
-
return so.value
|
37
|
-
end
|
38
|
-
return nil
|
31
|
+
Cachetastic::Caches::Base.unmarshall(self.drb_store.get(self.name, key))
|
39
32
|
end
|
40
33
|
|
41
34
|
def set(key, value, expiry = 0)
|
42
|
-
self.drb_store.set(self.name, key
|
35
|
+
self.drb_store.set(self.name, key, Cachetastic::Caches::Base.marshall(value), expiry)
|
43
36
|
end
|
44
37
|
|
45
38
|
def delete(key, delay = 0)
|
46
|
-
|
47
|
-
self.drb_store.delete(self.name, key.to_s)
|
48
|
-
else
|
49
|
-
so = self.get(key)
|
50
|
-
if so
|
51
|
-
self.set(so.key, so.value, delay)
|
52
|
-
end
|
53
|
-
end
|
39
|
+
self.drb_store.delete(self.name, key)
|
54
40
|
end
|
55
41
|
|
56
42
|
end
|
@@ -41,12 +41,9 @@ class Cachetastic::Adapters::File < Cachetastic::Adapters::Base
|
|
41
41
|
return nil
|
42
42
|
end
|
43
43
|
if so.value.is_a?(YAML::Object)
|
44
|
-
puts "require #{so.value.class.underscore}"
|
45
44
|
require so.value.class.underscore
|
46
45
|
so = YAML::load(File.open(full_path).read)
|
47
46
|
end
|
48
|
-
puts so.value.class
|
49
|
-
pp so.value
|
50
47
|
return so.value
|
51
48
|
end
|
52
49
|
return nil
|
@@ -0,0 +1,119 @@
|
|
1
|
+
# This adapter uses the file system as it's backing.
|
2
|
+
# Caches are stored in files called index.html.
|
3
|
+
# At the beginning of the html the following html comments are pre-pended:
|
4
|
+
# <!-- cachetastic: expires_at: Fri Feb 01 20:51:45 -0500 2008 -->
|
5
|
+
# <!-- cachetastic: key: /channels/1-arts-humanities -->
|
6
|
+
# Obviously the expires_at date will be the ACTUAL expire date,
|
7
|
+
# same goes for the key.
|
8
|
+
# The configuration for this should look something like this:
|
9
|
+
# my_awesome_cache_options:
|
10
|
+
# debug: false
|
11
|
+
# adapter: html_file
|
12
|
+
# marshall_method: none
|
13
|
+
# default_expiry: <%= 24.hours %>
|
14
|
+
# store_options:
|
15
|
+
# dir: /usr/local/caches/
|
16
|
+
# logging:
|
17
|
+
# logger_1:
|
18
|
+
# type: file
|
19
|
+
# file: log/file_store_cache.log
|
20
|
+
require 'time'
|
21
|
+
class Cachetastic::Adapters::HtmlFile < Cachetastic::Adapters::Base
|
22
|
+
|
23
|
+
attr_reader :directory
|
24
|
+
attr_reader :hashed_keys
|
25
|
+
|
26
|
+
def valid?
|
27
|
+
File.exists?(self.directory)
|
28
|
+
end
|
29
|
+
|
30
|
+
def setup
|
31
|
+
@directory = File.join(self.store_options["dir"], self.name.to_s)
|
32
|
+
FileUtils.mkdir_p(self.directory, :verbose => self.debug?)
|
33
|
+
@hashed_keys = {}
|
34
|
+
end
|
35
|
+
|
36
|
+
def expire_all
|
37
|
+
FileUtils.rm_rf(self.directory, :verbose => self.debug?)
|
38
|
+
setup
|
39
|
+
end
|
40
|
+
|
41
|
+
def get(key)
|
42
|
+
full_path = full_path_from_dir(get_key_directoy(key, false))
|
43
|
+
return nil unless File.exists?(full_path)
|
44
|
+
so = html_to_store_object(File.open(full_path).read)
|
45
|
+
if so
|
46
|
+
if so.invalid?
|
47
|
+
self.delete(key)
|
48
|
+
return nil
|
49
|
+
end
|
50
|
+
return so.value
|
51
|
+
end
|
52
|
+
return nil
|
53
|
+
end
|
54
|
+
|
55
|
+
def set(key, value, expiry = 0)
|
56
|
+
so = Cachetastic::Adapters::StoreObject.new(key.to_s, value, expiry)
|
57
|
+
File.open(full_path_from_key(key), "w") do |f|
|
58
|
+
f.puts store_object_to_html(so)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
def delete(key, delay = 0)
|
63
|
+
if delay <= 0
|
64
|
+
FileUtils.rm_rf(get_key_directoy(key), :verbose => self.debug?)
|
65
|
+
else
|
66
|
+
so = self.get(key)
|
67
|
+
if so
|
68
|
+
self.set(so.key, so.value, delay)
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
private
|
74
|
+
def get_key_directoy(key, mkdir = true)
|
75
|
+
hkey = self.hashed_keys[key.to_sym]
|
76
|
+
if hkey.nil?
|
77
|
+
hkey = key.to_s.hexdigest.hash
|
78
|
+
hkey = hkey * -1 if hkey < 0
|
79
|
+
hkey = hkey.to_s
|
80
|
+
i = 0
|
81
|
+
path = self.directory
|
82
|
+
until i == hkey.length do
|
83
|
+
path = File.join(path, hkey[i..i])
|
84
|
+
i += 1
|
85
|
+
end
|
86
|
+
self.hashed_keys[key.to_sym] = path
|
87
|
+
hkey = path
|
88
|
+
end
|
89
|
+
FileUtils.mkdir_p(hkey, :verbose => self.debug?) if mkdir
|
90
|
+
hkey
|
91
|
+
end
|
92
|
+
|
93
|
+
def full_path_from_key(key)
|
94
|
+
full_path_from_dir(get_key_directoy(key))
|
95
|
+
end
|
96
|
+
|
97
|
+
def full_path_from_dir(dir)
|
98
|
+
File.join(dir, STORE_FILE_NAME)
|
99
|
+
end
|
100
|
+
|
101
|
+
def html_to_store_object(html)
|
102
|
+
key = html.match(/<!-- cachetastic: key: (.*) -->/).captures.first
|
103
|
+
expires_at = html.match(/<!-- cachetastic: expires_at: (.*) -->/).captures.first
|
104
|
+
html.gsub!(/<!-- cachetastic: key: .* -->/, '')
|
105
|
+
html.gsub!(/<!-- cachetastic: expires_at: .* -->/, '')
|
106
|
+
so = Cachetastic::Adapters::StoreObject.new(key, html, 0)
|
107
|
+
so.expires_at = Time.parse(expires_at)
|
108
|
+
so
|
109
|
+
end
|
110
|
+
|
111
|
+
def store_object_to_html(so)
|
112
|
+
x = "<!-- cachetastic: expires_at: #{so.expires_at} -->\n"
|
113
|
+
x << "<!-- cachetastic: key: #{so.key} -->\n"
|
114
|
+
x << so.value
|
115
|
+
end
|
116
|
+
|
117
|
+
STORE_FILE_NAME = "index.html"
|
118
|
+
|
119
|
+
end
|
@@ -164,6 +164,30 @@ class Cachetastic::Caches::Base
|
|
164
164
|
return !unsupported_adapters.include?(a)
|
165
165
|
end
|
166
166
|
|
167
|
+
def marshall(value)
|
168
|
+
return value if value.nil?
|
169
|
+
return case adapter.all_options["marshall_method"]
|
170
|
+
when "yaml"
|
171
|
+
YAML.dump(value)
|
172
|
+
when "ruby"
|
173
|
+
Marshal.dump(value)
|
174
|
+
else
|
175
|
+
value
|
176
|
+
end
|
177
|
+
end
|
178
|
+
|
179
|
+
def unmarshall(value)
|
180
|
+
return value if value.nil?
|
181
|
+
return case adapter.all_options["marshall_method"]
|
182
|
+
when "yaml"
|
183
|
+
YAML.load(value)
|
184
|
+
when "ruby"
|
185
|
+
Marshal.load(value)
|
186
|
+
else
|
187
|
+
value
|
188
|
+
end
|
189
|
+
end
|
190
|
+
|
167
191
|
private
|
168
192
|
# If the expiry time is set to 60 minutes and the expiry_swing time is set to
|
169
193
|
# 15 minutes, this method will return a number between 45 minutes and 75 minutes.
|
@@ -187,24 +211,6 @@ class Cachetastic::Caches::Base
|
|
187
211
|
# puts "all_registered_caches: #{all_registered_caches.inspect}"
|
188
212
|
end
|
189
213
|
|
190
|
-
def marshall(value)
|
191
|
-
return case adapter.all_options["marshall_method"]
|
192
|
-
when "yaml"
|
193
|
-
YAML.dump(value)
|
194
|
-
else
|
195
|
-
value
|
196
|
-
end
|
197
|
-
end
|
198
|
-
|
199
|
-
def unmarshall(value)
|
200
|
-
return case adapter.all_options["marshall_method"]
|
201
|
-
when "yaml"
|
202
|
-
YAML.load(value)
|
203
|
-
else
|
204
|
-
value
|
205
|
-
end
|
206
|
-
end
|
207
|
-
|
208
214
|
def cache_conn_instance
|
209
215
|
Cachetastic::Connection.instance
|
210
216
|
end
|
data/lib/cachetastic.rb
CHANGED
@@ -29,12 +29,14 @@ require 'cachetastic_logger'
|
|
29
29
|
require 'caches/cachetastic_caches_base'
|
30
30
|
require 'caches/cachetastic_caches_page_cache'
|
31
31
|
require 'caches/cachetastic_caches_rails_session_cache'
|
32
|
+
require 'caches/cachetastic_caches_mack_session_cache'
|
32
33
|
require 'errors/cachetastic_errors_unsupported_adapter'
|
33
34
|
require 'adapters/cachetastic_adapters_base'
|
34
35
|
require 'adapters/cachetastic_adapters_store_object'
|
35
36
|
require 'adapters/cachetastic_adapters_memcache'
|
36
37
|
require 'adapters/cachetastic_adapters_local_memory'
|
37
38
|
require 'adapters/cachetastic_adapters_file'
|
39
|
+
require 'adapters/cachetastic_adapters_html_file'
|
38
40
|
require 'adapters/cachetastic_adapters_drb'
|
39
41
|
require 'helpers/cachetastic_helpers_active_record'
|
40
42
|
require 'rails_extensions/cachetastic_active_record_base'
|
data/lib/cachetastic_logger.rb
CHANGED
@@ -16,7 +16,7 @@ class Cachetastic::Logger
|
|
16
16
|
|
17
17
|
LOG_LEVELS.each do |level|
|
18
18
|
define_method(level) do |*args|
|
19
|
-
lm = "[CACHE] [#{level.to_s.upcase}]\t#{Time.now.strftime("%m/%d/%y %H:%
|
19
|
+
lm = "[CACHE] [#{level.to_s.upcase}]\t#{Time.now.strftime("%m/%d/%y %H:%M:%S")}"
|
20
20
|
exs = []
|
21
21
|
args.each do |arg|
|
22
22
|
if arg.is_a?(Exception)
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: cachetastic
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.2.
|
4
|
+
version: 1.2.7.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- markbates
|
@@ -10,7 +10,7 @@ autorequire:
|
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
12
|
|
13
|
-
date: 2008-
|
13
|
+
date: 2008-02-18 00:00:00 -05:00
|
14
14
|
default_executable:
|
15
15
|
dependencies: []
|
16
16
|
|
@@ -20,122 +20,19 @@ executables:
|
|
20
20
|
- cachetastic_drb_server
|
21
21
|
extensions: []
|
22
22
|
|
23
|
-
extra_rdoc_files:
|
24
|
-
|
23
|
+
extra_rdoc_files:
|
24
|
+
- README
|
25
25
|
files:
|
26
26
|
- README
|
27
|
-
- doc/classes/ActiveRecord/Base.html
|
28
|
-
- doc/classes/ActiveRecord/Base.src
|
29
|
-
- doc/classes/ActiveRecord/Base.src/M000001.html
|
30
|
-
- doc/classes/ActiveRecord/Base.src/M000002.html
|
31
|
-
- doc/classes/ActiveRecord/Base.src/M000003.html
|
32
|
-
- doc/classes/ActiveRecord/Base.src/M000004.html
|
33
|
-
- doc/classes/ActiveRecord/Base.src/M000005.html
|
34
|
-
- doc/classes/Cachetastic/Adapters/Base.html
|
35
|
-
- doc/classes/Cachetastic/Adapters/Base.src
|
36
|
-
- doc/classes/Cachetastic/Adapters/Base.src/M000024.html
|
37
|
-
- doc/classes/Cachetastic/Adapters/Base.src/M000025.html
|
38
|
-
- doc/classes/Cachetastic/Adapters/Base.src/M000026.html
|
39
|
-
- doc/classes/Cachetastic/Adapters/Drb.html
|
40
|
-
- doc/classes/Cachetastic/Adapters/Drb.src
|
41
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000027.html
|
42
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000028.html
|
43
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000029.html
|
44
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000030.html
|
45
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000031.html
|
46
|
-
- doc/classes/Cachetastic/Adapters/Drb.src/M000032.html
|
47
|
-
- doc/classes/Cachetastic/Adapters/File.html
|
48
|
-
- doc/classes/Cachetastic/Adapters/File.src
|
49
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000033.html
|
50
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000034.html
|
51
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000035.html
|
52
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000036.html
|
53
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000037.html
|
54
|
-
- doc/classes/Cachetastic/Adapters/File.src/M000038.html
|
55
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.html
|
56
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src
|
57
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000018.html
|
58
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000019.html
|
59
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000020.html
|
60
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000021.html
|
61
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000022.html
|
62
|
-
- doc/classes/Cachetastic/Adapters/LocalMemory.src/M000023.html
|
63
|
-
- doc/classes/Cachetastic/Adapters/Memcache.html
|
64
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src
|
65
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000007.html
|
66
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000008.html
|
67
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000009.html
|
68
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000010.html
|
69
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000011.html
|
70
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000012.html
|
71
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000013.html
|
72
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000014.html
|
73
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000015.html
|
74
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000016.html
|
75
|
-
- doc/classes/Cachetastic/Adapters/Memcache.src/M000017.html
|
76
|
-
- doc/classes/Cachetastic/Caches/Base/RegisteredCaches.html
|
77
|
-
- doc/classes/Cachetastic/Caches/Base/RegisteredCaches.src
|
78
|
-
- doc/classes/Cachetastic/Caches/Base/RegisteredCaches.src/M000053.html
|
79
|
-
- doc/classes/Cachetastic/Caches/Base.html
|
80
|
-
- doc/classes/Cachetastic/Caches/Base.src
|
81
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000040.html
|
82
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000041.html
|
83
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000042.html
|
84
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000043.html
|
85
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000044.html
|
86
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000045.html
|
87
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000046.html
|
88
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000047.html
|
89
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000048.html
|
90
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000049.html
|
91
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000050.html
|
92
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000051.html
|
93
|
-
- doc/classes/Cachetastic/Caches/Base.src/M000052.html
|
94
|
-
- doc/classes/Cachetastic/Caches/PageCache.html
|
95
|
-
- doc/classes/Cachetastic/Caches/RailsSessionCache.html
|
96
|
-
- doc/classes/Cachetastic/Caches/RailsSessionCache.src
|
97
|
-
- doc/classes/Cachetastic/Caches/RailsSessionCache.src/M000039.html
|
98
|
-
- doc/classes/Cachetastic/Connection.html
|
99
|
-
- doc/classes/Cachetastic/Connection.src
|
100
|
-
- doc/classes/Cachetastic/Connection.src/M000054.html
|
101
|
-
- doc/classes/Cachetastic/Connection.src/M000055.html
|
102
|
-
- doc/classes/Cachetastic/Errors/UnsupportedAdapter.html
|
103
|
-
- doc/classes/Cachetastic/Errors/UnsupportedAdapter.src
|
104
|
-
- doc/classes/Cachetastic/Errors/UnsupportedAdapter.src/M000006.html
|
105
|
-
- doc/classes/Cachetastic/Logger.html
|
106
|
-
- doc/classes/Cachetastic/Logger.src
|
107
|
-
- doc/classes/Cachetastic/Logger.src/M000056.html
|
108
|
-
- doc/classes/CGI/Session/CachetasticStore.html
|
109
|
-
- doc/created.rid
|
110
|
-
- doc/files/init_rb.html
|
111
|
-
- doc/files/lib/adapters/cachetastic_adapters_base_rb.html
|
112
|
-
- doc/files/lib/adapters/cachetastic_adapters_drb_rb.html
|
113
|
-
- doc/files/lib/adapters/cachetastic_adapters_file_rb.html
|
114
|
-
- doc/files/lib/adapters/cachetastic_adapters_local_memory_rb.html
|
115
|
-
- doc/files/lib/adapters/cachetastic_adapters_memcache_rb.html
|
116
|
-
- doc/files/lib/adapters/cachetastic_adapters_store_object_rb.html
|
117
|
-
- doc/files/lib/caches/cachetastic_caches_base_rb.html
|
118
|
-
- doc/files/lib/caches/cachetastic_caches_page_cache_rb.html
|
119
|
-
- doc/files/lib/caches/cachetastic_caches_rails_session_cache_rb.html
|
120
|
-
- doc/files/lib/cachetastic_connection_rb.html
|
121
|
-
- doc/files/lib/cachetastic_logger_rb.html
|
122
|
-
- doc/files/lib/cachetastic_rb.html
|
123
|
-
- doc/files/lib/errors/cachetastic_errors_unsupported_adapter_rb.html
|
124
|
-
- doc/files/lib/helpers/cachetastic_helpers_active_record_rb.html
|
125
|
-
- doc/files/lib/rails_extensions/cachetastic_active_record_base_rb.html
|
126
|
-
- doc/files/lib/rails_extensions/cgi_session_cachetastic_store_rb.html
|
127
|
-
- doc/fr_class_index.html
|
128
|
-
- doc/fr_file_index.html
|
129
|
-
- doc/fr_method_index.html
|
130
|
-
- doc/index.html
|
131
|
-
- doc/rdoc-style.css
|
132
27
|
- lib/adapters/cachetastic_adapters_base.rb
|
133
28
|
- lib/adapters/cachetastic_adapters_drb.rb
|
134
29
|
- lib/adapters/cachetastic_adapters_file.rb
|
30
|
+
- lib/adapters/cachetastic_adapters_html_file.rb
|
135
31
|
- lib/adapters/cachetastic_adapters_local_memory.rb
|
136
32
|
- lib/adapters/cachetastic_adapters_memcache.rb
|
137
33
|
- lib/adapters/cachetastic_adapters_store_object.rb
|
138
34
|
- lib/caches/cachetastic_caches_base.rb
|
35
|
+
- lib/caches/cachetastic_caches_mack_session_cache.rb
|
139
36
|
- lib/caches/cachetastic_caches_page_cache.rb
|
140
37
|
- lib/caches/cachetastic_caches_rails_session_cache.rb
|
141
38
|
- lib/cachetastic.rb
|
@@ -149,8 +46,13 @@ files:
|
|
149
46
|
has_rdoc: true
|
150
47
|
homepage:
|
151
48
|
post_install_message:
|
152
|
-
rdoc_options:
|
153
|
-
|
49
|
+
rdoc_options:
|
50
|
+
- --title
|
51
|
+
- Cachetastic-RDoc
|
52
|
+
- --main
|
53
|
+
- README
|
54
|
+
- --line-numbers
|
55
|
+
- --inline-source
|
154
56
|
require_paths:
|
155
57
|
- lib
|
156
58
|
- lib
|