类 DEBUGGER__::DAP_TraceInspector::MultiTracer

属性

dropped_trace_cnt[RW]
log[R]

公共类方法

new(ui, evts, trace_params, max_log_size: nil, **kw) 点击切换源代码
调用父类方法
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 4
def initialize ui, evts, trace_params, max_log_size: nil, **kw
  @evts = evts
  @log = []
  @trace_params = trace_params
  if max_log_size
    @max_log_size = max_log_size
  else
    @max_log_size = 50000
  end
  @dropped_trace_cnt = 0
  super(ui, **kw)
  @type = 'multi'
  @name = 'TraceInspector'
end

公共实例方法

append(log) 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 60
def append log
  if @log.size >= @max_log_size
    @dropped_trace_cnt += 1
    @log.shift
  end
  @log << log
end
call_identifier_str(tp) 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 52
def call_identifier_str tp
  if tp.defined_class
    minfo(tp)
  else
    "block"
  end
end
call_trace_log(tp, return_str: nil, params: nil) 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 68
def call_trace_log tp, return_str: nil, params: nil
  log = {
    depth: DEBUGGER__.frame_depth,
    name: call_identifier_str(tp),
    threadId: Thread.current.instance_variable_get(:@__thread_client_id),
    location: {
      path: tp.path,
      line: tp.lineno
    }
  }
  log[:returnValue] = return_str if return_str
  log[:parameters] = params if params && params.size > 0
  log
end
line_trace_log(tp) 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 83
def line_trace_log tp
  {
    depth: DEBUGGER__.frame_depth,
    threadId: Thread.current.instance_variable_get(:@__thread_client_id),
    location: {
      path: tp.path,
      line: tp.lineno
    }
  }
end
parameters_info(tp) 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 41
def parameters_info tp
  b = tp.binding
  tp.parameters.map{|_type, name|
    begin
      { name: name, value: DEBUGGER__.safe_inspect(b.local_variable_get(name), short: true, max_length: 4096) }
    rescue NameError, TypeError
      nil
    end
  }.compact
end
setup() 点击切换源代码
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 22
def setup
  @tracer = TracePoint.new(*@evts){|tp|
    next if skip?(tp)
  
    case tp.event
    when :call, :c_call, :b_call
      if @trace_params
        params = parameters_info tp
      end
      append(call_trace_log(tp, params: params))
    when :return, :c_return, :b_return
      return_str = DEBUGGER__.safe_inspect(tp.return_value, short: true, max_length: 4096)
      append(call_trace_log(tp, return_str: return_str))
    when :line
      append(line_trace_log(tp))
    end
  }
end
skip?(tp) 点击切换源代码
调用父类方法
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 94
def skip? tp
  super || !@evts.include?(tp.event)
end
skip_with_pattern?(tp) 点击切换源代码
调用父类方法
# File debug-1.10.0/lib/debug/dap_custom/traceInspector.rb, line 98
def skip_with_pattern?(tp)
  super && !tp.method_id&.match?(@pattern)
end