erector_cache 0.0.4 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (5) hide show
  1. data/README +48 -0
  2. data/README.rdoc +161 -13
  3. data/VERSION +1 -1
  4. data/lib/erector_cache/widget.rb +1 -1
  5. metadata +4 -4
data/README CHANGED
@@ -0,0 +1,48 @@
1
+ erector_cache
2
+
3
+ ....:~~~~~~~~~~~~~:~~::::::,..
4
+ ......,~===~=====~~~~~::::::::::::::,..... ..
5
+ ....,~+++=++++++==~~~~:::::::::::::::,... ..
6
+ ..~I?+?????+?+++===~~~~::::::::::::::~:,... .
7
+ .=I7?I?????+?+++===~~~~~:::::::::::::~~:.... ..
8
+ .....~$$77II7III?+?++++===~~~~::::::::::::::~~=:......
9
+ ....:ZZ$$7IIIIII???++++++==~~~:::::::::~~~:~~~==,.....
10
+ ....7OZZ$77I777I????+++++==~~::::::::::~~::~~~===, ..
11
+ ...?OOOZ$$$7777II?????+++===~~:::::::::::::~~~~==~....
12
+ ..,7OOO$$$$$7777II??+++==~~~~~::::::::::::~::::~~=,...
13
+ . ?OOOOZZ$$$77777I??++=++=~~~~:::::::::::::::~~===:...
14
+ ..I8OOO$Z$ZZ77777I???+=+==~~::::::::::,:::::~=+++++...
15
+ ,78OOO$ZZZ$$7777II7ZOOOOZ$7?+~~::::,,,::~~~?I7ZOOZ?..... ..
16
+ ,7O8OO$$ZZZ$77$77ZOO8OOZ$II?+++=::,,,:::~===~+++I$Z:.... ..
17
+ :7O88O8Z$$$$$$$OOZ???+III777$?+=~~::::::~:=I7+=::~+:~~, ..
18
+ ,7OOO8OOZ77$I$OZIII~~~~=+???++I7I=:~=~=+I$=~I~=~:~+...=,:,
19
+ ..IOOO8OOZ777IZZ+=I++++?+=??I7II7$Z$??I$$$+?+=::~~=:.. ,=?:
20
+ ..?O88O88OZ$$$$7$Z+?+?77ZOO7III$7$ZI=:::Z7+78ZO8$I~=~++,~=..
21
+ ..+O88O8OOZ$777=$7=??$ODN$8?+$I?7787=~~:O$?ZN88$Z8?=~...+:..
22
+ ,:+7ZDDD8OZZ$$7?$Z?IZOII$7?++++?77$??+~:IZ=?+~~=+II=,...+,.
23
+ .....:II++7O8DOZ$$7$7IIZ??7Z7?~~=+++=+7O7+I?=:+$~=?7I??I?+:..:+..
24
+ ... .?ZOZ?++$8O$$7777??7$=???I?+===~:~77+I?==~:~=~~~~~~~~==.,:..
25
+ ... ,+77?7OI78O777777II+?$=~~~~~~~:::II+$7?+~:~:~~~:,:::::~=:.....
26
+ ....,+77==Z$$8O$7777IIII??I=:::::,,+?II?77I+~,,::=I7~,,.:=++:....
27
+ .....=7?=?O8$88Z$$$777II?+=+7$IIII=:+$7III77?==~~=+=+?+=~~~~:.....
28
+ .....~7++7877O8O$$$$77I?+===:~~:::~+IZ$I?+7O$+=~~?++==~::::~:....
29
+ .....,I+?==?788OZZ$$77II?+==~~~~~===+7ODD8OZ8OZZ8D7+~~++~~~=: ...
30
+ ......I=+=+I7O8OOZZ$777I??+===~~====+?IOO$7$O88Z$$7+=~=+=~==:.....
31
+ ,$++7ZIOD8OZ$$$7777I?++=====?I$ZZZ$Z77ZZOOZ$ZZ$I+~+++=.....
32
+ ~I++?7OO$$$$$$777$77?++=?IZOZOOOOZZOOOOOOZ$ZOZ$Z$+=+~......
33
+ .,?++?IZO$$Z$$$777777I??I$ZOOOOOOOZZOZZ7II$7IZOOOZI=+~......
34
+ ..,II=:?Z$$$$$$77I77I?78888888OZZZ$77$III7?+?$O8OO$++,.. .
35
+ ...,,..,7$$$$$$77I7777O8O8D888OZ?II:===?=,:.?NNOZO7++,..
36
+ ........?7$$$$$77II77II=+77Z8NNNNDNNN8DNDNMNO7+?7I++~. .
37
+ ........?$$$$$$$7I777I?==+++?IO8OZI==,::,?$7I?==?+==:
38
+ .....?7$$$$Z$77I7$$7?=++++I??7I+===+?+=?I?===~=+=..
39
+ ..?$$ZZZZ$$$77777I?+=+++II++++=====++===~~==+...
40
+ . ?$$$ZZZZ$$777777I+=+++?II?+????++?+++=~~==~...
41
+ . . ..I$$ZZOOOZZ$$777777+=+?+=+?++++==+=~~~~~~~~...
42
+ .......:$$ZZZOOOOOZZ$777$$?+=+++===~~=~~~~~~~~~~=, ..
43
+ .....,I$7$$$$$ZOOOOZ$$7$Z7I+=====~~:::~:~~~~~=~.....
44
+ . ....+77777$$$ZOO88OZZ$$Z$I?+=====~~::~~~~~=~=,.. ..
45
+ . .,, ......,I77$$7I7777$$ZO888OOZOO$I?+++==~::~~:~=~+~ . . ..
46
+ . :D88DDDZ7+:.,?7I7$$$7IIIII777$ZOOO888OOZ$II??+====+==++,.
47
+ ..?8Z8O88DDDDO7I??777IIIII?77I7$$ZOOOOOOOOZ$$7I?+===+???,..
48
+ ,Z8OOOOOO888888DD8DDD88DDD$?IIII7$ZOZOOOOOOOOZZZZZ$Z$I=.....
data/README.rdoc CHANGED
@@ -1,16 +1,164 @@
1
- = erector_cache
2
-
3
- Description goes here.
4
-
5
- == Note on Patches/Pull Requests
6
-
7
- * Fork the project.
8
- * Make your feature addition or bug fix.
9
- * Add tests for it. This is important so I don't break it in a
10
- future version unintentionally.
11
- * Commit, do not mess with rakefile, version, or history.
12
- (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)
13
- * Send me a pull request. Bonus points for topic branches.
1
+ = Erector Cache
2
+
3
+ Widget caching for Erector.
4
+
5
+ <em>Note:
6
+ This only works at the widget level as this is essentially a fragment caching utility, and will not work for widgets rendered directly from a controller. (widget vs render_widget)</em>
7
+
8
+ == Installation
9
+ sudo gem install erector_cache
10
+
11
+ Checkout redis http://github.com/antirez/redis and install
12
+
13
+ MAKE SURE REDIS SERVER IS RUNNING
14
+
15
+ First, connect to the Redis database. This would most likely go into an environment.rb.
16
+
17
+ Lawnchair.connectdb
18
+
19
+ This will connect to a default database on localhost, if you want to connect to a particular database you can do:
20
+
21
+ Lawnchair.connectdb(Redis.new(:database => 11, :host => "127.0.0.1", :port => 6379))
22
+
23
+ == Usage
24
+ * cache_for - Use this to tell the widget how long it should be cached for. Defaults to 1 hour
25
+ * cache_with - These are the widget parameters you want to use to build the cache key
26
+ * expire! - Expire the instances of a widget matching the given parameters
27
+
28
+ class Bluth < Erector::Widget
29
+ cache_with :name, :mistake
30
+ cache_for 3.seasons
31
+
32
+ def content
33
+ div "My name is #{@name} and #{@mistake.to_param}"
34
+ end
35
+ end
36
+
37
+ class Mistake < ORM::Base
38
+ attr_reader :updated_at
39
+
40
+ def initialize(size)
41
+ @size = size || :huge
42
+ @updated_at = Time.now
43
+ end
44
+
45
+ def size
46
+ @size
47
+ end
48
+
49
+ def to_param
50
+ "I_just_made_a_#{size}_mistake"
51
+ end
52
+ end
53
+
54
+ === cache_with
55
+
56
+ In the simple case the cache key will be built off of the value of the parameter eg.
57
+
58
+ widget Bluth, :name => "George Michael", :mistake => "consubrinaphilia"
59
+
60
+ This will yield a cache key of <em>"Lawnchair:Bluth:name:GeorgeMichael:mistake:consubrinaphilia"</em>
61
+ ---
62
+ You can also pass whole objects into the widget and build the cache based on this. It will default to using the to_param of the object as the key component value.
63
+
64
+ @mistake = Mistake.create(:huge)
65
+ widget Bluth, :name => "Gob", :mistake => @mistake
66
+
67
+ This will yield a cache key of <em>"Lawnchair:Bluth:name:Gob:mistake:I_just_made_a_huge_mistake"</em>
68
+ ---
69
+ This is essentially the same as doing this, which opens up more complex possibilities for generating cache keys
70
+
71
+ class Bluth < Erector::Widget
72
+ cache_with :name, :mistake => lambda {|mistake| mistake.to_param }
73
+ end
74
+
75
+ @mistake = Mistake.create(:huge)
76
+ widget Bluth, :name => "Gob", :mistake => @mistake
77
+ ---
78
+ Using this, we could set the cache to auto expire every time the associated object is updated.
79
+
80
+ class Bluth < Erector::Widget
81
+ cache_with :name, :mistake => lambda {|mistake| mistake.updated_at }
82
+ end
83
+
84
+ == Expiration
85
+
86
+ Widget expiration is possible by calling the widget class's expire! method and passing in as much information about the keys to expire as you want.
87
+
88
+ Assume the following have occurred:
89
+
90
+ widget Bluth, :name => "Tobias", :mistake => "I_just_blue_myself"
91
+ widget Bluth, :name => "Tobias", :mistake => "analyst_and_therapist"
92
+ widget Bluth, :name => "Buster", :mistake => "swimming_with_seal"
93
+
94
+ You can expire all Bluth widgets regardless of what the values of the params passed into them with:
95
+
96
+ Bluth.expire!
97
+
98
+ You can expire only the Bluth widget with <em>:mistake => "I_just_blue_myself"</em> by using:
99
+
100
+ Bluth.expire!(:mistake => "I_just_blue_myself")
101
+
102
+ You can expire all widgets with <em>:name => "Tobias"</em> with:
103
+
104
+ Bluth.expire!(:name => "Tobias")
105
+
106
+ Likewise, calling the following will expire only the one cached version of the widget that exists, leaving the other instance in the cache:
107
+
108
+ Bluth.expire!(:name => "Tobias", :mistake => "I_just_blue_myself")
109
+
110
+ Any cache key component that is not passed into the expire! method will result in a wildcard match on that component, allowing you to be as specific as you wish.
111
+
112
+ <em>Note:
113
+ Lawnchair will automatically condense spaces, so don't feel constrained to using underscores or dashes in keys.</em>
114
+
115
+
116
+ ....:~~~~~~~~~~~~~:~~::::::,..
117
+ ......,~===~=====~~~~~::::::::::::::,..... ..
118
+ ....,~+++=++++++==~~~~:::::::::::::::,... ..
119
+ ..~I?+?????+?+++===~~~~::::::::::::::~:,... .
120
+ .=I7?I?????+?+++===~~~~~:::::::::::::~~:.... ..
121
+ .....~$$77II7III?+?++++===~~~~::::::::::::::~~=:......
122
+ ....:ZZ$$7IIIIII???++++++==~~~:::::::::~~~:~~~==,.....
123
+ ....7OZZ$77I777I????+++++==~~::::::::::~~::~~~===, ..
124
+ ...?OOOZ$$$7777II?????+++===~~:::::::::::::~~~~==~....
125
+ ..,7OOO$$$$$7777II??+++==~~~~~::::::::::::~::::~~=,...
126
+ . ?OOOOZZ$$$77777I??++=++=~~~~:::::::::::::::~~===:...
127
+ ..I8OOO$Z$ZZ77777I???+=+==~~::::::::::,:::::~=+++++...
128
+ ,78OOO$ZZZ$$7777II7ZOOOOZ$7?+~~::::,,,::~~~?I7ZOOZ?..... ..
129
+ ,7O8OO$$ZZZ$77$77ZOO8OOZ$II?+++=::,,,:::~===~+++I$Z:.... ..
130
+ :7O88O8Z$$$$$$$OOZ???+III777$?+=~~::::::~:=I7+=::~+:~~, ..
131
+ ,7OOO8OOZ77$I$OZIII~~~~=+???++I7I=:~=~=+I$=~I~=~:~+...=,:,
132
+ ..IOOO8OOZ777IZZ+=I++++?+=??I7II7$Z$??I$$$+?+=::~~=:.. ,=?:
133
+ ..?O88O88OZ$$$$7$Z+?+?77ZOO7III$7$ZI=:::Z7+78ZO8$I~=~++,~=..
134
+ ..+O88O8OOZ$777=$7=??$ODN$8?+$I?7787=~~:O$?ZN88$Z8?=~...+:..
135
+ ,:+7ZDDD8OZZ$$7?$Z?IZOII$7?++++?77$??+~:IZ=?+~~=+II=,...+,.
136
+ .....:II++7O8DOZ$$7$7IIZ??7Z7?~~=+++=+7O7+I?=:+$~=?7I??I?+:..:+..
137
+ ... .?ZOZ?++$8O$$7777??7$=???I?+===~:~77+I?==~:~=~~~~~~~~==.,:..
138
+ ... ,+77?7OI78O777777II+?$=~~~~~~~:::II+$7?+~:~:~~~:,:::::~=:.....
139
+ ....,+77==Z$$8O$7777IIII??I=:::::,,+?II?77I+~,,::=I7~,,.:=++:....
140
+ .....=7?=?O8$88Z$$$777II?+=+7$IIII=:+$7III77?==~~=+=+?+=~~~~:.....
141
+ .....~7++7877O8O$$$$77I?+===:~~:::~+IZ$I?+7O$+=~~?++==~::::~:....
142
+ .....,I+?==?788OZZ$$77II?+==~~~~~===+7ODD8OZ8OZZ8D7+~~++~~~=: ...
143
+ ......I=+=+I7O8OOZZ$777I??+===~~====+?IOO$7$O88Z$$7+=~=+=~==:.....
144
+ ,$++7ZIOD8OZ$$$7777I?++=====?I$ZZZ$Z77ZZOOZ$ZZ$I+~+++=.....
145
+ ~I++?7OO$$$$$$777$77?++=?IZOZOOOOZZOOOOOOZ$ZOZ$Z$+=+~......
146
+ .,?++?IZO$$Z$$$777777I??I$ZOOOOOOOZZOZZ7II$7IZOOOZI=+~......
147
+ ..,II=:?Z$$$$$$77I77I?78888888OZZZ$77$III7?+?$O8OO$++,.. .
148
+ ...,,..,7$$$$$$77I7777O8O8D888OZ?II:===?=,:.?NNOZO7++,..
149
+ ........?7$$$$$77II77II=+77Z8NNNNDNNN8DNDNMNO7+?7I++~. .
150
+ ........?$$$$$$$7I777I?==+++?IO8OZI==,::,?$7I?==?+==:
151
+ .....?7$$$$Z$77I7$$7?=++++I??7I+===+?+=?I?===~=+=..
152
+ ..?$$ZZZZ$$$77777I?+=+++II++++=====++===~~==+...
153
+ . ?$$$ZZZZ$$777777I+=+++?II?+????++?+++=~~==~...
154
+ . . ..I$$ZZOOOZZ$$777777+=+?+=+?++++==+=~~~~~~~~...
155
+ .......:$$ZZZOOOOOZZ$777$$?+=+++===~~=~~~~~~~~~~=, ..
156
+ .....,I$7$$$$$ZOOOOZ$$7$Z7I+=====~~:::~:~~~~~=~.....
157
+ . ....+77777$$$ZOO88OZZ$$Z$I?+=====~~::~~~~~=~=,.. ..
158
+ . .,, ......,I77$$7I7777$$ZO888OOZOO$I?+++==~::~~:~=~+~ . . ..
159
+ . :D88DDDZ7+:.,?7I7$$$7IIIII777$ZOOO888OOZ$II??+====+==++,.
160
+ ..?8Z8O88DDDDO7I??777IIIII?77I7$$ZOOOOOOOOZ$$7I?+===+???,..
161
+ ,Z8OOOOOO888888DD8DDD88DDD$?IIII7$ZOZOOOOOOOOZZZZZ$Z$I=.....
14
162
 
15
163
  == Copyright
16
164
 
data/VERSION CHANGED
@@ -1 +1 @@
1
- 0.0.4
1
+ 0.0.5
@@ -71,7 +71,7 @@ module ErectorCache
71
71
  if self.class.key_components.blank?
72
72
  _render_via_without_caching(parent, options)
73
73
  else
74
- options = {:expire_in => @expire_in || 1.hour}
74
+ options = {:expire_in => @expire_in || 1.hour, :raw => true}
75
75
  cached_fragment = LAWNCHAIR.cache(cache_key, options) do
76
76
  parent.capture { _render_via_without_caching(parent, options) }
77
77
  end
metadata CHANGED
@@ -1,13 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: erector_cache
3
3
  version: !ruby/object:Gem::Version
4
- hash: 23
4
+ hash: 21
5
5
  prerelease: false
6
6
  segments:
7
7
  - 0
8
8
  - 0
9
- - 4
10
- version: 0.0.4
9
+ - 5
10
+ version: 0.0.5
11
11
  platform: ruby
12
12
  authors:
13
13
  - Grockit
@@ -15,7 +15,7 @@ autorequire:
15
15
  bindir: bin
16
16
  cert_chain: []
17
17
 
18
- date: 2010-09-20 00:00:00 -07:00
18
+ date: 2010-10-08 00:00:00 -07:00
19
19
  default_executable:
20
20
  dependencies:
21
21
  - !ruby/object:Gem::Dependency