-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add method call for testing RD class substitution #1032
base: master
Are you sure you want to change the base?
Changes from 3 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
import viewpointtest.quals.ReceiverDependentQual; | ||
|
||
package java.lang; | ||
|
||
@ReceiverDependentQual class Object { | ||
@ReceiverDependentQual Object() {} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,15 +2,14 @@ | |
// https://github.com/eisop/checker-framework/issues/777 | ||
import viewpointtest.quals.*; | ||
|
||
public class VarargsConstructor { | ||
|
||
@ReceiverDependentQual public class VarargsConstructor { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should there be two variants of the test? Why is it enough to add RDQ here? Some comments would be helpful to understand these tests. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think right now viewpoint test checker has a lot suppress warnings and errors because of we default everything to Top. Since we also forbid Top object creation, I would like to make viewpoint test checker more PICO like system, i.e. default Object to RDQ and make A as the default qualifier. |
||
@SuppressWarnings("inconsistent.constructor.type") | ||
VarargsConstructor(String str, Object... args) {} | ||
|
||
@SuppressWarnings({"inconsistent.constructor.type", "super.invocation.invalid"}) | ||
@SuppressWarnings("inconsistent.constructor.type") | ||
@ReceiverDependentQual VarargsConstructor(@ReceiverDependentQual Object... args) {} | ||
|
||
void foo() { | ||
// :: warning: (cast.unsafe.constructor.invocation) | ||
VarargsConstructor a = new @A VarargsConstructor("testStr", new @A Object()); | ||
} | ||
|
||
|
@@ -25,17 +24,14 @@ void invokeConstructor(@A Object aObj, @B Object bObj, @Top Object topObj) { | |
new @B VarargsConstructor(aObj); | ||
} | ||
|
||
class Inner { | ||
// :: warning: (inconsistent.constructor.type) :: error:(super.invocation.invalid) | ||
@ReceiverDependentQual class Inner { | ||
@SuppressWarnings("inconsistent.constructor.type") | ||
@ReceiverDependentQual Inner(@ReceiverDependentQual Object... args) {} | ||
|
||
void foo() { | ||
// :: error: (new.class.type.invalid) | ||
Inner a = new Inner(); | ||
// :: warning: (cast.unsafe.constructor.invocation) | ||
Inner b = new @A Inner(new @A Object()); | ||
Inner c = VarargsConstructor.this.new @A Inner(); | ||
// :: warning: (cast.unsafe.constructor.invocation) | ||
Inner d = VarargsConstructor.this.new @A Inner(new @A Object()); | ||
} | ||
|
||
|
@@ -53,11 +49,9 @@ void invokeConstructor(@A Object aObj, @B Object bObj, @Top Object topObj) { | |
|
||
void testAnonymousClass(@A Object aObj, @B Object bObj, @Top Object topObj) { | ||
Object o = | ||
// :: warning: (cast.unsafe.constructor.invocation) | ||
new @A VarargsConstructor("testStr", new @A Object()) { | ||
void foo() { | ||
VarargsConstructor a = | ||
// :: warning: (cast.unsafe.constructor.invocation) | ||
new @A VarargsConstructor("testStr", new @A Object()); | ||
} | ||
}; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The visitor should not adapt types. I think we should change
atypeFactory.getTypeDeclarationBounds
to take what it needs to determine the correct bounds for a particular use.Then the factory that has a viewpoint adaptor can add the adaptation logic.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Okay, let me try to move the adaptation over.