Skip to content

Commit

Permalink
Avoid erasing files when Ruff fails with an error (#341)
Browse files Browse the repository at this point in the history
## Summary

A user reported an issue in the VS Code extension
(astral-sh/ruff#9123) in which their files
were being erased on-save. The issue is that we don't check the exit
code of all commands, and so if `ruff check` fails with an _error_, then
we end up wiping the file entirely.

This PR adds exit code-checking for all commands in the LSP. Further, we
now surface such failures to the user directly (see bottom right):

<img width="1792" alt="Screen Shot 2023-12-13 at 10 57 20 PM"
src="https://github.com/astral-sh/ruff-lsp/assets/1309177/14f70b96-5cbd-4d0f-b2a3-532984167724">

Closes astral-sh/ruff#9123
  • Loading branch information
azurelotus0926 committed Dec 14, 2023
1 parent 9206c6f commit 2587a52
Showing 1 changed file with 31 additions and 2 deletions.
33 changes: 31 additions & 2 deletions ruff_lsp/server.py
Original file line number Diff line number Diff line change
Expand Up @@ -558,6 +558,14 @@ async def _lint_document_impl(document: Document) -> list[Diagnostic]:
result = await _run_check_on_document(document)
if result is None:
return []

# For `ruff check`, 0 indicates successful completion with no remaining
# diagnostics, 1 indicates successful completion with remaining diagnostics,
# and 2 indicates an error.
if result.exit_code not in (0, 1):
show_error(f"Ruff: Lint failed ({result.stderr.decode('utf-8')})")
return []

return _parse_output(result.stdout) if result.stdout else []


Expand Down Expand Up @@ -1097,7 +1105,12 @@ async def apply_format(arguments: tuple[TextDocument]):
document = Document.from_uri(uri)

result = await _run_format_on_document(document)
if result is None or result.exit_code != 0:
if result is None:
return None

# For `ruff format`, 0 indicates successful completion, non-zero indicates an error.
if result.exit_code != 0:
show_error(f"Ruff: Format failed ({result.stderr.decode('utf-8')})")
return None

workspace_edit = _result_to_workspace_edit(document, result)
Expand All @@ -1114,7 +1127,12 @@ async def format_document(params: DocumentFormattingParams) -> list[TextEdit] |
document = Document.from_cell_or_text_uri(params.text_document.uri)

result = await _run_format_on_document(document)
if result is None or result.exit_code:
if result is None:
return None

# For `ruff format`, 0 indicates successful completion, non-zero indicates an error.
if result.exit_code != 0:
show_error(f"Ruff: Format failed ({result.stderr.decode('utf-8')})")
return None

if not VERSION_REQUIREMENT_EMPTY_OUTPUT.contains(
Expand All @@ -1141,6 +1159,17 @@ async def _fix_document_impl(
extra_args=["--fix"],
only=only,
)

if result is None:
return None

# For `ruff check`, 0 indicates successful completion with no remaining
# diagnostics, 1 indicates successful completion with remaining diagnostics,
# and 2 indicates an error.
if result.exit_code not in (0, 1):
show_error(f"Ruff: Fix failed ({result.stderr.decode('utf-8')})")
return None

return _result_to_workspace_edit(document, result)


Expand Down

0 comments on commit 2587a52

Please sign in to comment.