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

feat: add support for ES2025 duplicate named capturing groups #195

Merged
merged 10 commits into from
Jun 28, 2024
Merged

Conversation

ota-meshi
Copy link
Member

@ota-meshi ota-meshi commented Apr 13, 2024

close #194

@RunDevelopment
Copy link

How does this handle backreferences? The resolved field points to the referenced capturing group, but this is no longer unique.

@ota-meshi
Copy link
Member Author

ota-meshi commented Apr 14, 2024

Thank you for letting me know! I think we need to change the node.
That should be treated as a breaking change, right?

@ota-meshi ota-meshi added the BREAKING CHANGE This change will require a major version bump label Apr 14, 2024
@RunDevelopment
Copy link

That should be treated as a breaking change, right?

Maybe. You currently implemented resolved: CapturingGroup[] which is a breaking change. However, we could also use the same trick you used for Unicode set character classes in v-flag regexes. So we could do something like this:

type Backreference = AmbiguousBackreference | UnambiguousBackreference
interface BaseBackreference {
  type: "Backreference"
  // other props
  ambiguous: boolean
  resolved: CaptruingGroup | CaptruingGroup[]
}
interface AmbiguousBackreference extends BaseBackreference {
  ambiguous: true
  resolved: CaptruingGroup[]
}
interface UnambiguousBackreference extends BaseBackreference {
  ambiguous: false
  resolved: CaptruingGroup
}

The interface/property names could use some work, but I hope I communicated the idea. This wouldn't be a breaking change, because regexes without duplicate group names produce the same AST as before (except for the additional ambiguous: false property).

However, I'm not sure whether this AST is ideal. It's backwards compatible, but it's also a bit more tricky to understand.

@ota-meshi
Copy link
Member Author

Thank you! That's a good idea!
I think it's a good thing that it avoids breaking changes since it is additional information that is not related to the AST.

@ota-meshi ota-meshi removed the BREAKING CHANGE This change will require a major version bump label Apr 14, 2024
@ota-meshi ota-meshi marked this pull request as ready for review June 14, 2024 09:59
@ota-meshi ota-meshi requested a review from a team June 14, 2024 09:59
@ota-meshi
Copy link
Member Author

@eslint-community/regexpp I think this is now ready for review.

@ota-meshi ota-meshi requested a review from a team June 22, 2024 21:00
@ota-meshi
Copy link
Member Author

@eslint-community/core-team Can someone please review this PR?

Copy link

@aladdin-add aladdin-add left a comment

Choose a reason for hiding this comment

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

LGTM, thanks!

@aladdin-add aladdin-add merged commit fb20f68 into main Jun 28, 2024
16 checks passed
@aladdin-add aladdin-add deleted the es2025 branch June 28, 2024 08:01
Copy link

🎉 This PR is included in version 4.11.0 🎉

The release is available on:

Your semantic-release bot 📦🚀

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Support for duplicate named capturing groups
3 participants