w2tags 0.9.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/COPYING +340 -0
- data/LICENSE +6 -0
- data/MIT-LICENSE +18 -0
- data/Manifest.txt +95 -0
- data/README.rdoc +264 -0
- data/Rakefile +23 -0
- data/VERSION +1 -0
- data/bin/w2tags +143 -0
- data/doc/ERB.HOT.rdoc +82 -0
- data/doc/FAQ.rdoc +81 -0
- data/doc/HAML.rdoc +310 -0
- data/doc/HOT.rdoc +137 -0
- data/doc/History.rdoc +757 -0
- data/doc/W2TAGS.rdoc +150 -0
- data/example/common.hot +11 -0
- data/example/from_readme.erb +78 -0
- data/example/from_readme.w2erb +64 -0
- data/example/from_w2tags.erb +32 -0
- data/example/from_w2tags.w2erb +32 -0
- data/example/rails_basic.hot +10 -0
- data/hot/erb.hot +156 -0
- data/hot/erb_form.hot +42 -0
- data/hot/erb_head.hot +15 -0
- data/hot/erb_jquery.hot +8 -0
- data/hot/erb_merb.hot +12 -0
- data/hot/erb_table.hot +43 -0
- data/hot/html.hot +31 -0
- data/hot/jquery.hot +88 -0
- data/hot/nvelocity.hot +23 -0
- data/hot/rails/sc_zebra.hot +10 -0
- data/hot/rails/scaffold.hot +15 -0
- data/hot/vm.hot +9 -0
- data/hot/vm2.hot +34 -0
- data/hot/vm_crud.hot +34 -0
- data/hot/vm_popup.hot +74 -0
- data/hot/xul.hot +114 -0
- data/lib/w2tags/block/plain_text.rb +57 -0
- data/lib/w2tags/block/remark.rb +37 -0
- data/lib/w2tags/block/sass.rb +66 -0
- data/lib/w2tags/merb_hook.rb +15 -0
- data/lib/w2tags/parser.rb +975 -0
- data/lib/w2tags/rails_hook.rb +15 -0
- data/lib/w2tags/sinatra_hook.rb +50 -0
- data/lib/w2tags.rb +100 -0
- data/plugins//w2tags//README +2 -0
- data/plugins//w2tags//generators//w2scaffold//USAGE +29 -0
- data/plugins//w2tags//generators//w2scaffold//templates//controller.rb +85 -0
- data/plugins//w2tags//generators//w2scaffold//templates//functional_test.rb +45 -0
- data/plugins//w2tags//generators//w2scaffold//templates//helper.rb +2 -0
- data/plugins//w2tags//generators//w2scaffold//templates//helper_test.rb +4 -0
- data/plugins//w2tags//generators//w2scaffold//templates//layout.html.erb +17 -0
- data/plugins//w2tags//generators//w2scaffold//templates//style.css +54 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_edit.html.erb +18 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_edit.html.w2erb +17 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_index.html.erb +24 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_index.html.w2erb +14 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_new.html.erb +17 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_new.html.w2erb +16 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_show.html.erb +10 -0
- data/plugins//w2tags//generators//w2scaffold//templates//view_show.html.w2erb +9 -0
- data/plugins//w2tags//generators//w2scaffold//w2scaffold_generator.rb +106 -0
- data/plugins//w2tags//install.rb +1 -0
- data/spec/spec_helper.rb +17 -0
- data/spec/w2tags_spec.rb +8 -0
- data/tasks/ann.rake +81 -0
- data/tasks/bones.rake +21 -0
- data/tasks/gem.rake +126 -0
- data/tasks/git.rake +41 -0
- data/tasks/manifest.rake +49 -0
- data/tasks/notes.rake +28 -0
- data/tasks/post_load.rake +39 -0
- data/tasks/rdoc.rake +51 -0
- data/tasks/rubyforge.rake +57 -0
- data/tasks/setup.rb +268 -0
- data/tasks/spec.rake +55 -0
- data/tasks/svn.rake +48 -0
- data/tasks/test.rake +38 -0
- data/test/enlightning.hot +3 -0
- data/test/feature.hot +28 -0
- data/test/parser_test.rb +203 -0
- data/test/tricky.hot +8 -0
- data/test/vars.hot +30 -0
- data/test/w2tags_basic_usability.rb +187 -0
- data/test/w2tags_enlightning.rb +42 -0
- data/test/w2tags_form.rb +32 -0
- data/test/w2tags_hot.rb +85 -0
- data/test/w2tags_hot_var.rb +115 -0
- data/test/w2tags_no_parsing.rb +37 -0
- metadata +163 -0
@@ -0,0 +1,15 @@
|
|
1
|
+
module ActionView
|
2
|
+
if Object::RAILS_ENV != "development"
|
3
|
+
puts 'W2Tags Only RUN on (RAILS_ENV == "development")'
|
4
|
+
else
|
5
|
+
puts 'W2Tags Hooked on Rails 2.3.2 & Up!'
|
6
|
+
class ReloadableTemplate < Template
|
7
|
+
W2TAGS = W2Tags::Parser.new
|
8
|
+
def mtime
|
9
|
+
src = filename.gsub(/\.erb$/,'.w2erb')
|
10
|
+
W2TAGS.parse_file(src,false,true)
|
11
|
+
File.mtime(filename)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
module Sinatra
|
2
|
+
if Sinatra::VERSION < '0.9'
|
3
|
+
if Sinatra::Application.default_options[:env] != :development
|
4
|
+
puts 'W2Tags Only RUN on (Sinatra::Application.default_options[:env] == :development)'
|
5
|
+
else
|
6
|
+
puts 'W2Tags Hooked on Sinatra < 0.9.x!'
|
7
|
+
|
8
|
+
module W2TagsHooked
|
9
|
+
W2TAGS = W2Tags::Parser.new
|
10
|
+
def read_template_file(renderer, template, options, scream = true)
|
11
|
+
path = File.join(
|
12
|
+
options[:views_directory] || Sinatra.application.options.views,
|
13
|
+
"#{template}.#{renderer}"
|
14
|
+
)
|
15
|
+
src = path.gsub(path[/(\.\w+)$/,1],'.w2'<<$1[1,9])
|
16
|
+
W2TAGS.parse_file(src,false,true)
|
17
|
+
super
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
class EventContext
|
22
|
+
include W2TagsHooked
|
23
|
+
end
|
24
|
+
end
|
25
|
+
elsif Sinatra::VERSION > '0.9'
|
26
|
+
|
27
|
+
if Sinatra::Application.environment != :development
|
28
|
+
puts 'W2Tags Only RUN on (Sinatra::Application.environment == :development)'
|
29
|
+
else
|
30
|
+
puts 'W2Tags Hooked on Sinatra > 0.9.x!'
|
31
|
+
|
32
|
+
module W2TagsHooked
|
33
|
+
W2TAGS = W2Tags::Parser.new
|
34
|
+
def lookup_template(engine, template, options={})
|
35
|
+
case template
|
36
|
+
when Symbol
|
37
|
+
path= template_path(engine, template, options)
|
38
|
+
src = path.gsub(path[/(\.\w+)$/,1],'.w2'<<$1[1,9])
|
39
|
+
W2TAGS.parse_file(src,false,true)
|
40
|
+
end
|
41
|
+
super
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
class Base
|
46
|
+
include W2TagsHooked
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
data/lib/w2tags.rb
ADDED
@@ -0,0 +1,100 @@
|
|
1
|
+
dir = File.dirname(__FILE__)
|
2
|
+
Dir["#{dir}/w2tags/block/*.rb"].each{|f|require f}
|
3
|
+
$LOAD_PATH << dir unless $LOAD_PATH.include?(dir)
|
4
|
+
|
5
|
+
# = W2TAGS (Way to Tags)
|
6
|
+
#
|
7
|
+
# W2TAGS is a shortcut of tags, macros, and it is very simple describer for HTML
|
8
|
+
# its not to become a replacement for inline tamplating engine, it best use for
|
9
|
+
# developement (sinatra / rails / merb) and the result is an "erb" file to be
|
10
|
+
# execute by erb or erubis (the fastest templating engine).
|
11
|
+
#
|
12
|
+
# It focus on how developer can code and generate dynamic content with
|
13
|
+
# DRY philosophy, easy to understand and in a very clean way.
|
14
|
+
#
|
15
|
+
# == Features
|
16
|
+
#
|
17
|
+
# * Mimics HAML syntax (inherit features define in HAML)
|
18
|
+
# * Extended syntax for Next Tag, Variable, Constanta
|
19
|
+
# * HOT file is patern for put in repetitif code and leter can be call it
|
20
|
+
# * HOT Variable interpolation, make it code really DRY
|
21
|
+
#
|
22
|
+
# == Using W2TAGS
|
23
|
+
#
|
24
|
+
# some of the guide are inside
|
25
|
+
# * README.rdoc
|
26
|
+
# * doc/W2TAGS.rdoc
|
27
|
+
# * doc/HAML.rdoc
|
28
|
+
# * doc/FAQ.rdoc
|
29
|
+
# * doc/HOT.rdoc
|
30
|
+
|
31
|
+
module W2Tags
|
32
|
+
Dir = File.dirname(__FILE__)
|
33
|
+
VERSION = File.read(Dir + '/../VERSION').strip unless defined?(VERSION)
|
34
|
+
|
35
|
+
#split string with aditional option escape charaters'\'
|
36
|
+
def self.splitter(data,deli=';')
|
37
|
+
tg_esc = data.split("\\"+deli)
|
38
|
+
if tg_esc.size > 1
|
39
|
+
tg_esc = tg_esc.collect {|x|x.split(deli)}
|
40
|
+
result = tg_esc.shift
|
41
|
+
while tg_esc != []
|
42
|
+
token = tg_esc[0]
|
43
|
+
result[-1,1] = result[-1,1][0] +';'+ token[0,1][0]
|
44
|
+
result = result + token[1,99]
|
45
|
+
tg_esc.shift
|
46
|
+
end
|
47
|
+
else
|
48
|
+
result = data.split(deli)
|
49
|
+
end
|
50
|
+
result
|
51
|
+
end
|
52
|
+
|
53
|
+
#hot files is a collection of w2tags function
|
54
|
+
#example of the function that will translate by this method
|
55
|
+
#
|
56
|
+
# >>body
|
57
|
+
# <body>
|
58
|
+
# <</
|
59
|
+
# </body>
|
60
|
+
#
|
61
|
+
#and example of use that function
|
62
|
+
# @body()
|
63
|
+
# @div!Hello Tags
|
64
|
+
# ./
|
65
|
+
#
|
66
|
+
#it will produce
|
67
|
+
# <body>
|
68
|
+
# <div>Hello Tags</div>
|
69
|
+
# </body>
|
70
|
+
def self.read_filehot(fhot)
|
71
|
+
hot_new = {}
|
72
|
+
hot = ("\n"+IO.read(fhot)).delete("\r").split(/\n\>\>/)
|
73
|
+
hot.shift
|
74
|
+
hot.each do |item|
|
75
|
+
item.gsub!(/\n([ \t]*)$/,'') #remove blank lines
|
76
|
+
ends = item.split(/\n\<\<\/[^\n]*\n/) #hots | ends
|
77
|
+
mems = ends[0].split(/\n\!~[^\n]*\n/) #hots | mems
|
78
|
+
khot = mems[0].split("\n") #key | hot
|
79
|
+
keys = khot.shift.rstrip #hots = mems[0].gsub(keys+"\n",'')
|
80
|
+
hots = khot.join("\n")
|
81
|
+
hot = [nil,nil]
|
82
|
+
hot[0]= proc do |this|
|
83
|
+
this.chg_mem_hot(mems[1]) if this!= nil
|
84
|
+
hots
|
85
|
+
end
|
86
|
+
if ends.size>1
|
87
|
+
hot[1] = [ends[1]]
|
88
|
+
# tend = splitter(ends[1])
|
89
|
+
# if tend.size==1
|
90
|
+
# hot[1] = [tend]
|
91
|
+
# else
|
92
|
+
# hot[1] = tend.collect {|x|"</#{x}>"}
|
93
|
+
# end
|
94
|
+
end
|
95
|
+
hot_new[keys] = hot
|
96
|
+
end
|
97
|
+
hot_new
|
98
|
+
end
|
99
|
+
end
|
100
|
+
require 'w2tags/parser'
|
@@ -0,0 +1,29 @@
|
|
1
|
+
Description:
|
2
|
+
Scaffolds an entire resource, from model and migration to controller and
|
3
|
+
views, along with a full test suite. The resource is ready to use as a
|
4
|
+
starting point for your RESTful, resource-oriented application.
|
5
|
+
|
6
|
+
Pass the name of the model (in singular form), either CamelCased or
|
7
|
+
under_scored, as the first argument, and an optional list of attribute
|
8
|
+
pairs.
|
9
|
+
|
10
|
+
Attribute pairs are column_name:sql_type arguments specifying the
|
11
|
+
model's attributes. Timestamps are added by default, so you don't have to
|
12
|
+
specify them by hand as 'created_at:datetime updated_at:datetime'.
|
13
|
+
|
14
|
+
You don't have to think up every attribute up front, but it helps to
|
15
|
+
sketch out a few so you can start working with the resource immediately.
|
16
|
+
|
17
|
+
For example, 'scaffold post title:string body:text published:boolean'
|
18
|
+
gives you a model with those three attributes, a controller that handles
|
19
|
+
the create/show/update/destroy, forms to create and edit your posts, and
|
20
|
+
an index that lists them all, as well as a map.resources :posts
|
21
|
+
declaration in config/routes.rb.
|
22
|
+
|
23
|
+
If you want to remove all the generated files, run
|
24
|
+
'script/destroy scaffold ModelName'.
|
25
|
+
|
26
|
+
Examples:
|
27
|
+
`./script/generate w2scaffold post`
|
28
|
+
`./script/generate w2scaffold post title:string body:text published:boolean`
|
29
|
+
`./script/generate w2scaffold purchase order_id:integer amount:decimal`
|
@@ -0,0 +1,85 @@
|
|
1
|
+
class <%= controller_class_name %>Controller < ApplicationController
|
2
|
+
# GET /<%= table_name %>
|
3
|
+
# GET /<%= table_name %>.xml
|
4
|
+
def index
|
5
|
+
@<%= table_name %> = <%= class_name %>.all
|
6
|
+
|
7
|
+
respond_to do |format|
|
8
|
+
format.html # index.html.erb
|
9
|
+
format.xml { render :xml => @<%= table_name %> }
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
# GET /<%= table_name %>/1
|
14
|
+
# GET /<%= table_name %>/1.xml
|
15
|
+
def show
|
16
|
+
@<%= file_name %> = <%= class_name %>.find(params[:id])
|
17
|
+
|
18
|
+
respond_to do |format|
|
19
|
+
format.html # show.html.erb
|
20
|
+
format.xml { render :xml => @<%= file_name %> }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
# GET /<%= table_name %>/new
|
25
|
+
# GET /<%= table_name %>/new.xml
|
26
|
+
def new
|
27
|
+
@<%= file_name %> = <%= class_name %>.new
|
28
|
+
|
29
|
+
respond_to do |format|
|
30
|
+
format.html # new.html.erb
|
31
|
+
format.xml { render :xml => @<%= file_name %> }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
# GET /<%= table_name %>/1/edit
|
36
|
+
def edit
|
37
|
+
@<%= file_name %> = <%= class_name %>.find(params[:id])
|
38
|
+
end
|
39
|
+
|
40
|
+
# POST /<%= table_name %>
|
41
|
+
# POST /<%= table_name %>.xml
|
42
|
+
def create
|
43
|
+
@<%= file_name %> = <%= class_name %>.new(params[:<%= file_name %>])
|
44
|
+
|
45
|
+
respond_to do |format|
|
46
|
+
if @<%= file_name %>.save
|
47
|
+
flash[:notice] = '<%= class_name %> was successfully created.'
|
48
|
+
format.html { redirect_to(@<%= file_name %>) }
|
49
|
+
format.xml { render :xml => @<%= file_name %>, :status => :created, :location => @<%= file_name %> }
|
50
|
+
else
|
51
|
+
format.html { render :action => "new" }
|
52
|
+
format.xml { render :xml => @<%= file_name %>.errors, :status => :unprocessable_entity }
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
# PUT /<%= table_name %>/1
|
58
|
+
# PUT /<%= table_name %>/1.xml
|
59
|
+
def update
|
60
|
+
@<%= file_name %> = <%= class_name %>.find(params[:id])
|
61
|
+
|
62
|
+
respond_to do |format|
|
63
|
+
if @<%= file_name %>.update_attributes(params[:<%= file_name %>])
|
64
|
+
flash[:notice] = '<%= class_name %> was successfully updated.'
|
65
|
+
format.html { redirect_to(@<%= file_name %>) }
|
66
|
+
format.xml { head :ok }
|
67
|
+
else
|
68
|
+
format.html { render :action => "edit" }
|
69
|
+
format.xml { render :xml => @<%= file_name %>.errors, :status => :unprocessable_entity }
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
# DELETE /<%= table_name %>/1
|
75
|
+
# DELETE /<%= table_name %>/1.xml
|
76
|
+
def destroy
|
77
|
+
@<%= file_name %> = <%= class_name %>.find(params[:id])
|
78
|
+
@<%= file_name %>.destroy
|
79
|
+
|
80
|
+
respond_to do |format|
|
81
|
+
format.html { redirect_to(<%= table_name %>_url) }
|
82
|
+
format.xml { head :ok }
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class <%= controller_class_name %>ControllerTest < ActionController::TestCase
|
4
|
+
test "should get index" do
|
5
|
+
get :index
|
6
|
+
assert_response :success
|
7
|
+
assert_not_nil assigns(:<%= table_name %>)
|
8
|
+
end
|
9
|
+
|
10
|
+
test "should get new" do
|
11
|
+
get :new
|
12
|
+
assert_response :success
|
13
|
+
end
|
14
|
+
|
15
|
+
test "should create <%= file_name %>" do
|
16
|
+
assert_difference('<%= class_name %>.count') do
|
17
|
+
post :create, :<%= file_name %> => { }
|
18
|
+
end
|
19
|
+
|
20
|
+
assert_redirected_to <%= file_name %>_path(assigns(:<%= file_name %>))
|
21
|
+
end
|
22
|
+
|
23
|
+
test "should show <%= file_name %>" do
|
24
|
+
get :show, :id => <%= table_name %>(:one).to_param
|
25
|
+
assert_response :success
|
26
|
+
end
|
27
|
+
|
28
|
+
test "should get edit" do
|
29
|
+
get :edit, :id => <%= table_name %>(:one).to_param
|
30
|
+
assert_response :success
|
31
|
+
end
|
32
|
+
|
33
|
+
test "should update <%= file_name %>" do
|
34
|
+
put :update, :id => <%= table_name %>(:one).to_param, :<%= file_name %> => { }
|
35
|
+
assert_redirected_to <%= file_name %>_path(assigns(:<%= file_name %>))
|
36
|
+
end
|
37
|
+
|
38
|
+
test "should destroy <%= file_name %>" do
|
39
|
+
assert_difference('<%= class_name %>.count', -1) do
|
40
|
+
delete :destroy, :id => <%= table_name %>(:one).to_param
|
41
|
+
end
|
42
|
+
|
43
|
+
assert_redirected_to <%= table_name %>_path
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
2
|
+
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
3
|
+
|
4
|
+
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
5
|
+
<head>
|
6
|
+
<meta http-equiv="content-type" content="text/html;charset=UTF-8" />
|
7
|
+
<title><%= controller_class_name %>: <%%= controller.action_name %></title>
|
8
|
+
<%%= stylesheet_link_tag 'scaffold' %>
|
9
|
+
</head>
|
10
|
+
<body>
|
11
|
+
|
12
|
+
<p style="color: green"><%%= flash[:notice] %></p>
|
13
|
+
|
14
|
+
<%%= yield %>
|
15
|
+
|
16
|
+
</body>
|
17
|
+
</html>
|
@@ -0,0 +1,54 @@
|
|
1
|
+
body { background-color: #fff; color: #333; }
|
2
|
+
|
3
|
+
body, p, ol, ul, td {
|
4
|
+
font-family: verdana, arial, helvetica, sans-serif;
|
5
|
+
font-size: 13px;
|
6
|
+
line-height: 18px;
|
7
|
+
}
|
8
|
+
|
9
|
+
pre {
|
10
|
+
background-color: #eee;
|
11
|
+
padding: 10px;
|
12
|
+
font-size: 11px;
|
13
|
+
}
|
14
|
+
|
15
|
+
a { color: #000; }
|
16
|
+
a:visited { color: #666; }
|
17
|
+
a:hover { color: #fff; background-color:#000; }
|
18
|
+
|
19
|
+
.fieldWithErrors {
|
20
|
+
padding: 2px;
|
21
|
+
background-color: red;
|
22
|
+
display: table;
|
23
|
+
}
|
24
|
+
|
25
|
+
#errorExplanation {
|
26
|
+
width: 400px;
|
27
|
+
border: 2px solid red;
|
28
|
+
padding: 7px;
|
29
|
+
padding-bottom: 12px;
|
30
|
+
margin-bottom: 20px;
|
31
|
+
background-color: #f0f0f0;
|
32
|
+
}
|
33
|
+
|
34
|
+
#errorExplanation h2 {
|
35
|
+
text-align: left;
|
36
|
+
font-weight: bold;
|
37
|
+
padding: 5px 5px 5px 15px;
|
38
|
+
font-size: 12px;
|
39
|
+
margin: -7px;
|
40
|
+
background-color: #c00;
|
41
|
+
color: #fff;
|
42
|
+
}
|
43
|
+
|
44
|
+
#errorExplanation p {
|
45
|
+
color: #333;
|
46
|
+
margin-bottom: 0;
|
47
|
+
padding: 5px;
|
48
|
+
}
|
49
|
+
|
50
|
+
#errorExplanation ul li {
|
51
|
+
font-size: 12px;
|
52
|
+
list-style: square;
|
53
|
+
}
|
54
|
+
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<h1>Editing <%= singular_name %></h1>
|
2
|
+
|
3
|
+
<%% form_for(@<%= singular_name %>) do |f| %>
|
4
|
+
<%%= f.error_messages %>
|
5
|
+
|
6
|
+
<% for attribute in attributes -%>
|
7
|
+
<p>
|
8
|
+
<%%= f.label :<%= attribute.name %> %><br />
|
9
|
+
<%%= f.<%= attribute.field_type %> :<%= attribute.name %> %>
|
10
|
+
</p>
|
11
|
+
<% end -%>
|
12
|
+
<p>
|
13
|
+
<%%= f.submit 'Update' %>
|
14
|
+
</p>
|
15
|
+
<%% end %>
|
16
|
+
|
17
|
+
<%%= link_to 'Show', @<%= singular_name %> %> |
|
18
|
+
<%%= link_to 'Back', <%= plural_name %>_path %>
|
@@ -0,0 +1,17 @@
|
|
1
|
+
%h1 Editing <%= singular_name %>
|
2
|
+
|
3
|
+
-- form_for(@<%= singular_name %>) do |f|
|
4
|
+
= f.error_messages
|
5
|
+
|
6
|
+
<% for attribute in attributes -%>
|
7
|
+
%p
|
8
|
+
= f.label :<%= attribute.name %>
|
9
|
+
%br
|
10
|
+
= f.<%= attribute.field_type %> :<%= attribute.name %>
|
11
|
+
<% end -%>
|
12
|
+
|
13
|
+
%p
|
14
|
+
= f.submit 'Update'
|
15
|
+
|
16
|
+
= link_to 'Show', @<%= singular_name %>
|
17
|
+
= link_to 'Back', <%= plural_name %>_path
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<h1>Listing <%= plural_name %></h1>
|
2
|
+
|
3
|
+
<table>
|
4
|
+
<tr>
|
5
|
+
<% for attribute in attributes -%>
|
6
|
+
<th><%= attribute.column.human_name %></th>
|
7
|
+
<% end -%>
|
8
|
+
</tr>
|
9
|
+
|
10
|
+
<%% @<%= plural_name %>.each do |<%= singular_name %>| %>
|
11
|
+
<tr>
|
12
|
+
<% for attribute in attributes -%>
|
13
|
+
<td><%%=h <%= singular_name %>.<%= attribute.name %> %></td>
|
14
|
+
<% end -%>
|
15
|
+
<td><%%= link_to 'Show', <%= singular_name %> %></td>
|
16
|
+
<td><%%= link_to 'Edit', edit_<%= singular_name %>_path(<%= singular_name %>) %></td>
|
17
|
+
<td><%%= link_to 'Destroy', <%= singular_name %>, :confirm => 'Are you sure?', :method => :delete %></td>
|
18
|
+
</tr>
|
19
|
+
<%% end %>
|
20
|
+
</table>
|
21
|
+
|
22
|
+
<br />
|
23
|
+
|
24
|
+
<%%= link_to 'New <%= singular_name %>', new_<%= singular_name %>_path %>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
!hot!scaffold
|
2
|
+
%h1 Listing <%= plural_name %>
|
3
|
+
&rec=<%= singular_name %>
|
4
|
+
&fld=<%= attributes.collect {|f|f.name}.join(";") %>
|
5
|
+
%table
|
6
|
+
%tr
|
7
|
+
-th &fld!
|
8
|
+
|
9
|
+
-each_tr @<%= plural_name %>;&rec!
|
10
|
+
-td= &fld!
|
11
|
+
-td_link_crud
|
12
|
+
%br
|
13
|
+
|
14
|
+
= link_to "New &rec!", new_&rec!_path
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<h1>New <%= singular_name %></h1>
|
2
|
+
|
3
|
+
<%% form_for(@<%= singular_name %>) do |f| %>
|
4
|
+
<%%= f.error_messages %>
|
5
|
+
|
6
|
+
<% for attribute in attributes -%>
|
7
|
+
<p>
|
8
|
+
<%%= f.label :<%= attribute.name %> %><br />
|
9
|
+
<%%= f.<%= attribute.field_type %> :<%= attribute.name %> %>
|
10
|
+
</p>
|
11
|
+
<% end -%>
|
12
|
+
<p>
|
13
|
+
<%%= f.submit 'Create' %>
|
14
|
+
</p>
|
15
|
+
<%% end %>
|
16
|
+
|
17
|
+
<%%= link_to 'Back', <%= plural_name %>_path %>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
%h1 New <%= singular_name %>
|
2
|
+
|
3
|
+
-- form_for(@<%= singular_name %>) do |f|
|
4
|
+
= f.error_messages
|
5
|
+
|
6
|
+
<% for attribute in attributes -%>
|
7
|
+
%p
|
8
|
+
= f.label :<%= attribute.name %>
|
9
|
+
%br
|
10
|
+
= f.<%= attribute.field_type %> :<%= attribute.name %>
|
11
|
+
<% end -%>
|
12
|
+
|
13
|
+
%p
|
14
|
+
= f.submit 'Create'
|
15
|
+
|
16
|
+
= link_to 'Back', <%= plural_name %>_path
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<% for attribute in attributes -%>
|
2
|
+
<p>
|
3
|
+
<b><%= attribute.column.human_name %>:</b>
|
4
|
+
<%%=h @<%= singular_name %>.<%= attribute.name %> %>
|
5
|
+
</p>
|
6
|
+
|
7
|
+
<% end -%>
|
8
|
+
|
9
|
+
<%%= link_to 'Edit', edit_<%= singular_name %>_path(@<%= singular_name %>) %> |
|
10
|
+
<%%= link_to 'Back', <%= plural_name %>_path %>
|
@@ -0,0 +1,9 @@
|
|
1
|
+
<% for attribute in attributes -%>
|
2
|
+
%p
|
3
|
+
%b <%= attribute.column.human_name %>:
|
4
|
+
= h @<%= singular_name %>.<%= attribute.name %>
|
5
|
+
|
6
|
+
<% end -%>
|
7
|
+
|
8
|
+
= link_to 'Edit', edit_<%= singular_name %>_path(@<%= singular_name %>)
|
9
|
+
= link_to 'Back', <%= plural_name %>_path
|
@@ -0,0 +1,106 @@
|
|
1
|
+
class W2scaffoldGenerator < Rails::Generator::NamedBase
|
2
|
+
default_options :skip_timestamps => false, :skip_migration => false, :force_plural => false
|
3
|
+
|
4
|
+
attr_reader :controller_name,
|
5
|
+
:controller_class_path,
|
6
|
+
:controller_file_path,
|
7
|
+
:controller_class_nesting,
|
8
|
+
:controller_class_nesting_depth,
|
9
|
+
:controller_class_name,
|
10
|
+
:controller_underscore_name,
|
11
|
+
:controller_singular_name,
|
12
|
+
:controller_plural_name
|
13
|
+
alias_method :controller_file_name, :controller_underscore_name
|
14
|
+
alias_method :controller_table_name, :controller_plural_name
|
15
|
+
|
16
|
+
def initialize(runtime_args, runtime_options = {})
|
17
|
+
super
|
18
|
+
|
19
|
+
if @name == @name.pluralize && !options[:force_plural]
|
20
|
+
logger.warning "Plural version of the model detected, using singularized version. Override with --force-plural."
|
21
|
+
@name = @name.singularize
|
22
|
+
end
|
23
|
+
|
24
|
+
@controller_name = @name.pluralize
|
25
|
+
|
26
|
+
base_name, @controller_class_path, @controller_file_path, @controller_class_nesting, @controller_class_nesting_depth = extract_modules(@controller_name)
|
27
|
+
@controller_class_name_without_nesting, @controller_underscore_name, @controller_plural_name = inflect_names(base_name)
|
28
|
+
@controller_singular_name=base_name.singularize
|
29
|
+
if @controller_class_nesting.empty?
|
30
|
+
@controller_class_name = @controller_class_name_without_nesting
|
31
|
+
else
|
32
|
+
@controller_class_name = "#{@controller_class_nesting}::#{@controller_class_name_without_nesting}"
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def manifest
|
37
|
+
record do |m|
|
38
|
+
# Check for class naming collisions.
|
39
|
+
m.class_collisions("#{controller_class_name}Controller", "#{controller_class_name}Helper")
|
40
|
+
m.class_collisions(class_name)
|
41
|
+
|
42
|
+
# Controller, helper, views, test and stylesheets directories.
|
43
|
+
m.directory(File.join('app/models', class_path))
|
44
|
+
m.directory(File.join('app/controllers', controller_class_path))
|
45
|
+
m.directory(File.join('app/helpers', controller_class_path))
|
46
|
+
m.directory(File.join('app/views', controller_class_path, controller_file_name))
|
47
|
+
m.directory(File.join('app/views/layouts', controller_class_path))
|
48
|
+
m.directory(File.join('test/functional', controller_class_path))
|
49
|
+
m.directory(File.join('test/unit', class_path))
|
50
|
+
m.directory(File.join('test/unit/helpers', class_path))
|
51
|
+
m.directory(File.join('public/stylesheets', class_path))
|
52
|
+
|
53
|
+
for action in scaffold_views
|
54
|
+
m.template(
|
55
|
+
"view_#{action}.html.erb",
|
56
|
+
File.join('app/views', controller_class_path, controller_file_name, "#{action}.html.erb")
|
57
|
+
)
|
58
|
+
m.template(
|
59
|
+
"view_#{action}.html.w2erb",
|
60
|
+
File.join('app/views', controller_class_path, controller_file_name, "#{action}.html.w2erb")
|
61
|
+
)
|
62
|
+
end
|
63
|
+
|
64
|
+
# Layout and stylesheet.
|
65
|
+
m.template('layout.html.erb', File.join('app/views/layouts', controller_class_path, "#{controller_file_name}.html.erb"))
|
66
|
+
m.template('style.css', 'public/stylesheets/scaffold.css')
|
67
|
+
|
68
|
+
m.template(
|
69
|
+
'controller.rb', File.join('app/controllers', controller_class_path, "#{controller_file_name}_controller.rb")
|
70
|
+
)
|
71
|
+
|
72
|
+
m.template('functional_test.rb', File.join('test/functional', controller_class_path, "#{controller_file_name}_controller_test.rb"))
|
73
|
+
m.template('helper.rb', File.join('app/helpers', controller_class_path, "#{controller_file_name}_helper.rb"))
|
74
|
+
m.template('helper_test.rb', File.join('test/unit/helpers', controller_class_path, "#{controller_file_name}_helper_test.rb"))
|
75
|
+
|
76
|
+
m.route_resources controller_file_name
|
77
|
+
|
78
|
+
m.dependency 'model', [name] + @args, :collision => :skip
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
protected
|
83
|
+
# Override with your own usage banner.
|
84
|
+
def banner
|
85
|
+
"Usage: #{$0} scaffold ModelName [field:type, field:type]"
|
86
|
+
end
|
87
|
+
|
88
|
+
def add_options!(opt)
|
89
|
+
opt.separator ''
|
90
|
+
opt.separator 'Options:'
|
91
|
+
opt.on("--skip-timestamps",
|
92
|
+
"Don't add timestamps to the migration file for this model") { |v| options[:skip_timestamps] = v }
|
93
|
+
opt.on("--skip-migration",
|
94
|
+
"Don't generate a migration file for this model") { |v| options[:skip_migration] = v }
|
95
|
+
opt.on("--force-plural",
|
96
|
+
"Forces the generation of a plural ModelName") { |v| options[:force_plural] = v }
|
97
|
+
end
|
98
|
+
|
99
|
+
def scaffold_views
|
100
|
+
%w[ index show new edit ]
|
101
|
+
end
|
102
|
+
|
103
|
+
def model_name
|
104
|
+
class_name.demodulize
|
105
|
+
end
|
106
|
+
end
|
@@ -0,0 +1 @@
|
|
1
|
+
puts IO.read(File.join(File.dirname(__FILE__), 'README'))
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
# $Id$
|
2
|
+
|
3
|
+
require File.expand_path(
|
4
|
+
File.join(File.dirname(__FILE__), %w[.. lib w2tags]))
|
5
|
+
|
6
|
+
Spec::Runner.configure do |config|
|
7
|
+
# == Mock Framework
|
8
|
+
#
|
9
|
+
# RSpec uses it's own mocking framework by default. If you prefer to
|
10
|
+
# use mocha, flexmock or RR, uncomment the appropriate line:
|
11
|
+
#
|
12
|
+
# config.mock_with :mocha
|
13
|
+
# config.mock_with :flexmock
|
14
|
+
# config.mock_with :rr
|
15
|
+
end
|
16
|
+
|
17
|
+
# EOF
|