This repository is private.
All pages are served over SSL and all pushing and pulling is done over SSH.
No one may fork, clone, or view it unless they are added as a member.
Every repository with this icon (
) is private.
Every repository with this icon (
This repository is public.
Anyone may fork, clone, or view it.
Every repository with this icon (
) is public.
Every repository with this icon (
| name | age | message | |
|---|---|---|---|
| |
.gitignore | Tue May 26 14:23:53 -0700 2009 | |
| |
LICENSE | Fri Oct 09 21:46:15 -0700 2009 | |
| |
README.rdoc | Sun Jul 26 19:52:35 -0700 2009 | |
| |
Rakefile | Fri Oct 02 15:15:30 -0700 2009 | |
| |
benchmark/ | Fri Oct 09 19:29:48 -0700 2009 | |
| |
deps.rip | Sun Sep 06 14:35:01 -0700 2009 | |
| |
lib/ | Tue Oct 20 07:50:54 -0700 2009 | |
| |
rack-mount.gemspec | Fri Oct 09 21:46:15 -0700 2009 | |
| |
test/ | Tue Oct 20 07:50:54 -0700 2009 |
README.rdoc
Rack::Mount
A stackable dynamic tree based Rack router.
Rack::Mount supports Rack’s Cascade style of trying several routes until it finds one that is not a 404. This allows multiple routes to be nested or stacked on top of each other. Since the application endpoint can trigger the router to continue matching, middleware can be used to add arbitrary conditions to any route. This allows you to route based on other request attributes, session information, or even data dynamically pulled from a database.
Usage
Rack::Mount provides a plugin API to build custom DSLs on top of.
The API is extremely minimal and only 3 methods are exposed as the public API.
| Rack::Mount::RouteSet#add_route: | builder method for adding routes to the set |
| Rack::Mount::RouteSet#call: | Rack compatible recognition and dispatching method |
| Rack::Mount::RouteSet#url: | generates path from identifiers or significant keys |
Example
require 'rack/mount'
Routes = Rack::Mount::RouteSet.new do |set|
# add_route takes a rack application and conditions to match with
# conditions may be strings or regexps
# See Rack::Mount::RouteSet#add_route for more options.
set.add_route FooApp, :method => 'get' :path => %{/foo}
end
# The route set itself is a simple rack app you mount
run Routes







