blob: 011ac6cecc324b84228aaf8c66d6a6353bce2fcf (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
module Rails
module Rack
class LogTailer
def initialize(app, log = nil)
@app = app
path = Pathname.new(log || "#{File.expand_path(Rails.root)}/log/#{Rails.env}.log").cleanpath
@cursor = ::File.size(path)
@file = ::File.open(path, 'r')
end
def call(env)
response = @app.call(env)
tail!
response
end
def tail!
@file.seek @cursor
if !@file.eof?
contents = @file.read
@cursor = @file.tell
$stdout.print contents
end
end
end
end
end
|