Sha256: 185a9fc13c8672e1cf79b7018485d383670591da4709acbb4fbb3d7b759c89bb

Contents?: true

Size: 1.3 KB

Versions: 4

Compression:

Stored size: 1.3 KB

Contents

module Middleman
  module Profiling

    # The profiler instance. There can only be one!
    def self.profiler=(prof)
      @profiler = prof
    end
    def self.profiler
      @profiler ||= NullProfiler.new
    end

    # Start the profiler
    def self.start
      profiler.start
    end

    # Stop the profiler and generate a report. Make sure to call start first
    def self.report(report_name)
      profiler.report(report_name)
    end

    # A profiler that does nothing. The default.
    class NullProfiler
      def start
      end

      def report(report_name)
      end
    end

    # A profiler that uses ruby-prof
    class RubyProfProfiler
      def initialize
        begin
          require 'ruby-prof'
        rescue LoadError
          raise "To use the --profile option, you must add the 'ruby-prof' gem to your Gemfile"
        end
      end

      def start
        RubyProf.start
      end

      def report(report_name)
        result = RubyProf.stop

        printer = RubyProf::GraphHtmlPrinter.new(result)
        outfile = File.join('profile', report_name)
        outfile = (outfile + '.html') unless outfile.end_with? '.html'
        FileUtils.mkdir_p(File.dirname(outfile))
        File.open(outfile, 'w') do |f|
          printer.print(f, :min_percent=> 1)
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
middleman-core-3.3.2 lib/middleman-core/profiling.rb
middleman-core-3.3.1 lib/middleman-core/profiling.rb
middleman-core-3.3.0 lib/middleman-core/profiling.rb
middleman-core-3.2.2 lib/middleman-core/profiling.rb