1674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen/*** 2674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * ASM: a very small and fast Java bytecode manipulation framework 3674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Copyright (c) 2000-2007 INRIA, France Telecom 4674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * All rights reserved. 5674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 6674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Redistribution and use in source and binary forms, with or without 7674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * modification, are permitted provided that the following conditions 8674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * are met: 9674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 1. Redistributions of source code must retain the above copyright 10674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * notice, this list of conditions and the following disclaimer. 11674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 2. Redistributions in binary form must reproduce the above copyright 12674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * notice, this list of conditions and the following disclaimer in the 13674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * documentation and/or other materials provided with the distribution. 14674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 3. Neither the name of the copyright holders nor the names of its 15674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * contributors may be used to endorse or promote products derived from 16674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * this software without specific prior written permission. 17674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 18674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 19674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 22674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 28674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * THE POSSIBILITY OF SUCH DAMAGE. 29674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 30674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenpackage org.mockito.asm.tree; 31674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 32674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport java.util.ArrayList; 33674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport java.util.List; 34674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 35674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport org.mockito.asm.AnnotationVisitor; 36674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenimport org.mockito.asm.Attribute; 37674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 38674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen/** 39674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * An abstract class, field or method node. 40674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 41674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @author Eric Bruneton 42674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 43674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenpublic abstract class MemberNode { 44674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 45674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 46674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * The runtime visible annotations of this class, field or method. This list 47674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * is a list of {@link AnnotationNode} objects. May be <tt>null</tt>. 48674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 49674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @associates org.mockito.asm.tree.AnnotationNode 50674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @label visible 51674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 52674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public List visibleAnnotations; 53674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 54674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 55674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * The runtime invisible annotations of this class, field or method. This 56674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * list is a list of {@link AnnotationNode} objects. May be <tt>null</tt>. 57674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 58674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @associates org.mockito.asm.tree.AnnotationNode 59674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @label invisible 60674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 61674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public List invisibleAnnotations; 62674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 63674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 64674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * The non standard attributes of this class, field or method. This list is 65674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * a list of {@link Attribute} objects. May be <tt>null</tt>. 66674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 67674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @associates org.mockito.asm.Attribute 68674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 69674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public List attrs; 70674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 71674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 72674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Constructs a new {@link MemberNode}. 73674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 74674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen protected MemberNode() { 75674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 76674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 77674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 78674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Visits an annotation of this class, field or method. 79674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 80674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @param desc the class descriptor of the annotation class. 81674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @param visible <tt>true</tt> if the annotation is visible at runtime. 82674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @return a visitor to visit the annotation values. 83674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 84674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public AnnotationVisitor visitAnnotation( 85674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen final String desc, 86674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen final boolean visible) 87674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen { 88674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen AnnotationNode an = new AnnotationNode(desc); 89674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen if (visible) { 90674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen if (visibleAnnotations == null) { 91674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen visibleAnnotations = new ArrayList(1); 92674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 93674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen visibleAnnotations.add(an); 94674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } else { 95674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen if (invisibleAnnotations == null) { 96674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen invisibleAnnotations = new ArrayList(1); 97674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 98674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen invisibleAnnotations.add(an); 99674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 100674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen return an; 101674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 102674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 103674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 104674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Visits a non standard attribute of this class, field or method. 105674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * 106674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @param attr an attribute. 107674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 108674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public void visitAttribute(final Attribute attr) { 109674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen if (attrs == null) { 110674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen attrs = new ArrayList(1); 111674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 112674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen attrs.add(attr); 113674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 114674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen 115674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen /** 116674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * Visits the end of this class, field or method. 117674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */ 118674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen public void visitEnd() { 119674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen } 120674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen} 121