Coverage Report

Created: 2026-05-30 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/logging-log4cxx/src/main/include/log4cxx/rolling/manualtriggeringpolicy.h
Line
Count
Source
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
    using TriggeringPolicy::activateOptions;
71
    /**
72
    \copybrief TriggeringPolicy::activateOptions()
73
74
    No action is performed in this implementation.
75
    */
76
    void activateOptions( LOG4CXX_ACTIVATE_OPTIONS_FORMAL_PARAMETERS ) override;
77
78
    /**
79
    \copybrief spi::OptionHandler::setOption()
80
81
    Supported options | Supported values | Default value |
82
    -------------- | ---------------- | --------------- |
83
    - | - | - |
84
    */
85
    void setOption(const LogString& option, const LogString& value) override;
86
};
87
}
88
}
89
#endif
90