Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
b77a7dcf
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
b77a7dcf
编写于
6月 30, 2009
作者:
J
José Valim
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Added controller named base.
上级
d5d0b8ea
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
56 addition
and
42 deletion
+56
-42
railties/lib/generators/named_base.rb
railties/lib/generators/named_base.rb
+50
-38
railties/lib/generators/rails/resource/resource_generator.rb
railties/lib/generators/rails/resource/resource_generator.rb
+3
-3
railties/lib/generators/rails/scaffold_controller/scaffold_controller_generator.rb
...ails/scaffold_controller/scaffold_controller_generator.rb
+3
-1
未找到文件。
railties/lib/generators/named_base.rb
浏览文件 @
b77a7dcf
...
@@ -7,49 +7,21 @@ class NamedBase < Base
...
@@ -7,49 +7,21 @@ class NamedBase < Base
argument
:name
,
:type
=>
:string
argument
:name
,
:type
=>
:string
attr_reader
:class_name
,
:singular_name
,
:plural_name
,
:table_name
,
attr_reader
:class_name
,
:singular_name
,
:plural_name
,
:table_name
,
:class_path
,
:file_path
,
:class_nesting
,
:class_nesting
_depth
:class_path
,
:file_path
,
:class_nesting_depth
alias
:file_name
:singular_name
alias
:file_name
:singular_name
class
<<
self
# Add a class collisions name to be checked on class initialization. You
# can supply a hash with a :prefix or :suffix to be tested.
#
# ==== Examples
#
# check_class_collision :suffix => "Observer"
#
# If the generator is invoked with class name Admin, it will check for
# the presence of "AdminObserver".
#
def
check_class_collision
(
options
=
{})
@class_collisions
=
options
end
# Returns the class collisions for this class and retreives one from
# superclass. The from_superclass method used below is from Thor.
#
def
class_collisions
#:nodoc:
@class_collisions
||=
from_superclass
(
:class_collisions
,
nil
)
end
end
def
initialize
(
*
args
)
#:nodoc:
def
initialize
(
*
args
)
#:nodoc:
super
super
assign_names!
(
self
.
name
)
assign_names!
(
self
.
name
)
parse_attributes!
if
respond_to?
(
:attributes
)
parse_attributes!
if
respond_to?
(
:attributes
)
if
self
.
class
.
class_collisions
value
=
add_prefix_and_suffix
(
class_name
,
self
.
class
.
class_collisions
)
class_collisions
(
value
)
end
end
end
protected
protected
def
assign_names!
(
given_name
)
#:nodoc:
def
assign_names!
(
given_name
)
#:nodoc:
self
.
name
,
@class_path
,
@file_path
,
@
class_nesting
,
@class_nesting_depth
=
extract_modules
(
given_name
)
base_name
,
@class_path
,
@file_path
,
class_nesting
,
@class_nesting_depth
=
extract_modules
(
given_name
)
@class_name_without_nesting
,
@singular_name
,
@plural_name
=
inflect_names
(
self
.
name
)
class_name_without_nesting
,
@singular_name
,
@plural_name
=
inflect_names
(
base_
name
)
@table_name
=
if
!
defined?
(
ActiveRecord
::
Base
)
||
ActiveRecord
::
Base
.
pluralize_table_names
@table_name
=
if
!
defined?
(
ActiveRecord
::
Base
)
||
ActiveRecord
::
Base
.
pluralize_table_names
plural_name
plural_name
...
@@ -58,11 +30,11 @@ def assign_names!(given_name) #:nodoc:
...
@@ -58,11 +30,11 @@ def assign_names!(given_name) #:nodoc:
end
end
@table_name
.
gsub!
'/'
,
'_'
@table_name
.
gsub!
'/'
,
'_'
if
@
class_nesting
.
empty?
if
class_nesting
.
empty?
@class_name
=
@
class_name_without_nesting
@class_name
=
class_name_without_nesting
else
else
@table_name
=
@
class_nesting
.
underscore
<<
"_"
<<
@table_name
@table_name
=
class_nesting
.
underscore
<<
"_"
<<
@table_name
@class_name
=
"
#{
@class_nesting
}
::
#{
@
class_name_without_nesting
}
"
@class_name
=
"
#{
class_nesting
}
::
#{
class_name_without_nesting
}
"
end
end
end
end
...
@@ -97,12 +69,52 @@ def inflect_names(name) #:nodoc:
...
@@ -97,12 +69,52 @@ def inflect_names(name) #:nodoc:
[
camel
,
under
,
plural
]
[
camel
,
under
,
plural
]
end
end
# Receives a name and add suffix and prefix values frrm hash.
# Add a class collisions name to be checked on class initialization. You
# can supply a hash with a :prefix or :suffix to be tested.
#
# ==== Examples
#
# check_class_collision :suffix => "Observer"
#
#
def
add_prefix_and_suffix
(
name
,
hash
)
#:nodoc:
# If the generator is invoked with class name Admin, it will check for
"
#{
hash
[
:prefix
]
}#{
name
}#{
hash
[
:suffix
]
}
"
# the presence of "AdminObserver".
#
def
self
.
check_class_collision
(
options
=
{})
define_method
:check_class_collision
do
name
=
if
self
.
respond_to?
(
:controller_class_name
)
# for ControllerNamedBase
controller_class_name
else
class_name
end
class_collisions
"
#{
options
[
:prefix
]
}#{
name
}#{
options
[
:suffix
]
}
"
end
end
end
end
# Deal with controller named base on scaffold
#
module
ControllerNamedBase
def
self
.
included
(
base
)
#:nodoc:
base
.
send
:attr_reader
,
:controller_name
,
:controller_class_name
,
:controller_file_name
end
# Set controller variables on initialization.
#
def
initialize
(
*
args
)
super
@controller_name
=
name
.
pluralize
base_name
,
class_path
,
file_path
,
class_nesting
,
class_nesting_depth
=
extract_modules
(
@controller_name
)
class_name_without_nesting
,
@controller_file_name
,
controller_plural_name
=
inflect_names
(
base_name
)
@controller_class_name
=
if
class_nesting
.
empty?
class_name_without_nesting
else
"
#{
class_nesting
}
::
#{
class_name_without_nesting
}
"
end
end
end
end
end
end
end
end
railties/lib/generators/rails/resource/resource_generator.rb
浏览文件 @
b77a7dcf
...
@@ -13,11 +13,11 @@ class ResourceGenerator < ModelGenerator #metagenerator
...
@@ -13,11 +13,11 @@ class ResourceGenerator < ModelGenerator #metagenerator
class_option
:singleton
,
:type
=>
:boolean
,
:desc
=>
"Supply to create a singleton controller"
class_option
:singleton
,
:type
=>
:boolean
,
:desc
=>
"Supply to create a singleton controller"
class_option
:force_plural
,
:type
=>
:boolean
,
:desc
=>
"Forces the use of a plural ModelName"
class_option
:force_plural
,
:type
=>
:boolean
,
:desc
=>
"Forces the use of a plural ModelName"
def
initialize
(
args
=
[],
options
=
{},
config
=
{}
)
def
initialize
(
*
args
)
super
super
if
args
[
0
]
==
args
[
0
].
pluralize
&&
!
self
.
options
[
:force_plural
]
if
name
==
name
.
pluralize
&&
!
options
[
:force_plural
]
say
"Plural version of the model detected, using singularized version. Override with --force-plural."
say
"Plural version of the model detected, using singularized version. Override with --force-plural."
args
[
0
]
=
args
[
0
]
.
singularize
name
.
replace
name
.
singularize
end
end
end
end
...
...
railties/lib/generators/rails/scaffold_controller/scaffold_controller_generator.rb
浏览文件 @
b77a7dcf
module
Rails
module
Rails
module
Generators
module
Generators
class
ScaffoldControllerGenerator
<
NamedBase
class
ScaffoldControllerGenerator
<
NamedBase
class_option
:singleton
,
:type
=>
:boolean
,
:desc
=>
"Supply to create a singleton controller"
include
ControllerNamedBase
check_class_collision
:suffix
=>
"Controller"
check_class_collision
:suffix
=>
"Controller"
class_option
:singleton
,
:type
=>
:boolean
,
:desc
=>
"Supply to create a singleton controller"
def
create_controller_files
def
create_controller_files
template
'controller.rb'
,
File
.
join
(
'app/controllers'
,
class_path
,
"
#{
file_name
}
_controller.rb"
)
template
'controller.rb'
,
File
.
join
(
'app/controllers'
,
class_path
,
"
#{
file_name
}
_controller.rb"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录