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

refactor(linter): use regex visitor in no-empty-character-class #6058

Conversation

camchenry
Copy link
Contributor

@camchenry camchenry commented Sep 25, 2024

Replaces rule-specific regex AST visitor method with the standard oxc_regular_expression one. This simplifies the code and also enables more capabilities (visiting more than just terms, but also character class contents, etc.)

Copy link

graphite-app bot commented Sep 25, 2024

Your org has enabled the Graphite merge queue for merging into main

Add the label “0-merge” to the PR and Graphite will automatically add it to the merge queue when it’s ready to merge. Or use the label “hotfix” to add to the merge queue as a hot fix.

You must have a Graphite account and log in to Graphite in order to use the merge queue. Sign up using this link.

Copy link

codspeed-hq bot commented Sep 25, 2024

CodSpeed Performance Report

Merging #6058 will not alter performance

Comparing 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ (eeb8873) with main (2090fce)

Summary

✅ 29 untouched benchmarks

@camchenry camchenry marked this pull request as ready for review September 25, 2024 18:37
@camchenry camchenry force-pushed the 09-25-feat_regular_expression_implement_getspan_for_regex_ast_nodes branch from 6a2b88e to a55a885 Compare September 26, 2024 03:35
@camchenry camchenry force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from c9d6086 to 9da07eb Compare September 26, 2024 03:35
@camchenry camchenry force-pushed the 09-25-feat_regular_expression_implement_getspan_for_regex_ast_nodes branch from a55a885 to 6f5bd2b Compare September 26, 2024 03:39
@camchenry camchenry force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from 9da07eb to a9b8801 Compare September 26, 2024 03:39
@Boshen Boshen force-pushed the 09-25-feat_regular_expression_implement_getspan_for_regex_ast_nodes branch 2 times, most recently from 6afd0b6 to 54884d2 Compare September 26, 2024 05:10
@Boshen Boshen force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from a9b8801 to 9939460 Compare September 26, 2024 05:10
@Boshen Boshen changed the base branch from 09-25-feat_regular_expression_implement_getspan_for_regex_ast_nodes to graphite-base/6058 September 26, 2024 05:51
@Boshen Boshen force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from 9939460 to d2d87ee Compare September 26, 2024 05:59
@Boshen Boshen changed the base branch from graphite-base/6058 to main September 26, 2024 06:00
@Boshen Boshen force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from d2d87ee to 45b7f10 Compare September 26, 2024 06:00
Copy link
Member

@Boshen Boshen left a comment

Choose a reason for hiding this comment

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

LOVE how simplified this is.

@camchenry camchenry added the 0-merge Merge with Graphite Merge Queue label Sep 27, 2024
Copy link

graphite-app bot commented Sep 27, 2024

Merge activity

  • Sep 27, 10:31 AM EDT: The merge label '0-merge' was detected. This PR will be added to the Graphite merge queue once it meets the requirements.
  • Sep 27, 10:31 AM EDT: camchenry added this pull request to the Graphite merge queue.
  • Sep 27, 10:32 AM EDT: The Graphite merge queue couldn't merge this PR because it failed for an unknown reason.
  • Sep 27, 10:32 AM EDT: The merge label '0-merge' was detected. This PR will be added to the Graphite merge queue once it meets the requirements.
  • Sep 27, 10:33 AM EDT: camchenry added this pull request to the Graphite merge queue.
  • Sep 27, 10:33 AM EDT: The Graphite merge queue couldn't merge this PR because it failed for an unknown reason.
  • Sep 27, 11:58 AM EDT: Boshen added this pull request to the Graphite merge queue.
  • Sep 27, 12:03 PM EDT: Boshen merged this pull request with the Graphite merge queue.

@graphite-app graphite-app bot removed the 0-merge Merge with Graphite Merge Queue label Sep 27, 2024
@camchenry camchenry added the 0-merge Merge with Graphite Merge Queue label Sep 27, 2024 — with Graphite App
@graphite-app graphite-app bot removed the 0-merge Merge with Graphite Merge Queue label Sep 27, 2024
@camchenry camchenry force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from 45b7f10 to 6e7f0a4 Compare September 27, 2024 15:19
@Boshen Boshen added the 0-merge Merge with Graphite Merge Queue label Sep 27, 2024 — with Graphite App
)

Replaces rule-specific regex AST visitor method with the standard `oxc_regular_expression` one. This simplifies the code and also enables more capabilities (visiting more than just terms, but also character class contents, etc.)
@Boshen Boshen force-pushed the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch from 6e7f0a4 to eeb8873 Compare September 27, 2024 15:58
@graphite-app graphite-app bot merged commit eeb8873 into main Sep 27, 2024
26 checks passed
@graphite-app graphite-app bot deleted the 09-25-refactor_linter_use_regex_visitor_in_no-empty-character-class_ branch September 27, 2024 16:03
This was referenced Oct 7, 2024
Boshen added a commit that referenced this pull request Oct 8, 2024
## [0.9.10] - 2024-10-07

### Features

- f272137 editors/vscode: Clear diagnostics on file deletion (#6326)
(dalaoshu)
- 1a5f293 editors/vscode: Update VSCode extention to use project's
language server (#6132) (dalaoshu)
- 376cc09 linter: Implement `no-throw-literal` (#6144) (dalaoshu)
- 5957214 linter: Allow fixing in files with source offsets (#6197)
(camchenry)
- a089e19 linter: Eslint/no-else-return (#4305) (yoho)
- 183739f linter: Implement prefer-await-to-callbacks (#6153) (dalaoshu)
- ae539af linter: Implement no-return-assign (#6108) (Radu Baston)

### Bug Fixes

- 9e9808b linter: Fix regression when parsing ts in vue files (#6336)
(Boshen)
- 93c6db6 linter: Improve docs and diagnostics message for
no-else-return (#6327) (DonIsaac)
- e0a3378 linter: Correct false positive in
`unicorn/prefer-string-replace-all` (#6263) (H11)
- ea28ee9 linter: Improve the fixer of `prefer-namespace-keyword`
(#6230) (dalaoshu)
- f6a3450 linter: Get correct source offsets for astro files (#6196)
(camchenry)
- be0030c linter: Allow whitespace control characters in
`no-control-regex` (#6140) (camchenry)
- e7e8ead linter: False positive in `no-return-assign` (#6128)
(DonIsaac)

### Performance

- ac0a82a linter: Reuse allocator when there are multiple source texts
(#6337) (Boshen)
- 50a0029 linter: Do not concat vec in `no-useless-length-check` (#6276)
(camchenry)

### Documentation

- 7ca70dd linter: Add docs for `ContextHost` and `LintContext` (#6272)
(camchenry)
- a949ecb linter: Improve docs for `eslint/getter-return` (#6229)
(DonIsaac)
- 14ba263 linter: Improve docs for `eslint-plugin-import` rules (#6131)
(dalaoshu)

### Refactor

- 642725c linter: Rename vars from `ast_node_id` to `node_id` (#6305)
(overlookmotel)
- 8413175 linter: Move shared function from utils to rule (#6127)
(dalaoshu)
- ba9c372 linter: Make jest/vitest rule mapping more clear (#6273)
(camchenry)
- 82b8f21 linter: Add schemars and serde traits to AllowWarnDeny and
RuleCategories (#6119) (DonIsaac)
- ea908f7 linter: Consolidate file loading logic (#6130) (DonIsaac)
- db751f0 linter: Use regexp AST visitor in `no-control-regex` (#6129)
(camchenry)
- 3aa7e42 linter: Use RegExp AST visitor for `no-hex-escape` (#6117)
(camchenry)
- 9d5b44a linter: Use regex visitor in `no-regex-spaces` (#6063)
(camchenry)
- 0d44cf7 linter: Use regex visitor in `no-useless-escape` (#6062)
(camchenry)
- eeb8873 linter: Use regex visitor in `no-empty-character-class`
(#6058) (camchenry)

### Testing

- d883562 linter: Invalid `eslint/no-unused-vars` options (#6228)
(DonIsaac)

---------

Co-authored-by: Boshen <[email protected]>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
0-merge Merge with Graphite Merge Queue A-linter Area - Linter
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants