Skip to content

[dotnet] Don't enable InlineClassGetHandle if we're using the static registrar as a custom trimmer step.#25524

Merged
rolfbjarne merged 1 commit into
mainfrom
dev/rolf/no-inlining-static-registrar
May 27, 2026
Merged

[dotnet] Don't enable InlineClassGetHandle if we're using the static registrar as a custom trimmer step.#25524
rolfbjarne merged 1 commit into
mainfrom
dev/rolf/no-inlining-static-registrar

Conversation

@rolfbjarne

Copy link
Copy Markdown
Member

The InlineClassGetHandle step runs before marking, and the StaticRegistrar
step runs after sweeping, which causes a problem when the InlineClassGetHandle
step needs the registrar to run first.

This won't be a problem once we've moved out of custom trimmer steps.

…registrar as a custom trimmer step.

The InlineClassGetHandle step runs before marking, and the StaticRegistrar
step runs after sweeping, which causes a problem when the InlineClassGetHandle
step needs the registrar to run first.

This won't be a problem once we've moved out of custom trimmer steps.
Copilot AI review requested due to automatic review settings May 26, 2026 12:00
@rolfbjarne rolfbjarne enabled auto-merge (squash) May 26, 2026 12:00

Copilot AI left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

Note

Copilot was unable to run its full agentic suite in this review.

Updates the defaulting logic for InlineClassGetHandle to avoid enabling it in scenarios where the static registrar runs as a custom trimmer step (ordering mismatch with InlineClassGetHandle).

Changes:

  • Tighten the condition that sets the default InlineClassGetHandle value for newer target framework versions.
  • Explicitly exclude Registrar=static + custom trimmer step (PrepareAssemblies not true) from getting InlineClassGetHandle defaulted.


<!-- Set default value for InlineClassGetHandle based on .NET version -->
<PropertyGroup Condition="'$(InlineClassGetHandle)' == '' And $([MSBuild]::VersionGreaterThanOrEquals($(TargetFrameworkVersion), '11.0'))">
<PropertyGroup Condition="'$(InlineClassGetHandle)' == '' And $([MSBuild]::VersionGreaterThanOrEquals($(TargetFrameworkVersion), '11.0')) And !('$(Registrar)' == 'static' And '$(PrepareAssemblies)' != 'true')">

<!-- Set default value for InlineClassGetHandle based on .NET version -->
<PropertyGroup Condition="'$(InlineClassGetHandle)' == '' And $([MSBuild]::VersionGreaterThanOrEquals($(TargetFrameworkVersion), '11.0'))">
<PropertyGroup Condition="'$(InlineClassGetHandle)' == '' And $([MSBuild]::VersionGreaterThanOrEquals($(TargetFrameworkVersion), '11.0')) And !('$(Registrar)' == 'static' And '$(PrepareAssemblies)' != 'true')">
@vs-mobiletools-engineering-service2

Copy link
Copy Markdown
Collaborator

✅ [PR Build #97dee75] Build passed (Detect API changes) ✅

Pipeline on Agent
Hash: 97dee75441b23a41eda169c89e358ccf55480870 [PR build]

@vs-mobiletools-engineering-service2

This comment has been minimized.

@vs-mobiletools-engineering-service2

Copy link
Copy Markdown
Collaborator

✅ [PR Build #97dee75] Build passed (Build packages) ✅

Pipeline on Agent
Hash: 97dee75441b23a41eda169c89e358ccf55480870 [PR build]

@vs-mobiletools-engineering-service2

Copy link
Copy Markdown
Collaborator

✅ API diff for current PR / commit

NET (empty diffs)

✅ API diff vs stable

NET (empty diffs)

ℹ️ Generator diff

Generator Diff: vsdrops (html) vsdrops (raw diff) gist (raw diff) - Please review changes)

Pipeline on Agent
Hash: 97dee75441b23a41eda169c89e358ccf55480870 [PR build]

@vs-mobiletools-engineering-service2

Copy link
Copy Markdown
Collaborator

✅ [PR Build #97dee75] Build passed (Build macOS tests) ✅

Pipeline on Agent
Hash: 97dee75441b23a41eda169c89e358ccf55480870 [PR build]

@vs-mobiletools-engineering-service2

This comment has been minimized.

@vs-mobiletools-engineering-service2

This comment has been minimized.

@vs-mobiletools-engineering-service2

Copy link
Copy Markdown
Collaborator

🚀 [CI Build #97dee75] Test results 🚀

Test results

✅ All tests passed on VSTS: test results.

🎉 All 193 tests passed 🎉

Tests counts

✅ cecil: All 1 tests passed. Html Report (VSDrops) Download
✅ dotnettests (iOS): All 1 tests passed. Html Report (VSDrops) Download
✅ dotnettests (MacCatalyst): All 1 tests passed. Html Report (VSDrops) Download
✅ dotnettests (macOS): All 1 tests passed. Html Report (VSDrops) Download
✅ dotnettests (Multiple platforms): All 1 tests passed. Html Report (VSDrops) Download
✅ dotnettests (tvOS): All 1 tests passed. Html Report (VSDrops) Download
✅ framework: All 2 tests passed. Html Report (VSDrops) Download
✅ fsharp: All 4 tests passed. [attempt 2] Html Report (VSDrops) Download
✅ generator: All 5 tests passed. Html Report (VSDrops) Download
✅ interdependent-binding-projects: All 4 tests passed. [attempt 2] Html Report (VSDrops) Download
✅ introspection: All 6 tests passed. Html Report (VSDrops) Download
✅ linker (iOS): All 11 tests passed. [attempt 3] Html Report (VSDrops) Download
✅ linker (MacCatalyst): All 11 tests passed. Html Report (VSDrops) Download
✅ linker (macOS): All 11 tests passed. Html Report (VSDrops) Download
✅ linker (tvOS): All 11 tests passed. Html Report (VSDrops) Download
✅ monotouch (iOS): All 20 tests passed. [attempt 3] Html Report (VSDrops) Download
✅ monotouch (MacCatalyst): All 23 tests passed. Html Report (VSDrops) Download
✅ monotouch (macOS): All 23 tests passed. [attempt 2] Html Report (VSDrops) Download
✅ monotouch (tvOS): All 20 tests passed. Html Report (VSDrops) Download
✅ msbuild: All 2 tests passed. Html Report (VSDrops) Download
✅ sharpie: All 1 tests passed. Html Report (VSDrops) Download
✅ windows: All 3 tests passed. Html Report (VSDrops) Download
✅ xcframework: All 4 tests passed. Html Report (VSDrops) Download
✅ xtro: All 1 tests passed. Html Report (VSDrops) Download

macOS tests

✅ Tests on macOS Monterey (12): All 5 tests passed. Html Report (VSDrops) Download
✅ Tests on macOS Ventura (13): All 5 tests passed. Html Report (VSDrops) Download
✅ Tests on macOS Sonoma (14): All 5 tests passed. Html Report (VSDrops) Download
✅ Tests on macOS Sequoia (15): All 5 tests passed. Html Report (VSDrops) Download
✅ Tests on macOS Tahoe (26): All 5 tests passed. Html Report (VSDrops) Download

Linux Build Verification

Linux build succeeded

Pipeline on Agent
Hash: 97dee75441b23a41eda169c89e358ccf55480870 [PR build]

@rolfbjarne rolfbjarne merged commit 1becd48 into main May 27, 2026
48 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants