log4cplus
2.1.0
|
Base class for Appenders writing log events to a file. More...
#include <fileappender.h>
Public Member Functions | |
virtual void | close () |
Release any resources allocated within the appender such as file handles, network connections, etc. More... | |
virtual std::locale | imbue (std::locale const &loc) |
Redefine default locale for output stream. More... | |
virtual std::locale | getloc () const |
Public Member Functions inherited from log4cplus::Appender | |
Appender () | |
Appender (const log4cplus::helpers::Properties &properties) | |
virtual | ~Appender () |
void | destructorImpl () |
This function is for derived appenders to call from their destructors. More... | |
bool | isClosed () const |
Check if this appender is in closed state. More... | |
void | syncDoAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This method performs threshold checks and invokes filters before delegating actual logging to the subclasses specific {} method. More... | |
void | asyncDoAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This method performs book keeping related to asynchronous logging and executes syncDoAppend() to do the actual logging. More... | |
void | doAppend (const log4cplus::spi::InternalLoggingEvent &event) |
This function checks async flag. More... | |
virtual log4cplus::tstring | getName () |
Get the name of this appender. More... | |
virtual void | setName (const log4cplus::tstring &name) |
Set the name of this appender. More... | |
virtual void | setErrorHandler (std::unique_ptr< ErrorHandler > eh) |
Set the ErrorHandler for this Appender. More... | |
virtual ErrorHandler * | getErrorHandler () |
Return the currently set ErrorHandler for this Appender. More... | |
virtual void | setLayout (std::unique_ptr< Layout > layout) |
Set the layout for this appender. More... | |
virtual Layout * | getLayout () |
Returns the layout of this appender. More... | |
void | setFilter (log4cplus::spi::FilterPtr f) |
Set the filter chain on this Appender. More... | |
log4cplus::spi::FilterPtr | getFilter () const |
Get the filter chain on this Appender. More... | |
void | addFilter (log4cplus::spi::FilterPtr f) |
Add filter at the end of the filters chain. More... | |
void | addFilter (std::function< spi::FilterResult(const log4cplus::spi::InternalLoggingEvent &)>) |
Add filter at the end of the filters chain. More... | |
LogLevel | getThreshold () const |
Returns this appenders threshold LogLevel. More... | |
void | setThreshold (LogLevel th) |
Set the threshold LogLevel. More... | |
bool | isAsSevereAsThreshold (LogLevel ll) const |
Check whether the message LogLevel is below the appender's threshold. More... | |
void | waitToFinishAsyncLogging () |
This method waits for all events that are being asynchronously logged to finish. More... | |
Public Member Functions inherited from log4cplus::helpers::SharedObject | |
void | addReference () const LOG4CPLUS_NOEXCEPT |
void | removeReference () const |
Protected Member Functions | |
FileAppenderBase (const log4cplus::tstring &filename, std::ios_base::openmode mode=std::ios_base::trunc, bool immediateFlush=true, bool createDirs=false) | |
FileAppenderBase (const log4cplus::helpers::Properties &properties, std::ios_base::openmode mode=std::ios_base::trunc) | |
void | init () |
virtual void | append (const spi::InternalLoggingEvent &event) |
Subclasses of Appender should implement this method to perform actual logging. More... | |
virtual void | open (std::ios_base::openmode mode) |
bool | reopen () |
Protected Member Functions inherited from log4cplus::Appender | |
tstring & | formatEvent (const log4cplus::spi::InternalLoggingEvent &event) const |
Protected Member Functions inherited from log4cplus::helpers::SharedObject | |
SharedObject () | |
SharedObject (const SharedObject &) | |
SharedObject (SharedObject &&) | |
virtual | ~SharedObject () |
SharedObject & | operator= (const SharedObject &) LOG4CPLUS_NOEXCEPT |
SharedObject & | operator= (SharedObject &&) LOG4CPLUS_NOEXCEPT |
Protected Attributes | |
bool | immediateFlush |
Immediate flush means that the underlying writer or output stream will be flushed at the end of each append operation. More... | |
bool | createDirs |
When this variable is true, FileAppender will try to create missing directories in path leading to log file. More... | |
int | reopenDelay |
When any append operation fails, reopenDelay says for how many seconds the next attempt to re-open the log file and resume logging will be delayed. More... | |
unsigned long | bufferSize |
std::unique_ptr< log4cplus::tchar[]> | buffer |
log4cplus::tofstream | out |
log4cplus::tstring | filename |
log4cplus::tstring | localeName |
log4cplus::tstring | lockFileName |
std::ios_base::openmode | fileOpenMode |
log4cplus::helpers::Time | reopen_time |
Protected Attributes inherited from log4cplus::Appender | |
std::unique_ptr< Layout > | layout |
The layout variable does not need to be set if the appender implementation has its own layout. More... | |
log4cplus::tstring | name |
Appenders are named. More... | |
LogLevel | threshold |
There is no LogLevel threshold filtering by default. More... | |
log4cplus::spi::FilterPtr | filter |
The first filter in the filter chain. More... | |
std::unique_ptr< ErrorHandler > | errorHandler |
It is assumed and enforced that errorHandler is never null. More... | |
std::unique_ptr< helpers::LockFile > | lockFile |
Optional system wide synchronization lock. More... | |
bool | useLockFile |
Use lock file for inter-process synchronization of access to log file. More... | |
bool | async |
Asynchronous append. More... | |
std::atomic< std::size_t > | in_flight |
std::mutex | in_flight_mutex |
std::condition_variable | in_flight_condition |
bool | closed |
Is this appender closed? More... | |
Additional Inherited Members | |
Public Attributes inherited from log4cplus::helpers::SharedObject | |
thread::Mutex | access_mutex |
Base class for Appenders writing log events to a file.
It is constructed with uninitialized file object, so all classes derived from FileAppenderBase must call init() method.
File
This property specifies output file name.
ImmediateFlush
When it is set true, output stream will be flushed after each appended event.
Append
When it is set true, output file will be appended to instead of being truncated at opening.
ReopenDelay
This property sets a delay after which the appender will try to reopen log file again, after last logging failure.
BufferSize
Non-zero value of this property sets up buffering of output stream using a buffer of given size.
UseLockFile
true
if you want your output to go into a log file shared by multiple processes. When this property is set to true then log4cplus uses OS specific facilities (e.g., lockf()
) to provide inter-process file locking. LockFile
File
property by addition of ".lock" suffix. The property is only used when UseLockFile
is set to true. Locale
en_US.UTF-8
, or by one of four recognized keywords: GLOBAL
, DEFAULT
(which is an alias for GLOBAL
), USER
and CLASSIC
. When specified locale is not available, GLOBAL
is used instead. It is possible to register additional locale keywords by registering an instance of spi::LocaleFactory
in spi::LocaleFactoryRegistry
. CreateDirs
Set this property to true
if you want to create missing directories in path leading to log file and lock file.
TextMode
Binary
if the underlying stream should not translate EOLs to OS specific character sequence. The default value is Text
and the underlying stream will be opened in text mode. Definition at line 117 of file fileappender.h.
|
protected |
|
protected |
|
protectedvirtual |
Subclasses of Appender
should implement this method to perform actual logging.
Implements log4cplus::Appender.
Reimplemented in log4cplus::TimeBasedRollingFileAppender, log4cplus::DailyRollingFileAppender, and log4cplus::RollingFileAppender.
|
virtual |
Release any resources allocated within the appender such as file handles, network connections, etc.
It is a programming error to append to a closed appender.
Implements log4cplus::Appender.
Reimplemented in log4cplus::TimeBasedRollingFileAppender, and log4cplus::DailyRollingFileAppender.
|
virtual |
|
virtual |
Redefine default locale for output stream.
It may be a good idea to provide UTF-8 locale in case UNICODE macro is defined.
|
protected |
|
protectedvirtual |
Reimplemented in log4cplus::TimeBasedRollingFileAppender.
|
protected |
|
protected |
Definition at line 178 of file fileappender.h.
|
protected |
Definition at line 177 of file fileappender.h.
|
protected |
When this variable is true, FileAppender will try to create missing directories in path leading to log file.
The createDirs
variable is set to false
by default.
Definition at line 166 of file fileappender.h.
|
protected |
Definition at line 181 of file fileappender.h.
|
protected |
Definition at line 184 of file fileappender.h.
|
protected |
Immediate flush means that the underlying writer or output stream will be flushed at the end of each append operation.
Immediate flush is slower but ensures that each append request is actually written. If immediateFlush
is set to false
, then there is a good chance that the last few logs events are not actually written to persistent media if and when the application crashes.
The immediateFlush
variable is set to true
by default.
Definition at line 158 of file fileappender.h.
|
protected |
Definition at line 182 of file fileappender.h.
|
protected |
Definition at line 183 of file fileappender.h.
|
protected |
Definition at line 180 of file fileappender.h.
|
protected |
Definition at line 186 of file fileappender.h.
|
protected |
When any append operation fails, reopenDelay
says for how many seconds the next attempt to re-open the log file and resume logging will be delayed.
If reopenDelay
is zero, each failed append operation will cause log file to be re-opened. By default, reopenDelay
is 1 second.
Definition at line 175 of file fileappender.h.