quirkey / sinatra-gen

Rubigen based generator for new sinatra projects
http://code.quirkey.com/sinatra-gen
MIT License
146 stars 11 forks source link

= sinatra-gen

http://github.com/quirkey/sinatra-gen

== DESCRIPTION:

sinatra-gen generates a common file structure and basic app files for a web app utilizing the sinatra framework. For more information on sinatra, check out http://sinatrarb.com

== SYNOPSIS:

sinatra-gen has a bunch of different options (based looseley on merb-gen) to try to not lock the user into any specific frameworks/dev practices.

Run:

sinatra-gen [appname] [options] [paths]

e.g.

sinatra-gen mysinatrapp --vendor --init --test=shoulda --views=haml get:/ post:/:id

! Note: As of version 0.4.0 by default the sinatra app is placed in lib/appname.rb and is a subclass of Sinatra::Application. If you want 'classic' style apps (no class/module) use the --tiny option.

=== Actions

For even faster app development you specify actions to include in your app when generating. Actions are written out as

http_method:path

And are separated by spaces. For example:

get:/ post:/:id put:/update/*

Will be added you your app as:

get '/' do end

post '/:id' do end

put '/update/*' do end

It will also generate test skeletons in the test framework of your choosing.

=== Middleware

You can specify middleware to include by passing the filename(s) or class name(s), seperated by commas.

sinatra-gen myapp --middleware=rack/flash,Rack::Cache

Will place both the 'require' and 'use' statements in your app.

require 'rack/flash' require 'rack/cache'

...

use Rack::Flash use Rack::Cache

=== Options

(can also be obtained by running sinatra-gen with no arguments):

-v, --version                    Show the sinatra-gen version number and quit.
-d, --vendor                     Extract the latest sinatra to vendor/sinatra
    --tiny                       Only create the minimal files.
    --init                       Initialize a git repository
    --heroku                     Create a Heroku app (also runs 'git init').

Optionally, specify the path to the heroku bin --cap Adds config directory with basic capistrano deploy.rb --scripts Install the rubigen scripts (script/generate, script/destroy) --test=test_framework Specify your testing framework (bacon (default)/rspec/spec/shoulda/test) --views=view_framework Specify your view framework (haml (default)/erb/builder) --middleware=rack-middleware Specify Rack Middleware to be required and included (comma delimited) --vegas, --bin=[bin_name] Create an executable bin using Vegas. Pass an optional bin_name General Options: -h, --help Show this help message and quit. -p, --pretend Run but do not make any changes. -f, --force Overwrite files that already exist. -s, --skip Skip files that already exist. -q, --quiet Suppress normal output. -t, --backtrace Debugging: show backtrace on errors. -c, --svn Modify files with subversion. (Note: svn must be in path) -g, --git Modify files with git. (Note: git must be in path)

The --tiny option will create no directories. Just an app.rb, a Rakefile, and a config.ru (Rackup file)

== ACKNOWLEDGEMENTS:

Big props to the Sinatra developers (http://github.com/bmizerany/sinatra/). Also, thanks to Dr. Nic (http://github.com/drnic) for the Rubigen and Newgem libraries

== REQUIREMENTS:

To use the --vendor option, git must be installed. To use the --bin/vegas option Vegas is required (sudo gem install vegas). To use the --heroku option, a Heroku account and the heroku gem is required (sudo gem install heroku).

To run the app without using the vendor option, the sinatra gem must be installed.

== INSTALL:

sudo gem install sinatra-gen

You can also install directly from github:

sudo gem install quirkey-sinatra-gen -s http://gems.github.com