Changelog¶
Python 3.13.2 final¶
Release date: 2025-02-04
macOS¶
gh-127592: Usage of the unified Apple System Log APIs was disabled when the minimum macOS version is earlier than 10.12.
Windows¶
gh-127353: Allow to force color output on Windows using environment variables. Patch by Andrey Efremov.
Tools/Demos¶
Tests¶
Security¶
gh-105704: When using
urllib.parse.urlsplit()andurllib.parse.urlparse()host parsing would not reject domain names containing square brackets ([and]). Square brackets are only valid for IPv6 and IPvFuture hosts according to RFC 3986 Section 3.2.2.gh-127655: Fixed the
asyncio.selector_events._SelectorSocketTransporttransport not pausing writes for the protocol when the buffer reaches the high water mark when usingasyncio.WriteTransport.writelines().gh-126108: Fix a possible
NULLpointer dereference inPySys_AddWarnOptionUnicode().gh-80222: Fix bug in the folding of quoted strings when flattening an email message using a modern email policy. Previously when a quoted string was folded so that it spanned more than one line, the surrounding quotes and internal escapes would be omitted. This could theoretically be used to spoof header lines using a carefully constructed quoted string if the resulting rendered email was transmitted or re-parsed.
gh-119511: Fix a potential denial of service in the
imaplibmodule. When connecting to a malicious server, it could cause an arbitrary amount of memory to be allocated. On many systems this is harmless as unused virtual memory is only a mapping, but if this hit a virtual address size limit it could lead to aMemoryErroror other process crash. On unusual systems or builds where all allocated memory is touched and backed by actual ram or storage it could’ve consumed resources doing so until similarly crashing.
Library¶
gh-129502: Unlikely errors in preparing arguments for
ctypescallback are now handled in the same way as errors raised in the callback of in converting the result of the callback – usingsys.unraisablehook()instead ofsys.excepthook()and not settingsys.last_excand other variables.gh-129403: Corrected
ValueErrormessage forasyncio.Barrierandthreading.Barrier.gh-129409: Fix an integer overflow in the
csvmodule when writing a data field larger than 2GB.gh-118761: Improve import time of
subprocessby lazy importinglocaleandsignal. Patch by Taneli Hukkinen.gh-129346: In
sqlite3, handle out-of-memory when creating user-defined SQL functions.gh-129061: Fix FORCE_COLOR and NO_COLOR when empty strings. Patch by Hugo van Kemenade.
gh-128550: Removed an incorrect optimization relating to eager tasks in
asyncio.TaskGroupthat resulted in cancellations being missed.gh-128991: Release the enter frame reference within
bdbcallbackgh-128978: Fix a
NameErrorinsysconfig.expand_makefile_vars(). Patch by Bénédikt Tran.gh-128961: Fix a crash when setting state on an exhausted
array.arrayiterator.gh-128894: Fix
traceback.TracebackException._format_syntax_errornot to fail on exceptions with custom metadata.gh-128916: Do not attempt to set
SO_REUSEPORTon sockets of address families other thanAF_INETandAF_INET6, as it is meaningless with these address families, and the call with fail with Linux kernel 6.12.9 and newer.gh-128679: Fix
tracemalloc.stop()race condition. Fixtracemallocto support callingtracemalloc.stop()in one thread, while another thread is tracing memory allocations. Patch by Victor Stinner.gh-128636: Fix PyREPL failure when
os.environis overwritten with an invalid value.gh-128562: Fix possible conflicts in generated
tkinterwidget names if the widget class name ends with a digit.gh-128498: Default to stdout isatty for color detection instead of stderr. Patch by Hugo van Kemenade.
gh-128552: Fix cyclic garbage introduced by
asyncio.loop.create_task()andasyncio.TaskGroup.create_task()holding a reference to the created task if it is eager.gh-128479: Fix
asyncio.staggered.staggered_race()leaking tasks and issuing an unhandled exception.gh-128400: Fix crash when using
faulthandler.dump_traceback()while other threads are active on the free threaded build.gh-88834: Unify the instance check for
typing.Unionandtypes.UnionType:Unionnow uses the instance checks against its parameters instead of the subclass checks.gh-128302: Fix
xml.dom.xmlbuilder.DOMEntityResolver.resolveEntity(), which was broken by the Python 3.0 transition.gh-128302: Allow
xml.dom.xmlbuilder.DOMParser.parse()to correctly handlexml.dom.xmlbuilder.DOMInputSourceinstances that only have asystemIdattribute set.gh-112064: Fix incorrect handling of negative read sizes in
HTTPResponse.read. Patch by Yury Manushkin.gh-128131: Completely support random access of uncompressed unencrypted read-only zip files obtained by
ZipFile.open.gh-112328:
enum.EnumDictcan now be used without resorting to private API.gh-127975: Avoid reusing quote types in
ast.unparse()if not needed.gh-128062: Revert the font of
turtledemo’s menu bar to its default value and display the shortcut keys in the correct position.gh-128014: Fix resetting the default window icon by passing
default=''to thetkintermethodwm_iconbitmap().gh-115514: Fix exceptions and incomplete writes after
asyncio._SelectorTransportis closed before writes are completed.gh-41872: Fix quick extraction of module docstrings from a file in
pydoc. It now supports docstrings with single quotes, escape sequences, raw string literals, and other Python syntax.gh-127060: Set TERM environment variable to “dumb” to disable traceback colors in IDLE, since IDLE doesn’t understand ANSI escape sequences. Patch by Victor Stinner.
gh-126742: Fix support of localized error messages reported by dlerror(3) and gdbm_strerror in
ctypesanddbm.gnufunctions respectively. Patch by Bénédikt Tran.gh-127873: When
-Eis set, only ignorePYTHON_COLORSand notFORCE_COLOR/NO_COLOR/TERMwhen colourising output. Patch by Hugo van Kemenade.gh-127870: Detect recursive calls in ctypes
_as_parameter_handling. Patch by Victor Stinner.gh-127847: Fix the position when doing interleaved seeks and reads in uncompressed, unencrypted zip files returned by
zipfile.ZipFile.open().gh-127732: The
platformmodule now correctly detects Windows Server 2025.gh-126821: macOS and iOS apps can now choose to redirect stdout and stderr to the system log during interpreter configuration.
gh-93312: Include
<sys/pidfd.h>to getos.PIDFD_NONBLOCKconstant. Patch by Victor Stinner.gh-83662: Add missing
__class_getitem__method to the Python implementation offunctools.partial(), to make it compatible with the C version. This is mainly relevant for alternative Python implementations like PyPy and GraalPy, because CPython will usually use the C-implementation of that function.gh-127586:
multiprocessing.pool.Poolnow properly restores blocked signal handlers of the parent thread when creating processes via either spawn or forkserver.gh-98188: Fix an issue in
email.message.Message.get_payload()where data cannot be decoded if the Content Transfer Encoding mechanism contains trailing whitespaces or additional junk text. Patch by Hui Liu.gh-127257: In
ssl, system call failures that OpenSSL reports usingERR_LIB_SYSare now raised asOSError.gh-127096: Do not recreate unnamed section on every read in
configparser.ConfigParser. Patch by Andrey Efremov.gh-127196: Fix crash when dict with keys in invalid encoding were passed to several functions in
_interpretersmodule.gh-126775: Make
linecache.checkcache()thread safe and GC re-entrancy safe.gh-126332: Fix _pyrepl crash when entering a double CTRL-Z on an overflowing line.
gh-126225:
getoptandoptparseare no longer marked as deprecated. There are legitimate reasons to use one of these modules in preference toargparse, and none of these modules are at risk of being removed from the standard library. Of the three,argparseremains the recommended default choice, unless one of the concerns noted at the top of theoptparsemodule documentation applies.gh-125553: Fix round-trip invariance for backslash continuations in
tokenize.untokenize().gh-123987: Fixed issue in NamespaceReader where a non-path item in a namespace path, such as a sentinel added by an editable installer, would break resource loading.
gh-123401: The
http.cookiesmodule now supports parsing obsolete RFC 850 date formats, in accordance with RFC 9110 requirements. Patch by Nano Zheng.gh-122431:
readline.append_history_file()now raises aValueErrorwhen given a negative value.gh-119257: Show tab completions menu below the current line, which results in less janky behaviour, and fixes a cursor movement bug. Patch by Daniel Hollas
Documentation¶
gh-125722: Require Sphinx 8.1.3 or later to build the Python documentation. Patch by Adam Turner.
gh-67206: Document that
string.printableis not printable in the POSIX sense. In particular,string.printable.isprintable()returnsFalse. Patch by Bénédikt Tran.
Core and Builtins¶
gh-129345: Fix null pointer dereference in
syslog.openlog()when an audit hook raises an exception.gh-129093: Fix f-strings such as
f'{expr=}'sometimes not displaying the full expression when the expression contains!=.gh-124363: Treat debug expressions in f-string as raw strings. Patch by Pablo Galindo
gh-128799: Add frame of
except*to traceback when it wraps a naked exception.gh-128078: Fix a
SystemErrorwhen usinganext()with a default tuple value. Patch by Bénédikt Tran.gh-128717: Fix a crash when setting the recursion limit while other threads are active on the free threaded build.
gh-128330: Restore terminal control characters on REPL exit.
gh-128079: Fix a bug where
except*does not properly check the return value of anExceptionGroup’ssplit()function, leading to a crash in some cases. Now whensplit()returns an invalid object,except*raises aTypeErrorwith the original raisedExceptionGroupobject chained to it.gh-128030: Avoid error from calling
PyModule_GetFilenameObjecton a non-module object when importing a non-existent symbol from a non-module object.gh-127903:
Objects/unicodeobject.c: fix a crash on DEBUG builds in_copy_characterswhen there is nothing to copy.gh-127599: Fix statistics for increments of object reference counts (in particular, when a reference count was increased by more than 1 in a single operation).
gh-127651: When raising
ImportErrorfor missing symbols infromimports, use__file__in the error message if__spec__.originis not a locationgh-127582: Fix non-thread-safe object resurrection when calling finalizers and watcher callbacks in the free threading build.
gh-127434: The iOS compiler shims can now accept arguments with spaces.
gh-127536: Add missing locks around some list assignment operations in the free threading build.
gh-126862: Fix a possible overflow when a class inherits from an absurd number of super-classes. Reported by Valery Fedorenko. Patch by Bénédikt Tran.
gh-127349: Fixed the error when resizing terminal in Python REPL. Patch by Semyon Moroz.
gh-126076: Relocated objects such as
tuple,bytesandstrobjects are properly tracked bytracemallocand its associated hooks. Patch by Pablo Galindo.
C API¶
gh-127791: Fix loss of callbacks after more than one call to
PyUnstable_AtExit().
Build¶
gh-129539: Don’t redefine
EX_OKwhen the system has thesysexits.hheader.gh-128472: Skip BOLT optimization of functions using computed gotos, fixing errors on build with LLVM 19.
gh-123925: Fix building the
cursesmodule on platforms with libncurses but without libncursesw.gh-128321: Set
LIBSinstead ofLDFLAGSwhen checking ifsqlite3library functions are available. This fixes the ordering of linked libraries during checks, which was incorrect when using a statically linkedlibsqlite3.gh-127865: Fix build failure on systems without thread-locals support.
Python 3.13.1 final¶
Release date: 2024-12-03
macOS¶
gh-124448: Update bundled Tcl/Tk in macOS installer to 8.6.15.
Windows¶
gh-126911: Update credits command output.
gh-118973: Ensures the experimental free-threaded install includes the
_tkintermodule. The optional Tcl/Tk component must also be installed in order for the module to work.gh-126497: Fixes venv failure due to missing redirector executables in experimental free-threaded installs.
gh-126074: Removed unnecessary DLLs from Windows embeddable package
gh-125315: Avoid crashing in
platformdue to slow WMI calls on some Windows machines.gh-126084: Fix venvwlauncher to launch pythonw instead of python so no extra console window is created.
gh-125842: Fix a
SystemErrorwhensys.exit()is called with0xffffffffon Windows.gh-125550: Enable the Python Launcher for Windows to detect Python 3.14 installs from the Windows Store.
gh-124448: Updated bundled Tcl/Tk to 8.6.15.
Tools/Demos¶
Tests¶
gh-126909: Fix test_os extended attribute tests to work on filesystems with 1 KiB xattr size limit.
gh-125041: Re-enable skipped tests for
zlibon the s390x architecture: only skip checks of the compressed bytes, which can be different between zlib’s software implementation and the hardware-accelerated implementation.
Security¶
gh-126623: Upgrade libexpat to 2.6.4
gh-125140: Remove the current directory from
sys.pathwhen using PyREPL.gh-122792: Changed IPv4-mapped
ipaddress.IPv6Addressto consistently use the mapped IPv4 address value for deciding properties. Properties which have their behavior fixed areis_multicast,is_reserved,is_link_local,is_global, andis_unspecified.
Library¶
gh-127321:
pdb.set_trace()will not stop at an opcode that does not have an associated line number anymore.gh-127303: Publicly expose
EXACT_TOKEN_TYPESintoken.__all__.gh-123967: Fix faulthandler for trampoline frames. If the top-most frame is a trampoline frame, skip it. Patch by Victor Stinner.
gh-127182: Fix
io.StringIO.__setstate__()crash, whenNonewas passed as the first value.gh-127217: Fix
urllib.request.pathname2url()for paths starting with multiple slashes on Posix.gh-127035: Fix
shutil.whichon Windows. Now it looks at direct match if and only if the command ends with a PATHEXT extension or X_OK is not in mode. Support extensionless files if “.” is in PATHEXT. Support PATHEXT extensions that end with a dot.gh-122273: Support PyREPL history on Windows. Patch by devdanzin and Victor Stinner.
gh-127078: Fix issue where
urllib.request.url2pathname()failed to discard an extra slash before a UNC drive in the URL path on Windows.gh-126766: Fix issue where
urllib.request.url2pathname()failed to discard any ‘localhost’ authority present in the URL.gh-127065: Fix crash when calling a
operator.methodcaller()instance from multiple threads in the free threading build.gh-126997: Fix support of STRING and GLOBAL opcodes with non-ASCII arguments in
pickletools.pickletools.dis()now outputs non-ASCII bytes in STRING, BINSTRING and SHORT_BINSTRING arguments as escaped (\xXX).gh-126316:
grp: Makegrp.getgrall()thread-safe by adding a mutex. Patch by Victor Stinner.gh-126618: Fix the representation of
itertools.countobjects when the count value issys.maxsize.gh-85168: Fix issue where
urllib.request.url2pathname()andpathname2url()always used UTF-8 when quoting and unquoting file URIs. They now use the filesystem encoding and error handler.gh-67877: Fix memory leaks when
regular expressionmatching terminates abruptly, either because of a signal or because memory allocation fails.gh-126789: Fixed the values of
sysconfig.get_config_vars(),sysconfig.get_paths(), and their siblings when thesiteinitialization happens aftersysconfighas built a cache forsysconfig.get_config_vars().gh-126188: Update bundled pip to 24.3.1
gh-126780: Fix
os.path.normpath()for drive-relative paths on Windows.gh-126766: Fix issue where
urllib.request.url2pathname()failed to discard two leading slashes introducing an empty authority section.gh-126727:
locale.nl_langinfo(locale.ERA)now returns multiple era description segments separated by semicolons. Previously it only returned the first segment on platforms with Glibc.gh-126699: Allow
collections.abc.AsyncIteratorto be a base for Protocols.gh-126654: Fix crash when non-dict was passed to several functions in
_interpretersmodule.gh-104745: Limit starting a patcher (from
unittest.mock.patch()orunittest.mock.patch.object()) more than once without stopping itgh-126595: Fix a crash when instantiating
itertools.countwith an initial count ofsys.maxsizeon debug builds. Patch by Bénédikt Tran.gh-120423: Fix issue where
urllib.request.pathname2url()mishandled Windows paths with embedded forward slashes.gh-126565: Improve performances of
zipfile.Path.open()for non-reading modes.gh-126505: Fix bugs in compiling case-insensitive
regular expressionswith character classes containing non-BMP characters: upper-case non-BMP character did was ignored and the ASCII flag was ignored when matching a character range whose upper bound is beyond the BMP region.gh-117378: Fixed the
multiprocessing"forkserver"start method forkserver process to correctly inherit the parent’ssys.pathduring the importing ofmultiprocessing.set_forkserver_preload()modules in the same manner assys.pathis configured in workers before executing work items.This bug caused some forkserver module preloading to silently fail to preload. This manifested as a performance degration in child processes when the
sys.pathwas required due to additional repeated work in every worker.It could also have a side effect of
""remaining insys.pathduring forkserver preload imports instead of the absolute path fromos.getcwd()at multiprocessing import time used in the workersys.path.The
sys.pathdifferences between phases in the child process could potentially have caused preload to import incorrect things from the wrong location. We are unaware of that actually having happened in practice.gh-125679: The
multiprocessing.Lockandmultiprocessing.RLockreprvalues no longer say “unknown” on macOS.gh-126476: Raise
calendar.IllegalMonthError(now a subclass ofIndexError) forcalendar.month()when the input month is not correct.gh-126489: The Python implementation of
pickleno longer callspickle.Pickler.persistent_id()for the result ofpersistent_id().gh-126313: Fix an issue in
curses.napms()whencurses.initscr()has not yet been called. Patch by Bénédikt Tran.gh-126303: Fix pickling and copying of
os.sched_paramobjects.gh-126138: Fix a use-after-free crash on
asyncio.Taskobjects whose underlying coroutine yields an object that implements an evil__getattribute__(). Patch by Nico Posada.gh-126220: Fix crash in
cProfile.Profileand_lsprof.Profilerwhen their callbacks were directly called with 0 arguments.gh-126212: Fix issue where
urllib.request.pathname2url()andurl2pathname()removed slashes from Windows DOS drive paths and URLs.gh-126223: Raise a
UnicodeEncodeErrorinstead of aSystemErrorupon calling_interpreters.create()with an invalid Unicode character.gh-126205: Fix issue where
urllib.request.pathname2url()generated URLs beginning with four slashes (rather than two) when given a Windows UNC path.gh-126105: Fix a crash in
astwhen theast.AST._fieldsattribute is deleted.gh-126106: Fixes a possible
NULLpointer dereference inssl.gh-126080: Fix a use-after-free crash on
asyncio.Taskobjects for which the underlying event loop implements an evil__getattribute__(). Reported by Nico-Posada. Patch by Bénédikt Tran.gh-126083: Fixed a reference leak in
asyncio.Taskobjects when reinitializing the same object with a non-Nonecontext. Patch by Nico Posada.gh-125984: Fix use-after-free crashes on
asyncio.Futureobjects for which the underlying event loop implements an evil__getattribute__(). Reported by Nico-Posada. Patch by Bénédikt Tran.gh-125969: Fix an out-of-bounds crash when an evil
asyncio.loop.call_soon()mutates the length of the internal callbacks list. Patch by Bénédikt Tran.gh-125966: Fix a use-after-free crash in
asyncio.Future.remove_done_callback(). Patch by Bénédikt Tran.gh-125789: Fix possible crash when mutating list of callbacks returned by
asyncio.Future._callbacks. It now always returns a new copy in C implementation_asyncio. Patch by Kumar Aditya.gh-124452: Fix an issue in
email.policy.EmailPolicy.header_source_parse()andemail.policy.Compat32.header_source_parse()that introduced spurious leading whitespaces into header values when the header includes a newline character after the header name delimiter (:) and before the value.gh-125884: Fixed the bug for
pdbwhere it can’t set breakpoints on functions with certain annotations.gh-125355: Fix several bugs in
argparse.ArgumentParser.parse_intermixed_args().The parser no longer changes temporarily during parsing.
Default values are not processed twice.
Required mutually exclusive groups containing positional arguments are now supported.
The missing arguments report now includes the names of all required optional and positional arguments.
Unknown options can be intermixed with positional arguments in parse_known_intermixed_args().
gh-125666: Avoid the exiting the interpreter if a null byte is given as input in the new REPL.
gh-125710: [Enum] fix hashable<->nonhashable comparisons for member values
gh-125631: Restore ability to set
persistent_idandpersistent_loadattributes of instances of thePicklerandUnpicklerclasses in thepicklemodule.gh-125378: Fixed the bug in
pdbwhere after a multi-line command, an empty line repeats the first line of the multi-line command, instead of the full command.gh-125682: Reject non-ASCII digits in the Python implementation of
json.loads()conforming to the JSON specification.gh-125660: Reject invalid unicode escapes for Python implementation of
json.loads().gh-125259: Fix the notes removal logic for errors thrown in enum initialization.
gh-125590: Allow
FrameLocalsProxyto delete and pop if the key is not a fast variable.gh-125519: Improve traceback if
importlib.reload()is called with an object that is not a module. Patch by Alex Waygood.gh-125451: Fix deadlock when
concurrent.futures.ProcessPoolExecutorshuts down concurrently with an error when feeding a job to a worker process.gh-125422: Fixed the bug where
pdbandbdbcan step into the bottom caller frame.gh-100141: Fixed the bug where
pdbwill be stuck in an infinite loop when debugging an empty file.gh-125115: Fixed a bug in
pdbwhere arguments starting with-can’t be passed to the debugged script.gh-53203: Fix
time.strptime()for%c,%xand%Xformats in many locales that use non-ASCII digits, like Persian, Burmese, Odia and Shan.gh-125398: Fix the conversion of the
VIRTUAL_ENVpath in the activate script invenvwhen running in Git Bash for Windows.gh-125316: Fix using
functools.partial()asenum.Enummember. A FutureWarning with suggestion to useenum.member()is now emitted when thepartialinstance is used as an enum member.gh-125245: Fix race condition when importing
collections.abc, which could incorrectly return an empty module.gh-125243: Fix data race when creating
zoneinfo.ZoneInfoobjects in the free threading build.gh-125254: Fix a bug where ArgumentError includes the incorrect ambiguous option in
argparse.gh-125235: Keep
tkinterTCL paths in venv pointing to base installation on Windows.gh-61011: Fix inheritance of nested mutually exclusive groups from parent parser in
argparse.ArgumentParser. Previously, all nested mutually exclusive groups lost their connection to the group containing them and were displayed as belonging directly to the parser.gh-52551: Fix encoding issues in
time.strftime(), thestrftime()method of thedatetimeclassesdatetime,dateandtimeand formatting of these classes. Characters not encodable in the current locale are now acceptable in the format string. Surrogate pairs and sequence of surrogatescape-encoded bytes are no longer recombinated. Embedded null character no longer terminates the format string.gh-125118: Don’t copy arbitrary values to _Bool in the
structmodule.gh-125069: Fix an issue where providing a
pathlib.PurePathobject as an initializer argument to a secondPurePathobject with a differentparserresulted in arguments to the former object’s initializer being joined by the latter object’s parser.gh-125096: If the
PYTHON_BASIC_REPLenvironment variable is set, thesitemodule no longer imports the_pyreplmodule. Moreover, thesitemodule now respects-Eand-Icommand line options: ignorePYTHON_BASIC_REPLin this case. Patch by Victor Stinner.gh-124969: Fix
locale.nl_langinfo(locale.ALT_DIGITS)on platforms with glibc. Now it returns a string consisting of up to 100 semicolon-separated symbols (an empty string in most locales) on all Posix platforms. Previously it only returned the first symbol or an empty string.gh-124960: Fix support for the
barry_as_FLUFLfuture flag in the new REPL.gh-124984: Fixed thread safety in
sslin the free-threaded build. OpenSSL operations are now protected by a per-object lock.gh-124958: Fix refcycles in exceptions raised from
asyncio.TaskGroupand the python implementation ofasyncio.Futuregh-53203: Fix
time.strptime()for%cand%xformats in many locales: Arabic, Bislama, Breton, Bodo, Kashubian, Chuvash, Estonian, French, Irish, Ge’ez, Gurajati, Manx Gaelic, Hebrew, Hindi, Chhattisgarhi, Haitian Kreyol, Japanese, Kannada, Korean, Marathi, Malay, Norwegian, Nynorsk, Punjabi, Rajasthani, Tok Pisin, Yoruba, Yue Chinese, Yau/Nungon and Chinese.gh-124917: Allow calling
os.path.exists()andos.path.lexists()with keyword arguments on Windows. Fixes a regression in 3.13.0.gh-124653: Fix detection of the minimal Queue API needed by the
loggingmodule. Patch by Bénédikt Tran.gh-124858: Fix reference cycles left in tracebacks in
asyncio.open_connection()when used withhappy_eyeballs_delaygh-124390: Fixed
AssertionErrorwhen usingasyncio.staggered.staggered_race()withasyncio.eager_task_factory.gh-124651: Properly quote template strings in
venvactivation scripts.gh-116850: Fix
argparsefor namespaces with not directly writable dict (e.g. classes).gh-58573: Fix conflicts between abbreviated long options in the parent parser and subparsers in
argparse.gh-124594: All
asyncioREPL prompts run in the samecontext. Contributed by Bartosz Sławecki.gh-61181: Fix support of choices with string value in
argparse. Substrings of the specified string no longer considered valid values.gh-80259: Fix
argparsesupport of positional arguments withnargs='?',default=argparse.SUPPRESSand specifiedtype.gh-120378: Fix a crash related to an integer overflow in
curses.resizeterm()andcurses.resize_term().gh-123884: Fixed bug in itertools.tee() handling of other tee inputs (a tee in a tee). The output now has the promised n independent new iterators. Formerly, the first iterator was identical (not independent) to the input iterator. This would sometimes give surprising results.
gh-58956: Fixed a bug in
pdbwhere sometimes the breakpoint won’t trigger if it was set on a function which is already in the call stack.gh-124345:
argparsevim supports abbreviated single-dash long options separated by=from its value.gh-104860: Fix disallowing abbreviation of single-dash long options in
argparsewithallow_abbrev=False.gh-63143: Fix parsing mutually exclusive arguments in
argparse. Arguments with the value identical to the default value (e.g. booleans, small integers, empty or 1-character strings) are no longer considered “not present”.gh-72795: Positional arguments with nargs equal to
'*'orargparse.REMAINDERare no longer required. This allows to use positional argument withnargs='*'and withoutdefaultin mutually exclusive group and improves error message about required arguments.gh-59317: Fix parsing positional argument with nargs equal to
'?'or'*'if it is preceded by an option and another positional argument.gh-53780:
argparsenow ignores the first"--"(double dash) between an option and command.gh-124217: Add RFC 9637 reserved IPv6 block
3fff::/20inipaddressmodule.gh-81691: Fix handling of multiple
"--"(double dashes) inargparse. Only the first one has now been removed, all subsequent ones are now taken literally.gh-123978: Remove broken
time.thread_time()andtime.thread_time_ns()on NetBSD.gh-124008: Fix possible crash (in debug build), incorrect output or returning incorrect value from raw binary
write()when writing to console on Windows.gh-123935: Fix parent slots detection for dataclasses that inherit from classes with
__dictoffset__.gh-122765: Fix unbalanced quote errors occurring when activate.csh in
venvwas sourced with a custom prompt containing unpaired quotes or newlines.gh-123370: Fix the canvas not clearing after running turtledemo clock.
gh-116810: Resolve a memory leak introduced in CPython 3.10’s
sslwhen thessl.SSLSocket.sessionproperty was accessed. Speeds up read and write access to said property by no longer unnecessarily cloning session objects via serialization.gh-120754: Update unbounded
readcalls inzipfileto specify an explicitsizeputting a limit on how much data they may read. This also updates handling around ZIP max comment size to match the standard instead of reading comments that are one byte too long.gh-70764: Fixed an issue where
inspect.getclosurevars()would incorrectly classify an attribute name as a global variable when the name exists both as an attribute name and a global variable.gh-118289:
posixpath.realpath()now raisesNotADirectoryErrorwhen strict mode is enabled and a non-directory path with a trailing slash is supplied.gh-119826: Always return an absolute path for
os.path.abspath()on Windows.gh-101955: Fix SystemError when match regular expression pattern containing some combination of possessive quantifier, alternative and capture group.
gh-88110: Fixed
multiprocessing.Processreporting a.exitcodeof 1 even on success when using the"fork"start method while using aconcurrent.futures.ThreadPoolExecutor.gh-71936: Fix a race condition in
multiprocessing.pool.Pool.bpo-46128: Strip
unittest.IsolatedAsyncioTestCasestack frames from reported stacktraces.bpo-14074: Fix
argparsemetavar processing to allow positional arguments to have a tuple metavar.
IDLE¶
gh-122392: Increase currently inadequate vertical spacing for the IDLE browsers (path, module, and stack) on high-resolution monitors.
Documentation¶
gh-126622: Added stub pages for removed modules explaining their removal, where to find replacements, and linking to the last Python version that supported them. Contributed by Ned Batchelder.
gh-125277: Require Sphinx 7.2.6 or later to build the Python documentation. Patch by Adam Turner.
gh-124872: Added definitions for context, current context, and context management protocol, updated related definitions to be consistent, and expanded the documentation for
contextvars.Context.gh-125018: The
importlib.metadatadocumentation now includes semantic cross-reference targets for the significant documented APIs. This means intersphinx references likeimportlib.metadata.version()will now work as expected.gh-70870: Clarified the dual usage of the term “free variable” (both the formal meaning of any reference to names defined outside the local scope, and the narrower pragmatic meaning of nonlocal variables named in
co_freevars).gh-121277: Writers of CPython’s documentation can now use
nextas the version for theversionchanged,versionadded,deprecateddirectives.gh-60712: Include the
objecttype in the lists of documented types. Change by Furkan Onder and Martin Panter.bpo-34008: The
Py_Main()documentation moved from the “Very High Level API” section to the “Initialization and Finalization” section.Also make it explicit that we expect
Py_Mainto typically be called instead ofPy_Initializerather than after it (sincePy_Mainmakes its own call toPy_Initialize). Document that calling both is supported but is version dependent on which settings will be applied correctly.
Core and Builtins¶
gh-113841: Fix possible undefined behavior division by zero in
complex’s_Py_c_pow().gh-127020: Fix a crash in the free threading build when
PyCode_GetCode(),PyCode_GetVarnames(),PyCode_GetCellvars(), orPyCode_GetFreevars()were called from multiple threads at the same time.gh-126980: Fix
__buffer__()ofbytearraycrashing whenREADorWRITEare passed as flags.gh-126881: Fix crash in finalization of dtoa state. Patch by Kumar Aditya.
gh-126341: Now
ValueErroris raised instead ofSystemErrorwhen trying to iterate over a releasedmemoryviewobject.gh-126688: Fix a crash when calling
os.fork()on some operating systems, including SerenityOS.gh-126066: Fix
importlibto not write an incomplete .pyc files when a ulimit or some other operating system mechanism is preventing the write to go through fully.gh-126312: Fix crash during garbage collection on an object frozen by
gc.freeze()on the free-threaded build.gh-126139: Provide better error location when attempting to use a future statement with an unknown future feature.
gh-126018: Fix a crash in
sys.audit()when passing a non-string as first argument and Python was compiled in debug mode.gh-125942: On Android, the
errorssetting ofsys.stdoutwas changed fromsurrogateescapetobackslashreplace.gh-125859: Fix a crash in the free threading build when
gc.get_objects()orgc.get_referrers()is called during an in-progress garbage collection.gh-125703: Correctly honour
tracemallochooks in specializedPy_DECREFpaths. Patch by Pablo Galindogh-125593: Use color to highlight error locations in traceback from exception group
gh-125444: Fix illegal instruction for older Arm architectures. Patch by Diego Russo, testing by Ross Burton.
gh-124375: Fix a crash in the free threading build when the GC runs concurrently with a new thread starting.
gh-125221: Fix possible race condition when calling
__reduce_ex__()for the first time in the free threading build.gh-125038: Fix crash when iterating over a generator expression after direct changes on
gi_frame.f_locals. Patch by Mikhail Efimov.gh-123378: Fix a crash in the
__str__()method ofUnicodeErrorobjects when theUnicodeError.startandUnicodeError.endvalues are invalid or out-of-range. Patch by Bénédikt Tran.gh-116510: Fix a crash caused by immortal interned strings being shared between sub-interpreters that use basic single-phase init. In that case, the string can be used by an interpreter that outlives the interpreter that created and interned it. For interpreters that share obmalloc state, also share the interned dict with the main interpreter.
gh-122878: Use the
pagerbinary, if available (e.g. on Debian and derivatives), to display REPLhelp().gh-124188: Fix reading and decoding a line from the source file witn non-UTF-8 encoding for syntax errors raised in the compiler.
gh-123930: Improve the error message when a script shadowing a module from the standard library causes
ImportErrorto be raised during a “from” import. Similarly, improve the error message when a script shadowing a third party module attempts to “from” import an attribute from that third party module while still initialising.gh-122907: Building with
HAVE_DYNAMIC_LOADINGnow works as well as it did in 3.12. Existing deficiences will be addressed separately. (See https://github.com/python/cpython/issues/122950.)gh-118950: Fix bug where SSLProtocol.connection_lost wasn’t getting called when OSError was thrown on writing to socket.
gh-113570: Fixed a bug in
reprlib.reprwhere it incorrectly called the repr method on shadowed Python built-in types.gh-109746: If
_thread.start_new_thread()fails to start a new thread, it deletes its state from interpreter and thus avoids its repeated cleanup on finalization.
C API¶
gh-126554: Fix error handling in
ctypes.CDLLobjects which could result in a crash in rare situations.gh-125608: Fix a bug where dictionary watchers (e.g.,
PyDict_Watch()) on an object’s attribute dictionary (__dict__) were not triggered when the object’s attributes were modified.bpo-34008: Added
Py_IsInitializedto the list of APIs that are safe to call before the interpreter is initialized, and updated the embedding tests to cover it.
Build¶
gh-123877: Set
wasm32-wasip1as the WASI target. The oldwasm32-wasitarget is deprecated so it can be used for an eventual WASI 1.0.gh-89640: Hard-code float word ordering as little endian on WASM.
gh-125940: The Android build now supports 16 KB page sizes.
gh-89640: Improve detection of float word ordering on Linux when link-time optimizations are enabled.
gh-125269: Fix detection of whether
-latomicis needed when cross-compiling CPython using the configure script.gh-121634: Allow for specifying the target compile triple for WASI.
gh-122578: Use WASI SDK 24 for testing.
gh-115382: Fix cross compile failures when the host and target SOABIs match.
Python 3.13.0 final¶
Release date: 2024-10-07
Core and Builtins¶
gh-125008: Fix
tokenize.untokenize()producing invalid syntax for double braces preceded by certain escape characters.gh-124871: Fix compiler bug (in some versions of 3.13) where an assertion fails during reachability analysis.
Python 3.13.0 release candidate 3¶
Release date: 2024-10-01
macOS¶
gh-123797: Check for runtime availability of
ptsname_rfunction on macos.
Windows¶
Tests¶
gh-124378: Updated
test_ttkto pass with Tcl/Tk 8.6.15.
Library¶
gh-124538: Fixed crash when using
gc.get_referents()on a capsule object.gh-124498: Fix
typing.TypeAliasTypenot to be generic, whentype_paramsis an empty tuple.gh-123017: Due to unreliable results on some devices,
time.strftime()no longer accepts negative years on Android.gh-123014:
os.pidfd_open()andsignal.pidfd_send_signal()are now unavailable when building against Android API levels older than 31, since the underlying system calls may cause a crash.gh-124248: Fixed potential crash when using
structto process zero-width ‘Pascal string’ fields (0p).gh-87041: Fix a bug in
argparsewhere lengthy subparser argument help is incorrectly indented.gh-124212: Fix invalid variable in
venvhandling of failed symlink on Windowsgh-124171: Add workaround for broken
fmod()implementations on Windows, that loose zero sign (e.g.fmod(-10, 1)returns0.0). Patch by Sergey B Kirpichev.gh-123934: Fix
unittest.mock.MagicMockreseting magic methods return values after.reset_mock(return_value=True)was called.gh-123968: Fix the command-line interface for the
randommodule to select floats between 0 and N, not 1 and N.gh-123892: Add
"_wmi"tosys.stdlib_module_names. Patch by Victor Stinner.gh-123339: Fix
inspect.getsource()for classes incollections.abcanddecimal(for pure Python implementation) modules.inspect.getcomments()now raises OSError instead of IndexError if the__firstlineno__value for a class is out of bound.gh-121735: When working with zip archives, importlib.resources now properly honors module-adjacent references (e.g.
files(pkg.mod)and not justfiles(pkg)).gh-122145: Fix an issue when reporting tracebacks corresponding to Python code emitting an empty AST body. Patch by Nikita Sobolev and Bénédikt Tran.
gh-119004: Fix a crash in OrderedDict.__eq__ when operands are mutated during the check. Patch by Bénédikt Tran.
bpo-44864: Do not translate user-provided strings in
argparse.ArgumentParser.
IDLE¶
Documentation¶
Core and Builtins¶
gh-124567: Revert the incremental GC (in 3.13), since it’s not clear the benefits outweigh the costs at this point.
gh-124642: Fixed scalability issue in free-threaded builds for lock-free reads from dictionaries in multi-threaded scenarios
gh-116510: Fix a bug that can cause a crash when sub-interpreters use “basic” single-phase extension modules. Shared objects could refer to PyGC_Head nodes that had been freed as part of interpreter cleanup.
gh-124547: When deallocating an object with inline values whose
__dict__is still live: if memory allocation for the inline values fails, clear the dictionary. Prevents an interpreter crash.gh-124513: Fix a crash in FrameLocalsProxy constructor: check the number of arguments. Patch by Victor Stinner.
gh-124442: Fix nondeterminism in compilation by sorting the value of
__static_attributes__. Patch by kp2pml30.gh-123856: Fix PyREPL failure when a keyboard interrupt is triggered after using a history search
gh-65961: Document the deprecation of setting and using
__package__and__cached__.gh-124027: Support
<page up>,<page down>, and<delete>keys in the Python REPL when$TERMis set tovt100.gh-77894: Fix possible crash in the garbage collector when it tries to break a reference loop containing a
memoryviewobject. Now amemoryviewobject can only be cleared if there are no buffers that refer it.gh-123339: Setting the
__module__attribute for a class now removes the__firstlineno__item from the type’s dict, so they will no longer be inconsistent.
C API¶
Build¶
gh-124487: Windows builds now use Windows 8.1 as their API baseline (installation already required Windows 8.1).
gh-124043: Building using
--with-trace-refsis (temporarily) disallowed when the GIL is disabled.
Python 3.13.0 release candidate 2¶
Release date: 2024-09-06
macOS¶
gh-123418: Updated macOS installer build to use OpenSSL 3.0.15.
Windows¶
gh-123418: Updated Windows build to use OpenSSL 3.0.15.
gh-122573: The Windows build of CPython now requires 3.10 or newer.
gh-100256:
mimetypesno longer fails when it encounters an inaccessible registry key.gh-79846: Makes
ssl.create_default_context()ignore invalid certificates in the Windows certificate store
Tools/Demos¶
gh-123418: Update GitHub CI workflows to use OpenSSL 3.0.15 and multissltests to use 3.0.15, 3.1.7, and 3.2.3.
Tests¶
Security¶
Library¶
gh-123657: Fix crash and memory leak in
decimal.getcontext(). It crashed when using a thread-local context by--with-decimal-contextvar=no.gh-123448: Fixed memory leak of
typing.NoDefaultby moving it to the static types array.gh-123409: Fix
ipaddress.IPv6Address.reverse_pointeroutput according to RFC 3596, §2.5. Patch by Bénédikt Tran.gh-123270: Applied a more surgical fix for malformed payloads in
zipfile.Pathcausing infinite loops (gh-122905) without breaking contents using legitimate characters.gh-123228: Fix return type for
_pyrepl.readline._ReadlineWrapper.get_line_buffer()to bestr(). Patch by Sergey B Kirpichev.gh-123240: Raise audit events for the
input()in the new REPL.gh-123243: Fix memory leak in
_decimal.gh-122546: Consistently use same file name for different exceptions in the new repl. Patch by Sergey B Kirpichev.
gh-123213:
xml.etree.ElementTree.Element.extend()andElementassignment no longer hide the internal exception if an erronous generator is passed. Patch by Bar Harel.gh-85110: Preserve relative path in URL without netloc in
urllib.parse.urlunsplit()andurllib.parse.urlunparse().gh-123067: Fix quadratic complexity in parsing
"-quoted cookie values with backslashes byhttp.cookies.gh-122981: Fix
inspect.getsource()for generated classes with Python base classes (e.g. enums).gh-122903:
zipfile.Path.globnow correctly matches directories instead of silently omitting them.gh-122905:
zipfile.Pathobjects now sanitize names from the zipfile.gh-122695: Fixed double-free when using
gc.get_referents()with a freedasyncio.Futureiterator.gh-116263:
logging.handlers.RotatingFileHandlerno longer rolls over empty log files.gh-105376: Restore the deprecated
loggingwarn()method. It was removed in Python 3.13 alpha 1. Keep the deprecatedwarn()method in Python 3.13. Patch by Victor Stinner.gh-122744: Bump the version of pip bundled in ensurepip to version 24.2.
gh-118814: Fix the
typing.TypeVarconstructor when name is passed by keyword.gh-122478: Remove internal frames from tracebacks shown in
code.InteractiveInterpreterwith non-defaultsys.excepthook(). Save correct tracebacks insys.last_tracebackand update__traceback__attribute ofsys.last_valueandsys.last_exc.gh-116622: On Android, the
FICLONEandFICLONERANGEconstants are no longer exposed byfcntl, as these ioctls are blocked by SELinux.gh-82378: Make sure that the new REPL interprets
sys.tracebacklimitin the same way that the classic REPL did.gh-122334: Fix crash when importing
sslafter the main interpreter restarts.gh-87320: In
code.InteractiveInterpreter, handle exceptions caused by calling a non-defaultsys.excepthook(). Before, the exception bubbled up to the caller, ending the REPL.gh-121650:
emailheaders with embedded newlines are now quoted on output. Thegeneratorwill now refuse to serialize (write) headers that are unsafely folded or delimited; seeverify_generated_headers. (Contributed by Bas Bloemsaat and Petr Viktorin in gh-121650.)gh-121723: Make
logging.config.dictConfig()accept any object implementing the Queue public API. See the queue configuration section for details. Patch by Bénédikt Tran.gh-122081: Fix a crash in the
decimal.IEEEContext()optional function available via theEXTRA_FUNCTIONALITYconfiguration flag.gh-121804: Correctly show error locations, when
SyntaxErrorraised in new repl. Patch by Sergey B Kirpichev.gh-121151: Fix wrapping of long usage text of arguments inside a mutually exclusive group in
argparse.gh-108172:
webbrowserhonors OS preferred browser on Linux when its desktop entry name contains the text of a known browser name.gh-109109: You can now get the raw TLS certificate chains from TLS connections via
ssl.SSLSocket.get_verified_chain()andssl.SSLSocket.get_unverified_chain()methods.Contributed by Mateusz Nowak.
IDLE¶
gh-120083: Add explicit black IDLE Hovertip foreground color needed for recent macOS. Fixes Sonoma showing unreadable white on pale yellow. Patch by John Riggles.
Core and Builtins¶
gh-120221: asyncio REPL is now again properly recognizing KeyboardInterrupts. Display of exceptions raised in secondary threads is fixed.
gh-119310: Allow the new interactive shell to read history files written with the editline library that use unicode-escaped entries. Patch by aorcajo and Łukasz Langa.
gh-123572: Fix key mappings for various F-keys in Windows for the new REPL. Patch by devdanzin
gh-119034: Change
<page up>and<page down>keys of the Python REPL to history search forward/backward. Patch by Victor Stinner.gh-123545: Fix a double decref in rare cases on experimental JIT builds.
gh-123484: Fix
_Py_DebugOffsetsfor long objects to be relative to the start of the object rather than the start of a subobject.gh-123344: Add AST optimizations for type parameter defaults.
gh-123321: Prevent Parser/myreadline race condition from segfaulting on multi-threaded use. Patch by Bar Harel and Amit Wienner.
gh-123177: Fix a bug causing stray prompts to appear in the middle of wrapped lines in the new REPL.
gh-122982: Extend the deprecation period for bool inversion (
~) by two years.gh-123275: Support
-X gil=1andPYTHON_GIL=1on non-free-threaded builds.gh-123177: Deactivate line wrap in the Apple Terminal via a ANSI escape code. Patch by Pablo Galindo
gh-123229: Fix valgrind warning by initializing the f-string buffers to 0 in the tokenizer. Patch by Pablo Galindo
gh-122298: Restore printout of GC stats when
gc.set_debug(gc.DEBUG_STATS)is called. This featue was accidentally removed when implementing incremental GC.gh-121804: Correctly show error locations when a
SyntaxErroris raised in the basic REPL. Patch by Sergey B Kirpichev.gh-123142: Fix too-wide source location in exception tracebacks coming from broken iterables in comprehensions.
gh-123048: Fix a bug where pattern matching code could emit a
JUMP_FORWARDwith no source location.gh-123123: Fix displaying
SyntaxErrorexceptions covering multiple lines. Patch by Pablo Galindogh-123083: Fix a potential use-after-free in
STORE_ATTR_WITH_HINT.gh-123022: Fix crash in free-threaded build when calling
Py_Initialize()from a non-main thread.gh-122888: Fix crash on certain calls to
str()with positional arguments of the wrong type. Patch by Jelle Zijlstra.gh-116622: Fix Android stdout and stderr messages being truncated or lost.
gh-122527: Fix a crash that occurred when a
PyStructSequencewas deallocated after its type’s dictionary was cleared by the GC. The type’stp_basicsizenow accounts for non-sequence fields that aren’t included in thePy_SIZEof the sequence.gh-122445: Add only fields which are modified via self.* to
__static_attributes__.gh-98442: Fix too wide source locations of the cleanup instructions of a with statement.
gh-93691: Fix source locations of instructions generated for with statements.
gh-120097:
FrameLocalsProxynow subclassescollections.abc.Mappingand can be matched as a mapping inmatchstatements
C API¶
gh-122728: Fix
PyEval_GetLocals()to avoidSystemError(“bad argument to internal function”). Patch by Victor Stinner.
Build¶
gh-123418: Updated Android build to use OpenSSL 3.0.15.
gh-123297: Propagate the value of
LDFLAGStoLDCXXSHAREDinsysconfig. Patch by Pablo Galindogh-116622: Rename build variable
MODULE_LDFLAGSback toLIBPYTHON, as it’s used by package build systems (e.g. Meson).gh-118943: Fix an issue where the experimental JIT could be built several times by the
make regen-alltarget, leading to possible race conditions on heavily parallelized builds.gh-118943: Fix a possible race condition affecting parallel builds configured with
--enable-experimental-jit, in whichFileNotFoundErrorcould be caused by another process already movingjit_stencils.h.newtojit_stencils.h.
Python 3.13.0 release candidate 1¶
Release date: 2024-07-31
Tests¶
gh-59022: Add tests for
pkgutil.extend_path(). Patch by Andreas Stocker.gh-99242:
os.getloadavg()may throwOSErrorwhen running regression tests under certain conditions (e.g. chroot). This error is now caught and ignored, since reporting load average is optional.
Security¶
gh-122133: Authenticate the socket connection for the
socket.socketpair()fallback on platforms whereAF_UNIXis not available like Windows.Patch by Gregory P. Smith <greg@krypto.org> and Seth Larson <seth@python.org>. Reported by Ellie <el@horse64.org>
gh-121957: Fixed missing audit events around interactive use of Python, now also properly firing for
python -i, as well as forpython -m asyncio. The events in question arecpython.run_stdinandcpython.run_startup.
Library¶
gh-122400: Handle
ValueErrors raised byos.stat()infilecmp.dircmpandfilecmp.cmpfiles(). Patch by Bénédikt Tran.gh-122332: Fixed segfault with
asyncio.Task.get_coro()when using an eager task factory.gh-105733:
ctypes.ARRAY()is now soft deprecated: it no longer emits deprecation warnings and is not scheduled for removal.gh-122087: Restore
inspect.ismethoddescriptor()andinspect.isroutine()returningFalseforfunctools.partialobjects.gh-122170: Handle
ValueErrors raised byos.stat()inlinecache. Patch by Bénédikt Tran.gh-82951: Serializing objects with complex
__qualname__(such as unbound methods and nested classes) by name no longer involves serializing parent objects by value in pickle protocols < 4.gh-113785:
csvnow correctly parses numeric fields (when used withcsv.QUOTE_NONNUMERICorcsv.QUOTE_STRINGS) which start with an escape character.gh-122088:
@warnings.deprecatednow copies the coroutine status of functions and methods so thatinspect.iscoroutinefunction()returns the correct result.gh-120930: Fixed a bug introduced by gh-92081 that added an incorrect extra blank to encoded words occurring in wrapped headers.
gh-121474: Fix missing sanity check for
partiesarg inthreading.Barrierconstructor. Patch by Clinton Christian (pygeek).gh-120289: Fixed the use-after-free issue in
cProfileby disallowingdisable()andclear()in external timers.
IDLE¶
gh-122482: Change About IDLE to direct users to discuss.python.org instead of the now unused idle-dev email and mailing list.
Core and Builtins¶
gh-116090: Fix an issue in JIT builds that prevented some
forloops from correctly firingRAISEmonitoring events.gh-122208: Dictionary watchers now only deliver the PyDict_EVENT_ADDED event when the insertion is in a known good state to succeed.
gh-122300: Preserve AST nodes for f-string with single-element format specifiers. Patch by Pablo Galindo
gh-120906:
frame.f_localsnow supports arbitrary hashable objects as keys.gh-122029: Emit
c_callevents insys.setprofile()when aPyMethodObjectpointing to aPyCFunctionis called.gh-122026: Fix a bug that caused the tokenizer to not correctly identify mismatched parentheses inside f-strings in some situations. Patch by Pablo Galindo
gh-118934: Make
PyEval_GetLocalsreturn borrowed reference
C API¶
gh-116622: Make
PyObject_Printwork around a bug in Android and OpenBSD which prevented it from throwing an exception when trying to write to a read-only stream.gh-121489: Export private
_PyBytes_Join()again.
Build¶
gh-120522: Added a
--with-app-store-complianceoption to patch out known issues with macOS/iOS App Store review processes.
Python 3.13.0 beta 4¶
Release date: 2024-07-18
Tests¶
gh-121084: Fix test_typing random leaks. Clear typing ABC caches when running tests for refleaks (
-Roption): call_abc_caches_clear()on typing abstract classes and their subclasses. Patch by Victor Stinner.gh-121160: Add a test for
readline.set_history_length(). Note that this test may fail on readline libraries.gh-121200: Fix
test_expanduser_pwd2()oftest_posixpath. Callgetpwnam()to getpw_dir, since it can be different thangetpwall()pw_dir. Patch by Victor Stinner.gh-121188: When creating the JUnit XML file, regrtest now escapes characters which are invalid in XML, such as the chr(27) control character used in ANSI escape sequences. Patch by Victor Stinner.
Library¶
gh-57141: The shallow argument to
filecmp.dircmp(new in Python 3.13) is now keyword-only.gh-121245: Simplify handling of the history file in
site.register_readline()helper. TheCAN_USE_PYREPLvariable now will be initialized, when imported. Patch by Sergey B Kirpichev.gh-121332: Fix constructor of
astnodes with custom_attributes. Previously, passing custom attributes would raise aDeprecationWarning. Passing arguments to the constructor that are not in_fieldsor_attributesremains deprecated. Patch by Jelle Zijlstra.gh-121279: Avoid
NameErrorfor thewarningsmodule when accessing the depracated atributes of theimportlib.abcmodule.gh-121245: Fix a bug in the handling of the command history of the new REPL that caused the history file to be wiped at REPL exit.
gh-87744: Fix waitpid race while calling
send_signal()in asyncio. Patch by Kumar Aditya.gh-121018: Fixed other issues where
argparse.ArgumentParserdid not honorexit_on_error=False.gh-120678: Fix regression in the new REPL that meant that globals from files passed using the
-iargument would not be included in the REPL’s global namespace. Patch by Alex Waygood.gh-120782: Fix wrong references of the
datetimetypes after reloading the module.gh-120713:
datetime.datetime.strftime()now 0-pads years with less than four digits for the format specifiers%Yand%Gon Linux. Patch by Ben Hsinggh-117983: Defer the
threadingimport inimportlib.utiluntil lazy loading is used.gh-119189: When using the
**operator orpow()withFractionas the base and an exponent that is not rational, a float, or a complex, the fraction is no longer converted to a float.gh-118714: Allow
restartin post-mortem debugging ofpdb. Removed restart message when the user quits pdb from post-mortem mode.gh-105623: Fix performance degradation in
logging.handlers.RotatingFileHandler. Patch by Craig Robson.
IDLE¶
gh-78889: Stop Shell freezes by blocking user access to non-method sys.stdout.shell attributes, which are all private.
Documentation¶
gh-121749: Fix documentation for
PyModule_AddObjectRef().gh-120012: Clarify the behaviours of
multiprocessing.Queue.empty()andmultiprocessing.SimpleQueue.empty()on closed queues. Patch by Bénédikt Tran.
Core and Builtins¶
gh-121860: Fix crash when rematerializing a managed dictionary after it was deleted.
gh-121814: Fixed the SegFault when
PyEval_SetTrace()is used with no Python frame on stack.gh-121295: Fix PyREPL console getting into a blocked state after interrupting a long paste
gh-121794: Fix bug in free-threaded Python where a resurrected object could lead to a negative ref count assertion failure.
gh-121657: Improve the
SyntaxErrormessage if the user tries to useyield fromoutside a function.gh-121609: Fix pasting of characters containing unicode character joiners in the new REPL. Patch by Marta Gomez Macias
gh-117482: Unexpected slot wrappers are no longer created for builtin static types in subinterpreters.
gh-121499: Fix a bug affecting how multi-line history was being rendered in the new REPL after interacting with the new screen cache. Patch by Pablo Galindo
gh-121497: Fix a bug that was preventing the REPL to correctly respect the history when an input hook was set. Patch by Pablo Galindo
gh-121012: Tier 2 execution now ensures that list iterators remain exhausted, once they become exhausted.
gh-121439: Allow tuples of length 20 in the freelist to be reused.
gh-121368: Fix race condition in
_PyType_Lookupin the free-threaded build due to a missing memory fence. This could lead to_PyType_Lookupreturning incorrect results on arm64.gh-121130: Fix f-strings with debug expressions in format specifiers. Patch by Pablo Galindo
gh-121115:
PyLong_AsNativeBytes()no longer uses__index__()methods by default. ThePy_ASNATIVEBYTES_ALLOW_INDEXflag has been added to allow it.
C API¶
gh-89364: Export the
PySignal_SetWakeupFd()function. Previously, the function was documented but it couldn’t be used in 3rd party code. Patch by Victor Stinner.gh-113993:
PyUnicode_InternInPlace()no longer prevents its argument from being garbage collected.Several functions that take
char *are now documented as possibly preventing string objects from being garbage collected; refer to their documentation for details:PyUnicode_InternFromString(),PyDict_SetItemString(),PyObject_SetAttrString(),PyObject_DelAttrString(),PyUnicode_InternFromString(), andPyModule_Add*convenience functions.gh-113601: Removed debug build assertions related to interning strings, which were falsely triggered by stable ABI extensions.
gh-112136: Restore the private
_PyArg_Parserstructure and the private_PyArg_ParseTupleAndKeywordsFast()function, previously removed in Python 3.13 alpha 1. Patch by Victor Stinner.
Build¶
gh-120371: Support WASI SDK 22 by explicitly skipping functions that are just stubs in wasi-libc.
gh-121731: Fix mimalloc compile error on GNU/Hurd
gh-121487: Fix deprecation warning for ATOMIC_VAR_INIT in mimalloc.
gh-121467: Fix a Makefile bug that prevented mimalloc header files from being installed.
gh-121103: On POSIX systems, excluding macOS framework installs, the lib directory for the free-threaded build now includes a “t” suffix to avoid conflicts with a co-located default build installation.
gh-120831: The default minimum iOS version was increased to 13.0.
gh-113565: Improve
cursesandcurses.paneldependency checks in configure.
Python 3.13.0 beta 3¶
Release date: 2024-06-27
Core and Builtins¶
gh-120838:
Py_Finalize()andPy_FinalizeEx()now always run with the main interpreter active.gh-113433: Subinterpreters now get cleaned up automatically during runtime finalization.
gh-119462: Make sure that invariants of type versioning are maintained: * Superclasses always have their version number assigned before subclasses * The version tag is always zero if the tag is not valid. * The version tag is always non-zero if the tag is valid.
gh-120437: Fix
_CHECK_STACK_SPACEoptimization problems introduced in gh-118322.gh-120722: Correctly set the bytecode position on return instructions within lambdas. Patch by Jelle Zijlstra.
gh-120367: Fix bug where compiler creates a redundant jump during pseudo-op replacement. Can only happen with a synthetic AST that has a try on the same line as the instruction following the exception handler.
gh-113993: Strings interned with
sys.intern()are again garbage-collected when no longer used, as per the documentation. Strings interned with the C functionPyUnicode_InternInPlace()are still immortal. Internals of the string interning mechanism have been changed. This may affect performance and identities ofstrobjects.gh-120384: Fix an array out of bounds crash in
list_ass_subscript, which could be invoked via some specificly tailored input: including concurrent modification of a list object, where one thread assigns a slice and another clears it.gh-120367: Fix crash in compiler on code with redundant NOPs and JUMPs which show up after exception handlers are moved to the end of the code.
gh-120380: Fix Python implementation of
pickle.Picklerforbytesandbytearrayobjects when using protocol version 5. Patch by Bénédikt Tran.gh-120400: Support Linux perf profiler to see Python calls on RISC-V architecture.
gh-120221: Deliver real signals on Ctrl-C and Ctrl-Z in the new REPL. Patch by Pablo Galindo
gh-120346: Respect
PYTHON_BASIC_REPLwhen running in interative inspect mode (python -i). Patch by Pablo Galindogh-93691: Fix source locations of instructions generated for the iterator of a for statement.
gh-120198: Fix a crash when multiple threads read and write to the same
__class__of an object concurrently.gh-120298: Fix use-after free in
list_richcompare_implwhich can be invoked via some specificly tailored evil input.gh-119666: Fix a compiler crash in the case where two comprehensions in class scope both reference
__class__.gh-120225: Fix crash in compiler on empty block at end of exception handler.
gh-119933: Improve
SyntaxErrormessages for invalid expressions in a type parameters bound, a type parameter constraint tuple or a default type parameter. Patch by Bénédikt Tran.bpo-24766: Fix handling of
docargument to subclasses ofproperty.
Library¶
gh-121027: Add a future warning in
functools.partial.__get__(). In future Python versionsfunctools.partialwill be a method descriptor.gh-121025: Improve the
__repr__()offunctools.partialmethod. Patch by Bénédikt Tran.gh-121018: Fixed an issue where
argparse.ArgumentParser.parses_args()did not honorexit_on_error=Falsewhen given unrecognized arguments. Patch by Ben Hsing.gh-119614: Fix truncation of strings with embedded null characters in some internal operations in
tkinter.gh-120910: When reading installed files from an egg, use
relative_to(walk_up=True)to honor files installed outside of the installation root.gh-120888: Upgrade pip wheel bundled with ensurepip (pip 24.1.1)
gh-101830: Accessing the
tkinterobject’s string representation no longer converts the underlying Tcl object to a string on Windows.gh-120811: Fix possible memory leak in
contextvars.Context.run().gh-120769: Make empty line in
pdbrepeats the last command even when the command is fromcmdqueue.gh-120732: Fix
namepassing tounittest.mock.Mockobject when usingunittest.mock.create_autospec().gh-120683: Fix an error in
logging.LogRecord, when the integer part of the timestamp is rounded up, while the millisecond calculation truncates, causing the log timestamp to be wrong by up to 999 ms (affected roughly 1 in 8 million timestamps).gh-120633: Move scrollbar and remove tear-off menus in turtledemo.
gh-120541: Improve the prompt in the “less” pager when
help()is called with non-string argument.gh-120495: Fix incorrect exception handling in Tab Nanny. Patch by Wulian233.
gh-120381: Correct
inspect.ismethoddescriptor()to check also for the lack of__delete__(). Patch by Jan Kaliszewski.gh-90425: The OS byte in gzip headers is now always set to 255 when using
gzip.compress().gh-120343: Fix column offset reporting for tokens that come after multiline f-strings in the
tokenizemodule.gh-119600: Fix
unittest.mock.patch()to not read attributes of the target whennew_callableis set. Patch by Robert Collins.gh-114053: Fix edge-case bug where
typing.get_type_hints()would produce incorrect results if type parameters in a class scope were overridden by assignments in a class scope andfrom __future__ import annotationssemantics were enabled. Patch by Alex Waygood.gh-114053: Fix erroneous
NameErrorwhen callinginspect.get_annotations()witheval_str=True`on a class that made use of PEP 695 type parameters in a module that hadfrom __future__ import annotationsat the top of the file. Patch by Alex Waygood.gh-120268: Prohibit passing
Noneto pure-Pythondatetime.date.fromtimestamp()to achieve consistency with C-extension implementation.gh-120244: Fix memory leak in
re.sub()when the replacement string contains backreferences.gh-120211: Fix
tkinter.ttkwith Tcl/Tk 9.0.gh-71587: Fix crash in C version of
datetime.datetime.strptime()when called again on the restarted interpreter.gh-120161:
datetimeno longer crashes in certain complex reference cycle situations.gh-119698: Fix
symtable.Class.get_methods()and document its behaviour. Patch by Bénédikt Tran.gh-120121: Add
concurrent.futures.InvalidStateErrorto module’s__all__.gh-119933: Add the
symtable.SymbolTableTypeenumeration to represent the possible outputs of thesymtable.SymbolTable.get_typemethod. Patch by Bénédikt Tran.gh-120108: Fix calling
copy.deepcopy()onasttrees that have been modified to have references to parent nodes. Patch by Jelle Zijlstra.gh-65454:
unittest.mock.Mock.attach_mock()no longer triggers a call to aPropertyMockbeing attached.gh-81936:
help()andshowtopic()methods now respect a configured output argument topydoc.Helperand not use the pager in such cases. Patch by Enrico Tröger.gh-119577: The
DeprecationWarningemitted when testing the truth value of anxml.etree.ElementTree.Elementnow describes unconditionally returningTruein a future version rather than raising an exception in Python 3.14.gh-118908: Limit exposed globals from internal imports and definitions on new REPL startup. Patch by Eugene Triguba and Pablo Galindo.
gh-119506: Fix
io.TextIOWrapper.write()method breaks internal buffer when the method is called again during flushing internal buffer.
Build¶
gh-120671: Fix failing configure tests due to a missing space when appending to CFLAGS.
gh-120602: Correctly handle LLVM installs with
LLVM_VERSION_SUFFIXwhen building with--enable-experimental-jit.gh-120326: On Windows, fix build error when
--disable-giland--experimental-jitoptions are combined.gh-120291: Make the
python-configshell script compatible with non-bash shells.
C API¶
gh-120642: Remove the private
_Py_CODEUNITtype from the public C API. The internalpycore_code.hheader should now be used to get this internal type. Patch by Victor Stinner.gh-120858:
PyDict_Next()no longer locks the dictionary in the free-threaded build. The locking needs to be done by the caller around the entire iteration loop.gh-120642: Remove the following unstable functions:
PyUnstable_Replace_Executor()PyUnstable_SetOptimizer()PyUnstable_GetOptimizer()PyUnstable_GetExecutor()PyUnstable_Optimizer_NewCounter()PyUnstable_Optimizer_NewUOpOptimizer()
Patch by Victor Stinner.
gh-119344: The critical section API is now public as part of the non-limited C API.
gh-118789: Add
PyUnstable_Object_ClearWeakRefsNoCallbacks(), which clears weakrefs without calling their callbacks.gh-117511: Make the
PyMutexpublic in the non-limited C API.
Python 3.13.0 beta 2¶
Release date: 2024-06-05
Security¶
gh-118773: Fixes creation of ACLs in
os.mkdir()on Windows to work correctly on non-English machines.gh-118486:
os.mkdir()on Windows now accepts mode of0o700to restrict the new directory to the current user. This fixes CVE 2024-4030 affectingtempfile.mkdtemp()in scenarios where the base temporary directory is more permissive than the default.
Core and Builtins¶
gh-119724: Reverted improvements to error messages for
elif/elsestatements not matching any valid statements, which made in hard to locate the syntax errors inside thoseelif/elseblocks.gh-119842: Honor
PyOS_InputHook()in the new REPL. Patch by Pablo Galindogh-119821: Fix execution of annotation scopes within classes when
globalsis set to a non-dict. Patch by Jelle Zijlstra.gh-119548: Add a
clearcommand to the REPL. Patch by Pablo Galindogh-111999: Fix the signature of
str.format_map().gh-119560: An invalid assert in beta 1 has been removed. The assert would fail if
PyState_FindModule()was used in an extension module’s init function before the module def had been initialized.gh-119369: Fix deadlock during thread deletion in free-threaded build, which could occur when the GIL was enabled at runtime.
gh-119525: Fix deadlock involving
_PyType_Lookup()cache in the free-threaded build when the GIL is dynamically enabled at runtime.gh-119311: Fix bug where names are unexpectedly mangled in the bases of generic classes.
gh-119395: Fix bug where names appearing after a generic class are mangled as if they are in the generic class.
gh-119213: Non-builtin modules built with argument clinic were crashing if used in a subinterpreter before the main interpreter. The objects that were causing the problem by leaking between interpreters carelessly have been fixed.
gh-119011: Fixes
type.__type_params__to return an empty tuple instead of a descriptor.gh-118692: Avoid creating unnecessary
StopIterationinstances for monitoring.gh-119049: Fix displaying the source line for warnings created by the C API if the
warningsmodule had not yet been imported.gh-118844: Fix build failures when configuring with both
--disable-giland--enable-experimental-jit.gh-118921: Add
copy()method forFrameLocalsProxywhich returns a snapshotdictfor local variables.gh-117657: Fix data races on the field that stores a pointer to the interpreter’s main thread that occur in free-threaded builds.
gh-118561: Fix race condition in free-threaded build where
list.extend()could expose uninitialised memory to concurrent readers.gh-117195: Avoid assertion failure for debug builds when calling
object.__sizeof__(1)
Library¶
gh-119819: Fix regression to allow logging configuration with multiprocessing queue types.
gh-117142: The
ctypesmodule may now be imported in all subinterpreters, including those that have their own GIL.gh-118835: Fix _pyrepl crash when using custom prompt with ANSI escape codes.
gh-117398: The
_datetimemodule (C implementation fordatetime) now supports being imported in multiple interpreters.gh-89727: Fix issue with
shutil.rmtree()where aRecursionErroris raised on deep directory trees.gh-89727: Partially fix issue with
shutil.rmtree()where aRecursionErroris raised on deep directory trees. A recursion error is no longer raised whenrmtree.avoids_symlink_attacksis false.gh-119118: Fix performance regression in the
tokenizemodule by caching thelinetoken attribute and calculating the column offset more efficiently.gh-89727: Fix issue with
os.fwalk()where aRecursionErrorwas raised on deep directory trees by adjusting the implementation to be iterative instead of recursive.gh-119588:
zipfile.Path.is_symlinknow assesses if the given path is a symlink.gh-119555: Catch
SyntaxErrorfromcompile()in the runsource() method of the InteractiveColoredConsole. Patch by Sergey B Kirpichev.gh-113892: Now, the method
sock_connectofasyncio.ProactorEventLoopraises aValueErrorif given socket is not in non-blocking mode, as well as in other loop implementations.gh-119443: The interactive REPL no longer runs with
from __future__ import annotationsenabled. Patch by Jelle Zijlstra.gh-117398: Objects in the datetime C-API are now all statically allocated, which means better memory safety, especially when the module is reloaded. This should be transparent to users.
gh-118894:
asyncioREPL now has the same capabilities as PyREPL.gh-118911: In PyREPL, updated
maybe-accept’s logic so that if the user hits Enter twice, they are able to terminate the block even if there’s trailing whitespace. Also, now when the user hits arrow up, the cursor is on the last functional line. This matches IPython’s behavior. Patch by Aya Elsayed.gh-111201: Remove dependency to
readlinefrom the new Python REPL.gh-119174: Fix high DPI causes turtledemo(turtle-graphics examples) windows blurry Patch by Wulian233 and Terry Jan Reedy
gh-119121: Fix a NameError happening in
asyncio.staggered.staggered_race. This function is now tested.gh-119113: Fix issue where
pathlib.PurePath.with_suffix()didn’t raiseTypeErrorwhen givenNoneas a suffix.gh-118643: Fix an AttributeError in the
emailmodule when re-fold a long address list. Also fix more cases of incorrect encoding of the address separator in the address list.gh-58933: Make
pdbreturn to caller frame correctly whenf_traceof the caller frame is not setgh-118895: Setting attributes on
typing.NoDefaultnow raisesAttributeErrorinstead ofTypeError.gh-118868: Fixed issue where kwargs were no longer passed to the logging handler QueueHandler
gh-118851:
ctxarguments to the constructors ofastnode classes now default toast.Load(). Patch by Jelle Zijlstra.gh-118760: Restore the default value of
tkiter.wantobjectsto1.gh-118760: Fix errors in calling Tkinter bindings on Windows.
gh-118507: Fix
os.path.isfile()on Windows for pipes. Speedupos.path.isjunction()andos.path.lexists()on Windows with a native implementation.gh-118772: Allow
typing.TypeVarinstances without a default to follow instances without a default in some cases. Patch by Jelle Zijlstra.gh-110863:
os.path.realpath()now suppresses anyOSErrorfromos.readlink()when strict mode is disabled (the default).gh-118263: Speed up
os.path.splitroot()&os.path.normpath()with a direct C call.gh-118033: Fix
dataclasses.dataclass()not creating a__weakref__slot when subclassingtyping.Generic.gh-106531: In
importlib.resources, sync with importlib_resources 6.3.2, including:MultiplexedPathnow expectsTraversablepaths, deprecating string arguments toMultiplexedPath; Enabled support for resources in namespace packages in zip files; FixedNotADirectoryErrorwhen calling files on a subdirectory of a namespace package.gh-113978: Ignore warnings on text completion inside REPL.
gh-103956: Fix lack of newline characters in
tracemodule output when line tracing is enabled but source code line for current frame is not available.gh-92081: Fix missing spaces in email headers when the spaces are mixed with encoded 8-bit characters.
gh-103194: Prepare Tkinter for C API changes in Tcl 8.7/9.0 to avoid
_tkinter.Tcl_Objbeing unexpectedly returned instead ofbool,str,bytearray, orint.gh-87106: Fixed handling in
inspect.Signature.bind()of keyword arguments having the same name as positional-only arguments when a variadic keyword argument (e.g.**kwargs) is present.bpo-45767: Fix integer conversion in
os.major(),os.minor(), andos.makedev(). Support device numbers larger than2**63-1. Support non-existent device number (NODEV).gh-67693: Fix
urllib.parse.urlunparse()andurllib.parse.urlunsplit()for URIs with path starting with multiple slashes and no authority. Based on patch by Ashwin Ramaswami.
Tests¶
gh-119050: regrtest test runner: Add XML support to the refleak checker (-R option). Patch by Victor Stinner.
Build¶
gh-119729: On POSIX systems, the pkg-config (
.pc) filenames now include the ABI flags, which may include debug (“d”) and free-threaded (“t”). For example: *python-3.14.pc(default, non-debug build) *python-3.14d.pc(default, debug build) *python-3.14t.pc(free-threaded build)gh-115119: Fall back to the bundled libmpdec if a system version cannot be found.
gh-119132: Update
sys.versionto identify whether the build is default build or free-threading build. Patch By Donghee Na.gh-118836: Fix an
AssertionErrorwhen building with--enable-experimental-jitand the compiler emits aSHT_NOTEsection.gh-118943: Fix a possible race condition affecting parallel builds configured with
--enable-experimental-jit, in which compilation errors could be caused by an incompletely-generated header file.
Windows¶
gh-119679: Ensures correct import libraries are included in Windows installs.
gh-119690: Adds Unicode support and fixes audit events for
_winapi.CreateNamedPipe.gh-111201: Add support for new pyrepl on Windows
gh-119070: Fixes
py.exehandling of shebangs like/usr/bin/env python3.12, which were previously interpreted aspython3.exeinstead ofpython3.12.exe.gh-117505: Fixes an issue with the Windows installer not running ensurepip in a fully isolated environment. This could cause unexpected interactions with the user site-packages.
gh-118209: Avoid crashing in
mmapon Windows when the mapped memory is inaccessible due to file system errors or access violations.gh-116145: Updated bundled Tcl/Tk to 8.6.14.
C API¶
gh-119585: Fix crash when a thread state that was created by
PyGILState_Ensure()calls a destructor that duringPyThreadState_Clear()that calls back intoPyGILState_Ensure()andPyGILState_Release(). This might occur when in the free-threaded build or when using thread-local variables whose destructors callPyGILState_Ensure().gh-119336: Restore the removed
_PyLong_NumBits()function. It is used by the pywin32 project. Patch by Ethan Smithgh-119247: Added
Py_BEGIN_CRITICAL_SECTION_SEQUENCE_FASTandPy_END_CRITICAL_SECTION_SEQUENCE_FASTmacros to make it possible to use PySequence_Fast APIs safely when free-threaded, and update str.join to work without the GIL using them.gh-111389: Add
PyHASH_MULTIPLIERconstant: prime multiplier used in string and various other hashes. Patch by Victor Stinner.gh-116984: Make mimalloc includes relative to the current file to avoid embedders or extensions needing to include
Internal/mimallocif they are already including internal CPython headers.gh-118789: Restore
_PyWeakref_ClearRefthat was previously removed in Python 3.13 alpha 1.
Python 3.13.0 beta 1¶
Release date: 2024-05-08
Security¶
Core and Builtins¶
gh-118414: Add instrumented opcodes to YIELD_VALUE assertion for tracing cases.
gh-117953: When a builtin or extension module is imported for the first time, while a subinterpreter is active, the module’s init function is now run by the main interpreter first before import continues in the subinterpreter. Consequently, single-phase init modules now fail in an isolated subinterpreter without the init function running under that interpreter, whereas before it would run under the subinterpreter before failing, potentially leaving behind global state and callbacks and otherwise leaving the module in an inconsistent state.
gh-117549: Don’t use designated initializer syntax in inline functions in internal headers. They cause problems for C++ or MSVC users who aren’t yet using the latest C++ standard (C++20). While internal, pycore_backoff.h, is included (indirectly, via pycore_code.h) by some key 3rd party software that does so for speed.
gh-95382: Improve performance of
json.dumps()andjson.dump()when using the argument indent. Depending on the data the encoding usingjson.dumps()with indent can be up to 2 to 3 times faster.gh-116322: In
--disable-gilbuilds, the GIL will be enabled while loading C extension modules. If the module indicates that it supports running without the GIL, the GIL will be disabled once loading is complete. Otherwise, the GIL will remain enabled for the remainder of the interpreter’s lifetime. This behavior does not apply if the GIL has been explicitly enabled or disabled withPYTHON_GILor-Xgil.gh-118513: Fix incorrect
UnboundLocalErrorwhen two comprehensions in the same function both reference the same name, and in one comprehension the name is bound while in the other it’s an implicit global.gh-118518: Allow the Linux perf support to work without frame pointers using perf’s advanced JIT support. The feature is activated when using the
PYTHON_PERF_JIT_SUPPORTenvironment variable or when running Python with-Xperf_jit. Patch by Pablo Galindo.gh-117514: Add
sys._is_gil_enabled()function that returns whether the GIL is currently enabled. In the default build it always returnsTruebecause the GIL is always enabled. In the free-threaded build, it may returnTrueorFalse.gh-118164: Break a loop between the Python implementation of the
decimalmodule and the Python code for integer to string conversion. Also optimize integer to string conversion for values in the range from 9_000 to 135_000 decimal digits.gh-118473: Fix
sys.set_asyncgen_hooks()not to be partially set when raisingTypeError.gh-118465: Compiler populates the new
__firstlineno__field on a class with the line number of the first line of the class definition.gh-118492: Fix an issue where the type cache can expose a previously accessed attribute when a finalizer is run.
gh-117714: update
async_generator.athrow().close()andasync_generator.asend().close()to close their section of the underlying async generatorgh-111201: The interactive interpreter is now implemented in Python, which allows for a number of new features like colors, multiline input, history viewing, and paste mode. Contributed by Pablo Galindo, Łukasz Langa and Lysandros Nikolaou based on code from the PyPy project.
gh-74929: Implement PEP 667: converted
FrameType.f_localsandPyFrame_GetLocals()to return a write-through proxy object when the frame refers to a function or comprehension.gh-116767: Fix crash in compiler on ‘async with’ that has many context managers.
gh-118335: Change how to use the tier 2 interpreter. Instead of running Python with
-X uopsor setting the environment variablePYTHON_UOPS=1, this choice is now made at build time by configuring with--enable-experimental-jit=interpreter.Beware! This changes the environment variable to enable or disable micro-ops to
PYTHON_JIT. The oldPYTHON_UOPSis no longer used.gh-118306: Update JIT compilation to use LLVM 18
gh-118160: Annotation scopes within classes can now contain comprehensions. However, such comprehensions are not inlined into their parent scope at runtime. Patch by Jelle Zijlstra.
gh-118272: Fix bug where
generator.closedoes not free the generator frame’s locals.gh-118216: Don’t consider
__future__imports with dots before the module name.gh-118074: Make sure that the Executor objects in the COLD_EXITS array aren’t assumed to be GC-able (which would access bytes outside the object).
gh-107674: Lazy load frame line number to improve performance of tracing
gh-118082: Improve
SyntaxErrormessage for imports without names, like infrom x importandimportcases. It now points out to users thatimportexpects at least one name after it.gh-118090: Improve
SyntaxErrormessage for empty type param brackets.gh-117958: Added a
get_jit_code()method to access JIT compiled machine code from the UOp Executor when the experimental JIT is enabled. Patch by Anthony Shaw.gh-117901: Add option for compiler’s codegen to save nested instruction sequences for introspection.
gh-116622: Redirect stdout and stderr to system log when embedded in an Android app.
gh-109118: annotation scope within class scopes can now contain lambdas.
gh-117894: Prevent
agen.aclose()objects being re-used after.throw().gh-117881: prevent concurrent access to an async generator via athrow().throw() or asend().throw()
gh-117536: Fix a
RuntimeWarningwhen callingagen.aclose().throw(Exception).gh-117755: Fix mimalloc allocator for huge memory allocation (around 8,589,934,592 GiB) on s390x. Patch by Victor Stinner.
gh-117750: Fix issue where an object’s dict would get out of sync with the object’s internal values when being cleared.
obj.__dict__.clear()now clears the internal values, but leaves the dict attached to the object.gh-117431: Improve the performance of the following
bytesandbytearraymethods by adapting them to theMETH_FASTCALLcalling convention:count()find()index()rfind()rindex()
gh-117709: Speed up calls to
str()with positional-only argument, by using the PEP 590vectorcallcalling convention. Patch by Erlend Aasland.gh-117680: Give
_PyInstructionSequencea Python interface and use it in tests.gh-115776: Statically allocated objects are, by definition, immortal so must be marked as such regardless of whether they are in extension modules or not.
gh-117385: Remove unhandled
PY_MONITORING_EVENT_BRANCHandPY_MONITORING_EVENT_EXCEPTION_HANDLEDevents fromsys.settrace().gh-116322: Extension modules may indicate to the runtime that they can run without the GIL. Multi-phase init modules do so by calling providing
Py_MOD_GIL_NOT_USEDfor thePy_mod_gilslot, while single-phase init modules callPyUnstable_Module_SetGIL(mod, Py_MOD_GIL_NOT_USED)from their init function.gh-116129: Implement PEP 696, adding support for defaults on type parameters. Patch by Jelle Zijlstra.
gh-93502: Add two new functions to the C-API,
PyRefTracer_SetTracer()andPyRefTracer_GetTracer(), that allows to track object creation and destruction the same way thetracemallocmodule does. Patch by Pablo Galindogh-107674: Improved the performance of
sys.settrace()significantlygh-95754: Improve the error message when a script shadowing a module from the standard library causes
AttributeErrorto be raised. Similarly, improve the error message when a script shadowing a third party module attempts to access an attribute from that third party module while still initialising.gh-99180: Elide uninformative traceback indicators in
returnand simpleassignmentstatements. Patch by Pablo Galindo.gh-105879: Allow the globals and locals arguments to
exec()andeval()to be passed as keywords.
Library¶
gh-118418: A
DeprecationWarningis now emitted if you fail to pass a value to the new type_params parameter oftyping._eval_type()ortyping.ForwardRef._evaluate(). (Using either of these private and undocumented functions is discouraged to begin with, but failing to pass a value to thetype_paramsparameter may lead to incorrect behaviour on Python 3.12 or newer.)gh-118660: Add an optional second type parameter to
typing.ContextManagerandtyping.AsyncContextManager, representing the return types of__exit__()and__aexit__()respectively. This parameter defaults tobool | None.gh-118650: The
enummodule allows method named_repr_*to be defined onEnumtypes.gh-118648: Add type parameter defaults to
typing.Generatorandtyping.AsyncGenerator.gh-101137: Mime type
text/x-rstis now supported bymimetypes.gh-118164: The Python implementation of the
decimalmodule could appear to hang in relatively small power cases (like2**117) if context precision was set to a very high value. A different method to check for exactly representable results is used now that doesn’t rely on computing10**precision(which could be effectively too large to compute).gh-111744:
breakpoint()andpdb.set_trace()now enter the debugger immediately after the call rather than before the next line is executed.gh-118406: Add signature for
sqlite3.Connectionobjects.gh-101732: Use a Y2038 compatible openssl time function when available.
gh-118404: Fix
inspect.signature()for non-comparable callables.gh-118402: Fix
inspect.signature()for the result of thefunctools.cmp_to_key()call.gh-116622: On Android,
sysconfig.get_platformnow returns the format specified by PEP 738.gh-118285: Allow to specify the signature of custom callable instances of extension type by the
__text_signature__attribute. Specify signatures ofoperator.attrgetter,operator.itemgetter, andoperator.methodcallerinstances.gh-118314: Fix an edge case in
binascii.a2b_base64()strict mode, where excessive padding is not detected when no padding is necessary.gh-118271: Add the
PhotoImagemethodsread()to read an image from a file anddata()to get the image data. Add background and grayscale parameters toPhotoImagemethodwrite().gh-118225: Add the
PhotoImagemethodcopy_replace()to copy a region from one image to other image, possibly with pixel zooming and/or subsampling. Add from_coords parameter toPhotoImagemethodscopy(),zoom()andsubsample(). Add zoom and subsample parameters toPhotoImagemethodcopy().gh-118221: Fix a bug where
sqlite3.Connection.iterdump()could fail if a customrow factorywas used. Patch by Erlend Aasland.gh-118013: Fix regression introduced in gh-103193 that meant that calling
inspect.getattr_static()on an instance would cause a strong reference to that instance’s class to persist in an internal cache in theinspectmodule. This caused unexpected memory consumption if the class was dynamically created, the class held strong references to other objects which took up a significant amount of memory, and the cache contained the sole strong reference to the class. The fix for the regression leads to a slowdown ingetattr_static(), but the function should still be significantly faster than it was in Python 3.11. Patch by Alex Waygood.gh-118218: Speed up
itertools.pairwise()in the common case by up to 1.8x.gh-117486: Improve the behavior of user-defined subclasses of
ast.AST. Such classes will now require no changes in the usual case to conform with the behavior changes of theastmodule in Python 3.13. Patch by Jelle Zijlstra.gh-90848: Fixed
unittest.mock.create_autospec()to configure parent mock with keyword arguments.gh-118168: Fix incorrect argument substitution when
typing.Unpackis used with the builtintuple.typing.Unpacknow raisesTypeErrorwhen used with certain invalid types. Patch by Jelle Zijlstra.gh-118131: Add command-line interface for the
randommodule. Patch by Hugo van Kemenade.gh-118107: Fix
zipimportreading of ZIP64 files with file entries that are too big or offset too far.gh-102511: Fix
os.path.normpath()for UNC paths on Windows. Speed upos.path.splitroot()with a native implementation.gh-117535: Change the unknown filename of
warningsfromsysto<sys>to clarify that it’s not a real filename.gh-114053: Fix erroneous
NameErrorwhen callingtyping.get_type_hints()on a class that made use of PEP 695 type parameters in a module that hadfrom __future__ import annotationsat the top of the file. Patch by Alex Waygood.gh-116931: Add parameter fileobj check for
tarfile.TarFile.addfile()gh-117995: Don’t raise
DeprecationWarningwhen a sequence of parameters is used to bind indexed, nameless placeholders. See also gh-100668.gh-80361: Fix TypeError in
email.message.Message.get_payload()when the charset is RFC 2231 encoded.gh-86650: Fix IndexError when parse some emails with invalid Message-ID (including one-off addresses generated by Microsoft Outlook).
gh-117691: Improve the error messages emitted by
tarfiledeprecation warnings relating to PEP 706. If afilterargument is not provided toextract()orextractall, the deprecation warning now points to the line in the user’s code where the relevant function was called. Patch by Alex Waygood.gh-115874: Fixed a possible segfault during garbage collection of
_asyncio.FutureIterobjects. Patch by Savannah Ostrowski.gh-115060: Speed up
pathlib.Path.glob()by omitting an initialis_dir()call. As a result of this change,glob()can no longer raiseOSError.gh-77102:
sitemodule now parses.pthfile with UTF-8 first, and locale encoding ifUnicodeDecodeErrorhappened. It supported only locale encoding before.gh-76785: We’ve exposed the low-level
_interpretersmodule for the sake of the PyPI implementation of PEP 734. It was sometimes available as the_xxsubinterpretersmodule and was formerly used only for testing. For the most part, it should be considered an internal module, like_threadand_imp. See https://discuss.python.org/t/pep-734-multiple-interpreters-in-the-stdlib/41147/26.gh-115060: Speed up
pathlib.Path.glob()by not scanning directories for non-wildcard pattern segments.gh-117727: Speed up
pathlib.Path.iterdir()by usingos.scandir()internally.gh-117586: Speed up
pathlib.Path.walk()by working with strings internally.gh-117722: Change the new multi-separator support in
asyncio.StreamReader.readuntil()to only accept tuples of separators rather than arbitrary iterables.gh-117692: Fixes a bug when
doctest.DocTestFinderwas failing on wrappedbuiltin_function_or_method.gh-117348: Largely restored import time performance of configparser by avoiding dataclasses.
gh-117641: Speedup
os.path.commonpath()on Unix.gh-117663: Fix
_simple_enumto detect aliases when multiple arguments are present but only one is the member value.gh-117636: Speedup
os.path.join().gh-117618: Support
package.moduleasfilenameforbreakcommand ofpdbgh-102247: the status codes enum with constants in http.HTTPStatus are updated to include the names from RFC9110. This RFC includes some HTTP statuses previously only used for WEBDAV and assigns more generic names to them.
The old constants are preserved for backwards compatibility.
gh-117607: Speedup
os.path.relpath().gh-117586: Speed up
pathlib.Path.glob()by working with strings internally.gh-117225: Add colour to doctest output. Patch by Hugo van Kemenade.
gh-117566:
ipaddress.IPv6Address.is_loopback()will now returnTruefor IPv4-mapped loopback addresses, i.e. addresses in the::ffff:127.0.0.0/104address space.gh-117546: Fix issue where
os.path.realpath()stopped resolving symlinks after encountering a symlink loop on POSIX.gh-116720: Improved behavior of
asyncio.TaskGroupwhen an external cancellation collides with an internal cancellation. For example, when two task groups are nested and both experience an exception in a child task simultaneously, it was possible that the outer task group would misbehave, because its internal cancellation was swallowed by the inner task group.In the case where a task group is cancelled externally and also must raise an
ExceptionGroup, it will now call the parent task’scancel()method. This ensures that aasyncio.CancelledErrorwill be raised at the nextawait, so the cancellation is not lost.An added benefit of these changes is that task groups now preserve the cancellation count (
asyncio.Task.cancelling()).In order to handle some corner cases,
asyncio.Task.uncancel()may now reset the undocumented_must_cancelflag when the cancellation count reaches zero.gh-117516: Add
typing.TypeIs, implementing PEP 742. Patch by Jelle Zijlstra.gh-117503: Fix support of non-ASCII user names in bytes paths in
os.path.expanduser()on Posix.gh-117394:
os.path.ismount()is now 2-3 times faster if the user has permissions.gh-117313: Only treat
'\n','\r'and'\r\n'as line separators in re-folding theemailmessages. Preserve control characters'\v','\f','\x1c','\x1d'and'\x1e'and Unicode line separators'\x85','\u2028'and'\u2029'as is.gh-117142: Convert
_ctypesto multi-phase initialisation (PEP 489).gh-66543: Add the
mimetypes.guess_file_type()function which works with file path. Passing file path instead of URL inguess_type()is soft deprecated.gh-68583: webbrowser CLI: replace getopt with argparse, add long options. Patch by Hugo van Kemenade.
gh-116871: Name suggestions for
AttributeErrorandImportErrornow only include underscored names if the original name was underscored.gh-116023: Don’t show empty fields (value
Noneor[]) inast.dump()by default. Addshow_empty=Falseparameter to optionally show them.gh-115961: Added
nameandmodeattributes for compressed and archived file-like objects in modulesbz2,lzma,tarfileandzipfile. The value of themodeattribute ofgzip.GzipFilewas changed from integer (1or2) to string ('rb'or'wb'). The value of themodeattribute of the readable file-like object returned byzipfile.ZipFile.open()was changed from'r'to'rb'.gh-82062: Fix
inspect.signature()to correctly handle parameter defaults on methods in extension modules that use names defined in the module namespace.gh-83856: Honor
atexitfor allmultiprocessingstart methodsgh-113081: Print colorized exception just like built-in traceback in
pdbgh-112855: Speed up pickling of
pathlib.PurePathobjects. Patch by Barney Gale.gh-109617:
ncurses: fixed a crash that could occur on macOS 13 or earlier when Python was built with Apple Xcode 15’s SDK.gh-83151: Enabled arbitrary statements and evaluations in
pdbshell to access the local variables of the current frame, which made it possible for multi-scope code like generators or nested function to work.gh-110209: Add
__class_getitem__()totypes.GeneratorTypeandtypes.CoroutineTypefor type hinting purposes. Patch by James Hilton-Balfe.gh-108191: The
types.SimpleNamespacenow accepts an optional positional argument which specifies initial values of attributes as a dict or an iterable of key-value pairs.gh-62090: Fix assertion errors caused by whitespace in metavars or
SUPPRESS-ed groups inargparseby simplifying usage formatting. Patch by Ali Hamdan.gh-102402: Adjust
logging.LogRecordto usetime.time_ns()and fix minor bug related to floating-point math.gh-100242: Bring pure Python implementation
functools.partial.__new__more in line with the C-implementation by not just always checking for the presence of the attribute'func'on the first argument ofpartial. Instead, both the Python version and the C version perform anisinstance(func, partial)check on the first argument ofpartial.gh-99730: HEAD requests are no longer upgraded to GET request during redirects in urllib.
gh-66410: Setting the
tkintermodule globalwantobjectsto2before creating theTkobject or call thewantobjects()method of theTkobject with argument2makes now arguments to callbacks registered in thetkintermodule to be passed as various Python objects (int,float,bytes,tuple), depending on their internal representation in Tcl, instead of alwaysstr.tkinter.wantobjectsis now set to2by default.bpo-40943: Fix several IndexError when parse emails with truncated Message-ID, address, routes, etc, e.g.
example@.bpo-39324: Add mime type mapping for .md <-> text/markdown
bpo-18108:
shutil.chown()now supports dir_fd and follow_symlinks keyword arguments.bpo-30988: Fix parsing of emails with invalid address headers having a leading or trailing dot. Patch by tsufeki.
bpo-32839: Add the
after_info()method for Tkinter widgets.
Documentation¶
gh-117928: The minimum Sphinx version required for the documentation is now 6.2.1.
Build¶
gh-118734: Fixes Windows build when invoked directly (not through the
build.batscript) without specifying a value forUseTIER2.gh-115119: The
configureoption--with-system-libmpdecnow defaults toyes. The bundled copy oflibmpdecimalwill be removed in Python 3.15.gh-117845: Fix building against recent libedit versions by detecting readline hook signatures in configure.
gh-116622: A testbed project was added to run the test suite on Android.
gh-117645: Increase WASI stack size from 512 KiB to 8 MiB and the initial memory from 10 MiB to 20 MiB. Patch by Victor Stinner.
gh-115119: configure now uses pkg-config to detect
decimaldependencies if the--with-system-libmpdecoption is given.
Windows¶
gh-115119: Update Windows installer to use libmpdecimal 4.0.0.
gh-118486:
os.mkdir()now accepts mode of0o700to restrict the new directory to the current user.gh-118347: Fixes launcher updates not being installed.
gh-118293: The
multiprocessingmodule now passes theSTARTF_FORCEOFFFEEDBACKflag when spawning processes to tell Windows not to change the mouse cursor.gh-115009: Update Windows installer to use SQLite 3.45.3.
gh-90329: Suppress the warning displayed on virtual environment creation when the requested and created paths differ only by a short (8.3 style) name. Warnings will continue to be shown if a junction or symlink in the path caused the venv to be created in a different location than originally requested.
gh-117786: Fixes virtual environments not correctly launching when created from a Store install.
macOS¶
gh-115119: Update macOS installer to use libmpdecimal 4.0.0.
gh-114099: iOS preprocessor symbol usage was made compatible with older macOS SDKs.
gh-115009: Update macOS installer to use SQLite 3.45.3.
gh-91629: Use
~/.config/fish/conf.dconfigs and fish_add_path to setPATHwhen installing for the Fish shell.
IDLE¶
bpo-34774: Use user-selected color theme for Help => IDLE Doc.
C API¶
gh-118124: Fix
Py_BUILD_ASSERTandPy_BUILD_ASSERT_EXPRfor non-constant expressions: usestatic_assert()on C11 and newer. Patch by Victor Stinner.gh-110850: Add “Raw” variant of PyTime functions
Patch by Victor Stinner.
gh-117987: Restore functions removed in Python 3.13 alpha 1:
Patch by Victor Stinner.
gh-117929: Restore removed
PyEval_InitThreads()function. Patch by Victor Stinner.gh-117534: Improve validation logic in the C implementation of
datetime.datetime.fromisoformat()to better handle invalid years. Patch by Vlad Efanov.gh-68114: Fixed skipitem()’s handling of the old ‘w’ and ‘w#’ formatters. These are no longer supported and now raise an exception if used.
gh-111997: Add a C-API for firing monitoring events.
Python 3.13.0 alpha 6¶
Release date: 2024-04-09
Core and Builtins¶
gh-117494: Refactored the instruction sequence data structure out of compile.c into instruction_sequence.c.
gh-116968: Introduce a unified 16-bit backoff counter type (
_Py_BackoffCounter), shared between the Tier 1 adaptive specializer and the Tier 2 optimizer. The API used for adaptive specialization counters is changed but the behavior is (supposed to be) identical.The behavior of the Tier 2 counters is changed:
There are no longer dynamic thresholds (we never varied these).
All counters now use the same exponential backoff.
The counter for
JUMP_BACKWARDstarts counting down from 16.The
temperaturein side exits starts counting down from 64.
gh-117431: Improve the performance of the following
bytesandbytearraymethods by adapting them to theMETH_FASTCALLcalling convention:endswith()startswith()
gh-117431: Improve the performance of the following
strmethods by adapting them to theMETH_FASTCALLcalling convention:gh-117411: Move
PyFutureFeaturesto an internal header and make it private.gh-109120: Added handle of incorrect star expressions, e.g
f(3, *). Patch by Grigoryev Semyongh-117266: Fix crashes for certain user-created subclasses of
ast.AST. Such classes are now expected to set the_field_typesattribute.gh-99108: Updated the
hashlibbuilt-in HACL* project C code from upstream that we use for many implementations when they are not present via OpenSSL in a given build. This also avoids the rare potential for a C symbol name one definition rule linking issue.gh-117108: Change the old space bit of objects in the young generation from 0 to gcstate->visited, so that any objects created during GC will have the old bit set correctly if they get moved into the old generation.
gh-117108: The cycle GC now chooses the size of increments based on the total heap size, instead of the rate of object creation. This ensures that it can keep up with growing heaps.
gh-116735: For
INSTRUMENTED_CALL_FUNCTION_EX, setarg0tosys.monitoring.MISSINGinstead ofNoneforCALLevent.gh-113964: Starting new threads and process creation through
os.fork()are now only prevented once all non-daemon threads exit.gh-116626: Ensure
INSTRUMENTED_CALL_FUNCTION_EXalways emitsCALLgh-116554:
list.sort()now exploits more cases of partial ordering, particularly those with long descending runs with sub-runs of equal values. Those are recognized as single runs now (previously, each block of repeated values caused a new run to be created).gh-114099: Added a Loader that can discover extension modules in an iOS-style Frameworks folder.
gh-115775: Compiler populates the new
__static_attributes__field on a class with the names of attributes of this class which are accessed through self.X from any function in its body.gh-115776: The array of values, the
PyDictValuesstruct is now embedded in the object during allocation. This provides better performance in the common case, and does not degrade as much when the object’s__dict__is materialized.gh-108362: Implement an incremental cyclic garbage collector. By collecting the old generation in increments, there is no need for a full heap scan. This can hugely reduce maximum pause time for programs with large heaps.
Reduce the number of generations from three to two. The old generation is split into two spaces, “visited” and “pending”.
Collection happens in two steps:: * An increment is formed from the young generation and a small part of the pending space. * This increment is scanned and the survivors moved to the end of the visited space.
When the collecting space becomes empty, the two spaces are swapped.
gh-109870: Dataclasses now calls
exec()once per dataclass, instead of once per method being added. This can speed up dataclass creation by up to 20%.bpo-24612: Improve the
SyntaxErrorthat happens when ‘not’ appears after an operator. Patch by Pablo Galindo
Library¶
gh-117648: Improve performance of
os.path.join()andos.path.expanduser().gh-117584: Raise
TypeErrorfor non-paths inposixpath.relpath().gh-117467: Preserve mailbox ownership when rewriting in
mailbox.mbox.flush(). Patch by Tony Mountifield.gh-114848: Raise
FileNotFoundErrorwhengetcwd()returns ‘(unreachable)’, which can happen on Linux >= 2.6.36 with glibc < 2.27.gh-117459:
asyncio.asyncio.run_coroutine_threadsafe()now keeps the traceback ofCancelledError,TimeoutErrorandInvalidStateErrorwhich are raised in the coroutine.gh-117381: Fix error message for
ntpath.commonpath().gh-117337: Deprecate undocumented
glob.glob0()andglob.glob1()functions. Useglob.glob()and pass a directory to its root_dir argument instead.gh-117348: Refactored
configparser.RawConfigParser._read()to reduce cyclometric complexity and improve comprehensibility.gh-117335: Raise TypeError for non-sequences for
ntpath.commonpath().gh-66449:
configparser.ConfigParsernow accepts unnamed sections before named ones, if configured to do so.gh-88014: In documentation of
gzip.GzipFilein module gzip, explain data type of optional constructor argument mtime, and recommendmtime = 0for generating deterministic streams.gh-117310: Fixed an unlikely early & extra
Py_DECREFtriggered crash insslwhen creating a new_ssl._SSLContextif CPython was built implausibly such that the default cipher list is empty or the SSL library it was linked against reports a failure from its CSSL_CTX_set_cipher_list()API.gh-117294: A
DocTestCasenow reports as skipped if all examples in the doctest are skipped.gh-98966: In
subprocess, raise a more informative message whenstdout=STDOUT.gh-117225: doctest: only print “and X failed” when non-zero, don’t pluralise “1 items”. Patch by Hugo van Kemenade.
gh-117205: Speed up
compileall.compile_dir()by 20% when using multiprocessing by increasingchunksize.gh-117178: Fix regression in lazy loading of self-referential modules, introduced in gh-114781.
gh-112383: Fix
dismodule’s handling ofENTER_EXECUTORinstructions.gh-117182: Lazy-loading of modules that modify their own
__class__no longer reverts the__class__totypes.ModuleType.gh-117084: Fix
zipfileextraction for directory entries with the name containing backslashes on Windows.gh-117114: Make
os.path.isdevdrive()available on all platforms. For those that do not offer Dev Drives, it will always returnFalse.gh-117110: Fix a bug that prevents subclasses of
typing.Anyto be instantiated with arguments. Patch by Chris Fu.gh-109653: Deferred select imports in importlib.metadata and importlib.resources for a 14% speedup.
gh-70647: Start the deprecation period for the current behavior of
datetime.datetime.strptime()andtime.strptime()which always fails to parse a date string with aValueErrorinvolving a day of month such asstrptime("02-29", "%m-%d")when a year is not specified and the date happen to be February 29th. This should help avoid users finding new bugs every four years due to a natural mistaken assumption about the API when parsing partial date values.gh-116987: Fixed
inspect.findsource()for class code objects.gh-114099: Modify standard library to allow for iOS platform differences.
gh-90872: On Windows,
subprocess.Popen.wait()no longer callsWaitForSingleObject()with a negative timeout: pass0ms if the timeout is negative. Patch by Victor Stinner.gh-116957: configparser: Don’t leave ConfigParser values in an invalid state (stored as a list instead of a str) after an earlier read raised DuplicateSectionError or DuplicateOptionError.
gh-115538:
_io.WindowsConsoleIOnow emit a warning if a boolean value is passed as a filedescriptor argument.gh-90095: Ignore empty lines and comments in
.pdbrcgh-106531: Refreshed zipfile._path from zipp 3.18, providing better compatibility for PyPy, better glob performance for deeply nested zipfiles, and providing internal access to
CompleteDirs.injectfor use in other tests (like importlib.resources).gh-63207: On Windows,
time.time()now uses theGetSystemTimePreciseAsFileTime()clock to have a resolution better than 1 us, instead of theGetSystemTimeAsFileTime()clock which has a resolution of 15.6 ms. Patch by Victor Stinner.gh-116764: Restore support of
Noneand other false values inurllib.parsefunctionsparse_qs()andparse_qsl(). Also, they now raise a TypeError for non-zero integers and non-empty sequences.gh-116811: In
PathFinder.invalidate_caches, delegate toMetadataPathFinder.invalidate_caches.gh-116647: Fix recursive child in dataclasses
gh-113171: Fixed various false positives and false negatives in
ipaddress.IPv4Address.is_private(see these docs for details)
Also in the corresponding
ipaddress.IPv4Networkandipaddress.IPv6Networkattributes.gh-63283: In
encodings.idna, any capitalization of the ACE prefix (xn--) is now acceptable. Patch by Pepijn de Vos and Zackery Spytz.gh-71042: Add
platform.android_ver(), which provides device and OS information on Android.gh-73468: Added new
math.fma()function, wrapping C99’sfma()operation: fused multiply-add function. Patch by Mark Dickinson and Victor Stinner.gh-116608: The
importlib.resourcesfunctionsis_resource(),open_binary(),open_text(),path(),read_binary(), andread_text()are un-deprecated, and support subdirectories via multiple positional arguments. Thecontents()function also allows subdirectories, but remains deprecated.gh-116484: Change automatically generated
tkinter.Checkbuttonwidget names to avoid collisions with automatically generatedtkinter.ttk.Checkbuttonwidget names within the same parent widget.gh-114314: In
ctypes, ctype data is now stored in type objects directly rather than in a dict subclass. This is an internal change that should not affect usage.gh-116401: Fix blocking
os.fwalk()andshutil.rmtree()on opening named pipe.gh-71052: Implement
ctypes.util.find_library()on Android.gh-90535: Fix support of interval values > 1 in
logging.TimedRotatingFileHandlerforwhen='MIDNIGHT'andwhen='Wx'.gh-113308: Remove some internal protected parts from
uuid:_has_uuid_generate_time_safe,_netbios_getnode,_ipconfig_getnode, and_load_system_functions. They were unused.gh-115627: Fix the
sslmodule error handling of connection terminate by peer. It now throws an OSError with the appropriate error code instead of an EOFError.gh-114847: Speed up
os.path.realpath()on non-Windows platforms.gh-114271: Fix a race in
threading.Thread.join().threading._MainThreadnow always represents the main thread of the main interpreter.PyThreadState.on_deleteandPyThreadState.on_delete_datahave been removed.gh-113538: Add
asyncio.Server.close_clients()andasyncio.Server.abort_clients()methods which allow to more forcefully close an asyncio server.gh-85287: Changes Unicode codecs to return UnicodeEncodeError or UnicodeDecodeError, rather than just UnicodeError.
gh-105866: Fixed
_get_slotsbug which caused error when defining dataclasses with slots and a weakref_slot.gh-96471: Add
asyncio.Queuetermination withshutdown()method.bpo-33533:
asyncio.as_completed()now returns an object that is both an asynchronous iterator and plain iterator. The new asynchronous iteration pattern allows for easier correlation between prior tasks and their completed results. This is a closer match toconcurrent.futures.as_completed()’s iteration pattern. Patch by Justin Arthur.bpo-27578:
inspect.getsource()(and related functions) work with empty module files, returning'\n'(or reasonable equivalent) instead of raisingOSError. Patch by Kernc.bpo-37141: Accept an iterable of separators in
asyncio.StreamReader.readuntil(), stopping when one of them is encountered.gh-66543: Make
mimetypes.guess_type()properly parsing of URLs with only a host name, URLs containing fragment or query, and filenames with only a UNC sharepoint on Windows. Based on patch by Dong-hee Na.bpo-15010:
unittest.TestLoader.discover()now saves the original value ofunittest.TestLoader._top_level_dirand restores it at the end of the call.
Documentation¶
Tests¶
gh-83434: Disable JUnit XML output (
--junit-xml=FILEcommand line option) in regrtest when hunting for reference leaks (-Roption). Patch by Victor Stinner.gh-117187: Fix XML tests for vanilla Expat <2.6.0.
gh-116333: Tests of TLS related things (error codes, etc) were updated to be more lenient about specific error message strings and behaviors as seen in the BoringSSL and AWS-LC forks of OpenSSL.
gh-117089: Consolidated tests for importlib.metadata in their own
metadatapackage.gh-115979: Update test_importlib so that it passes under WASI SDK 21.
gh-112536: Add –tsan to test.regrtest for running TSAN tests in reasonable execution times. Patch by Donghee Na.
gh-116307: Added import helper
isolated_modulesasCleanImportdoes not remove modules imported during the context. Use it in importlib.resources tests to avoid leavingmodaround to impede importlib.metadata tests.
Build¶
Windows¶
gh-117267: Ensure
DirEntry.stat().st_ctimebehaves consistently withos.stat()during the deprecation period ofst_ctimeby containing the same value asst_birthtime. After the deprecation period,st_ctimewill be the metadata change time (or unavailable throughDirEntry), and onlyst_birthtimewill contain the creation time.gh-116195: Improves performance of
os.getppid()by using an alternate system API when available. Contributed by vxiiduu.gh-88494: On Windows,
time.monotonic()now uses theQueryPerformanceCounter()clock to have a resolution better than 1 us, instead of theGetTickCount64()clock which has a resolution of 15.6 ms. Patch by Victor Stinner.gh-116773: Fix instances of
<_overlapped.Overlapped object at 0xXXX> still has pending operation at deallocation, the process may crash.gh-91227: Fix the asyncio ProactorEventLoop implementation so that sending a datagram to an address that is not listening does not prevent receiving any more datagrams.
gh-115119: Switched from vendored
libmpdecimalcode to a separately-hosted external package in thecpython-source-depsrepository when building the_decimalmodule.
C API¶
gh-87193:
_PyBytes_Resize()can now be called for bytes objects with reference count > 1, including 1-byte bytes objects. It creates a new bytes object and destroys the old one if it has reference count > 1.gh-117021: Fix integer overflow in
PyLong_AsPid()on non-Windows 64-bit platforms.gh-115756:
PyCode_GetFirstFree()is an ustable API now and has been renamed toPyUnstable_Code_GetFirstFree(). (Contributed by Bogdan Romanyuk in gh-115781)gh-116869: Add
test_cexttest: build a C extension to check if the Python C API emits C compiler warnings. Patch by Victor Stinner.gh-116869: Make the C API compatible with
-Werror=declaration-after-statementcompiler flag again. Patch by Victor Stinner.gh-116936: Add
PyType_GetModuleByDef()to the limited C API. Patch by Victor Stinner.gh-116809: Restore removed private
_PyErr_ChainExceptions1()function. Patch by Victor Stinner.gh-115754: In the limited C API version 3.13, getting
Py_None,Py_False,Py_True,Py_EllipsisandPy_NotImplementedsingletons is now implemented as function calls at the stable ABI level to hide implementation details. Getting these constants still return borrowed references. Patch by Victor Stinner.gh-115754: Add
Py_GetConstant()andPy_GetConstantBorrowed()functions to get constants. For example,Py_GetConstant(Py_CONSTANT_ZERO)returns a strong reference to the constant zero. Patch by Victor Stinner.gh-111696: Add support for
%T,%T#,%Nand%N#formats toPyUnicode_FromFormat(): format the fully qualified name of an object type and of a type: callPyType_GetModuleName(). See PEP 737 for more information. Patch by Victor Stinner.gh-111696: Add
PyType_GetModuleName()function to get the type’s module name. Equivalent to getting thetype.__module__attribute. Patch by Eric Snow and Victor Stinner.gh-111696: Add
PyType_GetFullyQualifiedName()function to get the type’s fully qualified name. Equivalent tof"{type.__module__}.{type.__qualname__}", ortype.__qualname__iftype.__module__is not a string or is equal to"builtins". Patch by Victor Stinner.gh-85283: The
fcntl,grp,pwd,termios,_statisticsand_testconsoleC extensions are now built with the limited C API. Patch by Victor Stinner.gh-111140: Add additional flags to
PyLong_AsNativeBytes()andPyLong_FromNativeBytes()to allow the caller to determine how to handle edge cases around values that fill the entire buffer.gh-113024: Add
PyObject_GenericHash()function.
Python 3.13.0 alpha 5¶
Release date: 2024-03-12
Security¶
gh-115398: Allow controlling Expat >=2.6.0 reparse deferral (CVE 2023-52425) by adding five new methods:
gh-114572:
ssl.SSLContext.cert_store_stats()andssl.SSLContext.get_ca_certs()now correctly lock access to the certificate store, when thessl.SSLContextis shared across multiple threads.
Core and Builtins¶
gh-116604: Respect the status of the garbage collector when indirect calls are made via
PyErr_CheckSignals()and the evaluation breaker. Patch by Pablo Galindogh-112087:
listis now compatible with the implementation of PEP 703.gh-116381: Add specialization for
CONTAINS_OP.gh-116296: Fix possible refleak in
object.__reduce__()internal error handling.gh-115823: Properly calculate error ranges in the parser when raising
SyntaxErrorexceptions caused by invalid byte sequences. Patch by Pablo Galindogh-115778: Add
tierNannotation for instruction definition in interpreter DSL.gh-115733: Fix crash when calling
next()on exhausted list iterators.gh-115700: The regen-cases build stage now works on Windows.
gh-115347: Fix bug where docstring was replaced by a redundant NOP when Python is run with
-OO.gh-115323: Make error message more meaningful for when
bytearray.extend()is called with astrobject.gh-112175: Every
PyThreadStatenow has its owneval_breaker, allowing specific threads to be interrupted.gh-115154: Fix a bug that was causing the
tokenize.untokenize()function to handle unicode named literals incorrectly. Patch by Pablo Galindogh-112433: Add ability to force alignment of
ctypes.Structureby way of the new_align_attribute on the class.gh-104090: The multiprocessing resource tracker now exits with non-zero status code if a resource leak was detected. It still exits with status code 0 otherwise.
gh-105858: Improve the constructors for
astnodes. Arguments of list types now default to an empty list if omitted, and optional fields default toNone. AST nodes now have an__annotations__attribute with the expected types of their attributes. Passing unrecognized extra arguments to AST nodes is deprecated and will become an error in Python 3.15. Omitting a required argument to an AST node is deprecated and will become an error in Python 3.15. Patch by Jelle Zijlstra.gh-101860: Expose
__name__attribute on property.gh-96497: Fix incorrect resolution of mangled class variables used in assignment expressions in comprehensions.
Library¶
gh-116349:
platform.java_ver()is deprecated and will be removed in 3.15. It was largely untested, had a confusing API, and was only useful for Jython support.gh-116143: Fix a race in pydoc
_start_server, eliminating a window in which_start_servercan return a thread that is “serving” but without adocserverset.gh-116127:
typing: implement PEP 705 which addstyping.ReadOnlysupport totyping.TypedDict.gh-116325:
typing: raiseSyntaxErrorinstead ofAttributeErroron forward references as empty strings.gh-115957: When
asyncio.TaskGroup.create_taskis called on an inactiveasyncio.TaskGroup, the given coroutine will be closed (which prevents aRuntimeWarning).gh-115978: Disable preadv(), readv(), pwritev(), and writev() on WASI.
Under wasmtime for WASI 0.2, these functions don’t pass test_posix (https://github.com/bytecodealliance/wasmtime/issues/7830).
gh-88352: Fix the computation of the next rollover time in the
logging.TimedRotatingFileHandlerhandler.computeRollover()now always returns a timestamp larger than the specified time and works correctly during the DST change.doRollover()no longer overwrite the already rolled over file, saving from data loss when run at midnight or during repeated time at the DST change.gh-87115: Set
__main__.__spec__toNonewhen running a script withpdbgh-76511: Fix UnicodeEncodeError in
email.Message.as_string()that results when a message that claims to be in the ascii character set actually has non-ascii characters. Non-ascii characters are now replaced with the U+FFFD replacement character, like in thereplaceerror handler.gh-89547: Add support for nested typing special forms like Final[ClassVar[int]].
gh-116040: [Enum] fix by-value calls when second value is falsey; e.g. Cardinal(1, 0)
gh-115821: [Enum] Improve error message when calling super().__new__() in custom __new__.
gh-85644: Use the
XDG_CURRENT_DESKTOPenvironment variable inwebbrowserto check desktop. Prefer it to the deprecatedGNOME_DESKTOP_SESSION_IDfor GNOME detection.gh-75988: Fixed
unittest.mock.create_autospec()to pass the call through to the wrapped object to return the real result.gh-115881: Fix issue where
ast.parse()would incorrectly flag conditional context managers (such aswith (x() if y else z()): ...) as invalid syntax iffeature_version=(3, 8)was passed. This reverts changes to the grammar made as part of gh-94949.gh-115886: Fix silent truncation of the name with an embedded null character in
multiprocessing.shared_memory.SharedMemory.gh-115532: Add kernel density estimation to the statistics module.
gh-115714: On WASI, the
timemodule no longer get process time usingtimes()orCLOCK_PROCESS_CPUTIME_ID, system API is that is unreliable and is likely to be removed from WASI. The affected clock functions fall back to callingclock().gh-115809: Improve algorithm for computing which rolled-over log files to delete in
logging.TimedRotatingFileHandler. It is now reliable for handlers withoutnamerand with arbitrary deterministicnamerthat leaves the datetime part in the file name unmodified.gh-74668:
urllib.parsefunctionsparse_qs()andparse_qsl()now support bytes arguments containing raw and percent-encoded non-ASCII data.gh-67044:
csv.writer()now always quotes or escapes'\r'and'\n', regardless of lineterminator value.gh-115712: Restore support of space delimiter with
skipinitialspace=Trueincsv.csv.writer()now quotes empty fields if delimiter is a space and skipinitialspace is true and raises exception if quoting is not possible.gh-112364: Fixed
ast.unparse()to handle format_spec with",'or\\. Patched by Frank Hoffmann.gh-112997: Stop logging potentially sensitive callback arguments in
asynciounless debug mode is active.gh-114914: Fix an issue where an abandoned
StreamWriterwould not be garbage collected.gh-111358: Fix a bug in
asyncio.BaseEventLoop.shutdown_default_executor()to ensure the timeout passed to the coroutine behaves as expected.gh-115618: Fix improper decreasing the reference count for
Noneargument inpropertymethodsgetter(),setter()anddeleter().gh-112720: Refactor
dis.ArgResolverto make it possible to subclass and change the way jump args are interpreted.gh-112006: Fix
inspect.unwrap()for types with the__wrapper__data descriptor. Fixinspect.Signature.from_callable()for builtinsclassmethod()andstaticmethod().gh-101293: Support callables with the
__call__()method and types with__new__()and__init__()methods set to class methods, static methods, bound methods, partial functions, and other types of methods and descriptors ininspect.Signature.from_callable().gh-113942:
pydocno longer skips global functions implemented as builtin methods, such asMethodDescriptorTypeandWrapperDescriptorType.gh-115256: Added DeprecationWarning when accessing the tarfile attribute of TarInfo objects. The attribute is never used internally and is only attached to TarInfos when the tarfile is opened in write-mode, not read-mode. The attribute creates an unnecessary reference cycle which may cause corruption when not closing the handle after writing a tarfile.
gh-115197:
urllib.requestno longer resolves the hostname before checking it against the system’s proxy bypass list on macOS and Windows.gh-113812:
DatagramTransport.sendto()will now send zero-length datagrams if called with an empty bytes object. The transport flow control also now accounts for the datagram header when calculating the buffer size.gh-114763: Protect modules loaded with
importlib.util.LazyLoaderfrom race conditions when multiple threads try to access attributes before the loading is complete.gh-114709:
posixpath.commonpath()now raises aValueErrorexception when passed an empty iterable. Previously,IndexErrorwas raised.posixpath.commonpath()now raises aTypeErrorexception when passedNone. Previously,ValueErrorwas raised.gh-114610: Fix bug where
pathlib.PurePath.with_stem()converted a non-empty path suffix to a stem when given an empty stem argument. It now raisesValueError, just likepathlib.PurePath.with_suffix()does when called on a path with an empty stem, given a non-empty suffix argument.gh-107361: Add
ssl.VERIFY_X509_PARTIAL_CHAINandVERIFY_X509_STRICTto the default SSL context created withssl.create_default_context().gh-112281: Allow creating union of types for
typing.Annotatedwith unhashable metadata.gh-111775: Fix
importlib.resources.simple.ResourceHandle.open()for text mode, added missedstreamargument.gh-90095: Make .pdbrc and -c work with any valid pdb commands.
gh-107625: Raise
configparser.ParsingErrorfromread()andread_file()methods ofconfigparser.ConfigParserif a key without a corresponding value is continued (that is, followed by an indented line).gh-107155: Fix incorrect output of
help(x)wherexis alambdafunction, which has an__annotations__dictionary attribute with a"return"key.gh-57141: Add option for non-shallow comparisons to
filecmp.dircmplikefilecmp.cmp(). Original patch by Steven Ward. Enhanced by Tobias Rautenkranzgh-69990:
Profile.print_stats()has been improved to accept multiple sort arguments. Patched by Chiu-Hsiang Hsu and Furkan Onder.gh-104061: Add
socket.SO_BINDTOIFINDEXconstant.gh-60346: Fix ArgumentParser inconsistent with parse_known_args.
gh-102389: Add
windows_31jto aliases forcp932codecgh-72249:
functools.partial`s of :func:`repr()has been improved to include the module name. Patched by Furkan Onder and Anilyka Barry.gh-100985: Update HTTPSConnection to consistently wrap IPv6 Addresses when using a proxy.
gh-100884: email: fix misfolding of comma in address-lists over multiple lines in combination with unicode encoding.
gh-95782: Fix
io.BufferedReader.tell(),io.BufferedReader.seek(),_pyio.BufferedReader.tell(),io.BufferedRandom.tell(),io.BufferedRandom.seek()and_pyio.BufferedRandom.tell()being able to return negative offsets.gh-96310: Fix a traceback in
argparsewhen all options in a mutually exclusive group are suppressed.gh-93205: Fixed a bug in
logging.handlers.TimedRotatingFileHandlerwhere multiple rotating handler instances pointing to files with the same name but different extensions would conflict and not delete the correct files.bpo-31116: Add Z85 encoding to
base64.bpo-44865: Add missing call to localization function in
argparse.bpo-43952: Fix
multiprocessing.connection.Listener.accept()to accept empty bytes as authkey. Not accepting empty bytes as key causes it to hang indefinitely.bpo-42125: linecache: get module name from
__spec__if available. This allows getting source code for the__main__module when a custom loader is used.bpo-41122: Failing to pass arguments properly to
functools.singledispatchmethod()now throws a TypeError instead of hitting an index out of bounds internally.bpo-40818: The asyncio REPL now runs
sys.__interactivehook__on startup. The default implementation ofsys.__interactivehook__provides auto-completion to the asyncio REPL. Patch contributed by Rémi Lapeyre.bpo-33775: Add ‘default’ and ‘version’ help text for localization in argparse.
Documentation¶
gh-115399: Document CVE 2023-52425 of Expat <2.6.0 under “XML vulnerabilities”.
Tests¶
gh-71052: Add test exclusions to support running the test suite on Android.
gh-71052: Enable
test_concurrent_futureson platforms that support threading but not multiprocessing.gh-115796: Make ‘_testinternalcapi.assemble_code_object’ construct the exception table for the code object.
gh-115720: Leak tests (
-R,--huntrleaks) now show a summary of the number of leaks found in each iteration.gh-115122: Add
--bisectoption to regrtest test runner: run failed tests withtest.bisect_cmdto identify failing tests. Patch by Victor Stinner.gh-115596: Fix
ProgramPriorityTestsintest_ospermanently changing the process priority.gh-115556: On Windows, commas passed in arguments to
Tools\buildbot\test.batandPCbuild\\rt.batare now properly handled.gh-115420: Fix translation of exception handler targets by
_testinternalcapi.optimize_cfg.gh-115376: Fix segfault in
_testinternalcapi.compiler_codegenon bad input.
Build¶
gh-116313: Get WASI builds to work under wasmtime 18 w/ WASI 0.2/preview2 primitives.
gh-71052: Change Android’s
sys.platformfrom"linux"to"android".gh-116117: Backport
libb2’s PR #42 to fix compiling CPython on 32-bit Windows withclang-cl.gh-71052: Fix several Android build issues
gh-114099: A testbed project was added to run the test suite on iOS.
gh-115350: Fix building ctypes module with -DWIN32_LEAN_AND_MEAN defined
gh-111225: Link extension modules against libpython on Android.
gh-115737: The install name for libPython is now correctly set for non-framework macOS builds.
gh-114099: Makefile targets were added to support compiling an iOS-compatible framework build.
Windows¶
gh-116012: Ensure the value of
GetLastError()is preserved across GIL operations.gh-115582: Building extensions intended for free-threaded builds of CPython now require compiling with
/DPy_GIL_DISABLEDmanually when using a regular install. This is expected to change in future releases.gh-115554: The installer now has more strict rules about updating the Python Launcher for Windows. In general, most users only have a single launcher installed and will see no difference. When multiple launchers have been installed, the option to install the launcher is disabled until all but one have been removed. Downgrading the launcher (which was never allowed) is now more obviously blocked.
gh-115543: Python Launcher for Windows can now detect Python 3.13 when installed from the Microsoft Store, and will install Python 3.12 by default when
PYLAUNCHER_ALLOW_INSTALLis set.
macOS¶
gh-116145: Update macOS installer to Tcl/Tk 8.6.14.
IDLE¶
gh-88516: On macOS show a proxy icon in the title bar of editor windows to match platform behaviour.
Tools/Demos¶
C API¶
gh-114626: Add again
_PyCFunctionFastWithKeywordsname, removed in Python 3.13 alpha 4 by mistake. Keep the old private_PyCFunctionFastWithKeywordsname (Python 3.7) as an alias to the new public namePyCFunctionFastWithKeywords(Python 3.13a4). Patch by Victor Stinner.gh-111418: Add
PyHASH_MODULUS,PyHASH_BITS,PyHASH_INFandPyHASH_IMAGC macros. Patch by Sergey B Kirpichev.
Python 3.13.0 alpha 4¶
Release date: 2024-02-15
Security¶
gh-115399: Update bundled libexpat to 2.6.0
gh-115243: Fix possible crashes in
collections.deque.index()when the deque is concurrently modified.
Core and Builtins¶
gh-112087: For an empty reverse iterator for list will be reduced to
reversed(). Patch by Donghee Nagh-114570: Add
PythonFinalizationErrorexception. This exception derived fromRuntimeErroris raised when an operation is blocked during the Python finalization. Patch by Victor Stinner.gh-114695: Add
sys._clear_internal_caches(), which clears all internal performance-related caches (and deprecate the less-generalsys._clear_type_cache()function).gh-114828: Fix compilation crashes in uncommon code examples using
super()inside a comprehension in a class body.gh-112069: Adapt
setandfrozensetmethods to Argument Clinic.gh-115011: Setters for members with an unsigned integer type now support the same range of valid values for objects that has a
__index__()method as forint.gh-114887: Changed socket type validation in
create_datagram_endpoint()to accept all non-stream sockets. This fixes a regression in compatibility with raw sockets.gh-114944: Fixes a race between
PyParkingLot_Parkand_PyParkingLot_UnparkAll.gh-113462: Limit the number of versions that a single class can use. Prevents a few wayward classes using up all the version numbers.
gh-76763: The
chr()builtin function now always raisesValueErrorfor values outside the valid range. Previously it raisedOverflowErrorfor very large or small values.gh-114806: No longer specialize calls to classes, if those classes have metaclasses. Fixes bug where the
__call__method of the metaclass was not being called.gh-107944: Improve error message for function calls with bad keyword arguments via getargs
gh-112529: The free-threaded build no longer allocates space for the
PyGC_Headstructure in objects that support cyclic garbage collection. A number of other fields and data structures are used as replacements, includingob_gc_bits,ob_tid, and mimalloc internal data structures.gh-114456: Lower the recursion limit under a debug build of WASI.
gh-114083: Compiler applies folding of LOAD_CONST with following instruction in a separate pass before other optimisations. This enables jump threading in certain circumstances.
gh-114388: Fix a
RuntimeWarningemitted when assign an integer-like value that is not an instance ofintto an attribute that corresponds to a C struct member of type T_UINT and T_ULONG. Fix a doubleRuntimeWarningemitted when assign a negative integer value to an attribute that corresponds to a C struct member of type T_UINT.gh-114265: Compiler propagates line numbers before optimization, leading to more optimization opportunities and removing the need for the
guarantee_lineno_for_exitshack.gh-112529: The free-threaded build now has its own thread-safe GC implementation that uses mimalloc to find GC tracked objects. It is non-generational, unlike the existing GC implementation.
gh-114050: Fix segmentation fault caused by an incorrect format string in
TypeErrorexception when more than two arguments are passed toint.gh-112354: The
END_FORinstruction now pops only one value. This is to better support side exits in loops.gh-113884: Make
queue.SimpleQueuethread safe when the GIL is disabled.gh-114058: Implement the foundations of the Tier 2 redundancy eliminator.
gh-113939: frame.clear(): Clear frame.f_locals as well, and not only the fast locals. This is relevant once frame.f_locals was accessed, which would contain also references to all the locals.
gh-112050: Convert
collections.dequeto use Argument Clinic.gh-112050: Make methods on
collections.dequethread-safe when the GIL is disabled.gh-113464: Add an option (
--enable-experimental-jitforconfigure-based builds or--experimental-jitforPCbuild-based ones) to build an experimental just-in-time compiler, based on copy-and-patchgh-113055: Make interp->obmalloc a pointer. For interpreters that share state with the main interpreter, this points to the same static memory structure. For interpreters with their own obmalloc state, it is heap allocated. Add free_obmalloc_arenas() which will free the obmalloc arenas and radix tree structures for interpreters with their own obmalloc state.
gh-55664: Add warning when creating
typeusing a namespace dictionary with non-string keys. Patched by Daniel Urban and Furkan Onder.gh-104530: Use native Win32 condition variables.
Library¶
gh-115392: Fix a bug in
doctestwhere incorrect line numbers would be reported for decorated functions.gh-114563: Fix several
format()bugs when using the C implementation ofDecimal: * memory leak in some rare cases when using thezformat option (coerce negative 0) * incorrect output when applying thezformat option to typeF(fixed-point with capitalNAN/INF) * incorrect output when applying the#format option (alternate form)gh-102840: Fix confused traceback when floordiv, mod, or divmod operations happens between instances of
fractions.Fractionandcomplex.gh-115165: Most exceptions are now ignored when attempting to set the
__orig_class__attribute on objects returned when callingtypinggeneric aliases (including generic aliases created usingtyping.Annotated). Previously onlyAttributeErrorwas ignored. Patch by Dave Shawley.gh-112903: Fix “issubclass() arg 1 must be a class” errors in certain cases of multiple inheritance with generic aliases (regression in early 3.13 alpha releases).
gh-115133: Fix tests for
XMLPullParserwith Expat 2.6.0.gh-115059:
io.BufferedRandom.read1()now flushes the underlying write buffer.gh-79382: Trailing
**no longer allows to match files and non-existing paths in recursiveglob().gh-67837: Avoid race conditions in the creation of directories during concurrent extraction in
tarfileandzipfile.gh-115060: Speed up
pathlib.Path.glob()by removing redundant regex matching.gh-97928: Partially revert the behavior of
tkinter.Text.count(). By default it preserves the behavior of older Python versions, except that settingwantobjectsto 0 no longer has effect. Add a new parameter return_ints: specifyingreturn_ints=TruemakesText.count()always returning the single count as an integer instead of a 1-tuple orNone.gh-114628: When csv.Error is raised when handling TypeError, do not print the TypeError traceback.
gh-85984: Added
_POSIX_VDISABLEfrom C’s<unistd.h>totermios.gh-114965: Update bundled pip to 24.0
gh-114959:
tarfileno longer ignores errors when trying to extract a directory on top of a file.gh-114894: Add
array.array.clear().gh-114071: Support tuple subclasses using auto() for enum member value.
gh-109475: Fix support of explicit option value “–” in
argparse(e.g.--option=--).gh-49766: Fix
date-datetimecomparison. Now the special comparison methods like__eq__and__lt__returnNotImplementedif one of comparands isdateand other isdatetimeinstead of ignoring the time part and the time zone or forcefully return “not equal” or raiseTypeError. It makes comparison ofdateanddatetimesubclasses more symmetric and allows to change the default behavior by overriding the special comparison methods in subclasses.gh-110190: Fix ctypes structs with array on Windows ARM64 platform by setting
MAX_STRUCT_SIZEto 32 in stgdict. Patch by Diego Russogh-114678: Ensure that deprecation warning for ‘N’ specifier in
Decimalformat is not raised for cases where ‘N’ appears in other places in the format specifier. Based on patch by Stefan Krah.gh-70303: Return both files and directories from
pathlib.Path.glob()if a pattern ends with “**”. Previously only directories were returned.gh-109653: Improve import time of
importlib.metadataandemail.utils.gh-113280: Fix a leak of open socket in rare cases when error occurred in
ssl.SSLSocketcreation.gh-77749:
email.policy.EmailPolicy.fold()now always encodes non-ASCII characters in headers ifutf8is false.gh-83383: Synchronization of the
dbm.dumbdatabase is now no-op if there was no modification since opening or last synchronization. The directory file for a newly created emptydbm.dumbdatabase is now created immediately after opening instead of deferring this until synchronizing or closing.gh-91602: Add filter keyword-only parameter to
sqlite3.Connection.iterdump()for filtering database objects to dump. Patch by Mariusz Felisiak.gh-112451: Prohibit subclassing pure-Python
datetime.timezone. This is consistent with C-extension implementation. Patch by Mariusz Felisiak.gh-69893: Add the
close()method for the iterator returned byxml.etree.ElementTree.iterparse().gh-109653: Reduce the import time of
threadingmodule by ~50%. Patch by Daniel Hollas.gh-114492: Make the result of
termios.tcgetattr()reproducible on Alpine Linux. Previously it could leave a random garbage in some fields.gh-114315: Make
threading.Locka real class, not a factory function. Add__new__to_thread.locktype.gh-100414: Add
dbm.sqlite3as a backend todbm, and make it the new defaultdbmbackend. Patch by Raymond Hettinger and Erlend E. Aasland.gh-113267: Revert changes in gh-106584 which made calls of
TestResultmethodsstartTest()andstopTest()unbalanced.gh-75128: Ignore an
OSErrorinasyncio.BaseEventLoop.create_server()when IPv6 is available but the interface cannot actually support it.gh-114423:
_DummyThreadentries inthreading._activeare now automatically removed when the related thread dies.gh-114257: Dismiss the
FileNotFounderror inctypes.util.find_library()and just returnNoneon Linux.gh-114321: Expose more platform specific constants in the
fcntlmodule on Linux, macOS, FreeBSD and NetBSD.gh-114328: The
tty.setcbreak()and newtty.cfmakecbreak()no longer clears the terminal input ICRLF flag. This fixes a regression introduced in 3.12 that no longer matched how OSes define cbreak mode in theirstty(1)manual pages.gh-114281: Remove type hints from
Lib/asyncio/staggered.py. The annotations in the typeshed project should be used instead.gh-101438: Avoid reference cycle in ElementTree.iterparse. The iterator returned by
ElementTree.iterparsemay hold on to a file descriptor. The reference cycle prevented prompt clean-up of the file descriptor if the returned iterator was not exhausted.gh-114198: The signature for the
__replace__method ondataclassesnow has the first argument namedself, rather thanobj.gh-104522:
OSErrorraised when run a subprocess now only has filename attribute set to cwd if the error was caused by a failed attempt to change the current directory.gh-114149: Enum: correctly handle tuple subclasses in custom
__new__.gh-83648: Support deprecation of options, positional arguments and subcommands in
argparse.gh-114087: Speed up
dataclasses.asdictup to 1.35x.gh-109534: Fix a reference leak in
asyncio.selector_events.BaseSelectorEventLoopwhen SSL handshakes fail. Patch contributed by Jamie Phan.gh-79634: Accept path-like objects as patterns in
pathlib.Path.glob()andrglob().gh-112202: Ensure that a
asyncio.Condition.notify()call does not get lost if the awakenedTaskis simultaneously cancelled or encounters any other error.gh-113951: Fix the behavior of
tag_unbind()methods oftkinter.Textandtkinter.Canvasclasses with three arguments. Previously,widget.tag_unbind(tag, sequence, funcid)destroyed the current binding for sequence, leaving sequence unbound, and deleted the funcid command. Now it removes only funcid from the binding for sequence, keeping other commands, and deletes the funcid command. It leaves sequence unbound only if funcid was the last bound command.gh-97959: Fix rendering class methods, bound methods, method and function aliases in
pydoc. Class methods no longer have “method of builtins.type instance” note. Corresponding notes are now added for class and unbound methods. Method and function aliases now have references to the module or the class where the origin was defined if it differs from the current. Bound methods are now listed in the static methods section. Methods of builtin classes are now supported as well as methods of Python classes.gh-113796: Add more validation checks in the
csv.Dialectconstructor.ValueErroris now raised if the same character is used in different roles.gh-113732: Fix support of
QUOTE_NOTNULLandQUOTE_STRINGSincsv.reader().gh-113225: Speed up
pathlib.Path.walk()by usingos.DirEntry.pathwhere possible.gh-89039: When replace() method is called on a subclass of datetime, date or time, properly call derived constructor. Previously, only the base class’s constructor was called.
Also, make sure to pass non-zero fold values when creating subclasses in various methods. Previously, fold was silently ignored.
gh-112919: Speed-up
datetime.datetime.replace(),datetime.date.replace()anddatetime.time.replace().gh-59013: Set breakpoint on the first executable line of the function, instead of the line of function definition when the user do
break funcusingpdbgh-112343: Improve handling of pdb convenience variables to avoid replacing string contents.
gh-112240: Add option to calendar module CLI to specify the weekday to start each week. Patch by Steven Ward.
gh-111741: Recognise
image/webpas a standard format in themimetypesmodule.gh-43457: Fix the
tkinterwidget methodwm_attributes(). It now accepts the attribute name without the minus prefix to get window attributes and allows to specify attributes and values to set as keyword arguments. Add new optional keyword argument return_python_dict: callingw.wm_attributes(return_python_dict=True)returns the attributes as a dict instead of a tuple. Callingw.wm_attributes()now returns a tuple instead of string if wantobjects was set to 0.gh-82626: Many functions now emit a warning if a boolean value is passed as a file descriptor argument.
gh-111051: Added check for file modification during debugging with
pdbgh-110345: Show the Tcl/Tk patchlevel (rather than version) in
tkinter._test().gh-38807: Fix race condition in
trace. Instead of checking if a directory exists and creating it, directly callos.makedirs()with the kwargexist_ok=True.gh-75705: Set unixfrom envelope in
mailbox.mboxandmailbox.MMDF.gh-106233: Fix stacklevel in
InvalidTZPathWarningduringzoneinfomodule import.gh-105102: Allow
ctypes.Unionto be nested inctypes.Structurewhen the system endianness is the opposite of the classes.gh-104282: Fix null pointer dereference in
lzma._decode_filter_properties()due to improper handling of BCJ filters with properties of zero length. Patch by Radislav Chugunov.gh-96471: Add
queue.Queuetermination withshutdown().gh-101599: Changed argparse flag options formatting to remove redundancy.
gh-85984: Add POSIX pseudo-terminal functions
os.posix_openpt(),os.grantpt(),os.unlockpt(), andos.ptsname().gh-102512: When
os.fork()is called from a foreign thread (aka_DummyThread), the type of the thread in a child process is changed to_MainThread. Also changed its name and daemonic status, it can be now joined.gh-88569: Add
os.path.isreserved(), which identifies reserved pathnames such as “NUL”, “AUX” and “CON”. This function is only available on Windows.Deprecate
pathlib.PurePath.is_reserved().bpo-38364: The
inspectfunctionsisgeneratorfunction,iscoroutinefunction,isasyncgenfunctionnow supportfunctools.partialmethodwrapped functions the same way they supportfunctools.partial.
Documentation¶
gh-115233: Fix an example for
LoggerAdapterin the Logging Cookbook.gh-114123: Move the
csvmodule docstring to thecsvmodule instead of reexporting it from the internal_csvmodule, and remove__doc__fromcsv.__all__.Move
csv.__version__to thecsvmodule instead of reexporting it from the internal_csvmodule, and remove__version__fromcsv.__all__.
Tests¶
Build¶
gh-115167: Avoid vendoring
vcruntime140_threads.dllwhen building with Visual Studio 2022 version 17.8.gh-113632: Promote WASI to a tier 2 platform and drop Emscripten from tier 3 in configure.ac.
gh-114099: configure and Makefile were refactored to accommodate framework builds on Apple platforms other than macOS.
gh-114875: Add
getgrent()as a prerequisite for building thegrpmodule.
Windows¶
gh-115049: Fixes
py.exelauncher failing when run as users without user profiles.gh-115009: Update Windows installer to use SQLite 3.45.1.
gh-109991: Update Windows build to use OpenSSL 3.0.13.
gh-111239: Update Windows builds to use zlib v1.3.1.
gh-100107: The
py.exelauncher will no longer attempt to run the Microsoft Store redirector when launching a script containing a/usr/bin/envshebanggh-112984: Adds free-threaded binaries to Windows installer as an optional component.
gh-89240: Allows
multiprocessingto create pools of greater than 62 processes.
macOS¶
gh-115009: Update macOS installer to use SQLite 3.45.1.
gh-109991: Update macOS installer to use OpenSSL 3.0.13.
gh-114490: Add Mach-O linkage support for
platform.architecture().gh-87804: On macOS the result of
os.statvfsandos.fstatvfsnow correctly report the size of very large disks, in previous versions the reported number of blocks was wrong for disks with at least 2**32 blocks.
IDLE¶
Tools/Demos¶
gh-113516: Don’t set
LDSHAREDwhen building for WASI.gh-109991: Update GitHub CI workflows to use OpenSSL 3.0.13 and multissltests to use 1.1.1w, 3.0.13, 3.1.5, and 3.2.1.
gh-115015: Fix a bug in Argument Clinic that generated incorrect code for methods with no parameters that use the METH_METHOD | METH_FASTCALL | METH_KEYWORDS calling convention. Only the positional parameter count was checked; any keyword argument passed would be silently accepted.
C API¶
gh-111140: Adds
PyLong_AsNativeBytes(),PyLong_FromNativeBytes()andPyLong_FromUnsignedNativeBytes()functions.gh-114685:
PyBuffer_FillInfo()now raises aSystemErrorif called withPyBUF_READorPyBUF_WRITEas flags. These flags should only be used with thePyMemoryView_*C API.gh-114685:
PyObject_GetBuffer()now raises aSystemErrorif called withPyBUF_READorPyBUF_WRITEas flags. These flags should only be used with thePyMemoryView_*C API.gh-114626: Add
PyCFunctionFastandPyCFunctionFastWithKeywordstypedefs (identical to the existing_PyCFunctionFastand_PyCFunctionFastWithKeywordstypedefs, just without a leading_prefix).gh-114329: Add
PyList_GetItemRef(), which is similar toPyList_GetItem()but returns a strong reference instead of a borrowed reference.gh-110850: Add PyTime C API:
PyTime_ttype.PyTime_MINandPyTime_MAXconstants.PyTime_AsSecondsDouble(),PyTime_Monotonic(),PyTime_PerfCounter(), andPyTime_Time()functions.
Patch by Victor Stinner.
gh-112066: Add
PyDict_SetDefaultRef(): insert a key and value into a dictionary if the key is not already present. This is similar todict.setdefault(), but returns an integer value indicating if the key was already present. It is also similar toPyDict_SetDefault(), but returns a strong reference instead of a borrowed reference.
Python 3.13.0 alpha 3¶
Release date: 2024-01-17
Security¶
Core and Builtins¶
gh-107901: Compiler duplicates basic blocks that have an eval breaker check, no line number, and multiple predecessors.
gh-107901: A jump leaving an exception handler back to normal code no longer checks the eval breaker.
gh-113655: Set the C recursion limit to 4000 on Windows, and 10000 on Linux/OSX. This seems to be near the sweet spot to maintain safety, but not compromise backwards compatibility.
gh-113710: Add typed stack effects to the interpreter DSL, along with various instruction annotations.
gh-77046: On Windows, file descriptors wrapping Windows handles are now created non inheritable by default (PEP 446). Patch by Zackery Spytz and Victor Stinner.
gh-113853: Guarantee that all executors make progress. This then guarantees that tier 2 execution always makes progress.
gh-113753: Fix an issue where the finalizer of
PyAsyncGenASendobjects might not be called if they were allocated from a free list.gh-107901: Compiler changed so that synthetic jumps which are not at loop end no longer check the eval breaker.
gh-113703: Fix a regression in the
codeopmodule that was causing it to incorrectly identify incomplete f-strings. Patch by Pablo Galindogh-89811: Check for a valid
tp_version_tagbefore performing bytecode specializations that rely on this value being usable.gh-111488: Changed error message in case of no ‘in’ keyword after ‘for’ in list comprehensions
gh-113657: Fix an issue that caused important instruction pointer updates to be optimized out of tier two traces.
gh-113603: Fixed bug where a redundant NOP is not removed, causing an assertion to fail in the compiler in debug mode.
gh-113602: Fix an error that was causing the parser to try to overwrite existing errors and crashing in the process. Patch by Pablo Galindo
gh-113486: No longer issue spurious
PY_UNWINDevents for optimized calls to classes.gh-113297: Fix segfault in the compiler on with statement with 19 context managers.
gh-111375: Only use
NULLin the exception stack to indicate an exception was handled. Patch by Carey Metcalfe.gh-112215: Increase the C recursion limit by a factor of 3 for non-debug builds, except for webassembly and s390 platforms which are unchanged. This mitigates some regressions in 3.12 with deep recursion mixing builtin (C) and Python code.
gh-113054: Fixed bug where a redundant NOP is not removed, causing an assertion to fail in the compiler in debug mode.
gh-106905: Use per AST-parser state rather than global state to track recursion depth within the AST parser to prevent potential race condition due to simultaneous parsing.
The issue primarily showed up in 3.11 by multithreaded users of
ast.parse(). In 3.12 a change to when garbage collection can be triggered prevented the race condition from occurring.gh-108866: Change the API and contract of
_PyExecutorObjectto return the next_instr pointer, instead of the frame, and to always execute at least one instruction.gh-112943: Correctly compute end column offsets for multiline tokens in the
tokenizemodule. Patch by Pablo Galindogh-112125: Fix
None.__ne__(None)returningNotImplementedinstead ofFalse.gh-74616:
input()now raises a ValueError when output on the terminal if the prompt contains embedded null characters instead of silently truncating it.gh-112716: Fix SystemError in the
importstatement and in__reduce__()methods of builtin types when__builtins__is not a dict.gh-112730: Use color to highlight error locations in tracebacks. Patch by Pablo Galindo
gh-112625: Fixes a bug where a bytearray object could be cleared while iterating over an argument in the
bytearray.join()method that could result in reading memory after it was freed.gh-112660: Do not clear unexpected errors during formatting error messages for ImportError and AttributeError for modules.
gh-105967: Workaround a bug in Apple’s macOS platform zlib library where
zlib.crc32()andbinascii.crc32()could produce incorrect results on multi-gigabyte inputs. Including when usingzipfileon zips containing large data.gh-95754: Provide a better error message when accessing invalid attributes on partially initialized modules. The origin of the module being accessed is now included in the message to help with the common issue of shadowing other modules.
gh-112217: Add check for the type of
__cause__returned from calling the typeTinraise from T.gh-111058: Change coro.cr_frame/gen.gi_frame to return
Noneafter the coroutine/generator has been closed. This fixes a bug wheregetcoroutinestate()andgetgeneratorstate()return the wrong state for a closed coroutine/generator.gh-112388: Fix an error that was causing the parser to try to overwrite tokenizer errors. Patch by pablo Galindo
gh-112387: Fix error positions for decoded strings with backwards tokenize errors. Patch by Pablo Galindo
gh-99606: Make code generated for an empty f-string identical to the code of an empty normal string.
gh-112367: Avoid undefined behaviour when using the perf trampolines by not freeing the code arenas until shutdown. Patch by Pablo Galindo
gh-112320: The Tier 2 translator now tracks the confidence level for staying “on trace” (i.e. not exiting back to the Tier 1 interpreter) for branch instructions based on the number of bits set in the branch “counter”. Trace translation ends when the confidence drops below 1/3rd.
gh-109598:
PyComplex_RealAsDouble()/PyComplex_ImagAsDouble()now tries to convert an object to acomplexinstance using its__complex__()method before falling back to the__float__()method. Patch by Sergey B Kirpichev.gh-94606: Fix UnicodeEncodeError when
email.message.get_payload()reads a message with a Unicode surrogate character and the message content is not well-formed for surrogateescape encoding. Patch by Sidney Markowitz.bpo-21861: Use the object’s actual class name in
_io.FileIO.__repr__(),_io._WindowsConsoleIO()and_io.TextIOWrapper.__repr__(), to make these methods subclass friendly.bpo-34392: Added
sys._is_interned().
Library¶
gh-114077: Fix possible
OverflowErrorinsocket.socket.sendfile()when pass count larger than 2 GiB on 32-bit platform.gh-111803:
plistlibnow supports loading more deeply nested lists in binary format.gh-114014: Fixed a bug in
fractions.Fractionwhere an invalid string usingdin the decimals part creates a different error compared to other invalid letters/characters. Patch by Jeremiah Gabriel Pascual.gh-108364:
sqlite3.Connection.iterdump()now ensures that foreign key support is disabled before dumping the database schema, if there is any foreign key violation. Patch by Erlend E. Aasland and Mariusz Felisiak.gh-113971: The
zipfile.ZipInfopreviously protected._compresslevelattribute has been made public as.compress_levelwith the old_compresslevelname remaining available as a property to retain compatibility.gh-113877: Fix
tkintermethodwinfo_pathname()on 64-bit Windows.gh-113868: Added
mmap.MAP_NORESERVE,mmap.MAP_NOEXTEND,mmap.MAP_HASSEMAPHORE,mmap.MAP_NOCACHE,mmap.MAP_JIT,mmap.MAP_RESILIENT_CODESIGN,mmap.MAP_RESILIENT_MEDIA,mmap.MAP_32BIT,mmap.MAP_TRANSLATED_ALLOW_EXECUTE,mmap.MAP_UNIX03andmmap.MAP_TPRO. All of them aremmap(2)flags on macOS.gh-113848:
asyncio.TaskGroup()andasyncio.timeout()context managers now handleCancelledErrorsubclasses as well as exactCancelledError.gh-113661: unittest runner: Don’t exit 5 if tests were skipped. The intention of exiting 5 was to detect issues where the test suite wasn’t discovered at all. If we skipped tests, it was correctly discovered.
gh-96037: Insert
TimeoutErrorin the context of the exception that was raised during exiting an expiredasyncio.timeout()block.gh-113781: Silence unraisable AttributeError when warnings are emitted during Python finalization.
gh-113238: Add
Anchortoimportlib.resources(in order for the code to comply with the documentation)gh-111693:
asyncio.Condition.wait()now re-raises the sameCancelledErrorinstance that may have caused it to be interrupted. Fixed race condition inasyncio.Semaphore.acquire()when interrupted with aCancelledError.gh-113791: Add
CLOCK_MONOTONIC_RAW_APPROXandCLOCK_UPTIME_RAW_APPROXtotimeon macOS. These are clocks available on macOS 10.12 or later.gh-112932: Restore the ability for
zipfiletoextractallfrom zip files with a “/” directory entry in them as is commonly added to zips by some wiki or bug tracker data exporters.gh-113568: Raise deprecation warnings from
pathlib.PurePathand not its private base classPurePathBase.gh-113594: Fix
UnicodeEncodeErrorinemailwhen re-fold lines that contain unknown-8bit encoded part followed by non-unknown-8bit encoded part.gh-113538: In
asyncio.StreamReaderProtocol.connection_made(), there is callback that logs an error if the task wrapping the “connected callback” fails. This callback would itself fail if the task was cancelled. Prevent this by checking whether the task was cancelled first. If so, close the transport but don’t log an error.gh-113626: Add support for the allow_code argument in the
marshalmodule. Passingallow_code=Falseprevents serialization and de-serialization of code objects which is incompatible between Python versions.gh-85567: Fix resource warnings for unclosed files in
pickleandpickletoolscommand line interfaces.gh-113537: Support loads
strinplistlib.loads().gh-89850: Add default implementations of
pickle.Pickler.persistent_id()andpickle.Unpickler.persistent_load()methods in the C implementation. Callingsuper().persistent_id()andsuper().persistent_load()in subclasses of the C implementation ofpickle.Picklerandpickle.Unpicklerclasses no longer causes infinite recursion.gh-113569: Indicate if there were no actual calls in unittest
assert_has_calls()failure.gh-101225: Increase the backlog for
multiprocessing.connection.Listenerobjects created bymultiprocessing.managerandmultiprocessing.resource_sharerto significantly reduce the risk of getting a connection refused error when creating amultiprocessing.connection.Connectionto them.gh-113568: Raise audit events from
pathlib.Pathand not its private base classPathBase.gh-113543: Make sure that
webbrowser.MacOSXOSAScriptsendswebbrowser.openaudit event.gh-113028: When a second reference to a string appears in the input to
pickle, and the Python implementation is in use, we are guaranteed that a single copy gets pickled and a single object is shared when reloaded. Previously, in protocol 0, when a string contained certain characters (e.g. newline) it resulted in duplicate objects.gh-113421: Fix multiprocessing logger for
%(filename)s.gh-111784: Fix segfaults in the
_elementtreemodule. Fix first segfault during deallocation of_elementtree.XMLParserinstances by keeping strong reference topyexpatmodule in module state for capsule lifetime. Fix second segfault which happens in the same deallocation process by keeping strong reference to_elementtreemodule inXMLParserstructure for_elementtreemodule lifetime.gh-113407: Fix import of
unittest.mockwhen CPython is built without docstrings.gh-113320: Fix regression in Python 3.12 where
Protocolclasses that were not marked asruntime-checkablewould be unnecessarily introspected, potentially causing exceptions to be raised if the protocol had problematic members. Patch by Alex Waygood.gh-53502: Add a new option
aware_datetimeinplistlibto loads or dumps aware datetime.gh-113358: Fix rendering tracebacks with exceptions with a broken __getattr__
gh-113214: Fix an
AttributeErrorduring asyncio SSL protocol aborts in SSL-over-SSL scenarios.gh-113246: Update bundled pip to 23.3.2.
gh-87264: Fixed tarfile list() method to show file type.
gh-112182:
asyncio.futures.Future.set_exception()now transformsStopIterationintoRuntimeErrorinstead of hanging or other misbehavior. Patch contributed by Jamie Phan.gh-113225: Speed up
pathlib.Path.glob()by usingos.DirEntry.pathwhere possible.gh-113149: Improve error message when a JSON array or object contains a trailing comma. Patch by Carson Radtke.
gh-113117: The
subprocessmodule can now use theos.posix_spawn()function withclose_fds=Trueon platforms whereposix_spawn_file_actions_addclosefrom_npis available. Patch by Jakub Kulik.gh-113199: Make
http.client.HTTPResponse.read1andhttp.client.HTTPResponse.readlineclose IO after reading all data when content length is known. Patch by Illia Volochii.gh-113191: Add support of
os.fchmod()and a file descriptor inos.chmod()on Windows.gh-113188: Fix
shutil.copymode()andshutil.copystat()on Windows. Previously they worked differently if dst is a symbolic link: they modified the permission bits of dst itself rather than the file it points to if follow_symlinks is true or src is not a symbolic link, and did not modify the permission bits if follow_symlinks is false and src is a symbolic link.gh-113119:
os.posix_spawn()now acceptsenv=None, which makes the newly spawned process use the current process environment. Patch by Jakub Kulik.gh-113202: Add a
strictoption tobatched()in theitertoolsmodule.gh-61648: Detect line numbers of properties in doctests.
gh-113175: Sync with importlib_metadata 7.0, including improved type annotations, fixed issue with symlinked packages in
package_distributions, addedEntryPoints.__repr__, introduced thediagnosescript, addedDistribution.originproperty, and removed deprecatedEntryPointaccess by numeric index (tuple behavior).gh-59616: Add support of
os.lchmod()and the follow_symlinks argument inos.chmod()on Windows. Note that the default value of follow_symlinks inos.lchmod()isFalseon Windows.gh-112559:
signal.signal()andsignal.getsignal()no longer callrepron callable handlers.asyncio.run()andasyncio.Runner.run()no longer callrepron the task results. Patch by Yilei Yang.gh-112962:
dismodule functions add cache information to theInstructioninstance rather than creating fakeInstructioninstances to represent the cache entries.gh-112989: Reduce overhead to connect sockets with
asyncioSelectorEventLoop.gh-112970: Use
closefrom()on Linux where available (e.g. glibc-2.34), rather than only FreeBSD.gh-110190: Fix ctypes structs with array on PPC64LE platform by setting
MAX_STRUCT_SIZEto 64 in stgdict. Patch by Diego Russo.gh-112540: The statistics.geometric_mean() function now returns zero for datasets containing a zero. Formerly, it would raise an exception.
gh-87286: Added
LOG_FTP,LOG_NETINFO,LOG_REMOTEAUTH,LOG_INSTALL,LOG_RAS, andLOG_LAUNCHDtot thesyslogmodule, all of them constants on used on macOS.gh-112800: Fix
asyncioSubprocessTransport.close()not to throwPermissionErrorwhen used with setuid executables.gh-51944: Add the following constants to the
termiosmodule. These values are present in macOS system headers:ALTWERASE,B14400,B28800,B7200,B76800,CCAR_OFLOW,CCTS_OFLOW,CDSR_OFLOW,CDTR_IFLOW,CIGNORE,CRTS_IFLOW,EXTPROC,IUTF8,MDMBUF,NL2,NL3,NOKERNINFO,ONOEOT,OXTABS,VDSUSP,VSTATUS.gh-79325: Fix an infinite recursion error in
tempfile.TemporaryDirectory()cleanup on Windows.gh-94692:
shutil.rmtree()now only catches OSError exceptions. Previously a symlink attack resistant version ofshutil.rmtree()could ignore or pass to the error handler arbitrary exception when invalid arguments were provided.gh-112736: The use of del-safe symbols in
subprocesswas refactored to allow for use in cross-platform build environments.gh-112727: Speed up
pathlib.Path.absolute(). Patch by Barney Gale.gh-74690: Speedup
issubclass()checks against simpleruntime-checkable protocolsby around 6%. Patch by Alex Waygood.gh-74690: Speedup
isinstance()checks by roughly 20% forruntime-checkable protocolsthat only have one callable member. Speedupissubclass()checks for these protocols by roughly 10%. Patch by Alex Waygood.gh-112645: Remove deprecation error on passing
onerrortoshutil.rmtree().gh-112640: Add
kwdefaultsparameter totypes.FunctionTypeto set default keyword argument values.gh-112622: Ensure
nameparameter is passed to event loop inasyncio.create_task().gh-112618: Fix a caching bug relating to
typing.Annotated.Annotated[str, True]is no longer identical toAnnotated[str, 1].gh-112334: Fixed a performance regression in 3.12’s
subprocesson Linux where it would no longer use the fast-pathvfork()system call when it could have due to a logic bug, instead falling back to the safe but slowerfork().Also fixed a second 3.12.0 potential security bug. If a value of
extra_groups=[]was passed tosubprocess.Popenor related APIs, the underlyingsetgroups(0, NULL)system call to clear the groups list would not be made in the child process prior toexec().This was identified via code inspection in the process of fixing the first bug.
gh-110190: Fix ctypes structs with array on Arm platform by setting
MAX_STRUCT_SIZEto 32 in stgdict. Patch by Diego Russo.gh-81194: Fix a crash in
socket.if_indextoname()with specific value (UINT_MAX). Fix an integer overflow insocket.if_indextoname()on 64-bit non-Windows platforms.gh-112578: Fix a spurious
RuntimeWarningwhen executing thezipfilemodule.gh-112516: Update the bundled copy of pip to version 23.3.1.
gh-112510: Add
readline.backendfor the backend readline uses (editlineorreadline)gh-112328: [Enum] Make
EnumDict,EnumDict.member_names,EnumType._add_alias_andEnumType._add_value_alias_public.gh-112509: Fix edge cases that could cause a key to be present in both the
__required_keys__and__optional_keys__attributes of atyping.TypedDict. Patch by Jelle Zijlstra.gh-101336: Add
keep_alivekeyword parameter forAbstractEventLoop.create_server()andBaseEventLoop.create_server().gh-63284: Added support for TLS-PSK (pre-shared key) mode to the
sslmodule.gh-112414: Fix regression in Python 3.12 where calling
repr()on a module that had been imported using a custom loader could fail withAttributeError. Patch by Alex Waygood.gh-112358: Revert change to
struct.Structinitialization that broke some cases of subclassing.gh-112405: Optimize
pathlib.PurePath.relative_to(). Patch by Alex Waygood.gh-94722: Fix bug where comparison between instances of
DocTestfails if one of them hasNoneas its lineno.gh-112361: Speed up a small handful of
pathlibmethods by removing some temporary objects.gh-112345: Improve error message when trying to call
issubclass()against atyping.Protocolthat has non-method members. Patch by Randolf Scholz.gh-112137: Change
disoutput to display no-lineno as “–” instead of “None”.gh-112332: Deprecate the
exc_typefield oftraceback.TracebackException. Addexc_type_strto replace it.gh-81620: Add extra tests for
random.binomialvariate()gh-112292: Fix a crash in
readlinewhen imported from a sub interpreter. Patch by Anthony Shawgh-77621: Slightly improve the import time of the
pathlibmodule by deferring some imports. Patch by Barney Gale.gh-112137: Change
disoutput to display logical labels for jump targets instead of offsets.gh-112139: Add
Signature.format()to format signatures to string with extra options. And use it inpydocto render more readable signatures that have new lines between parameters.gh-112105: Make
readline.set_completer_delims()work with libeditgh-106922: Display multiple lines with
tracebackwhen errors span multiple lines.gh-111874: When creating a
typing.NamedTupleclass, ensure__set_name__()is called on all objects that define__set_name__and exist in the values of theNamedTupleclass’s class dictionary. Patch by Alex Waygood.gh-68166: Add support of the “vsapi” element type in
tkinter.ttk.Style.element_create().gh-110275: Named tuple’s methods
_replace()and__replace__()now raise TypeError instead of ValueError for invalid keyword arguments.gh-99367: Do not mangle
sys.path[0]inpdbif safe_path is setgh-111615: Fix a regression caused by a fix to gh-93162 whereby you couldn’t configure a
QueueHandlerwithout specifying handlers.gh-75666: Fix the behavior of
tkinterwidget’sunbind()method with two arguments. Previously,widget.unbind(sequence, funcid)destroyed the current binding for sequence, leaving sequence unbound, and deleted the funcid command. Now it removes only funcid from the binding for sequence, keeping other commands, and deletes the funcid command. It leaves sequence unbound only if funcid was the last bound command.gh-67790: Implement basic formatting support (minimum width, alignment, fill) for
fractions.Fraction.gh-111049: Fix crash during garbage collection of the
io.BytesIObuffer object.gh-102980: Redirect the output of
interactcommand ofpdbto the same channel as the debugger. Add tests and improve docs.gh-102988:
email.utils.getaddresses()andemail.utils.parseaddr()now return('', '')2-tuples in more situations where invalid email addresses are encountered instead of potentially inaccurate values. Add optional strict parameter to these two functions: usestrict=Falseto get the old behavior, accept malformed inputs.getattr(email.utils, 'supports_strict_parsing', False)can be use to check if the strict parameter is available. Patch by Thomas Dwyer and Victor Stinner to improve the CVE 2023-27043 fix.gh-52161:
cmd.Cmd.do_help()now cleans docstrings withinspect.cleandoc()before writing them. Patch by Filip Łapkiewicz.gh-82300: Add
trackparameter tomultiprocessing.shared_memory.SharedMemorythat allows using shared memory blocks without having to register with the POSIX resource tracker that automatically releases them upon process exit.gh-110109: Add private
pathlib._PurePathBaseclass: a base class forpathlib.PurePaththat omits certain magic methods. It may be made public (along with_PathBase) in future.gh-109858: Protect
zipfilefrom “quoted-overlap” zipbomb. It now raises BadZipFile when try to read an entry that overlaps with other entry or central directory.gh-109786: Fix possible reference leaks and crash when re-enter the
__next__()method ofitertools.pairwise.gh-91539: Small (10 - 20%) and trivial performance improvement of
urllib.request.getproxies_environment(), typically useful when there are many environment variables to go over.gh-103363: Add follow_symlinks keyword-only argument to
pathlib.Path.owner()andgroup(), defaulting toTrue.gh-99437:
runpy.run_path()now decodes path-like objects, making sure __file__ and sys.argv[0] of the module being run are always strings.gh-104003: Add
warnings.deprecated(), a decorator to mark deprecated functions to static type checkers and to warn on usage of deprecated classes and functions. See PEP 702. Patch by Jelle Zijlstra.gh-103708: Make hardcoded python name, a configurable parameter so that different implementations of python can override it instead of making huge diffs in sysconfig.py
gh-66515:
mailbox.MHnow supports folders that do not contain a.mh_sequencesfile (e.g. Claws Mail IMAP-cache folders). Patch by Serhiy Storchaka.gh-83162: Renamed
re.errortoPatternErrorfor clarity, and keptre.errorfor backward compatibility. Patch by Matthias Bussonnier and Adam Chhina.gh-91133: Fix a bug in
tempfile.TemporaryDirectorycleanup, which now no longer dereferences symlinks when working around file system permission errors.bpo-43153: On Windows,
tempfile.TemporaryDirectorypreviously masked aPermissionErrorwithNotADirectoryErrorduring directory cleanup. It now correctly raisesPermissionErrorif errors are not ignored. Patch by Andrei Kulakov and Ken Jin.bpo-32731:
getpass.getuser()now raisesOSErrorfor all failures rather thanImportErroron systems lacking thepwdmodule orKeyErrorif the password database is empty.bpo-34321:
mmap.mmapnow has a trackfd parameter on Unix; if it isFalse, the file descriptor specified by fileno will not be duplicated.bpo-35332: The
shutil.rmtree()function now ignores errors when callingos.close()when ignore_errors isTrue, andos.close()no longer retried after error.bpo-35928:
io.TextIOWrappernow correctly handles the decoding buffer afterread()andwrite().bpo-26791:
shutil.move()now moves a symlink into a directory when that directory is the target of the symlink. This provides the same behavior as the mv shell command. The previous behavior raised an exception. Patch by Jeffrey Kintscher.bpo-41422: Fixed memory leaks of
pickle.Picklerandpickle.Unpicklerinvolving cyclic references via the internal memo mapping.bpo-19821: The
pydoc.ispackage()function has been deprecated.bpo-40262: The
ssl.SSLSocket.recv_into()method no longer requires the buffer argument to implement__len__and supports buffers with arbitrary item size.bpo-39912:
warnings.filterwarnings()andwarnings.simplefilter()now raise appropriate exceptions instead ofAssertionError. Patch contributed by Rémi Lapeyre.bpo-37260: Fixed a race condition in
shutil.rmtree()in which directory entries removed by another process or thread whileshutil.rmtree()is running can cause it to raise FileNotFoundError. Patch by Jeffrey Kintscher.bpo-36959: Fix some error messages for invalid ISO format string combinations in
strptime()that referred to directives not contained in the format string. Patch by Gordon P. Hemsley.bpo-18060: Fixed a class inheritance issue that can cause segfaults when deriving two or more levels of subclasses from a base class of Structure or Union.
bpo-29779: Add a new
PYTHON_HISTORYenvironment variable to set the location of a.python_historyfile.bpo-21360:
mailbox.Maildirnow ignores files with a leading dot.
Documentation¶
gh-111699: Relocate
smtpddeprecation notice to its own section rather than underlocalein What’s New in Python 3.12 documentgh-110746: Improved markup for valid options/values for methods ttk.treeview.column and ttk.treeview.heading, and for Layouts.
gh-95649: Document that the
asynciomodule contains code taken from v0.16.0 of the uvloop project, as well as the required MIT licensing information.
Tests¶
gh-111798: Disable
test_super_deep()fromtest_callunder pydebug builds on WASI; the stack depth is too small to make the test useful.gh-111801: Lower the recursion limit in
test_isinstancefortest_infinitely_many_bases(). This prevents a stack overflow on a pydebug build of WASI.gh-111802: Specify a low recursion depth for
test_bad_getattr()intest.pickletesterto avoid exhausting the stack under a pydebug build for WASI.gh-44626: Fix
os.path.isabs()incorrectly returningTruewhen given a path that starts with exactly one (back)slash on Windows.Fix
pathlib.PureWindowsPath.is_absolute()incorrectly returningFalsefor some paths beginning with two (back)slashes.gh-113633: Use module state for the _testcapi extension module.
gh-109980: Fix
test_tarfile_vs_tarintest_shutilfor macOS, where system tar can include more information in the archive thanshutil.make_archive.gh-112769: The tests now correctly compare zlib version when
zlib.ZLIB_RUNTIME_VERSIONcontains non-integer suffixes. For example zlib-ng defines the version as1.3.0.zlib-ng.gh-112334: Adds a regression test to verify that
vfork()is used when expected bysubprocesson vfork enabled POSIX systems (Linux).gh-108927: Fixed order dependence in running tests in the same process when a test that has submodules (e.g. test_importlib) follows a test that imports its submodule (e.g. test_importlib.util) and precedes a test (e.g. test_unittest or test_compileall) that uses that submodule.
bpo-40648: Test modes that file can get with chmod() on Windows.
Build¶
gh-114013: Fix
Tools/wasm/wasi.pyto not include the path topython.wasmas part ofHOSTRUNNER. The environment variable is meant to specify how to run the WASI host only, havingpython.wasmand relevant flags appended to theHOSTRUNNER. This fixesmake testwork.gh-113258: Changed the Windows build to write out generated frozen modules into the build tree instead of the source tree.
gh-112305: Fixed the
check-clean-srcstep performed on out of tree builds to detect errant$(srcdir)/Python/frozen_modules/*.hfiles and recommend appropriate source tree cleanup steps to get a working build again.gh-112536: Add support for thread sanitizer (TSAN)
gh-112867: Fix the build for the case that WITH_PYMALLOC_RADIX_TREE=0 set.
gh-103065: Introduce
Tools/wasm/wasi.pyto simplify doing a WASI build.bpo-11102: The
os.major(),os.makedev(), andos.minor()functions are now available on HP-UX v3.bpo-36351: Do not set ipv6type when cross-compiling.
Windows¶
gh-114096: Process privileges that are activated for creating directory junctions are now restored afterwards, avoiding behaviour changes in other parts of the program.
gh-111877:
os.stat()calls were returning incorrect time values for files that could not be accessed directly.gh-111973: Update Windows installer to use SQLite 3.44.2.
gh-113009:
multiprocessing: On Windows, fix a race condition inProcess.terminate(): no longer set thereturncodeattribute to always callWaitForSingleObject()inProcess.wait(). Previously, sometimes the process was still running afterTerminateProcess()even ifGetExitCodeProcess()is notSTILL_ACTIVE. Patch by Victor Stinner.gh-86179: Fixes path calculations when launching Python on Windows through a symlink.
gh-71383: Update Tcl/Tk in Windows installer to 8.6.13 with a patch to suppress incorrect ThemeChanged warnings.
gh-111650: Ensures the
Py_GIL_DISABLEDpreprocessor variable is defined inpyconfig.hso that extension modules written in C are able to use it.gh-112278: Reduce the time cost for some functions in
platformon Windows if current user has no permission to the WMI.gh-73427: Deprecate
sys._enablelegacywindowsfsencoding(). UsePYTHONLEGACYWINDOWSFSENCODINGinstead. Patch by Inada Naoki.gh-87868: Correctly sort and remove duplicate environment variables in
_winapi.CreateProcess().bpo-37308: Fix mojibake in
mmap.mmapwhen using a non-ASCII tagname argument on Windows.
macOS¶
gh-113666: Add the following constants to module
stat:UF_SETTABLE,UF_TRACKED,UF_DATAVAULT,SF_SUPPORTED,SF_SETTABLE,SF_SYNTHETIC,SF_RESTRICTED,SF_FIRMLINKandSF_DATALESS. The valuesUF_SETTABLE,SF_SUPPORTED,SF_SETTABLEandSF_SYNTHETICare only available on macOS.gh-113536:
os.waitid()is now available on macOSgh-110459: Running
configure ... --with-openssl-rpath=X/Y/Zno longer fails to detect OpenSSL on macOS.gh-74573: Document that
dbm.ndbmcan silently corrupt DBM files on updates when exceeding undocumented platform limits, and can crash (segmentation fault) when reading such a corrupted file. (FB8919203)gh-65701: The freeze tool doesn’t work with framework builds of Python. Document this and bail out early when running the tool with such a build.
gh-87277: webbrowser: Don’t look for X11 browsers on macOS. Those are generally not used and probing for them can result in starting XQuartz even if it isn’t used otherwise.
gh-111973: Update macOS installer to use SQLite 3.44.2.
gh-108269: Set
CFBundleAllowMixedLocalizationsto true in the Info.plist for the framework, embedded Python.app and IDLE.app with framework installs on macOS. This allows applications to pick up the user’s preferred locale when that’s different from english.gh-102362: Make sure the result of
sysconfig.get_plaform()includes at least a major and minor versions, even ifMACOSX_DEPLOYMENT_TARGETis set to only a major version during build to match the format expected by pip.gh-110017: Disable a signal handling stress test on macOS due to a bug in macOS (FB13453490).
gh-110820: Make sure the preprocessor definitions for
ALIGNOF_MAX_ALIGN_T,SIZEOF_LONG_DOUBLEandHAVE_GCC_ASM_FOR_X64are correct for Universal 2 builds on macOS.gh-109981: Use
/dev/fdon macOS to determine the number of open files intest.support.os_helper.fd_countto avoid a crash with “guarded” file descriptors when probing for open files.
IDLE¶
gh-72284: Improve the lists of features, editor key bindings, and shell key bingings in the IDLE doc.
gh-113903: Fix rare failure of test.test_idle, in test_configdialog.
gh-113729: Fix the “Help -> IDLE Doc” menu bug in 3.11.7 and 3.12.1.
gh-113269: Fix test_editor hang on macOS Catalina.
gh-112898: Fix processing unsaved files when quitting IDLE on macOS.
bpo-13586: Enter the selected text when opening the “Replace” dialog.
C API¶
gh-106560: Fix redundant declarations in the public C API. Declare PyBool_Type, PyLong_Type and PySys_Audit() only once. Patch by Victor Stinner.
gh-112438: Fix support of format units “es”, “et”, “es#”, and “et#” in nested tuples in
PyArg_ParseTuple()-like functions.gh-111545: Add
Py_HashPointer()function to hash a pointer. Patch by Victor Stinner.gh-65210: Change the declaration of the keywords parameter of
PyArg_ParseTupleAndKeywords()andPyArg_VaParseTupleAndKeywords()for better compatibility with C++.
Python 3.13.0 alpha 2¶
Release date: 2023-11-22
Core and Builtins¶
gh-112243: Don’t include comments in f-string debug expressions. Patch by Pablo Galindo
gh-112287: Slightly optimize the Tier 2 (uop) interpreter by only loading
opargandoperandwhen needed. Also double the trace size limit again, to 512 this time.gh-111807: Lower the max parser stack depth to 1000 under WASI debug builds.
gh-111798: When Python is built in debug mode, set the C recursion limit to 500 instead of 1500. A debug build is likely built with low optimization level which implies higher stack memory usage than a release build. Patch by Victor Stinner.
gh-106529: Enable translating unspecialized
FOR_ITERto Tier 2.gh-111916: Make hashlib related modules thread-safe without the GIL
gh-81137: Deprecate assignment to a function’s
__code__field when the new code object is of a mismatched type (e.g., from a generator to a plain function).gh-79932: Raise exception if
frame.clear()is called on a suspended frame.gh-81925: Implement native thread ids for GNU KFreeBSD.
gh-111843: Use exponential backoff to reduce the number of failed tier 2 optimization attempts by over 99%.
gh-110829: Joining a thread now ensures the underlying OS thread has exited. This is required for safer fork() in multi-threaded processes.
gh-109369: Make sure that tier 2 traces are de-optimized if the code is instrumented
gh-111772: Specialize slot loads and stores for _Py_T_OBJECT as well as Py_T_OBJECT_EX
gh-111666: Speed up
BaseExceptionGroup.derive(),BaseExceptionGroup.subgroup(), andBaseExceptionGroup.split()by changing how they parse passed arguments.gh-111654: Fix runtime crash when some error happens in opcode
LOAD_FROM_DICT_OR_DEREF.gh-111623: Add support for sharing tuples between interpreters using the cross-interpreter API. Patch by Anthony Shaw.
gh-111354: The oparg of
YIELD_VALUEis now1if the instruction is part of a yield-from or await, and0otherwise.The SUSPENDED frame state is now split into
SUSPENDEDandSUSPENDED_YIELD_FROM. This simplifies the code in_PyGen_yf.gh-111520: Merge the Tier 1 (bytecode) and Tier 2 (micro-ops) interpreters together, moving the Tier 2 interpreter loop and switch into
_PyEval_EvalFrameDefault()inPython/ceval.c. ThePython/executor.cfile is gone. Also theTIER_ONEandTIER_TWOmacros are now handled by the code generator.Beware! This changes the environment variables to enable micro-ops and their debugging to
PYTHON_UOPSandPYTHON_LLTRACE.gh-109181: Speed up
Tracebackobject creation by lazily compute the line number. Patch by Pablo Galindogh-111420: Allow type comments in parenthesized
withstatementsgh-111438: Add support for sharing floats between interpreters using the cross-interpreter API. Patch by Anthony Shaw.
gh-111435: Add support for sharing of
TrueandFalsebetween interpreters using the cross-interpreter API. Patch by Anthony Shaw.gh-102388: Fix a bug where
iso2022_jp_3andiso2022_jp_2004codecs read out of boundsgh-111366: Fix an issue in the
codeopthat was causingSyntaxErrorexceptions raised in the presence of invalid syntax to not contain precise error messages. Patch by Pablo Galindogh-111380: Fix a bug that was causing
SyntaxWarningto appear twice when parsing if invalid syntax is encountered later. Patch by Pablo galindogh-111374: Added a new environment variable
PYTHON_FROZEN_MODULES. It determines whether or not frozen modules are ignored by the import machinery, equivalent of the-X frozen_modulescommand-line option.gh-111354: Remove
opargfromYIELD_VALUE. ChangeopargofRESUMEto include information about the except-depth. These changes make it possible to simplify the code in generator close.gh-94438: Fix a regression that prevented jumping across
is Noneandis not Nonewhen debugging. Patch by Savannah Ostrowski.gh-67224: Show source lines in tracebacks when using the
-coption when running Python. Patch by Pablo Galindogh-111123: Fix a bug where a
globaldeclaration in anexceptblock is rejected when the global is used in theelseblock.gh-110938: Fix error messages for indented blocks with functions and classes with generic type parameters. Patch by Pablo Galindo
gh-109214: Remove unnecessary instruction pointer updates before returning from frames.
gh-110912: Correctly display the traceback for
MemoryErrorexceptions using thetracebackmodule. Patch by Pablo Galindogh-109894: Fixed crash due to improperly initialized static
MemoryErrorin subinterpreter.gh-110892: Return
NULLforPyTrace_RETURNevents caused by an exceptiongh-110864: Fix argument parsing by
_PyArg_UnpackKeywordsWithVarargfor functions defining pos-or-keyword, vararg, and kw-only parameters.gh-109094: Replace
prev_instron the interpreter frame byinstr_ptrwhich points to the beginning of the instruction that is currently executing (or will execute once the frame resumes).gh-110805: Allow the repl to show source code and complete tracebacks. Patch by Pablo Galindo
gh-110722: Add
PYTHON_PRESITE=package.moduleto import a module early in the interpreter lifecycle beforesite.pyis executed. Python needs to be built in debug mode for this option to exist.gh-110481: Implement biased reference counting in
--disable-gilbuilds.gh-110543: Fix regression in Python 3.12 where
types.CodeType.replace()would produce a broken code object if called on a module or class code object that contains a comprehension. Patch by Jelle Zijlstra.gh-89519: Removed chained
classmethoddescriptors (introduced in bpo-19072). This can no longer be used to wrap other descriptors such asproperty. The core design of this feature was flawed and caused a number of downstream problems. To “pass-through” aclassmethod, consider using the__wrapped__attribute that was added in Python 3.10.gh-103615: Use local events for opcode tracing
bpo-46657: Add mimalloc memory allocator support.
gh-106718: When PyConfig.stdlib_dir is explicitly set, it’s now respected and won’t be overridden by PyConfig.home.
gh-106905: Fix incorrect SystemError about AST constructor recursion depth mismatch.
gh-100445: Improve error message for unterminated strings with escapes.
bpo-45759: Improved error messages for
elif/elsestatements not matching any valid statements. Patch by Jeremiah Vivian.
Library¶
gh-111942: Fix SystemError in the TextIOWrapper constructor with non-encodable “errors” argument in non-debug mode.
gh-111995: Added the
NI_IDNconstant to thesocketmodule when present in C at build time for use withsocket.getnameinfo().gh-109538: Issue warning message instead of having
RuntimeErrorbe displayed when event loop has already been closed atStreamWriter.__del__().gh-111942: Fix crashes in
io.TextIOWrapper.reconfigure()when pass invalid arguments, e.g. non-string encoding.gh-111460:
curses: restore wide character support (includingcurses.unget_wch()andget_wch()) on macOS, which was unavailable due to a regression in Python 3.12.gh-103791:
contextlib.suppressnow supports suppressing exceptions raised as part of aBaseExceptionGroup, in addition to the recent support forExceptionGroup.gh-111835: The
mmap.mmapclass now has anseekable()method that can be used when a seekable file-like object is required. Theseek()method now returns the new absolute position. Patch by Donghee Na.gh-111804: Remove posix.fallocate() under WASI as the underlying posix_fallocate() is not available in WASI preview2.
gh-111841: Fix truncating arguments on an embedded null character in
os.putenv()andos.unsetenv()on Windows.gh-111768:
wsgiref.util.is_hop_by_hop()is now exposed correctly in__all__.gh-80731: Avoid executing the default function in
cmd.Cmdin an except blockgh-111541: Fix
doctestforSyntaxErrornot-builtin subclasses.gh-111719: Add extra argument validation for
aliascommand inpdbgh-111482:
time: Maketime.clock_gettime()andtime.clock_gettime_ns()functions up to 2x faster by faster calling convention. Patch by Victor Stinner.gh-110894: Call loop exception handler for exceptions in
client_connected_cbofasyncio.start_server()so that applications can handle it. Patch by Kumar Aditya.gh-111531: Fix reference leaks in
bind_class()andbind_all()methods oftkinterwidgets.gh-111246:
asyncio.loop.create_unix_server()will now automatically remove the Unix socket when the server is closed.gh-111356: Added
io.text_encoding(),io.DEFAULT_BUFFER_SIZE, andio.IncrementalNewlineDecodertoio.__all__.gh-66425: Remove the code to set the REMOTE_HOST header from wsgiref module, as it is unreachable. This header is used for performance reasons, which is not necessary in the wsgiref module.
gh-111429: Speed up
pathlib.PurePath.relative_to()andis_relative_to().gh-111342: Fixed typo in
math.sumprod().gh-68166: Remove mention of not supported “vsapi” element type in
tkinter.ttk.Style.element_create(). Add tests forelement_create()and otherttk.Stylemethods. Add examples forelement_create()in the documentation.gh-111388: Add
show_groupparameter totraceback.format_exception_only(), which allows to formatExceptionGroupinstances.gh-79033: Another attempt at fixing
asyncio.Server.wait_closed(). It now blocks until both conditions are true: the server is closed, and there are no more active connections. (This means that in some cases where in 3.12.0 this function would incorrectly have returned immediately, it will now block; in particular, when there are no active connections but the server hasn’t been closed yet.)gh-111295: Fix
timenot checking for errors when initializing.gh-111253: Add error checking during
_socketmodule init.gh-111251: Fix
_blake2not checking for errors when initializing.gh-111233: Fix
selectnot checking for errors when initializing.gh-111230: Fix
sslnot checking for errors when initializing.gh-111174: Fix crash in
io.BytesIO.getbuffer()called repeatedly for empty BytesIO.gh-111187: Postpone removal version for locale.getdefaultlocale() to Python 3.15.
gh-111159: Fix
doctestoutput comparison for exceptions with notes.gh-110910: Fix invalid state handling in
asyncio.TaskGroupandasyncio.Timeout. They now raise proper RuntimeError if they are improperly used and are left in consistent state after this.gh-111092: Make turtledemo run without default root enabled.
gh-110944: Support alias and convenience vars for
pdbcompletiongh-110745: Added newline parameter to
pathlib.Path.read_text(). Patch by Junya Okabe.gh-84583: Make
pdbenter post-mortem mode even forSyntaxErrorgh-80675: Set
f_trace_lines = Trueon all frames uponpdb.set_trace()gh-110771: Expose the setup and cleanup portions of
asyncio.run_forever()as the standalone methodsasyncio.run_forever_setup()andasyncio.run_forever_cleanup(). This allows for tighter integration with GUI event loops.gh-110774: Support setting the
asyncio.Runnerloop_factory kwarg inunittest.IsolatedAsyncioTestCasegh-110392: Fix
tty.setraw()andtty.setcbreak(): previously they returned partially modified list of the original tty attributes.tty.cfmakeraw()andtty.cfmakecbreak()now make a copy of the list of special characters before modifying it.gh-59013: Make line number of function breakpoint more precise in
pdbgh-88434: Emit deprecation warning for non-integer numbers in
gettextfunctions and methods that consider plural forms even if the translation was not found.gh-110395: Ensure that
select.kqueue()objects correctly appear as closed in forked children, to prevent operations on an invalid file descriptor.gh-110196: Add
__reduce__method toIPv6Addressin order to keepscope_idgh-109747: Improve errors for unsupported look-behind patterns. Now re.error is raised instead of OverflowError or RuntimeError for too large width of look-behind pattern.
gh-109466: Add the
ipaddress.IPv4Address.ipv6_mappedproperty, which returns the IPv4-mapped IPv6 address.gh-85098: Implement the CLI of the
symtablemodule and improve the repr ofSymbol.gh-108791: Improved error handling in
pdbcommand line interface, making it produce more concise error messages.gh-105931: Change
compileallto only strip the stripdir prefix from the full path recorded in the compiled.pycfile, when the prefix matches the start of the full path in its entirety. When the prefix does not match, no stripping is performed and a warning to this effect is displayed.Previously all path components of the stripdir prefix that matched the full path were removed, while those that did not match were left alone (including ones interspersed between matching components).
gh-107431: Make the
DictProxyandListProxytypes inmultiprocessing.managersGeneric Alias Types for[]use in typing contexts.gh-72904: Add
glob.translate(). This function converts a pathname with shell-style wildcards to a regular expression.gh-90026: Define
USE_XATTRSon Cygwin so that XATTR-related functions in theosmodule become available.gh-90890: New methods
mailbox.Maildir.get_info(),mailbox.Maildir.set_info(),mailbox.Maildir.get_flags(),mailbox.Maildir.set_flags(),mailbox.Maildir.add_flag(),mailbox.Maildir.remove_flag(). These methods speed up accessing a message’s info and/or flags and are useful when it is not necessary to access the message’s contents, as when iterating over a Maildir to find messages with specific flags.gh-102956: Fix returning of empty byte strings after seek in zipfile module
gh-102895: Added a parameter
local_exitforcode.interact()to preventexit()andquitfrom closingsys.stdinand raiseSystemExit.gh-97928: Change the behavior of
tkinter.Text.count(). It now always returns an integer if one or less counting options are specified. Previously it could return a single count as a 1-tuple, an integer (only if option"update"was specified) orNoneif no items found. The result is now the same ifwantobjectsis set to0.gh-96954: Switch the storage of the unicode codepoint names to use a different data-structure, a directed acyclic word graph. This makes the unicodedata shared library about 440 KiB smaller. Contributed by Carl Friedrich Bolz-Tereick using code from the PyPy project.
gh-73561: Omit the interface scope from an IPv6 address when used as Host header by
http.client.gh-86826:
zipinfonow supports the full range of values in the TZ string determined by RFC 8536 and detects all invalid formats. Both Python and C implementations now raise exceptions of the same type on invalid data.
Tests¶
gh-111808: Make the default value of
test.support.infinite_recursion()to be conditional based on whether optimizations were used when compiling the interpreter. This helps with platforms like WASI whose stack size is greatly restricted in debug builds.gh-110722: Gathering line coverage of standard libraries within the regression test suite is now precise, as well as much faster. Patch by Łukasz Langa.
gh-110367: Make regrtest
--verbose3option compatible with--huntrleaks -jNoptions. The./python -m test -j1 -R 3:3 --verbose3command now works as expected. Patch by Victor Stinner.gh-111165: Remove no longer used functions
run_unittest()andrun_doctest()from thetest.supportmodule.gh-110932: Fix regrtest if the
SOURCE_DATE_EPOCHenvironment variable is defined: use the variable value as the random seed. Patch by Victor Stinner.gh-110995: test_gdb: Fix detection of gdb built without Python scripting support. Patch by Victor Stinner.
gh-110918: Test case matching patterns specified by options
--match,--ignore,--matchfileand--ignorefileare now tested in the order of specification, and the last match determines whether the test case be run or ignored.gh-108747: Add unit test for
usercustomizeandsitecustomizehooks fromsite.