This file is indexed.

/usr/include/log4cxx/pattern/patternconverter.h is in liblog4cxx-dev 0.10.0-12.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef _LOG4CXX_PATTERN_PATTERN_CONVERTER_H
#define _LOG4CXX_PATTERN_PATTERN_CONVERTER_H


#include <log4cxx/helpers/objectimpl.h>
#include <log4cxx/logstring.h>
#include <vector>

#ifdef _MSC_VER
//   disable identifier too wide for debugging warning
#pragma warning ( disable: 4231 4251 4275 4786 )
#endif

#define DECLARE_LOG4CXX_PATTERN(cls) DECLARE_ABSTRACT_LOG4CXX_OBJECT(cls)

namespace log4cxx {
  namespace pattern {

  typedef std::vector<LogString> OptionsList;

/**

   <p>PatternConverter is an abstract class that provides the
   formatting functionality that derived classes need.

   <p>Conversion specifiers in a conversion patterns are parsed to
   individual PatternConverters. Each of which is responsible for
   converting an object in a converter specific manner.
   
 */
class LOG4CXX_EXPORT PatternConverter : public virtual log4cxx::helpers::ObjectImpl {

  /**
   * Converter name.
   */
  const LogString name;

  /**
   * Converter style name.
   */
  const LogString style;


protected:
  /**
   * Create a new pattern converter.
   * @param name name for pattern converter.
   * @param style CSS style for formatted output.
   */
  PatternConverter(const LogString& name,
         const LogString& style);

  virtual ~PatternConverter();

public:
  DECLARE_LOG4CXX_PATTERN(PatternConverter)
  BEGIN_LOG4CXX_CAST_MAP()
          LOG4CXX_CAST_ENTRY(PatternConverter)
  END_LOG4CXX_CAST_MAP()

  /**
   * Formats an object into a string buffer.
   * @param obj event to format, may not be null.
   * @param toAppendTo string buffer to which the formatted event will be appended.  May not be null.
   * @param p pool for any allocations necessary during formatting.
   */
  virtual void format(const log4cxx::helpers::ObjectPtr& obj,
      LogString& toAppendTo,
      log4cxx::helpers::Pool& p) const = 0;

  /**
   * This method returns the name of the conversion pattern.
   *
   * The name can be useful to certain Layouts such as HTMLLayout.
   *
   * @return        the name of the conversion pattern
   */
  LogString getName() const;

  /**
   * This method returns the CSS style class that should be applied to
   * the LoggingEvent passed as parameter, which can be null.
   *
   * This information is currently used only by HTMLLayout.
   *
   * @param e null values are accepted
   * @return  the name of the conversion pattern
   */
  virtual LogString getStyleClass(const log4cxx::helpers::ObjectPtr& e) const;

protected:
/**
* Appends content in the locale code page to a LogString.
* @param toAppendTo string to which content is appended.
* @param src content.
*/
  static void append(LogString& toAppendTo, const std::string& src);
};


LOG4CXX_PTR_DEF(PatternConverter);

  }
}


#endif