Class: Mnemosyne::Span

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

Direct Known Subclasses

Trace

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, start: false, finish: false, meta: {}) ⇒ Span

Returns a new instance of Span.



7
8
9
10
11
12
13
14
15
# File 'lib/mnemosyne/span.rb', line 7

def initialize(name, start: false, finish: false, meta: {})
  @type = nil
  @name = name
  @meta = meta
  @uuid = ::SecureRandom.uuid

  @start  = start
  @finish = finish
end

Instance Attribute Details

#finishObject (readonly)

Returns the value of attribute finish.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def finish
  @finish
end

#metaObject (readonly)

Returns the value of attribute meta.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def meta
  @meta
end

#nameObject (readonly)

Returns the value of attribute name.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def name
  @name
end

#startObject (readonly)

Returns the value of attribute start.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def start
  @start
end

#typeObject (readonly)

Returns the value of attribute type.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def type
  @type
end

#uuidObject (readonly)

Returns the value of attribute uuid.



5
6
7
# File 'lib/mnemosyne/span.rb', line 5

def uuid
  @uuid
end

Instance Method Details

#finish!(oneshot: false) ⇒ Object



25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/mnemosyne/span.rb', line 25

def finish!(oneshot: false)
  raise 'Already finished' if @finish

  @finish = ::Mnemosyne::Clock.tick

  if oneshot
    @start ||= @finish
    @type = :oneshot
  end

  self
end

#serializeObject



38
39
40
41
42
43
44
45
46
47
# File 'lib/mnemosyne/span.rb', line 38

def serialize
  {
    uuid: uuid,
    name: name,
    type: type,
    start: start,
    stop: finish,
    meta: meta
  }
end

#start!Object



17
18
19
20
21
22
23
# File 'lib/mnemosyne/span.rb', line 17

def start!
  raise 'Already started' if @start

  @start = ::Mnemosyne::Clock.tick

  self
end