Coverage Report

Created: 2025-08-24 06:21

/src/logging-log4cxx/src/main/include/log4cxx/rolling/manualtriggeringpolicy.h
Line
Count
Source (jump to first uncovered line)
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_MANUAL_TRIGGERING_POLICY_H)
19
#define _LOG4CXX_ROLLING_MANUAL_TRIGGERING_POLICY_H
20
21
#include <log4cxx/rolling/triggeringpolicy.h>
22
23
namespace LOG4CXX_NS
24
{
25
26
class File;
27
28
namespace helpers
29
{
30
class Pool;
31
}
32
33
namespace rolling
34
{
35
36
/**
37
 * ManualTriggeringPolicy only rolls over on explicit calls to
38
 * RollingFileAppender.rollover().
39
 *
40
 *
41
 *
42
 */
43
class LOG4CXX_EXPORT ManualTriggeringPolicy : public TriggeringPolicy
44
{
45
    DECLARE_LOG4CXX_OBJECT(ManualTriggeringPolicy)
46
0
    BEGIN_LOG4CXX_CAST_MAP()
47
0
    LOG4CXX_CAST_ENTRY(ManualTriggeringPolicy)
48
0
    LOG4CXX_CAST_ENTRY_CHAIN(TriggeringPolicy)
49
0
    END_LOG4CXX_CAST_MAP()
50
51
  public:
52
    ManualTriggeringPolicy();
53
    /**
54
     * Determines if a rollover may be appropriate at this time.  If
55
     * true is returned, RolloverPolicy.rollover will be called but it
56
     * can determine that a rollover is not warranted.
57
     *
58
     * @param appender A reference to the appender.
59
     * @param event A reference to the currently event.
60
     * @param filename The filename for the currently active log file.
61
     * @param fileLength Length of the file in bytes.
62
     * @return true if a rollover should occur.
63
     */
64
    bool isTriggeringEvent(
65
      Appender* appender,
66
      const spi::LoggingEventPtr& event,
67
      const LogString& filename,
68
      size_t fileLength) override;
69
70
    /**
71
    \copybrief spi::OptionHandler::activateOptions()
72
73
    No action is performed in this implementation.
74
    */
75
    void activateOptions(helpers::Pool&) override;
76
77
    /**
78
    \copybrief spi::OptionHandler::setOption()
79
80
    Supported options | Supported values | Default value |
81
    -------------- | ---------------- | --------------- |
82
    - | - | - |
83
    */
84
    void setOption(const LogString& option, const LogString& value) override;
85
};
86
}
87
}
88
#endif
89