| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- // -*- C++ -*-
- // Module: Log4cplus
- // File: asyncappender.h
- // Created: 1/2009
- // Author: Vaclav Haisman
- //
- //
- // Copyright (C) 2009-2017, Vaclav Haisman. All rights reserved.
- //
- // Redistribution and use in source and binary forms, with or without modifica-
- // tion, are permitted provided that the following conditions are met:
- //
- // 1. Redistributions of source code must retain the above copyright notice,
- // this list of conditions and the following disclaimer.
- //
- // 2. Redistributions in binary form must reproduce the above copyright notice,
- // this list of conditions and the following disclaimer in the documentation
- // and/or other materials provided with the distribution.
- //
- // THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
- // INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
- // FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- // APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
- // INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
- // DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
- // OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
- // ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- //
- /** @file */
- #ifndef LOG4CPLUS_ASYNCAPPENDER_H
- #define LOG4CPLUS_ASYNCAPPENDER_H
- #include <log4cplus/config.hxx>
- #if defined (LOG4CPLUS_HAVE_PRAGMA_ONCE)
- #pragma once
- #endif
- #ifndef LOG4CPLUS_SINGLE_THREADED
- #include <log4cplus/helpers/queue.h>
- #include <log4cplus/appender.h>
- #include <log4cplus/thread/threads.h>
- #include <log4cplus/helpers/appenderattachableimpl.h>
- namespace log4cplus
- {
- /**
- This `Appender` is a wrapper to which other appenders can be attached. The
- attached appendres are then appended to from a separate thread which reads
- events appended to this appender from a queue.
- <h3>Properties</h3>
- <dl>
- <dt><tt>QueueLimit</tt></dt>
- <dd>Events queue size limit. Default is 100.</dd>
- </dt>
- <dt><tt>Appender</tt></dt>
- <dd>`Appender` and its properties to use as sink for logged events.</dd>
- </dt>
- </dl>
- \sa helpers::AppenderAttachableImpl
- */
- class LOG4CPLUS_EXPORT AsyncAppender
- : public Appender
- , public helpers::AppenderAttachableImpl
- {
- public:
- AsyncAppender (SharedAppenderPtr const & app, unsigned max_len);
- AsyncAppender (helpers::Properties const &);
- virtual ~AsyncAppender ();
- virtual void close ();
- protected:
- virtual void append (spi::InternalLoggingEvent const &);
- void init_queue_thread (unsigned);
- thread::AbstractThreadPtr queue_thread;
- thread::QueuePtr queue;
- private:
- AsyncAppender (AsyncAppender const &);
- AsyncAppender & operator = (AsyncAppender const &);
- };
- typedef helpers::SharedObjectPtr<AsyncAppender> AsyncAppenderPtr;
- } // namespace log4cplus
- #endif // LOG4CPLUS_SINGLE_THREADED
- #endif // LOG4CPLUS_ASYNCAPPENDER_H
|