public
Description: A Ruby web application framework
Homepage: http://www.mackframework.com
Clone URL: git://github.com/markbates/mack.git
Search Repo:
Click here to lend your support to: mack and make a donation at www.pledgie.com !
commit  c06ff8eeb58296d78dee96747194ccd70030ce82
tree    51b3938d16c124cbc32b2403af0a841e0f811cc3
parent  50ba59f1c6eb8d7c5823f54bdcf4d976b658e394
mack /
name age message
folder .gitignore Fri Mar 28 14:07:19 -0700 2008 Added mack_ring_server binary. Added some rake ... [markbates]
folder CHANGELOG Wed Apr 09 13:41:50 -0700 2008 More scaffold_generator tests. [markbates]
folder README Wed Mar 05 08:27:37 -0800 2008 initial import [markbates]
folder RakeFile Fri Mar 14 14:13:26 -0700 2008 More testing for distributed routes, as well as... [markbates]
folder bin/ Sun Apr 13 08:05:07 -0700 2008 Merge branch 'distributed_routes_rework' into 0... [markbates]
folder lib/ Sun Apr 13 08:33:19 -0700 2008 Refactored the orm_support.rb file to be a bit ... [markbates]
folder tasks/ Sun Apr 13 08:05:07 -0700 2008 Merge branch 'distributed_routes_rework' into 0... [markbates]
folder test/ Sun Apr 13 08:33:19 -0700 2008 Refactored the orm_support.rb file to be a bit ... [markbates]
README
=Hello, and welcome to Mack!

Mack is a Ruby web application framework. It takes the best ideas from several frameworks, including Rails, Merb, and 
Ramaze, and tries to improve upon those ideas. Mack uses Rack[http://rack.rubyforge.org] as an abstraction layer to 
separate itself from it's deployment.

Mack is also about performance. Because Mack uses technologies like Thin[http://code.macournoyer.com/thin] and 
Rack[http://rack.rubyforge.org], Mack is a multithreaded and fast framework. Current tests show 
Mack/Thin[http://code.macournoyer.com/thin] is twice as fast as Rails/Mongrel. Mack tries to strip out a lot of the 
cruft from other frameworks, like Rails, and delivers you a fast, efficient framework designed for actual real world 
development.

==Installation
  $ sudo gem install mack

==Getting Started
First things first, let's generate your application:
  $ mack <app_name>

To run a Mack application:
  $ rake script:server

It will try and run the app using the following servers in this order:
  * Thin
  * Mongrel
  * WEBrick

rake script:server takes the following options:
  $ rake script:server PORT=<port> MACK_ENV=<environment> HANDLER=<rack_handler>
  
The port and rack_handler flags don't apply if you're using Thin[http://code.macournoyer.com/thin] to run the app, which 
is the default if it is installed. Use the thin.yml file in your application's config directory to configure Thin. The 
rack_handler one will allow you to switch which server is used to run the app. See Rack for more Rack::Handlers.
  
The environment can also be changed like this:
  $ rake script:server#<environment>
  
You can also run:
  $ rake console
This will give you console level access to your application.


==Contact
Please mail bugs, suggestions and patches to <bugs@mackframework.com>.

On the web at: http://www.mackframework.com

==License and Copyright
Copyright (C) 2008 Mark Bates, http://www.mackframework.com

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated 
documentation files (the "Software"), to deal in the Software without restriction, including without limitation the 
rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit 
persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the 
Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE 
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE 
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT 
OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

==Other documentation:
* Rack[http://rack.rubyforge.org]
* Thin[http://code.macournoyer.com/thin]