-
Notifications
You must be signed in to change notification settings - Fork 331
/
Bundle.java
94 lines (82 loc) · 2.99 KB
/
Bundle.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
package jmri.jmrix.easydcc.serialdriver;
import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import java.util.Locale;
import javax.annotation.CheckReturnValue;
import javax.annotation.CheckForNull;
import javax.annotation.ParametersAreNonnullByDefault;
@ParametersAreNonnullByDefault
@CheckReturnValue
@SuppressFBWarnings(value = "NM_SAME_SIMPLE_NAME_AS_SUPERCLASS",justification="Desired pattern is repeated class names with package-level access to members")
@javax.annotation.concurrent.Immutable
/**
* Provides standard access for resource bundles in a package.
*
* Convention is to provide a subclass of this name
* in each package, working off the local resource bundle name.
*
* @author Bob Jacobsen Copyright (C) 2012
* @since 3.7.2
*/
public class Bundle extends jmri.jmrix.easydcc.Bundle {
@CheckForNull private static final String name = null; // No local resources
//
// below here is boilerplate to be copied exactly
//
/**
* Provides a translated string for a given
* key from the package resource bundle or
* parent.
* <p>
* Note that this is intentionally package-local
* access.
*
* @param key Bundle key to be translated
* @return Internationalized text
*/
static String getMessage(String key) {
return getBundle().handleGetMessage(key);
}
/**
* Merges user data with a translated string for a given
* key from the package resource bundle or
* parent.
* <p>
* Uses the transformation conventions of
* the Java MessageFormat utility.
* <p>
* Note that this is intentionally package-local
* access.
*
* @see java.text.MessageFormat
* @param key Bundle key to be translated
* @param subs One or more objects to be inserted into the message
* @return Internationalized text
*/
static String getMessage(String key, Object ... subs) {
return getBundle().handleGetMessage(key, subs);
}
/**
* Merges user data with a translated string for a given key in a given
* locale from the package resource bundle or parent.
* <p>
* Uses the transformation conventions of the Java MessageFormat utility.
* <p>
* Note that this is intentionally package-local access.
*
* @see java.text.MessageFormat
* @param locale The locale to be used
* @param key Bundle key to be translated
* @param subs One or more objects to be inserted into the message
* @return Internationalized text
*/
static String getMessage(Locale locale, String key, Object... subs) {
return getBundle().handleGetMessage(locale, key, subs);
}
private final static Bundle b = new Bundle();
@Override @CheckForNull protected String bundleName() {return name; }
protected static jmri.Bundle getBundle() { return b; }
@Override
protected String retry(Locale locale,String key) {
return super.getBundle().handleGetMessage(locale,key);
}
}