|
29 | 29 | import java.util.Optional; |
30 | 30 |
|
31 | 31 | import org.apache.maven.api.annotations.Nullable; |
| 32 | +import org.apache.maven.api.di.Inject; |
32 | 33 | import org.apache.maven.api.di.Named; |
33 | 34 | import org.apache.maven.api.di.Singleton; |
34 | 35 | import org.apache.maven.api.model.Model; |
35 | | -import org.apache.maven.api.services.Source; |
36 | 36 | import org.apache.maven.api.services.model.ModelProcessor; |
37 | 37 | import org.apache.maven.api.services.xml.ModelXmlFactory; |
38 | 38 | import org.apache.maven.api.services.xml.XmlReaderRequest; |
39 | 39 | import org.apache.maven.api.spi.ModelParser; |
40 | 40 | import org.apache.maven.api.spi.ModelParserException; |
41 | 41 |
|
42 | | -import static org.apache.maven.api.spi.ModelParser.STRICT; |
43 | | - |
44 | 42 | /** |
45 | 43 | * |
46 | 44 | * Note: uses @Typed to limit the types it is available for injection to just ModelProcessor. |
|
71 | 69 | public class DefaultModelProcessor implements ModelProcessor { |
72 | 70 |
|
73 | 71 | private final ModelXmlFactory modelXmlFactory; |
74 | | - private final @Nullable List<ModelParser> modelParsers; |
| 72 | + private final List<ModelParser> modelParsers; |
75 | 73 |
|
| 74 | + @Inject |
76 | 75 | public DefaultModelProcessor(ModelXmlFactory modelXmlFactory, @Nullable List<ModelParser> modelParsers) { |
77 | 76 | this.modelXmlFactory = modelXmlFactory; |
78 | 77 | this.modelParsers = modelParsers; |
79 | 78 | } |
80 | 79 |
|
81 | | - /** |
82 | | - * @implNote The ModelProcessor#locatePom never returns null while the ModelParser#locatePom needs to return an existing path! |
83 | | - */ |
84 | 80 | @Override |
85 | 81 | public Path locateExistingPom(Path projectDirectory) { |
86 | | - return modelParsers.stream() |
87 | | - .map(parser -> parser.locate(projectDirectory)) |
88 | | - .filter(Optional::isPresent) |
89 | | - .map(Optional::get) |
90 | | - .map(Source::getPath) |
91 | | - .peek(path -> throwIfWrongProjectDirLocation(path, projectDirectory)) |
| 82 | + // Note that the ModelProcessor#locatePom never returns null |
| 83 | + // while the ModelParser#locatePom needs to return an existing path! |
| 84 | + Path pom = modelParsers.stream() |
| 85 | + .map(m -> m.locate(projectDirectory) |
| 86 | + .map(org.apache.maven.api.services.Source::getPath) |
| 87 | + .orElse(null)) |
| 88 | + .filter(Objects::nonNull) |
92 | 89 | .findFirst() |
93 | | - .orElseGet(() -> locateExistingPomWithUserDirDefault(projectDirectory)); |
94 | | - } |
95 | | - |
96 | | - private static void throwIfWrongProjectDirLocation(Path pom, Path projectDirectory) { |
| 90 | + .orElseGet(() -> doLocateExistingPom(projectDirectory)); |
97 | 91 | if (pom != null && !pom.equals(projectDirectory) && !pom.getParent().equals(projectDirectory)) { |
98 | 92 | throw new IllegalArgumentException("The POM found does not belong to the given directory: " + pom); |
99 | 93 | } |
100 | | - } |
101 | | - |
102 | | - private Path locateExistingPomWithUserDirDefault(Path project) { |
103 | | - return locateExistingPomInDirOrFile(project != null ? project : Paths.get(System.getProperty("user.dir"))); |
104 | | - } |
105 | | - |
106 | | - private static Path locateExistingPomInDirOrFile(Path project) { |
107 | | - return Files.isDirectory(project) ? isRegularFileOrNull(project.resolve("pom.xml")) : project; |
108 | | - } |
109 | | - |
110 | | - private static Path isRegularFileOrNull(Path pom) { |
111 | | - return Files.isRegularFile(pom) ? pom : null; |
| 94 | + return pom; |
112 | 95 | } |
113 | 96 |
|
114 | 97 | @Override |
115 | 98 | public Model read(XmlReaderRequest request) throws IOException { |
116 | 99 | Objects.requireNonNull(request, "source cannot be null"); |
117 | | - return readPomWithParentInheritance(request, request.getPath()); |
118 | | - } |
119 | | - |
120 | | - private Model readPomWithParentInheritance(XmlReaderRequest request, Path pomFile) { |
121 | | - List<ModelParserException> exceptions = new ArrayList<>(); |
| 100 | + Path pomFile = request.getPath(); |
122 | 101 | if (pomFile != null) { |
| 102 | + Path projectDirectory = pomFile.getParent(); |
| 103 | + List<ModelParserException> exceptions = new ArrayList<>(); |
123 | 104 | for (ModelParser parser : modelParsers) { |
124 | 105 | try { |
125 | | - return parser.locateAndParse(pomFile, Map.of(STRICT, request.isStrict())) |
126 | | - .orElseThrow() |
127 | | - .withPomFile(pomFile); |
128 | | - } catch (RuntimeException ex) { |
129 | | - exceptions.add(new ModelParserException(ex)); |
| 106 | + Optional<Model> model = |
| 107 | + parser.locateAndParse(projectDirectory, Map.of(ModelParser.STRICT, request.isStrict())); |
| 108 | + if (model.isPresent()) { |
| 109 | + return model.get().withPomFile(pomFile); |
| 110 | + } |
| 111 | + } catch (ModelParserException e) { |
| 112 | + exceptions.add(e); |
130 | 113 | } |
131 | 114 | } |
| 115 | + try { |
| 116 | + return doRead(request); |
| 117 | + } catch (IOException e) { |
| 118 | + exceptions.forEach(e::addSuppressed); |
| 119 | + throw e; |
| 120 | + } |
| 121 | + } else { |
| 122 | + return doRead(request); |
132 | 123 | } |
133 | | - return readPomWithSuppressedErrorRethrow(request, exceptions); |
134 | 124 | } |
135 | 125 |
|
136 | | - private Model readPomWithSuppressedErrorRethrow(XmlReaderRequest request, List<ModelParserException> exceptions) { |
137 | | - try { |
138 | | - return modelXmlFactory.read(request); |
139 | | - } catch (RuntimeException ex) { |
140 | | - exceptions.forEach(ex::addSuppressed); |
141 | | - throw ex; |
| 126 | + private Path doLocateExistingPom(Path project) { |
| 127 | + if (project == null) { |
| 128 | + project = Paths.get(System.getProperty("user.dir")); |
142 | 129 | } |
| 130 | + if (Files.isDirectory(project)) { |
| 131 | + Path pom = project.resolve("pom.xml"); |
| 132 | + return Files.isRegularFile(pom) ? pom : null; |
| 133 | + } else if (Files.isRegularFile(project)) { |
| 134 | + return project; |
| 135 | + } else { |
| 136 | + return null; |
| 137 | + } |
| 138 | + } |
| 139 | + |
| 140 | + private Model doRead(XmlReaderRequest request) throws IOException { |
| 141 | + return modelXmlFactory.read(request); |
143 | 142 | } |
144 | 143 | } |
0 commit comments