- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.2k
Support for arbitrary self-referential static fields on a type #118413
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
Support for arbitrary self-referential static fields on a type #118413
Conversation
- Instead of loading the static field type, use metadata directly to pull the needed info - Add tests covering various scenarios found by customers in the last year or so - Remove existing scheme which could handle directly self referential statics - Defer checking RVA static valuetypes for their field type until a later type loader stage - Add VMFLAG for HasRVAStaticFields - Remove VMFLAG for HasPublicFields, this was found to be unused (its a legacy of an old CAS type loader check which no longer exists)
… gets mono coverage
…ential type triggers a type load failure - This should mitigate any performance concerns since we are able to use the existing caching schemes in most cases
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.
Pull Request Overview
This PR adds support for arbitrary self-referential static fields on types by improving type loading and validation mechanisms. Instead of relying on loading the static field type, it uses metadata directly to extract needed information when the target type cannot be loaded, preventing circular dependency issues.
Key changes:
- Replaces the existing self-referential static field handling scheme with a more robust metadata-based approach
- Defers RVA static valuetype field validation to a later type loader stage to avoid circular dependencies
- Removes the unused HasPublicFieldsVM flag and replaces it withHasRVAStaticFields
Reviewed Changes
Copilot reviewed 6 out of 6 changed files in this pull request and generated 1 comment.
Show a summary per file
| File | Description | 
|---|---|
| SelfReferentialStatics.csproj | New test project configuration with unsafe blocks enabled | 
| SelfReferentialStatics.cs | Comprehensive test cases covering various self-referential static field scenarios | 
| methodtablebuilder.h | Removes HasNonPublicFieldsmethods and addsGetCorElementTypeOfTypeDefOrRefForStaticFielddeclaration | 
| methodtablebuilder.cpp | Core implementation replacing old self-ref handling with metadata-based approach | 
| class.h | Renames VMFLAG_HASNONPUBLICFIELDStoVMFLAG_HASRVASTATICFIELDSand related methods | 
| class.cpp | Adds deferred validation for RVA static fields during LoadExactParents | 
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.
So much deleted code 🥳
LGTM aside from comments
Fixes #104511