[Checkers] Exception in checker's API
Artemus Harper
subanark at gmail.com
Thu Sep 4 16:37:48 EDT 2008
I just found out this only happens if I put UniqueList as the first source
file in the compilation list. If I do ListTest followed by UniqueList it
works fine.
On Thu, Sep 4, 2008 at 1:12 PM, Artemus Harper <subanark at gmail.com> wrote:
> Its attached
>
>
> On Thu, Sep 4, 2008 at 12:50 PM, Mahmood Ali <mahmood at mit.edu> wrote:
>
>> Greetings Artemus,
>>
>> Unfortunately, I cannot replicate your finding when only using the
>> provided snippets. Can you please send me your UniqueList code?
>>
>> Regards,
>> Mahmood
>>
>>
>> On Sep 4, 2008, at 3:10 PM, Artemus Harper wrote:
>>
>> I am getting an illegal argument: LOCAL_VARIABLE in
>>> TypeFromElement.annotate method which is invoked as a result of calling
>>> AnnotatedTypeFactory.methodFromUse.
>>> Part of the processed file:
>>> @Unique("{T}") UniqueList<String> list = new UniqueList<String>();
>>> @Unique String s1 = new String("s1");
>>> list.add( (@Unique String) s1); //<--- this line
>>>
>>> where list.add is:
>>> public synchronized void add(@Unique("T") T item) @NoEscape
>>> {
>>> ensureCapasity(size + 1);
>>> items.set(size++, (@Unique("T") T) item);
>>> }
>>>
>>> I only get this error when I invoke add from a different source file.
>>>
>>> Stack trace:
>>> Caused by: java.lang.IllegalArgumentException: illegal argument:
>>> LOCAL_VARIABLE
>>> at checkers.types.TypeFromElement.annotate(TypeFromElement.java:98)
>>> at
>>> checkers.types.AnnotatedTypeFactory.fromElement(AnnotatedTypeFactory.java:248)
>>> at
>>> checkers.types.AnnotatedTypeFactory.getAnnotatedType(AnnotatedTypeFactory.java:146)
>>> at
>>> checkers.types.AnnotatedTypes.asMemberOfImpl(AnnotatedTypes.java:272)
>>> at checkers.types.AnnotatedTypes.asMemberOf(AnnotatedTypes.java:239)
>>> at
>>> checkers.types.TypeFromTree$TypeFromExpression.visitIdentifier(TypeFromTree.java:154)
>>> at
>>> checkers.types.TypeFromTree$TypeFromExpression.visitIdentifier(TypeFromTree.java:58)
>>> at com.sun.tools.javac.tree.JCTree$JCIdent.accept(JCTree.java:1698)
>>> at
>>> com.sun.source.util.SimpleTreeVisitor.visit(SimpleTreeVisitor.java:52)
>>> at
>>> checkers.types.AnnotatedTypeFactory.fromTreeWithVisitor(AnnotatedTypeFactory.java:355)
>>> at
>>> checkers.types.AnnotatedTypeFactory.fromExpression(AnnotatedTypeFactory.java:306)
>>> at
>>> checkers.types.AnnotatedTypeFactory.getAnnotatedType(AnnotatedTypeFactory.java:193)
>>> at
>>> checkers.types.AnnotatedTypeFactory.getAnnotatedType(AnnotatedTypeFactory.java:735)
>>> at
>>> checkers.types.AnnotatedTypeFactory.getReceiver(AnnotatedTypeFactory.java:601)
>>> at
>>> checkers.escape.EscapeAnnotatedTypeFactory.methodFromUse(EscapeAnnotatedTypeFactory.java:199)
>>> <-- I get this error even when I don't override this method
>>> at
>>> checkers.basetype.BaseTypeVisitor.visitMethodInvocation(BaseTypeVisitor.java:266)
>>> at
>>> com.sun.tools.javac.tree.JCTree$JCMethodInvocation.accept(JCTree.java:1312)
>>> at com.sun.source.util.TreePathScanner.scan(TreePathScanner.java:67)
>>> at checkers.basetype.BaseTypeVisitor.scan(BaseTypeVisitor.java:110)
>>> at
>>> com.sun.source.util.TreeScanner.visitExpressionStatement(TreeScanner.java:239)
>>> at
>>> com.sun.tools.javac.tree.JCTree$JCExpressionStatement.accept(JCTree.java:1152)
>>> at com.sun.source.util.TreePathScanner.scan(TreePathScanner.java:67)
>>> at checkers.basetype.BaseTypeVisitor.scan(BaseTypeVisitor.java:110)
>>> at com.sun.source.util.TreeScanner.scanAndReduce(TreeScanner.java:80)
>>> at com.sun.source.util.TreeScanner.scan(TreeScanner.java:90)
>>> at com.sun.source.util.TreeScanner.visitBlock(TreeScanner.java:159)
>>> at com.sun.tools.javac.tree.JCTree$JCBlock.accept(JCTree.java:778)
>>> at com.sun.source.util.TreePathScanner.scan(TreePathScanner.java:67)
>>> at checkers.basetype.BaseTypeVisitor.scan(BaseTypeVisitor.java:110)
>>> at com.sun.source.util.TreeScanner.scanAndReduce(TreeScanner.java:80)
>>> at com.sun.source.util.TreeScanner.visitMethod(TreeScanner.java:143)
>>> at
>>> checkers.basetype.BaseTypeVisitor.visitMethod(BaseTypeVisitor.java:184)
>>> at
>>> com.sun.tools.javac.tree.JCTree$JCMethodDecl.accept(JCTree.java:678)
>>> at com.sun.source.util.TreePathScanner.scan(TreePathScanner.java:67)
>>> at checkers.basetype.BaseTypeVisitor.scan(BaseTypeVisitor.java:110)
>>> at com.sun.source.util.TreeScanner.scanAndReduce(TreeScanner.java:80)
>>> at com.sun.source.util.TreeScanner.scan(TreeScanner.java:90)
>>> at com.sun.source.util.TreeScanner.scanAndReduce(TreeScanner.java:98)
>>> at com.sun.source.util.TreeScanner.visitClass(TreeScanner.java:132)
>>> at
>>> checkers.basetype.BaseTypeVisitor.visitClass(BaseTypeVisitor.java:127)
>>> at com.sun.tools.javac.tree.JCTree$JCClassDecl.accept(JCTree.java:601)
>>> at com.sun.source.util.TreePathScanner.scan(TreePathScanner.java:49)
>>> at checkers.source.SourceChecker.process(SourceChecker.java:199)
>>> --
>>> Artemus Harper
>>> _______________________________________________
>>> checkers mailing list
>>> checkers at lists.csail.mit.edu
>>> https://lists.csail.mit.edu/mailman/listinfo/checkers
>>>
>>
>>
>
>
> --
> Artemus Harper
>
--
Artemus Harper
-------------- next part --------------
An HTML attachment was scrubbed...
URL: https://lists.csail.mit.edu/mailman/private/checkers/attachments/20080904/3eec71c8/attachment.htm
More information about the checkers
mailing list