Skip to content

Conversation

@mbovel
Copy link
Member

@mbovel mbovel commented May 21, 2025

Fixes #19177. Done during the compiler issue spree of Monday, May 19th.

Note: hashCode of String is cached (see https://github.com/openjdk/jdk/blob/master/src/java.base/share/classes/java/lang/String.java#L2403-L2436), so this change should not introduce a significant performance overhead.

Co-authored-by: anna herlihy <herlihyap@gmail.com>
Co-authored-by: Miguel Trigueira <12471808+mtrigueira@users.noreply.github.com>
def syntheticDefIfMissing(sym: Symbol): List[Tree] =
if (existingDef(sym, clazz).exists) Nil else syntheticDef(sym) :: Nil

def identifierRef: Tree =
Copy link
Member Author

Choose a reason for hiding this comment

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

Note: this was just moved from an inner scope. No changes.

@mbovel mbovel requested a review from sjrd May 21, 2025 12:49
@soronpo
Copy link
Contributor

soronpo commented May 22, 2025

I think a proper check should show different cases have different hashes and also if you have a case with an argument that two instances with the same argument have the same hash.

@mbovel
Copy link
Member Author

mbovel commented May 22, 2025

@soronpo I added both tests. This PR only changes the hashcode of "enum values" (cases without parentheses), but it's probably still good to test the other cases as well.

@sjrd sjrd merged commit a8f2e1f into scala:main Jun 26, 2025
29 checks passed
@sjrd sjrd deleted the mb/19177 branch June 26, 2025 11:25
@WojciechMazur WojciechMazur added this to the 3.7.3 milestone Jul 29, 2025
soronpo pushed a commit to DFiantHDL/DFHDL that referenced this pull request Oct 25, 2025
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.

HashCode of enum cases is not stable

4 participants