mirror of
https://github.com/mcMMO-Dev/mcMMO.git
synced 2024-11-23 05:36:46 +01:00
Refactor LocaleLoader a bit
This commit is contained in:
parent
bbfbe1e72c
commit
c13593def1
@ -10,8 +10,8 @@ import org.bukkit.ChatColor;
|
|||||||
import com.gmail.nossr50.config.Config;
|
import com.gmail.nossr50.config.Config;
|
||||||
|
|
||||||
public final class LocaleLoader {
|
public final class LocaleLoader {
|
||||||
private static final String BUNDLE_NAME = "com.gmail.nossr50.locale.locale";
|
private static final String BUNDLE_ROOT = "com.gmail.nossr50.locale.locale";
|
||||||
private static ResourceBundle RESOURCE_BUNDLE = null;
|
private static ResourceBundle bundle = null;
|
||||||
|
|
||||||
private LocaleLoader() {};
|
private LocaleLoader() {};
|
||||||
|
|
||||||
@ -27,23 +27,12 @@ public final class LocaleLoader {
|
|||||||
* @return The properly formatted locale string
|
* @return The properly formatted locale string
|
||||||
*/
|
*/
|
||||||
public static String getString(String key, Object ... messageArguments) {
|
public static String getString(String key, Object ... messageArguments) {
|
||||||
|
if (bundle == null) {
|
||||||
|
initialize();
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (RESOURCE_BUNDLE == null) {
|
String output = bundle.getString(key);
|
||||||
Locale.setDefault(new Locale("en", "US"));
|
|
||||||
Locale locale = null;
|
|
||||||
String[] myLocale = Config.getInstance().getLocale().split("[-_ ]");
|
|
||||||
|
|
||||||
if (myLocale.length == 1) {
|
|
||||||
locale = new Locale(myLocale[0]);
|
|
||||||
}
|
|
||||||
else if (myLocale.length >= 2) {
|
|
||||||
locale = new Locale(myLocale[0], myLocale[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
RESOURCE_BUNDLE = ResourceBundle.getBundle(BUNDLE_NAME, locale);
|
|
||||||
}
|
|
||||||
|
|
||||||
String output = RESOURCE_BUNDLE.getString(key);
|
|
||||||
|
|
||||||
if (messageArguments != null) {
|
if (messageArguments != null) {
|
||||||
MessageFormat formatter = new MessageFormat("");
|
MessageFormat formatter = new MessageFormat("");
|
||||||
@ -60,6 +49,30 @@ public final class LocaleLoader {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Locale getCurrentLocale() {
|
||||||
|
if (bundle == null) {
|
||||||
|
initialize();
|
||||||
|
}
|
||||||
|
return bundle.getLocale();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void initialize() {
|
||||||
|
if (bundle == null) {
|
||||||
|
Locale.setDefault(new Locale("en", "US"));
|
||||||
|
Locale locale = null;
|
||||||
|
String[] myLocale = Config.getInstance().getLocale().split("[-_ ]");
|
||||||
|
|
||||||
|
if (myLocale.length == 1) {
|
||||||
|
locale = new Locale(myLocale[0]);
|
||||||
|
}
|
||||||
|
else if (myLocale.length >= 2) {
|
||||||
|
locale = new Locale(myLocale[0], myLocale[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
bundle = ResourceBundle.getBundle(BUNDLE_ROOT, locale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static String addColors(String input) {
|
private static String addColors(String input) {
|
||||||
input = input.replaceAll("\\Q[[BLACK]]\\E", ChatColor.BLACK.toString());
|
input = input.replaceAll("\\Q[[BLACK]]\\E", ChatColor.BLACK.toString());
|
||||||
input = input.replaceAll("\\Q[[DARK_BLUE]]\\E", ChatColor.DARK_BLUE.toString());
|
input = input.replaceAll("\\Q[[DARK_BLUE]]\\E", ChatColor.DARK_BLUE.toString());
|
||||||
|
@ -564,4 +564,3 @@ public class mcMMO extends JavaPlugin {
|
|||||||
xpEventEnabled = !xpEventEnabled;
|
xpEventEnabled = !xpEventEnabled;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user