File: nullappender.h

package info (click to toggle)
log4cxx 0.9.7-6.1
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 4,620 kB
  • ctags: 2,766
  • sloc: cpp: 18,909; sh: 8,896; xml: 1,146; makefile: 480; ansic: 159
file content (64 lines) | stat: -rwxr-xr-x 1,810 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
/*
 * Copyright 2003,2004 The Apache Software Foundation.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef _LOG4CXX_PERFORMANCE_NULL_APPENDER_H
#define _LOG4CXX_PERFORMANCE_NULL_APPENDER_H

#include <log4cxx/config.h>
#include <log4cxx/helpers/tchar.h>
#include <log4cxx/appenderskeleton.h>


namespace log4cxx
{
	class Layout;
	typedef helpers::ObjectPtrT<Layout> LayoutPtr;

	namespace performance
	{
		class NullAppender;
		typedef helpers::ObjectPtrT<NullAppender> NullAppenderPtr;

		/**
		* A bogus appender which calls the format method of its layout object
		* but does not write the result anywhere.
		* */
		class NullAppender : public AppenderSkeleton
		{
		public:
			StringBuffer sbuf;

			DECLARE_LOG4CXX_OBJECT(NullAppender)
			BEGIN_LOG4CXX_CAST_MAP()
				LOG4CXX_CAST_ENTRY(NullAppender)
				LOG4CXX_CAST_ENTRY_CHAIN(AppenderSkeleton)
			END_LOG4CXX_CAST_MAP()

			NullAppender();
			NullAppender(const LayoutPtr& layout);
			void close();
			void doAppend(const spi::LoggingEventPtr& event);
			void append(const spi::LoggingEventPtr& event);

			/**
			This is a bogus appender but it still uses a layout.
			*/
			bool requiresLayout() const;
		}; // NullAppender
	}  // namespace performance
}; // namespace log4cxx

#endif //_LOG4CXX_PERFORMANCE_NULL_APPENDER_H