- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.2k
[cDAC] implement IXCLRDataMethodInstance::GetName and associated APIs #118966
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
[cDAC] implement IXCLRDataMethodInstance::GetName and associated APIs #118966
Conversation
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 implements the IXCLRDataMethodInstance::GetName method in the cDAC (contract-based Data Access Component) implementation, replacing a previously unimplemented stub that delegated to the legacy implementation.
Key changes:
- Implements method name generation using TypeNameBuilder.AppendMethodInternalwith fallback mechanisms
- Adds error handling and debug validation against the legacy implementation
- Improves robustness of string retrieval from EE addresses
Reviewed Changes
Copilot reviewed 3 out of 3 changed files in this pull request and generated 2 comments.
| File | Description | 
|---|---|
| ClrDataMethodInstance.cs | Implements GetNamemethod with proper name formatting, fallback logic, and debug validation | 
| SOSDacImpl.cs | Removes nested try-catch block in GetMethodTableNamemethod | 
| DacStreams_1.cs | Adds exception handling for VirtualReadExceptioninStringFromEEAddressmethod | 
        
          
                src/native/managed/cdac/mscordaccore_universal/Legacy/ClrDataMethodInstance.cs
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                src/native/managed/cdac/mscordaccore_universal/Legacy/ClrDataMethodInstance.cs
          
            Show resolved
            Hide resolved
        
      54a82b9    to
    84bc116      
    Compare
  
            
          
                src/native/managed/cdac/mscordaccore_universal/Legacy/ClrDataFrame.cs
              
                Outdated
          
            Show resolved
            Hide resolved
        
              
          
                src/native/managed/cdac/mscordaccore_universal/Legacy/ClrDataStackWalk.cs
          
            Show resolved
            Hide resolved
        
      Co-authored-by: Noah Falk <noahfalk@users.noreply.github.com>
        
          
                src/native/managed/cdac/mscordaccore_universal/Legacy/ClrDataMethodInstance.cs
          
            Show resolved
            Hide resolved
        
              
          
                ...d/cdac/Microsoft.Diagnostics.DataContractReader.Contracts/Contracts/StackWalk/StackWalk_1.cs
          
            Show resolved
            Hide resolved
        
      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.
LGTM otherwise
Implements:
IXCLRDataStackWalk::GetFrameIXCLRDataFrame::GetMethodInstanceIXCLRDataMethodInstance::GetNameThe former two are required to verify
GetNameas SOS usesIXCLRDataStackWalk::GetFrame->IXCLRDataFrame::GetMethodInstanceto get the instantiation ofIXCLRDataMethodInstance it callsGetName` on.Modifies:
IDacStreams_1.StringFromEEAddressto not throw on read failure. Previously we wrapped this API in a try/catch, given it can return a null value, I believe it is acceptable to return null on read failures.