FBB::LogBuf(3bobcat)
log messages stream buffer
(libbobcat-dev_6.06.02)
2005-2024
NAME
FBB::LogBuf -  std::streambuf handling log messages
SYNOPSIS
    #include <bobcat/logbuf>
    Linking option: -lbobcat
DESCRIPTION
FBB::LogBuf is a class derived from std::streambuf handling log
messages. The stream to log to, timestamps and log-levels can be configured
both at construction time and beyond. The FBB::LogBuf may be used to
initialize a std::ostream.
NAMESPACE
    FBB
    All constructors, members, operators and manipulators, mentioned in this
man-page, are defined in the namespace FBB.
INHERITS FROM
    std::streambuf
ENUMERATIONS
    The enumeration TimeStamps is defined in the namespace FBB to be
used when initializing FBB::LogBuf objects. It has the following
values:
    
    -  NOTIMESTAMPS:
 Log-messages will not have timestamps prepended to them.
-  TIMESTAMPS:
 Log-messages will have timestamps prepended to them.
-  UTCTIMESTAMPS:
 Log-messages will have timestamps showing the UTC time prepended to
        them.
The enumeration Active is used to distinguish between suspending
message insertion when a message's level does not exceed a minimum level and
suspending all message insertions (e.g., when suspending inserting messages
into FBB::Log objects after calling their off member):
    
    -  OFF:
 All insertions into the LogBuf object are suspended;
-  NOT_ACTIVE:
 Insertions of messages into the LogBuf object are suspended if
        their levels are less than the a specified minimum (as set by, e.g.,
        Log::setLevel).
-  ACTIVE:
 Messages are inserted
CONSTRUCTORS
    
    -  LogBuf(TimeStamps timestamps = TIMESTAMPS,
                bool active = true,
                char const *delim = " "):
 This constructor constructs an FBB::LogBuf object writing its
log-messages to std::cerr. If the active parameter is initialized to
false no messages will be logged until the buffer's activity is switched
on (see setActive() below).  The parameter delim is inserted
immediately beyond the time stamp. If a delimiter is inappropriate, an empty
string or a 0-pointer may be specified. When stamps == FBB::NOTIMESTAMPS
delim is ignored. A time stamp consists of the month, the day number of the
month and the (local) time of the current message, as usually appearing in
messages in /var/log files. E.g., Aug 5 13:52:23;
 
-  LogBuf(std::ostream &stream,
                TimeStamps timestamps = TIMESTAMPS,
                bool active = true,
                char const *delim = " "):
 This constructor constructs an FBB::LogBuf object writing its
log-messages to the stream used to initialize its stream parameter. If the
active parameter is initialized to false no messages will be logged
until the buffer's activity is switched on (see setActive() below). The
parameter delim is inserted immediately beyond the time stamp. If a
delimiter is inappropriate, an empty string or a 0-pointer may be
specified. When stamps == FBB::NOTIMESTAMPS delim is ignored. A time stamp
consists of the month, the day number of the month and the (local) time of the
current message, as usually appearing in messages in /var/log files. E.g.,
Aug 5 13:52:23.
Copy and move constructors (and assignment operators) are not available.
PUBLIC MEMBER FUNCTIONS
     All members of std::streambuf are available, as FBB::LogBuf
inherits from this class.
    
    -  bool active() const:
 Returns true if log-messages are currently processed;
 
-  bool empty() const:
 Returns true if the object's buffer is currently empty (initially
or after a newline character has been inserted);
 
-  void setStream(std::ostream &stream):
 This member may be used to switch the stream to log to. It is the
responsibility of the programmer to ensure that the external stream remains
available for as long as log-messages are inserted into it;
 
-  void settimestamp(FBB::TimeStamps timestamps,
                char const *delim = " "):
 The member function (de)activates time stamp prepending. Use the value
FBB::TIMESTAMPS to prepend time stamps, FBB::NOTIMESTAMPS suppresses
time stamps.   A time stamp consists of the month, the day number of the month
and the (local) time of the current message, as usually appearing in messages
in /var/log files. E.g., Aug 5 13:52:23. The parameter delim is
inserted immediately beyond the time stamp. If a delimiter is inappropriate,
an empty string or a 0-pointer may be specified. When stamps ==
FBB::NOTIMESTAMPS delim is ignored;
 
-  void setActive(bool active):
 Unless the current object's Active state is OFF this member
can be used to (de)activate logging. The argument true activates logging,
the argument false deactivates it. If the current Active status is
OFF then this member does not change the object's activity status. This
member is normally called by FBB::Log::level members;
 
-  void setActive(Active active):
 The member function (de)activates logging. The argument ACTIVE
activates logging, the argument OFF completely suppresses logging, the
argument NOT_ACTIVE also suppresses logging, but here setActive(true)
can also be used reactivate logging;
 
-  void setEmpty(bool empty):
 This member may be called to ensure that a timestamp is inserted
before the next insertion. It is called as setEmpty(true) when a newline
character (\n) is inserted, ensuring that another timestamp is prepended
before the next insertion.
EXAMPLE
    
#include <iostream>
#include <iomanip>
#include <bobcat/log>
#include <bobcat/level>
using namespace std;
using namespace FBB;
int main()
{
    LogBuf buffer(cout, FBB::TIMESTAMPS);
    ostream log(&buffer);
    log << "This message is written to cout" << nl <<
           setw(16) << ' ' << "occupying multiple lines\n";
    buffer.setActive(false);
    log << "one line\n";
    log << "more lines ";
    log << fnl;
    log << "another\n";
    buffer.setActive(true);
    log << "and active again\n";
    log << "another log msg\n";
}
FILES
    bobcat/logbuf - defines the class interface
SEE ALSO
    bobcat(7), log(3bobcat)
BUGS
    None Reported.
BOBCAT PROJECT FILES
    -  https://fbb-git.gitlab.io/bobcat/: gitlab project page;
    
-  bobcat_6.06.02-x.dsc: detached signature;
    
-  bobcat_6.06.02-x.tar.gz: source archive;
    
-  bobcat_6.06.02-x_i386.changes: change log;
    
-  libbobcat1_6.06.02-x_*.deb: debian package containing the
            libraries;
    
-  libbobcat1-dev_6.06.02-x_*.deb: debian package containing the
            libraries, headers and manual pages;
    
BOBCAT
    Bobcat is an acronym of `Brokken's Own Base Classes And Templates'.
COPYRIGHT
    This is free software, distributed under the terms of the
    GNU General Public License (GPL).
AUTHOR
    Frank B. Brokken (f.b.brokken@rug.nl).