Apache log4cxx Version 0.13.0
filterbasedtriggeringpolicy.h
Go to the documentation of this file.
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one or more
3 * contributor license agreements. See the NOTICE file distributed with
4 * this work for additional information regarding copyright ownership.
5 * The ASF licenses this file to You under the Apache License, Version 2.0
6 * (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#if !defined(_LOG4CXX_ROLLING_FILTER_BASED_TRIGGERING_POLICY_H)
19#define _LOG4CXX_ROLLING_FILTER_BASED_TRIGGERING_POLICY_H
20
22#include <log4cxx/spi/filter.h>
23
24namespace log4cxx
25{
26
27class File;
28
29namespace helpers
30{
31class Pool;
32}
33
34
35namespace rolling
36{
37
38
48class LOG4CXX_EXPORT FilterBasedTriggeringPolicy : public TriggeringPolicy
49{
50
56
57
60 log4cxx::spi::FilterPtr headFilter;
61
65 log4cxx::spi::FilterPtr tailFilter;
66
67 public:
73
85 virtual bool isTriggeringEvent(
86 Appender* appender,
88 const LogString& filename,
89 size_t fileLength);
90
95 void addFilter(const log4cxx::spi::FilterPtr& newFilter);
96
102
108
113
114 void setOption(const LogString& option, const LogString& value);
115};
116
118
119}
120}
121
122#endif
Implement this interface for your own strategies for outputting log statements.
Definition: appender.h:57
Definition: pool.h:33
FilterBasedTriggeringPolicy determines if rolling should be triggered by evaluating the current messa...
Definition: filterbasedtriggeringpolicy.h:49
void clearFilters()
Clear the filters chain.
void addFilter(const log4cxx::spi::FilterPtr &newFilter)
Add a filter to end of the filter list.
void activateOptions(log4cxx::helpers::Pool &)
Prepares the instance for use.
virtual bool isTriggeringEvent(Appender *appender, const log4cxx::spi::LoggingEventPtr &event, const LogString &filename, size_t fileLength)
Determines if a rollover may be appropriate at this time.
log4cxx::spi::FilterPtr & getFilter()
Returns the head Filter.
void setOption(const LogString &option, const LogString &value)
Set option to value.
FilterBasedTriggeringPolicy()
Creates a new FilterBasedTriggeringPolicy.
A TriggeringPolicy controls the conditions under which rollover occurs.
Definition: triggeringpolicy.h:47
LOG4CXX_PTR_DEF(Action)
std::shared_ptr< Filter > FilterPtr
Definition: appender.h:41
std::shared_ptr< LoggingEvent > LoggingEventPtr
Definition: appender.h:38
Definition: messagehandler.h:23
std::basic_string< logchar > LogString
Definition: logstring.h:66
#define LOG4CXX_CAST_ENTRY(Interface)
Definition: object.h:153
#define END_LOG4CXX_CAST_MAP()
Definition: object.h:147
#define DECLARE_LOG4CXX_OBJECT(object)
Definition: object.h:39
#define LOG4CXX_CAST_ENTRY_CHAIN(Interface)
Definition: object.h:159
#define BEGIN_LOG4CXX_CAST_MAP()
Definition: object.h:141