Skip to content

Conversation

@Sysix
Copy link
Member

@Sysix Sysix commented Sep 27, 2025

part of #11707
disable rule for this file are only valid for the current SubContextHost and will produce syntax error for vue files.
A comment like this will be added.

// oxlint-disable no-debugger
<script>
debugger;
</script>

This is the first part to refactor the logic, by moving it nearer to the linter, where the source text / sections are available.
Probably needs some LSP feature flag for the message to pass the information of the current ContextSubHost source text offset.

@github-actions github-actions bot added A-linter Area - Linter A-editor Area - Editor and Language Server labels Sep 27, 2025
Copy link
Member Author

Sysix commented Sep 27, 2025


How to use the Graphite Merge Queue

Add either label to this PR to merge it via the merge queue:

  • 0-merge - adds this PR to the back of the merge queue
  • hotfix - for urgent hot fixes, skip the queue and merge this PR next

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

An organization admin has enabled the Graphite Merge Queue in this repository.

Please do not merge from GitHub as this will restart CI on PRs being processed by the merge queue.

This stack of pull requests is managed by Graphite. Learn more about stacking.

@github-actions github-actions bot added the C-cleanup Category - technical debt or refactoring. Solution not expected to change behavior label Sep 27, 2025
@codspeed-hq
Copy link

codspeed-hq bot commented Sep 27, 2025

CodSpeed Instrumentation Performance Report

Merging #14183 will not alter performance

Comparing 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix (7a0eb57) with main (aa0689f)1

Summary

✅ 4 untouched
⏩ 33 skipped2

Footnotes

  1. No successful run was found on main (7a0eb57) during the generation of this report, so aa0689f was used instead as the comparison base. There might be some changes unrelated to this pull request in this report.

  2. 33 benchmarks were skipped, so the baseline results were used instead. If they were deleted from the codebase, click here and archive them to remove them from the performance reports.

@Sysix Sysix force-pushed the 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix branch 2 times, most recently from 1577033 to b5d90d5 Compare September 27, 2025 12:32
@Sysix Sysix marked this pull request as ready for review September 27, 2025 12:36
@Sysix Sysix requested a review from camc314 as a code owner September 27, 2025 12:36
Copilot AI review requested due to automatic review settings September 27, 2025 12:36
@Sysix Sysix force-pushed the 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix branch from b5d90d5 to a1c7090 Compare September 27, 2025 12:37
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

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

Pull Request Overview

This PR refactors the ignore code action logic from the language server layer to the linter layer, making it available as part of the linter's fix suggestions. This change is aimed at fixing issues with Vue files where "disable rule for this file" comments would be incorrectly placed and cause syntax errors.

Key changes:

  • Added ignore fixes (disable for line/file) to the linter's PossibleFixesWithPosition system
  • Removed duplicate ignore code action logic from the language server worker
  • Added section offset parameter to track source text positioning for proper comment placement

Reviewed Changes

Copilot reviewed 26 out of 26 changed files in this pull request and generated 5 comments.

Show a summary per file
File Description
crates/oxc_linter/src/lsp.rs Added ignore fix generation logic and extended PossibleFixesWithPosition enum
crates/oxc_linter/src/service/runtime.rs Updated to pass section offset parameter for ignore fix positioning
crates/oxc_linter/src/tsgolint.rs Updated to pass section offset parameter for ignore fix positioning
crates/oxc_language_server/src/worker.rs Removed duplicate ignore code action generation logic
crates/oxc_language_server/src/code_actions.rs Removed ignore code action functions and updated fix preference handling
crates/oxc_language_server/src/linter/error_with_position.rs Removed rule_name field that's no longer needed
crates/oxc_language_server/src/linter/isolated_lint_handler.rs Removed rule_name field initialization
crates/oxc_language_server/src/tester.rs Updated debug formatting
Multiple snapshot files Updated test snapshots to reflect new ignore fixes being included

Tip: Customize your code reviews with copilot-instructions.md. Create the file or learn how to get started.

@Sysix Sysix force-pushed the 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix branch from a1c7090 to 7079e73 Compare September 27, 2025 13:43
@camc314 camc314 added the 0-merge Merge with Graphite Merge Queue label Sep 28, 2025
Copy link
Contributor

camc314 commented Sep 28, 2025

Merge activity

…ter fix (#14183)

part of #11707
`disable rule for this file` are only valid for the current `SubContextHost` and will produce syntax error for vue files.
A comment like this will be added.
```
// oxlint-disable no-debugger
<script>
debugger;
</script>
```

This is the first part to refactor the logic, by moving it nearer to the linter, where the source text / sections are available.
Probably needs some LSP feature flag for the message to pass the information of the current `ContextSubHost` source text offset.
@graphite-app graphite-app bot force-pushed the 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix branch from 7079e73 to 7a0eb57 Compare September 28, 2025 15:44
@graphite-app graphite-app bot merged commit 7a0eb57 into main Sep 28, 2025
20 checks passed
@graphite-app graphite-app bot deleted the 09-27-refactor_language_server_refactor_ignore_code_action_logic_as_a_linter_fix branch September 28, 2025 15:48
@graphite-app graphite-app bot removed the 0-merge Merge with Graphite Merge Queue label Sep 28, 2025
taearls pushed a commit to taearls/oxc that referenced this pull request Sep 28, 2025
…ter fix (oxc-project#14183)

part of oxc-project#11707
`disable rule for this file` are only valid for the current `SubContextHost` and will produce syntax error for vue files.
A comment like this will be added.
```
// oxlint-disable no-debugger
<script>
debugger;
</script>
```

This is the first part to refactor the logic, by moving it nearer to the linter, where the source text / sections are available.
Probably needs some LSP feature flag for the message to pass the information of the current `ContextSubHost` source text offset.
taearls pushed a commit to taearls/oxc that referenced this pull request Sep 28, 2025
…ter fix (oxc-project#14183)

part of oxc-project#11707
`disable rule for this file` are only valid for the current `SubContextHost` and will produce syntax error for vue files.
A comment like this will be added.
```
// oxlint-disable no-debugger
<script>
debugger;
</script>
```

This is the first part to refactor the logic, by moving it nearer to the linter, where the source text / sections are available.
Probably needs some LSP feature flag for the message to pass the information of the current `ContextSubHost` source text offset.
camc314 added a commit that referenced this pull request Sep 29, 2025
## [1.19.0] - 2025-09-29

### 🚀 Features

- eb6345f linter/unicorn: Implement no-array-callback-reference (#14230)
(camc314)
- c64fa61 linter: Add `import/no-named-export` rule (#14229) (yefan)
- d30159b linter: Fix for unsorted keys (#14225) (Hamir Mahal)
- acd1266 linter/plugins: `oxlint` export types (#14163) (overlookmotel)
- c0e461f linter: Add `unicorn/no-array-sort` rule (#14117) (Cason
Kervis)
- 00954de linter/plugins: Remove `--js-plugins` CLI option (#14134)
(overlookmotel)
- b4d716f linter/plugins: Move custom JS plugin config to `jsPlugins`
(#14133) (overlookmotel)
- 60f0b3f linter: Add fix for `preserve-caught-error` (#14104) (Cam
McHenry)
- 2d74c17 linter/no-multiple-resolved: Implement promise rule
no-multiple-resolved (#13420) (Li Wei)
- 5e05d1b semantic: Put jsdoc behind linter feature, remove runtime flag
(#14140) (Boshen)
- 71af1aa semantic: Add "linter" feature (#14139) (Boshen)
- 1a6d7ae linter: Add `vue/max-props` rule (#14039) (yefan)
- 9c3afea linter/plugins: Support fixes (#14094) (overlookmotel)
- 1472147 linter: Move `no-unused-expressions` to correctness (#14099)
(camchenry)
- 8b7c784 linter: Add react/jsx-pascal-case rule (#12165) (Mikhail Baev)
- c796966 linter/plugins: Add `meta` property to rules (#14089)
(overlookmotel)

### 🐛 Bug Fixes

- 39a171e linter: Get cli args on JS side, to avoid runtime
inconsistencies (#14223) (camc314)
- e045391 linter/plugins: Error on JS plugin with reserved name (#14226)
(overlookmotel)
- 6005015 linter: Correctly handle CRLF when inserting disable comments
in framework files (#14228) (shulaoda)
- 37f6b09 linter/plugins: Make `null` a valid value for `meta.fixable`
(#14204) (overlookmotel)
- 8879b5a linter/plugins: Add types export to `npm/oxlint` (#14219)
(overlookmotel)
- e37c435 language_server: Correct position for "ignore this rule for
this file" in vue/astro/svelte files (#14187) (Sysix)
- f8abab2 editor: Stricter path validation for `oxc.path.server`
(#14202) (Sysix)
- e9a14d1 linter/plugins: Allow `fix` function to return `undefined`
(#14182) (overlookmotel)
- ee9ecbe linter/plugins: Fix TS type for fixer methods (#14166)
(overlookmotel)
- 03d1684 linter/plugins: Output warning on first JS plugin load
(#14165) (overlookmotel)
- 9716f7c linter/plugins: Fix TS types (#14162) (overlookmotel)
- d36d227 language_server: Don't lint file on code action when it is
already ignored (#13976) (Sysix)
- 353bfe7 language_server: Check if tsconfig path is a file before
starting the `LintService` (#14126) (Sysix)
- fc7026d linter: Add missing `NODE_TYPES`, `cfg_id` method for
no-multiple-resolved (#14147) (camc314)
- 180c790 linter: Fix false positive in `no-restricted-globals` (#14135)
(yefan)
- 4a4fce8 linter: Fix cli argument parsing (#14112) (camc314)
- 9f3e2bc linter/plugins: Output errors thrown in JS plugins (#14096)
(overlookmotel)
- 357a2d3 linter: Add support for `tsgolint.exe` on Windows (#14101)
(camchenry)
- 2604b28 linter: Fix lint errors building `oxlint` (#14095)
(overlookmotel)
- d8e9cc5 linter/plugins: Validate type of `before` and `after` hooks
(#14086) (overlookmotel)

### 🚜 Refactor

- 4c3f1ac linter: Move `BUILT_IN_ERRORS` to utils file (#14221)
(camc314)
- 61ec0a7 linter/plugins: Simplify creation of `context` in `defineRule`
ESLint shim (#14206) (overlookmotel)
- 7a0eb57 language_server: Refactor ignore code action logic as a linter
fix (#14183) (Sysix)
- 3b1fe6f linter/plugins: Flatten directory structure of `dist` (#14199)
(overlookmotel)
- d52cba6 linter: Bump TSDown to latest (#14198) (overlookmotel)
- 983dd1b linter/plugins: Add `Fixer` type (#14180) (overlookmotel)
- 2f8b076 linter/plugins: Remove dead code (#14178) (overlookmotel)
- 497236e semantic: Move AstNode::cfg_id to struct of arrays in AstNodes
(#14137) (Boshen)
- 5ba765c semantic: Move AstNode::flags to struct of arrays in AstNodes
(#14136) (Boshen)
- ffc810d linter: `preserve-caught-errors`: rename config and add docs
(#14103) (camchenry)
- f91db73 linter: Add `CompositeFix::merge_fixes_fallible` method
(#14093) (overlookmotel)
- e55ffe0 curly: Enhance curly brace rule configuration and handling
(#13498) (Antoine Zanardi)
- 2fb69fd eslint/eqeqeq: Clean up implementation and improve
documentation (#13527) (Antoine Zanardi)
- e69cd86 linter/plugins: `loadPluginImpl` return an object (#14087)
(overlookmotel)

### 📚 Documentation

- b83b1bd language_server: Docs for `Backend` struct (#14172) (Sysix)
- 3106ba0 language_server: Docs for `WorkspaceWorker` (#14161) (Sysix)
- b19f5bc linter/plugins: Improve JSDoc comments for `definePlugin` and
`defineRule` (#14159) (overlookmotel)

### ⚡ Performance

- 2575065 linter/plugins: Store if rule is fixable as boolean (#14205)
(overlookmotel)
- b6d2546 linter: Reduce string cloning in tsgo fixes (#14092)
(overlookmotel)
- c94c5dc linter: Remove allocation in `CompositeFix::merge_fixes`
(#14090) (overlookmotel)

### 🧪 Testing

- be58d6d language_server: Fix test for ServerFormatter in windows
(#14210) (Sysix)
- a9b603e linter/plugins: Convert all plugins in tests to TS (#14200)
(overlookmotel)
- 6ff3a23 linter/plugins: Add tests for `.ts`, `.mts`, `.cts` plugin
files (#14164) (overlookmotel)
- 8988d64 linter/plugins: Add line breaks to plugins files (#14181)
(overlookmotel)
- d7041c1 language_server: Add linebreaks for formatter snapshot
(#14173) (Sysix)
- 52db331 linter/plugins: Type-check test fixtures (#14158)
(overlookmotel)
- aca083a linter/plugins: Include stderr output in snapshots (#14155)
(overlookmotel)
- a3c8f46 linter/plugins: Do not run `pnpm` in tests (#14157)
(overlookmotel)
- d985aeb editor: Remove cross-module tests, covered by language server
(#14156) (Sysix)
- 0029b7f linter/plugins: Normalize line breaks in snapshots (#14154)
(overlookmotel)
- 7f2c101 linter/plugins: Specify path to `node` in tests (#14152)
(overlookmotel)
- fc14abc linter/plugins: Format test fixtures (#14125) (overlookmotel)
- a6f965f linter/plugins: Simplify configs in test fixtures (#14124)
(overlookmotel)
- b1685f7 linter/plugins: Refactor tests (#14123) (overlookmotel)
- 788e495 linter/plugins: Improve ESLint compat tests (#14119)
(overlookmotel)
- 5750077 linter/plugins: Fix file paths in snapshots (#14115)
(overlookmotel)
- 5c862f9 linter/plugins: Standardize test fixture structure (#14114)
(overlookmotel)

Co-authored-by: camc314 <18101008+camc314@users.noreply.github.com>
graphite-app bot pushed a commit that referenced this pull request Sep 29, 2025
… code action + command (#14243)

This PR fixes a bug where on `source.fixAll.oxc` code action or `oxc.fixAll` command will append `// oxlint-disable ...` comments to the file.
This bug was introduced in #14183
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

A-editor Area - Editor and Language Server A-linter Area - Linter C-cleanup Category - technical debt or refactoring. Solution not expected to change behavior

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants