ALib C++ Library
Library Version: 2312 R0
Documentation generated by doxygen
Public Fields | Public Methods | Protected Fields | Protected Methods | List of all members
TextFileLogger Class Reference

#include <textfilelogger.hpp>

Inheritance diagram for TextFileLogger:
[legend]
Collaboration diagram for TextFileLogger:
[legend]

Class Description


This is a very simple file logger for textual log outputs. The file name string provided in the constructor is not verified. The fileName may be changed by simply setting the public member FileName.

In alignment with ALox principles (ALox does not throw!), the logger does not throw i/o exceptions. In debug-compilations, ALib warnings are issued. Recent system io/ errors are stored in public field# LastSystemError. The constructor tries to open/close the file with write permissions. For many applications, it should be enough to check this field after construction and take according actions on failure. Otherwise, errors may periodically be checked by an application (e.g. no space left on device, etc.).

Definition at line 39 of file textfilelogger.hpp.

Public Fields

aworx::AString FileName
 
system::SystemErrors LastSystemError = system::SystemErrors::None
 
- Public Fields inherited from PlainTextLogger
bool PruneESCSequences = true
 
- Public Fields inherited from TextLogger
lib::strings::util::AutoSizes AutoSizes
 
ObjectConverterConverter = nullptr
 
String16 FmtMsgSuffix
 
String64 FmtMultiLineMsgHeadline = A_CHAR("ALox: Multi line message follows: ")
 
String16 FmtMultiLinePrefix = A_CHAR(">> ")
 
String16 FmtMultiLineSuffix = A_CHAR("")
 
textlogger::MetaInfoMetaInfo
 
AString MultiLineDelimiter
 
String16 MultiLineDelimiterRepl = A_CHAR("\\r")
 
int MultiLineMsgMode =2
 
- Public Fields inherited from Logger
integer CntLogs =0
 
lib::time::Ticks TimeOfCreation
 
lib::time::Ticks TimeOfLastLog
 
- Public Fields inherited from ThreadLock
NCString DbgOwnerFile =nullptr
 
NCString DbgOwnerFunc =nullptr
 
int DbgOwnerLine
 
uint16_t DbgRecursionWarningThreshold =10
 
integer DbgWarningAfterWaitTimeInMillis =2000L
 

Public Methods

ALIB_API TextFileLogger (const aworx::String &fileName, const aworx::NString &loggerName=nullptr)
 
virtual ~TextFileLogger () override
 
- Public Methods inherited from TextLogger
virtual ALIB_API ~TextLogger () override
 
virtual ALIB_API void AcknowledgeLox (LoxImpl *lox, ContainerOp op) override
 
virtual ALIB_API void ClearReplacements ()
 
virtual ALIB_API void Log (Domain &domain, Verbosity verbosity, Boxes &logables, ScopeInfo &scope) override
 
virtual ALIB_API void ResetAutoSizes ()
 
virtual ALIB_API void SetReplacement (const String &searched, const String &replacement)
 
- Public Methods inherited from Logger
virtual ~Logger ()
 
const NStringGetName () const
 
const NStringGetTypeName () const
 
- Public Methods inherited from SmartLock
 SmartLock ()
 
void Acquire (const NCString &dbgFile, int dbgLine, const NCString &dbgFunc)
 
ALIB_API int AddAcquirer (ThreadLock *newAcquirer)
 
ALIB_API int CntAcquirers ()
 
ALIB_API void Release ()
 defined(ALIB_DOX) More...
 
ALIB_API int RemoveAcquirer (ThreadLock *acquirer)
 
- Public Methods inherited from ThreadLock
ALIB_API ThreadLock (Safeness safeness=Safeness::Safe)
 
ALIB_API ~ThreadLock ()
 
ALIB_API void Acquire (const NCString &dbgFile, int dbgLine, const NCString &dbgFunc)
 
int CountAcquirements () const
 
ThreadGetOwner () const
 
Safeness GetSafeness () const
 
bool IsOwnedByCurrentThread () const
 
ALIB_API void Release ()
 defined(ALIB_DOX) More...
 
ALIB_API void SetSafeness (Safeness safeness)
 
bool WillRelease () const
 

Protected Fields

bool currentlyInMultiLineOp = false
 
StringWriter writer
 
- Protected Fields inherited from TextLogger
AString logBuf
 
AString msgBuf
 
std::vector< AStringreplacements
 
int stdStreamLockRegistrationCounter =0
 
bool usesStdStreams
 
- Protected Fields inherited from Logger
NString32 Name
 
NString32 TypeName
 
- Protected Fields inherited from SmartLock
std::vector< ThreadLock * > acquirers
 
ThreadLockNR lock
 
- Protected Fields inherited from ThreadLock
uint16_t cntAcquirements =0
 
std::mutex mutex
 
std::condition_variable mutexNotifier
 
std::thread::id owner
 
Safeness safeness
 

Protected Methods

ALIB_API void closeFile ()
 
virtual ALIB_API integer logSubstring (const String &buffer, integer start, integer length) override
 
virtual ALIB_API bool notifyLogOp (Phase phase) override
 
virtual ALIB_API void notifyMultiLineOp (Phase phase) override
 
ALIB_API void openFile ()
 
- Protected Methods inherited from PlainTextLogger
 PlainTextLogger (const NString &name, const NString &typeName, bool pUsesStdStreams)
 
virtual ~PlainTextLogger () override
 
virtual ALIB_API void logText (detail::Domain &domain, Verbosity verbosity, AString &msg, detail::ScopeInfo &scope, int lineNumber) override
 
- Protected Methods inherited from TextLogger
ALIB_API TextLogger (const NString &pName, const NString &typeName, bool pUsesStdStreams)
 
- Protected Methods inherited from Logger
 Logger (const NString &name, const NString &typeName)
 

Additional Inherited Members

- Public Types inherited from TextLogger
enum  LightColorUsage { Auto, Never, Foreground, Background }
 
- Public Static Fields inherited from SmartLock
static ALIB_API SmartLock StdOutputStreams
 

Constructor & Destructor Documentation

◆ TextFileLogger()

TextFileLogger ( const aworx::String fileName,
const aworx::NString loggerName = nullptr 
)
explicit

Creates a TextFileLogger.

Parameters
fileNameThe filename (potentially including a path) of the output log file.
loggerNameThe name of the Logger. Defaults to "TEXTFILE".

Definition at line 26 of file textfilelogger.cpp.

◆ ~TextFileLogger()

virtual ~TextFileLogger ( )
inlineoverridevirtual

Destructs a TextFileLogger

Definition at line 82 of file textfilelogger.hpp.

Member Function Documentation

◆ closeFile()

void closeFile ( )
protected

Closes the file.

Definition at line 67 of file textfilelogger.cpp.

Here is the call graph for this function:

◆ logSubstring()

integer logSubstring ( const String buffer,
integer  start,
integer  length 
)
overrideprotectedvirtual

Writes the given region of the given string to the console.

Parameters
bufferThe string to write a portion of.
startThe start of the portion in buffer to write out.
lengthThe length of the portion in buffer to write out.
Returns
The number of characters written, -1 on error.

Implements PlainTextLogger.

Definition at line 110 of file textfilelogger.cpp.

Here is the call graph for this function:

◆ notifyLogOp()

bool notifyLogOp ( Phase  phase)
overrideprotectedvirtual

Starts/ends log line. Appends a new-line character sequence to previously logged lines.

Parameters
phaseIndicates the beginning or end of a log line.
Returns
Always returns true.

Implements PlainTextLogger.

Definition at line 92 of file textfilelogger.cpp.

Here is the call graph for this function:

◆ notifyMultiLineOp()

void notifyMultiLineOp ( Phase  phase)
overrideprotectedvirtual

Empty implementation, not needed for this class

Parameters
phaseIndicates the beginning or end of a multi-line operation.

Implements TextLogger.

Definition at line 80 of file textfilelogger.cpp.

Here is the call graph for this function:

◆ openFile()

void openFile ( )
protected

Opens the file.

Definition at line 48 of file textfilelogger.cpp.

Here is the call graph for this function:

Member Data Documentation

◆ currentlyInMultiLineOp

bool currentlyInMultiLineOp = false
protected

Flag to prevent file open/close operations when multi line text logging is performed.

Definition at line 50 of file textfilelogger.hpp.

◆ FileName

aworx::AString FileName

The path and fileName to the log file.

Definition at line 58 of file textfilelogger.hpp.

◆ LastSystemError

Errors that usually indicate i/o problems. With construction of the logger, the file is tried to be opened and closed, which might indicate major problems (permissions, path, etc) with this public field very early.

Definition at line 63 of file textfilelogger.hpp.

◆ writer

StringWriter writer
protected

Encapsulates the text file stream in a system dependent way.

Definition at line 47 of file textfilelogger.hpp.


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