0

機能することがわかったヒントからまとめたコードがいくつかあります。しかし、何かがうまくいかず、私は困惑しています。画面には何も送信されず、ファイルは空です。

プログラムは次のとおりです。

#!/usr/bin/env ruby -w

require "stringio"

class Tee

    def initialize
      date_str = `date '+%Y%m%d_%H%M%S'`.chomp
      @log = File.new("tee_output_example_#{date_str}.log","w")
    end

["$stdout", "$stderr"].each do |std|
   io           = eval(std)
   old_write    = io.method(:write)

   class << io
     self
   end.module_eval do
     define_method(:write) do |text|
       unless text =~ /^[\r\n]+$/       # Because puts calls twice.
         File.open(@log, "a") do |f|
#           f.puts [std[1..-1].upcase, caller[2], text].join(" ")
            f.puts text
         end
       end

       old_write.call(text)
     end
   end
 end
end

logger = Tee.new()

 logger.puts "text on stdout"
 logger.puts "Something else"

 $stdout = STDOUT
 $stderr = STDERR
 $stdout.puts "plain puts to $stdout"
 $stderr.puts "plain puts to $stderr"
4

3 に答える 3

3

このコマンドで簡単に解決できました:

STDOUT.reopen IO.popen "tee stdout.log", "a"
STDERR.reopen IO.popen "tee stderr.log", "a"
于 2012-09-10T10:46:42.420 に答える
0

あなたの期待は私にはあまり明確ではありませんが、これは合理的なスタートのようです (最終的な目標に応じて、いくつかの方向性があります)。

#!/usr/bin/env ruby -w

class Tee
  attr_accessor :log_file

  def initialize()
    self.log_file = File.open "tee_output_example_#{date_str}.log", "w"
    at_exit { log_file.close }
  end

  def date_str
    Time.now.strftime "%Y%m%d_%H%M%S"
  end

  def puts(*strings)
    log_file.puts(*strings)
    $stdout.puts(*strings)
  end
end

# will be sent to both $stdout and the logfile
logger = Tee.new
logger.puts "text on stdout"
logger.puts "Something else"

# will only be sent to $stdout or $stderr
$stdout.puts "plain puts to $stdout"
$stderr.puts "plain puts to $stderr"
于 2012-01-21T11:28:37.310 に答える
0

デバッグ手法に関するヒントをいくつか提供できますが、代わりに、ニーズを満たす可能性のある代替ソリューションを提案します。

class Tee
  def initialize(a,b); @a,@b = a,b; end
  def method_missing(m,*args,&b)
    @a.send(m,*args,&b)
    @b.send(m,*args,&b)
  end
end

このクラスは、作成しようとしていたものよりも一般的に役立ちます。2 つのオブジェクトを取り、すべてのメソッド呼び出し (引数とブロックを含む) を両方に渡します。したがって、次のようなことができます。

tee = Tee.new(File.open("log","w"), $stdout)
tee.puts "Hello world AND log file!"
于 2012-01-21T11:50:43.117 に答える