mirror of
https://github.com/astral-sh/ruff.git
synced 2025-07-23 04:55:09 +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
|
@ -1435,7 +1435,7 @@ impl<'a> Generator<'a> {
|
|||
#[cfg(test)]
|
||||
mod tests {
|
||||
use ruff_python_ast::{Mod, ModModule};
|
||||
use ruff_python_parser::{self, parse_module, Mode};
|
||||
use ruff_python_parser::{self, parse_module, Mode, ParseOptions};
|
||||
use ruff_source_file::LineEnding;
|
||||
|
||||
use crate::stylist::Indentation;
|
||||
|
@ -1467,7 +1467,8 @@ mod tests {
|
|||
fn jupyter_round_trip(contents: &str) -> String {
|
||||
let indentation = Indentation::default();
|
||||
let line_ending = LineEnding::default();
|
||||
let parsed = ruff_python_parser::parse(contents, Mode::Ipython).unwrap();
|
||||
let parsed =
|
||||
ruff_python_parser::parse(contents, ParseOptions::from(Mode::Ipython)).unwrap();
|
||||
let Mod::Module(ModModule { body, .. }) = parsed.into_syntax() else {
|
||||
panic!("Source code didn't return ModModule")
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue