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

net.sourceforge.pmd.lang.apex.ast.ASTAnnotationParameter Maven / Gradle / Ivy

There is a newer version: 7.5.0
Show newest version
/*
 * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
 */

package net.sourceforge.pmd.lang.apex.ast;

import org.checkerframework.checker.nullness.qual.NonNull;

import com.google.summit.ast.expression.Expression;
import com.google.summit.ast.expression.LiteralExpression;
import com.google.summit.ast.modifier.ElementArgument;
import com.google.summit.ast.modifier.ElementValue;

public final class ASTAnnotationParameter extends AbstractApexNode.Single {
    public static final String SEE_ALL_DATA = "seeAllData";

    ASTAnnotationParameter(ElementArgument elementArgument) {
        super(elementArgument);
    }


    @Override
    protected  R acceptApexVisitor(ApexVisitor visitor, P data) {
        return visitor.visit(this, data);
    }

    public String getName() {
        return node.getName().getString();
    }

    public String getValue() {
        if (node.getValue() instanceof ElementValue.ExpressionValue) {
            Expression value = ((ElementValue.ExpressionValue) node.getValue()).getValue();
            if (value instanceof LiteralExpression) {
                return literalToString((LiteralExpression) value);
            }
        }
        return null;
    }

    public Boolean getBooleanValue() {
        if (node.getValue() instanceof ElementValue.ExpressionValue) {
            Expression value = ((ElementValue.ExpressionValue) node.getValue()).getValue();
            if (value instanceof LiteralExpression.BooleanVal) {
                return ((LiteralExpression.BooleanVal) value).getValue();
            }
        }
        return false;
    }

    @Override
    public String getImage() {
        return getValue();
    }

    /**
     * Checks whether this annotation parameter has the given name.
     * The check is done case-insensitive.
     *
     * @param name the expected annotation parameter name
     * @return {@code true} if this parameter has the expected name.
     * @see #SEE_ALL_DATA
     * @since 7.4.0
     */
    public boolean hasName(@NonNull String name) {
        return name.equalsIgnoreCase(getName());
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy