mirror of
https://github.com/astral-sh/ruff.git
synced 2025-09-27 12:29:28 +00:00
Auto-generate AST boilerplate (#15544)
This PR replaces most of the hard-coded AST definitions with a generation script, similar to what happens in `rust_python_formatter`. I've replaced every "rote" definition that I could find, where the content is entirely boilerplate and only depends on what syntax nodes there are and which groups they belong to. This is a pretty massive diff, but it's entirely a refactoring. It should make absolutely no changes to the API or implementation. In particular, this required adding some configuration knobs that let us override default auto-generated names where they don't line up with types that we created previously by hand. ## Test plan There should be no changes outside of the `rust_python_ast` crate, which verifies that there were no API changes as a result of the auto-generation. Aggressive `cargo clippy` and `uvx pre-commit` runs after each commit in the branch. --------- Co-authored-by: Micha Reiser <micha@reiser.io> Co-authored-by: Alex Waygood <Alex.Waygood@Gmail.com>
This commit is contained in:
parent
4351d85d24
commit
8e3633f55a
15 changed files with 10074 additions and 8513 deletions
|
@ -4,334 +4,15 @@ use ruff_text_size::{Ranged, TextRange};
|
|||
|
||||
use crate::{
|
||||
self as ast, AnyNodeRef, AnyStringFlags, Expr, ExprBytesLiteral, ExprFString,
|
||||
ExprStringLiteral, StringFlags,
|
||||
ExprStringLiteral, ExpressionRef, StringFlags,
|
||||
};
|
||||
|
||||
/// Unowned pendant to [`ast::Expr`] that stores a reference instead of a owned value.
|
||||
#[derive(Copy, Clone, Debug, PartialEq)]
|
||||
pub enum ExpressionRef<'a> {
|
||||
BoolOp(&'a ast::ExprBoolOp),
|
||||
Named(&'a ast::ExprNamed),
|
||||
BinOp(&'a ast::ExprBinOp),
|
||||
UnaryOp(&'a ast::ExprUnaryOp),
|
||||
Lambda(&'a ast::ExprLambda),
|
||||
If(&'a ast::ExprIf),
|
||||
Dict(&'a ast::ExprDict),
|
||||
Set(&'a ast::ExprSet),
|
||||
ListComp(&'a ast::ExprListComp),
|
||||
SetComp(&'a ast::ExprSetComp),
|
||||
DictComp(&'a ast::ExprDictComp),
|
||||
Generator(&'a ast::ExprGenerator),
|
||||
Await(&'a ast::ExprAwait),
|
||||
Yield(&'a ast::ExprYield),
|
||||
YieldFrom(&'a ast::ExprYieldFrom),
|
||||
Compare(&'a ast::ExprCompare),
|
||||
Call(&'a ast::ExprCall),
|
||||
FString(&'a ast::ExprFString),
|
||||
StringLiteral(&'a ast::ExprStringLiteral),
|
||||
BytesLiteral(&'a ast::ExprBytesLiteral),
|
||||
NumberLiteral(&'a ast::ExprNumberLiteral),
|
||||
BooleanLiteral(&'a ast::ExprBooleanLiteral),
|
||||
NoneLiteral(&'a ast::ExprNoneLiteral),
|
||||
EllipsisLiteral(&'a ast::ExprEllipsisLiteral),
|
||||
Attribute(&'a ast::ExprAttribute),
|
||||
Subscript(&'a ast::ExprSubscript),
|
||||
Starred(&'a ast::ExprStarred),
|
||||
Name(&'a ast::ExprName),
|
||||
List(&'a ast::ExprList),
|
||||
Tuple(&'a ast::ExprTuple),
|
||||
Slice(&'a ast::ExprSlice),
|
||||
IpyEscapeCommand(&'a ast::ExprIpyEscapeCommand),
|
||||
}
|
||||
|
||||
impl<'a> From<&'a Box<Expr>> for ExpressionRef<'a> {
|
||||
fn from(value: &'a Box<Expr>) -> Self {
|
||||
ExpressionRef::from(value.as_ref())
|
||||
}
|
||||
}
|
||||
|
||||
impl<'a> From<&'a Expr> for ExpressionRef<'a> {
|
||||
fn from(value: &'a Expr) -> Self {
|
||||
match value {
|
||||
Expr::BoolOp(value) => ExpressionRef::BoolOp(value),
|
||||
Expr::Named(value) => ExpressionRef::Named(value),
|
||||
Expr::BinOp(value) => ExpressionRef::BinOp(value),
|
||||
Expr::UnaryOp(value) => ExpressionRef::UnaryOp(value),
|
||||
Expr::Lambda(value) => ExpressionRef::Lambda(value),
|
||||
Expr::If(value) => ExpressionRef::If(value),
|
||||
Expr::Dict(value) => ExpressionRef::Dict(value),
|
||||
Expr::Set(value) => ExpressionRef::Set(value),
|
||||
Expr::ListComp(value) => ExpressionRef::ListComp(value),
|
||||
Expr::SetComp(value) => ExpressionRef::SetComp(value),
|
||||
Expr::DictComp(value) => ExpressionRef::DictComp(value),
|
||||
Expr::Generator(value) => ExpressionRef::Generator(value),
|
||||
Expr::Await(value) => ExpressionRef::Await(value),
|
||||
Expr::Yield(value) => ExpressionRef::Yield(value),
|
||||
Expr::YieldFrom(value) => ExpressionRef::YieldFrom(value),
|
||||
Expr::Compare(value) => ExpressionRef::Compare(value),
|
||||
Expr::Call(value) => ExpressionRef::Call(value),
|
||||
Expr::FString(value) => ExpressionRef::FString(value),
|
||||
Expr::StringLiteral(value) => ExpressionRef::StringLiteral(value),
|
||||
Expr::BytesLiteral(value) => ExpressionRef::BytesLiteral(value),
|
||||
Expr::NumberLiteral(value) => ExpressionRef::NumberLiteral(value),
|
||||
Expr::BooleanLiteral(value) => ExpressionRef::BooleanLiteral(value),
|
||||
Expr::NoneLiteral(value) => ExpressionRef::NoneLiteral(value),
|
||||
Expr::EllipsisLiteral(value) => ExpressionRef::EllipsisLiteral(value),
|
||||
Expr::Attribute(value) => ExpressionRef::Attribute(value),
|
||||
Expr::Subscript(value) => ExpressionRef::Subscript(value),
|
||||
Expr::Starred(value) => ExpressionRef::Starred(value),
|
||||
Expr::Name(value) => ExpressionRef::Name(value),
|
||||
Expr::List(value) => ExpressionRef::List(value),
|
||||
Expr::Tuple(value) => ExpressionRef::Tuple(value),
|
||||
Expr::Slice(value) => ExpressionRef::Slice(value),
|
||||
Expr::IpyEscapeCommand(value) => ExpressionRef::IpyEscapeCommand(value),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<'a> From<&'a ast::ExprBoolOp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprBoolOp) -> Self {
|
||||
Self::BoolOp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprNamed> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprNamed) -> Self {
|
||||
Self::Named(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprBinOp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprBinOp) -> Self {
|
||||
Self::BinOp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprUnaryOp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprUnaryOp) -> Self {
|
||||
Self::UnaryOp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprLambda> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprLambda) -> Self {
|
||||
Self::Lambda(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprIf> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprIf) -> Self {
|
||||
Self::If(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprDict> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprDict) -> Self {
|
||||
Self::Dict(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprSet> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprSet) -> Self {
|
||||
Self::Set(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprListComp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprListComp) -> Self {
|
||||
Self::ListComp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprSetComp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprSetComp) -> Self {
|
||||
Self::SetComp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprDictComp> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprDictComp) -> Self {
|
||||
Self::DictComp(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprGenerator> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprGenerator) -> Self {
|
||||
Self::Generator(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprAwait> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprAwait) -> Self {
|
||||
Self::Await(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprYield> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprYield) -> Self {
|
||||
Self::Yield(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprYieldFrom> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprYieldFrom) -> Self {
|
||||
Self::YieldFrom(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprCompare> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprCompare) -> Self {
|
||||
Self::Compare(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprCall> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprCall) -> Self {
|
||||
Self::Call(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprFString> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprFString) -> Self {
|
||||
Self::FString(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprStringLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprStringLiteral) -> Self {
|
||||
Self::StringLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprBytesLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprBytesLiteral) -> Self {
|
||||
Self::BytesLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprNumberLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprNumberLiteral) -> Self {
|
||||
Self::NumberLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprBooleanLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprBooleanLiteral) -> Self {
|
||||
Self::BooleanLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprNoneLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprNoneLiteral) -> Self {
|
||||
Self::NoneLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprEllipsisLiteral> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprEllipsisLiteral) -> Self {
|
||||
Self::EllipsisLiteral(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprAttribute> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprAttribute) -> Self {
|
||||
Self::Attribute(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprSubscript> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprSubscript) -> Self {
|
||||
Self::Subscript(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprStarred> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprStarred) -> Self {
|
||||
Self::Starred(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprName> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprName) -> Self {
|
||||
Self::Name(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprList> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprList) -> Self {
|
||||
Self::List(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprTuple> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprTuple) -> Self {
|
||||
Self::Tuple(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprSlice> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprSlice) -> Self {
|
||||
Self::Slice(value)
|
||||
}
|
||||
}
|
||||
impl<'a> From<&'a ast::ExprIpyEscapeCommand> for ExpressionRef<'a> {
|
||||
fn from(value: &'a ast::ExprIpyEscapeCommand) -> Self {
|
||||
Self::IpyEscapeCommand(value)
|
||||
}
|
||||
}
|
||||
|
||||
impl<'a> From<ExpressionRef<'a>> for AnyNodeRef<'a> {
|
||||
fn from(value: ExpressionRef<'a>) -> Self {
|
||||
match value {
|
||||
ExpressionRef::BoolOp(expression) => AnyNodeRef::ExprBoolOp(expression),
|
||||
ExpressionRef::Named(expression) => AnyNodeRef::ExprNamed(expression),
|
||||
ExpressionRef::BinOp(expression) => AnyNodeRef::ExprBinOp(expression),
|
||||
ExpressionRef::UnaryOp(expression) => AnyNodeRef::ExprUnaryOp(expression),
|
||||
ExpressionRef::Lambda(expression) => AnyNodeRef::ExprLambda(expression),
|
||||
ExpressionRef::If(expression) => AnyNodeRef::ExprIf(expression),
|
||||
ExpressionRef::Dict(expression) => AnyNodeRef::ExprDict(expression),
|
||||
ExpressionRef::Set(expression) => AnyNodeRef::ExprSet(expression),
|
||||
ExpressionRef::ListComp(expression) => AnyNodeRef::ExprListComp(expression),
|
||||
ExpressionRef::SetComp(expression) => AnyNodeRef::ExprSetComp(expression),
|
||||
ExpressionRef::DictComp(expression) => AnyNodeRef::ExprDictComp(expression),
|
||||
ExpressionRef::Generator(expression) => AnyNodeRef::ExprGenerator(expression),
|
||||
ExpressionRef::Await(expression) => AnyNodeRef::ExprAwait(expression),
|
||||
ExpressionRef::Yield(expression) => AnyNodeRef::ExprYield(expression),
|
||||
ExpressionRef::YieldFrom(expression) => AnyNodeRef::ExprYieldFrom(expression),
|
||||
ExpressionRef::Compare(expression) => AnyNodeRef::ExprCompare(expression),
|
||||
ExpressionRef::Call(expression) => AnyNodeRef::ExprCall(expression),
|
||||
ExpressionRef::FString(expression) => AnyNodeRef::ExprFString(expression),
|
||||
ExpressionRef::StringLiteral(expression) => AnyNodeRef::ExprStringLiteral(expression),
|
||||
ExpressionRef::BytesLiteral(expression) => AnyNodeRef::ExprBytesLiteral(expression),
|
||||
ExpressionRef::NumberLiteral(expression) => AnyNodeRef::ExprNumberLiteral(expression),
|
||||
ExpressionRef::BooleanLiteral(expression) => AnyNodeRef::ExprBooleanLiteral(expression),
|
||||
ExpressionRef::NoneLiteral(expression) => AnyNodeRef::ExprNoneLiteral(expression),
|
||||
ExpressionRef::EllipsisLiteral(expression) => {
|
||||
AnyNodeRef::ExprEllipsisLiteral(expression)
|
||||
}
|
||||
ExpressionRef::Attribute(expression) => AnyNodeRef::ExprAttribute(expression),
|
||||
ExpressionRef::Subscript(expression) => AnyNodeRef::ExprSubscript(expression),
|
||||
ExpressionRef::Starred(expression) => AnyNodeRef::ExprStarred(expression),
|
||||
ExpressionRef::Name(expression) => AnyNodeRef::ExprName(expression),
|
||||
ExpressionRef::List(expression) => AnyNodeRef::ExprList(expression),
|
||||
ExpressionRef::Tuple(expression) => AnyNodeRef::ExprTuple(expression),
|
||||
ExpressionRef::Slice(expression) => AnyNodeRef::ExprSlice(expression),
|
||||
ExpressionRef::IpyEscapeCommand(expression) => {
|
||||
AnyNodeRef::ExprIpyEscapeCommand(expression)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Ranged for ExpressionRef<'_> {
|
||||
fn range(&self) -> TextRange {
|
||||
match self {
|
||||
ExpressionRef::BoolOp(expression) => expression.range(),
|
||||
ExpressionRef::Named(expression) => expression.range(),
|
||||
ExpressionRef::BinOp(expression) => expression.range(),
|
||||
ExpressionRef::UnaryOp(expression) => expression.range(),
|
||||
ExpressionRef::Lambda(expression) => expression.range(),
|
||||
ExpressionRef::If(expression) => expression.range(),
|
||||
ExpressionRef::Dict(expression) => expression.range(),
|
||||
ExpressionRef::Set(expression) => expression.range(),
|
||||
ExpressionRef::ListComp(expression) => expression.range(),
|
||||
ExpressionRef::SetComp(expression) => expression.range(),
|
||||
ExpressionRef::DictComp(expression) => expression.range(),
|
||||
ExpressionRef::Generator(expression) => expression.range(),
|
||||
ExpressionRef::Await(expression) => expression.range(),
|
||||
ExpressionRef::Yield(expression) => expression.range(),
|
||||
ExpressionRef::YieldFrom(expression) => expression.range(),
|
||||
ExpressionRef::Compare(expression) => expression.range(),
|
||||
ExpressionRef::Call(expression) => expression.range(),
|
||||
ExpressionRef::FString(expression) => expression.range(),
|
||||
ExpressionRef::StringLiteral(expression) => expression.range(),
|
||||
ExpressionRef::BytesLiteral(expression) => expression.range(),
|
||||
ExpressionRef::NumberLiteral(expression) => expression.range(),
|
||||
ExpressionRef::BooleanLiteral(expression) => expression.range(),
|
||||
ExpressionRef::NoneLiteral(expression) => expression.range(),
|
||||
ExpressionRef::EllipsisLiteral(expression) => expression.range(),
|
||||
ExpressionRef::Attribute(expression) => expression.range(),
|
||||
ExpressionRef::Subscript(expression) => expression.range(),
|
||||
ExpressionRef::Starred(expression) => expression.range(),
|
||||
ExpressionRef::Name(expression) => expression.range(),
|
||||
ExpressionRef::List(expression) => expression.range(),
|
||||
ExpressionRef::Tuple(expression) => expression.range(),
|
||||
ExpressionRef::Slice(expression) => expression.range(),
|
||||
ExpressionRef::IpyEscapeCommand(expression) => expression.range(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// Unowned pendant to all the literal variants of [`ast::Expr`] that stores a
|
||||
/// reference instead of an owned value.
|
||||
#[derive(Copy, Clone, Debug, PartialEq, is_macro::Is)]
|
||||
|
|
8790
crates/ruff_python_ast/src/generated.rs
generated
Normal file
8790
crates/ruff_python_ast/src/generated.rs
generated
Normal file
File diff suppressed because it is too large
Load diff
|
@ -2,13 +2,15 @@ use std::ffi::OsStr;
|
|||
use std::path::Path;
|
||||
|
||||
pub use expression::*;
|
||||
pub use generated::*;
|
||||
pub use int::*;
|
||||
pub use node::{AnyNode, AnyNodeRef, AstNode, NodeKind};
|
||||
pub use node::AstNode;
|
||||
pub use nodes::*;
|
||||
|
||||
pub mod comparable;
|
||||
pub mod docstrings;
|
||||
mod expression;
|
||||
mod generated;
|
||||
pub mod helpers;
|
||||
pub mod identifier;
|
||||
mod int;
|
||||
|
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -1,10 +1,10 @@
|
|||
use crate::AnyNodeRef;
|
||||
use crate::{
|
||||
Alias, Arguments, BoolOp, BytesLiteral, CmpOp, Comprehension, Decorator, ElifElseClause,
|
||||
ExceptHandler, Expr, FString, FStringElement, Keyword, MatchCase, Mod, Operator, Parameter,
|
||||
ParameterWithDefault, Parameters, Pattern, PatternArguments, PatternKeyword, Singleton, Stmt,
|
||||
StringLiteral, TypeParam, TypeParams, UnaryOp, WithItem,
|
||||
};
|
||||
use crate::{AnyNodeRef, AstNode};
|
||||
|
||||
/// Visitor that traverses all nodes recursively in the order they appear in the source.
|
||||
///
|
||||
|
@ -203,33 +203,7 @@ where
|
|||
let node = AnyNodeRef::from(stmt);
|
||||
|
||||
if visitor.enter_node(node).is_traverse() {
|
||||
match stmt {
|
||||
Stmt::Expr(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::FunctionDef(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::ClassDef(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Return(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Delete(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::TypeAlias(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Assign(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::AugAssign(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::AnnAssign(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::For(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::While(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::If(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::With(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Match(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Raise(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Try(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Assert(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Import(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::ImportFrom(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Pass(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Break(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Continue(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Global(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::Nonlocal(stmt) => stmt.visit_source_order(visitor),
|
||||
Stmt::IpyEscapeCommand(stmt) => stmt.visit_source_order(visitor),
|
||||
}
|
||||
stmt.visit_source_order(visitor);
|
||||
}
|
||||
|
||||
visitor.leave_node(node);
|
||||
|
@ -455,11 +429,7 @@ where
|
|||
{
|
||||
let node = AnyNodeRef::from(type_param);
|
||||
if visitor.enter_node(node).is_traverse() {
|
||||
match type_param {
|
||||
TypeParam::TypeVar(type_param) => type_param.visit_source_order(visitor),
|
||||
TypeParam::TypeVarTuple(type_param) => type_param.visit_source_order(visitor),
|
||||
TypeParam::ParamSpec(type_param) => type_param.visit_source_order(visitor),
|
||||
}
|
||||
type_param.visit_source_order(visitor);
|
||||
}
|
||||
visitor.leave_node(node);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue