diff --git a/stdlib/_curses.pyi b/stdlib/_curses.pyi index 80e7776c1f0a..d2eb1e1a4efb 100644 --- a/stdlib/_curses.pyi +++ b/stdlib/_curses.pyi @@ -1,5 +1,6 @@ import sys -from typing import IO, Any, BinaryIO, NamedTuple, Union, overload +from _typeshed import SupportsRead +from typing import IO, Any, NamedTuple, Union, overload _chtype = Union[str, bytes, int] @@ -293,9 +294,14 @@ def erasechar() -> bytes: ... def filter() -> None: ... def flash() -> None: ... def flushinp() -> None: ... + +if sys.version_info >= (3, 9): + def get_escdelay() -> int: ... + def get_tabsize() -> int: ... + def getmouse() -> tuple[int, int, int, int, int]: ... def getsyx() -> tuple[int, int]: ... -def getwin(__file: BinaryIO) -> _CursesWindow: ... +def getwin(__file: SupportsRead[bytes]) -> _CursesWindow: ... def halfdelay(__tenths: int) -> None: ... def has_colors() -> bool: ... @@ -337,6 +343,11 @@ def resetty() -> None: ... def resize_term(__nlines: int, __ncols: int) -> None: ... def resizeterm(__nlines: int, __ncols: int) -> None: ... def savetty() -> None: ... + +if sys.version_info >= (3, 9): + def set_escdelay(__ms: int) -> None: ... + def set_tabsize(__size: int) -> None: ... + def setsyx(__y: int, __x: int) -> None: ... def setupterm(term: str | None = ..., fd: int = ...) -> None: ... def start_color() -> None: ... @@ -344,7 +355,7 @@ def termattrs() -> int: ... def termname() -> bytes: ... def tigetflag(__capname: str) -> int: ... def tigetnum(__capname: str) -> int: ... -def tigetstr(__capname: str) -> bytes: ... +def tigetstr(__capname: str) -> bytes | None: ... def tparm( __str: bytes, __i1: int = ..., @@ -362,7 +373,7 @@ def unctrl(__ch: _chtype) -> bytes: ... def unget_wch(__ch: int | str) -> None: ... def ungetch(__ch: _chtype) -> None: ... def ungetmouse(__id: int, __x: int, __y: int, __z: int, __bstate: int) -> None: ... -def update_lines_cols() -> int: ... +def update_lines_cols() -> None: ... def use_default_colors() -> None: ... def use_env(__flag: bool) -> None: ... diff --git a/tests/stubtest_allowlists/darwin-py310.txt b/tests/stubtest_allowlists/darwin-py310.txt index 10ce26026ecd..d6256794a9e8 100644 --- a/tests/stubtest_allowlists/darwin-py310.txt +++ b/tests/stubtest_allowlists/darwin-py310.txt @@ -3,10 +3,6 @@ _curses.color_pair curses.color_pair # Exists at runtime, but missing from stubs -_curses.get_escdelay -_curses.get_tabsize -_curses.set_escdelay -_curses.set_tabsize asyncio.PidfdChildWatcher asyncio.unix_events.PidfdChildWatcher os.CLD_KILLED diff --git a/tests/stubtest_allowlists/darwin-py39.txt b/tests/stubtest_allowlists/darwin-py39.txt index 1a75d252c504..6c7075800257 100644 --- a/tests/stubtest_allowlists/darwin-py39.txt +++ b/tests/stubtest_allowlists/darwin-py39.txt @@ -1,10 +1,6 @@ _?curses.A_ITALIC # Exists at runtime, but missing from stubs -_curses.get_escdelay -_curses.get_tabsize -_curses.set_escdelay -_curses.set_tabsize asyncio.PidfdChildWatcher asyncio.unix_events.PidfdChildWatcher os.CLD_KILLED diff --git a/tests/stubtest_allowlists/linux-py310.txt b/tests/stubtest_allowlists/linux-py310.txt index 768560017ce0..aa9d84584ee3 100644 --- a/tests/stubtest_allowlists/linux-py310.txt +++ b/tests/stubtest_allowlists/linux-py310.txt @@ -18,10 +18,6 @@ signal.sigwaitinfo select.epoll.register # Exists at runtime, but missing from stubs -_curses.get_escdelay -_curses.get_tabsize -_curses.set_escdelay -_curses.set_tabsize asyncio.PidfdChildWatcher asyncio.unix_events.PidfdChildWatcher os.CLD_KILLED diff --git a/tests/stubtest_allowlists/linux-py39.txt b/tests/stubtest_allowlists/linux-py39.txt index 046b7923cce6..a88f186c39f0 100644 --- a/tests/stubtest_allowlists/linux-py39.txt +++ b/tests/stubtest_allowlists/linux-py39.txt @@ -2,10 +2,6 @@ select.epoll.register # Exists at runtime, but missing from stubs -_curses.get_escdelay -_curses.get_tabsize -_curses.set_escdelay -_curses.set_tabsize asyncio.PidfdChildWatcher asyncio.unix_events.PidfdChildWatcher os.CLD_KILLED