Coverage Report

Created: 2025-07-12 06:12

/src/logging-log4cxx/src/main/include/log4cxx/helpers/resourcebundle.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
#ifndef _LOG4CXX_HELPERS_RESOURCE_BUNDLE_H
19
#define _LOG4CXX_HELPERS_RESOURCE_BUNDLE_H
20
21
#include <log4cxx/helpers/object.h>
22
23
namespace LOG4CXX_NS
24
{
25
namespace helpers
26
{
27
class Locale;
28
29
class ResourceBundle;
30
LOG4CXX_PTR_DEF(ResourceBundle);
31
32
/**
33
Resource bundles contain locale-specific objects
34
*/
35
class LOG4CXX_EXPORT ResourceBundle : public Object
36
{
37
  public:
38
    DECLARE_ABSTRACT_LOG4CXX_OBJECT(ResourceBundle)
39
0
    BEGIN_LOG4CXX_CAST_MAP()
40
0
    LOG4CXX_CAST_ENTRY(ResourceBundle)
41
0
    END_LOG4CXX_CAST_MAP()
42
43
    /**
44
    Gets a string for the given key from this resource bundle or one of
45
    its parents. Calling this method is equivalent to calling
46
47
    @param key the key for the desired string
48
    @return the string for the given key
49
    @throw MissingResourceException - if no object for the given key
50
    can be found
51
    */
52
    virtual LogString getString(const LogString& key) const = 0;
53
54
    /**
55
    Gets a resource bundle using the specified base name and locale
56
57
    @param baseName the base name of the resource bundle, a fully
58
    qualified class name or property filename
59
    @param locale the locale for which a resource bundle is desired
60
    */
61
    static ResourceBundlePtr getBundle(const LogString& baseName,
62
      const Locale& locale);
63
64
  protected:
65
    /*
66
    Sets the parent bundle of this bundle. The parent bundle is
67
    searched by #getString when this bundle does not contain a particular
68
    resource.
69
70
    Parameters:
71
    parent - this bundle's parent bundle.
72
    */
73
    inline void setParent(const ResourceBundlePtr& parent1)
74
0
    {
75
0
      this->parent = parent1;
76
0
    }
77
78
    /**
79
    The parent bundle of this bundle.
80
81
    The parent bundle is searched by #getString when this bundle does
82
    not contain a particular resource.
83
    */
84
    LOG4CXX_DECLARE_PRIVATE_MEMBER(ResourceBundlePtr, parent)
85
86
}; // class ResourceBundle
87
}  // namespace helpers
88
} // namespace log4cxx
89
90
#endif
91