Class: Benchmark::Job

Inherits:
Object
  • Object
show all
Defined in:
lib/benchmark.rb

Overview

A Job is a sequence of labelled blocks to be processed by the Benchmark.bmbm method. It is of little direct interest to the user.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(width) ⇒ Job

Returns an initialized Job instance. Usually, one doesn't call this method directly, as new Job objects are created by the #bmbm method. width is a initial value for the label offset used in formatting; the #bmbm method passes its width argument to this constructor.


314
315
316
317
# File 'lib/benchmark.rb', line 314

def initialize(width)
  @width = width
  @list = []
end

Instance Attribute Details

#listObject (readonly)

An array of 2-element arrays, consisting of label and block pairs.


334
335
336
# File 'lib/benchmark.rb', line 334

def list
  @list
end

#widthObject (readonly)

Length of the widest label in the #list.


337
338
339
# File 'lib/benchmark.rb', line 337

def width
  @width
end

Instance Method Details

#item(label = "", &blk) ⇒ Object Also known as: report

Registers the given label and block pair in the job list.

Raises:

  • (ArgumentError)

322
323
324
325
326
327
328
329
# File 'lib/benchmark.rb', line 322

def item(label = "", &blk) # :yield:
  raise ArgumentError, "no block" unless block_given?
  label = label.to_s
  w = label.length
  @width = w if @width < w
  @list << [label, blk]
  self
end