JavaParser Source Viewer

Home|JavaParser/com/github/javaparser/ast/nodeTypes/NodeWithJavadoc.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.ast.nodeTypes;
23
24import com.github.javaparser.ast.Node;
25import com.github.javaparser.ast.comments.Comment;
26import com.github.javaparser.ast.comments.JavadocComment;
27import com.github.javaparser.javadoc.Javadoc;
28
29import java.util.Optional;
30
31/**
32 * A node that can be documented with a Javadoc comment.
33 */
34public interface NodeWithJavadoc<N extends Node> {
35    Optional<CommentgetComment();
36
37    Node setComment(Comment comment);
38
39    /**
40     * Gets the JavadocComment for this node. You can set the JavadocComment by calling setJavadocComment passing a
41     * JavadocComment.
42     *
43     * @return The JavadocComment for this node wrapped in an optional as it may be absent.
44     */
45    default Optional<JavadocCommentgetJavadocComment() {
46        return getComment()
47                .filter(comment -> comment instanceof JavadocComment)
48                .map(comment -> (JavadocCommentcomment);
49    }
50
51    /**
52     * Gets the Javadoc for this node. You can set the Javadoc by calling setJavadocComment passing a Javadoc.
53     *
54     * @return The Javadoc for this node wrapped in an optional as it may be absent.
55     */
56    default Optional<JavadocgetJavadoc() {
57        return getJavadocComment().map(JavadocComment::parse);
58    }
59
60    /**
61     * Use this to store additional information to this node.
62     *
63     * @param comment to be set
64     */
65    @SuppressWarnings("unchecked")
66    default N setJavadocComment(String comment) {
67        return setJavadocComment(new JavadocComment(comment));
68    }
69
70    default N setJavadocComment(JavadocComment comment) {
71        setComment(comment);
72        return (N) this;
73    }
74
75    default N setJavadocComment(String indentationJavadoc javadoc) {
76        return setJavadocComment(javadoc.toComment(indentation));
77    }
78
79    default N setJavadocComment(Javadoc javadoc) {
80        return setJavadocComment(javadoc.toComment());
81    }
82
83    default boolean removeJavaDocComment() {
84        return hasJavaDocComment() && getComment().get().remove();
85    }
86
87    default boolean hasJavaDocComment() {
88        return getComment().isPresent() && getComment().get() instanceof JavadocComment;
89    }
90
91}
92
MembersX
NodeWithJavadoc:getJavadoc
NodeWithJavadoc:hasJavaDocComment
NodeWithJavadoc:setJavadocComment
NodeWithJavadoc:getJavadocComment
NodeWithJavadoc:getComment
NodeWithJavadoc:removeJavaDocComment
NodeWithJavadoc:setComment
Members
X