nifty-generators 0.1.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (76) hide show
  1. data/CHANGELOG +43 -0
  2. data/LICENSE +20 -0
  3. data/Manifest +74 -0
  4. data/README +75 -0
  5. data/Rakefile +16 -0
  6. data/TODO +7 -0
  7. data/lib/nifty_generators.rb +3 -0
  8. data/nifty-generators.gemspec +142 -0
  9. data/rails_generators/nifty_config/USAGE +23 -0
  10. data/rails_generators/nifty_config/nifty_config_generator.rb +32 -0
  11. data/rails_generators/nifty_config/templates/config.yml +8 -0
  12. data/rails_generators/nifty_config/templates/load_config.rb +2 -0
  13. data/rails_generators/nifty_layout/USAGE +25 -0
  14. data/rails_generators/nifty_layout/nifty_layout_generator.rb +44 -0
  15. data/rails_generators/nifty_layout/templates/helper.rb +23 -0
  16. data/rails_generators/nifty_layout/templates/layout.html.erb +22 -0
  17. data/rails_generators/nifty_layout/templates/layout.html.haml +19 -0
  18. data/rails_generators/nifty_layout/templates/stylesheet.css +80 -0
  19. data/rails_generators/nifty_layout/templates/stylesheet.sass +66 -0
  20. data/rails_generators/nifty_scaffold/USAGE +51 -0
  21. data/rails_generators/nifty_scaffold/nifty_scaffold_generator.rb +224 -0
  22. data/rails_generators/nifty_scaffold/templates/actions/create.rb +9 -0
  23. data/rails_generators/nifty_scaffold/templates/actions/destroy.rb +6 -0
  24. data/rails_generators/nifty_scaffold/templates/actions/edit.rb +3 -0
  25. data/rails_generators/nifty_scaffold/templates/actions/index.rb +3 -0
  26. data/rails_generators/nifty_scaffold/templates/actions/new.rb +3 -0
  27. data/rails_generators/nifty_scaffold/templates/actions/show.rb +3 -0
  28. data/rails_generators/nifty_scaffold/templates/actions/update.rb +9 -0
  29. data/rails_generators/nifty_scaffold/templates/controller.rb +3 -0
  30. data/rails_generators/nifty_scaffold/templates/fixtures.yml +9 -0
  31. data/rails_generators/nifty_scaffold/templates/helper.rb +2 -0
  32. data/rails_generators/nifty_scaffold/templates/migration.rb +16 -0
  33. data/rails_generators/nifty_scaffold/templates/model.rb +2 -0
  34. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/create.rb +11 -0
  35. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/destroy.rb +6 -0
  36. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/edit.rb +4 -0
  37. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/index.rb +4 -0
  38. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/new.rb +4 -0
  39. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/show.rb +4 -0
  40. data/rails_generators/nifty_scaffold/templates/tests/rspec/actions/update.rb +11 -0
  41. data/rails_generators/nifty_scaffold/templates/tests/rspec/controller.rb +8 -0
  42. data/rails_generators/nifty_scaffold/templates/tests/rspec/model.rb +7 -0
  43. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/create.rb +13 -0
  44. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/destroy.rb +8 -0
  45. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/edit.rb +6 -0
  46. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/index.rb +6 -0
  47. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/new.rb +6 -0
  48. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/show.rb +6 -0
  49. data/rails_generators/nifty_scaffold/templates/tests/shoulda/actions/update.rb +13 -0
  50. data/rails_generators/nifty_scaffold/templates/tests/shoulda/controller.rb +5 -0
  51. data/rails_generators/nifty_scaffold/templates/tests/shoulda/model.rb +7 -0
  52. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/create.rb +11 -0
  53. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/destroy.rb +6 -0
  54. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/edit.rb +4 -0
  55. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/index.rb +4 -0
  56. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/new.rb +4 -0
  57. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/show.rb +4 -0
  58. data/rails_generators/nifty_scaffold/templates/tests/testunit/actions/update.rb +11 -0
  59. data/rails_generators/nifty_scaffold/templates/tests/testunit/controller.rb +5 -0
  60. data/rails_generators/nifty_scaffold/templates/tests/testunit/model.rb +7 -0
  61. data/rails_generators/nifty_scaffold/templates/views/erb/_form.html.erb +10 -0
  62. data/rails_generators/nifty_scaffold/templates/views/erb/edit.html.erb +14 -0
  63. data/rails_generators/nifty_scaffold/templates/views/erb/index.html.erb +29 -0
  64. data/rails_generators/nifty_scaffold/templates/views/erb/new.html.erb +7 -0
  65. data/rails_generators/nifty_scaffold/templates/views/erb/show.html.erb +20 -0
  66. data/rails_generators/nifty_scaffold/templates/views/haml/_form.html.haml +11 -0
  67. data/rails_generators/nifty_scaffold/templates/views/haml/edit.html.haml +14 -0
  68. data/rails_generators/nifty_scaffold/templates/views/haml/index.html.haml +25 -0
  69. data/rails_generators/nifty_scaffold/templates/views/haml/new.html.haml +7 -0
  70. data/rails_generators/nifty_scaffold/templates/views/haml/show.html.haml +20 -0
  71. data/tasks/deployment.rake +2 -0
  72. data/test/test_helper.rb +117 -0
  73. data/test/test_nifty_config_generator.rb +37 -0
  74. data/test/test_nifty_layout_generator.rb +42 -0
  75. data/test/test_nifty_scaffold_generator.rb +532 -0
  76. metadata +140 -0
@@ -0,0 +1,8 @@
1
+ development:
2
+ domain: localhost:3000
3
+
4
+ test:
5
+ domain: test.host
6
+
7
+ production:
8
+ domain: example.com
@@ -0,0 +1,2 @@
1
+ raw_config = File.read(RAILS_ROOT + "/config/<%= file_name %>_config.yml")
2
+ <%= constant_name %>_CONFIG = YAML.load(raw_config)[RAILS_ENV].symbolize_keys
@@ -0,0 +1,25 @@
1
+ Description:
2
+ The nifty_layout generator creates a basic layout, stylesheet and
3
+ helper which will give some structure to a starting Rails app.
4
+
5
+ The generator takes one argument which will be the name of the
6
+ layout and stylesheet files. If no argument is passed then it defaults
7
+ to "application".
8
+
9
+ The helper module includes some methods which can be called in any
10
+ template or partial to set variables to be used in the layout, such as
11
+ page title and javascript/stylesheet includes.
12
+
13
+ Examples:
14
+ script/generate nifty_layout
15
+
16
+ Layout: app/views/layouts/application.html.erb
17
+ Stylesheet: public/stylesheets/application.css
18
+ Helper: app/helpers/layout_helper.rb
19
+
20
+
21
+ script/generate nifty_layout admin
22
+
23
+ Layout: app/views/layouts/admin.html.erb
24
+ Stylesheet: public/stylesheets/admin.css
25
+ Helper: app/helpers/layout_helper.rb
@@ -0,0 +1,44 @@
1
+ class NiftyLayoutGenerator < Rails::Generator::Base
2
+ def initialize(runtime_args, runtime_options = {})
3
+ super
4
+ @name = @args.first || 'application'
5
+ end
6
+
7
+ def manifest
8
+ record do |m|
9
+ m.directory 'app/views/layouts'
10
+ m.directory 'public/stylesheets'
11
+ m.directory 'app/helpers'
12
+
13
+ if options[:haml]
14
+ m.directory 'public/stylesheets/sass'
15
+ m.template "layout.html.haml", "app/views/layouts/#{file_name}.html.haml"
16
+ m.file "stylesheet.sass", "public/stylesheets/sass/#{file_name}.sass"
17
+ else
18
+ m.template "layout.html.erb", "app/views/layouts/#{file_name}.html.erb"
19
+ m.file "stylesheet.css", "public/stylesheets/#{file_name}.css"
20
+ end
21
+ m.file "helper.rb", "app/helpers/layout_helper.rb"
22
+ end
23
+ end
24
+
25
+ def file_name
26
+ @name.underscore
27
+ end
28
+
29
+ protected
30
+
31
+ def add_options!(opt)
32
+ opt.separator ''
33
+ opt.separator 'Options:'
34
+ opt.on("--haml", "Generate HAML for view, and SASS for stylesheet.") { |v| options[:haml] = v }
35
+ end
36
+
37
+ def banner
38
+ <<-EOS
39
+ Creates generic layout, stylesheet, and helper files.
40
+
41
+ USAGE: #{$0} #{spec.name} [layout_name]
42
+ EOS
43
+ end
44
+ end
@@ -0,0 +1,23 @@
1
+ # These helper methods can be called in your template to set variables to be used in the layout
2
+ # This module should be included in all views globally,
3
+ # to do so you may need to add this line to your ApplicationController
4
+ # helper :layout
5
+ module LayoutHelper
6
+ def title(page_title, show_title = true)
7
+ @content_for_title = page_title.to_s
8
+ @show_title = show_title
9
+ end
10
+
11
+ def show_title?
12
+ @show_title
13
+ end
14
+
15
+ def stylesheet(*args)
16
+ content_for(:head) { stylesheet_link_tag(*args.map(&:to_s)) }
17
+ end
18
+
19
+ def javascript(*args)
20
+ args = args.map { |arg| arg == :defaults ? arg : arg.to_s }
21
+ content_for(:head) { javascript_include_tag(*args) }
22
+ end
23
+ end
@@ -0,0 +1,22 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3
+ <html>
4
+ <head>
5
+ <title><%%= h(yield(:title) || "Untitled") %></title>
6
+ <%%= stylesheet_link_tag '<%= file_name %>' %>
7
+ <%%= yield(:head) %>
8
+ </head>
9
+ <body>
10
+ <div id="container">
11
+ <%%- flash.each do |name, msg| -%>
12
+ <%%= content_tag :div, msg, :id => "flash_#{name}" %>
13
+ <%%- end -%>
14
+
15
+ <%%- if show_title? -%>
16
+ <h1><%%=h yield(:title) %></h1>
17
+ <%%- end -%>
18
+
19
+ <%%= yield %>
20
+ </div>
21
+ </body>
22
+ </html>
@@ -0,0 +1,19 @@
1
+ !!! Strict
2
+ %html{html_attrs}
3
+
4
+ %head
5
+ %title
6
+ = h(yield(:title) || "Untitled")
7
+ %meta{"http-equiv"=>"Content-Type", :content=>"text/html; charset=utf-8"}/
8
+ = stylesheet_link_tag '<%= file_name %>'
9
+ = yield(:head)
10
+
11
+ %body
12
+ #container
13
+ - flash.each do |name, msg|
14
+ = content_tag :div, msg, :id => "flash_#{name}"
15
+
16
+ - if show_title?
17
+ %h1=h yield(:title)
18
+
19
+ = yield
@@ -0,0 +1,80 @@
1
+ body {
2
+ background-color: #4B7399;
3
+ font-family: Verdana, Helvetica, Arial;
4
+ font-size: 14px;
5
+ }
6
+
7
+ a img {
8
+ border: none;
9
+ }
10
+
11
+ a {
12
+ color: #0000FF;
13
+ }
14
+
15
+ .clear {
16
+ clear: both;
17
+ height: 0px;
18
+ overflow: hidden;
19
+ }
20
+
21
+ #container {
22
+ width: 75%;
23
+ margin: 0 auto;
24
+ background-color: #FFF;
25
+ padding: 20px 40px;
26
+ border: solid 1px black;
27
+ margin-top: 20px;
28
+ }
29
+
30
+ #flash_notice, #flash_error {
31
+ padding: 5px 8px;
32
+ margin: 10px 0;
33
+ }
34
+
35
+ #flash_notice {
36
+ background-color: #CFC;
37
+ border: solid 1px #6C6;
38
+ }
39
+
40
+ #flash_error {
41
+ background-color: #FCC;
42
+ border: solid 1px #C66;
43
+ }
44
+
45
+
46
+
47
+ .fieldWithErrors {
48
+ display: inline;
49
+ }
50
+
51
+ #errorExplanation {
52
+ width: 400px;
53
+ border: 2px solid #CF0000;
54
+ padding: 0px;
55
+ padding-bottom: 12px;
56
+ margin-bottom: 20px;
57
+ background-color: #f0f0f0;
58
+ }
59
+
60
+ #errorExplanation h2 {
61
+ text-align: left;
62
+ font-weight: bold;
63
+ padding: 5px 5px 5px 15px;
64
+ font-size: 12px;
65
+ margin: 0px;
66
+ background-color: #c00;
67
+ color: #fff;
68
+ }
69
+ #errorExplanation p {
70
+ color: #333;
71
+ margin-bottom: 0;
72
+ padding: 8px;
73
+ }
74
+ #errorExplanation ul {
75
+ margin: 2px 24px;
76
+ }
77
+ #errorExplanation ul li {
78
+ font-size: 12px;
79
+ list-style: disc;
80
+ }
@@ -0,0 +1,66 @@
1
+ !primary_color = #4B7399
2
+
3
+ body
4
+ :background-color = !primary_color
5
+ :font
6
+ :family Verdana, Helvetica, Arial
7
+ :size 14px
8
+
9
+ ul li
10
+ :list-style none
11
+
12
+ a
13
+ :color #0000FF
14
+ img
15
+ :border none
16
+
17
+ .clear
18
+ :clear both
19
+ :height 0px
20
+ :overflow hidden
21
+
22
+ #container
23
+ :width 75%
24
+ :margin 0 auto
25
+ :background #fff
26
+ :padding 20px 40px
27
+ :border solid 1px black
28
+ :margin-top 20px
29
+
30
+ #flash_notice,
31
+ #flash_error
32
+ :padding 5px 8px
33
+ :margin 10px 0
34
+
35
+ #flash_notice
36
+ :background-color #CFC
37
+ :border solid 1px #6C6
38
+
39
+ #flash_error
40
+ :background-color #FCC
41
+ :border solid 1px #C66
42
+
43
+ #errorExplanation
44
+ :width 400px
45
+ :border 2px solid #CF0000
46
+ :padding 0px
47
+ :padding-bottom 12px
48
+ :margin-bottom 20px
49
+ :background-color #f0f0f0
50
+ h2
51
+ :text-align left
52
+ :font-weight bold
53
+ :padding 5px 5px 5px 15px
54
+ :font-size 12px
55
+ :margin 0px
56
+ :background-color #c00
57
+ :color #fff
58
+ p
59
+ :color #333
60
+ :margin-bottom 0
61
+ :padding 8px
62
+ ul
63
+ :margin 2px 24px
64
+ li
65
+ :font-size 12px
66
+ :list-style disc
@@ -0,0 +1,51 @@
1
+ Description:
2
+ Scaffolds an entire resource, from model and migration to controller and
3
+ views. The resource is ready to use as a starting point for your restful,
4
+ resource-oriented application. Tests or specs are also generated depending
5
+ on if you have a "spec" directory or not.
6
+
7
+ IMPORTANT: This generator uses the "title" helper method which is generated
8
+ by the nifty_layout generator. You may want to run that generator first.
9
+
10
+ Usage:
11
+ Pass the name of the model, either CamelCased or under_scored, as the first
12
+ argument, and an optional list of attribute pairs and controller actions.
13
+
14
+ If no controller actions are specified, they will default to index, show,
15
+ new, create, edit, update, and destroy.
16
+
17
+ IMPORTANT: If no attribute pairs are specified, no model will be generated.
18
+ It will try to determine the attributes from an existing model.
19
+
20
+ Attribute pairs are column_name:sql_type arguments specifying the
21
+ model's attributes. Timestamps are added by default, so you don't have to
22
+ specify them by hand as 'created_at:datetime updated_at:datetime'.
23
+
24
+ For example, `nifty_scaffold post name:string content:text hidden:boolean`
25
+ gives you a model with those three attributes, a controller that handles
26
+ the create/show/update/destroy, forms to create and edit your posts, and
27
+ an index that lists them all, as well as a map.resources :posts
28
+ declaration in config/routes.rb.
29
+
30
+ Adding an "!" in the mix of arguments will invert the passed controller
31
+ actions. This will include all 7 controller actitons except the ones
32
+ mentioned. This option doesn't effect model attributes.
33
+
34
+ Examples:
35
+ script/generate nifty_scaffold post
36
+
37
+ Will create a controller called "posts" it will contain all seven
38
+ CRUD actions along with the views. A model will NOT be created,
39
+ instead it will look for an existing model and use those attributes.
40
+
41
+ script/generate nifty_scaffold post name:string content:text index new edit
42
+
43
+ Will create a Post model and migration file with the name and content
44
+ attributes. It will also create a controller with index, new, create,
45
+ edit, and update actions. Notice the create and update actions are
46
+ added automatically with new and edit.
47
+
48
+ script/generate nifty_scaffold post ! show new
49
+
50
+ Creates a posts controller (no model) with index, edit, update, and
51
+ destroy actions.
@@ -0,0 +1,224 @@
1
+ class NiftyScaffoldGenerator < Rails::Generator::Base
2
+ attr_accessor :name, :attributes, :controller_actions
3
+
4
+ def initialize(runtime_args, runtime_options = {})
5
+ super
6
+ usage if @args.empty?
7
+
8
+ @name = @args.first
9
+ @controller_actions = []
10
+ @attributes = []
11
+
12
+ @args[1..-1].each do |arg|
13
+ if arg == '!'
14
+ options[:invert] = true
15
+ elsif arg.include? ':'
16
+ @attributes << Rails::Generator::GeneratedAttribute.new(*arg.split(":"))
17
+ else
18
+ @controller_actions << arg
19
+ @controller_actions << 'create' if arg == 'new'
20
+ @controller_actions << 'update' if arg == 'edit'
21
+ end
22
+ end
23
+
24
+ @controller_actions.uniq!
25
+ @attributes.uniq!
26
+
27
+ if options[:invert] || @controller_actions.empty?
28
+ @controller_actions = all_actions - @controller_actions
29
+ end
30
+
31
+ if @attributes.empty?
32
+ options[:skip_model] = true # default to skipping model if no attributes passed
33
+ if model_exists?
34
+ model_columns_for_attributes.each do |column|
35
+ @attributes << Rails::Generator::GeneratedAttribute.new(column.name.to_s, column.type.to_s)
36
+ end
37
+ else
38
+ @attributes << Rails::Generator::GeneratedAttribute.new('name', 'string')
39
+ end
40
+ end
41
+ end
42
+
43
+ def manifest
44
+ record do |m|
45
+ unless options[:skip_model]
46
+ m.directory "app/models"
47
+ m.template "model.rb", "app/models/#{singular_name}.rb"
48
+ unless options[:skip_migration]
49
+ m.migration_template "migration.rb", "db/migrate", :migration_file_name => "create_#{plural_name}"
50
+ end
51
+
52
+ if rspec?
53
+ m.directory "spec/models"
54
+ m.template "tests/#{test_framework}/model.rb", "spec/models/#{singular_name}_spec.rb"
55
+ m.directory "spec/fixtures"
56
+ m.template "fixtures.yml", "spec/fixtures/#{plural_name}.yml"
57
+ else
58
+ m.directory "test/unit"
59
+ m.template "tests/#{test_framework}/model.rb", "test/unit/#{singular_name}_test.rb"
60
+ m.directory "test/fixtures"
61
+ m.template "fixtures.yml", "test/fixtures/#{plural_name}.yml"
62
+ end
63
+ end
64
+
65
+ unless options[:skip_controller]
66
+ m.directory "app/controllers"
67
+ m.template "controller.rb", "app/controllers/#{plural_name}_controller.rb"
68
+
69
+ m.directory "app/helpers"
70
+ m.template "helper.rb", "app/helpers/#{plural_name}_helper.rb"
71
+
72
+ m.directory "app/views/#{plural_name}"
73
+ controller_actions.each do |action|
74
+ if File.exist? source_path("views/#{view_language}/#{action}.html.#{view_language}")
75
+ m.template "views/#{view_language}/#{action}.html.#{view_language}", "app/views/#{plural_name}/#{action}.html.#{view_language}"
76
+ end
77
+ end
78
+
79
+ if form_partial?
80
+ m.template "views/#{view_language}/_form.html.#{view_language}", "app/views/#{plural_name}/_form.html.#{view_language}"
81
+ end
82
+
83
+ m.route_resources plural_name
84
+
85
+ if rspec?
86
+ m.directory "spec/controllers"
87
+ m.template "tests/#{test_framework}/controller.rb", "spec/controllers/#{plural_name}_controller_spec.rb"
88
+ else
89
+ m.directory "test/functional"
90
+ m.template "tests/#{test_framework}/controller.rb", "test/functional/#{plural_name}_controller_test.rb"
91
+ end
92
+ end
93
+ end
94
+ end
95
+
96
+ def form_partial?
97
+ actions? :new, :edit
98
+ end
99
+
100
+ def all_actions
101
+ %w[index show new create edit update destroy]
102
+ end
103
+
104
+ def action?(name)
105
+ controller_actions.include? name.to_s
106
+ end
107
+
108
+ def actions?(*names)
109
+ names.all? { |n| action? n.to_s }
110
+ end
111
+
112
+ def singular_name
113
+ name.underscore
114
+ end
115
+
116
+ def plural_name
117
+ name.underscore.pluralize
118
+ end
119
+
120
+ def class_name
121
+ name.camelize
122
+ end
123
+
124
+ def plural_class_name
125
+ plural_name.camelize
126
+ end
127
+
128
+ def controller_methods(dir_name)
129
+ controller_actions.map do |action|
130
+ read_template("#{dir_name}/#{action}.rb")
131
+ end.join(" \n").strip
132
+ end
133
+
134
+ def render_form
135
+ if form_partial?
136
+ if options[:haml]
137
+ "= render :partial => 'form'"
138
+ else
139
+ "<%= render :partial => 'form' %>"
140
+ end
141
+ else
142
+ read_template("views/#{view_language}/_form.html.#{view_language}")
143
+ end
144
+ end
145
+
146
+ def item_path(suffix = 'path')
147
+ if action? :show
148
+ "@#{singular_name}"
149
+ else
150
+ "#{plural_name}_#{suffix}"
151
+ end
152
+ end
153
+
154
+ def item_path_for_spec(suffix = 'path')
155
+ if action? :show
156
+ "#{singular_name}_#{suffix}(assigns[:#{singular_name}])"
157
+ else
158
+ "#{plural_name}_#{suffix}"
159
+ end
160
+ end
161
+
162
+ def item_path_for_test(suffix = 'path')
163
+ if action? :show
164
+ "#{singular_name}_#{suffix}(assigns(:#{singular_name}))"
165
+ else
166
+ "#{plural_name}_#{suffix}"
167
+ end
168
+ end
169
+
170
+ def model_columns_for_attributes
171
+ class_name.constantize.columns.reject do |column|
172
+ column.name.to_s =~ /^(id|created_at|updated_at)$/
173
+ end
174
+ end
175
+
176
+ def rspec?
177
+ test_framework == :rspec
178
+ end
179
+
180
+ protected
181
+
182
+ def view_language
183
+ options[:haml] ? 'haml' : 'erb'
184
+ end
185
+
186
+ def test_framework
187
+ options[:test_framework] ||= default_test_framework
188
+ end
189
+
190
+ def default_test_framework
191
+ File.exist?(destination_path("spec")) ? :rspec : :testunit
192
+ end
193
+
194
+ def add_options!(opt)
195
+ opt.separator ''
196
+ opt.separator 'Options:'
197
+ opt.on("--skip-model", "Don't generate a model or migration file.") { |v| options[:skip_model] = v }
198
+ opt.on("--skip-migration", "Don't generate migration file for model.") { |v| options[:skip_migration] = v }
199
+ opt.on("--skip-timestamps", "Don't add timestamps to migration file.") { |v| options[:skip_timestamps] = v }
200
+ opt.on("--skip-controller", "Don't generate controller, helper, or views.") { |v| options[:skip_controller] = v }
201
+ opt.on("--invert", "Generate all controller actions except these mentioned.") { |v| options[:invert] = v }
202
+ opt.on("--haml", "Generate HAML views instead of ERB.") { |v| options[:haml] = v }
203
+ opt.on("--testunit", "Use test/unit for test files.") { options[:test_framework] = :testunit }
204
+ opt.on("--rspec", "Use RSpec for test files.") { options[:test_framework] = :rspec }
205
+ opt.on("--shoulda", "Use Shoulda for test files.") { options[:test_framework] = :shoulda }
206
+ end
207
+
208
+ # is there a better way to do this? Perhaps with const_defined?
209
+ def model_exists?
210
+ File.exist? destination_path("app/models/#{singular_name}.rb")
211
+ end
212
+
213
+ def read_template(relative_path)
214
+ ERB.new(File.read(source_path(relative_path)), nil, '-').result(binding)
215
+ end
216
+
217
+ def banner
218
+ <<-EOS
219
+ Creates a controller and optional model given the name, actions, and attributes.
220
+
221
+ USAGE: #{$0} #{spec.name} ModelName [controller_actions and model:attributes] [options]
222
+ EOS
223
+ end
224
+ end