Apache Log4cxx  Version 1.7.0
Loading...
Searching...
No Matches
timebasedrollingpolicy.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
19#if !defined(_LOG4CXX_ROLLING_TIME_BASED_ROLLING_POLICY_H)
20#define _LOG4CXX_ROLLING_TIME_BASED_ROLLING_POLICY_H
21
26#include <functional>
27
28namespace LOG4CXX_NS
29{
30
31namespace rolling
32{
33
34
35
140class LOG4CXX_EXPORT TimeBasedRollingPolicy
141#if LOG4CXX_ABI_VERSION <= 15
142 : public virtual RollingPolicyBase
143 , public virtual TriggeringPolicy
144#else
145 : public RollingPolicyBase
146 , public virtual TriggeringPolicy
147#endif
148{
155
156 private:
157 LOG4CXX_DECLARE_PRIVATE_MEMBER_PTR(TimeBasedRollingPolicyPrivate, m_priv)
158
159 public:
162
172
173 void setMultiprocess(bool multiprocess);
174
178 RolloverDescriptionPtr initialize(
179 const LogString& currentActiveFile,
180 const bool append,
181 helpers::Pool& pool) override;
182
186 RolloverDescriptionPtr rollover(
187 const LogString& currentActiveFile,
188 const bool append,
189 helpers::Pool& pool) override;
190
203 Appender* appender,
204 const spi::LoggingEventPtr& event,
205 const LogString& filename,
206 size_t fileLength) override;
207
217 void setOption(const LogString& option, const LogString& value) override;
218
223
228
229 protected:
235 LOG4CXX_NS::pattern::PatternMap getFormatSpecifiers() const override;
236
237 private:
238
242 int createMMapFile(const std::string& lastfilename, LOG4CXX_NS::helpers::Pool& pool);
243
247 bool isMapFileEmpty(LOG4CXX_NS::helpers::Pool& pool);
248
252 void initMMapFile(const LogString& lastFileName, LOG4CXX_NS::helpers::Pool& pool);
253
257 int lockMMapFile(int type);
258
262 int unLockMMapFile();
263
267 const std::string createFile(const std::string& filename, const std::string& suffix, LOG4CXX_NS::helpers::Pool& pool);
268
269};
270
272
273}
274}
275
276#endif
277
Implement this interface for your own strategies for outputting log statements.
Definition appender.h:55
Definition pool.h:33
void activateOptions(helpers::Pool &) override
TimeBasedRollingPolicy is both easy to configure and quite powerful.
Definition timebasedrollingpolicy.h:148
bool isTriggeringEvent(Appender *appender, const spi::LoggingEventPtr &event, const LogString &filename, size_t fileLength) override
Determines if a rollover may be appropriate at this time.
void activateOptions(helpers::Pool &) override
RolloverDescriptionPtr rollover(const LogString &currentActiveFile, const bool append, helpers::Pool &pool) override
Prepare for a rollover.This method is called prior to closing the active log file,...
bool isLastFileNameUnchanged()
Was the name in shared memory set by this process?
RolloverDescriptionPtr initialize(const LogString &currentActiveFile, const bool append, helpers::Pool &pool) override
Initialize the policy and return any initial actions for rolling file appender.Description of the ini...
void setOption(const LogString &option, const LogString &value) override
Set option to value.
log4cxx::pattern::PatternMap getFormatSpecifiers() const override
A map from "d" and "date" to a date conversion formatter.
void setMultiprocess(bool multiprocess)
void loadLastFileName()
Load the name (set by some other process) from shared memory.
A TriggeringPolicy controls the conditions under which rollover occurs.
Definition triggeringpolicy.h:51
LOG4CXX_PTR_DEF(Action)
std::shared_ptr< LoggingEvent > LoggingEventPtr
Definition appender.h:32
std::basic_string< logchar > LogString
Definition logstring.h:60
#define LOG4CXX_CAST_ENTRY(Interface)
Definition object.h:154
#define END_LOG4CXX_CAST_MAP()
Definition object.h:148
#define DECLARE_LOG4CXX_OBJECT(object)
Definition object.h:41
#define LOG4CXX_CAST_ENTRY_CHAIN(Interface)
Definition object.h:160
#define BEGIN_LOG4CXX_CAST_MAP()
Definition object.h:142
#define LOG4CXX_ACTIVATE_OPTIONS_FORMAL_PARAMETERS
Activate the options that were previously set with calls to option setters.
Definition optionhandler.h:53