All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jsoup.nodes.Comment Maven / Gradle / Ivy

There is a newer version: 1.9.2
Show newest version
package org.jsoup.nodes;

import org.jsoup.internal.QuietAppendable;
import org.jsoup.parser.Parser;
import org.jspecify.annotations.Nullable;

import java.util.List;

/**
 A comment node.

 @author Jonathan Hedley, [email protected] */
public class Comment extends LeafNode {
    /**
     Create a new comment node.
     @param data The contents of the comment
     */
    public Comment(String data) {
        super(data);
    }

    @Override public String nodeName() {
        return "#comment";
    }

    /**
     Get the contents of the comment.
     @return comment content
     */
    public String getData() {
        return coreValue();
    }

    public Comment setData(String data) {
        coreValue(data);
        return this;
    }

    @Override
    void outerHtmlHead(QuietAppendable accum, Document.OutputSettings out) {
        accum
            .append("");
    }

    @Override
    public Comment clone() {
        return (Comment) super.clone();
    }

    /**
     * Check if this comment looks like an XML Declaration. This is the case when the HTML parser sees an XML
     * declaration or processing instruction. Other than doctypes, those aren't part of HTML, and will be parsed as a
     * bogus comment.
     * @return true if it looks like, maybe, it's an XML Declaration.
     * @see #asXmlDeclaration()
     */
    public boolean isXmlDeclaration() {
        String data = getData();
        return isXmlDeclarationData(data);
    }

    private static boolean isXmlDeclarationData(String data) {
        return (data.length() > 1 && (data.startsWith("!") || data.startsWith("?")));
    }

    /**
     * Attempt to cast this comment to an XML Declaration node.
     * @return an XML declaration if it could be parsed as one, null otherwise.
     * @see #isXmlDeclaration()
     */
    public @Nullable XmlDeclaration asXmlDeclaration() {
        String fragment = "<" + getData() + ">";
        Parser parser = Parser.xmlParser();
        List nodes = parser.parseFragmentInput(fragment, null, "");
        if (!nodes.isEmpty() && nodes.get(0) instanceof XmlDeclaration)
            return (XmlDeclaration) nodes.get(0);
        return null;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy