Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
f939fb5e
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,发现更多精彩内容 >>
提交
f939fb5e
编写于
8月 15, 2010
作者:
S
Santiago Pastorino
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Makes use of class << self instead of def self.
上级
331c5da7
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
31 addition
and
32 deletion
+31
-32
activesupport/lib/active_support/log_subscriber.rb
activesupport/lib/active_support/log_subscriber.rb
+31
-32
未找到文件。
activesupport/lib/active_support/log_subscriber.rb
浏览文件 @
f939fb5e
...
...
@@ -31,19 +31,6 @@ module ActiveSupport
# all logs when the request finishes (via action_dispatch.callback notification) in
# a Rails environment.
class
LogSubscriber
mattr_accessor
:colorize_logging
self
.
colorize_logging
=
true
class_attribute
:logger
class
<<
self
remove_method
:logger
end
def
self
.
logger
@logger
||=
Rails
.
logger
if
defined?
(
Rails
)
end
# Embed in a String to clear all previous ANSI sequences.
CLEAR
=
"
\e
[0m"
BOLD
=
"
\e
[1m"
...
...
@@ -58,32 +45,44 @@ def self.logger
CYAN
=
"
\e
[36m"
WHITE
=
"
\e
[37m"
def
self
.
attach_to
(
namespace
,
log_subscriber
=
new
,
notifier
=
ActiveSupport
::
Notifications
)
log_subscribers
<<
log_subscriber
@@flushable_loggers
=
nil
mattr_accessor
:colorize_logging
self
.
colorize_logging
=
true
log_subscriber
.
public_methods
(
false
).
each
do
|
event
|
next
if
'call'
==
event
.
to_s
class_attribute
:logger
notifier
.
subscribe
(
"
#{
event
}
.
#{
namespace
}
"
,
log_subscriber
)
class
<<
self
remove_method
:logger
def
logger
@logger
||=
Rails
.
logger
if
defined?
(
Rails
)
end
end
def
self
.
log_subscribers
@@log_subscribers
||=
[]
end
def
attach_to
(
namespace
,
log_subscriber
=
new
,
notifier
=
ActiveSupport
::
Notifications
)
log_subscribers
<<
log_subscriber
@@flushable_loggers
=
nil
def
self
.
flushable_loggers
@@flushable_loggers
||=
begin
loggers
=
log_subscribers
.
map
(
&
:logger
)
loggers
.
uniq!
loggers
.
select
{
|
l
|
l
.
respond_to?
(
:flush
)
}
log_subscriber
.
public_methods
(
false
).
each
do
|
event
|
next
if
'call'
==
event
.
to_s
notifier
.
subscribe
(
"
#{
event
}
.
#{
namespace
}
"
,
log_subscriber
)
end
end
end
# Flush all log_subscribers' logger.
def
self
.
flush_all!
flushable_loggers
.
each
(
&
:flush
)
def
log_subscribers
@@log_subscribers
||=
[]
end
def
flushable_loggers
@@flushable_loggers
||=
begin
loggers
=
log_subscribers
.
map
(
&
:logger
)
loggers
.
uniq!
loggers
.
select
{
|
l
|
l
.
respond_to?
(
:flush
)
}
end
end
# Flush all log_subscribers' logger.
def
flush_all!
flushable_loggers
.
each
(
&
:flush
)
end
end
def
call
(
message
,
*
args
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录