Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
94de5b8c
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,发现更多精彩内容 >>
提交
94de5b8c
编写于
6月 14, 2010
作者:
X
Xavier Noria
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
edit pass in #define_callbacks rdoc
上级
e4c8bc1b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
20 deletion
+22
-20
activesupport/lib/active_support/callbacks.rb
activesupport/lib/active_support/callbacks.rb
+22
-20
未找到文件。
activesupport/lib/active_support/callbacks.rb
浏览文件 @
94de5b8c
...
...
@@ -449,7 +449,9 @@ def __update_callbacks(name, filters = [], block = nil) #:nodoc:
# we convert :only and :except conditions into per-key conditions.
#
# before_filter :authenticate, :except => "index"
#
# becomes
#
# dispatch_callback :before, :authenticate, :per_key => {:unless => proc {|c| c.action_name == "index"}}
#
# Per-Key conditions are evaluated only once per use of a given key.
...
...
@@ -510,33 +512,33 @@ def reset_callbacks(symbol)
__define_runner
(
symbol
)
end
# Define callbacks types.
#
# ==== Example
# Defines callbacks types:
#
# define_callbacks :validate
#
#
==== Options
#
This macro accepts the following options:
#
# * <tt>:terminator</tt> - Indicates when a before filter is considered
# to be halted.
#
# define_callbacks :validate, :terminator => "result == false"
#
# In the example above, if any before validate callbacks returns false,
# other callbacks are not executed. Defaults to "false".
# In the example above, if any before validate callbacks returns +false+,
# other callbacks are not executed. Defaults to "false", meaning no value
# halts the chain.
#
# * <tt>:rescuable</tt> - By default, after filters are not executed if
# the given block or a
n before_filter raises an error. Supply :rescuable => true
# to change this behavior.
# the given block or a
before filter raises an error. Set this option to
# t
rue t
o change this behavior.
#
# * <tt>:scope</tt> - Indicates which methods should be executed when a class
# is given as callback
:
# is given as callback
. Defaults to <tt>[:kind]</tt>.
#
# class Audit
# def before(caller)
# puts 'Audit: before is called'
# end
#
# def before_save(caller)
# puts 'Audit: before_save is called'
# end
...
...
@@ -544,8 +546,10 @@ def reset_callbacks(symbol)
#
# class Account
# include ActiveSupport::Callbacks
#
# define_callbacks :save
# set_callback :save, :before, Audit.new
#
# def save
# run_callbacks :save do
# puts 'save in main'
...
...
@@ -553,22 +557,20 @@ def reset_callbacks(symbol)
# end
# end
#
#
In the above case if you execute Account.new.save then method "before" of Audit class
#
will be called. Now change the class "Account" and pass "scope" to method "define_callbacks".
#
In the above case whenever you save an account the method <tt>Audit#before</tt> will
#
be called. On the other hand
#
# define_callbacks :save, :scope => [:kind, :name]
#
define_callbacks :save, :scope => [:kind, :name]
#
# Now if you invoke Account.new.save then method "before_save" of Audit will be called
# instead of method "before".
# would trigger <tt>Audit#before_save</tt> instead. That's constructed by calling
# <tt>"#{kind}_#{name}"</tt> on the given instance. In this case "kind" is "before" and
# "name" is "save".
#
# When you do not pass any scope then the default value of scope ":kind" is implicitly being
# passed. In the above case method "before_save" is constructed by calling "#{kind}_#{name}"
# in the given class. In this case "kind" is "before" and "name" is "save".
# A declaration like
#
# Although ":kind" is the default scope that is passed, it is possible to not to make use of ":kind".
# define_callbacks :save, :scope => [:name] . A declaration like this would call "save" method of
# Audit class since ":kind" is skipped.
# define_callbacks :save, :scope => [:name]
#
# would call <tt>Audit#save</tt>.
#
def
define_callbacks
(
*
callbacks
)
config
=
callbacks
.
last
.
is_a?
(
Hash
)
?
callbacks
.
pop
:
{}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录