Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
2b8750eb
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,发现更多精彩内容 >>
提交
2b8750eb
编写于
12月 28, 2008
作者:
M
Michael S. Klishin
浏览文件
操作
浏览文件
下载
差异文件
Sync with rails/rails/master, merge two metaprogramming annotation efforts
上级
e523b43e
0efec645
变更
34
隐藏空白更改
内联
并排
Showing
34 changed file
with
437 addition
and
285 deletion
+437
-285
actionpack/lib/action_controller/helpers.rb
actionpack/lib/action_controller/helpers.rb
+3
-3
actionpack/lib/action_controller/mime_responds.rb
actionpack/lib/action_controller/mime_responds.rb
+3
-3
actionpack/lib/action_controller/polymorphic_routes.rb
actionpack/lib/action_controller/polymorphic_routes.rb
+11
-7
actionpack/lib/action_controller/request.rb
actionpack/lib/action_controller/request.rb
+1
-1
actionpack/lib/action_controller/routing/route_set.rb
actionpack/lib/action_controller/routing/route_set.rb
+31
-30
actionpack/lib/action_controller/test_process.rb
actionpack/lib/action_controller/test_process.rb
+1
-5
actionpack/lib/action_view/helpers/form_helper.rb
actionpack/lib/action_view/helpers/form_helper.rb
+7
-3
actionpack/test/controller/rack_test.rb
actionpack/test/controller/rack_test.rb
+2
-2
activerecord/CHANGELOG
activerecord/CHANGELOG
+2
-0
activerecord/lib/active_record.rb
activerecord/lib/active_record.rb
+1
-0
activerecord/lib/active_record/associations.rb
activerecord/lib/active_record/associations.rb
+18
-18
activerecord/lib/active_record/base.rb
activerecord/lib/active_record/base.rb
+71
-2
activerecord/lib/active_record/connection_adapters/abstract/query_cache.rb
...active_record/connection_adapters/abstract/query_cache.rb
+6
-6
activerecord/lib/active_record/connection_adapters/abstract/schema_definitions.rb
...record/connection_adapters/abstract/schema_definitions.rb
+24
-24
activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
...rd/lib/active_record/connection_adapters/mysql_adapter.rb
+13
-11
activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
...b/active_record/connection_adapters/postgresql_adapter.rb
+7
-7
activerecord/lib/active_record/dirty.rb
activerecord/lib/active_record/dirty.rb
+1
-1
activerecord/lib/active_record/dynamic_scope_match.rb
activerecord/lib/active_record/dynamic_scope_match.rb
+25
-0
activerecord/test/cases/named_scope_test.rb
activerecord/test/cases/named_scope_test.rb
+20
-0
activeresource/lib/active_resource/http_mock.rb
activeresource/lib/active_resource/http_mock.rb
+8
-0
activesupport/lib/active_support/callbacks.rb
activesupport/lib/active_support/callbacks.rb
+18
-14
activesupport/lib/active_support/core_ext/class/attribute_accessors.rb
.../lib/active_support/core_ext/class/attribute_accessors.rb
+24
-24
activesupport/lib/active_support/core_ext/class/delegating_attributes.rb
...ib/active_support/core_ext/class/delegating_attributes.rb
+17
-16
activesupport/lib/active_support/core_ext/class/inheritable_attributes.rb
...b/active_support/core_ext/class/inheritable_attributes.rb
+27
-27
activesupport/lib/active_support/core_ext/logger.rb
activesupport/lib/active_support/core_ext/logger.rb
+6
-6
activesupport/lib/active_support/core_ext/module/aliasing.rb
activesupport/lib/active_support/core_ext/module/aliasing.rb
+3
-3
activesupport/lib/active_support/core_ext/module/attr_accessor_with_default.rb
...ive_support/core_ext/module/attr_accessor_with_default.rb
+4
-4
activesupport/lib/active_support/core_ext/module/attribute_accessors.rb
...lib/active_support/core_ext/module/attribute_accessors.rb
+24
-24
activesupport/lib/active_support/core_ext/module/delegation.rb
...esupport/lib/active_support/core_ext/module/delegation.rb
+3
-3
activesupport/lib/active_support/core_ext/module/synchronization.rb
...ort/lib/active_support/core_ext/module/synchronization.rb
+5
-5
activesupport/lib/active_support/deprecation.rb
activesupport/lib/active_support/deprecation.rb
+9
-6
activesupport/lib/active_support/memoizable.rb
activesupport/lib/active_support/memoizable.rb
+30
-28
railties/lib/rails_generator/generators/applications/app/template_runner.rb
..._generator/generators/applications/app/template_runner.rb
+11
-1
railties/test/generators/rails_template_runner_test.rb
railties/test/generators/rails_template_runner_test.rb
+1
-1
未找到文件。
actionpack/lib/action_controller/helpers.rb
浏览文件 @
2b8750eb
...
...
@@ -163,9 +163,9 @@ def helper(*args, &block)
def
helper_method
(
*
methods
)
methods
.
flatten
.
each
do
|
method
|
master_helper_module
.
module_eval
<<-
end_eval
def
#{
method
}
(*args, &block)
controller.send(%(
#{
method
}
), *args, &block)
end
def
#{
method
}
(*args, &block)
# def current_user(*args, &block)
controller.send(%(
#{
method
}
), *args, &block)
# controller.send(%(current_user), *args, &block)
end
# end
end_eval
end
end
...
...
actionpack/lib/action_controller/mime_responds.rb
浏览文件 @
2b8750eb
...
...
@@ -145,9 +145,9 @@ def self.generate_method_for_mime(mime)
sym
=
mime
.
is_a?
(
Symbol
)
?
mime
:
mime
.
to_sym
const
=
sym
.
to_s
.
upcase
class_eval
<<-
RUBY
,
__FILE__
,
__LINE__
+
1
def
#{
sym
}
(&block)
# def html(&block)
custom(Mime::
#{
const
}
, &block)
# custom(Mime::HTML, &block)
end
# end
def
#{
sym
}
(&block) # def html(&block)
custom(Mime::
#{
const
}
, &block) # custom(Mime::HTML, &block)
end # end
RUBY
end
...
...
actionpack/lib/action_controller/polymorphic_routes.rb
浏览文件 @
2b8750eb
...
...
@@ -118,13 +118,17 @@ def polymorphic_path(record_or_hash_or_array, options = {})
%w(edit new)
.
each
do
|
action
|
module_eval
<<-
EOT
,
__FILE__
,
__LINE__
def
#{
action
}
_polymorphic_url(record_or_hash, options = {})
polymorphic_url(record_or_hash, options.merge(:action => "
#{
action
}
"))
end
def
#{
action
}
_polymorphic_path(record_or_hash, options = {})
polymorphic_url(record_or_hash, options.merge(:action => "
#{
action
}
", :routing_type => :path))
end
def
#{
action
}
_polymorphic_url(record_or_hash, options = {}) # def edit_polymorphic_url(record_or_hash, options = {})
polymorphic_url( # polymorphic_url(
record_or_hash, # record_or_hash,
options.merge(:action => "
#{
action
}
")) # options.merge(:action => "edit"))
end # end
#
def
#{
action
}
_polymorphic_path(record_or_hash, options = {}) # def edit_polymorphic_path(record_or_hash, options = {})
polymorphic_url( # polymorphic_url(
record_or_hash, # record_or_hash,
options.merge(:action => "
#{
action
}
", :routing_type => :path)) # options.merge(:action => "edit", :routing_type => :path))
end # end
EOT
end
...
...
actionpack/lib/action_controller/request.rb
浏览文件 @
2b8750eb
...
...
@@ -295,7 +295,7 @@ def raw_host_with_port
if
forwarded
=
env
[
"HTTP_X_FORWARDED_HOST"
]
forwarded
.
split
(
/,\s?/
).
last
else
env
[
'HTTP_HOST'
]
||
env
[
'SERVER_NAME'
]
||
"
#{
env
[
'SERVER_ADDR'
]
}
:
#{
env
[
'SERVER_PORT'
]
}
"
env
[
'HTTP_HOST'
]
||
"
#{
env
[
'SERVER_NAME'
]
||
env
[
'SERVER_ADDR'
]
}
:
#{
env
[
'SERVER_PORT'
]
}
"
end
end
...
...
actionpack/lib/action_controller/routing/route_set.rb
浏览文件 @
2b8750eb
...
...
@@ -145,10 +145,10 @@ def named_helper_module_eval(code, *args)
def
define_hash_access
(
route
,
name
,
kind
,
options
)
selector
=
hash_access_name
(
name
,
kind
)
named_helper_module_eval
<<-
end_eval
# We use module_eval to avoid leaks
def
#{
selector
}
(options = nil)
options ?
#{
options
.
inspect
}
.merge(options) :
#{
options
.
inspect
}
end
protected :
#{
selector
}
def
#{
selector
}
(options = nil)
# def hash_for_users_url(options = nil)
options ?
#{
options
.
inspect
}
.merge(options) :
#{
options
.
inspect
}
# options ? {:only_path=>false}.merge(options) : {:only_path=>false}
end
# end
protected :
#{
selector
}
# protected :hash_for_users_url
end_eval
helpers
<<
selector
end
...
...
@@ -173,32 +173,33 @@ def define_url_helper(route, name, kind, options)
# foo_url(bar, baz, bang, :sort_by => 'baz')
#
named_helper_module_eval
<<-
end_eval
# We use module_eval to avoid leaks
def
#{
selector
}
(*args)
#{
generate_optimisation_block
(
route
,
kind
)
}
opts = if args.empty? || Hash === args.first
args.first || {}
else
options = args.extract_options!
args = args.zip(
#{
route
.
segment_keys
.
inspect
}
).inject({}) do |h, (v, k)|
h[k] = v
h
end
options.merge(args)
end
url_for(
#{
hash_access_method
}
(opts))
end
#Add an alias to support the now deprecated formatted_* URL.
def formatted_
#{
selector
}
(*args)
ActiveSupport::Deprecation.warn(
"formatted_
#{
selector
}
() has been deprecated. please pass format to the standard" +
"
#{
selector
}
() method instead.", caller)
#{
selector
}
(*args)
end
protected :
#{
selector
}
def
#{
selector
}
(*args) # def users_url(*args)
#
#{
generate_optimisation_block
(
route
,
kind
)
}
#
#{
generate_optimisation_block
(
route
,
kind
)
}
#
opts = if args.empty? || Hash === args.first # opts = if args.empty? || Hash === args.first
args.first || {} # args.first || {}
else # else
options = args.extract_options! # options = args.extract_options!
args = args.zip(
#{
route
.
segment_keys
.
inspect
}
).inject({}) do |h, (v, k)| # args = args.zip([]).inject({}) do |h, (v, k)|
h[k] = v # h[k] = v
h # h
end # end
options.merge(args) # options.merge(args)
end # end
#
url_for(
#{
hash_access_method
}
(opts)) # url_for(hash_for_users_url(opts))
#
end # end
#Add an alias to support the now deprecated formatted_* URL. # #Add an alias to support the now deprecated formatted_* URL.
def formatted_
#{
selector
}
(*args) # def formatted_users_url(*args)
ActiveSupport::Deprecation.warn( # ActiveSupport::Deprecation.warn(
"formatted_
#{
selector
}
() has been deprecated. " + # "formatted_users_url() has been deprecated. " +
"please pass format to the standard" + # "please pass format to the standard" +
"
#{
selector
}
() method instead.", caller) # "users_url() method instead.", caller)
#{
selector
}
(*args) # users_url(*args)
end # end
protected :
#{
selector
}
# protected :users_url
end_eval
helpers
<<
selector
end
...
...
actionpack/lib/action_controller/test_process.rb
浏览文件 @
2b8750eb
...
...
@@ -33,11 +33,7 @@ class TestRequest < Request #:nodoc:
attr_accessor
:host
def
initialize
env
=
Rack
::
MockRequest
.
env_for
(
"/"
)
# TODO: Fix Request to assume env['SERVER_ADDR'] doesn't contain port number
env
[
'SERVER_ADDR'
]
=
env
.
delete
(
"SERVER_NAME"
)
super
(
env
)
super
(
Rack
::
MockRequest
.
env_for
(
"/"
))
@query_parameters
=
{}
@session
=
TestSession
.
new
...
...
actionpack/lib/action_view/helpers/form_helper.rb
浏览文件 @
2b8750eb
...
...
@@ -737,9 +737,13 @@ def initialize(object_name, object, template, options, proc)
(
field_helpers
-
%w(label check_box radio_button fields_for)
).
each
do
|
selector
|
src
=
<<-
end_src
def
#{
selector
}
(method, options = {})
@template.send(
#{
selector
.
inspect
}
, @object_name, method, objectify_options(options))
end
def
#{
selector
}
(method, options = {}) # def text_field(method, options = {})
@template.send( # @template.send(
#{
selector
.
inspect
}
, # "text_field",
@object_name, # @object_name,
method, # method,
objectify_options(options)) # objectify_options(options))
end # end
end_src
class_eval
src
,
__FILE__
,
__LINE__
end
...
...
actionpack/test/controller/rack_test.rb
浏览文件 @
2b8750eb
...
...
@@ -4,7 +4,7 @@ class BaseRackTest < Test::Unit::TestCase
def
setup
@env
=
{
"HTTP_MAX_FORWARDS"
=>
"10"
,
"SERVER_NAME"
=>
"glu.ttono.us
:8007
"
,
"SERVER_NAME"
=>
"glu.ttono.us"
,
"FCGI_ROLE"
=>
"RESPONDER"
,
"AUTH_TYPE"
=>
"Basic"
,
"HTTP_X_FORWARDED_HOST"
=>
"glu.ttono.us"
,
...
...
@@ -145,7 +145,7 @@ def test_cgi_environment_variables
assert_equal
"kevin"
,
@request
.
remote_user
assert_equal
:get
,
@request
.
request_method
assert_equal
"/dispatch.fcgi"
,
@request
.
script_name
assert_equal
"glu.ttono.us
:8007
"
,
@request
.
server_name
assert_equal
"glu.ttono.us"
,
@request
.
server_name
assert_equal
8007
,
@request
.
server_port
assert_equal
"HTTP/1.1"
,
@request
.
server_protocol
assert_equal
"lighttpd"
,
@request
.
server_software
...
...
activerecord/CHANGELOG
浏览文件 @
2b8750eb
*2.3.0/3.0*
* Added dynamic scopes ala dynamic finders #1648 [Yaroslav Markin]
* Fixed that ActiveRecord::Base#new_record? should return false (not nil) for existing records #1219 [Yaroslav Markin]
* I18n the word separator for error messages. Introduces the activerecord.errors.format.separator translation key. #1294 [Akira Matsuda]
...
...
activerecord/lib/active_record.rb
浏览文件 @
2b8750eb
...
...
@@ -51,6 +51,7 @@ def self.load_all!
autoload
:Callbacks
,
'active_record/callbacks'
autoload
:Dirty
,
'active_record/dirty'
autoload
:DynamicFinderMatch
,
'active_record/dynamic_finder_match'
autoload
:DynamicScopeMatch
,
'active_record/dynamic_scope_match'
autoload
:Migration
,
'active_record/migration'
autoload
:Migrator
,
'active_record/migration'
autoload
:NamedScope
,
'active_record/named_scope'
...
...
activerecord/lib/active_record/associations.rb
浏览文件 @
2b8750eb
...
...
@@ -1216,11 +1216,11 @@ def has_and_belongs_to_many(association_id, options = {}, &extension)
# callbacks will be executed after the association is wiped out.
old_method
=
"destroy_without_habtm_shim_for_
#{
reflection
.
name
}
"
class_eval
<<-
end_eval
unless
method_defined?
(
old_method
)
alias_method :
#{
old_method
}
, :destroy_without_callbacks
def destroy_without_callbacks
#{
reflection
.
name
}
.clear
#{
old_method
}
end
alias_method :
#{
old_method
}
, :destroy_without_callbacks
# alias_method :destroy_without_habtm_shim_for_posts, :destroy_without_callbacks
def destroy_without_callbacks
# def destroy_without_callbacks
#{
reflection
.
name
}
.clear
# posts.clear
#{
old_method
}
# destroy_without_habtm_shim_for_posts
end
# end
end_eval
add_association_callbacks
(
reflection
.
name
,
options
)
...
...
@@ -1463,22 +1463,22 @@ def configure_dependency_for_has_many(reflection, extra_conditions = nil)
before_destroy
method_name
when
:delete_all
module_eval
%Q{
before_destroy do |record|
delete_all_has_many_dependencies(record,
"
#{
reflection
.
name
}
",
#{
reflection
.
class_name
}
,
%@
#{
dependent_conditions
}
@)
end
before_destroy do |record|
# before_destroy do |record|
delete_all_has_many_dependencies(record,
# delete_all_has_many_dependencies(record,
"
#{
reflection
.
name
}
",
# "posts",
#{
reflection
.
class_name
}
,
# Post,
%@
#{
dependent_conditions
}
@)
# %@...@) # this is a string literal like %(...)
end
# end
}
when
:nullify
module_eval
%Q{
before_destroy do |record|
nullify_has_many_dependencies(record,
"
#{
reflection
.
name
}
",
#{
reflection
.
class_name
}
,
"
#{
reflection
.
primary_key_name
}
",
%@
#{
dependent_conditions
}
@)
end
before_destroy do |record|
# before_destroy do |record|
nullify_has_many_dependencies(record,
# nullify_has_many_dependencies(record,
"
#{
reflection
.
name
}
",
# "posts",
#{
reflection
.
class_name
}
,
# Post,
"
#{
reflection
.
primary_key_name
}
",
# "user_id",
%@
#{
dependent_conditions
}
@)
# %@...@) # this is a string literal like %(...)
end
# end
}
else
raise
ArgumentError
,
"The :dependent option expects either :destroy, :delete_all, or :nullify (
#{
reflection
.
options
[
:dependent
].
inspect
}
)"
...
...
activerecord/lib/active_record/base.rb
浏览文件 @
2b8750eb
...
...
@@ -1456,7 +1456,10 @@ def abstract_class?
def
respond_to?
(
method_id
,
include_private
=
false
)
if
match
=
DynamicFinderMatch
.
match
(
method_id
)
return
true
if
all_attributes_exists?
(
match
.
attribute_names
)
elsif
match
=
DynamicScopeMatch
.
match
(
method_id
)
return
true
if
all_attributes_exists?
(
match
.
attribute_names
)
end
super
end
...
...
@@ -1809,7 +1812,11 @@ def undecorated_table_name(class_name = base_class.name)
# This also enables you to initialize a record if it is not found, such as find_or_initialize_by_amount(amount)
# or find_or_create_by_user_and_password(user, password).
#
# Each dynamic finder or initializer/creator is also defined in the class after it is first invoked, so that future
# Also enables dynamic scopes like scoped_by_user_name(user_name) and scoped_by_user_name_and_password(user_name, password) that
# are turned into scoped(:conditions => ["user_name = ?", user_name]) and scoped(:conditions => ["user_name = ? AND password = ?", user_name, password])
# respectively.
#
# Each dynamic finder, scope or initializer/creator is also defined in the class after it is first invoked, so that future
# attempts to use it do not run through method_missing.
def
method_missing
(
method_id
,
*
arguments
,
&
block
)
if
match
=
DynamicFinderMatch
.
match
(
method_id
)
...
...
@@ -1818,10 +1825,31 @@ def method_missing(method_id, *arguments, &block)
if
match
.
finder?
finder
=
match
.
finder
bang
=
match
.
bang?
# def self.find_by_login_and_activated(*args)
# options = args.extract_options!
# attributes = construct_attributes_from_arguments(
# [:login,:activated],
# args
# )
# finder_options = { :conditions => attributes }
# validate_find_options(options)
# set_readonly_option!(options)
#
# if options[:conditions]
# with_scope(:find => finder_options) do
# find(:first, options)
# end
# else
# find(:first, options.merge(finder_options))
# end
# end
self
.
class_eval
%{
def self.#{method_id}(*args)
options = args.extract_options!
attributes = construct_attributes_from_arguments([:#{attribute_names.join(',:')}], args)
attributes = construct_attributes_from_arguments(
[:#{attribute_names.join(',:')}],
args
)
finder_options = { :conditions => attributes }
validate_find_options(options)
set_readonly_option!(options)
...
...
@@ -1839,6 +1867,31 @@ def self.#{method_id}(*args)
send
(
method_id
,
*
arguments
)
elsif
match
.
instantiator?
instantiator
=
match
.
instantiator
# def self.find_or_create_by_user_id(*args)
# guard_protected_attributes = false
#
# if args[0].is_a?(Hash)
# guard_protected_attributes = true
# attributes = args[0].with_indifferent_access
# find_attributes = attributes.slice(*[:user_id])
# else
# find_attributes = attributes = construct_attributes_from_arguments([:user_id], args)
# end
#
# options = { :conditions => find_attributes }
# set_readonly_option!(options)
#
# record = find(:first, options)
#
# if record.nil?
# record = self.new { |r| r.send(:attributes=, attributes, guard_protected_attributes) }
# yield(record) if block_given?
# record.save
# record
# else
# record
# end
# end
self
.
class_eval
%{
def self.#{method_id}(*args)
guard_protected_attributes = false
...
...
@@ -1868,6 +1921,22 @@ def self.#{method_id}(*args)
}
,
__FILE__
,
__LINE__
send
(
method_id
,
*
arguments
,
&
block
)
end
elsif
match
=
DynamicScopeMatch
.
match
(
method_id
)
attribute_names
=
match
.
attribute_names
super
unless
all_attributes_exists?
(
attribute_names
)
if
match
.
scope?
self
.
class_eval
%{
def self.#{method_id}(*args) # def self.scoped_by_user_name_and_password(*args)
options = args.extract_options! # options = args.extract_options!
attributes = construct_attributes_from_arguments( # attributes = construct_attributes_from_arguments(
[:#{attribute_names.join(',:')}], args # [:user_name, :password], args
) # )
#
scoped(:conditions => attributes) # scoped(:conditions => attributes)
end # end
}
,
__FILE__
,
__LINE__
send
(
method_id
,
*
arguments
)
end
else
super
end
...
...
activerecord/lib/active_record/connection_adapters/abstract/query_cache.rb
浏览文件 @
2b8750eb
...
...
@@ -14,12 +14,12 @@ def included(base)
def
dirties_query_cache
(
base
,
*
method_names
)
method_names
.
each
do
|
method_name
|
base
.
class_eval
<<-
end_code
,
__FILE__
,
__LINE__
def
#{
method_name
}
_with_query_dirty(*args)
clear_query_cache if @query_cache_enabled
#{
method_name
}
_without_query_dirty(*args)
end
alias_method_chain :
#{
method_name
}
, :query_dirty
def
#{
method_name
}
_with_query_dirty(*args)
# def update_with_query_dirty(*args)
clear_query_cache if @query_cache_enabled
# clear_query_cache if @query_cache_enabled
#{
method_name
}
_without_query_dirty(*args)
# update_without_query_dirty(*args)
end
# end
#
alias_method_chain :
#{
method_name
}
, :query_dirty
# alias_method_chain :update, :query_dirty
end_code
end
end
...
...
activerecord/lib/active_record/connection_adapters/abstract/schema_definitions.rb
浏览文件 @
2b8750eb
...
...
@@ -476,12 +476,12 @@ def column(name, type, options = {})
%w( string text integer float decimal datetime timestamp time date binary boolean )
.
each
do
|
column_type
|
class_eval
<<-
EOV
def
#{
column_type
}
(*args)
options = args.extract_options!
column_names = args
column_names.each { |name| column(name, '
#{
column_type
}
', options) }
end
def
#{
column_type
}
(*args)
# def string(*args)
options = args.extract_options!
# options = args.extract_options!
column_names = args
# column_names = args
#
column_names.each { |name| column(name, '
#{
column_type
}
', options) }
# column_names.each { |name| column(name, 'string', options) }
end
# end
EOV
end
...
...
@@ -676,24 +676,24 @@ def remove_references(*args)
# t.string(:goat, :sheep)
%w( string text integer float decimal datetime timestamp time date binary boolean )
.
each
do
|
column_type
|
class_eval
<<-
EOV
def
#{
column_type
}
(*args)
options = args.extract_options!
column_names = args
column_names.each do |name|
column = ColumnDefinition.new(@base, name, '
#{
column_type
}
')
if options[:limit]
column.limit = options[:limit]
elsif native['
#{
column_type
}
'.to_sym].is_a?(Hash)
column.limit = native['
#{
column_type
}
'.to_sym][:limit]
end
column.precision = options[:precision]
column.scale = options[:scale]
column.default = options[:default]
column.null = options[:null]
@base.add_column(@table_name, name, column.sql_type, options)
end
end
def
#{
column_type
}
(*args)
# def string(*args)
options = args.extract_options!
# options = args.extract_options!
column_names = args
# column_names = args
#
column_names.each do |name|
# column_names.each do |name|
column = ColumnDefinition.new(@base, name, '
#{
column_type
}
')
# column = ColumnDefinition.new(@base, name, 'string')
if options[:limit]
# if options[:limit]
column.limit = options[:limit]
# column.limit = options[:limit]
elsif native['
#{
column_type
}
'.to_sym].is_a?(Hash)
# elsif native['string'.to_sym].is_a?(Hash)
column.limit = native['
#{
column_type
}
'.to_sym][:limit]
# column.limit = native['string'.to_sym][:limit]
end
# end
column.precision = options[:precision]
# column.precision = options[:precision]
column.scale = options[:scale]
# column.scale = options[:scale]
column.default = options[:default]
# column.default = options[:default]
column.null = options[:null]
# column.null = options[:null]
@base.add_column(@table_name, name, column.sql_type, options)
# @base.add_column(@table_name, name, column.sql_type, options)
end
# end
end
# end
EOV
end
...
...
activerecord/lib/active_record/connection_adapters/mysql_adapter.rb
浏览文件 @
2b8750eb
...
...
@@ -13,23 +13,25 @@ def self.define_all_hashes_method!
# C driver >= 2.7 returns null values in each_hash
if
Mysql
.
const_defined?
(
:VERSION
)
&&
(
Mysql
::
VERSION
.
is_a?
(
String
)
||
Mysql
::
VERSION
>=
20700
)
target
.
class_eval
<<-
'end_eval'
def all_hashes
rows = []
each_hash { |row| rows << row }
rows
end
def all_hashes
# def all_hashes
rows = []
# rows = []
each_hash { |row| rows << row }
# each_hash { |row| rows << row }
rows
# rows
end
# end
end_eval
# adapters before 2.7 don't have a version constant
# and don't return null values in each_hash
else
target
.
class_eval
<<-
'end_eval'
def all_hashes
rows = []
all_fields = fetch_fields.inject({}) { |fields, f| fields[f.name] = nil; fields }
each_hash { |row| rows << all_fields.dup.update(row) }
rows
end
def all_hashes # def all_hashes
rows = [] # rows = []
all_fields = fetch_fields.inject({}) { |fields, f| # all_fields = fetch_fields.inject({}) { |fields, f|
fields[f.name] = nil; fields # fields[f.name] = nil; fields
} # }
each_hash { |row| rows << all_fields.dup.update(row) } # each_hash { |row| rows << all_fields.dup.update(row) }
rows # rows
end # end
end_eval
end
...
...
activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
浏览文件 @
2b8750eb
...
...
@@ -950,13 +950,13 @@ def connect
# should know about this but can't detect it there, so deal with it here.
money_precision
=
(
postgresql_version
>=
80300
)
?
19
:
10
PostgreSQLColumn
.
module_eval
(
<<-
end_eval
)
def extract_precision(sql_type)
if sql_type =~ /^money$/
#{
money_precision
}
else
super
end
end
def extract_precision(sql_type)
# def extract_precision(sql_type)
if sql_type =~ /^money$/
# if sql_type =~ /^money$/
#{
money_precision
}
# 19
else
# else
super
# super
end
# end
end
# end
end_eval
configure_connection
...
...
activerecord/lib/active_record/dirty.rb
浏览文件 @
2b8750eb
...
...
@@ -174,7 +174,7 @@ def alias_attribute_with_dirty(new_name, old_name)
alias_attribute_without_dirty
(
new_name
,
old_name
)
DIRTY_SUFFIXES
.
each
do
|
suffix
|
module_eval
<<-
STR
,
__FILE__
,
__LINE__
+
1
def
#{
new_name
}#{
suffix
}
; self.
#{
old_name
}#{
suffix
}
; end
def
#{
new_name
}#{
suffix
}
; self.
#{
old_name
}#{
suffix
}
; end
# def subject_changed?; self.title_changed?; end
STR
end
end
...
...
activerecord/lib/active_record/dynamic_scope_match.rb
0 → 100644
浏览文件 @
2b8750eb
module
ActiveRecord
class
DynamicScopeMatch
def
self
.
match
(
method
)
ds_match
=
self
.
new
(
method
)
ds_match
.
scope
?
ds_match
:
nil
end
def
initialize
(
method
)
@scope
=
true
case
method
.
to_s
when
/^scoped_by_([_a-zA-Z]\w*)$/
names
=
$1
else
@scope
=
nil
end
@attribute_names
=
names
&&
names
.
split
(
'_and_'
)
end
attr_reader
:scope
,
:attribute_names
def
scope?
!
@scope
.
nil?
end
end
end
activerecord/test/cases/named_scope_test.rb
浏览文件 @
2b8750eb
...
...
@@ -278,3 +278,23 @@ def test_chaining_with_duplicate_joins
assert_equal
post
.
comments
.
size
,
Post
.
scoped
(
:joins
=>
join
).
scoped
(
:joins
=>
join
,
:conditions
=>
"posts.id =
#{
post
.
id
}
"
).
size
end
end
class
DynamicScopeMatchTest
<
ActiveRecord
::
TestCase
def
test_scoped_by_no_match
assert_nil
ActiveRecord
::
DynamicScopeMatch
.
match
(
"not_scoped_at_all"
)
end
def
test_scoped_by
match
=
ActiveRecord
::
DynamicScopeMatch
.
match
(
"scoped_by_age_and_sex_and_location"
)
assert_not_nil
match
assert
match
.
scope?
assert_equal
%w(age sex location)
,
match
.
attribute_names
end
end
class
DynamicScopeTest
<
ActiveRecord
::
TestCase
def
test_dynamic_scope
assert_equal
Post
.
scoped_by_author_id
(
1
).
find
(
1
),
Post
.
find
(
1
)
assert_equal
Post
.
scoped_by_author_id_and_title
(
1
,
"Welcome to the weblog"
).
first
,
Post
.
find
(
:first
,
:conditions
=>
{
:author_id
=>
1
,
:title
=>
"Welcome to the weblog"
})
end
end
activeresource/lib/active_resource/http_mock.rb
浏览文件 @
2b8750eb
...
...
@@ -54,6 +54,9 @@ def initialize(responses)
end
for
method
in
[
:post
,
:put
,
:get
,
:delete
,
:head
]
# def post(path, request_headers = {}, body = nil, status = 200, response_headers = {})
# @responses[Request.new(:post, path, nil, request_headers)] = Response.new(body || "", status, response_headers)
# end
module_eval
<<-
EOE
,
__FILE__
,
__LINE__
def
#{
method
}
(path, request_headers = {}, body = nil, status = 200, response_headers = {})
@responses[Request.new(:
#{
method
}
, path, nil, request_headers)] = Response.new(body || "", status, response_headers)
...
...
@@ -118,6 +121,11 @@ def reset!
end
for
method
in
[
:post
,
:put
]
# def post(path, body, headers)
# request = ActiveResource::Request.new(:post, path, body, headers)
# self.class.requests << request
# self.class.responses[request] || raise(InvalidRequestError.new("No response recorded for #{request}"))
# end
module_eval
<<-
EOE
,
__FILE__
,
__LINE__
def
#{
method
}
(path, body, headers)
request = ActiveResource::Request.new(:
#{
method
}
, path, body, headers)
...
...
activesupport/lib/active_support/callbacks.rb
浏览文件 @
2b8750eb
...
...
@@ -210,20 +210,24 @@ module ClassMethods
def
define_callbacks
(
*
callbacks
)
callbacks
.
each
do
|
callback
|
class_eval
<<-
"end_eval"
,
__FILE__
,
__LINE__
+
1
def self.
#{
callback
}
(*methods, &block) # def self.validate_on_create(*methods, &block)
callbacks = CallbackChain.build(:
#{
callback
}
, *methods, &block) # callbacks = CallbackChain.build(:validate_on_create, *methods, &block)
(@
#{
callback
}
_callbacks ||= CallbackChain.new).concat callbacks # (@validate_on_create_callbacks ||= CallbackChain.new).concat callbacks
end # end
def self.
#{
callback
}
_callback_chain # def self.validate_on_create_callback_chain
@
#{
callback
}
_callbacks ||= CallbackChain.new # @validate_on_create_callbacks ||= CallbackChain.new
#
if superclass.respond_to?(:
#{
callback
}
_callback_chain) # if superclass.respond_to?(:validate_on_create_callback_chain)
CallbackChain.new(superclass.
#{
callback
}
_callback_chain + @
#{
callback
}
_callbacks) # CallbackChain.new(superclass.validate_on_create_callback_chain + @validate_on_create_callbacks)
else # else
@
#{
callback
}
_callbacks # @validate_on_create_callbacks
end # end
end # end
def self.
#{
callback
}
(*methods, &block) # def self.before_save(*methods, &block)
callbacks = CallbackChain.build(:
#{
callback
}
, *methods, &block) # callbacks = CallbackChain.build(:before_save, *methods, &block)
@
#{
callback
}
_callbacks ||= CallbackChain.new # @before_save_callbacks ||= CallbackChain.new
@
#{
callback
}
_callbacks.concat callbacks # @before_save_callbacks.concat callbacks
end # end
#
def self.
#{
callback
}
_callback_chain # def self.before_save_callback_chain
@
#{
callback
}
_callbacks ||= CallbackChain.new # @before_save_callbacks ||= CallbackChain.new
#
if superclass.respond_to?(:
#{
callback
}
_callback_chain) # if superclass.respond_to?(:before_save_callback_chain)
CallbackChain.new( # CallbackChain.new(
superclass.
#{
callback
}
_callback_chain + # superclass.before_save_callback_chain +
@
#{
callback
}
_callbacks # @before_save_callbacks
) # )
else # else
@
#{
callback
}
_callbacks # @before_save_callbacks
end # end
end # end
end_eval
end
end
...
...
activesupport/lib/active_support/core_ext/class/attribute_accessors.rb
浏览文件 @
2b8750eb
...
...
@@ -11,17 +11,17 @@ def cattr_reader(*syms)
syms
.
flatten
.
each
do
|
sym
|
next
if
sym
.
is_a?
(
Hash
)
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
unless defined? @@
#{
sym
}
# unless defined @@property
@@
#{
sym
}
= nil
# @@property
= nil
end
# end
def self.
#{
sym
}
# def self.property
@@
#{
sym
}
# @@property
end
# end
def
#{
sym
}
# def property
@@
#{
sym
}
# @@property
end
# end
unless defined? @@
#{
sym
}
# unless defined? @@hair_colors
@@
#{
sym
}
= nil
# @@hair_colors
= nil
end # end
#
def self.
#{
sym
}
# def self.hair_colors
@@
#{
sym
}
# @@hair_colors
end # end
#
def
#{
sym
}
# def hair_colors
@@
#{
sym
}
# @@hair_colors
end # end
EOS
end
end
...
...
@@ -30,19 +30,19 @@ def cattr_writer(*syms)
options
=
syms
.
extract_options!
syms
.
flatten
.
each
do
|
sym
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
unless defined? @@
#{
sym
}
# unless defined? @@property
@@
#{
sym
}
= nil
# @@property
= nil
end # end
def self.
#{
sym
}
=(obj)
# def self.property
=(obj)
@@
#{
sym
}
= obj
# @@property
end # end
#{
"
def
#{
sym
}
=(obj)
# def property
=(obj)
@@
#{
sym
}
= obj
# @@property
= obj
end # end
"
unless
options
[
:instance_writer
]
==
false
}
unless defined? @@
#{
sym
}
# unless defined? @@hair_colors
@@
#{
sym
}
= nil
# @@hair_colors
= nil
end
# end
#
def self.
#{
sym
}
=(obj)
# def self.hair_colors
=(obj)
@@
#{
sym
}
= obj
# @@hair_colors = obj
end
# end
#
#{
"
#
def
#{
sym
}
=(obj)
# def hair_colors
=(obj)
@@
#{
sym
}
= obj
# @@hair_colors
= obj
end
# end
"
unless
options
[
:instance_writer
]
==
false
}
# # instance writer above is generated unless options[:instance_writer] == false
EOS
end
end
...
...
activesupport/lib/active_support/core_ext/class/delegating_attributes.rb
浏览文件 @
2b8750eb
...
...
@@ -9,22 +9,23 @@ def superclass_delegating_reader(*names)
class_name_to_stop_searching_on
=
self
.
superclass
.
name
.
blank?
?
"Object"
:
self
.
superclass
.
name
names
.
each
do
|
name
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
def self.
#{
name
}
# def self.property
if defined?(@
#{
name
}
) # if defined?(@property)
@
#{
name
}
# @property
elsif superclass <
#{
class_name_to_stop_searching_on
}
&& superclass.respond_to?(:
#{
name
}
) # elseif superclass < Object && superclass.respond_to?(:property)
superclass.
#{
name
}
# superclass.property
end # end
end # end
def
#{
name
}
# def property
self.class.
#{
name
}
# self.class.property
end # end
def self.
#{
name
}
? # def self.property?
!!
#{
name
}
# !!property
end # end
def
#{
name
}
? # def property?
!!
#{
name
}
# !!property
end # end
def self.
#{
name
}
# def self.only_reader
if defined?(@
#{
name
}
) # if defined?(@only_reader)
@
#{
name
}
# @only_reader
elsif superclass <
#{
class_name_to_stop_searching_on
}
&& # elsif superclass < Object &&
superclass.respond_to?(:
#{
name
}
) # superclass.respond_to?(:only_reader)
superclass.
#{
name
}
# superclass.only_reader
end # end
end # end
def
#{
name
}
# def only_reader
self.class.
#{
name
}
# self.class.only_reader
end # end
def self.
#{
name
}
? # def self.only_reader?
!!
#{
name
}
# !!only_reader
end # end
def
#{
name
}
? # def only_reader?
!!
#{
name
}
# !!only_reader
end # end
EOS
end
end
...
...
activesupport/lib/active_support/core_ext/class/inheritable_attributes.rb
浏览文件 @
2b8750eb
...
...
@@ -26,15 +26,15 @@ def class_inheritable_writer(*syms)
options
=
syms
.
extract_options!
syms
.
each
do
|
sym
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
def self.
#{
sym
}
=(obj)
# def self.property
=(obj)
write_inheritable_attribute(:
#{
sym
}
, obj)
# write_inheritable_attribute(:property
, obj)
end # end
#{
"
def
#{
sym
}
=(obj)
# def property
=(obj)
self.class.
#{
sym
}
= obj
# self.class.property
= obj
end # end
"
unless
options
[
:instance_writer
]
==
false
}
def self.
#{
sym
}
=(obj)
# def self.color
=(obj)
write_inheritable_attribute(:
#{
sym
}
, obj)
# write_inheritable_attribute(:color
, obj)
end
# end
#
#{
"
#
def
#{
sym
}
=(obj)
# def color
=(obj)
self.class.
#{
sym
}
= obj
# self.class.color
= obj
end
# end
"
unless
options
[
:instance_writer
]
==
false
}
# # the writer above is generated unless options[:instance_writer] == false
EOS
end
end
...
...
@@ -43,15 +43,15 @@ def class_inheritable_array_writer(*syms)
options
=
syms
.
extract_options!
syms
.
each
do
|
sym
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
def self.
#{
sym
}
=(obj)
# def self.property
=(obj)
write_inheritable_array(:
#{
sym
}
, obj)
# write_inheritable_array(:property
, obj)
end # end
#{
"
def
#{
sym
}
=(obj)
# def property
=(obj)
self.class.
#{
sym
}
= obj
# self.class.property
= obj
end # end
"
unless
options
[
:instance_writer
]
==
false
}
def self.
#{
sym
}
=(obj)
# def self.levels
=(obj)
write_inheritable_array(:
#{
sym
}
, obj)
# write_inheritable_array(:levels
, obj)
end
# end
#
#{
"
#
def
#{
sym
}
=(obj)
# def levels
=(obj)
self.class.
#{
sym
}
= obj
# self.class.levels
= obj
end
# end
"
unless
options
[
:instance_writer
]
==
false
}
# # the writer above is generated unless options[:instance_writer] == false
EOS
end
end
...
...
@@ -60,15 +60,15 @@ def class_inheritable_hash_writer(*syms)
options
=
syms
.
extract_options!
syms
.
each
do
|
sym
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
def self.
#{
sym
}
=(obj)
# def self.property
=(obj)
write_inheritable_hash(:
#{
sym
}
, obj)
# write_inheritable_hash(:property
, obj)
end # end
#{
"
def
#{
sym
}
=(obj)
# def property
=(obj)
self.class.
#{
sym
}
= obj
# self.class.property
= obj
end # end
"
unless
options
[
:instance_writer
]
==
false
}
def self.
#{
sym
}
=(obj)
# def self.nicknames
=(obj)
write_inheritable_hash(:
#{
sym
}
, obj)
# write_inheritable_hash(:nicknames
, obj)
end
# end
#
#{
"
#
def
#{
sym
}
=(obj)
# def nicknames
=(obj)
self.class.
#{
sym
}
= obj
# self.class.nicknames
= obj
end
# end
"
unless
options
[
:instance_writer
]
==
false
}
# # the writer above is generated unless options[:instance_writer] == false
EOS
end
end
...
...
activesupport/lib/active_support/core_ext/logger.rb
浏览文件 @
2b8750eb
...
...
@@ -3,12 +3,12 @@
class
Logger
def
self
.
define_around_helper
(
level
)
module_eval
<<-
end_eval
def around_
#{
level
}
(before_message, after_message, &block)
self.
#{
level
}
(before_message)
return_value = block.call(self)
self.
#{
level
}
(after_message)
return return_value
end
def around_
#{
level
}
(before_message, after_message, &block)
# def around_debug(before_message, after_message, &block)
self.
#{
level
}
(before_message)
# self.debug(before_message)
return_value = block.call(self)
# return_value = block.call(self)
self.
#{
level
}
(after_message)
# self.debug(after_message)
return return_value
# return return_value
end
# end
end_eval
end
[
:debug
,
:info
,
:error
,
:fatal
].
each
{
|
level
|
define_around_helper
(
level
)
}
...
...
activesupport/lib/active_support/core_ext/module/aliasing.rb
浏览文件 @
2b8750eb
...
...
@@ -64,9 +64,9 @@ def alias_method_chain(target, feature)
# e.title # => "Megastars"
def
alias_attribute
(
new_name
,
old_name
)
module_eval
<<-
STR
,
__FILE__
,
__LINE__
+
1
def
#{
new_name
}
; self.
#{
old_name
}
; end
def
#{
new_name
}
?; self.
#{
old_name
}
?; end
def
#{
new_name
}
=(v); self.
#{
old_name
}
= v; end
def
#{
new_name
}
; self.
#{
old_name
}
; end
# def subject; self.title; end
def
#{
new_name
}
?; self.
#{
old_name
}
?; end
# def subject?; self.title?; end
def
#{
new_name
}
=(v); self.
#{
old_name
}
= v; end
# def subject=(v); self.title = v; end
STR
end
end
...
...
activesupport/lib/active_support/core_ext/module/attr_accessor_with_default.rb
浏览文件 @
2b8750eb
...
...
@@ -22,10 +22,10 @@ def attr_accessor_with_default(sym, default = nil, &block)
raise
'Default value or block required'
unless
!
default
.
nil?
||
block
define_method
(
sym
,
block_given?
?
block
:
Proc
.
new
{
default
})
module_eval
(
<<-
EVAL
,
__FILE__
,
__LINE__
)
def
#{
sym
}
=(value)
class << self; attr_reader :
#{
sym
}
end
@
#{
sym
}
= value
end
def
#{
sym
}
=(value)
# def age=(value)
class << self; attr_reader :
#{
sym
}
end
# class << self; attr_reader :age end
@
#{
sym
}
= value
# @age = value
end
# end
EVAL
end
end
activesupport/lib/active_support/core_ext/module/attribute_accessors.rb
浏览文件 @
2b8750eb
...
...
@@ -15,17 +15,17 @@ def mattr_reader(*syms)
syms
.
each
do
|
sym
|
next
if
sym
.
is_a?
(
Hash
)
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
unless defined? @@
#{
sym
}
# unless defined? @@property
@@
#{
sym
}
= nil
# @@ property
= nil
end # end
def self.
#{
sym
}
# def self.property
@@
#{
sym
}
# @@property
end # end
def
#{
sym
}
# def property
@@
#{
sym
}
# @@property
end # end
unless defined? @@
#{
sym
}
# unless defined? @@pagination_options
@@
#{
sym
}
= nil
# @@pagination_options
= nil
end
# end
#
def self.
#{
sym
}
# def self.pagination_options
@@
#{
sym
}
# @@pagination_options
end
# end
#
def
#{
sym
}
# def pagination_options
@@
#{
sym
}
# @@pagination_options
end
# end
EOS
end
end
...
...
@@ -34,19 +34,19 @@ def mattr_writer(*syms)
options
=
syms
.
extract_options!
syms
.
each
do
|
sym
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
unless defined? @@
#{
sym
}
# unless defined? @@property
@@
#{
sym
}
= nil
# @@ property
= nil
end # end
def self.
#{
sym
}
=(obj)
# def self.property
=(obj)
@@
#{
sym
}
= obj
# @@property
= obj
end # end
#{
"
def
#{
sym
}
=(obj)
# def property
=(obj)
@@
#{
sym
}
= obj
# @@property
= obj
end # end
"
unless
options
[
:instance_writer
]
==
false
}
unless defined? @@
#{
sym
}
# unless defined? @@pagination_options
@@
#{
sym
}
= nil
# @@pagination_options
= nil
end
# end
#
def self.
#{
sym
}
=(obj)
# def self.pagination_options
=(obj)
@@
#{
sym
}
= obj
# @@pagination_options
= obj
end
# end
#
#{
"
#
def
#{
sym
}
=(obj)
# def pagination_options
=(obj)
@@
#{
sym
}
= obj
# @@pagination_options
= obj
end
# end
"
unless
options
[
:instance_writer
]
==
false
}
# # instance writer above is generated unless options[:instance_writer] == false
EOS
end
end
...
...
activesupport/lib/active_support/core_ext/module/delegation.rb
浏览文件 @
2b8750eb
...
...
@@ -112,9 +112,9 @@ def delegate(*methods)
methods
.
each
do
|
method
|
module_eval
(
<<-
EOS
,
"(__DELEGATION__)"
,
1
)
def
#{
prefix
}#{
method
}
(*args, &block)
#{
allow_nil
}#{
to
}
.__send__(
#{
method
.
inspect
}
, *args, &block)
end
def
#{
prefix
}#{
method
}
(*args, &block)
# def customer_name(*args, &block)
#{
allow_nil
}#{
to
}
.__send__(
#{
method
.
inspect
}
, *args, &block)
# client && client.__send__(:name, *args, &block)
end
# end
EOS
end
end
...
...
activesupport/lib/active_support/core_ext/module/synchronization.rb
浏览文件 @
2b8750eb
...
...
@@ -26,11 +26,11 @@ def synchronize(*methods)
end
module_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
)
def
#{
aliased_method
}
_with_synchronization
#{
punctuation
}
(*args, &block)
#{
with
}
.synchronize do
#{
aliased_method
}
_without_synchronization
#{
punctuation
}
(*args, &block)
end
end
def
#{
aliased_method
}
_with_synchronization
#{
punctuation
}
(*args, &block)
# def expire_with_synchronization(*args, &block)
#{
with
}
.synchronize do
# @@lock.synchronize do
#{
aliased_method
}
_without_synchronization
#{
punctuation
}
(*args, &block)
# expire_without_synchronization(*args, &block)
end
# end
end
# end
EOS
alias_method_chain
method
,
:synchronization
...
...
activesupport/lib/active_support/deprecation.rb
浏览文件 @
2b8750eb
...
...
@@ -90,12 +90,15 @@ def deprecate(*method_names)
method_names
.
each
do
|
method_name
|
alias_method_chain
(
method_name
,
:deprecation
)
do
|
target
,
punctuation
|
class_eval
(
<<-
EOS
,
__FILE__
,
__LINE__
+
1
)
def
#{
target
}
_with_deprecation
#{
punctuation
}
(*args, &block) # def multi_with_reprecation(*args, &block)
::ActiveSupport::Deprecation.warn( # ::ActiveSupport::Deprecation.warn(
self.class.deprecated_method_warning(:
#{
method_name
}
,
#{
options
[
method_name
].
inspect
}
), # self.class.deprecated_method_warning(:multi, "this method is deprecated, blah, blah, blah")
caller) # caller)
#{
target
}
_without_deprecation
#{
punctuation
}
(*args, &block) # multi_without_deprecation(*args, &block)
end # end
def
#{
target
}
_with_deprecation
#{
punctuation
}
(*args, &block) # def generate_secret_with_deprecation(*args, &block)
::ActiveSupport::Deprecation.warn( # ::ActiveSupport::Deprecation.warn(
self.class.deprecated_method_warning( # self.class.deprecated_method_warning(
:
#{
method_name
}
, # :generate_secret,
#{
options
[
method_name
].
inspect
}
), # "You should use ActiveSupport::SecureRandom.hex(64)"),
caller # caller
) # )
#{
target
}
_without_deprecation
#{
punctuation
}
(*args, &block) # generate_secret_without_deprecation(*args, &block)
end # end
EOS
end
end
...
...
activesupport/lib/active_support/memoizable.rb
浏览文件 @
2b8750eb
...
...
@@ -59,34 +59,36 @@ def memoize(*symbols)
memoized_ivar
=
ActiveSupport
::
Memoizable
.
memoized_ivar_for
(
symbol
)
class_eval
<<-
EOS
,
__FILE__
,
__LINE__
+
1
include InstanceMethods
raise "Already memoized
#{
symbol
}
" if method_defined?(:
#{
original_method
}
) # raise "Already memoized if_modified_since" if method_defined?(:__unmemoized_if_modified_since)
alias
#{
original_method
}
#{
symbol
}
# alias __unmemoized_if_modified_since if_modified_since
if instance_method(:
#{
symbol
}
).arity == 0 # if instance_method(:if_modified_since).arity == 0
def
#{
symbol
}
(reload = false) # def if_modified_since(reload = false)
if reload || !defined?(
#{
memoized_ivar
}
) ||
#{
memoized_ivar
}
.empty? # if reload || !defined?(@_memoized_if_modified_since) || @_memoized_if_modified_since.empty?
#{
memoized_ivar
}
= [
#{
original_method
}
.freeze] # @_memoized_if_modified_since = [__unmemoized_if_modified_since.freeze]
end # end
#{
memoized_ivar
}
[0] # @_memoized_if_modified_since[0]
end # end
else # else
def
#{
symbol
}
(*args) # def if_modified_since(*args)
#{
memoized_ivar
}
||= {} unless frozen? # @_memoized_if_modified_since ||= {} unless frozen?
reload = args.pop if args.last == true || args.last == :reload # reload = args.pop if args.last == true || args.last == :reload
#
if defined?(
#{
memoized_ivar
}
) &&
#{
memoized_ivar
}
# if defined?(@_memoized_if_modified_since) && @_memoized_if_modified_since
if !reload &&
#{
memoized_ivar
}
.has_key?(args) # if !reload && @_memoized_if_modified_since.has_key?(args)
#{
memoized_ivar
}
[args] # @_memoized_if_modified_since[args]
elsif
#{
memoized_ivar
}
# elsif @_memoized_if_modified_since
#{
memoized_ivar
}
[args] =
#{
original_method
}
(*args).freeze # @_memoized_if_modified_since[args] = __unmemoized_if_modified_since(*args).freeze
end # end
else # else
#{
original_method
}
(*args) # __unmemoized_if_modified_since(*args)
end # end
end # end
end # end
include InstanceMethods # include InstanceMethods
#
if method_defined?(:
#{
original_method
}
) # if method_defined?(:_unmemoized_mime_type)
raise "Already memoized
#{
symbol
}
" # raise "Already memoized mime_type"
end # end
alias
#{
original_method
}
#{
symbol
}
# alias _unmemoized_mime_type mime_type
#
if instance_method(:
#{
symbol
}
).arity == 0 # if instance_method(:mime_type).arity == 0
def
#{
symbol
}
(reload = false) # def mime_type(reload = false)
if reload || !defined?(
#{
memoized_ivar
}
) ||
#{
memoized_ivar
}
.empty? # if reload || !defined?(@_memoized_mime_type) || @_memoized_mime_type.empty?
#{
memoized_ivar
}
= [
#{
original_method
}
.freeze] # @_memoized_mime_type = [_unmemoized_mime_type.freeze]
end # end
#{
memoized_ivar
}
[0] # @_memoized_mime_type[0]
end # end
else # else
def
#{
symbol
}
(*args) # def mime_type(*args)
#{
memoized_ivar
}
||= {} unless frozen? # @_memoized_mime_type ||= {} unless frozen?
reload = args.pop if args.last == true || args.last == :reload # reload = args.pop if args.last == true || args.last == :reload
#
if defined?(
#{
memoized_ivar
}
) &&
#{
memoized_ivar
}
# if defined?(@_memoized_mime_type) && @_memoized_mime_type
if !reload &&
#{
memoized_ivar
}
.has_key?(args) # if !reload && @_memoized_mime_type.has_key?(args)
#{
memoized_ivar
}
[args] # @_memoized_mime_type[args]
elsif
#{
memoized_ivar
}
# elsif @_memoized_mime_type
#{
memoized_ivar
}
[args] =
#{
original_method
}
(*args).freeze # @_memoized_mime_type[args] = _unmemoized_mime_type(*args).freeze
end # end
else # else
#{
original_method
}
(*args) # _unmemoized_mime_type(*args)
end # end
end # end
end # end
EOS
end
end
...
...
railties/lib/rails_generator/generators/applications/app/template_runner.rb
浏览文件 @
2b8750eb
...
...
@@ -89,7 +89,7 @@ def gem(name, options = {})
gems_code
=
"config.gem '
#{
name
}
'"
if
options
.
any?
opts
=
options
.
inject
([])
{
|
result
,
h
|
result
<<
[
":
#{
h
[
0
]
}
=> '
#{
h
[
1
]
}
'"
]
}.
join
(
", "
)
opts
=
options
.
inject
([])
{
|
result
,
h
|
result
<<
[
":
#{
h
[
0
]
}
=> '
#{
h
[
1
]
}
'"
]
}.
sort
.
join
(
", "
)
gems_code
<<
",
#{
opts
}
"
end
...
...
@@ -355,5 +355,15 @@ def log(action, message = '')
def
logger
@logger
||=
Rails
::
Generator
::
Base
.
logger
end
def
logger
@logger
||=
if
defined?
(
Rails
::
Generator
::
Base
)
Rails
::
Generator
::
Base
.
logger
else
require
'rails_generator/simple_logger'
Rails
::
Generator
::
SimpleLogger
.
new
(
STDOUT
)
end
end
end
end
\ No newline at end of file
railties/test/generators/rails_template_runner_test.rb
浏览文件 @
2b8750eb
...
...
@@ -79,7 +79,7 @@ def test_gem_should_put_gem_dependency_in_enviroment
def
test_gem_with_options_should_include_options_in_gem_dependency_in_environment
run_template_method
(
:gem
,
'mislav-will-paginate'
,
:lib
=>
'will-paginate'
,
:source
=>
'http://gems.github.com'
)
assert_rails_initializer_includes
(
"config.gem 'mislav-will-paginate', :
source => 'http://gems.github.com', :lib => 'will-paginate
'"
)
assert_rails_initializer_includes
(
"config.gem 'mislav-will-paginate', :
lib => 'will-paginate', :source => 'http://gems.github.com
'"
)
end
def
test_environment_should_include_data_in_environment_initializer_block
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录