Cantera  2.4.0
Public Member Functions | List of all members

Base class for 'loggers' that write text messages to log files. More...

#include <logger.h>

Inherited by PythonLogger.

Public Member Functions

 Logger ()
 Constructor - empty. More...
 
virtual ~Logger ()
 Destructor - empty. More...
 
virtual void write (const std::string &msg)
 Write a log message. More...
 
virtual void writeendl ()
 Write an end of line character and flush output. More...
 
virtual void error (const std::string &msg)
 Write an error message and quit. More...
 

Detailed Description

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 MATLAB. The Cantera MATLAB interface derives a class from Logger that implements these methods with MATLAB-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 files Cantera/python/src/pylogger.h and Cantera/matlab/cantera/private/mllogger.h for examples of deriving logger classes.

Definition at line 40 of file logger.h.

Constructor & Destructor Documentation

◆ Logger()

Logger ( )
inline

Constructor - empty.

Definition at line 44 of file logger.h.

◆ ~Logger()

virtual ~Logger ( )
inlinevirtual

Destructor - empty.

Definition at line 47 of file logger.h.

Member Function Documentation

◆ write()

virtual void write ( const std::string &  msg)
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.

Parameters
msgString message to be written to cout

Definition at line 57 of file logger.h.

◆ writeendl()

virtual void writeendl ( )
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.

Definition at line 66 of file logger.h.

◆ error()

virtual void error ( const std::string &  msg)
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.

Parameters
msgError message to be written to cerr.

Definition at line 81 of file logger.h.

Referenced by Cantera::setLogger().


The documentation for this class was generated from the following file: