Class: TraceTree::Point

Inherits:
Object
  • Object
show all
Includes:
TreeGraphable, TreeHtmlable
Defined in:
lib/trace_tree/point.rb,
lib/trace_tree/point.rb,
lib/trace_tree/point/omit.rb,
lib/trace_tree/point/common.rb,
lib/trace_tree/point/threadend.rb,
lib/trace_tree/point/threadbegin.rb,
lib/trace_tree/point/ccall_kernel_raise.rb,
lib/trace_tree/point/ccall_kernel_extend.rb,
lib/trace_tree/point/ccall_module_include.rb,
lib/trace_tree/point/ccall_module_prepend.rb,
lib/trace_tree/point/ccall_classthread_new.rb,
lib/trace_tree/point/ccall_thread_initialize.rb,
lib/trace_tree/point/creturn_classthread_new.rb,
lib/trace_tree/point/ccall_module_extendobject.rb,
lib/trace_tree/point/creturn_thread_initialize.rb,
lib/trace_tree/point/creturn_module_extendobject.rb

Defined Under Namespace

Classes: CcallClassthreadNew, CcallKernelExtend, CcallKernelRaise, CcallModuleExtendobject, CcallModuleInclude, CcallModulePrepend, CcallThreadInitialize, Common, CreturnClassthreadNew, CreturnModuleExtendobject, CreturnThreadInitialize, Loader, Omitted, Threadbegin, Threadend

Constant Summary collapse

Interfaces =
[:event, :defined_class, :method_id, :path, :lineno]
NativeThreadCall =
[CcallClassthreadNew,
CreturnClassthreadNew,
CcallThreadInitialize,
CreturnThreadInitialize,
Threadbegin,
Threadend]

Constants included from TreeHtmlable

TreeHtmlable::DEFAULT_JS

Class Attribute Summary collapse

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from TreeHtmlable

#body_js_for_tree_html, #children_for_tree_html, #css_for_tree_html, #data_for_tree_html, #label_for_tree_html

Methods included from TreeGraphable

#children_for_tree_graph, #label_for_tree_graph

Constructor Details

#initialize(trace_point) ⇒ Point

Returns a new instance of Point.



71
72
73
74
75
76
77
78
79
80
81
82
83
84
# File 'lib/trace_tree/point.rb', line 71

def initialize trace_point
  assign_trace_point_values(trace_point)

  @return_value = trace_point.return_value if x_return?
  @thread = Thread.current

  unless thread?
    there = trace_point.binding.of_caller(3)
    @current = BindingOfCallers::Revealed.new there
    @frame_env = current.frame_env.to_sym
  end
rescue => e
  puts e
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method_id, *args, &blk) ⇒ Object

Raises:

  • (NoMethodError)


66
67
68
69
# File 'lib/trace_tree/point.rb', line 66

def method_missing method_id, *args, &blk
  raise NoMethodError, "NoMethodError: undefined method `#{method_id}' "\
    "for #<#{self.class.proto or self.class.name}#{inspect}>"
end

Class Attribute Details

.protoObject (readonly)

Returns the value of attribute proto.



50
51
52
# File 'lib/trace_tree/point.rb', line 50

def proto
  @proto
end

Instance Attribute Details

#configObject

Returns the value of attribute config.



11
12
13
# File 'lib/trace_tree/point.rb', line 11

def config
  @config
end

#currentObject (readonly)

Returns the value of attribute current.



10
11
12
# File 'lib/trace_tree/point.rb', line 10

def current
  @current
end

#frame_envObject (readonly)

Returns the value of attribute frame_env.



10
11
12
# File 'lib/trace_tree/point.rb', line 10

def frame_env
  @frame_env
end

#terminalObject

Returns the value of attribute terminal.



11
12
13
# File 'lib/trace_tree/point.rb', line 11

def terminal
  @terminal
end

#threadObject (readonly)

Returns the value of attribute thread.



10
11
12
# File 'lib/trace_tree/point.rb', line 10

def thread
  @thread
end

Class Method Details

.basesObject



22
23
24
# File 'lib/trace_tree/point.rb', line 22

def bases
  @bases ||= []
end

.cache_event_class_method!Object



52
53
54
55
56
57
58
59
60
61
62
63
# File 'lib/trace_tree/point.rb', line 52

def cache_event_class_method!
  bases.each do |base|
    base.class_eval "      class << self\n        alias_method :_event_class_method, :event_class_method\n        def self.event_class_method\n          @ecm ||= _event_class_method.freeze\n        end\n      end\n"
  end
end

.class_of?(point) ⇒ Boolean

Returns:

  • (Boolean)


39
40
41
42
# File 'lib/trace_tree/point.rb', line 39

def class_of? point
  e, c, m = event_class_method
  point.method_id == m && point.event == e && point.defined_class == c
end

.hashify(point) ⇒ Object



26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/trace_tree/point.rb', line 26

def hashify point
  h = {}
  h[:event] = point.event
  h[:defined_class] = point.defined_class
  h[:method_id] = point.method_id
  h[:frame_env] = point.frame_env unless point.thread?
  h[:path] = point.path
  h[:lineno] = point.lineno
  h[:thread] = point.thread
  h[:return_value] = point.return_value if point.event =~ /return/
  h
end

.inherited(base) ⇒ Object



18
19
20
# File 'lib/trace_tree/point.rb', line 18

def inherited base
  bases << base
end

.initialize_clone(proto) ⇒ Object



44
45
46
47
48
# File 'lib/trace_tree/point.rb', line 44

def initialize_clone proto
  super.tap do
    instance_variable_set :@proto, proto
  end
end

Instance Method Details

#<<(node) ⇒ Object



144
145
146
# File 'lib/trace_tree/point.rb', line 144

def << node
  callees << node
end

#_class_and_methodObject



156
157
158
# File 'lib/trace_tree/point.rb', line 156

def _class_and_method
  @km ||= "#{class_name}#{call_symbol}#{method_name}"
end

#argObject



180
181
182
# File 'lib/trace_tree/point.rb', line 180

def arg
  respond_to?(:parameters) ? "(#{parameters})" : nil
end

#argumentsObject



113
114
115
116
117
118
119
120
# File 'lib/trace_tree/point.rb', line 113

def arguments
  {}.tap do |args|
    if event == :call
      defined_class.instance_method(method_id).parameters.
        each{ |role, name| args[name] = current.lv(name) unless name.nil? && role == :rest }
    end
  end
end

#b_call?Boolean

Returns:

  • (Boolean)


86
87
88
# File 'lib/trace_tree/point.rb', line 86

def b_call?
  event == :b_call
end

#c_call?Boolean

Returns:

  • (Boolean)


90
91
92
# File 'lib/trace_tree/point.rb', line 90

def c_call?
  event == :c_call
end

#call_symbolObject



172
173
174
# File 'lib/trace_tree/point.rb', line 172

def call_symbol
  c_call? ? '#' : current.call_symbol
end

#calleesObject



148
149
150
# File 'lib/trace_tree/point.rb', line 148

def callees
  @callees ||= []
end

#class?Boolean

Returns:

  • (Boolean)


94
95
96
# File 'lib/trace_tree/point.rb', line 94

def class?
  event == :class
end

#class_and_methodObject



152
153
154
# File 'lib/trace_tree/point.rb', line 152

def class_and_method
  "#{_class_and_method}#{arg}"
end

#class_nameObject



160
161
162
163
164
# File 'lib/trace_tree/point.rb', line 160

def class_name
  c_call? ? defined_class : current.klass
rescue
  puts event
end

#end_of_trace?Boolean

Returns:

  • (Boolean)


106
107
108
109
110
111
# File 'lib/trace_tree/point.rb', line 106

def end_of_trace?
  MainFile == path && (
    (:c_return == event && :instance_eval == method_id) ||
      (:c_call == event && :disable == method_id)
  )
end

#inspectObject



126
127
128
# File 'lib/trace_tree/point.rb', line 126

def inspect
  to_h.inspect
end

#method_defined_by_define_method?Boolean

Returns:

  • (Boolean)


251
252
253
254
# File 'lib/trace_tree/point.rb', line 251

def method_defined_by_define_method?
  (event == :call || event == :return) &&
    method_id != frame_env
end

#method_nameObject



166
167
168
169
170
# File 'lib/trace_tree/point.rb', line 166

def method_name
  return method_id if c_call?
  return frame_env if b_call? || class?
  (method_id == frame_env) ? method_id : "#{method_id} -> #{frame_env}"
end

#return_valueObject



122
123
124
# File 'lib/trace_tree/point.rb', line 122

def return_value
  x_return? ? @return_value : (terminal.nil? ? nil : terminal.return_value)
end

#source_locationObject



176
177
178
# File 'lib/trace_tree/point.rb', line 176

def source_location
  "#{path}:#{lineno}"
end

#terminate?(point) ⇒ Boolean

Returns:

  • (Boolean)


134
135
136
137
138
139
140
141
142
# File 'lib/trace_tree/point.rb', line 134

def terminate? point
  (point.defined_class == defined_class && point.method_id == method_id) && (
    (event == :return && point.event == :call) ||
    (event == :b_return && point.event == :b_call) ||
    (event == :c_return && point.event == :c_call) ||
    (event == :end && point.event == :class) ||
    (event == :thread_end && point.event == :thread_begin)
  )
end

#thread?Boolean

Returns:

  • (Boolean)


102
103
104
# File 'lib/trace_tree/point.rb', line 102

def thread?
  event =~ /thread/
end

#thread_relative?Boolean

Returns:

  • (Boolean)


246
247
248
249
# File 'lib/trace_tree/point.rb', line 246

def thread_relative?
  NativeThreadCall.any?{ |k| k.class_of? self } ||
    Thread == defined_class
end

#to_hObject



130
131
132
# File 'lib/trace_tree/point.rb', line 130

def to_h
  self.class.hashify(self)
end

#x_return?Boolean

Returns:

  • (Boolean)


98
99
100
# File 'lib/trace_tree/point.rb', line 98

def x_return?
  event =~ /return/
end