Skip to content

Commit

Permalink
Move function visit out of Expr::Call branches (astral-sh#5772)
Browse files Browse the repository at this point in the history
## Summary

Non-behavioral change, but this is the same in each branch. Visiting the
`func` first also means we've visited the `func` by the time we try to
resolve it (via `resolve_call_path`), which should be helpful in a
future refactor.
  • Loading branch information
charliermarsh authored and evanrittenhouse committed Jul 19, 2023
1 parent 1367896 commit 6a022df
Showing 1 changed file with 3 additions and 11 deletions.
14 changes: 3 additions & 11 deletions crates/ruff/src/checkers/ast/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3582,6 +3582,8 @@ where
keywords,
range: _,
}) => {
self.visit_expr(func);

let callable = self.semantic.resolve_call_path(func).and_then(|call_path| {
if self.semantic.match_typing_call_path(&call_path, "cast") {
Some(typing::Callable::Cast)
Expand Down Expand Up @@ -3620,7 +3622,6 @@ where
});
match callable {
Some(typing::Callable::Bool) => {
self.visit_expr(func);
let mut args = args.iter();
if let Some(arg) = args.next() {
self.visit_boolean_test(arg);
Expand All @@ -3630,7 +3631,6 @@ where
}
}
Some(typing::Callable::Cast) => {
self.visit_expr(func);
let mut args = args.iter();
if let Some(arg) = args.next() {
self.visit_type_definition(arg);
Expand All @@ -3640,7 +3640,6 @@ where
}
}
Some(typing::Callable::NewType) => {
self.visit_expr(func);
let mut args = args.iter();
if let Some(arg) = args.next() {
self.visit_non_type_definition(arg);
Expand All @@ -3650,7 +3649,6 @@ where
}
}
Some(typing::Callable::TypeVar) => {
self.visit_expr(func);
let mut args = args.iter();
if let Some(arg) = args.next() {
self.visit_non_type_definition(arg);
Expand All @@ -3674,8 +3672,6 @@ where
}
}
Some(typing::Callable::NamedTuple) => {
self.visit_expr(func);

// Ex) NamedTuple("a", [("a", int)])
let mut args = args.iter();
if let Some(arg) = args.next() {
Expand Down Expand Up @@ -3711,8 +3707,6 @@ where
}
}
Some(typing::Callable::TypedDict) => {
self.visit_expr(func);

// Ex) TypedDict("a", {"a": int})
let mut args = args.iter();
if let Some(arg) = args.next() {
Expand Down Expand Up @@ -3743,8 +3737,6 @@ where
}
}
Some(typing::Callable::MypyExtension) => {
self.visit_expr(func);

let mut args = args.iter();
if let Some(arg) = args.next() {
// Ex) DefaultNamedArg(bool | None, name="some_prop_name")
Expand Down Expand Up @@ -3777,7 +3769,7 @@ where
// If we're in a type definition, we need to treat the arguments to any
// other callables as non-type definitions (i.e., we don't want to treat
// any strings as deferred type definitions).
self.visit_expr(func);

for arg in args {
self.visit_non_type_definition(arg);
}
Expand Down

0 comments on commit 6a022df

Please sign in to comment.