From 6dea4ecb95b56ccba200cd35696dd5f850f209b6 Mon Sep 17 00:00:00 2001 From: Rsl1122 Date: Thu, 10 Aug 2017 15:07:01 +0300 Subject: [PATCH] Fix issues with new Locale. --- .../java/com/djrapitops/plan/Settings.java | 2 +- .../com/djrapitops/plan/locale/Locale.java | 36 +++++++++++-------- 2 files changed, 22 insertions(+), 16 deletions(-) diff --git a/Plan/src/main/java/com/djrapitops/plan/Settings.java b/Plan/src/main/java/com/djrapitops/plan/Settings.java index 70686c466..2e666638b 100644 --- a/Plan/src/main/java/com/djrapitops/plan/Settings.java +++ b/Plan/src/main/java/com/djrapitops/plan/Settings.java @@ -25,7 +25,7 @@ public enum Settings { COMBINE_COMMAND_ALIASES_TO_MAIN_COMMAND("Customization.Data.CombineCommandAliasesToMainCommand"), SECURITY_IP_UUID("Settings.WebServer.Security.DisplayIPsAndUUIDs"), PLAYERLIST_SHOW_IMAGES("Customization.SmallHeadImagesOnAnalysisPlayerlist"), - WRITE_NEW_LOCALE("WriteNewLocaleFileOnStart"), + WRITE_NEW_LOCALE("Settings.WriteNewLocaleFileOnStart"), // Integer ANALYSIS_MINUTES_FOR_ACTIVE("Settings.Analysis.MinutesPlayedUntilConsidiredActive"), SAVE_CACHE_MIN("Settings.Cache.DataCache.SaveEveryXMinutes"), diff --git a/Plan/src/main/java/com/djrapitops/plan/locale/Locale.java b/Plan/src/main/java/com/djrapitops/plan/locale/Locale.java index 9e3a2810f..68be5c89e 100644 --- a/Plan/src/main/java/com/djrapitops/plan/locale/Locale.java +++ b/Plan/src/main/java/com/djrapitops/plan/locale/Locale.java @@ -17,6 +17,7 @@ import org.bukkit.ChatColor; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; +import java.nio.charset.StandardCharsets; import java.nio.file.Files; import java.util.HashMap; import java.util.List; @@ -42,20 +43,25 @@ public class Locale { messages = new HashMap<>(); } - public void loadLocale() throws IOException { + public void loadLocale() { String locale = Settings.LOCALE.toString().toUpperCase(); Benchmark.start("Initializing locale"); loadDefault(); - if (Settings.WRITE_NEW_LOCALE.isTrue()) { - writeNewDefaultLocale(); - } - File localeFile = new File(plugin.getDataFolder(), "locale.txt"); - if (localeFile.exists()) { - loadFromFile(localeFile); - } else if (locale.equals("DEFAULT")) { - Log.info("Using Locale: Default (EN)"); - } else { - loadFromResource("locale_" + locale + ".txt"); + try { + if (Settings.WRITE_NEW_LOCALE.isTrue()) { + writeNewDefaultLocale(); + } + File localeFile = new File(plugin.getDataFolder(), "locale.txt"); + if (localeFile.exists()) { + loadFromFile(localeFile); + } else if (locale.equals("DEFAULT")) { + Log.info("Using Locale: Default (EN)"); + } else { + loadFromResource("locale_" + locale + ".txt"); + } + } catch (IOException e) { + Log.toLog(this.getClass().getName(), e); + } Benchmark.stop("Enable", "Initializing locale"); } @@ -68,9 +74,9 @@ public class Locale { .get().length() + 2; List lines = messages.entrySet().stream() .sorted(new LocaleEntryComparator()) - .map(entry -> getSpacedIdentifier(entry.getKey().getIdentifier(), length) + "| " + entry.getValue().toString()) + .map(entry -> getSpacedIdentifier(entry.getKey().getIdentifier(), length) + "|| " + entry.getValue().toString()) .collect(Collectors.toList()); - Files.write(new File(plugin.getDataFolder(), "locale.txt").toPath(), lines); + Files.write(new File(plugin.getDataFolder(), "locale.txt").toPath(), lines, StandardCharsets.UTF_8); plugin.getConfig().set(Settings.WRITE_NEW_LOCALE.getPath(), false); } @@ -278,7 +284,7 @@ public class Locale { } private void loadFromFile(File localeFile) throws IOException { - loadFromContents(Files.lines(localeFile.toPath()).collect(Collectors.toList()), "Custom File"); + loadFromContents(Files.lines(localeFile.toPath(), StandardCharsets.UTF_8).collect(Collectors.toList()), "Custom File"); } private void loadFromResource(String fileName) { @@ -297,7 +303,7 @@ public class Locale { Log.info("Using Locale: " + name); Map identifiers = Msg.getIdentifiers(); locale.forEach(line -> { - String[] split = line.split(" \\| "); + String[] split = line.split(" \\|\\| "); if (split.length == 2) { String identifier = split[0].trim(); Msg msg = identifiers.get(identifier);