Sha256: 523a8254a3f0aae856e6f6eb1ba32577136b8c1b7649db0c2ad965e821b384d4

Contents?: true

Size: 1.27 KB

Versions: 8

Compression:

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

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

          @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-5.1.0.beta lib/skylight/vm/gc.rb
skylight-5.0.1 lib/skylight/vm/gc.rb
skylight-5.0.0 lib/skylight/vm/gc.rb
skylight-5.0.0.beta5 lib/skylight/vm/gc.rb
skylight-5.0.0.beta4 lib/skylight/vm/gc.rb
skylight-5.0.0.beta3 lib/skylight/vm/gc.rb
skylight-5.0.0.beta2 lib/skylight/vm/gc.rb
skylight-5.0.0.beta lib/skylight/vm/gc.rb