/
ResourceBundleUtil.java
170 lines (152 loc) · 5.96 KB
/
ResourceBundleUtil.java
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
/*
* Copyright 2012-2024 CodeLibs Project and the Others.
*
* Licensed 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.
*/
package org.codelibs.core.io;
import static org.codelibs.core.collection.CollectionsUtil.newHashMap;
import static org.codelibs.core.misc.AssertionUtil.assertArgumentNotEmpty;
import static org.codelibs.core.misc.AssertionUtil.assertArgumentNotNull;
import java.util.Enumeration;
import java.util.Locale;
import java.util.Map;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import org.codelibs.core.misc.LocaleUtil;
/**
* {@link ResourceBundle}用のユーティリティクラスです。
*
* @author higa
*/
public abstract class ResourceBundleUtil {
/**
* バンドルを返します。 見つからない場合は、<code>null</code>を返します。
*
* @param name
* リソースバンドの名前。{@literal null}や空文字列であってはいけません
* @return {@link ResourceBundle}
* @see ResourceBundle#getBundle(String)
*/
public static final ResourceBundle getBundle(final String name) {
assertArgumentNotEmpty("name", name);
try {
return ResourceBundle.getBundle(name);
} catch (final MissingResourceException ignore) {
return null;
}
}
/**
* バンドルを返します。 見つからない場合は、<code>null</code>を返します。
*
* @param name
* リソースバンドの名前。{@literal null}や空文字列であってはいけません
* @param locale
* ロケール
* @return {@link ResourceBundle}
* @see ResourceBundle#getBundle(String, Locale)
*/
public static final ResourceBundle getBundle(final String name, final Locale locale) {
assertArgumentNotEmpty("name", name);
try {
return ResourceBundle.getBundle(name, getLocale(locale));
} catch (final MissingResourceException ignore) {
return null;
}
}
/**
* バンドルを返します。 見つからない場合は、<code>null</code>を返します。
*
* @param name
* リソースバンドルの名前。{@literal null}や空文字列であってはいけません
* @param locale
* ロケール
* @param classLoader
* クラスローダ。{@literal null}や空文字列であってはいけません
* @return {@link ResourceBundle}
* @see ResourceBundle#getBundle(String, Locale, ClassLoader)
*/
public static final ResourceBundle getBundle(final String name, final Locale locale, final ClassLoader classLoader) {
assertArgumentNotNull("name", name);
assertArgumentNotNull("classLoader", classLoader);
try {
return ResourceBundle.getBundle(name, getLocale(locale), classLoader);
} catch (final MissingResourceException ignore) {
return null;
}
}
/**
* リソースバンドルから指定されたキーの文字列を返します。
*
* @param bundle
* リソースバンドル。{@literal null}や空文字列であってはいけません
* @param key
* キー
* @return 指定されたキーの文字列。{@literal null}や空文字列であってはいけません
* @see ResourceBundle#getString(String)
*/
public static String getString(final ResourceBundle bundle, final String key) {
assertArgumentNotNull("bundle", bundle);
assertArgumentNotEmpty("key", key);
try {
return bundle.getString(key);
} catch (final Throwable t) {
return null;
}
}
/**
* リソースバンドルを{@link Map}に変換します。
*
* @param bundle
* リソースバンドル。{@literal null}であってはいけません
* @return {@link Map}
*/
public static final Map<String, String> convertMap(final ResourceBundle bundle) {
assertArgumentNotNull("bundle", bundle);
final Map<String, String> ret = newHashMap();
for (final Enumeration<String> e = bundle.getKeys(); e.hasMoreElements();) {
final String key = e.nextElement();
final String value = bundle.getString(key);
ret.put(key, value);
}
return ret;
}
/**
* リソースバンドルを{@link Map}に変換して返します。
*
* @param name
* リソースバンドルの名前。{@literal null}や空文字列であってはいけません
* @param locale
* ロケール
* @return {@link Map}
*/
public static final Map<String, String> convertMap(final String name, final Locale locale) {
assertArgumentNotEmpty("name", name);
final ResourceBundle bundle = getBundle(name, locale);
return convertMap(bundle);
}
/**
* {@literal locale}が{@literal null}でなければ{@literal locale}を、{@literal null}
* ならデフォルトのロケールを返します。
*
* @param locale
* ロケール
* @return {@literal locale}が{@literal null}でなければ{@literal locale}を、
* {@literal null}ならデフォルトのロケールを返します。
*/
protected static Locale getLocale(final Locale locale) {
if (locale != null) {
return locale;
}
return LocaleUtil.getDefault();
}
}