Skip to content
GitLab
Menu
Projects
Groups
Snippets
/
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
Jamie Mansfield
asm
Commits
984ba8d3
Commit
984ba8d3
authored
Jan 10, 2006
by
andrei
Browse files
added some more tests for method signatures, fixed? visitInterfaceBound() method
parent
cf865d3e
Changes
3
Hide whitespace changes
Inline
Side-by-side
src/org/objectweb/asm/util/TraceSignatureVisitor.java
View file @
984ba8d3
...
...
@@ -89,10 +89,19 @@ public class TraceSignatureVisitor implements SignatureVisitor {
}
public
SignatureVisitor
visitInterfaceBound
()
{
separator
=
seenInterfaceBound
?
", "
:
(
isInterface
?
" extends "
:
" implements "
);
seenInterfaceBound
=
true
;
/*
* Andrei: as a human, I wish to see "implements" keyword here, but
* in the sourcecode we denote interface bound also as
* <pre>
* A extends Comparable<E>
* </pre>,
* see crasy1() method in GenericHell class.
*/
// separator = seenInterfaceBound ? ", " : (isInterface
// ? " extends "
// : " implements ");
// seenInterfaceBound = true;
separator
=
" extends "
;
startType
();
return
this
;
}
...
...
test/conform/org/objectweb/asm/util/GenericHell.java
0 → 100644
View file @
984ba8d3
/***
* ASM: a very small and fast Java bytecode manipulation framework
* Copyright (c) 2000-2005 INRIA, France Telecom
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the copyright holders nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
package
org.objectweb.asm.util
;
import
java.util.Map
;
/**
* Class to compare Sun/Eclipse bytecode for 1.5 and understand all freaky
* generic possibilities of the 1.5 source/bytecode.
* @author Andrei
*/
public
class
GenericHell
{
/*
* signature:
* <E:Ljava/lang/Object;T::Ljava/lang/Comparable<TE;>;>(Ljava/lang/Object;Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;TT;)Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;
*/
public
<
E
,
T
extends
Comparable
<
E
>>
Map
<
Object
,
String
>
crazy1
(
Object
o
,
Map
<
Object
,
String
>
map
,
T
t
)
{
return
null
;
}
}
test/conform/org/objectweb/asm/util/TraceSignatureVisitorTest.java
View file @
984ba8d3
...
...
@@ -39,26 +39,53 @@ import org.objectweb.asm.signature.SignatureReader;
/**
* ClassSignatureDecompilerTest
*
*
* @author Eugene Kuleshov
*/
public
class
TraceSignatureVisitorTest
extends
TestCase
{
private
static
String
[]
DATA
=
{
"C|E|<E extends java.lang.Enum<E>> implements java.lang.Comparable<E>, java.io.Serializable|<E:Ljava/lang/Enum<TE;>;>Ljava/lang/Object;Ljava/lang/Comparable<TE;>;Ljava/io/Serializable;"
,
"C|I|<D extends java.lang.reflect.GenericDeclaration> extends java.lang.reflect.Type|<D::Ljava/lang/reflect/GenericDeclaration;>Ljava/lang/Object;Ljava/lang/reflect/Type;"
,
"C|C|<K, V> extends java.util.AbstractMap<K, V> implements java.util.concurrent.ConcurrentMap<K, V>, java.io.Serializable|<K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/util/AbstractMap<TK;TV;>;Ljava/util/concurrent/ConcurrentMap<TK;TV;>;Ljava/io/Serializable;"
,
"C|C|<K extends java.lang.Enum<K>, V> extends java.util.AbstractMap<K, V> implements java.io.Serializable, java.lang.Cloneable|<K:Ljava/lang/Enum<TK;>;V:Ljava/lang/Object;>Ljava/util/AbstractMap<TK;TV;>;Ljava/io/Serializable;Ljava/lang/Cloneable;"
,
"C|E|<E extends java.lang.Enum<E>> implements java.lang.Comparable<E>, java.io.Serializable"
+
"|<E:Ljava/lang/Enum<TE;>;>Ljava/lang/Object;Ljava/lang/Comparable<TE;>;Ljava/io/Serializable;"
,
"C|I|<D extends java.lang.reflect.GenericDeclaration> extends java.lang.reflect.Type"
+
"|<D::Ljava/lang/reflect/GenericDeclaration;>Ljava/lang/Object;Ljava/lang/reflect/Type;"
,
"C|C|<K, V> extends java.util.AbstractMap<K, V> implements java.util.concurrent.ConcurrentMap<K, V>, java.io.Serializable"
+
"|<K:Ljava/lang/Object;V:Ljava/lang/Object;>Ljava/util/AbstractMap<TK;TV;>;Ljava/util/concurrent/ConcurrentMap<TK;TV;>;Ljava/io/Serializable;"
,
"C|C|<K extends java.lang.Enum<K>, V> extends java.util.AbstractMap<K, V> implements java.io.Serializable, java.lang.Cloneable"
+
"|<K:Ljava/lang/Enum<TK;>;V:Ljava/lang/Object;>Ljava/util/AbstractMap<TK;TV;>;Ljava/io/Serializable;Ljava/lang/Cloneable;"
,
"F|C|java.lang.Class<?>|Ljava/lang/Class<*>;"
,
"F|C|java.lang.reflect.Constructor<T>|Ljava/lang/reflect/Constructor<TT;>;"
,
"F|C|T[]|[TT;"
,
"F|C|java.util.Hashtable<?, ?>|Ljava/util/Hashtable<**>;"
,
"F|C|java.util.concurrent.atomic.AtomicReferenceFieldUpdater<java.io.BufferedInputStream, byte[]>|Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Ljava/io/BufferedInputStream;[B>;"
,
"M|C|(java.lang.String, java.lang.Class<?>, java.lang.reflect.Method[], java.lang.reflect.Method, java.lang.reflect.Method)|(Ljava/lang/String;Ljava/lang/Class<*>;[Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;)V"
,
"F|C|java.util.concurrent.atomic.AtomicReferenceFieldUpdater<java.io.BufferedInputStream, byte[]>"
+
"|Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Ljava/io/BufferedInputStream;[B>;"
,
"F|C|AA<byte[][]>|LAA<[[B>;"
,
"F|C|AA<java.util.Map<java.lang.String, java.lang.String>[][]>|LAA<[[Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;>;"
,
"M|C|()|()V^TE;"
,
"F|C|java.util.Hashtable<java.lang.Object, java.lang.String>|Ljava/util/Hashtable<Ljava/lang/Object;Ljava/lang/String;>;"
};
"F|C|AA<java.util.Map<java.lang.String, java.lang.String>[][]>"
+
"|LAA<[[Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;>;"
,
"F|C|java.util.Hashtable<java.lang.Object, java.lang.String>"
+
"|Ljava/util/Hashtable<Ljava/lang/Object;Ljava/lang/String;>;"
,
"M|C|void()E|()V^TE;"
,
"M|C|void(java.lang.String, java.lang.Class<?>, java.lang.reflect.Method[], java.lang.reflect.Method, java.lang.reflect.Method)"
+
"|(Ljava/lang/String;Ljava/lang/Class<*>;[Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;Ljava/lang/reflect/Method;)V"
,
"M|C|java.util.Map<java.lang.Object, java.lang.String>(java.lang.Object, java.util.Map<java.lang.Object, java.lang.String>)"
+
"|(Ljava/lang/Object;Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;)Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;"
,
"M|C|java.util.Map<java.lang.Object, java.lang.String><T>(java.lang.Object, java.util.Map<java.lang.Object, java.lang.String>, T)"
+
"|<T:Ljava/lang/Object;>(Ljava/lang/Object;Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;TT;)Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;"
,
"M|C|java.util.Map<java.lang.Object, java.lang.String><E, T extends java.lang.Comparable<E>>(java.lang.Object, java.util.Map<java.lang.Object, java.lang.String>, T)"
+
"|<E:Ljava/lang/Object;T::Ljava/lang/Comparable<TE;>;>(Ljava/lang/Object;Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;TT;)Ljava/util/Map<Ljava/lang/Object;Ljava/lang/String;>;"
,
};
public
static
TestSuite
suite
()
{
TestSuite
suite
=
new
TestSuite
(
TraceSignatureVisitorTest
.
class
.
getName
());
...
...
@@ -84,16 +111,21 @@ public class TraceSignatureVisitorTest extends TestCase {
switch
(
data
.
type
)
{
case
'C'
:
r
.
accept
(
d
);
assertEquals
(
data
.
declaration
,
d
.
getDeclaration
());
break
;
case
'F'
:
r
.
acceptType
(
d
);
assertEquals
(
data
.
declaration
,
d
.
getDeclaration
());
break
;
case
'M'
:
r
.
accept
(
d
);
String
fullMethodDeclaration
=
d
.
getReturnType
()
+
d
.
getDeclaration
()
+
(
d
.
getExceptions
()
!=
null
?
d
.
getExceptions
()
:
""
);
assertEquals
(
data
.
declaration
,
fullMethodDeclaration
);
break
;
}
assertEquals
(
data
.
declaration
,
d
.
getDeclaration
());
}
public
String
getName
()
{
...
...
Write
Preview
Supports
Markdown
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment