mirror of
https://github.com/BentoBoxWorld/BentoBox.git
synced 2025-01-12 03:13:33 +01:00
Makes console output more useful - just copy and paste missing YAML
This commit is contained in:
parent
650e370ffe
commit
765f6adfce
@ -1,7 +1,7 @@
|
|||||||
package world.bentobox.bentobox.managers;
|
package world.bentobox.bentobox.managers;
|
||||||
|
|
||||||
import net.md_5.bungee.api.ChatColor;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.configuration.file.YamlConfiguration;
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
import world.bentobox.bentobox.BentoBox;
|
import world.bentobox.bentobox.BentoBox;
|
||||||
import world.bentobox.bentobox.api.addons.Addon;
|
import world.bentobox.bentobox.api.addons.Addon;
|
||||||
@ -32,6 +32,7 @@ public class LocalesManager {
|
|||||||
private Map<Locale, BentoBoxLocale> languages = new HashMap<>();
|
private Map<Locale, BentoBoxLocale> languages = new HashMap<>();
|
||||||
private static final String LOCALE_FOLDER = "locales";
|
private static final String LOCALE_FOLDER = "locales";
|
||||||
private static final String BENTOBOX = "BentoBox";
|
private static final String BENTOBOX = "BentoBox";
|
||||||
|
private static final String SPACER = "*************************************************";
|
||||||
|
|
||||||
public LocalesManager(BentoBox plugin) {
|
public LocalesManager(BentoBox plugin) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
@ -252,16 +253,16 @@ public class LocalesManager {
|
|||||||
|
|
||||||
User user = User.getInstance(Bukkit.getConsoleSender());
|
User user = User.getInstance(Bukkit.getConsoleSender());
|
||||||
|
|
||||||
user.sendRawMessage(ChatColor.AQUA + "*************************************************");
|
user.sendRawMessage(ChatColor.AQUA + SPACER);
|
||||||
plugin.log(ChatColor.AQUA + "Analyzing BentoBox locale files");
|
plugin.log(ChatColor.AQUA + "Analyzing BentoBox locale files");
|
||||||
user.sendRawMessage(ChatColor.AQUA + "*************************************************");
|
user.sendRawMessage(ChatColor.AQUA + SPACER);
|
||||||
loadLocalesFromFile(BENTOBOX);
|
loadLocalesFromFile(BENTOBOX);
|
||||||
analyze(fix);
|
analyze(fix);
|
||||||
user.sendRawMessage(ChatColor.AQUA + "Analyzing Addon locale files");
|
user.sendRawMessage(ChatColor.AQUA + "Analyzing Addon locale files");
|
||||||
plugin.getAddonsManager().getAddons().forEach(addon -> {
|
plugin.getAddonsManager().getAddons().forEach(addon -> {
|
||||||
user.sendRawMessage(ChatColor.AQUA + "*************************************************");
|
user.sendRawMessage(ChatColor.AQUA + SPACER);
|
||||||
user.sendRawMessage(ChatColor.AQUA + "Analyzing addon " + addon.getDescription().getName());
|
user.sendRawMessage(ChatColor.AQUA + "Analyzing addon " + addon.getDescription().getName());
|
||||||
user.sendRawMessage(ChatColor.AQUA + "*************************************************");
|
user.sendRawMessage(ChatColor.AQUA + SPACER);
|
||||||
languages.clear();
|
languages.clear();
|
||||||
loadLocalesFromFile(addon.getDescription().getName());
|
loadLocalesFromFile(addon.getDescription().getName());
|
||||||
analyze(fix);
|
analyze(fix);
|
||||||
@ -285,25 +286,26 @@ public class LocalesManager {
|
|||||||
languages.forEach((k,v) -> user.sendRawMessage(ChatColor.GOLD + k.toLanguageTag() + " " + k.getDisplayLanguage() + " " + k.getDisplayCountry()));
|
languages.forEach((k,v) -> user.sendRawMessage(ChatColor.GOLD + k.toLanguageTag() + " " + k.getDisplayLanguage() + " " + k.getDisplayCountry()));
|
||||||
// Start with US English
|
// Start with US English
|
||||||
YamlConfiguration usConfig = languages.get(Locale.US).getConfig();
|
YamlConfiguration usConfig = languages.get(Locale.US).getConfig();
|
||||||
|
// Fix config
|
||||||
|
YamlConfiguration fixConfig = new YamlConfiguration();
|
||||||
languages.values().stream().filter(l -> !l.toLanguageTag().equals(Locale.US.toLanguageTag())).forEach(l -> {
|
languages.values().stream().filter(l -> !l.toLanguageTag().equals(Locale.US.toLanguageTag())).forEach(l -> {
|
||||||
System.out.println(l.toLanguageTag());
|
user.sendRawMessage(ChatColor.GREEN + SPACER);
|
||||||
user.sendRawMessage(ChatColor.GREEN + "*************************************************");
|
|
||||||
user.sendRawMessage(ChatColor.GREEN + "Analyzing locale file " + l.toLanguageTag() + ":");
|
user.sendRawMessage(ChatColor.GREEN + "Analyzing locale file " + l.toLanguageTag() + ":");
|
||||||
YamlConfiguration c = l.getConfig();
|
YamlConfiguration c = l.getConfig();
|
||||||
boolean complete = true;
|
boolean complete = true;
|
||||||
for (String path : usConfig.getKeys(true)) {
|
for (String path : usConfig.getKeys(true)) {
|
||||||
if (!c.contains(path, true)) {
|
if (!c.contains(path, true)) {
|
||||||
complete = false;
|
complete = false;
|
||||||
user.sendRawMessage(ChatColor.RED + "Missing " + path);
|
fixConfig.set(path, user.getTranslationOrNothing(path));
|
||||||
if (fix) {
|
|
||||||
// TODO: add an option to add missing strings to locale files.
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (complete) {
|
if (complete) {
|
||||||
user.sendRawMessage(ChatColor.GREEN + "Language file covers all strings.");
|
user.sendRawMessage(ChatColor.GREEN + "Language file covers all strings.");
|
||||||
|
} else {
|
||||||
|
user.sendRawMessage(ChatColor.RED + "The following YAML is missing. Please translate it:");
|
||||||
|
plugin.log("\n" + fixConfig.saveToString());
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user