Merge pull request #3910 from mikroskeem/feature/locales-in-plugin-data-folder

Try to load locale from plugin data folder first
This commit is contained in:
Robert A. C 2019-04-30 10:33:28 -07:00 committed by GitHub
commit 0c8b001d05
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 57 additions and 17 deletions

View File

@ -4,14 +4,25 @@ import com.gmail.nossr50.config.Config;
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,14 +43,27 @@ public final class LocaleLoader {
initialize(); initialize();
} }
try { String rawMessage = bundleCache.computeIfAbsent(key, LocaleLoader::getRawString);
return getString(key, bundle, messageArguments); return formatString(rawMessage, messageArguments);
} }
catch (MissingResourceException ex) {
private static String getRawString(String key) {
if (filesystemBundle != null) {
try { try {
return getString(key, enBundle, messageArguments); return filesystemBundle.getString(key);
} }
catch (MissingResourceException ex2) { catch (MissingResourceException ignored) {}
}
try {
return bundle.getString(key);
}
catch (MissingResourceException ignored) {}
try {
return enBundle.getString(key);
}
catch (MissingResourceException ignored) {
if (!key.contains("Guides")) { if (!key.contains("Guides")) {
mcMMO.p.getLogger().warning("Could not find locale string: " + key); mcMMO.p.getLogger().warning("Could not find locale string: " + key);
} }
@ -47,11 +71,6 @@ public final class LocaleLoader {
return '!' + key + '!'; return '!' + key + '!';
} }
} }
}
private static String getString(String key, ResourceBundle bundle, Object... messageArguments) throws MissingResourceException {
return formatString(bundle.getString(key), messageArguments);
}
public static String formatString(String string, Object... messageArguments) { public static String formatString(String string, Object... messageArguments) {
if (messageArguments != null) { if (messageArguments != null) {
@ -85,6 +104,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 '" + Config.getInstance().getLocale() + "'");
}
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);
} }

View File

@ -79,6 +79,7 @@ public class mcMMO extends JavaPlugin {
/* File Paths */ /* File Paths */
private static String mainDirectory; private static String mainDirectory;
private static String localesDirectory;
private static String flatFileDirectory; private static String flatFileDirectory;
private static String usersFile; private static String usersFile;
private static String modDirectory; private static String modDirectory;
@ -357,6 +358,10 @@ public class mcMMO extends JavaPlugin {
return mainDirectory; return mainDirectory;
} }
public static String getLocalesDirectory() {
return localesDirectory;
}
public static String getFlatFileDirectory() { public static String getFlatFileDirectory() {
return flatFileDirectory; return flatFileDirectory;
} }
@ -432,6 +437,7 @@ public class mcMMO extends JavaPlugin {
private void setupFilePaths() { private void setupFilePaths() {
mcmmo = getFile(); mcmmo = getFile();
mainDirectory = getDataFolder().getPath() + File.separator; mainDirectory = getDataFolder().getPath() + File.separator;
localesDirectory = mainDirectory + "locales" + File.separator;
flatFileDirectory = mainDirectory + "flatfile" + File.separator; flatFileDirectory = mainDirectory + "flatfile" + File.separator;
usersFile = flatFileDirectory + "mcmmo.users"; usersFile = flatFileDirectory + "mcmmo.users";
modDirectory = mainDirectory + "mods" + File.separator; modDirectory = mainDirectory + "mods" + File.separator;
@ -485,6 +491,8 @@ public class mcMMO extends JavaPlugin {
File currentFlatfilePath = new File(flatFileDirectory); File currentFlatfilePath = new File(flatFileDirectory);
currentFlatfilePath.mkdirs(); currentFlatfilePath.mkdirs();
File localesDirectoryPath = new File(localesDirectory);
localesDirectoryPath.mkdirs();
} }
private void loadConfigFiles() { private void loadConfigFiles() {