Skip to content

Commit

Permalink
Simplify things Rack gives us for free
Browse files Browse the repository at this point in the history
  • Loading branch information
judofyr committed Jun 11, 2009
1 parent 332e0a1 commit a7cff36
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 15 deletions.
24 changes: 15 additions & 9 deletions lib/camping-unabridged.rb
Original file line number Diff line number Diff line change
Expand Up @@ -391,7 +391,6 @@ def URL c='/',*a
#
module Base
attr_accessor :input, :cookies, :headers, :body, :status, :root
M = proc { |_, o, n| o.merge(n, &M) }

# Display a view, calling it by its method name +v+. If a <tt>layout</tt>
# method is found in Camping::Views, it will be used to wrap the HTML.
Expand Down Expand Up @@ -510,22 +509,29 @@ def to_a
@env['rack.session'] = @state
r = Rack::Response.new(@body, @status, @headers)
@cookies.each do |k, v|
v = {:value => v, :path => self / "/"} if String===v
v = {:value => v, :path => self / "/"} if String === v
r.set_cookie(k, v)
end
r.to_a
end

def initialize(env, m) #:nodoc:
r = @request = Rack::Request.new(@env = env)
@root, p, @cookies, @state,
@root, @input, @cookies, @state,
@headers, @status, @method =
(env['SCRIPT_NAME']||'').sub(/\/$/,''),
H[r.params], H[r.cookies], H[r.session],
r.script_name.sub(/\/$/,''), n(r.params),
H[r.cookies], H[r.session],
{}, m =~ /r(\d+)/ ? $1.to_i : 200, m

@input = p.inject(H[]) do |h, (k, v)|
h.merge(k.split(/[\]\[]+/).reverse.inject(v) { |x, i| H[i => x] }, &M)
end

def n(h) # :nodoc:
if Hash === h
h.inject(H[]) do |m, (k, v)|
m[k] = n(v)
m
end
else
h
end
end

Expand Down Expand Up @@ -843,7 +849,7 @@ def goes(m)
def call(e)
X.M
p = e['PATH_INFO'] = U.unescape(e['PATH_INFO'])
k,m,*a=X.D p,(e['REQUEST_METHOD']||'get').downcase
k,m,*a=X.D p,e['REQUEST_METHOD'].downcase
k.new(e,m).service(*a).to_a
rescue
r500(:I, k, m, $!, :env => e).to_a
Expand Down
10 changes: 4 additions & 6 deletions lib/camping.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ def method_missing m,*a;m.to_s=~/=$/?self[$`]=a[0]:a==[]?self[m.to_s]:super end
p[0]==?/?@root+p:p end;def URL c='/',*a;c=R(c, *a) if c.respond_to?:urls
c=self/c;c=@request.url[/.{8,}?(?=\/)/]+c if c[0]==?/;URI c end
end;module Base;attr_accessor:input,:cookies,:headers,:body,:status,:root
M=proc{|_,o,n|o.merge(n,&M)}
def render v,*a,&b;mab(/^_/!~v.to_s){send(v,*a,&b)} end
def mab l=nil,&b;m=Mab.new({},self);s=m.capture(&b)
s=m.capture{layout{s}} if l && m.respond_to?(:layout);s end
Expand All @@ -24,11 +23,10 @@ def r501 m;P%"#{m.upcase} not implemented"end;def to_a
r.set_cookie(k,v)}
r.to_a;end;def initialize(env,m)
r=@request=Rack::Request.new(@env=env)
@root,p,@cookies,@state,@headers,@status,@method=
(env['SCRIPT_NAME']||'').sub(/\/$/,''),H[r.params],
@root,@input,@cookies,@state,@headers,@status,@method=
r.script_name.sub(/\/$/,''),n(r.params),
H[r.cookies],H[r.session],{},m=~/r(\d+)/?$1.to_i: 200,m
@input=p.inject(H[]){|h,(k,v)|h.merge k.split(/[\]\[]+/).reverse.inject(v){|x,i|
H[i=>x]},&M};end;def service *a
end;def n h;Hash===h ?h.inject(H[]){|m,(k,v)|m[k]=n(v);m}: h end;def service *a
r=catch(:halt){send(@method,*a)};@body||=r
self;end;end;module Controllers;@r=[];class<<self;def r;@r end;def R *u;r=@r
Class.new{meta_def(:urls){u};meta_def(:inherited){|x|r<<x}}end
Expand All @@ -43,7 +41,7 @@ def M;def M;end;constants.map{|c|k=const_get(c)
end;X=Controllers;class<<self;def goes m
Apps<<eval(S.gsub(/Camping/,m.to_s),TOPLEVEL_BINDING) end;def call e
X.M;p=e['PATH_INFO']=U.unescape(e['PATH_INFO'])
k,m,*a=X.D p,(e['REQUEST_METHOD']||'get').downcase
k,m,*a=X.D p,e['REQUEST_METHOD'].downcase
k.new(e,m).service(*a).to_a;rescue;r500(:I,k,m,$!,:env=>e).to_a;end
def method_missing m,c,*a;X.M;h=Hash===a[-1]?a.pop: {}
e=H[Rack::MockRequest.env_for('',h[:env]||{})]
Expand Down

0 comments on commit a7cff36

Please sign in to comment.