Sha256: 867dbfb33803f43c80e57870dd5d2673492b0b7e5ea81c801457688e4a63735d

Contents?: true

Size: 1.24 KB

Versions: 12

Compression:

Stored size: 1.24 KB

Contents

module Skylight
  # @api private
  module VM
    if defined?(JRUBY_VERSION)
      # This doesn't quite work as we would like it. I believe that the GC
      # statistics includes time that is not stop-the-world, this does not
      # necessarily take time away from the application.
      #
      # require 'java'
      # class GC
      #   def initialize
      #     @factory = Java::JavaLangManagement::ManagementFactory
      #   end
      #
      #   def enable
      #   end
      #
      #   def total_time
      #     res = 0.0
      #
      #     @factory.garbage_collector_mx_beans.each do |mx|
      #       res += (mx.collection_time.to_f / 1_000.0)
      #     end
      #
      #     res
      #   end
      # end
    elsif defined?(::GC::Profiler)
      class GC
        def initialize
          @total = 0
        end

        def enable
          ::GC::Profiler.enable
        end

        def total_time
          # Reported in seconds
          run = (::GC::Profiler.total_time * 1_000_000).to_i

          ::GC::Profiler.clear if run > 0

          @total += run
        end
      end
    end

    # Fallback
    unless defined?(VM::GC)
      class GC
        def enable; end

        def total_time
          0
        end
      end
    end
  end
end

Version data entries

12 entries across 12 versions & 1 rubygems

Version Path
skylight-5.3.5 lib/skylight/vm/gc.rb
skylight-5.3.4 lib/skylight/vm/gc.rb
skylight-5.3.3 lib/skylight/vm/gc.rb
skylight-5.3.2 lib/skylight/vm/gc.rb
skylight-5.3.1 lib/skylight/vm/gc.rb
skylight-5.3.0 lib/skylight/vm/gc.rb
skylight-5.2.0 lib/skylight/vm/gc.rb
skylight-5.2.0.beta2 lib/skylight/vm/gc.rb
skylight-5.2.0.beta lib/skylight/vm/gc.rb
skylight-5.1.1 lib/skylight/vm/gc.rb
skylight-5.1.0.beta3 lib/skylight/vm/gc.rb
skylight-5.1.0.beta2 lib/skylight/vm/gc.rb