KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > net > sf > retrotranslator > runtime > impl > AnnotationArray


1 /***
2  * Retrotranslator: a Java bytecode transformer that translates Java classes
3  * compiled with JDK 5.0 into classes that can be run on JVM 1.4.
4  *
5  * Copyright (c) 2005 - 2007 Taras Puchko
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  * 1. Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * 2. Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in the
15  * documentation and/or other materials provided with the distribution.
16  * 3. Neither the name of the copyright holders nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
30  * THE POSSIBILITY OF SUCH DAMAGE.
31  */

32 package net.sf.retrotranslator.runtime.impl;
33
34 import java.util.*;
35 import net.sf.retrotranslator.runtime.asm.AnnotationVisitor;
36
37 /**
38  * @author Taras Puchko
39  */

40 public class AnnotationArray implements AnnotationVisitor {
41
42     private final List<Object JavaDoc> values = new ArrayList<Object JavaDoc>();
43
44     public AnnotationArray() {
45     }
46
47     public List<Object JavaDoc> getValues() {
48         return values;
49     }
50
51     public void visit(String JavaDoc name, Object JavaDoc value) {
52         values.add(value);
53     }
54
55     public void visitEnum(String JavaDoc name, String JavaDoc desc, String JavaDoc value) {
56         values.add(new EnumValue(desc, value));
57     }
58
59     public AnnotationVisitor visitAnnotation(String JavaDoc name, String JavaDoc desc) {
60         AnnotationValue value = new AnnotationValue(desc);
61         values.add(value);
62         return value;
63     }
64
65     public AnnotationVisitor visitArray(String JavaDoc name) {
66         AnnotationArray array = new AnnotationArray();
67         values.add(array);
68         return array;
69     }
70
71     public void visitEnd() {
72     }
73
74 }
75
Popular Tags