-
Notifications
You must be signed in to change notification settings - Fork 4.7k
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
Implement Array.Initialize in C# #77336
Merged
Merged
Changes from 2 commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
8dcad5f
Implement Array.Initialize in C#
reflectronic cf4ede4
Add KeepAlive for good measure
reflectronic 08220af
Reimplement according to feedback
reflectronic 97f72db
Add Mono implementation of Initialize
reflectronic cd85e02
Fix test failure
reflectronic 266378a
Fix for real this time
reflectronic 2407b33
Sigh
reflectronic 003c215
Address review feedback
reflectronic cb435ce
Rework according to feedback
reflectronic ad26d52
Implement for NativeAOT
reflectronic 07a28d7
Add RequiresUnreferencedCode
reflectronic a945257
Needs to be in ref too
reflectronic ba27fd2
Update src/coreclr/System.Private.CoreLib/src/System/Array.CoreCLR.cs
jkotas e1d6ec9
Update src/coreclr/nativeaot/System.Private.CoreLib/src/System/Array.…
jkotas 4b5a4ec
Update src/mono/System.Private.CoreLib/src/System/Array.Mono.cs
jkotas 7988ae3
Revert RequiresUnreferenceCode
jkotas b0d6af6
Use unboxing entrypoint
jkotas be576ad
Merge branch 'main' into array-initialize
jkotas File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
@dotnet/ilc-contrib Should
Array.Initialize
be marked withRequiresUnreferenceCode
, or is the value type default constructor the special-cased by the trimmer and always preserved?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 it should:
dotnet run
prints out ".ctor called".But trimmed the app doesn't print out anything.
Related question - what should
default
do in this case, for example:Running it seems like it will NOT call the .ctor - but what does it do?
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.
Same goes for AOT - published as Native AOT the app above also doesn't print out anything.
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.
According to the specification,
default
ignores the parameterless constructor and generates a zeroed instance.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.
Hmmm, adding
RequiresUnreferencedCode
onArray.Initialize
has a ripple effect. It introduces warnings in situations where array type is passed intoDynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.All)
.I guess it will need more careful thought.
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.
Opened #77426