Standard Java-ResourceBundles har temmelig utilstrækkelige pladskarakteristika. Da en igangværende Eclipse har en tendens til at have mange eksterne meddelelser, er der implementeret en ny meddelelsesbundthistorie, der kan anvendes i Eclipse. Mekanismen er ganske enkel og fuldstændig generisk - den kan anvendes alle vegne.
messages.properties
- Denne fil er den samme som før med undtagelse af, at alle nøgler skal være gyldige Java-id'er.public static String
, hvis navn er det samme som meddelelsesnøglen.
messages.properties
.Messages.java
.messages.properties
, hvor nøglenavnet matcher feltnavnet.
Messages.my_key
) i stedet for standardopslaget.
public class MyClass {
public void myMethod() {
Strengmeddelelse:
...
// no args
message = Messages.getString("key.one"); //$NON-NLS-1$
...
// bind one arg
message = MessageFormat.format(Messages.getString("key.two"), new Object[] {"eksempelbrug"}); //$NON-NLS-1$ //$NON-NLS-2$
...
}
}
public class MyClass {
public void myMethod() {
Strengmeddelelse:
...
// no args
message = Messages.key_one;
...
// bind one arg
message = NLS.bind(Messages.key_two, "eksempelbrug"); //$NON-NLS-1$
...
}
}
public class Messages {
private static final String BUNDLE_NAME = "org.eclipse.core.utils.messages"; //$NON-NLS-1$
private static final ResourceBundle bundle = ResourceBundle.getBundle(BUNDLE_NAME);
public static String getString(String key) {
try {
return bundle.getString(key);
} catch (MissingResourceException e) {
return key;
}
}
}
import org.eclipse.osgi.util.NLS;
public class Messages extends NLS {
private static final String BUNDLE_NAME = "org.eclipse.core.utils.messages"; //$NON-NLS-1$
public static String key_one;
public static String key_two;
...
static {
NLS.initializeMessages(BUNDLE_NAME, Messages.class);
}
}
key.one = Hello world. key.two = Dette er en {0} af bindingen med en parameter.
key_one = Hello world. key_two = Dette er en {0} af bindingen med en parameter.