Skip to content
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

le/symbols as weak map keys #76

Merged

Conversation

leoelm
Copy link

@leoelm leoelm commented Mar 16, 2023

Issue number of the reported bug or feature request: microsoft#52534

Describe your changes
Add type support for symbol to WeakMap, WeakSet, WeakRef and FinalizationRegistry. This has been achieved by retrospectively introducing the interface WeakKeyTypesStore which then composes the type WeakKeyTypes. In previous es versions this custom type will only support object, however expanding the interface to also support symbol has been done in ES2023.

Testing performed
To test the feature addition, WeakMap, WeakSet, WeakRef and FinalizationRegistry and all their member functions have been tested using symbol for the relevant inputs to prove failure in versions preceding es2023 and show it to be working in ES2023.

@leoelm leoelm changed the title Le/symbols as weak map keys le/symbols as weak map keys Mar 16, 2023
@acutmore acutmore self-requested a review March 27, 2023 10:47
@acutmore acutmore added the enhancement New feature or request label Mar 27, 2023
Copy link

@acutmore acutmore left a comment

Choose a reason for hiding this comment

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

Thank you @leoelm this is fantastic!

I've left just a few small comments. Feel free to IB me if want to chat over any of them in person/on a call.

Also feel free to post a link to the PR in the TypeScript contributors IB pchat if you'd like to share your progress.

@leoelm leoelm marked this pull request as ready for review March 29, 2023 22:28
Copy link

@acutmore acutmore left a comment

Choose a reason for hiding this comment

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

Thanks for making those extra changes. They made me notice a few other little things we can do next. Feel free to IB or put in a APPT if want to pair up on any changes.

leoelm added 2 commits April 3, 2023 13:35
Signed-off-by: Leo Elmecker <[email protected]>
Signed-off-by: Leo Elmecker <[email protected]>
Copy link

@acutmore acutmore left a comment

Choose a reason for hiding this comment

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

This is looking great. I just spotted a few other small places we probably want to update:

  • WeakMap.prototype.add comment says the value must be an object: ref
  • WeakMap constructor and prototype default to object instead of WeakKey: ref
  • WeakSet method comments mention object ref & ref

@acutmore acutmore merged commit 8d529f6 into bloomberg:le/symbol-as-weak-keys May 4, 2023
leoelm added a commit that referenced this pull request Jun 1, 2023
Support symbols in WeakMap, WeakSet, WeakRef and FinalizationRegistry

Signed-off-by: Leo Elmecker <[email protected]>
leoelm added a commit that referenced this pull request Jun 8, 2023
Support symbols in WeakMap, WeakSet, WeakRef and FinalizationRegistry

Signed-off-by: Leo Elmecker <[email protected]>
leoelm added a commit that referenced this pull request Jun 9, 2023
Support symbols in WeakMap, WeakSet, WeakRef and FinalizationRegistry

Signed-off-by: Leo Elmecker <[email protected]>
dragomirtitian pushed a commit that referenced this pull request Aug 29, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants