From aaf31c56c1307088f09ee6bdf4855ed68d3aa134 Mon Sep 17 00:00:00 2001 From: andrecs <12188364+andrecsilva@users.noreply.github.com> Date: Thu, 14 Sep 2023 09:39:12 -0300 Subject: [PATCH] Typing changes for 3.9 --- src/codemodder/codemods/https_connection.py | 2 +- src/codemodder/codemods/utils_mixin.py | 13 ++++++++----- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/codemodder/codemods/https_connection.py b/src/codemodder/codemods/https_connection.py index fd51cd88..f39e73a1 100644 --- a/src/codemodder/codemods/https_connection.py +++ b/src/codemodder/codemods/https_connection.py @@ -118,7 +118,7 @@ def match_line(pos, line): return pos.start.line == line and pos.end.line == line -def count_positional_args(arglist: Sequence[cst.Arg]) -> int | None: +def count_positional_args(arglist: Sequence[cst.Arg]) -> int: for i, arg in enumerate(arglist): if arg.keyword: return i diff --git a/src/codemodder/codemods/utils_mixin.py b/src/codemodder/codemods/utils_mixin.py index fbbe754d..ee72dd17 100644 --- a/src/codemodder/codemods/utils_mixin.py +++ b/src/codemodder/codemods/utils_mixin.py @@ -1,3 +1,4 @@ +from typing import Optional, Union import libcst as cst from libcst import MetadataDependent, matchers from libcst.helpers import get_full_name_for_node @@ -42,7 +43,7 @@ def base_name_for_import(self, import_node, import_alias): def _is_direct_call_from_imported_module( self, call: cst.Call - ) -> tuple[cst.Import | cst.ImportFrom, cst.ImportAlias] | None: + ) -> Optional[tuple[Union[cst.Import, cst.ImportFrom], cst.ImportAlias]]: for nodo in iterate_left_expressions(call): if matchers.matches(nodo, matchers.Name() | matchers.Attribute()): maybe_assignment = self.find_single_assignment(nodo) @@ -57,7 +58,8 @@ def _is_direct_call_from_imported_module( return None def find_assignments( - self, node: cst.Name | cst.Attribute | cst.Call | cst.Subscript | cst.Decorator + self, + node: Union[cst.Name, cst.Attribute, cst.Call, cst.Subscript, cst.Decorator], ) -> set[Assignment]: """ Given a MetadataWrapper and a CSTNode with a possible access to it, find all the possible assignments that it refers. @@ -76,8 +78,9 @@ def find_assignments( return set() def find_single_assignment( - self, node: cst.Name | cst.Attribute | cst.Call | cst.Subscript | cst.Decorator - ) -> Assignment | None: + self, + node: Union[cst.Name, cst.Attribute, cst.Call, cst.Subscript, cst.Decorator], + ) -> Optional[Assignment]: """ Given a MetadataWrapper and a CSTNode representing an access, find if there is a single assignment that it refers to. """ @@ -106,7 +109,7 @@ def get_leftmost_expression(node: cst.BaseExpression) -> cst.BaseExpression: return node -def _get_name(node: cst.Import | cst.ImportFrom) -> str: +def _get_name(node: Union[cst.Import, cst.ImportFrom]) -> str: """ Get the full name of a module referenced by a Import or ImportFrom node. For relative modules, dots are added at the beginning