Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
010eda2e
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,发现更多精彩内容 >>
提交
010eda2e
编写于
7月 17, 2010
作者:
Ł
Łukasz Strzałkowski
提交者:
Aaron Patterson
7月 19, 2010
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Removed warnings about method redefining
上级
fc71d592
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
9 deletion
+24
-9
activerecord/lib/active_record/associations.rb
activerecord/lib/active_record/associations.rb
+24
-9
未找到文件。
activerecord/lib/active_record/associations.rb
浏览文件 @
010eda2e
...
...
@@ -1354,6 +1354,7 @@ def join_table_name(first_table_name, second_table_name)
end
def
association_accessor_methods
(
reflection
,
association_proxy_class
)
remove_possible_method
(
reflection
.
name
)
define_method
(
reflection
.
name
)
do
|*
params
|
force_reload
=
params
.
first
unless
params
.
empty?
association
=
association_instance_get
(
reflection
.
name
)
...
...
@@ -1371,12 +1372,16 @@ def association_accessor_methods(reflection, association_proxy_class)
association
.
target
.
nil?
?
nil
:
association
end
define_method
(
"loaded_
#{
reflection
.
name
}
?"
)
do
method
=
"loaded_
#{
reflection
.
name
}
?"
remove_possible_method
(
method
)
define_method
(
method
)
do
association
=
association_instance_get
(
reflection
.
name
)
association
&&
association
.
loaded?
end
define_method
(
"
#{
reflection
.
name
}
="
)
do
|
new_value
|
method
=
"
#{
reflection
.
name
}
="
remove_possible_method
(
method
)
define_method
(
method
)
do
|
new_value
|
association
=
association_instance_get
(
reflection
.
name
)
if
association
.
nil?
||
association
.
target
!=
new_value
...
...
@@ -1386,8 +1391,10 @@ def association_accessor_methods(reflection, association_proxy_class)
association
.
replace
(
new_value
)
association_instance_set
(
reflection
.
name
,
new_value
.
nil?
?
nil
:
association
)
end
define_method
(
"set_
#{
reflection
.
name
}
_target"
)
do
|
target
|
method
=
"set_
#{
reflection
.
name
}
_target"
remove_possible_method
(
method
)
define_method
(
method
)
do
|
target
|
return
if
target
.
nil?
and
association_proxy_class
==
BelongsToAssociation
association
=
association_proxy_class
.
new
(
self
,
reflection
)
association
.
target
=
target
...
...
@@ -1396,6 +1403,7 @@ def association_accessor_methods(reflection, association_proxy_class)
end
def
collection_reader_method
(
reflection
,
association_proxy_class
)
remove_possible_method
(
reflection
.
name
)
define_method
(
reflection
.
name
)
do
|*
params
|
force_reload
=
params
.
first
unless
params
.
empty?
association
=
association_instance_get
(
reflection
.
name
)
...
...
@@ -1409,8 +1417,10 @@ def collection_reader_method(reflection, association_proxy_class)
association
end
define_method
(
"
#{
reflection
.
name
.
to_s
.
singularize
}
_ids"
)
do
method
=
"
#{
reflection
.
name
.
to_s
.
singularize
}
_ids"
remove_possible_method
(
method
)
define_method
(
method
)
do
if
send
(
reflection
.
name
).
loaded?
||
reflection
.
options
[
:finder_sql
]
send
(
reflection
.
name
).
map
(
&
:id
)
else
...
...
@@ -1436,8 +1446,10 @@ def collection_accessor_methods(reflection, association_proxy_class, writer = tr
association
.
replace
(
new_value
)
association
end
define_method
(
"
#{
reflection
.
name
.
to_s
.
singularize
}
_ids="
)
do
|
new_value
|
method
=
"
#{
reflection
.
name
.
to_s
.
singularize
}
_ids="
remove_possible_method
(
method
)
define_method
(
method
)
do
|
new_value
|
ids
=
(
new_value
||
[]).
reject
{
|
nid
|
nid
.
blank?
}.
map
(
&
:to_i
)
send
(
"
#{
reflection
.
name
}
="
,
reflection
.
klass
.
find
(
ids
).
index_by
(
&
:id
).
values_at
(
*
ids
))
end
...
...
@@ -1445,7 +1457,9 @@ def collection_accessor_methods(reflection, association_proxy_class, writer = tr
end
def
association_constructor_method
(
constructor
,
reflection
,
association_proxy_class
)
define_method
(
"
#{
constructor
}
_
#{
reflection
.
name
}
"
)
do
|*
params
|
method
=
"
#{
constructor
}
_
#{
reflection
.
name
}
"
remove_possible_method
(
method
)
define_method
(
method
)
do
|*
params
|
attributees
=
params
.
first
unless
params
.
empty?
replace_existing
=
params
[
1
].
nil?
?
true
:
params
[
1
]
association
=
association_instance_get
(
reflection
.
name
)
...
...
@@ -1487,6 +1501,7 @@ def add_counter_cache_callbacks(reflection)
def
add_touch_callbacks
(
reflection
,
touch_attribute
)
method_name
=
"belongs_to_touch_after_save_or_destroy_for_
#{
reflection
.
name
}
"
.
to_sym
remove_possible_method
(
method_name
)
define_method
(
method_name
)
do
association
=
send
(
reflection
.
name
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录