Coverage Report

Created: 2026-03-12 07:00

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/logging-log4cxx/src/main/cpp/ndcpatternconverter.cpp
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
#include <log4cxx/logstring.h>
19
#include <log4cxx/pattern/ndcpatternconverter.h>
20
#include <log4cxx/spi/loggingevent.h>
21
#include <log4cxx/spi/location/locationinfo.h>
22
23
using namespace LOG4CXX_NS;
24
using namespace LOG4CXX_NS::pattern;
25
using namespace LOG4CXX_NS::spi;
26
using namespace LOG4CXX_NS::helpers;
27
28
IMPLEMENT_LOG4CXX_OBJECT(NDCPatternConverter)
29
30
NDCPatternConverter::NDCPatternConverter() :
31
1.34k
  LoggingEventPatternConverter(LOG4CXX_STR("NDC"),
32
1.34k
    LOG4CXX_STR("ndc"))
33
1.34k
{
34
1.34k
}
Unexecuted instantiation: log4cxx::pattern::NDCPatternConverter::NDCPatternConverter()
log4cxx::pattern::NDCPatternConverter::NDCPatternConverter()
Line
Count
Source
31
1.34k
  LoggingEventPatternConverter(LOG4CXX_STR("NDC"),
32
1.34k
    LOG4CXX_STR("ndc"))
33
1.34k
{
34
1.34k
}
35
36
PatternConverterPtr NDCPatternConverter::newInstance(
37
  const std::vector<LogString>& /* options */)
38
1.32k
{
39
1.32k
  return std::make_shared<NDCPatternConverter>();
40
1.32k
}
log4cxx::pattern::NDCPatternConverter::newInstance(std::__1::vector<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >, std::__1::allocator<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > > > const&)
Line
Count
Source
38
651
{
39
651
  return std::make_shared<NDCPatternConverter>();
40
651
}
log4cxx::pattern::NDCPatternConverter::newInstance(std::__1::vector<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> >, std::__1::allocator<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> > > > const&)
Line
Count
Source
38
673
{
39
673
  return std::make_shared<NDCPatternConverter>();
40
673
}
41
42
void NDCPatternConverter::format(
43
  const LoggingEventPtr& event,
44
  LogString& toAppendTo,
45
  Pool& /* p */) const
46
17
{
47
17
  LogString value;
48
17
  if (event->getNDC(value))
49
0
  {
50
0
    auto& info = getFormattingInfo();
51
0
    if (info.getMaxLength() < value.length())
52
0
      toAppendTo.append(value.substr(value.length() - info.getMaxLength()));
53
0
    else
54
0
      toAppendTo.append(value);
55
0
  }
56
17
  else
57
17
  {
58
17
    toAppendTo.append(LOG4CXX_STR("null"));
59
17
  }
60
17
}
log4cxx::pattern::NDCPatternConverter::format(std::__1::shared_ptr<log4cxx::spi::LoggingEvent> const&, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> >&, log4cxx::helpers::Pool&) const
Line
Count
Source
46
9
{
47
9
  LogString value;
48
9
  if (event->getNDC(value))
49
0
  {
50
0
    auto& info = getFormattingInfo();
51
0
    if (info.getMaxLength() < value.length())
52
0
      toAppendTo.append(value.substr(value.length() - info.getMaxLength()));
53
0
    else
54
0
      toAppendTo.append(value);
55
0
  }
56
9
  else
57
9
  {
58
9
    toAppendTo.append(LOG4CXX_STR("null"));
59
9
  }
60
9
}
log4cxx::pattern::NDCPatternConverter::format(std::__1::shared_ptr<log4cxx::spi::LoggingEvent> const&, std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> >&, log4cxx::helpers::Pool&) const
Line
Count
Source
46
8
{
47
8
  LogString value;
48
8
  if (event->getNDC(value))
49
0
  {
50
0
    auto& info = getFormattingInfo();
51
0
    if (info.getMaxLength() < value.length())
52
0
      toAppendTo.append(value.substr(value.length() - info.getMaxLength()));
53
0
    else
54
0
      toAppendTo.append(value);
55
0
  }
56
8
  else
57
8
  {
58
8
    toAppendTo.append(LOG4CXX_STR("null"));
59
8
  }
60
8
}