The route-generator package
Most of the defacto Haskell web routing libraries are either linear in complexity, or require lots of extra extensions, like Template Haskell.
Luckily, yesod-routes has Yesod.Routes.Dispatch, which is a very clean, efficient, and extension-free router. Writing routes out in code can, however, be quite verbose. This utility is a code generator to produce routes compatible with Yesod.Routes.Dispatch from a nice input format.
GET / => home GET /post/: => showPost PUT /* => updateSomething
./routeGenerator routes.txt SomeModule
Will generate routes that map the correct HTTP verb (which you should pass as a prepended path segment to your Dispatch) and path to functions imported from the module specified in the second parameter.
A colon matches any path segment, and passes the matched segment through to the specified function, passing each match segment in order. The expected type of the segment is inferred from the type of the function. If the segment cannot be parsed as that type, the path does not match. Parsing is done with Web.PathPieces.fromPathPiece.
An asterisk at the end of the path causes rhHasMulti to be set to True, meaning that any path segments after what has been specified will be allowed.
[Skip to Readme]
|Versions||0.1, 0.2, 0.3, 0.3.1, 0.4, 0.5, 0.6, 0.6.1|
|Dependencies||attoparsec (>=0.10.0.0), base (==4.*), text (>=0.7), yesod-routes [details]|
|Copyright||© 2012 Stephen Paul Weber|
|Author||Stephen Paul Weber <email@example.com>|
|Maintainer||Stephen Paul Weber <firstname.lastname@example.org>|
|Source repository||head: git clone git://github.com/route-generator/BitBrawl.git|
|Uploaded||Thu Aug 9 03:02:22 UTC 2012 by StephenWeber|
|Downloads||1524 total (15 in the last 30 days)|
|Status||Docs not available [build log]
Last success reported on 2015-10-19 [all 5 reports]
For package maintainers and hackage trustees