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