Class: MicroProfiler

Inherits:
Object
  • Object
show all
Defined in:
lib/micro_profiler.rb,
lib/micro_profiler/version.rb

Constant Summary collapse

TIME_PRECISION =
2
VERSION =
"0.1.0"

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(garbage_collection: false) ⇒ MicroProfiler

Returns a new instance of MicroProfiler.



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

def initialize(garbage_collection: false)
  @garbage_collection = garbage_collection
end

Class Method Details

.measure(garbage_collection: false, block: Proc.new) ⇒ Object



7
8
9
# File 'lib/micro_profiler.rb', line 7

def self.measure(garbage_collection: false, block: Proc.new)
  new(garbage_collection: garbage_collection).measure(block: block)
end

Instance Method Details

#measure(result: nil, block: Proc.new) ⇒ Object



15
16
17
18
19
20
21
22
23
# File 'lib/micro_profiler.rb', line 15

def measure(result: nil, block: Proc.new)
  calling_method
  before
  self.time = Benchmark.realtime { result = block.call }
  after

  print_measurements
  result
end