Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
9476daa8
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,发现更多精彩内容 >>
提交
9476daa8
编写于
4月 22, 2010
作者:
J
José Valim
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Speed up xml serializer by computing values just once and remove unecessary code duplication.
上级
81fb7424
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
17 addition
and
29 deletion
+17
-29
activemodel/lib/active_model/serializers/xml.rb
activemodel/lib/active_model/serializers/xml.rb
+17
-18
activerecord/lib/active_record/serializers/xml_serializer.rb
activerecord/lib/active_record/serializers/xml_serializer.rb
+0
-11
未找到文件。
activemodel/lib/active_model/serializers/xml.rb
浏览文件 @
9476daa8
require
'active_support/core_ext/array/wrap'
require
'active_support/core_ext/class/attribute_accessors'
require
'active_support/core_ext/hash/conversions'
require
'active_support/core_ext/hash/slice'
module
ActiveModel
module
Serializers
...
...
@@ -12,8 +13,10 @@ class Serializer #:nodoc:
class
Attribute
#:nodoc:
attr_reader
:name
,
:value
,
:type
def
initialize
(
name
,
serializable
)
def
initialize
(
name
,
serializable
,
raw_value
=
nil
)
@name
,
@serializable
=
name
,
serializable
@raw_value
=
raw_value
||
@serializable
.
send
(
name
)
@type
=
compute_type
@value
=
compute_value
end
...
...
@@ -51,20 +54,17 @@ def decorations(include_types = true)
protected
def
compute_type
value
=
@serializable
.
send
(
name
)
type
=
Hash
::
XML_TYPE_NAMES
[
value
.
class
.
name
]
type
||=
:string
if
value
.
respond_to?
(
:to_str
)
type
=
Hash
::
XML_TYPE_NAMES
[
@raw_value
.
class
.
name
]
type
||=
:string
if
@raw_value
.
respond_to?
(
:to_str
)
type
||=
:yaml
type
end
def
compute_value
value
=
@serializable
.
send
(
name
)
if
formatter
=
Hash
::
XML_FORMATTING
[
type
.
to_s
]
value
?
formatter
.
call
(
value
)
:
nil
@raw_value
?
formatter
.
call
(
@raw_
value
)
:
nil
else
value
@raw_
value
end
end
end
...
...
@@ -72,7 +72,7 @@ def compute_value
class
MethodAttribute
<
Attribute
#:nodoc:
protected
def
compute_type
Hash
::
XML_TYPE_NAMES
[
@
serializable
.
send
(
name
)
.
class
.
name
]
||
:string
Hash
::
XML_TYPE_NAMES
[
@
raw_value
.
class
.
name
]
||
:string
end
end
...
...
@@ -92,25 +92,24 @@ def initialize(serializable, options = nil)
# then because <tt>:except</tt> is set to a default value, the second
# level model can have both <tt>:except</tt> and <tt>:only</tt> set. So if
# <tt>:only</tt> is set, always delete <tt>:except</tt>.
def
serializable_attribute_names
attribute_names
=
@serializable
.
attributes
.
keys
.
sort
def
serializable_attributes_hash
attributes
=
@serializable
.
attributes
if
options
[
:only
].
any?
attribute
_names
&=
options
[
:only
]
attribute
s
.
slice
(
*
options
[
:only
])
elsif
options
[
:except
].
any?
attribute_names
-=
options
[
:except
]
attributes
.
except
(
*
options
[
:except
])
else
attributes
end
attribute_names
end
def
serializable_attributes
serializable_attribute
_names
.
collect
{
|
name
|
Attribute
.
new
(
name
,
@serializabl
e
)
}
serializable_attribute
s_hash
.
map
{
|
name
,
value
|
self
.
class
::
Attribute
.
new
(
name
,
@serializable
,
valu
e
)
}
end
def
serializable_method_attributes
Array
.
wrap
(
options
[
:methods
]).
inject
([])
do
|
methods
,
name
|
methods
<<
MethodAttribute
.
new
(
name
.
to_s
,
@serializable
)
if
@serializable
.
respond_to?
(
name
.
to_s
)
methods
<<
self
.
class
::
MethodAttribute
.
new
(
name
.
to_s
,
@serializable
)
if
@serializable
.
respond_to?
(
name
.
to_s
)
methods
end
end
...
...
activerecord/lib/active_record/serializers/xml_serializer.rb
浏览文件 @
9476daa8
...
...
@@ -182,17 +182,6 @@ def initialize(*args)
options
[
:except
]
|=
Array
.
wrap
(
@serializable
.
class
.
inheritance_column
)
end
def
serializable_attributes
serializable_attribute_names
.
collect
{
|
name
|
Attribute
.
new
(
name
,
@serializable
)
}
end
def
serializable_method_attributes
Array
.
wrap
(
options
[
:methods
]).
inject
([])
do
|
method_attributes
,
name
|
method_attributes
<<
MethodAttribute
.
new
(
name
.
to_s
,
@serializable
)
if
@serializable
.
respond_to?
(
name
.
to_s
)
method_attributes
end
end
def
add_associations
(
association
,
records
,
opts
)
if
records
.
is_a?
(
Enumerable
)
tag
=
reformat_name
(
association
.
to_s
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录