JavaParser Source Viewer

Home|JavaParser/com/github/javaparser/ParseResult.java
1/*
2 * Copyright (C) 2007-2010 JĂșlio Vilmar Gesser.
3 * Copyright (C) 2011, 2013-2020 The JavaParser Team.
4 *
5 * This file is part of JavaParser.
6 *
7 * JavaParser can be used either under the terms of
8 * a) the GNU Lesser General Public License as published by
9 *     the Free Software Foundation, either version 3 of the License, or
10 *     (at your option) any later version.
11 * b) the terms of the Apache License
12 *
13 * You should have received a copy of both licenses in LICENCE.LGPL and
14 * LICENCE.APACHE. Please refer to those files for details.
15 *
16 * JavaParser is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19 * GNU Lesser General Public License for more details.
20 */
21
22package com.github.javaparser;
23
24import com.github.javaparser.ast.Node;
25import com.github.javaparser.ast.comments.CommentsCollection;
26
27import java.util.List;
28import java.util.Optional;
29import java.util.function.Consumer;
30
31import static com.github.javaparser.utils.Utils.SYSTEM_EOL;
32
33/**
34 * The results given when parsing with an instance of JavaParser.
35 */
36public class ParseResult<T> {
37    private final T result;
38    private final List<Problemproblems;
39    private final CommentsCollection commentsCollection;
40
41    /**
42     * General constructor.
43     *
44     * @param result the AST, or empty if it wasn't created.
45     * @param problems a list of encountered parsing problems.
46     */
47    public ParseResult(T resultList<ProblemproblemsCommentsCollection commentsCollection) {
48        this.commentsCollection = commentsCollection;
49        this.result = result;
50        this.problems = problems;
51    }
52
53    /**
54     * @return if parsing was successful, meaning no errors of any kind were encountered.
55     */
56    public boolean isSuccessful() {
57        return problems.isEmpty() && result != null;
58    }
59
60    /**
61     * Calls the consumer with the result if parsing was succesful.
62     */
63    public void ifSuccessful(Consumer<Tconsumer) {
64        if (isSuccessful()) {
65            consumer.accept(result);
66        }
67    }
68
69    /**
70     * @return the list of encountered parsing problems. Empty when no problems were encountered.
71     */
72    public List<ProblemgetProblems() {
73        return problems;
74    }
75
76    /**
77     * @return the {@code i}'th encountered parsing problem. May throw <code>IndexOutOfBoundsException</code>.
78     */
79    public Problem getProblem(int i) {
80        return getProblems().get(i);
81    }
82
83    /**
84     * @return the complete collection of comments encountered while parsing.
85     */
86    public Optional<CommentsCollectiongetCommentsCollection() {
87        return Optional.ofNullable(commentsCollection);
88    }
89
90    /**
91     * @return the AST of the parsed source code, or empty if parsing failed completely.
92     */
93    public Optional<TgetResult() {
94        return Optional.ofNullable(result);
95    }
96
97    @Override
98    public String toString() {
99        if (isSuccessful()) {
100            return "Parsing successful";
101        }
102        StringBuilder message = new StringBuilder("Parsing failed:").append(SYSTEM_EOL);
103        for (Problem problem : problems) {
104            message.append(problem.toString()).append(SYSTEM_EOL);
105        }
106        return message.toString();
107    }
108
109    /**
110     * A post processor that can be added to ParserConfiguration to add some processing right after parsing.
111     */
112    public interface PostProcessor {
113        void process(ParseResult<? extends NoderesultParserConfiguration configuration);
114    }
115}
116
MembersX
ParseResult:ParseResult
ParseResult:problems
ParseResult:getProblems
ParseResult:toString:Block:message
ParseResult:toString
ParseResult:getCommentsCollection
ParseResult:commentsCollection
ParseResult:getResult
ParseResult:isSuccessful
ParseResult:ifSuccessful
ParseResult:result
ParseResult:PostProcessor:process
ParseResult:getProblem
Members
X