From 83310f6ac0873460c856815151e5c52595d4fb9d Mon Sep 17 00:00:00 2001 From: Avasam Date: Fri, 25 Oct 2024 13:17:22 -0400 Subject: [PATCH] type `Distribution.get_command_obj` to not return `None` with `create=True` --- distutils/dist.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/distutils/dist.py b/distutils/dist.py index 154301ba..75becaf0 100644 --- a/distutils/dist.py +++ b/distutils/dist.py @@ -3,6 +3,7 @@ Provides the Distribution class, which represents the module distribution being built/installed/distributed. """ +from __future__ import annotations import contextlib import logging @@ -10,6 +11,7 @@ import pathlib import re import sys +from typing import TYPE_CHECKING, Literal, overload import warnings from collections.abc import Iterable from email import message_from_file @@ -27,6 +29,10 @@ from .fancy_getopt import FancyGetopt, translate_longopt from .util import check_environ, rfc822_escape, strtobool +if TYPE_CHECKING: + # type-only import because of mutual dependence between these modules + from .cmd import Command + # Regex to define acceptable Distutils command names. This is not *quite* # the same as a Python NAME -- I don't allow leading underscores. The fact # that they're very similar is no coincidence; the default naming scheme is @@ -829,7 +835,11 @@ def get_command_class(self, command): raise DistutilsModuleError(f"invalid command '{command}'") - def get_command_obj(self, command, create=True): + @overload + def get_command_obj(self, command: str, create: Literal[True] = True) -> Command: ... + @overload + def get_command_obj(self, command: str, create: Literal[False]) -> Command | None: ... + def get_command_obj(self, command: str, create: bool = True) -> Command | None: """Return the command object for 'command'. Normally this object is cached on a previous call to 'get_command_obj()'; if no command object for 'command' is in the cache, then we either create and