Tracer question

B

Bart Masschelein

Hello all,

Is there a reason why these lines of code:

require 'tracer'

Tracer.on

class SomeClass
def someMethod
puts "Some text"
end
end

produce the following output:

#0:TracerTest.rb:3:Tracer:<: Tracer.on
#0:TracerTest.rb:3:Tracer:<: Tracer.on
#0:TracerTest.rb:5::-: class SomeClass
#0:TracerTest.rb:5:Class:>: class SomeClass
#0:TracerTest.rb:5:Class:<: class SomeClass
#0:TracerTest.rb:5::C: class SomeClass
#0:TracerTest.rb:6::-: def someMethod
#0:TracerTest.rb:6:Module:>: def someMethod
#0:TracerTest.rb:6:Module:<: def someMethod
#0:TracerTest.rb:5::E: class SomeClass
#0:TracerTest.rb:11::-: Tracer.off
caller TracerTest.rb:13

Why isn't it :

#0:TracerTest.rb:3:Tracer:<: Tracer.on
#0:TracerTest.rb:3:Tracer:<: Tracer.on
#0:TracerTest.rb:5::-: class SomeClass
#0:TracerTest.rb:5:Class:>: class SomeClass
#0:TracerTest.rb:5:Class:<: class SomeClass
#0:TracerTest.rb:5::C: class SomeClass
#0:TracerTest.rb:6::-: def someMethod
#0:TracerTest.rb:6:Module:>: def someMethod
#0:TracerTest.rb:8:Module:<: def someMethod
#0:TracerTest.rb:9::E: class SomeClass
#0:TracerTest.rb:11::-: Tracer.off
caller TracerTest.rb:13

So you know when browsing through the require tree, on which line a
class or method begins, and where it ends. I guess it is not a Tracer
issue, but rather a set_trace_func method(), by the return values you get.

This would be useful, as you could first make a model of your code by
changing the Tracer, and when the execution starts, stopping the Tracer,
as it reduces the overhead (because of the set_trace_func_method() with
some filters on). Then later, you can call caller, and by the filename
and linenumber exactly know where this fits in the model.

Or are there other ways to do this?

Bart.
 
B

Bart Masschelein

Sorry, code should be

require 'tracer'

Tracer.on

class SomeClass
def someMethod
puts "caller #{caller}"
end
end

Tracer.off
someClass = SomeClass.new
someClass.someMethod
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,769
Messages
2,569,582
Members
45,060
Latest member
BuyKetozenseACV

Latest Threads

Top