diff options
author | Reinier Zwitserloot <reinier@tipit.to> | 2009-07-14 00:15:36 +0200 |
---|---|---|
committer | Reinier Zwitserloot <reinier@tipit.to> | 2009-07-14 00:15:36 +0200 |
commit | aa40323ae8dde889f4bcf21304e5cffdc0003b4c (patch) | |
tree | a58259d3e8d9dd5fe1cd3d253d930d951d9513a3 /src | |
parent | ba6f353fd867f641f6ab155c2ab83e47e0c9bed4 (diff) | |
download | lombok-aa40323ae8dde889f4bcf21304e5cffdc0003b4c.tar.gz lombok-aa40323ae8dde889f4bcf21304e5cffdc0003b4c.tar.bz2 lombok-aa40323ae8dde889f4bcf21304e5cffdc0003b4c.zip |
Fixed a problem where @Data with a static constructor and generics params on the class would generate errors regarding IllegalArgumentException in setSourcePosition in ASTNode.
Diffstat (limited to 'src')
-rw-r--r-- | src/lombok/eclipse/Eclipse.java | 5 | ||||
-rw-r--r-- | src/lombok/eclipse/handlers/HandleData.java | 2 |
2 files changed, 6 insertions, 1 deletions
diff --git a/src/lombok/eclipse/Eclipse.java b/src/lombok/eclipse/Eclipse.java index 7d852f18..a52b8d86 100644 --- a/src/lombok/eclipse/Eclipse.java +++ b/src/lombok/eclipse/Eclipse.java @@ -143,6 +143,11 @@ public class Eclipse { o.modifiers = param.modifiers; o.name = param.name; o.type = copyType(param.type); + o.sourceStart = param.sourceStart; + o.sourceEnd = param.sourceEnd; + o.declarationEnd = param.declarationEnd; + o.declarationSourceStart = param.declarationSourceStart; + o.declarationSourceEnd = param.declarationSourceEnd; if ( param.bounds != null ) { TypeReference[] b = new TypeReference[param.bounds.length]; int idx2 = 0; diff --git a/src/lombok/eclipse/handlers/HandleData.java b/src/lombok/eclipse/handlers/HandleData.java index 066361d2..73ff79b4 100644 --- a/src/lombok/eclipse/handlers/HandleData.java +++ b/src/lombok/eclipse/handlers/HandleData.java @@ -258,7 +258,7 @@ public class HandleData implements EclipseAnnotationHandler<Data> { TypeReference[] refs = new TypeReference[typeDecl.typeParameters.length]; int idx = 0; for ( TypeParameter param : typeDecl.typeParameters ) { - refs[idx++] = new SingleTypeReference(param.name, 0); + refs[idx++] = new SingleTypeReference(param.name, (long)param.sourceStart << 32 | param.sourceEnd); } constructor.returnType = new ParameterizedSingleTypeReference(typeDecl.name, refs, 0, p); } else constructor.returnType = new SingleTypeReference(((TypeDeclaration)type.get()).name, p); |