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

spoon.reflect.declaration.CtAnnotation Maven / Gradle / Ivy

/*
 * SPDX-License-Identifier: (MIT OR CECILL-C)
 *
 * Copyright (C) 2006-2019 INRIA and contributors
 *
 * Spoon is available either under the terms of the MIT License (see LICENSE-MIT.txt) of the Cecill-C License (see LICENSE-CECILL-C.txt). You as the user are entitled to choose the terms under which to adopt Spoon.
 */
package spoon.reflect.declaration;

import spoon.reflect.code.CtExpression;
import spoon.reflect.code.CtFieldAccess;
import spoon.reflect.code.CtLiteral;
import spoon.reflect.code.CtLocalVariable;
import spoon.reflect.code.CtNewArray;
import spoon.reflect.reference.CtTypeParameterReference;
import spoon.reflect.reference.CtTypeReference;
import spoon.support.DerivedProperty;
import spoon.reflect.annotations.PropertyGetter;
import spoon.reflect.annotations.PropertySetter;
import spoon.support.UnsettableProperty;

import java.lang.annotation.Annotation;
import java.util.List;
import java.util.Map;

import static spoon.reflect.path.CtRole.ANNOTATION_TYPE;
import static spoon.reflect.path.CtRole.VALUE;

/**
 * This element represents an annotation on an element.
 *
 * 
 *     // statement annotated by annotation @SuppressWarnings
 *     @SuppressWarnings("unchecked")
 *     java.util.List<?> x = new java.util.ArrayList<>()
 * 
* @param * type of represented annotation */ public interface CtAnnotation extends CtExpression, CtShadowable { /** * Returns the actual annotation (a dynamic proxy for this element). * *

* NOTE: before using an annotation proxy, you have to make sure that all * the types referenced by the annotation have been compiled and are in the * classpath so that accessed values can be converted into the actual types. */ @DerivedProperty A getActualAnnotation(); /** * Returns the annotation type of this annotation. * * @return a reference to the type of this annotation */ @PropertyGetter(role = ANNOTATION_TYPE) CtTypeReference getAnnotationType(); /** * Gets a value, as a CtExpression, for a given key without any conversion. * * If you need the actual value (eg an integer and not a literal, see {@link #getValueAsObject(String)} and similar methods. * * Note that this value type does not necessarily corresponds to the annotation * type member. For example, in case the annotation type expect an array of Object, * and a single value is given, Spoon will return only the object without the CtNewArray. * If you want to get a type closer to the annotation type one, see {@link #getWrappedValue(String)}. * * @param key * Name of searched value. * @return the value expression or null if not found. */ @PropertyGetter(role = VALUE) T getValue(String key); /** Returns the actual value of an annotation property */ @DerivedProperty Object getValueAsObject(String key); /** Returns the actual value of an annotation property, as an integer (utility method) */ @DerivedProperty int getValueAsInt(String key); /** Returns the actual value of an annotation property, as a String (utility method) */ @DerivedProperty String getValueAsString(String key); /** * Gets a value for a given key and try to fix its type based on the * annotation type. For example, if the annotation type member expects an array of String, * and it can be resolved, this method will return a CtNewArray instead of a CtLiteral. * * Warning: the returned element might be detached from the model * * @param key * Name of searched value. * @return the value expression or null if not found. */ @DerivedProperty @PropertyGetter(role = VALUE) T getWrappedValue(String key); /** * Returns this annotation's elements and their values. This is returned in * the form of a map that associates element names with their corresponding * values. If you iterate over the map with entrySet(), the iteration order * complies with the order of annotation values in the source code. * * @return this annotation's element names and their values, or an empty map * if there are none */ @PropertyGetter(role = VALUE) Map getValues(); /** Get all values of {@link #getValues()}, plus the default ones defined in the annotation type. */ @DerivedProperty Map getAllValues(); /** * Sets the annotation's type. * * @param type * reference to the type of this annotation */ @PropertySetter(role = ANNOTATION_TYPE) > T setAnnotationType(CtTypeReference type); /** * Set's this annotation's element names and their values. This is in the * form of a map that associates element names with their corresponding * values. Note that type values are stored as * {@link spoon.reflect.reference.CtTypeReference}. */ @PropertySetter(role = VALUE) > T setElementValues(Map values); /** * Set's this annotation's element names and their values. This is in the * form of a map that associates element names with their corresponding * values. */ @PropertySetter(role = VALUE) > T setValues(Map values); /** * Returns the element which is annotated by this annotation. * * @return annotated {@link spoon.reflect.declaration.CtElement} */ @DerivedProperty // the annotation is contained by the element not the other way around CtElement getAnnotatedElement(); /** * Returns the type of the element which is annotated by this annotation. * * @return {@link spoon.reflect.declaration.CtAnnotatedElementType} */ @DerivedProperty CtAnnotatedElementType getAnnotatedElementType(); /** * Adds a new key-value pair for this annotation */ @PropertySetter(role = VALUE) > T addValue(String elementName, Object value); /** * Adds a new key-literal pair for this annotation. */ @PropertySetter(role = VALUE) > T addValue(String elementName, CtLiteral value); /** * Adds a new key-array pair for this annotation. */ @PropertySetter(role = VALUE) > T addValue(String elementName, CtNewArray value); /** * Adds a new key-field access pair for this annotation. */ @PropertySetter(role = VALUE) > T addValue(String elementName, CtFieldAccess value); /** * Adds a new key-annotation pair for this annotation. */ @PropertySetter(role = VALUE) > T addValue(String elementName, CtAnnotation value); @Override CtAnnotation clone(); @Override @UnsettableProperty > C setTypeCasts(List> types); static CtAnnotatedElementType getAnnotatedElementTypeForCtElement(CtElement element) { if (element == null) { return null; } if (element instanceof CtMethod) { return CtAnnotatedElementType.METHOD; } if (element instanceof CtAnnotation || element instanceof CtAnnotationType) { return CtAnnotatedElementType.ANNOTATION_TYPE; } if (element instanceof CtType) { return CtAnnotatedElementType.TYPE; } if (element instanceof CtField) { return CtAnnotatedElementType.FIELD; } if (element instanceof CtConstructor) { return CtAnnotatedElementType.CONSTRUCTOR; } if (element instanceof CtParameter) { return CtAnnotatedElementType.PARAMETER; } if (element instanceof CtLocalVariable) { return CtAnnotatedElementType.LOCAL_VARIABLE; } if (element instanceof CtPackage) { return CtAnnotatedElementType.PACKAGE; } if (element instanceof CtTypeParameterReference) { return CtAnnotatedElementType.TYPE_PARAMETER; } if (element instanceof CtTypeReference) { return CtAnnotatedElementType.TYPE_USE; } return null; } /** * Returns the class name of the annotation, eg "Deprecated" for @Deprecated. * * @return the name of the annotation */ @DerivedProperty String getName(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy