Class: Vedeu::MonoLogger::LocklessLogDevice
- Inherits:
-
LogDevice
- Object
- LogDevice
- Vedeu::MonoLogger::LocklessLogDevice
- Defined in:
- lib/vedeu/support/log.rb
Overview
Ensures we can always write to the log file by creating a lock-less log device.
Instance Method Summary collapse
-
#close ⇒ Object
[].
-
#initialize(log = nil) ⇒ Object
constructor
Returns a new instance of Vedeu::LocklessLogDevice.
-
#open_logfile(filename) ⇒ Object
private
[].
-
#write(message) ⇒ Object
[].
Constructor Details
#initialize(log = nil) ⇒ Object
Returns a new instance of Vedeu::LocklessLogDevice.
28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/vedeu/support/log.rb', line 28 def initialize(log = nil) @dev = nil @filename = nil if log.respond_to?(:write) && log.respond_to?(:close) @dev = log else @dev = open_logfile(log) @dev.sync = true @filename = log end end |
Instance Method Details
#close ⇒ Object
Returns [].
53 54 55 |
# File 'lib/vedeu/support/log.rb', line 53 def close @dev.close rescue nil end |
#open_logfile(filename) ⇒ Object (private)
Returns [].
61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/vedeu/support/log.rb', line 61 def open_logfile(filename) if FileTest.exist?(filename) open(filename, (File::WRONLY | File::APPEND)) else logdev = open(filename, (File::WRONLY | File::APPEND | File::CREAT)) logdev.sync = true logdev end end |
#write(message) ⇒ Object
Returns [].
45 46 47 48 49 50 |
# File 'lib/vedeu/support/log.rb', line 45 def write() @dev.write() rescue StandardError => exception warn("log writing failed. #{exception}") end |