unnecessary inheritance from ad-hoc protocol (#12882)

This commit is contained in:
Stephen Morton
2024-10-23 07:11:51 -07:00
committed by GitHub
parent d5fff13c9b
commit c64f9d065b
2 changed files with 6 additions and 1 deletions

View File

@@ -660,6 +660,8 @@ tkinter.Tk.splitlist
tkinter.Tk.unsetvar
tkinter.Tk.wantobjects
tkinter.Tk.willdispatch
unittest.runner._WritelnDecorator.flush
unittest.runner._WritelnDecorator.write
tkinter.font.Font.__getitem__ # Argument name differs (doesn't matter for __dunder__ methods)
tkinter.Misc.grid_propagate # The noarg placeholder is a set value list

View File

@@ -18,13 +18,16 @@ class _TextTestStream(_SupportsWriteAndFlush, Protocol):
# _WritelnDecorator should have all the same attrs as its stream param.
# But that's not feasible to do Generically
# We can expand the attributes if requested
class _WritelnDecorator(_TextTestStream):
class _WritelnDecorator:
def __init__(self, stream: _TextTestStream) -> None: ...
def writeln(self, arg: str | None = None) -> str: ...
def __getattr__(self, attr: str) -> Any: ... # Any attribute from the stream type passed to __init__
# These attributes are prevented by __getattr__
stream: Never
__getstate__: Never
# Methods proxied from the wrapped stream object via __getattr__
def flush(self) -> object: ...
def write(self, s: str, /) -> object: ...
_StreamT = TypeVar("_StreamT", bound=_TextTestStream, default=_WritelnDecorator)