115 lines
3.0 KiB
C++

/*
* AppenderSkeleton.hh
*
* Copyright 2001, LifeLine Networks BV (www.lifeline.nl). All rights reserved.
* Copyright 2001, Bastiaan Bakker. All rights reserved.
*
* See the COPYING file for the terms of usage and distribution.
*/
#ifndef _LOG4CPP_APPENDERSKELETON_HH
#define _LOG4CPP_APPENDERSKELETON_HH
#include <log4cpp/Portability.hh>
#include <log4cpp/Appender.hh>
#include <log4cpp/Filter.hh>
LOG4CPP_NS_BEGIN
/**
* AppenderSkeleton is a helper class, simplifying implementation of
* Appenders: it already takes care of handling of Thresholds and
* Filters.
**/
class LOG4CPP_EXPORT AppenderSkeleton : public Appender {
protected:
/**
* Constructor for AppenderSkeleton. Will only be used in
* getAppender() (and in derived classes of course).
* @param name The name of this Appender.
**/
AppenderSkeleton(const std::string& name);
public:
/**
* Destructor for AppenderSkeleton.
**/
virtual ~AppenderSkeleton();
/**
* Log in Appender specific way.
* @param event The LoggingEvent to log.
**/
virtual void doAppend(const LoggingEvent& event);
/**
* Reopens the output destination of this Appender, e.g. the logfile
* or TCP socket.
* @returns false if an error occured during reopening, true otherwise.
**/
virtual bool reopen();
/**
* Release any resources allocated within the appender such as file
* handles, network connections, etc.
**/
virtual void close() = 0;
/**
* Check if the appender uses a layout.
*
* @returns true if the appender implementation requires a layout.
**/
virtual bool requiresLayout() const = 0;
/**
* Set the Layout for this appender.
* @param layout The layout to use.
**/
virtual void setLayout(Layout* layout) = 0;
/**
* Set the threshold priority of this Appender. The Appender will not
* appender LoggingEvents with a priority lower than the threshold.
* Use Priority::NOTSET to disable threshold checking.
* @param priority The priority to set.
**/
virtual void setThreshold(Priority::Value priority);
/**
* Get the threshold priority of this Appender.
* @returns the threshold
**/
virtual Priority::Value getThreshold();
/**
* Set a Filter for this appender.
**/
virtual void setFilter(Filter* filter);
/**
* Get the Filter for this appender.
* @returns the filter, or NULL if no filter has been set.
**/
virtual Filter* getFilter();
protected:
/**
* Log in Appender specific way. Subclasses of Appender should
* implement this method to perform actual logging.
* @param event The LoggingEvent to log.
**/
virtual void _append(const LoggingEvent& event) = 0;
private:
Priority::Value _threshold;
Filter* _filter;
private:
// suppress assignment operator
AppenderSkeleton & operator=(const AppenderSkeleton &);
};
LOG4CPP_NS_END
#endif // _LOG4CPP_APPENDERSKELETON_HH