-
Notifications
You must be signed in to change notification settings - Fork 794
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
Fix #17797 -- Realsig+ generates nested closures with incorrect Generic arguments #17877
base: main
Are you sure you want to change the base?
Conversation
❗ Release notes required
|
35a8aad
to
a7eeda8
Compare
bb06ffa
to
1d562ef
Compare
e13abad
to
ef80877
Compare
376285d
to
d2ff439
Compare
tests/FSharp.Compiler.ComponentTests/EmittedIL/RealInternalSignature/ClassTypeInitialization.fs
Outdated
Show resolved
Hide resolved
tests/FSharp.Compiler.ComponentTests/EmittedIL/RealInternalSignature/ClassTypeInitialization.fs
Show resolved
Hide resolved
...ler.ComponentTests/EmittedIL/Inlining/Match01_RealInternalSignatureOn.fs.il.net472.debug.bsl
Outdated
Show resolved
Hide resolved
...ler.ComponentTests/EmittedIL/Inlining/Match01_RealInternalSignatureOn.fs.il.net472.debug.bsl
Outdated
Show resolved
Hide resolved
@@ -1104,7 +1104,7 @@ type Generic1InGeneric1<'T>() = | |||
extends [runtime]System.Object | |||
{ | |||
.custom instance void [FSharp.Core]Microsoft.FSharp.Core.CompilationMappingAttribute::.ctor(valuetype [FSharp.Core]Microsoft.FSharp.Core.SourceConstructFlags) = ( 01 00 03 00 00 00 00 00 ) | |||
.class auto autochar sealed nested assembly beforefieldinit specialname clo@7<A> | |||
.class auto autochar sealed nested assembly beforefieldinit specialname clo@7<T,A> |
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.
This code is closure heavy, can we have it ilverified too?
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.
I think vlad may have added some ilverification, so I'll see what I can reuse.
tests/FSharp.Compiler.ComponentTests/Conformance/LexicalAnalysis/SymbolicOperators.fs
Outdated
Show resolved
Hide resolved
@@ -17,59 +18,59 @@ module ComputedCollections = | |||
[<Theory; Directory(__SOURCE_DIRECTORY__, Includes=[|"Int32RangeArrays.fs"|])>] | |||
let ``Int32RangeArrays_fs`` compilation = | |||
compilation | |||
|> verifyCompilation | |||
|> verifyCompilation false |
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.
I am okay with this PR not turning realSig's default to true yet.
But when we do, I think we should be running as much tests as possible with the same default.
Will it be a painful update, or was there another reason for using "false" here?
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.
I can double the test, so it does both, although InlineData and Directory don't play nice together.
My review is finished, but let's wait for the ilverify for realsig as a CI step as well. |
…is/SymbolicOperators.fs Yeah the comments are pointless. Co-authored-by: Tomas Grosup <[email protected]>
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.
I will make these changes, they are good suggestions.
tests/FSharp.Compiler.ComponentTests/EmittedIL/RealInternalSignature/ClassTypeInitialization.fs
Show resolved
Hide resolved
tests/FSharp.Compiler.ComponentTests/EmittedIL/RealInternalSignature/ClassTypeInitialization.fs
Outdated
Show resolved
Hide resolved
@@ -1104,7 +1104,7 @@ type Generic1InGeneric1<'T>() = | |||
extends [runtime]System.Object | |||
{ | |||
.custom instance void [FSharp.Core]Microsoft.FSharp.Core.CompilationMappingAttribute::.ctor(valuetype [FSharp.Core]Microsoft.FSharp.Core.SourceConstructFlags) = ( 01 00 03 00 00 00 00 00 ) | |||
.class auto autochar sealed nested assembly beforefieldinit specialname clo@7<A> | |||
.class auto autochar sealed nested assembly beforefieldinit specialname clo@7<T,A> |
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.
I think vlad may have added some ilverification, so I'll see what I can reuse.
@@ -17,59 +18,59 @@ module ComputedCollections = | |||
[<Theory; Directory(__SOURCE_DIRECTORY__, Includes=[|"Int32RangeArrays.fs"|])>] | |||
let ``Int32RangeArrays_fs`` compilation = | |||
compilation | |||
|> verifyCompilation | |||
|> verifyCompilation false |
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.
I can double the test, so it does both, although InlineData and Directory don't play nice together.
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.
Can't find anything suspicious here, well tested IMO.
@@ -204,6 +204,33 @@ Linux/macOS: | |||
export TEST_UPDATE_BSL=1 | |||
``` | |||
|
|||
## Retain Test run built artifacts | |||
|
|||
When investigating tests issues it is sometimes usefull to examine the artifacts built whe running tests. Those built using the newer test framework are usually, |
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.
When investigating tests issues it is sometimes usefull to examine the artifacts built whe running tests. Those built using the newer test framework are usually, | |
When investigating tests issues it is sometimes useful to examine the artifacts built when running tests. Those built using the newer test framework are usually, |
When realsig+ is specified we generate closures as nested classes rather than classes at the same level as the class that the closures are for. This eliminates the need for members of the class to be internal allowing us to make the members private to reflect their source visibility.
Issue 17797 occurs because the closures were generated without the generic parameters. This fix addresses that by getting the generic parameters from the argument/typar environment.