diff --git a/src/main/java/com/gtnewhorizon/gtnhlib/config/Config.java b/src/main/java/com/gtnewhorizon/gtnhlib/config/Config.java index 117ebd9..7fb45e1 100644 --- a/src/main/java/com/gtnewhorizon/gtnhlib/config/Config.java +++ b/src/main/java/com/gtnewhorizon/gtnhlib/config/Config.java @@ -56,6 +56,13 @@ @interface LangKeyPattern { String pattern() default "%mod.%cat.%field"; + + /** + * Whether subcategories should use their fully qualified name.
+ * Fully qualified: {@code category.category1.category2}
+ * Normal: {@code category2} + */ + boolean fullyQualified() default false; } @Retention(RetentionPolicy.RUNTIME) diff --git a/src/main/java/com/gtnewhorizon/gtnhlib/config/ConfigurationManager.java b/src/main/java/com/gtnewhorizon/gtnhlib/config/ConfigurationManager.java index 7e6ad3d..425d68f 100644 --- a/src/main/java/com/gtnewhorizon/gtnhlib/config/ConfigurationManager.java +++ b/src/main/java/com/gtnewhorizon/gtnhlib/config/ConfigurationManager.java @@ -25,6 +25,7 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; +import org.jetbrains.annotations.NotNull; import cpw.mods.fml.client.config.IConfigElement; import lombok.AccessLevel; @@ -139,7 +140,7 @@ private static void processSubCategory(Object instance, Configuration config, Fi subCategoryField.getType(), subCategoryField.getAnnotation(Config.LangKey.class), null, - subCat.getName()); + subCat); subCat.setComment(comment); subCat.setLanguageKey(langKey); @@ -206,7 +207,7 @@ private static void processConfigInternal(Class configClass, String category, configClass, field.getAnnotation(Config.LangKey.class), ConfigFieldParser.getFieldName(field), - category); + cat); ConfigFieldParser.loadField(instance, field, rawConfig, category, langKey); if (!requiresMcRestart) { @@ -223,7 +224,7 @@ private static void processConfigInternal(Class configClass, String category, } if (category.isEmpty()) return; - val langKey = getLangKey(configClass, configClass.getAnnotation(Config.LangKey.class), null, cat.getName()); + val langKey = getLangKey(configClass, configClass.getAnnotation(Config.LangKey.class), null, cat); cat.setLanguageKey(langKey); cat.setRequiresMcRestart(requiresMcRestart); cat.setRequiresWorldRestart(requiresWorldRestart); @@ -345,11 +346,11 @@ private static IConfigElementProxy getProxyElement(IConfigElement element, } private static String getLangKey(Class configClass, @Nullable Config.LangKey langKey, @Nullable String fieldName, - String categoryName) throws ConfigException { + @NotNull ConfigCategory category) throws ConfigException { if (langKey != null) return langKey.value(); Config.LangKeyPattern pattern = getClassOrBaseAnnotation(configClass, Config.LangKeyPattern.class); - String name = Optional.ofNullable(fieldName).orElse(categoryName); + String name = Optional.ofNullable(fieldName).orElse(category.getName()); if (pattern == null) return name; String patternStr = pattern.pattern(); @@ -361,6 +362,7 @@ private static String getLangKey(Class configClass, @Nullable Config.LangKey // Config annotation can't be null at this point assert cfg != null; + String categoryName = pattern.fullyQualified() ? category.getQualifiedName() : category.getName(); return buildKeyFromPattern(patternStr, cfg.modid(), cfg.filename(), categoryName, name); }