你可以写一个伪IO
将写入多个的类IO
对象。就像是:
class MultiIO
def initialize(*targets)
@targets = targets
end
def write(*args)
@targets.each {|t| t.write(*args)}
end
def close
@targets.each(&:close)
end
end
然后将其设置为日志文件:
log_file = File.open("log/debug.log", "a")
Logger.new MultiIO.new(STDOUT, log_file)
每次Logger
calls puts
在你的MultiIO
对象,它将写入两者STDOUT
和你的日志文件。
Edit:我继续思考界面的其余部分。日志设备必须响应write
and close
(not puts
)。只要MultiIO
响应这些并将它们代理到真实的 IO 对象,这应该可以工作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)