|
@@ -3,14 +3,25 @@ package com.gmail.nossr50.locale;
|
|
import com.gmail.nossr50.mcMMO;
|
|
import com.gmail.nossr50.mcMMO;
|
|
import org.bukkit.ChatColor;
|
|
import org.bukkit.ChatColor;
|
|
|
|
|
|
|
|
+import java.io.IOException;
|
|
|
|
+import java.io.Reader;
|
|
|
|
+import java.nio.file.Files;
|
|
|
|
+import java.nio.file.Path;
|
|
|
|
+import java.nio.file.Paths;
|
|
import java.text.MessageFormat;
|
|
import java.text.MessageFormat;
|
|
|
|
+import java.util.HashMap;
|
|
import java.util.Locale;
|
|
import java.util.Locale;
|
|
|
|
+import java.util.Map;
|
|
import java.util.MissingResourceException;
|
|
import java.util.MissingResourceException;
|
|
|
|
+import java.util.PropertyResourceBundle;
|
|
import java.util.ResourceBundle;
|
|
import java.util.ResourceBundle;
|
|
|
|
+import java.util.logging.Level;
|
|
|
|
|
|
public final class LocaleLoader {
|
|
public final class LocaleLoader {
|
|
private static final String BUNDLE_ROOT = "com.gmail.nossr50.locale.locale";
|
|
private static final String BUNDLE_ROOT = "com.gmail.nossr50.locale.locale";
|
|
|
|
+ private static Map<String, String> bundleCache = new HashMap<>();
|
|
private static ResourceBundle bundle = null;
|
|
private static ResourceBundle bundle = null;
|
|
|
|
+ private static ResourceBundle filesystemBundle = null;
|
|
private static ResourceBundle enBundle = null;
|
|
private static ResourceBundle enBundle = null;
|
|
|
|
|
|
private LocaleLoader() {
|
|
private LocaleLoader() {
|
|
@@ -32,23 +43,44 @@ public final class LocaleLoader {
|
|
initialize();
|
|
initialize();
|
|
}
|
|
}
|
|
|
|
|
|
- try {
|
|
|
|
- return getString(key, bundle, messageArguments);
|
|
|
|
- } catch (MissingResourceException ex) {
|
|
|
|
- try {
|
|
|
|
- return getString(key, enBundle, messageArguments);
|
|
|
|
- } catch (MissingResourceException ex2) {
|
|
|
|
- if (!key.contains("Guides")) {
|
|
|
|
- mcMMO.p.getLogger().warning("Could not find locale string: " + key);
|
|
|
|
- }
|
|
|
|
|
|
+ String rawMessage = bundleCache.computeIfAbsent(key, LocaleLoader::getRawString);
|
|
|
|
+ return formatString(rawMessage, messageArguments);
|
|
|
|
+ }
|
|
|
|
|
|
- return '!' + key + '!';
|
|
|
|
|
|
+ /**
|
|
|
|
+ * Reloads locale
|
|
|
|
+ */
|
|
|
|
+ public static void reloadLocale() {
|
|
|
|
+ bundle = null;
|
|
|
|
+ filesystemBundle = null;
|
|
|
|
+ enBundle = null;
|
|
|
|
+ bundleCache = new HashMap<>(); // Cheaper to replace than clear()
|
|
|
|
+ initialize();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ private static String getRawString(String key) {
|
|
|
|
+ if (filesystemBundle != null) {
|
|
|
|
+ try {
|
|
|
|
+ return filesystemBundle.getString(key);
|
|
}
|
|
}
|
|
|
|
+ catch (MissingResourceException ignored) {}
|
|
}
|
|
}
|
|
- }
|
|
|
|
|
|
|
|
- private static String getString(String key, ResourceBundle bundle, Object... messageArguments) throws MissingResourceException {
|
|
|
|
- return formatString(bundle.getString(key), messageArguments);
|
|
|
|
|
|
+ try {
|
|
|
|
+ return bundle.getString(key);
|
|
|
|
+ }
|
|
|
|
+ catch (MissingResourceException ignored) {}
|
|
|
|
+
|
|
|
|
+ try {
|
|
|
|
+ return enBundle.getString(key);
|
|
|
|
+ }
|
|
|
|
+ catch (MissingResourceException ignored) {
|
|
|
|
+ if (!key.contains("Guides")) {
|
|
|
|
+ mcMMO.p.getLogger().warning("Could not find locale string: " + key);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return '!' + key + '!';
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
public static String formatString(String string, Object... messageArguments) {
|
|
public static String formatString(String string, Object... messageArguments) {
|
|
@@ -82,6 +114,19 @@ public final class LocaleLoader {
|
|
locale = new Locale(myLocale[0], myLocale[1]);
|
|
locale = new Locale(myLocale[0], myLocale[1]);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if (locale == null) {
|
|
|
|
+ throw new IllegalStateException("Failed to parse locale string '" + mcMMO.getConfigManager().getConfigLanguage().getTargetLanguage() + "'");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ Path localePath = Paths.get(mcMMO.getLocalesDirectory() + "locale_" + locale.toString() + ".properties");
|
|
|
|
+ if (Files.exists(localePath) && Files.isRegularFile(localePath)) {
|
|
|
|
+ try (Reader localeReader = Files.newBufferedReader(localePath)) {
|
|
|
|
+ mcMMO.p.getLogger().log(Level.INFO, "Loading locale from {0}", localePath);
|
|
|
|
+ filesystemBundle = new PropertyResourceBundle(localeReader);
|
|
|
|
+ } catch (IOException e) {
|
|
|
|
+ mcMMO.p.getLogger().log(Level.WARNING, "Failed to load locale from " + localePath, e);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
bundle = ResourceBundle.getBundle(BUNDLE_ROOT, locale);
|
|
bundle = ResourceBundle.getBundle(BUNDLE_ROOT, locale);
|
|
enBundle = ResourceBundle.getBundle(BUNDLE_ROOT, Locale.US);
|
|
enBundle = ResourceBundle.getBundle(BUNDLE_ROOT, Locale.US);
|
|
}
|
|
}
|