mirror of
https://github.com/astral-sh/ruff.git
synced 2025-08-31 07:37:38 +00:00
Pass ParserOptions
to the parser (#16220)
## Summary This is part of the preparation for detecting syntax errors in the parser from https://github.com/astral-sh/ruff/pull/16090/. As suggested in [this comment](https://github.com/astral-sh/ruff/pull/16090/#discussion_r1953084509), I started working on a `ParseOptions` struct that could be stored in the parser. For this initial refactor, I only made it hold the existing `Mode` option, but for syntax errors, we will also need it to have a `PythonVersion`. For that use case, I'm picturing something like a `ParseOptions::with_python_version` method, so you can extend the current calls to something like ```rust ParseOptions::from(mode).with_python_version(settings.target_version) ``` But I thought it was worth adding `ParseOptions` alone without changing any other behavior first. Most of the diff is just updating call sites taking `Mode` to take `ParseOptions::from(Mode)` or those taking `PySourceType`s to take `ParseOptions::from(PySourceType)`. The interesting changes are in the new `parser/options.rs` file and smaller parts of `parser/mod.rs` and `ruff_python_parser/src/lib.rs`. ## Test Plan Existing tests, this should not change any behavior.
This commit is contained in:
parent
cfc6941d5c
commit
97d0659ce3
25 changed files with 148 additions and 93 deletions
|
@ -6,7 +6,7 @@ use std::path::Path;
|
|||
use ruff_annotate_snippets::{Level, Renderer, Snippet};
|
||||
use ruff_python_ast::visitor::source_order::{walk_module, SourceOrderVisitor, TraversalSignal};
|
||||
use ruff_python_ast::{AnyNodeRef, Mod};
|
||||
use ruff_python_parser::{parse_unchecked, Mode, ParseErrorType, Token};
|
||||
use ruff_python_parser::{parse_unchecked, Mode, ParseErrorType, ParseOptions, Token};
|
||||
use ruff_source_file::{LineIndex, OneIndexed, SourceCode};
|
||||
use ruff_text_size::{Ranged, TextLen, TextRange, TextSize};
|
||||
|
||||
|
@ -34,7 +34,7 @@ fn inline_err() {
|
|||
/// Snapshots the AST.
|
||||
fn test_valid_syntax(input_path: &Path) {
|
||||
let source = fs::read_to_string(input_path).expect("Expected test file to exist");
|
||||
let parsed = parse_unchecked(&source, Mode::Module);
|
||||
let parsed = parse_unchecked(&source, ParseOptions::from(Mode::Module));
|
||||
|
||||
if !parsed.is_valid() {
|
||||
let line_index = LineIndex::from_source_text(&source);
|
||||
|
@ -78,7 +78,7 @@ fn test_valid_syntax(input_path: &Path) {
|
|||
/// Snapshots the AST and the error messages.
|
||||
fn test_invalid_syntax(input_path: &Path) {
|
||||
let source = fs::read_to_string(input_path).expect("Expected test file to exist");
|
||||
let parsed = parse_unchecked(&source, Mode::Module);
|
||||
let parsed = parse_unchecked(&source, ParseOptions::from(Mode::Module));
|
||||
|
||||
assert!(
|
||||
!parsed.is_valid(),
|
||||
|
@ -130,7 +130,7 @@ f'{'
|
|||
f'{foo!r'
|
||||
";
|
||||
|
||||
let parsed = parse_unchecked(source, Mode::Module);
|
||||
let parsed = parse_unchecked(source, ParseOptions::from(Mode::Module));
|
||||
|
||||
println!("AST:\n----\n{:#?}", parsed.syntax());
|
||||
println!("Tokens:\n-------\n{:#?}", parsed.tokens());
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue