aboutsummaryrefslogblamecommitdiffstats
path: root/railties/lib/rails/rack/log_tailer.rb
blob: 46517713c9109e88d4bd34afa2fbd0e07a0d3f8a (plain) (tree)
1
2
3
4
5
6
7
8
9
10

                                    


                   
                                    
                                                                                                  
 

                  
                                                                                                      
 
                             
                              


                                        



                                 
             


                
               
                             

                          
                         
                               
                              





                                
require 'active_support/deprecation'

module Rails
  module Rack
    class LogTailer
      def initialize(app, log = nil)
        ActiveSupport::Deprecation.warn('LogTailer is deprecated and will be removed on Rails 5.')

        @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