Class: EventHub::MultiLogger

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(folder = nil) ⇒ MultiLogger

Returns a new instance of MultiLogger.



21
22
23
24
# File 'lib/eventhub/multi_logger.rb', line 21

def initialize(folder=nil)
    @folder = folder || Dir.pwd
    @devices = []
end

Instance Attribute Details

#devicesObject

Returns the value of attribute devices.



19
20
21
# File 'lib/eventhub/multi_logger.rb', line 19

def devices
  @devices
end

#folderObject

Returns the value of attribute folder.



19
20
21
# File 'lib/eventhub/multi_logger.rb', line 19

def folder
  @folder
end

Instance Method Details

#add_device(device) ⇒ Object



26
27
28
# File 'lib/eventhub/multi_logger.rb', line 26

def add_device(device)
  @devices << device
end

#save_detailed_error(feedback, message = nil) ⇒ Object



30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# File 'lib/eventhub/multi_logger.rb', line 30

def save_detailed_error(feedback,message=nil)
  time = Time.now
  stamp = "#{time.strftime("%Y%m%d_%H%M%S")}_#{"%03d" % (time.usec/1000)}"
  filename = "#{stamp}.log"

  FileUtils.makedirs("#{folder}/exceptions")

  File.open("#{@folder}/exceptions/#{filename}","w") do |output|
    output.write("#{feedback}\n\n")
    output.write("Exception: #{feedback.class.to_s}\n\n")
    output.write("Call Stack:\n")
    feedback.backtrace.each do |line|
      output.write("#{line}\n")
    end
  end

  # save message if provided
  if message
   File.open("#{@folder}/exceptions/#{stamp}.msg.raw","wb") do |output|
    output.write(message)
   end
  end  

  return stamp
end