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          #  | 
