Coverage Report

Created: 2026-03-19 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/logging-log4cxx/src/main/include/log4cxx/pattern/propertiespatternconverter.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
#ifndef _LOG4CXX_PATTERN_PROPERTIES_PATTERN_CONVERTER
19
#define _LOG4CXX_PATTERN_PROPERTIES_PATTERN_CONVERTER
20
21
#include <log4cxx/pattern/loggingeventpatternconverter.h>
22
23
namespace LOG4CXX_NS
24
{
25
namespace pattern
26
{
27
28
29
/**
30
 * Able to handle the contents of the LoggingEvent's Property bundle and either
31
 * output the entire contents of the properties in a similar format to the
32
 * java.util.Hashtable.toString(), or to output the value of a specific key
33
 * within the property bundle
34
 * when this pattern converter has the option set.
35
 *
36
 *
37
 *
38
 */
39
class LOG4CXX_EXPORT PropertiesPatternConverter
40
  : public LoggingEventPatternConverter
41
{
42
    struct PropertiesPatternConverterPrivate;
43
44
  public:
45
    DECLARE_LOG4CXX_PATTERN(PropertiesPatternConverter)
46
0
    BEGIN_LOG4CXX_CAST_MAP()
47
0
    LOG4CXX_CAST_ENTRY(PropertiesPatternConverter)
48
0
    LOG4CXX_CAST_ENTRY_CHAIN(LoggingEventPatternConverter)
49
0
    END_LOG4CXX_CAST_MAP()
50
51
    /**
52
     * A Property bundle converter.
53
     *
54
     * @param name of the converter.
55
     * @param option may be null.
56
     */
57
    PropertiesPatternConverter(const LogString& name, const LogString& option);
58
59
    /**
60
     * Obtains an instance of PropertiesPatternConverter.
61
     * @param options options, may be null or first element contains name of property to format.
62
     * @return instance of PropertiesPatternConverter.
63
     */
64
    static PatternConverterPtr newInstance(
65
      const std::vector<LogString>& options);
66
67
    using LoggingEventPatternConverter::format;
68
69
    void format(const spi::LoggingEventPtr& event,
70
      LogString& toAppendTo,
71
      LOG4CXX_NS::helpers::Pool& p) const override;
72
};
73
}
74
}
75
#endif
76