Module: TimeM

Defined in:
lib/time_m.rb,
lib/time_m/timer.rb,
lib/time_m/version.rb

Defined Under Namespace

Modules: TimeExt Classes: Timer

Constant Summary collapse

NAME =
"| time_m |"
SKIP_FLAG =
-1
VERSION =
"0.1.0"

Class Method Summary collapse

Class Method Details

.info(str = "", new_line: false) ⇒ Object



77
78
79
# File 'lib/time_m.rb', line 77

def self.info(str = "", new_line: false)
  log(str.magenta.italic, new_line: new_line)
end

.log(str = "", new_line: false) ⇒ Object



89
90
91
# File 'lib/time_m.rb', line 89

def self.log(str = "", new_line: false)
  new_line ? puts(str) : print(str)
end

.m(name = nil, label = nil, &block) ⇒ Object



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# File 'lib/time_m.rb', line 19

def self.m(name = nil, label = nil, &block)
  now = Process.clock_gettime(Process::CLOCK_MONOTONIC)
  if block_given?
    yield.tap do |res|
      output(name, label, Process.clock_gettime(Process::CLOCK_MONOTONIC) - now)
    end
  else
    timer = tracker.timers[name]
    if timer.nil?
      tracker.init(name)
      output(name, label)
    else
      diff = now - timer[:last_time] if timer[:last_time]
      output(name, label, now - timer[:time], diff)
      tracker.touch(name, now)
    end
  end
end

.method_missing(method, *args, &block) ⇒ Object

rubocop:disable Style/MissingRespondToMissing



11
12
13
14
15
16
17
# File 'lib/time_m.rb', line 11

def self.method_missing(method, *args, &block) # rubocop:disable Style/MissingRespondToMissing
  name = method.to_s
  label = args.first.to_s
  label = (label == "") ? nil : label

  m(name, label, &block)
end

.output(name, label, time = SKIP_FLAG, last_time = nil) ⇒ Object



40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# File 'lib/time_m.rb', line 40

def self.output(name, label, time = SKIP_FLAG, last_time = nil)
  display_name = label || name || caller[1..2].detect { |line| !line.include?("/lib/time_m") }
  display_name = display_name.gsub(Rails.root.to_s + "/", "") if defined?(Rails)

  if time == SKIP_FLAG
    info NAME.on_light_yellow
    info " #{display_name}", new_line: true
    return
  end

  time = time.round(3)
  last_time = last_time.round(3) if last_time
  info NAME.on_light_yellow

  if display_name
    info " #{display_name}"
    warning sprintf("%0.3f", time)
    info " seconds"

    if last_time
      info ", "
      success "+#{sprintf("%0.3f", last_time)}"
      info " seconds", new_line: true
    else
      info new_line: true
    end
  else
    info " Elapsed time: #{sprintf("%0.3f", time)} seconds", new_line: true
  end
end

.success(str = "", new_line: false) ⇒ Object



81
82
83
# File 'lib/time_m.rb', line 81

def self.success(str = "", new_line: false)
  log(str.light_green.bold, new_line: new_line)
end

.trackerObject



71
72
73
# File 'lib/time_m.rb', line 71

def self.tracker
  Thread.current[:time_m_timer] ||= Timer.new
end

.warning(str = "", new_line: false) ⇒ Object



85
86
87
# File 'lib/time_m.rb', line 85

def self.warning(str = "", new_line: false)
  log(str.light_yellow.bold, new_line: new_line)
end