Class: EventHub::MultiLogger
- Inherits:
-
Object
- Object
- EventHub::MultiLogger
- Defined in:
- lib/eventhub/multi_logger.rb
Instance Attribute Summary collapse
-
#devices ⇒ Object
Returns the value of attribute devices.
-
#folder ⇒ Object
Returns the value of attribute folder.
Instance Method Summary collapse
- #add_device(device) ⇒ Object
-
#initialize(folder = nil) ⇒ MultiLogger
constructor
A new instance of MultiLogger.
- #save_detailed_error(feedback, message = nil) ⇒ Object
Constructor Details
#initialize(folder = nil) ⇒ MultiLogger
Returns a new instance of MultiLogger.
21 22 23 24 25 26 |
# File 'lib/eventhub/multi_logger.rb', line 21 def initialize(folder=nil) @folder = folder || (Dir.pwd + '/log') @devices = [] FileUtils.makedirs(@folder) end |
Instance Attribute Details
#devices ⇒ Object
Returns the value of attribute devices.
19 20 21 |
# File 'lib/eventhub/multi_logger.rb', line 19 def devices @devices end |
#folder ⇒ Object
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
28 29 30 |
# File 'lib/eventhub/multi_logger.rb', line 28 def add_device(device) @devices << device end |
#save_detailed_error(feedback, message = nil) ⇒ Object
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/eventhub/multi_logger.rb', line 32 def save_detailed_error(feedback,=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 File.open("#{@folder}/exceptions/#{stamp}.msg.raw","wb") do |output| output.write() end end return stamp end |