Mirror von
https://github.com/IntellectualSites/FastAsyncWorldEdit.git
synchronisiert 2025-01-12 02:20:51 +01:00
Allow translation files to be missing entries, and use the english version in place.
Dieser Commit ist enthalten in:
Ursprung
5d0335eea5
Commit
625be46b30
@ -76,12 +76,17 @@ public class TranslationManager {
|
|||||||
this.defaultLocale = defaultLocale;
|
this.defaultLocale = defaultLocale;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Map<String, String> filterTranslations(Map<String, String> translations) {
|
||||||
|
translations.entrySet().removeIf(entry -> entry.getValue().isEmpty());
|
||||||
|
return translations;
|
||||||
|
}
|
||||||
|
|
||||||
private Map<String, String> parseTranslationFile(File file) throws IOException {
|
private Map<String, String> parseTranslationFile(File file) throws IOException {
|
||||||
return gson.fromJson(Files.toString(file, StandardCharsets.UTF_8), STRING_MAP_TYPE);
|
return filterTranslations(gson.fromJson(Files.toString(file, StandardCharsets.UTF_8), STRING_MAP_TYPE));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Map<String, String> parseTranslationFile(URL file) throws IOException {
|
private Map<String, String> parseTranslationFile(URL file) throws IOException {
|
||||||
return gson.fromJson(Resources.toString(file, StandardCharsets.UTF_8), STRING_MAP_TYPE);
|
return filterTranslations(gson.fromJson(Resources.toString(file, StandardCharsets.UTF_8), STRING_MAP_TYPE));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Optional<Map<String, String>> loadTranslationFile(String filename) {
|
private Optional<Map<String, String>> loadTranslationFile(String filename) {
|
||||||
@ -112,12 +117,18 @@ public class TranslationManager {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
checkedLocales.add(locale);
|
checkedLocales.add(locale);
|
||||||
|
// Make a copy of the default language file
|
||||||
|
Map<String, String> baseTranslations = new HashMap<>();
|
||||||
|
if (!locale.equals(defaultLocale)) {
|
||||||
|
baseTranslations.putAll(getTranslationMap(defaultLocale));
|
||||||
|
}
|
||||||
Optional<Map<String, String>> langData = loadTranslationFile(locale.getLanguage() + "-" + locale.getCountry() + "/strings.json");
|
Optional<Map<String, String>> langData = loadTranslationFile(locale.getLanguage() + "-" + locale.getCountry() + "/strings.json");
|
||||||
if (!langData.isPresent()) {
|
if (!langData.isPresent()) {
|
||||||
langData = loadTranslationFile(locale.getLanguage() + "/strings.json");
|
langData = loadTranslationFile(locale.getLanguage() + "/strings.json");
|
||||||
}
|
}
|
||||||
if (langData.isPresent()) {
|
if (langData.isPresent()) {
|
||||||
translationMap.put(locale, langData.get());
|
baseTranslations.putAll(langData.get());
|
||||||
|
translationMap.put(locale, baseTranslations);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (locale.equals(defaultLocale)) {
|
if (locale.equals(defaultLocale)) {
|
||||||
|
Laden…
x
In neuem Issue referenzieren
Einen Benutzer sperren