Skip to content

Bugfix :: Fix optimizer bug where field.Index included compiler generated static fields #18280

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

Conversation

T-Gro
Copy link
Member

@T-Gro T-Gro commented Jan 28, 2025

Fixes #18165

The issue was caused by optimizer using a recordField.Index member which was also increment with compiler generated static fields, like init@5. Those should not be part of Index calculation.

There are two usages of the .Index member (I am putting them here, since GH text based diff will not show that)

  • To sort fields. This remains the same if compiler generated static fields are excluded: let sortedRecdFields = unsortedRecdFields |> List.indexed |> Array.ofList |> Array.sortBy (fun (_, r) -> r.Index)
  • In the optimizer path for optimizing away field get => this is the one which this fix targets and where the reported issue was coming from.
and TryOptimizeRecordFieldGet cenv _env (e1info, (RecdFieldRef (rtcref, _) as r), _tinst, m) =
    let g = cenv.g

    match destRecdValue e1info.Info with
    | Some finfos when cenv.settings.EliminateRecdFieldGet && not e1info.HasEffect ->
        match TryFindFSharpAttribute g g.attrib_CLIMutableAttribute rtcref.Attribs with
        | Some _ -> None
        | None ->
            let n = r.Index
            if n >= finfos.Length then errorR(InternalError( "TryOptimizeRecordFieldGet: term argument out of range", m))
            Some finfos[n]

@dotnet dotnet deleted a comment from github-actions bot Feb 3, 2025
@T-Gro T-Gro marked this pull request as ready for review February 3, 2025 10:32
@T-Gro T-Gro requested a review from a team as a code owner February 3, 2025 10:32
…ing-record-with-construct-on-type-with-static-let
Copy link
Contributor

github-actions bot commented Feb 3, 2025

❗ Release notes required


✅ Found changes and release notes in following paths:

Change path Release notes path Description
src/Compiler docs/release-notes/.FSharp.Compiler.Service/9.0.300.md

@psfinaki psfinaki merged commit 5b910af into main Feb 3, 2025
33 checks passed
@T-Gro T-Gro deleted the 18165-compiler-throws-internal-error-when-using-record-with-construct-on-type-with-static-let branch February 4, 2025 13:03
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

Compiler throws internal error when using record 'with' construct on type with static let
4 participants