From d485986122765a663e97080a640e667ed8bf00f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Francisco=20Manr=C3=ADquez=20Novoa?= <49853152+chopan050@users.noreply.github.com> Date: Fri, 6 Dec 2024 20:07:31 -0300 Subject: [PATCH] Add support in documentation for type aliases using Python 3.12 `type` definition (#4044) --- manim/utils/docbuild/module_parsing.py | 33 ++++++++++++++++---------- 1 file changed, 21 insertions(+), 12 deletions(-) diff --git a/manim/utils/docbuild/module_parsing.py b/manim/utils/docbuild/module_parsing.py index 57ac9a56aa..24e44be215 100644 --- a/manim/utils/docbuild/module_parsing.py +++ b/manim/utils/docbuild/module_parsing.py @@ -3,6 +3,7 @@ from __future__ import annotations import ast +import sys from pathlib import Path from typing_extensions import TypeAlias @@ -158,27 +159,35 @@ def parse_module_attributes() -> tuple[AliasDocsDict, DataDict, TypeVarDict]: inner_nodes = [node] for node in inner_nodes: - # If we encounter an assignment annotated as "TypeAlias": - if ( + # Check if this node is a TypeAlias (type = ) + # or an AnnAssign annotated as TypeAlias (: TypeAlias = ). + is_type_alias = ( + sys.version_info >= (3, 12) and type(node) is ast.TypeAlias + ) + is_annotated_assignment_with_value = ( type(node) is ast.AnnAssign and type(node.annotation) is ast.Name and node.annotation.id == "TypeAlias" and type(node.target) is ast.Name and node.value is not None - ): - alias_name = node.target.id - def_node = node.value - # If it's an Union, replace it with vertical bar notation + ) + if is_type_alias or is_annotated_assignment_with_value: + alias_name = node.name.id if is_type_alias else node.target.id + definition_node = node.value + + # If the definition is a Union, replace with vertical bar notation. + # Instead of "Union[Type1, Type2]", we'll have "Type1 | Type2". if ( - type(def_node) is ast.Subscript - and type(def_node.value) is ast.Name - and def_node.value.id == "Union" + type(definition_node) is ast.Subscript + and type(definition_node.value) is ast.Name + and definition_node.value.id == "Union" ): + union_elements = definition_node.slice.elts definition = " | ".join( - ast.unparse(elem) for elem in def_node.slice.elts + ast.unparse(elem) for elem in union_elements ) else: - definition = ast.unparse(def_node) + definition = ast.unparse(definition_node) definition = definition.replace("npt.", "") if category_dict is None: @@ -188,7 +197,7 @@ def parse_module_attributes() -> tuple[AliasDocsDict, DataDict, TypeVarDict]: alias_info = category_dict[alias_name] continue - # Check if it is a typing.TypeVar + # Check if it is a typing.TypeVar ( = TypeVar(...)). elif ( type(node) is ast.Assign and type(node.targets[0]) is ast.Name