Base class for 'loggers' that write text messages to log files. More...
#include <logger.h>
Base class for 'loggers' that write text messages to log files.
This class is used to direct log messages to application- or environment- specific output. The default is to simply print the messages to the standard output stream or standard error stream, but classes may be derived from Logger that implement other output options. This is important when Cantera is used in applications that do not display the standard output, such as Python. The Cantera Python interface derives a class from Logger that implements these methods with Python-specific procedures, insuring that the messages will be passed through to the user. It would also be possible to derive a class that displayed the messages in a pop-up window, or redirected them to a file, etc.
To install a logger, call function setLogger (global.h / misc.cpp).
See the file Cantera/python/src/pylogger.h for examples of deriving logger classes.
Public Member Functions | |
Logger () | |
Constructor - empty. | |
virtual | ~Logger () |
Destructor - empty. | |
virtual void | write (const string &msg) |
Write a log message. | |
virtual void | writeendl () |
Write an end of line character and flush output. | |
virtual void | warn (const string &warning, const string &msg) |
Write a warning message. | |
virtual void | error (const string &msg) |
Write an error message and quit. | |
|
inlinevirtual |
Write a log message.
The default behavior is to write to the standard output. Note that no end-of-line character is appended to the message, and so if one is desired it must be included in the string.
msg | String message to be written to cout |
Reimplemented in PythonLogger, and ExternalLogger.
|
inlinevirtual |
Write an end of line character and flush output.
Some systems treat endl and
differently. The endl statement causes a flushing of stdout to the screen.
Reimplemented in ExternalLogger, and PythonLogger.
|
inlinevirtual |
Write a warning message.
The default behavior is to write to the logging output.
warning | String specifying type of warning |
msg | String message to be written to cout |
Reimplemented in PythonLogger, and ExternalLogger.
|
inlinevirtual |
Write an error message and quit.
The default behavior is to write to the standard error stream, and then call exit(). Note that no end-of-line character is appended to the message, and so if one is desired it must be included in the string. Note that this default behavior will terminate the application Cantera is invoked from (MATLAB, Excel, etc.) If this is not desired, then derive a class and reimplement this method.
msg | Error message to be written to cerr. |
Reimplemented in PythonLogger, ExternalLogger, and NoExitLogger.