diff options
author | Jérémy Zurcher <jeremy@asynk.ch> | 2011-09-13 10:12:55 +0200 |
---|---|---|
committer | Jérémy Zurcher <jeremy@asynk.ch> | 2011-09-13 10:12:55 +0200 |
commit | 285fa24544bf5feffb08b56deb03ec224f1726b4 (patch) | |
tree | 8b355476082aece51b41bd9516e18aa861488fbf /lib | |
parent | b06ae981c92040fe06c0317f0d12dc3f02044d21 (diff) | |
download | zorglub-285fa24544bf5feffb08b56deb03ec224f1726b4.zip zorglub-285fa24544bf5feffb08b56deb03ec224f1726b4.tar.gz |
add before_all and after_all hooks
Diffstat (limited to 'lib')
-rw-r--r-- | lib/zorglub/node.rb | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/lib/zorglub/node.rb b/lib/zorglub/node.rb index 6e0989f..e80c051 100644 --- a/lib/zorglub/node.rb +++ b/lib/zorglub/node.rb @@ -4,8 +4,15 @@ module Zorglub # class Node # + @hooks = { + :before_all => [], + :after_all => [], + } + # class << self # + attr_reader :hooks + # def engine engine=nil @engine = engine unless engine.nil? @engine ||= Config.engine @@ -42,6 +49,24 @@ module Zorglub node.content end # + def before_hooks obj + Node.hooks[:before_all].each do |blk| blk.call obj end + end + # + def before_all &blk + Node.hooks[:before_all]<< blk + Node.hooks[:before_all].uniq! + end + # + def after_hooks obj + Node.hooks[:after_all].each do |blk| blk.call obj end + end + # + def after_all &blk + Node.hooks[:after_all]<< blk + Node.hooks[:after_all].uniq! + end + # def error_404 node resp = node.response resp.status = 404 @@ -71,11 +96,13 @@ module Zorglub end # def feed! + Node.before_hooks self @content = self.send @action[:method], *@action[:args] e, v, l = Config.engine_proc(@action[:engine]), view, layout # TODO compile and cache @content = e.call v, self if e and File.exists? v @content = e.call l, self if e and File.exists? l + Node.after_hooks self @content end # |