Skip to content

Commit

Permalink
UpdateExtensionDocPageMojo is broken, fix apache#6418
Browse files Browse the repository at this point in the history
  • Loading branch information
ppalaga authored and jamesnetherton committed Oct 23, 2024
1 parent a847c8b commit e051a44
Showing 1 changed file with 13 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,11 @@
import io.quarkus.annotation.processor.documentation.config.merger.JavadocMerger;
import io.quarkus.annotation.processor.documentation.config.merger.JavadocRepository;
import io.quarkus.annotation.processor.documentation.config.merger.MergedModel;
import io.quarkus.annotation.processor.documentation.config.merger.MergedModel.ConfigRootKey;
import io.quarkus.annotation.processor.documentation.config.merger.ModelMerger;
import io.quarkus.annotation.processor.documentation.config.model.AbstractConfigItem;
import io.quarkus.annotation.processor.documentation.config.model.ConfigProperty;
import io.quarkus.annotation.processor.documentation.config.model.ConfigProperty.PropertyPath;
import io.quarkus.annotation.processor.documentation.config.model.ConfigRoot;
import io.quarkus.annotation.processor.documentation.config.model.Extension;
import io.quarkus.annotation.processor.documentation.config.model.JavadocElements.JavadocElement;
Expand Down Expand Up @@ -87,10 +89,8 @@ public class UpdateExtensionDocPageMojo extends AbstractDocGeneratorMojo {
private static final String TOOLTIP_MACRO = "tooltip:%s[%s]";
private static final String MORE_INFO_ABOUT_TYPE_FORMAT = "link:#%s[icon:question-circle[title=More information about the %s format]]";

// TODO: Revert the default back to false
// https://github.com/apache/camel-quarkus/issues/6418
@Parameter(defaultValue = "true", property = "camel-quarkus.update-extension-doc-page.skip")
boolean skip = true;
@Parameter(defaultValue = "false", property = "camel-quarkus.update-extension-doc-page.skip")
boolean skip = false;

@Parameter(defaultValue = "${project}", readonly = true)
MavenProject project;
Expand Down Expand Up @@ -487,10 +487,9 @@ static List<ConfigItem> listConfigOptions(Path runtimeModuleDir, Path deployment

final JavadocRepository javadocRepository = JavadocMerger.mergeJavadocElements(targetDirectories);
final MergedModel mergedModel = ModelMerger.mergeModel(targetDirectories);
for (Entry<Extension, Map<MergedModel.ConfigRootKey, ConfigRoot>> extensionConfigRootsEntry : mergedModel
.getConfigRoots().entrySet()) {
for (Entry<MergedModel.ConfigRootKey, ConfigRoot> configRootEntry : extensionConfigRootsEntry.getValue()
.entrySet()) {
for (Entry<Extension, Map<ConfigRootKey, ConfigRoot>> extensionConfigRootsEntry : mergedModel.getConfigRoots()
.entrySet()) {
for (Entry<ConfigRootKey, ConfigRoot> configRootEntry : extensionConfigRootsEntry.getValue().entrySet()) {
final ConfigRoot configRoot = configRootEntry.getValue();
for (AbstractConfigItem configItem : configRoot.getItems()) {
if (configItem instanceof ConfigProperty) {
Expand Down Expand Up @@ -592,19 +591,18 @@ public static class ConfigItem {

public static ConfigItem of(ConfigProperty configDocItem, JavadocRepository javadocRepository, String artifactIdBase) {
final Optional<JavadocElement> javadoc = javadocRepository
.getElement(configDocItem.getSourceClass(), configDocItem.getSourceName());
.getElement(configDocItem.getSourceType(), configDocItem.getSourceElementName());
final PropertyPath itemPath = configDocItem.getPath();
if (javadoc.isEmpty()) {
throw new IllegalStateException("No JavaDoc for " + configDocItem.getPath() + " alias "
+ configDocItem.getSourceClass() + "#" + configDocItem.getSourceName());
throw new IllegalStateException("No JavaDoc for " + itemPath.property() + " alias "
+ configDocItem.getSourceType() + "#" + configDocItem.getSourceElementName());
}
final String adocSource = LINK_PATTERN.matcher(javadoc.get().description()).replaceAll("xref:$1.adoc");
final String illustration = configDocItem.getPhase().isFixedAtBuildTime() ? "icon:lock[title=Fixed at build time]"
: "";
final TypeInfo typeInfo = typeContent(configDocItem, javadocRepository, true, artifactIdBase);
return new ConfigItem(
// TODO: Fix to use the correct value
// https://github.com/apache/camel-quarkus/issues/6418
configDocItem.getPath().toString(),
itemPath.property(),
illustration,
adocSource,
typeInfo.description,
Expand All @@ -613,7 +611,7 @@ public static ConfigItem of(ConfigProperty configDocItem, JavadocRepository java
configDocItem.getDefaultValue(),
configDocItem.isOptional(),
javadoc.get().since(),
configDocItem.getEnvironmentVariable());
itemPath.environmentVariable());
}

static TypeInfo typeContent(ConfigProperty configProperty, JavadocRepository javadocRepository,
Expand Down

0 comments on commit e051a44

Please sign in to comment.