Sha256: 54de2bd271bafe80914660411967b8646faff02bbd83bec495161c76e975635c

Contents?: true

Size: 1.25 KB

Versions: 8

Compression:

Stored size: 1.25 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

8 entries across 8 versions & 1 rubygems

Version Path
skylight-6.1.0.beta lib/skylight/vm/gc.rb
skylight-6.0.4 lib/skylight/vm/gc.rb
skylight-6.0.3 lib/skylight/vm/gc.rb
skylight-6.0.2 lib/skylight/vm/gc.rb
skylight-6.0.1 lib/skylight/vm/gc.rb
skylight-6.0.0 lib/skylight/vm/gc.rb
skylight-6.0.0.beta2 lib/skylight/vm/gc.rb
skylight-6.0.0.beta lib/skylight/vm/gc.rb