Skip to content

Conversation

@dwijnand
Copy link
Member

Note that "asSeenFrom" (aka asf) is used by SymDenotation#findMember,
which is used by TypeComparer's "hasMatchingMember", as a part of
"compareRefinedSlow".

Previously (using the minimisation in i17222.8.scala) summonOne is
inlined during the "inlining" phase, while "summonInline" is inlined
during typing. The result is that during inlining we fail to find
Reader[BC, Int] because we incorrectly consider A{type F = Int} as
stable.

Fixes #17222

Note that "asSeenFrom" (aka asf) is used by SymDenotation#findMember,
which is used by TypeComparer's "hasMatchingMember", as a part of
"compareRefinedSlow".

Previously (using the minimisation in i17222.8.scala) `summonOne` is
inlined during the "inlining" phase, while "summonInline" is inlined
during typing.  The result is that during inlining we fail to find
`Reader[BC, Int]` because we incorrectly consider `A{type F = Int}` as
stable.
@dwijnand dwijnand requested a review from odersky November 18, 2024 19:23
@dwijnand dwijnand marked this pull request as ready for review November 18, 2024 19:23
@Gedochao Gedochao requested a review from jchyb November 20, 2024 12:05
@Gedochao Gedochao added the backport:nominated If we agree to backport this PR, replace this tag with "backport:accepted", otherwise delete it. label Nov 20, 2024
@Gedochao Gedochao added this to the 3.6.3 milestone Nov 20, 2024
@Gedochao Gedochao requested review from noti0na1 and sjrd and removed request for jchyb November 20, 2024 12:28
Copy link
Member

@noti0na1 noti0na1 left a comment

Choose a reason for hiding this comment

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

LGTM

@noti0na1 noti0na1 merged commit 912b6f2 into scala:main Nov 22, 2024
29 checks passed
@dwijnand dwijnand deleted the i17222-anon-mixin-inline-match-erasedValue-summonInline branch November 22, 2024 12:44
@WojciechMazur
Copy link
Contributor

No longer backportable to 3.6.3 becouse of introduced regression #22070. Would target 3.6.4 along with the regression fix in #22241

@WojciechMazur WojciechMazur removed the backport:nominated If we agree to backport this PR, replace this tag with "backport:accepted", otherwise delete it. label Dec 30, 2024
smarter added a commit to dotty-staging/dotty that referenced this pull request Jun 26, 2025
The body of this method used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in scala#21954 (originally included in
3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This has led to a
number of regressions, the last ones discussed in scala#23423.

To make the testcases added in scala#21594 pass, this PR proposes a less drastic
change: relax isLegalPrefix as before, unless we're doing an implicit search.
This should dramatically reduce the possibility for regressions.
smarter added a commit to dotty-staging/dotty that referenced this pull request Jun 26, 2025
The body of isLegalPrefix used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in scala#21954 (originally included in
3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This has led to a
number of regressions, the last ones discussed in scala#23423.

To make the testcases added in scala#21594 pass, this PR proposes a less drastic
change: relax isLegalPrefix as before, unless we're doing an implicit search.
This should dramatically reduce the possibility for regressions.

Fixes scala#23423.
Fixes scala#22676.
smarter added a commit that referenced this pull request Jun 27, 2025
The body of isLegalPrefix used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in #21954 (originally
included in 3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This
has led to a number of regressions, the last ones discussed in #23423.

To make the testcases added in #21594 pass, this PR proposes a less
drastic change: relax isLegalPrefix as before, unless we're doing an
implicit search. This should dramatically reduce the possibility for
regressions.

Fixes #23423.
Fixes #22676.
tgodzik pushed a commit to scala/scala3-lts that referenced this pull request Jun 30, 2025
The body of isLegalPrefix used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in scala#21954 (originally included in
3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This has led to a
number of regressions, the last ones discussed in scala#23423.

To make the testcases added in scala#21594 pass, this PR proposes a less drastic
change: relax isLegalPrefix as before, unless we're doing an implicit search.
This should dramatically reduce the possibility for regressions.

Fixes scala#23423.
Fixes scala#22676.
tgodzik added a commit to scala/scala3-lts that referenced this pull request Jun 30, 2025
The body of isLegalPrefix used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in scala#21954 (originally included in
3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This has led to a
number of regressions, the last ones discussed in scala#23423.

To make the testcases added in scala#21594 pass, this PR proposes a less drastic
change: relax isLegalPrefix as before, unless we're doing an implicit search.
This should dramatically reduce the possibility for regressions.

Fixes scala#23423.
Fixes scala#22676.

[Cherry-picked 2e4bc0a][modified]
WojciechMazur pushed a commit that referenced this pull request Jul 16, 2025
The body of isLegalPrefix used to read:

    pre.isStable || !ctx.phase.isTyper

but was changed to drop the second condition in #21954 (originally included in
3.6.4-RC1, reverted from 3.6.4 final but back in 3.7). This has led to a
number of regressions, the last ones discussed in #23423.

To make the testcases added in #21594 pass, this PR proposes a less drastic
change: relax isLegalPrefix as before, unless we're doing an implicit search.
This should dramatically reduce the possibility for regressions.

Fixes #23423.
Fixes #22676.

[Cherry-picked 2e4bc0a]
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.

Anonymous trait mixin breaks inline match + erasedValue + summonInline

5 participants