blob: 50d0eb96fc118c43c065e41f7c0c9f08219ee57e (
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
31
32
33
34
 | 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 = nil
        if ::File.exist?(path)
          @cursor = ::File.size(path)
          @file = ::File.open(path, 'r')
        end
      end
      def call(env)
        response = @app.call(env)
        tail!
        response
      end
      def tail!
        return unless @cursor
        @file.seek @cursor
        unless @file.eof?
          contents = @file.read
          @cursor = @file.tell
          $stdout.print contents
        end
      end
    end
  end
end
 |