Sha256: 00d41ac526911af4b7efefc525d24d39f8857081ccf20cdd664e9dc862a21abb

Contents?: true

Size: 1.45 KB

Versions: 3

Compression:

Stored size: 1.45 KB

Contents

# typed: false

module Datadog
  module Profiling
    module Collectors
      # Used to periodically sample threads, recording elapsed CPU-time and Wall-time between samples.
      # Triggering of this component (e.g. deciding when to take a sample) is implemented in
      # Collectors::CpuAndWallTimeWorker.
      # The stack collection itself is handled using the Datadog::Profiling::Collectors::Stack.
      # Almost all of this class is implemented as native code.
      #
      # Methods prefixed with _native_ are implemented in `collectors_cpu_and_wall_time.c`
      class CpuAndWallTime
        def initialize(recorder:, max_frames:, tracer:)
          tracer_context_key = safely_extract_context_key_from(tracer)
          self.class._native_initialize(self, recorder, max_frames, tracer_context_key)
        end

        def inspect
          # Compose Ruby's default inspect with our custom inspect for the native parts
          result = super()
          result[-1] = "#{self.class._native_inspect(self)}>"
          result
        end

        def reset_after_fork
          self.class._native_reset_after_fork(self)
        end

        private

        def safely_extract_context_key_from(tracer)
          provider = tracer && tracer.respond_to?(:provider) && tracer.provider

          return unless provider

          context = provider.instance_variable_get(:@context)
          context && context.instance_variable_get(:@key)
        end
      end
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
ddtrace-1.9.0 lib/datadog/profiling/collectors/cpu_and_wall_time.rb
ddtrace-1.8.0 lib/datadog/profiling/collectors/cpu_and_wall_time.rb
ddtrace-1.7.0 lib/datadog/profiling/collectors/cpu_and_wall_time.rb