proguard.classfile.attribute.annotation.ElementValue Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of proguard-core Show documentation
Show all versions of proguard-core Show documentation
ProGuardCORE is a free library to read, analyze, modify, and write Java class files.
/*
* ProGuardCORE -- library to process Java bytecode.
*
* Copyright (c) 2002-2020 Guardsquare NV
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package proguard.classfile.attribute.annotation;
import proguard.classfile.*;
import proguard.classfile.attribute.annotation.visitor.ElementValueVisitor;
import proguard.classfile.visitor.MemberVisitor;
import proguard.util.SimpleProcessable;
/**
* This abstract class represents an element value that is attached to an
* annotation or an annotation default. Specific types of element values are
* subclassed from it.
*
* @author Eric Lafortune
*/
public abstract class ElementValue extends SimpleProcessable
{
public static final char TAG_STRING_CONSTANT = 's';
public static final char TAG_ENUM_CONSTANT = 'e';
public static final char TAG_CLASS = 'c';
public static final char TAG_ANNOTATION = '@';
public static final char TAG_ARRAY = '[';
/**
* An extra field for the optional element name. It is used in element value
* pairs of annotations. Otherwise, it is 0.
*/
public int u2elementNameIndex;
/**
* An extra field pointing to the referenced Clazz
* object, if applicable. This field is typically filled out by the
* {@link proguard.classfile.util.ClassReferenceInitializer}
.
*/
public Clazz referencedClass;
/**
* An extra field pointing to the referenced Method
* object, if applicable. This field is typically filled out by the
* {@link proguard.classfile.util.ClassReferenceInitializer}
.
*/
public Method referencedMethod;
/**
* Creates an uninitialized ElementValue.
*/
protected ElementValue()
{
}
/**
* Creates an initialized ElementValue.
*/
protected ElementValue(int u2elementNameIndex)
{
this.u2elementNameIndex = u2elementNameIndex;
}
/**
* Returns the element name.
*/
public String getMethodName(Clazz clazz)
{
return clazz.getString(u2elementNameIndex);
}
// Abstract methods to be implemented by extensions.
/**
* Returns the tag of this element value.
*/
public abstract char getTag();
/**
* Accepts the given visitor.
*/
public abstract void accept(Clazz clazz, Annotation annotation, ElementValueVisitor elementValueVisitor);
/**
* Applies the given visitor to the referenced method.
*/
public void referencedMethodAccept(MemberVisitor memberVisitor)
{
if (referencedMethod != null)
{
referencedMethod.accept(referencedClass, memberVisitor);
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy