Skip to content

Commit

Permalink
pythongh-90953: Don't use deprecated AST nodes in clinic.py
Browse files Browse the repository at this point in the history
  • Loading branch information
AlexWaygood committed May 9, 2023
1 parent 41aff46 commit d8d0ae6
Showing 1 changed file with 3 additions and 9 deletions.
12 changes: 3 additions & 9 deletions Tools/clinic/clinic.py
Original file line number Diff line number Diff line change
Expand Up @@ -4701,10 +4701,8 @@ def bad_node(self, node):
c_default = "NULL"
elif (isinstance(expr, ast.BinOp) or
(isinstance(expr, ast.UnaryOp) and
not (isinstance(expr.operand, ast.Num) or
(hasattr(ast, 'Constant') and
isinstance(expr.operand, ast.Constant) and
type(expr.operand.value) in (int, float, complex)))
not (isinstance(expr.operand, ast.Constant) and
type(expr.operand.value) in {int, float, complex})
)):
c_default = kwargs.get("c_default")
if not (isinstance(c_default, str) and c_default):
Expand Down Expand Up @@ -4806,14 +4804,10 @@ def bad_node(self, node):
self.function.parameters[key] = p

def parse_converter(self, annotation):
if (hasattr(ast, 'Constant') and
isinstance(annotation, ast.Constant) and
if (isinstance(annotation, ast.Constant) and
type(annotation.value) is str):
return annotation.value, True, {}

if isinstance(annotation, ast.Str):
return annotation.s, True, {}

if isinstance(annotation, ast.Name):
return annotation.id, False, {}

Expand Down

0 comments on commit d8d0ae6

Please sign in to comment.