You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@isis.apache.org by ah...@apache.org on 2020/12/13 08:51:49 UTC
[isis] 01/02: ISIS-2473: fix field formatting
This is an automated email from the ASF dual-hosted git repository.
ahuber pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/isis.git
commit 705e86032a2f62281ac25ac635b42f5deefaf07b
Author: Andi Huber <ah...@apache.org>
AuthorDate: Sun Dec 13 09:49:40 2020 +0100
ISIS-2473: fix field formatting
---
.../isis/tooling/j2adoc/test/J2AdocTest.java | 3 ++-
.../tooling/javamodel/ast/FieldDeclarations.java | 24 ++++++++++++++++++++--
2 files changed, 24 insertions(+), 3 deletions(-)
diff --git a/tooling/java2adoc/src/test/java/org/apache/isis/tooling/j2adoc/test/J2AdocTest.java b/tooling/java2adoc/src/test/java/org/apache/isis/tooling/j2adoc/test/J2AdocTest.java
index 8f83183..d6d1931 100644
--- a/tooling/java2adoc/src/test/java/org/apache/isis/tooling/j2adoc/test/J2AdocTest.java
+++ b/tooling/java2adoc/src/test/java/org/apache/isis/tooling/j2adoc/test/J2AdocTest.java
@@ -60,7 +60,8 @@ class J2AdocTest {
.stream()
//.filter(source->source.toString().contains("ExecutionMode"))
//.filter(source->source.toString().contains("FactoryService"))
- .filter(source->source.toString().contains("Action"))
+ //.filter(source->source.toString().contains("Action"))
+ .filter(source->source.toString().contains("SudoService"))
//.peek(source->System.out.println("parsing source: " + source))
.forEach(j2aContext::add);
diff --git a/tooling/javamodel/src/main/java/org/apache/isis/tooling/javamodel/ast/FieldDeclarations.java b/tooling/javamodel/src/main/java/org/apache/isis/tooling/javamodel/ast/FieldDeclarations.java
index de8d298..67ba114 100644
--- a/tooling/javamodel/src/main/java/org/apache/isis/tooling/javamodel/ast/FieldDeclarations.java
+++ b/tooling/javamodel/src/main/java/org/apache/isis/tooling/javamodel/ast/FieldDeclarations.java
@@ -18,27 +18,47 @@
*/
package org.apache.isis.tooling.javamodel.ast;
+import java.util.stream.Collectors;
+
import com.github.javaparser.ast.body.ClassOrInterfaceDeclaration;
import com.github.javaparser.ast.body.EnumDeclaration;
import com.github.javaparser.ast.body.FieldDeclaration;
+import com.github.javaparser.ast.body.VariableDeclarator;
+import com.github.javaparser.ast.expr.Expression;
import com.github.javaparser.ast.type.TypeParameter;
+import com.github.javaparser.printer.PrettyPrinterConfiguration;
import org.apache.isis.commons.collections.Can;
import lombok.NonNull;
+import lombok.val;
//TODO effective public might require more context
public final class FieldDeclarations {
+ private static PrettyPrinterConfiguration printingConf = new PrettyPrinterConfiguration();
+ static {
+ printingConf.setPrintJavadoc(false);
+ }
+
/**
* Returns given {@link FieldDeclaration} as normal text, without formatting.
*/
public static String asNormalized(final @NonNull FieldDeclaration fd) {
- return fd.toString().trim(); //TODO might miss the fields type here
+
+ //suppress initializer printing (that is assignments)
+ val clone = fd.clone();
+ clone.getVariables().stream()
+ .forEach(vd->vd.setInitializer((Expression)null));
+
+ return clone.toString(printingConf).trim();
}
public static String asNormalizedName(final @NonNull FieldDeclaration fd) {
- return fd.toString().trim(); //TODO might have the fields type to remove here
+ return fd.getVariables().stream()
+ .map(VariableDeclarator::getNameAsString)
+ .collect(Collectors.joining(", "))
+ .trim();
}
public static Can<TypeParameter> getTypeParameters(final @NonNull FieldDeclaration fd) {