From 9fab99acbc458d27c58b5182fa4e0ad7ef48796f Mon Sep 17 00:00:00 2001 From: Josh <8677174+bijij@users.noreply.github.com> Date: Sun, 5 May 2024 15:45:32 +1000 Subject: [PATCH] [commands] Add support for type statement and NewType --- discord/utils.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/discord/utils.py b/discord/utils.py index 3509bf3ab..99c7cfc94 100644 --- a/discord/utils.py +++ b/discord/utils.py @@ -68,6 +68,7 @@ import re import os import sys import types +import typing import warnings import logging @@ -1080,6 +1081,7 @@ def as_chunks(iterator: _Iter[T], max_size: int) -> _Iter[List[T]]: PY_310 = sys.version_info >= (3, 10) +PY_312 = sys.version_info >= (3, 12) def flatten_literal_params(parameters: Iterable[Any]) -> Tuple[Any, ...]: @@ -1118,6 +1120,16 @@ def evaluate_annotation( cache[tp] = evaluated return evaluated + if PY_312 and getattr(tp.__repr__, '__objclass__', None) is typing.TypeAliasType: # type: ignore + temp_locals = dict(**locals, **{t.__name__: t for t in tp.__type_params__}) + annotation = evaluate_annotation(tp.__value__, globals, temp_locals, cache.copy()) + if hasattr(tp, '__args__'): + annotation = annotation[tp.__args__] + return annotation + + if hasattr(tp, '__supertype__'): + return evaluate_annotation(tp.__supertype__, globals, locals, cache) + if hasattr(tp, '__metadata__'): # Annotated[X, Y] can access Y via __metadata__ metadata = tp.__metadata__[0]