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.signature;
31674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
32674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen/**
33674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * A type signature parser to make a signature visitor visit an existing
34674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * signature.
35674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen *
36674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @author Thomas Hallgren
37674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen * @author Eric Bruneton
38674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen */
39674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogenpublic class SignatureReader {
40674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
41674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    /**
42674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * The signature to be read.
43674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     */
44674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    private final String signature;
45674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
46674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    /**
47674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * Constructs a {@link SignatureReader} for the given signature.
48674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     *
49674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param signature A <i>ClassSignature</i>, <i>MethodTypeSignature</i>,
50674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     *        or <i>FieldTypeSignature</i>.
51674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     */
52674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    public SignatureReader(final String signature) {
53674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        this.signature = signature;
54674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    }
55674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
56674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    /**
57674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * Makes the given visitor visit the signature of this
58674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * {@link SignatureReader}. This signature is the one specified in the
59674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * constructor (see {@link #SignatureReader(String) SignatureReader}). This
60674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * method is intended to be called on a {@link SignatureReader} that was
61674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * created using a <i>ClassSignature</i> (such as the
62674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * <code>signature</code> parameter of the
63674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * {@link org.mockito.asm.ClassVisitor#visit ClassVisitor.visit} method)
64674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * or a <i>MethodTypeSignature</i> (such as the <code>signature</code>
65674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * parameter of the
66674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * {@link org.mockito.asm.ClassVisitor#visitMethod ClassVisitor.visitMethod}
67674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * method).
68674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     *
69674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param v the visitor that must visit this signature.
70674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     */
71674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    public void accept(final SignatureVisitor v) {
72674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        String signature = this.signature;
73674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        int len = signature.length();
74674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        int pos;
75674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        char c;
76674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
77674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        if (signature.charAt(0) == '<') {
78674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            pos = 2;
79674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            do {
80674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                int end = signature.indexOf(':', pos);
81674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                v.visitFormalTypeParameter(signature.substring(pos - 1, end));
82674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                pos = end + 1;
83674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
84674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                c = signature.charAt(pos);
85674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                if (c == 'L' || c == '[' || c == 'T') {
86674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                    pos = parseType(signature, pos, v.visitClassBound());
87674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                }
88674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
89674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                while ((c = signature.charAt(pos++)) == ':') {
90674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                    pos = parseType(signature, pos, v.visitInterfaceBound());
91674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                }
92674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            } while (c != '>');
93674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        } else {
94674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            pos = 0;
95674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        }
96674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
97674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        if (signature.charAt(pos) == '(') {
98674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            pos++;
99674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            while (signature.charAt(pos) != ')') {
100674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                pos = parseType(signature, pos, v.visitParameterType());
101674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            }
102674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            pos = parseType(signature, pos + 1, v.visitReturnType());
103674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            while (pos < len) {
104674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                pos = parseType(signature, pos + 1, v.visitExceptionType());
105674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            }
106674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        } else {
107674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            pos = parseType(signature, pos, v.visitSuperclass());
108674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            while (pos < len) {
109674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                pos = parseType(signature, pos, v.visitInterface());
110674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            }
111674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        }
112674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    }
113674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
114674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    /**
115674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * Makes the given visitor visit the signature of this
116674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * {@link SignatureReader}. This signature is the one specified in the
117674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * constructor (see {@link #SignatureReader(String) SignatureReader}). This
118674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * method is intended to be called on a {@link SignatureReader} that was
119674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * created using a <i>FieldTypeSignature</i>, such as the
120674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * <code>signature</code> parameter of the
121674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * {@link org.mockito.asm.ClassVisitor#visitField
122674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * ClassVisitor.visitField} or {@link
123674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * org.mockito.asm.MethodVisitor#visitLocalVariable
124674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * MethodVisitor.visitLocalVariable} methods.
125674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     *
126674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param v the visitor that must visit this signature.
127674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     */
128674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    public void acceptType(final SignatureVisitor v) {
129674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        parseType(this.signature, 0, v);
130674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    }
131674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
132674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    /**
133674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * Parses a field type signature and makes the given visitor visit it.
134674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     *
135674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param signature a string containing the signature that must be parsed.
136674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param pos index of the first character of the signature to parsed.
137674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @param v the visitor that must visit this signature.
138674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     * @return the index of the first character after the parsed signature.
139674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen     */
140674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    private static int parseType(
141674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        final String signature,
142674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        int pos,
143674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        final SignatureVisitor v)
144674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    {
145674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        char c;
146674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        int start, end;
147674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        boolean visited, inner;
148674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        String name;
149674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
150674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        switch (c = signature.charAt(pos++)) {
151674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'Z':
152674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'C':
153674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'B':
154674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'S':
155674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'I':
156674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'F':
157674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'J':
158674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'D':
159674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'V':
160674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                v.visitBaseType(c);
161674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                return pos;
162674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
163674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case '[':
164674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                return parseType(signature, pos, v.visitArrayType());
165674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
166674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            case 'T':
167674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                end = signature.indexOf(';', pos);
168674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                v.visitTypeVariable(signature.substring(pos, end));
169674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                return end + 1;
170674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
171674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen            default: // case 'L':
172674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                start = pos;
173674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                visited = false;
174674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                inner = false;
175674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                for (;;) {
176674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                    switch (c = signature.charAt(pos++)) {
177674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                        case '.':
178674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                        case ';':
179674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            if (!visited) {
180674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                name = signature.substring(start, pos - 1);
181674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                if (inner) {
182674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    v.visitInnerClassType(name);
183674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                } else {
184674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    v.visitClassType(name);
185674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                }
186674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            }
187674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            if (c == ';') {
188674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                v.visitEnd();
189674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                return pos;
190674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            }
191674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            start = pos;
192674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            visited = false;
193674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            inner = true;
194674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            break;
195674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen
196674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                        case '<':
197674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            name = signature.substring(start, pos - 1);
198674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            if (inner) {
199674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                v.visitInnerClassType(name);
200674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            } else {
201674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                v.visitClassType(name);
202674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            }
203674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            visited = true;
204674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            top: for (;;) {
205674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                switch (c = signature.charAt(pos)) {
206674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    case '>':
207674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        break top;
208674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    case '*':
209674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        ++pos;
210674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        v.visitTypeArgument();
211674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        break;
212674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    case '+':
213674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    case '-':
214674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        pos = parseType(signature,
215674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                                pos + 1,
216674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                                v.visitTypeArgument(c));
217674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        break;
218674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                    default:
219674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        pos = parseType(signature,
220674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                                pos,
221674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                                v.visitTypeArgument('='));
222674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                        break;
223674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                                }
224674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                            }
225674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                    }
226674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen                }
227674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen        }
228674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen    }
229674060f01e9090cd21b3c5656cc3204912ad17a6Jon Boekenoogen}
230