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

com.feilong.lib.javassist.bytecode.ParameterAnnotationsAttribute Maven / Gradle / Ivy

Go to download

feilong is a suite of core and expanded libraries that include utility classes, http, excel,cvs, io classes, and much much more.

There is a newer version: 4.3.0
Show newest version
/*
 * Javassist, a Java-bytecode translator toolkit.
 * Copyright (C) 1999- Shigeru Chiba. All Rights Reserved.
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License.  Alternatively, the contents of this file may be used under
 * the terms of the GNU Lesser General Public License Version 2.1 or later,
 * or the Apache License Version 2.0.
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 */

package com.feilong.lib.javassist.bytecode;

import java.io.ByteArrayOutputStream;
import java.io.DataInputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import com.feilong.lib.javassist.bytecode.AnnotationsAttribute.Copier;
import com.feilong.lib.javassist.bytecode.AnnotationsAttribute.Parser;
import com.feilong.lib.javassist.bytecode.AnnotationsAttribute.Renamer;
import com.feilong.lib.javassist.bytecode.annotation.Annotation;
import com.feilong.lib.javassist.bytecode.annotation.AnnotationsWriter;

/**
 * A class representing RuntimeVisibleAnnotations_attribute and
 * RuntimeInvisibleAnnotations_attribute.
 *
 * 

* To obtain an ParameterAnnotationAttribute object, invoke * getAttribute(ParameterAnnotationsAttribute.invisibleTag) * in MethodInfo. * The obtained attribute is a * runtime invisible annotations attribute. * If the parameter is * ParameterAnnotationAttribute.visibleTag, then the obtained * attribute is a runtime visible one. */ public class ParameterAnnotationsAttribute extends AttributeInfo{ /** * The name of the RuntimeVisibleParameterAnnotations * attribute. */ public static final String visibleTag = "RuntimeVisibleParameterAnnotations"; /** * The name of the RuntimeInvisibleParameterAnnotations * attribute. */ public static final String invisibleTag = "RuntimeInvisibleParameterAnnotations"; /** * Constructs * a Runtime(In)VisibleParameterAnnotations_attribute. * * @param cp * constant pool * @param attrname * attribute name (visibleTag or * invisibleTag). * @param info * the contents of this attribute. It does not * include attribute_name_index or * attribute_length. */ public ParameterAnnotationsAttribute(ConstPool cp, String attrname, byte[] info){ super(cp, attrname, info); } /** * Constructs an empty * Runtime(In)VisibleParameterAnnotations_attribute. * A new annotation can be later added to the created attribute * by setAnnotations(). * * @param cp * constant pool * @param attrname * attribute name (visibleTag or * invisibleTag). * @see #setAnnotations(Annotation[][]) */ public ParameterAnnotationsAttribute(ConstPool cp, String attrname){ this(cp, attrname, new byte[] { 0 }); } /** * @param n * the attribute name. */ ParameterAnnotationsAttribute(ConstPool cp, int n, DataInputStream in) throws IOException{ super(cp, n, in); } /** * Returns num_parameters. */ public int numParameters(){ return info[0] & 0xff; } /** * Copies this attribute and returns a new copy. */ @Override public AttributeInfo copy(ConstPool newCp,Map classnames){ Copier copier = new Copier(info, constPool, newCp, classnames); try{ copier.parameters(); return new ParameterAnnotationsAttribute(newCp, getName(), copier.close()); }catch (Exception e){ throw new RuntimeException(e.toString()); } } /** * Parses the annotations and returns a data structure representing * that parsed annotations. Note that changes of the node values of the * returned tree are not reflected on the annotations represented by * this object unless the tree is copied back to this object by * setAnnotations(). * * @return Each element of the returned array represents an array of * annotations that are associated with each method parameter. * * @see #setAnnotations(Annotation[][]) */ public Annotation[][] getAnnotations(){ try{ return new Parser(info, constPool).parseParameters(); }catch (Exception e){ throw new RuntimeException(e.toString()); } } /** * Changes the annotations represented by this object according to * the given array of Annotation objects. * * @param params * the data structure representing the * new annotations. Every element of this array * is an array of Annotation and * it represens annotations of each method parameter. */ public void setAnnotations(Annotation[][] params){ ByteArrayOutputStream output = new ByteArrayOutputStream(); AnnotationsWriter writer = new AnnotationsWriter(output, constPool); try{ writer.numParameters(params.length); for (Annotation[] anno : params){ writer.numAnnotations(anno.length); for (Annotation element : anno){ element.write(writer); } } writer.close(); }catch (IOException e){ throw new RuntimeException(e); // should never reach here. } set(output.toByteArray()); } /** * @param oldname * a JVM class name. * @param newname * a JVM class name. */ @Override void renameClass(String oldname,String newname){ Map map = new HashMap<>(); map.put(oldname, newname); renameClass(map); } @Override void renameClass(Map classnames){ Renamer renamer = new Renamer(info, getConstPool(), classnames); try{ renamer.parameters(); }catch (Exception e){ throw new RuntimeException(e); } } @Override void getRefClasses(Map classnames){ renameClass(classnames); } /** * Returns a string representation of this object. */ @Override public String toString(){ Annotation[][] aa = getAnnotations(); StringBuilder sbuf = new StringBuilder(); for (Annotation[] a : aa){ for (Annotation i : a){ sbuf.append(i.toString()).append(" "); } sbuf.append(", "); } return sbuf.toString().replaceAll(" (?=,)|, $", ""); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy