diff options
45 files changed, 5202 insertions, 14783 deletions
diff --git a/Doc/tutorial/interpreter.rst b/Doc/tutorial/interpreter.rst index faf57a3..c97f5d8 100644 --- a/Doc/tutorial/interpreter.rst +++ b/Doc/tutorial/interpreter.rst @@ -10,13 +10,13 @@ Using the Python Interpreter Invoking the Interpreter ======================== -The Python interpreter is usually installed as :file:`/usr/local/bin/python3.6` +The Python interpreter is usually installed as :file:`/usr/local/bin/python3.7` on those machines where it is available; putting :file:`/usr/local/bin` in your Unix shell's search path makes it possible to start it by typing the command: .. code-block:: text - python3.6 + python3.7 to the shell. [#]_ Since the choice of the directory where the interpreter lives is an installation option, other places are possible; check with your local @@ -98,8 +98,8 @@ before printing the first prompt: .. code-block:: shell-session - $ python3.6 - Python 3.6 (default, Sep 16 2015, 09:25:04) + $ python3.7 + Python 3.7 (default, Sep 16 2015, 09:25:04) [GCC 4.8.2] on linux Type "help", "copyright", "credits" or "license" for more information. >>> diff --git a/Doc/tutorial/stdlib.rst b/Doc/tutorial/stdlib.rst index 1dd06c2..6ac29fc 100644 --- a/Doc/tutorial/stdlib.rst +++ b/Doc/tutorial/stdlib.rst @@ -15,7 +15,7 @@ operating system:: >>> import os >>> os.getcwd() # Return the current working directory - 'C:\\Python36' + 'C:\\Python37' >>> os.chdir('/server/accesslogs') # Change current working directory >>> os.system('mkdir today') # Run the command mkdir in the system shell 0 diff --git a/Doc/tutorial/stdlib2.rst b/Doc/tutorial/stdlib2.rst index bf4cf87..feaff8a 100644 --- a/Doc/tutorial/stdlib2.rst +++ b/Doc/tutorial/stdlib2.rst @@ -278,7 +278,7 @@ applications include caching objects that are expensive to create:: Traceback (most recent call last): File "<stdin>", line 1, in <module> d['primary'] # entry was automatically removed - File "C:/python36/lib/weakref.py", line 46, in __getitem__ + File "C:/python37/lib/weakref.py", line 46, in __getitem__ o = self.data[key]() KeyError: 'primary' diff --git a/Doc/whatsnew/3.7.rst b/Doc/whatsnew/3.7.rst new file mode 100644 index 0000000..0b54019 --- /dev/null +++ b/Doc/whatsnew/3.7.rst @@ -0,0 +1,115 @@ +**************************** + What's New In Python 3.7 +**************************** + +:Release: |release| +:Date: |today| + +.. Rules for maintenance: + + * Anyone can add text to this document. Do not spend very much time + on the wording of your changes, because your text will probably + get rewritten to some degree. + + * The maintainer will go through Misc/NEWS periodically and add + changes; it's therefore more important to add your changes to + Misc/NEWS than to this file. + + * This is not a complete list of every single change; completeness + is the purpose of Misc/NEWS. Some changes I consider too small + or esoteric to include. If such a change is added to the text, + I'll just remove it. (This is another reason you shouldn't spend + too much time on writing your addition.) + + * If you want to draw your new text to the attention of the + maintainer, add 'XXX' to the beginning of the paragraph or + section. + + * It's OK to just add a fragmentary note about a change. For + example: "XXX Describe the transmogrify() function added to the + socket module." The maintainer will research the change and + write the necessary text. + + * You can comment out your additions if you like, but it's not + necessary (especially when a final release is some months away). + + * Credit the author of a patch or bugfix. Just the name is + sufficient; the e-mail address isn't necessary. + + * It's helpful to add the bug/patch number as a comment: + + XXX Describe the transmogrify() function added to the socket + module. + (Contributed by P.Y. Developer in :issue:`12345`.) + + This saves the maintainer the effort of going through the Mercurial log + when researching a change. + +This article explains the new features in Python 3.7, compared to 3.6. + +For full details, see the :source:`Misc/NEWS` file. + +.. note:: + + Prerelease users should be aware that this document is currently in draft + form. It will be updated substantially as Python 3.7 moves towards release, + so it's worth checking back even after reading earlier versions. + + +Summary -- Release highlights +============================= + +.. This section singles out the most important changes in Python 3.7. + Brevity is key. + + +.. PEP-sized items next. + + + +New Features +============ + + + +Other Language Changes +====================== + + + +New Modules +=========== + +* None yet. + + +Improved Modules +================ + + +Optimizations +============= + + +Build and C API Changes +======================= + + + +Deprecated +========== + + + +Removed +======= + + + +Porting to Python 3.7 +===================== + +This section lists previously described changes and other bugfixes +that may require changes to your code. + + diff --git a/Doc/whatsnew/index.rst b/Doc/whatsnew/index.rst index 7c92524..160b364 100644 --- a/Doc/whatsnew/index.rst +++ b/Doc/whatsnew/index.rst @@ -11,6 +11,7 @@ anyone wishing to stay up-to-date after a new release. .. toctree:: :maxdepth: 2 + 3.7.rst 3.6.rst 3.5.rst 3.4.rst diff --git a/Include/patchlevel.h b/Include/patchlevel.h index b623508..9644b1a 100644 --- a/Include/patchlevel.h +++ b/Include/patchlevel.h @@ -17,13 +17,13 @@ /* Version parsed out into numeric values */ /*--start constants--*/ #define PY_MAJOR_VERSION 3 -#define PY_MINOR_VERSION 6 +#define PY_MINOR_VERSION 7 #define PY_MICRO_VERSION 0 -#define PY_RELEASE_LEVEL PY_RELEASE_LEVEL_BETA -#define PY_RELEASE_SERIAL 1 +#define PY_RELEASE_LEVEL PY_RELEASE_LEVEL_ALPHA +#define PY_RELEASE_SERIAL 0 /* Version as a string */ -#define PY_VERSION "3.6.0b1+" +#define PY_VERSION "3.7.0a0" /*--end constants--*/ /* Version as a single 4-byte hex number, e.g. 0x010502B2 == 1.5.2b2. diff --git a/Lib/test/pystone.py b/Lib/test/pystone.py deleted file mode 100755 index cf1692e..0000000 --- a/Lib/test/pystone.py +++ /dev/null @@ -1,277 +0,0 @@ -#! /usr/bin/env python3 - -""" -"PYSTONE" Benchmark Program - -Version: Python/1.2 (corresponds to C/1.1 plus 3 Pystone fixes) - -Author: Reinhold P. Weicker, CACM Vol 27, No 10, 10/84 pg. 1013. - - Translated from ADA to C by Rick Richardson. - Every method to preserve ADA-likeness has been used, - at the expense of C-ness. - - Translated from C to Python by Guido van Rossum. - -Version History: - - Version 1.1 corrects two bugs in version 1.0: - - First, it leaked memory: in Proc1(), NextRecord ends - up having a pointer to itself. I have corrected this - by zapping NextRecord.PtrComp at the end of Proc1(). - - Second, Proc3() used the operator != to compare a - record to None. This is rather inefficient and not - true to the intention of the original benchmark (where - a pointer comparison to None is intended; the != - operator attempts to find a method __cmp__ to do value - comparison of the record). Version 1.1 runs 5-10 - percent faster than version 1.0, so benchmark figures - of different versions can't be compared directly. - - Version 1.2 changes the division to floor division. - - Under Python 3 version 1.1 would use the normal division - operator, resulting in some of the operations mistakenly - yielding floats. Version 1.2 instead uses floor division - making the benchmark an integer benchmark again. - -""" - -LOOPS = 50000 - -from time import time - -__version__ = "1.2" - -[Ident1, Ident2, Ident3, Ident4, Ident5] = range(1, 6) - -class Record: - - def __init__(self, PtrComp = None, Discr = 0, EnumComp = 0, - IntComp = 0, StringComp = 0): - self.PtrComp = PtrComp - self.Discr = Discr - self.EnumComp = EnumComp - self.IntComp = IntComp - self.StringComp = StringComp - - def copy(self): - return Record(self.PtrComp, self.Discr, self.EnumComp, - self.IntComp, self.StringComp) - -TRUE = 1 -FALSE = 0 - -def main(loops=LOOPS): - benchtime, stones = pystones(loops) - print("Pystone(%s) time for %d passes = %g" % \ - (__version__, loops, benchtime)) - print("This machine benchmarks at %g pystones/second" % stones) - - -def pystones(loops=LOOPS): - return Proc0(loops) - -IntGlob = 0 -BoolGlob = FALSE -Char1Glob = '\0' -Char2Glob = '\0' -Array1Glob = [0]*51 -Array2Glob = [x[:] for x in [Array1Glob]*51] -PtrGlb = None -PtrGlbNext = None - -def Proc0(loops=LOOPS): - global IntGlob - global BoolGlob - global Char1Glob - global Char2Glob - global Array1Glob - global Array2Glob - global PtrGlb - global PtrGlbNext - - starttime = time() - for i in range(loops): - pass - nulltime = time() - starttime - - PtrGlbNext = Record() - PtrGlb = Record() - PtrGlb.PtrComp = PtrGlbNext - PtrGlb.Discr = Ident1 - PtrGlb.EnumComp = Ident3 - PtrGlb.IntComp = 40 - PtrGlb.StringComp = "DHRYSTONE PROGRAM, SOME STRING" - String1Loc = "DHRYSTONE PROGRAM, 1'ST STRING" - Array2Glob[8][7] = 10 - - starttime = time() - - for i in range(loops): - Proc5() - Proc4() - IntLoc1 = 2 - IntLoc2 = 3 - String2Loc = "DHRYSTONE PROGRAM, 2'ND STRING" - EnumLoc = Ident2 - BoolGlob = not Func2(String1Loc, String2Loc) - while IntLoc1 < IntLoc2: - IntLoc3 = 5 * IntLoc1 - IntLoc2 - IntLoc3 = Proc7(IntLoc1, IntLoc2) - IntLoc1 = IntLoc1 + 1 - Proc8(Array1Glob, Array2Glob, IntLoc1, IntLoc3) - PtrGlb = Proc1(PtrGlb) - CharIndex = 'A' - while CharIndex <= Char2Glob: - if EnumLoc == Func1(CharIndex, 'C'): - EnumLoc = Proc6(Ident1) - CharIndex = chr(ord(CharIndex)+1) - IntLoc3 = IntLoc2 * IntLoc1 - IntLoc2 = IntLoc3 // IntLoc1 - IntLoc2 = 7 * (IntLoc3 - IntLoc2) - IntLoc1 - IntLoc1 = Proc2(IntLoc1) - - benchtime = time() - starttime - nulltime - if benchtime == 0.0: - loopsPerBenchtime = 0.0 - else: - loopsPerBenchtime = (loops / benchtime) - return benchtime, loopsPerBenchtime - -def Proc1(PtrParIn): - PtrParIn.PtrComp = NextRecord = PtrGlb.copy() - PtrParIn.IntComp = 5 - NextRecord.IntComp = PtrParIn.IntComp - NextRecord.PtrComp = PtrParIn.PtrComp - NextRecord.PtrComp = Proc3(NextRecord.PtrComp) - if NextRecord.Discr == Ident1: - NextRecord.IntComp = 6 - NextRecord.EnumComp = Proc6(PtrParIn.EnumComp) - NextRecord.PtrComp = PtrGlb.PtrComp - NextRecord.IntComp = Proc7(NextRecord.IntComp, 10) - else: - PtrParIn = NextRecord.copy() - NextRecord.PtrComp = None - return PtrParIn - -def Proc2(IntParIO): - IntLoc = IntParIO + 10 - while 1: - if Char1Glob == 'A': - IntLoc = IntLoc - 1 - IntParIO = IntLoc - IntGlob - EnumLoc = Ident1 - if EnumLoc == Ident1: - break - return IntParIO - -def Proc3(PtrParOut): - global IntGlob - - if PtrGlb is not None: - PtrParOut = PtrGlb.PtrComp - else: - IntGlob = 100 - PtrGlb.IntComp = Proc7(10, IntGlob) - return PtrParOut - -def Proc4(): - global Char2Glob - - BoolLoc = Char1Glob == 'A' - BoolLoc = BoolLoc or BoolGlob - Char2Glob = 'B' - -def Proc5(): - global Char1Glob - global BoolGlob - - Char1Glob = 'A' - BoolGlob = FALSE - -def Proc6(EnumParIn): - EnumParOut = EnumParIn - if not Func3(EnumParIn): - EnumParOut = Ident4 - if EnumParIn == Ident1: - EnumParOut = Ident1 - elif EnumParIn == Ident2: - if IntGlob > 100: - EnumParOut = Ident1 - else: - EnumParOut = Ident4 - elif EnumParIn == Ident3: - EnumParOut = Ident2 - elif EnumParIn == Ident4: - pass - elif EnumParIn == Ident5: - EnumParOut = Ident3 - return EnumParOut - -def Proc7(IntParI1, IntParI2): - IntLoc = IntParI1 + 2 - IntParOut = IntParI2 + IntLoc - return IntParOut - -def Proc8(Array1Par, Array2Par, IntParI1, IntParI2): - global IntGlob - - IntLoc = IntParI1 + 5 - Array1Par[IntLoc] = IntParI2 - Array1Par[IntLoc+1] = Array1Par[IntLoc] - Array1Par[IntLoc+30] = IntLoc - for IntIndex in range(IntLoc, IntLoc+2): - Array2Par[IntLoc][IntIndex] = IntLoc - Array2Par[IntLoc][IntLoc-1] = Array2Par[IntLoc][IntLoc-1] + 1 - Array2Par[IntLoc+20][IntLoc] = Array1Par[IntLoc] - IntGlob = 5 - -def Func1(CharPar1, CharPar2): - CharLoc1 = CharPar1 - CharLoc2 = CharLoc1 - if CharLoc2 != CharPar2: - return Ident1 - else: - return Ident2 - -def Func2(StrParI1, StrParI2): - IntLoc = 1 - while IntLoc <= 1: - if Func1(StrParI1[IntLoc], StrParI2[IntLoc+1]) == Ident1: - CharLoc = 'A' - IntLoc = IntLoc + 1 - if CharLoc >= 'W' and CharLoc <= 'Z': - IntLoc = 7 - if CharLoc == 'X': - return TRUE - else: - if StrParI1 > StrParI2: - IntLoc = IntLoc + 7 - return TRUE - else: - return FALSE - -def Func3(EnumParIn): - EnumLoc = EnumParIn - if EnumLoc == Ident3: return TRUE - return FALSE - -if __name__ == '__main__': - import sys - def error(msg): - print(msg, end=' ', file=sys.stderr) - print("usage: %s [number_of_loops]" % sys.argv[0], file=sys.stderr) - sys.exit(100) - nargs = len(sys.argv) - 1 - if nargs > 1: - error("%d arguments are too many;" % nargs) - elif nargs == 1: - try: loops = int(sys.argv[1]) - except ValueError: - error("Invalid argument %r;" % sys.argv[1]) - else: - loops = LOOPS - main(loops) diff --git a/Lib/zipfile.py b/Lib/zipfile.py index 7ba4e59..44e653d 100644 --- a/Lib/zipfile.py +++ b/Lib/zipfile.py @@ -1963,19 +1963,19 @@ def main(args = None): args = sys.argv[1:] if not args or args[0] not in ('-l', '-c', '-e', '-t'): - print(USAGE) + print(USAGE, file=sys.stderr) sys.exit(1) if args[0] == '-l': if len(args) != 2: - print(USAGE) + print(USAGE, file=sys.stderr) sys.exit(1) with ZipFile(args[1], 'r') as zf: zf.printdir() elif args[0] == '-t': if len(args) != 2: - print(USAGE) + print(USAGE, file=sys.stderr) sys.exit(1) with ZipFile(args[1], 'r') as zf: badfile = zf.testzip() @@ -1985,7 +1985,7 @@ def main(args = None): elif args[0] == '-e': if len(args) != 3: - print(USAGE) + print(USAGE, file=sys.stderr) sys.exit(1) with ZipFile(args[1], 'r') as zf: @@ -1993,7 +1993,7 @@ def main(args = None): elif args[0] == '-c': if len(args) < 3: - print(USAGE) + print(USAGE, file=sys.stderr) sys.exit(1) def addToZip(zf, path, zippath): @@ -505,7 +505,7 @@ Jan-Philip Gehrcke Thomas Gellekum Gabriel Genellina Christos Georgiou -Elazar Gershuni +Elazar (אלעזר) Gershuni Ben Gertzfield Nadim Ghaznavi Dinu Gherman @@ -1402,6 +1402,7 @@ Yann Sionneau George Sipe J. Sipprell Kragen Sitaker +Kaartic Sivaraam Ville Skyttä Michael Sloan Nick Sloan diff --git a/Misc/HISTORY b/Misc/HISTORY index fa2e3c7..6771bc4 100644 --- a/Misc/HISTORY +++ b/Misc/HISTORY @@ -8,6 +8,4307 @@ As you read on you go back to the dark ages of Python's history. ====================================================================== +What's New in Python 3.4.0? +=========================== + +Release date: 2014-03-16 + +Library +------- + +- Issue #20939: Fix test_geturl failure in test_urllibnet due to + new redirect of http://www.python.org/ to https://www.python.org. + +Documentation +------------- + +- Merge in all documentation changes since branching 3.4.0rc1. + + +What's New in Python 3.4.0 release candidate 3? +=============================================== + +Release date: 2014-03-09 + +Core and Builtins +----------------- + +- Issue #20786: Fix signatures for dict.__delitem__ and + property.__delete__ builtins. + +Library +------- + +- Issue #20839: Don't trigger a DeprecationWarning in the still supported + pkgutil.get_loader() API when __loader__ isn't set on a module (nor + when pkgutil.find_loader() is called directly). + +Build +----- + +- Issue #14512: Launch pydoc -b instead of pydocgui.pyw on Windows. + +- Issue #20748: Uninstalling pip does not leave behind the pyc of + the uninstaller anymore. + +- Issue #20568: The Windows installer now installs the unversioned ``pip`` + command in addition to the versioned ``pip3`` and ``pip3.4`` commands. + +- Issue #20757: The ensurepip helper for the Windows uninstaller now skips + uninstalling pip (rather than failing) if the user has updated pip to a + different version from the one bundled with ensurepip. + +- Issue #20465: Update OS X and Windows installer builds to use + SQLite 3.8.3.1. + + +What's New in Python 3.4.0 release candidate 2? +=============================================== + +Release date: 2014-02-23 + +Core and Builtins +----------------- + +- Issue #20625: Parameter names in __annotations__ were not mangled properly. + Discovered by Jonas Wielicki, patch by Yury Selivanov. + +- Issue #20261: In pickle, lookup __getnewargs__ and __getnewargs_ex__ on the + type of the object. + +- Issue #20619: Give the AST nodes of keyword-only arguments a column and line + number. + +- Issue #20526: Revert changes of issue #19466 which introduces a regression: + don't clear anymore the state of Python threads early during the Python + shutdown. + +Library +------- + +- Issue #20710: The pydoc summary line no longer displays the "self" parameter + for bound methods. + +- Issue #20566: Change asyncio.as_completed() to use a Queue, to + avoid O(N**2) behavior. + +- Issue #20704: Implement new debug API in asyncio. Add new methods + BaseEventLoop.set_debug() and BaseEventLoop.get_debug(). + Add support for setting 'asyncio.tasks._DEBUG' variable with + 'PYTHONASYNCIODEBUG' environment variable. + +- asyncio: Refactoring and fixes: BaseEventLoop.sock_connect() raises an + error if the address is not resolved; use __slots__ in Handle and + TimerHandle; as_completed() and wait() raise TypeError if the passed + list of Futures is a single Future; call_soon() and other 'call_*()' + functions raise TypeError if the passed callback is a coroutine + function; _ProactorBasePipeTransport uses _FlowControlMixin; + WriteTransport.set_write_buffer_size() calls _maybe_pause_protocol() + to consider pausing receiving if the watermark limits have changed; + fix _check_resolved_address() for IPv6 address; and other minor + improvements, along with multiple documentation updates. + +- Issue #20684: Fix inspect.getfullargspec() to not to follow __wrapped__ + chains. Make its behaviour consistent with bound methods first argument. + Patch by Nick Coghlan and Yury Selivanov. + +- Issue #20681: Add new error handling API in asyncio. New APIs: + loop.set_exception_handler(), loop.default_exception_handler(), and + loop.call_exception_handler(). + +- Issue #20673: Implement support for UNIX Domain Sockets in asyncio. + New APIs: loop.create_unix_connection(), loop.create_unix_server(), + streams.open_unix_connection(), and streams.start_unix_server(). + +- Issue #20616: Add a format() method to tracemalloc.Traceback. + +- Issue #19744: the ensurepip installation step now just prints a warning to + stderr rather than failing outright if SSL/TLS is unavailable. This allows + local installation of POSIX builds without SSL/TLS support. + +- Issue #20594: Avoid name clash with the libc function posix_close. + +Build +----- + +- Issue #20641: Run MSI custom actions (pip installation, pyc compilation) + with the NoImpersonate flag, to support elevated execution (UAC). + +- Issue #20221: Removed conflicting (or circular) hypot definition when + compiled with VS 2010 or above. Initial patch by Tabrez Mohammed. + +- Issue #20609: Restored the ability to build 64-bit Windows binaries on + 32-bit Windows, which was broken by the change in issue #19788. + + +What's New in Python 3.4.0 release candidate 1? +=============================================== + +Release date: 2014-02-10 + +Core and Builtins +----------------- + +- Issue #19255: The builtins module is restored to initial value before + cleaning other modules. The sys and builtins modules are cleaned last. + +- Issue #20588: Make Python-ast.c C89 compliant. + +- Issue #20437: Fixed 22 potential bugs when deleting object references. + +- Issue #20500: Displaying an exception at interpreter shutdown no longer + risks triggering an assertion failure in PyObject_Str. + +- Issue #20538: UTF-7 incremental decoder produced inconsistent string when + input was truncated in BASE64 section. + +- Issue #20404: io.TextIOWrapper (and hence the open() builtin) now uses the + internal codec marking system added for issue #19619 to throw LookupError + for known non-text encodings at stream construction time. The existing + output type checks remain in place to deal with unmarked third party + codecs. + +- Issue #17162: Add PyType_GetSlot. + +- Issue #20162: Fix an alignment issue in the siphash24() hash function which + caused a crash on PowerPC 64-bit (ppc64). + +Library +------- + +- Issue #20530: The signatures for slot builtins have been updated + to reflect the fact that they only accept positional-only arguments. + +- Issue #20517: Functions in the os module that accept two filenames + now register both filenames in the exception on failure. + +- Issue #20563: The ipaddress module API is now considered stable. + +- Issue #14983: email.generator now always adds a line end after each MIME + boundary marker, instead of doing so only when there is an epilogue. This + fixes an RFC compliance bug and solves an issue with signed MIME parts. + +- Issue #20540: Fix a performance regression (vs. Python 3.2) when layering + a multiprocessing Connection over a TCP socket. For small payloads, Nagle's + algorithm would introduce idle delays before the entire transmission of a + message. + +- Issue #16983: the new email header parsing code will now decode encoded words + that are (incorrectly) surrounded by quotes, and register a defect. + +- Issue #19772: email.generator no longer mutates the message object when + doing a down-transform from 8bit to 7bit CTEs. + +- Issue #20536: the statistics module now correctly handle Decimal instances + with positive exponents + +- Issue #18805: the netmask/hostmask parsing in ipaddress now more reliably + filters out illegal values and correctly allows any valid prefix length. + +- Issue #20481: For at least Python 3.4, the statistics module will require + that all inputs for a single operation be of a single consistent type, or + else a mixed of ints and a single other consistent type. This avoids + some interoperability issues that arose with the previous approach of + coercing to a suitable common type. + +- Issue #20478: the statistics module now treats collections.Counter inputs + like any other iterable. + +- Issue #17369: get_filename was raising an exception if the filename + parameter's RFC2231 encoding was broken in certain ways. This was + a regression relative to python2. + +- Issue #20013: Some imap servers disconnect if the current mailbox is + deleted, and imaplib did not handle that case gracefully. Now it + handles the 'bye' correctly. + +- Issue #20531: Revert 3.4 version of fix for #19063, and apply the 3.3 + version. That is, do *not* raise an error if unicode is passed to + email.message.Message.set_payload. + +- Issue #20476: If a non-compat32 policy is used with any of the email parsers, + EmailMessage is now used as the factory class. The factory class should + really come from the policy; that will get fixed in 3.5. + +- Issue #19920: TarFile.list() no longer fails when outputs a listing + containing non-encodable characters. Based on patch by Vajrasky Kok. + +- Issue #20515: Fix NULL pointer dereference introduced by issue #20368. + +- Issue #19186: Restore namespacing of expat symbols inside the pyexpat module. + +- Issue #20053: ensurepip (and hence venv) are no longer affected by the + settings in the default pip configuration file. + +- Issue #20426: When passing the re.DEBUG flag, re.compile() displays the + debug output every time it is called, regardless of the compilation cache. + +- Issue #20368: The null character now correctly passed from Tcl to Python. + Improved error handling in variables-related commands. + +- Issue #20435: Fix _pyio.StringIO.getvalue() to take into account newline + translation settings. + +- tracemalloc: Fix slicing traces and fix slicing a traceback. + +- Issue #20354: Fix an alignment issue in the tracemalloc module on 64-bit + platforms. Bug seen on 64-bit Linux when using "make profile-opt". + +- Issue #17159: inspect.signature now accepts duck types of functions, + which adds support for Cython functions. Initial patch by Stefan Behnel. + +- Issue #18801: Fix inspect.classify_class_attrs to correctly classify + object.__new__ and object.__init__. + +- Fixed cmath.isinf's name in its argument parsing code. + +- Issue #20311, #20452: poll and epoll now round the timeout away from zero, + instead of rounding towards zero, in select and selectors modules: + select.epoll.poll(), selectors.PollSelector.poll() and + selectors.EpollSelector.poll(). For example, a timeout of one microsecond + (1e-6) is now rounded to one millisecondi (1e-3), instead of being rounded to + zero. However, the granularity property and asyncio's resolution feature + were removed again. + +- asyncio: Some refactoring; various fixes; add write flow control to + unix pipes; Future.set_exception() instantiates the exception + argument if it is a class; improved proactor pipe transport; support + wait_for(f, None); don't log broken/disconnected pipes; use + ValueError instead of assert for forbidden subprocess_{shell,exec} + arguments; added a convenience API for subprocess management; added + StreamReader.at_eof(); properly handle duplicate coroutines/futures + in gather(), wait(), as_completed(); use a bytearray for buffering + in StreamReader; and more. + +- Issue #20288: fix handling of invalid numeric charrefs in HTMLParser. + +- Issue #20424: Python implementation of io.StringIO now supports lone surrogates. + +- Issue #20308: inspect.signature now works on classes without user-defined + __init__ or __new__ methods. + +- Issue #20372: inspect.getfile (and a bunch of other inspect functions that + use it) doesn't crash with unexpected AttributeError on classes defined in C + without __module__. + +- Issue #20356: inspect.signature formatting uses '/' to separate + positional-only parameters from others. + +- Issue #20223: inspect.signature now supports methods defined with + functools.partialmethods. + +- Issue #19456: ntpath.join() now joins relative paths correctly when a drive + is present. + +- Issue #19077: tempfile.TemporaryDirectory cleanup no longer fails when + called during shutdown. Emitting resource warning in __del__ no longer fails. + Original patch by Antoine Pitrou. + +- Issue #20394: Silence Coverity warning in audioop module. + +- Issue #20367: Fix behavior of concurrent.futures.as_completed() for + duplicate arguments. Patch by Glenn Langford. + +- Issue #8260: The read(), readline() and readlines() methods of + codecs.StreamReader returned incomplete data when were called after + readline() or read(size). Based on patch by Amaury Forgeot d'Arc. + +- Issue #20105: the codec exception chaining now correctly sets the + traceback of the original exception as its __traceback__ attribute. + +- Issue #17481: inspect.getfullargspec() now uses inspect.signature() API. + +- Issue #15304: concurrent.futures.wait() can block forever even if + Futures have completed. Patch by Glenn Langford. + +- Issue #14455: plistlib: fix serializing integers in the range + of an unsigned long long but outside of the range of signed long long for + binary plist files. + +IDLE +---- + +- Issue #20406: Use Python application icons for Idle window title bars. + Patch mostly by Serhiy Storchaka. + +- Update the python.gif icon for the Idle classbrowser and pathbowser + from the old green snake to the new blue and yellow snakes. + +- Issue #17721: Remove non-functional configuration dialog help button until we + make it actually gives some help when clicked. Patch by Guilherme Simões. + +Tests +----- + +- Issue #20532: Tests which use _testcapi now are marked as CPython only. + +- Issue #19920: Added tests for TarFile.list(). Based on patch by Vajrasky Kok. + +- Issue #19990: Added tests for the imghdr module. Based on patch by + Claudiu Popa. + +- Issue #20474: Fix test_socket "unexpected success" failures on OS X 10.7+. + +Tools/Demos +----------- + +- Issue #20530: Argument Clinic's signature format has been revised again. + The new syntax is highly human readable while still preventing false + positives. The syntax also extends Python syntax to denote "self" and + positional-only parameters, allowing inspect.Signature objects to be + totally accurate for all supported builtins in Python 3.4. + +- Issue #20456: Argument Clinic now observes the C preprocessor conditional + compilation statements of the C files it parses. When a Clinic block is + inside a conditional code, it adjusts its output to match, including + automatically generating an empty methoddef macro. + +- Issue #20456: Cloned functions in Argument Clinic now use the correct + name, not the name of the function they were cloned from, for text + strings inside generated code. + +- Issue #20456: Fixed Argument Clinic's test suite and "--converters" feature. + +- Issue #20456: Argument Clinic now allows specifying different names + for a parameter in Python and C, using "as" on the parameter line. + +- Issue #20326: Argument Clinic now uses a simple, unique signature to + annotate text signatures in docstrings, resulting in fewer false + positives. "self" parameters are also explicitly marked, allowing + inspect.Signature() to authoritatively detect (and skip) said parameters. + +- Issue #20326: Argument Clinic now generates separate checksums for the + input and output sections of the block, allowing external tools to verify + that the input has not changed (and thus the output is not out-of-date). + +Build +----- + +- Issue #20465: Update SQLite shipped with OS X installer to 3.8.3. + +C-API +----- + +- Issue #20517: Added new functions allowing OSError exceptions to reference + two filenames instead of one: PyErr_SetFromErrnoWithFilenameObjects() and + PyErr_SetExcFromWindowsErrWithFilenameObjects(). + +Documentation +------------- + +- Issue #20488: Change wording to say importlib is *the* implementation of + import instead of just *an* implementation. + +- Issue #6386: Clarify in the tutorial that specifying a symlink to execute + means the directory containing the executed script and not the symlink is + added to sys.path. + + +What's New in Python 3.4.0 Beta 3? +================================== + +Release date: 2014-01-26 + +Core and Builtins +----------------- + +- Issue #20189: Four additional builtin types (PyTypeObject, + PyMethodDescr_Type, _PyMethodWrapper_Type, and PyWrapperDescr_Type) + have been modified to provide introspection information for builtins. + +- Issue #17825: Cursor "^" is correctly positioned for SyntaxError and + IndentationError. + +- Issue #2382: SyntaxError cursor "^" is now written at correct position in most + cases when multibyte characters are in line (before "^"). This still not + works correctly with wide East Asian characters. + +- Issue #18960: The first line of Python script could be executed twice when + the source encoding was specified on the second line. Now the source encoding + declaration on the second line isn't effective if the first line contains + anything except a comment. 'python -x' works now again with files with the + source encoding declarations, and can be used to make Python batch files + on Windows. + +Library +------- + +- asyncio: Various improvements and small changes not all covered by + issues listed below. E.g. wait_for() now cancels the inner task if + the timeout occcurs; tweaked the set of exported symbols; renamed + Empty/Full to QueueEmpty/QueueFull; "with (yield from lock)" now + uses a separate context manager; readexactly() raises if not enough + data was read; PTY support tweaks. + +- Issue #20311: asyncio: Add a granularity attribute to BaseEventLoop: maximum + between the resolution of the BaseEventLoop.time() method and the resolution + of the selector. The granuarility is used in the scheduler to round time and + deadline. + +- Issue #20311: selectors: Add a resolution attribute to BaseSelector. + +- Issue #20189: unittest.mock now no longer assumes that any object for + which it could get an inspect.Signature is a callable written in Python. + Fix courtesy of Michael Foord. + +- Issue #20317: ExitStack.__exit__ could create a self-referential loop if an + exception raised by a cleanup operation already had its context set + correctly (for example, by the @contextmanager decorator). The infinite + loop this caused is now avoided by checking if the expected context is + already set before trying to fix it. + +- Issue #20374: Fix build with GNU readline >= 6.3. + +- Issue #20262: Warnings are raised now when duplicate names are added in the + ZIP file or too long ZIP file comment is truncated. + +- Issue #20165: The unittest module no longer considers tests marked with + @expectedFailure successful if they pass. + +- Issue #18574: Added missing newline in 100-Continue reply from + http.server.BaseHTTPRequestHandler. Patch by Nikolaus Rath. + +- Issue #20270: urllib.urlparse now supports empty ports. + +- Issue #20243: TarFile no longer raise ReadError when opened in write mode. + +- Issue #20238: TarFile opened with external fileobj and "w:gz" mode didn't + write complete output on close. + +- Issue #20245: The open functions in the tarfile module now correctly handle + empty mode. + +- Issue #20242: Fixed basicConfig() format strings for the alternative + formatting styles. Thanks to kespindler for the bug report and patch. + +- Issue #20246: Fix buffer overflow in socket.recvfrom_into. + +- Issues #20206 and #5803: Fix edge case in email.quoprimime.encode where it + truncated lines ending in a character needing encoding but no newline by + using a more efficient algorithm that doesn't have the bug. + +- Issue #19082: Working xmlrpc.server and xmlrpc.client examples. Both in + modules and in documentation. Initial patch contributed by Vajrasky Kok. + +- Issue #20138: The wsgiref.application_uri() and wsgiref.request_uri() + functions now conform to PEP 3333 when handle non-ASCII URLs. + +- Issue #19097: Raise the correct Exception when cgi.FieldStorage is given an + invalid fileobj. + +- Issue #20152: Ported Python/import.c over to Argument Clinic. + +- Issue #13107: argparse and optparse no longer raises an exception when output + a help on environment with too small COLUMNS. Based on patch by + Elazar Gershuni. + +- Issue #20207: Always disable SSLv2 except when PROTOCOL_SSLv2 is explicitly + asked for. + +- Issue #18960: The tokenize module now ignore the source encoding declaration + on the second line if the first line contains anything except a comment. + +- Issue #20078: Reading malformed zipfiles no longer hangs with 100% CPU + consumption. + +- Issue #20113: os.readv() and os.writev() now raise an OSError exception on + error instead of returning -1. + +- Issue #19719: Make importlib.abc.MetaPathFinder.find_module(), + PathEntryFinder.find_loader(), and Loader.load_module() use PEP 451 APIs to + help with backwards-compatibility. + +- Issue #20144: inspect.Signature now supports parsing simple symbolic + constants as parameter default values in __text_signature__. + +- Issue #20072: Fixed multiple errors in tkinter with wantobjects is False. + +- Issue #20229: Avoid plistlib deprecation warning in platform.mac_ver(). + +- Issue #14455: Fix some problems with the new binary plist support in plistlib. + +IDLE +---- + +- Issue #17390: Add Python version to Idle editor window title bar. + Original patches by Edmond Burnett and Kent Johnson. + +- Issue #18960: IDLE now ignores the source encoding declaration on the second + line if the first line contains anything except a comment. + +Tests +----- + +- Issue #20358: Tests for curses.window.overlay and curses.window.overwrite + no longer specify min{row,col} > max{row,col}. + +- Issue #19804: The test_find_mac test in test_uuid is now skipped if the + ifconfig executable is not available. + +- Issue #19886: Use better estimated memory requirements for bigmem tests. + +Tools/Demos +----------- + +- Issue #20390: Argument Clinic's "file" output preset now defaults to + "{dirname}/clinic/{basename}.h". + +- Issue #20390: Argument Clinic's "class" directive syntax has been extended + with two new required arguments: "typedef" and "type_object". + +- Issue #20390: Argument Clinic: If __new__ or __init__ functions didn't use + kwargs (or args), the PyArg_NoKeywords (or PyArg_NoPositional) calls + generated are only run when the type object is an exact match. + +- Issue #20390: Argument Clinic now fails if you have required parameters after + optional parameters. + +- Issue #20390: Argument Clinic converters now have a new template they can + inject code into: "modifiers". Code put there is run in the parsing + function after argument parsing but before the call to the impl. + +- Issue #20376: Argument Clinic now escapes backslashes in docstrings. + +- Issue #20381: Argument Clinic now sanity checks the default argument when + c_default is also specified, providing a nice failure message for + disallowed values. + +- Issue #20189: Argument Clinic now ensures that parser functions for + __new__ are always of type newfunc, the type of the tp_new slot. + Similarly, parser functions for __init__ are now always of type initproc, + the type of tp_init. + +- Issue #20189: Argument Clinic now suppresses the docstring for __new__ + and __init__ functions if no docstring is provided in the input. + +- Issue #20189: Argument Clinic now suppresses the "self" parameter in the + impl for @staticmethod functions. + +- Issue #20294: Argument Clinic now supports argument parsing for __new__ and + __init__ functions. + +- Issue #20299: Argument Clinic custom converters may now change the default + value of c_default and py_default with a class member. + +- Issue #20287: Argument Clinic's output is now configurable, allowing + delaying its output or even redirecting it to a separate file. + +- Issue #20226: Argument Clinic now permits simple expressions + (e.g. "sys.maxsize - 1") as default values for parameters. + +- Issue #19936: Added executable bits or shebang lines to Python scripts which + requires them. Disable executable bits and shebang lines in test and + benchmark files in order to prevent using a random system python, and in + source files of modules which don't provide command line interface. Fixed + shebang lines in the unittestgui and checkpip scripts. + +- Issue #20268: Argument Clinic now supports cloning the parameters and + return converter of existing functions. + +- Issue #20228: Argument Clinic now has special support for class special + methods. + +- Issue #20214: Fixed a number of small issues and documentation errors in + Argument Clinic (see issue for details). + +- Issue #20196: Fixed a bug where Argument Clinic did not generate correct + parsing code for functions with positional-only parameters where all arguments + are optional. + +- Issue #18960: 2to3 and the findnocoding.py script now ignore the source + encoding declaration on the second line if the first line contains anything + except a comment. + +- Issue #19723: The marker comments Argument Clinic uses have been changed + to improve readability. + +- Issue #20157: When Argument Clinic renames a parameter because its name + collides with a C keyword, it no longer exposes that rename to PyArg_Parse. + +- Issue #20141: Improved Argument Clinic's support for the PyArg_Parse "O!" + format unit. + +- Issue #20144: Argument Clinic now supports simple symbolic constants + as parameter default values. + +- Issue #20143: The line numbers reported in Argument Clinic errors are + now more accurate. + +- Issue #20142: Py_buffer variables generated by Argument Clinic are now + initialized with a default value. + +Build +----- + +- Issue #12837: Silence a tautological comparison warning on OS X under Clang in + socketmodule.c. + + +What's New in Python 3.4.0 Beta 2? +================================== + +Release date: 2014-01-05 + +Core and Builtins +----------------- + +- Issue #17432: Drop UCS2 from names of Unicode functions in python3.def. + +- Issue #19526: Exclude all new API from the stable ABI. Exceptions can be + made if a need is demonstrated. + +- Issue #19969: PyBytes_FromFormatV() now raises an OverflowError if "%c" + argument is not in range [0; 255]. + +- Issue #19995: %c, %o, %x, and %X now issue a DeprecationWarning on non-integer + input; reworded docs to clarify that an integer type should define both __int__ + and __index__. + +- Issue #19787: PyThread_set_key_value() now always set the value. In Python + 3.3, the function did nothing if the key already exists (if the current value + is a non-NULL pointer). + +- Issue #14432: Remove the thread state field from the frame structure. Fix a + crash when a generator is created in a C thread that is destroyed while the + generator is still used. The issue was that a generator contains a frame, and + the frame kept a reference to the Python state of the destroyed C thread. The + crash occurs when a trace function is setup. + +- Issue #19576: PyGILState_Ensure() now initializes threads. At startup, Python + has no concrete GIL. If PyGILState_Ensure() is called from a new thread for + the first time and PyEval_InitThreads() was not called yet, a GIL needs to be + created. + +- Issue #17576: Deprecation warning emitted now when __int__() or __index__() + return not int instance. + +- Issue #19932: Fix typo in import.h, missing whitespaces in function prototypes. + +- Issue #19736: Add module-level statvfs constants defined for GNU/glibc + based systems. + +- Issue #20097: Fix bad use of "self" in importlib's WindowsRegistryFinder. + +- Issue #19729: In str.format(), fix recursive expansion in format spec. + +- Issue #19638: Fix possible crash / undefined behaviour from huge (more than 2 + billion characters) input strings in _Py_dg_strtod. + +Library +------- + +- Issue #20154: Deadlock in asyncio.StreamReader.readexactly(). + +- Issue #16113: Remove sha3 module again. + +- Issue #20111: pathlib.Path.with_suffix() now sanity checks the given suffix. + +- Fix breakage in TestSuite.countTestCases() introduced by issue #11798. + +- Issue #20108: Avoid parameter name clash in inspect.getcallargs(). + +- Issue #19918: Fix PurePath.relative_to() under Windows. + +- Issue #19422: Explicitly disallow non-SOCK_STREAM sockets in the ssl + module, rather than silently let them emit clear text data. + +- Issue #20046: Locale alias table no longer contains entities which can be + calculated. Generalized support of the euro modifier. + +- Issue #20027: Fixed locale aliases for devanagari locales. + +- Issue #20067: Tkinter variables now work when wantobjects is false. + +- Issue #19020: Tkinter now uses splitlist() instead of split() in configure + methods. + +- Issue #19744: ensurepip now provides a better error message when Python is + built without SSL/TLS support (pip currently requires that support to run, + even if only operating with local wheel files) + +- Issue #19734: ensurepip now ignores all pip environment variables to avoid + odd behaviour based on user configuration settings + +- Fix TypeError on "setup.py upload --show-response". + +- Issue #20045: Fix "setup.py register --list-classifiers". + +- Issue #18879: When a method is looked up on a temporary file, avoid closing + the file before the method is possibly called. + +- Issue #20037: Avoid crashes when opening a text file late at interpreter + shutdown. + +- Issue #19967: Thanks to the PEP 442, asyncio.Future now uses a + destructor to log uncaught exceptions, instead of the dedicated + _TracebackLogger class. + +- Added a Task.current_task() class method to asyncio. + +- Issue #19850: Set SA_RESTART in asyncio when registering a signal + handler to limit EINTR occurrences. + +- Implemented write flow control in asyncio for proactor event loop (Windows). + +- Change write buffer in asyncio use to avoid O(N**2) behavior. Make + write()/sendto() accept bytearray/memoryview. + +- Issue #20034: Updated alias mapping to most recent locale.alias file + from X.org distribution using makelocalealias.py. + +- Issue #5815: Fixed support for locales with modifiers. Fixed support for + locale encodings with hyphens. + +- Issue #20026: Fix the sqlite module to handle correctly invalid isolation + level (wrong type). + +- Issue #18829: csv.Dialect() now checks type for delimiter, escapechar and + quotechar fields. Original patch by Vajrasky Kok. + +- Issue #19855: uuid.getnode() on Unix now looks on the PATH for the + executables used to find the mac address, with /sbin and /usr/sbin as + fallbacks. + +- Issue #20007: HTTPResponse.read(0) no more prematurely closes connection. + Original patch by Simon Sapin. + +- Issue #19946: multiprocessing now uses runpy to initialize __main__ in + child processes when necessary, allowing it to correctly handle scripts + without suffixes and submodules that use explicit relative imports or + otherwise rely on parent modules being correctly imported prior to + execution. + +- Issue #19921: When Path.mkdir() is called with parents=True, any missing + parent is created with the default permissions, ignoring the mode argument + (mimicking the POSIX "mkdir -p" command). + +- Issue #19887: Improve the Path.resolve() algorithm to support certain + symlink chains. + +- Issue #19912: Fixed numerous bugs in ntpath.splitunc(). + +- Issue #19911: ntpath.splitdrive() now correctly processes the 'İ' character + (U+0130, LATIN CAPITAL LETTER I WITH DOT ABOVE). + +- Issue #19532: python -m compileall with no filename/directory arguments now + respects the -f and -q flags instead of ignoring them. + +- Issue #19623: Fixed writing to unseekable files in the aifc module. + +- Issue #19946: multiprocessing.spawn now raises ImportError when the module to + be used as the main module cannot be imported. + +- Issue #17919: select.poll.register() again works with poll.POLLNVAL on AIX. + Fixed integer overflow in the eventmask parameter. + +- Issue #19063: if a Charset's body_encoding was set to None, the email + package would generate a message claiming the Content-Transfer-Encoding + was 7bit, and produce garbage output for the content. This now works. + A couple of other set_payload mishandlings of non-ASCII are also fixed. + In addition, calling set_payload with a string argument without + specifying a charset now raises an error (this is a new error in 3.4). + +- Issue #15475: Add __sizeof__ implementations for itertools objects. + +- Issue #19944: Fix importlib.find_spec() so it imports parents as needed + and move the function to importlib.util. + +- Issue #19880: Fix a reference leak in unittest.TestCase. Explicitly break + reference cycles between frames and the _Outcome instance. + +- Issue #17429: platform.linux_distribution() now decodes files from the UTF-8 + encoding with the surrogateescape error handler, instead of decoding from the + locale encoding in strict mode. It fixes the function on Fedora 19 which is + probably the first major distribution release with a non-ASCII name. Patch + written by Toshio Kuratomi. + +- Issue #19343: Expose FreeBSD-specific APIs in resource module. Original + patch by Koobs. + +- Issue #19929: Call os.read with 32768 within subprocess.Popen.communicate + rather than 4096 for efficiency. A microbenchmark shows Linux and OS X + both using ~50% less cpu time this way. + +- Issue #19506: Use a memoryview to avoid a data copy when piping data + to stdin within subprocess.Popen.communicate. 5-10% less cpu usage. + +- Issue #19876: selectors unregister() no longer raises ValueError or OSError + if the FD is closed (as long as it was registered). + +- Issue #19908: pathlib now joins relative Windows paths correctly when a drive + is present. Original patch by Antoine Pitrou. + +- Issue #19296: Silence compiler warning in dbm_open + +- Issue #6784: Strings from Python 2 can now be unpickled as bytes + objects by setting the encoding argument of Unpickler to be 'bytes'. + Initial patch by Merlijn van Deen. + +- Issue #19839: Fix regression in bz2 module's handling of non-bzip2 data at + EOF, and analogous bug in lzma module. + +- Issue #19881: Fix pickling bug where cpickle would emit bad pickle data for + large bytes string (i.e., with size greater than 2**32-1). + +- Issue #19138: doctest's IGNORE_EXCEPTION_DETAIL now allows a match when + no exception detail exists (no colon following the exception's name, or + a colon does follow but no text follows the colon). + +- Issue #19927: Add __eq__ to path-based loaders in importlib. + +- Issue #19827: On UNIX, setblocking() and settimeout() methods of + socket.socket can now avoid a second syscall if the ioctl() function can be + used, or if the non-blocking flag of the socket is unchanged. + +- Issue #19785: smtplib now supports SSLContext.check_hostname and server name + indication for TLS/SSL connections. + +- Issue #19784: poplib now supports SSLContext.check_hostname and server name + indication for TLS/SSL connections. + +- Issue #19783: nntplib now supports SSLContext.check_hostname and server name + indication for TLS/SSL connections. + +- Issue #19782: imaplib now supports SSLContext.check_hostname and server name + indication for TLS/SSL connections. + +- Issue #20123: Fix pydoc.synopsis() for "binary" modules. + +- Issue #19834: Support unpickling of exceptions pickled by Python 2. + +- Issue #19781: ftplib now supports SSLContext.check_hostname and server name + indication for TLS/SSL connections. + +- Issue #19509: Add SSLContext.check_hostname to match the peer's certificate + with server_hostname on handshake. + +- Issue #15798: Fixed subprocess.Popen() to no longer fail if file + descriptor 0, 1 or 2 is closed. + +- Issue #17897: Optimized unpickle prefetching. + +- Issue #3693: Make the error message more helpful when the array.array() + constructor is given a str. Move the array module typecode documentation to + the docstring of the constructor. + +- Issue #19088: Fixed incorrect caching of the copyreg module in + object.__reduce__() and object.__reduce_ex__(). + +- Issue #19698: Removed exec_module() methods from + importlib.machinery.BuiltinImporter and ExtensionFileLoader. + +- Issue #18864: Added a setter for ModuleSpec.has_location. + +- Fixed _pickle.Unpickler to not fail when loading empty strings as + persistent IDs. + +- Issue #11480: Fixed copy.copy to work with classes with custom metaclasses. + Patch by Daniel Urban. + +- Issue #6477: Added support for pickling the types of built-in singletons + (i.e., Ellipsis, NotImplemented, None). + +- Issue #19713: Add remaining PEP 451-related deprecations and move away + from using find_module/find_loaer/load_module. + +- Issue #19708: Update pkgutil to use the new importer APIs. + +- Issue #19703: Update pydoc to use the new importer APIs. + +- Issue #19851: Fixed a regression in reloading sub-modules. + +- ssl.create_default_context() sets OP_NO_COMPRESSION to prevent CRIME. + +- Issue #19802: Add socket.SO_PRIORITY. + +- Issue #11508: Fixed uuid.getnode() and uuid.uuid1() on environment with + virtual interface. Original patch by Kent Frazier. + +- Issue #11489: JSON decoder now accepts lone surrogates. + +- Issue #19545: Avoid chained exceptions while passing stray % to + time.strptime(). Initial patch by Claudiu Popa. + +IDLE +---- + +- Issue #20058: sys.stdin.readline() in IDLE now always returns only one line. + +- Issue #19481: print() of string subclass instance in IDLE no longer hangs. + +- Issue #18270: Prevent possible IDLE AttributeError on OS X when no initial + shell window is present. + +Tests +----- + +- Issue #20055: Fix test_shutil under Windows with symlink privileges held. + Patch by Vajrasky Kok. + +- Issue #20070: Don't run test_urllib2net when network resources are not + enabled. + +- Issue #19938: Re-enabled test_bug_1333982 in test_dis, which had been + disabled since 3.0 due to the changes in listcomp handling. + +- Issue #19320: test_tcl no longer fails when wantobjects is false. + +- Issue #19919: Fix flaky SSL test. connect_ex() sometimes returns + EWOULDBLOCK on Windows or VMs hosted on Windows. + +- Issue #19912: Added tests for ntpath.splitunc(). + +- Issue #19828: Fixed test_site when the whole suite is run with -S. + +- Issue #19928: Implemented a test for repr() of cell objects. + +- Issue #19535: Fixed test_docxmlrpc, test_functools, test_inspect, and + test_statistics when python is run with -OO. + +- Issue #19926: Removed unneeded test_main from test_abstract_numbers. + Patch by Vajrasky Kok. + +- Issue #19572: More skipped tests explicitly marked as skipped. + +- Issue #19595, #19987: Re-enabled a long-disabled test in test_winsound. + +- Issue #19588: Fixed tests in test_random that were silently skipped most + of the time. Patch by Julian Gindi. + +Build +----- + +- Issue #19728: Enable pip installation by default on Windows. + +- Issue #16136: Remove VMS support + +- Issue #18215: Add script Tools/ssl/test_multiple_versions.py to compile and + run Python's unit tests with multiple versions of OpenSSL. + +- Issue #19922: define _INCLUDE__STDC_A1_SOURCE in HP-UX to include mbstate_t + for mbrtowc(). + +- Issue #19788: kill_python(_d).exe is now run as a PreBuildEvent on the + pythoncore sub-project. This should prevent build errors due a previous + build's python(_d).exe still running. + +Documentation +------------- + +- Issue #20265: Updated some parts of the Using Windows document. + +- Issue #20266: Updated some parts of the Windows FAQ. + +- Issue #20255: Updated the about and bugs pages. + +- Issue #20253: Fixed a typo in the ipaddress docs that advertised an + illegal attribute name. Found by INADA Naoki. + +- Issue #18840: Introduce the json module in the tutorial, and de-emphasize + the pickle module. + +- Issue #19845: Updated the Compiling Python on Windows section. + +- Issue #19795: Improved markup of True/False constants. + +Tools/Demos +----------- + +- Issue #19659: Added documentation for Argument Clinic. + +- Issue #19976: Argument Clinic METH_NOARGS functions now always + take two parameters. + + +What's New in Python 3.4.0 Beta 1? +================================== + +Release date: 2013-11-24 + +Core and Builtins +----------------- + +- Use the repr of a module name in more places in import, especially + exceptions. + +- Issue #19619: str.encode, bytes.decode and bytearray.decode now use an + internal API to throw LookupError for known non-text encodings, rather + than attempting the encoding or decoding operation and then throwing a + TypeError for an unexpected output type. (The latter mechanism remains + in place for third party non-text encodings) + +- Issue #19183: Implement PEP 456 'secure and interchangeable hash algorithm'. + Python now uses SipHash24 on all major platforms. + +- Issue #12892: The utf-16* and utf-32* encoders no longer allow surrogate code + points (U+D800-U+DFFF) to be encoded. The utf-32* decoders no longer decode + byte sequences that correspond to surrogate code points. The surrogatepass + error handler now works with the utf-16* and utf-32* codecs. Based on + patches by Victor Stinner and Kang-Hao (Kenny) Lu. + +- Issue #17806: Added keyword-argument support for "tabsize" to + str/bytes.expandtabs(). + +- Issue #17828: Output type errors in str.encode(), bytes.decode() and + bytearray.decode() now direct users to codecs.encode() or codecs.decode() + as appropriate. + +- Issue #17828: The interpreter now attempts to chain errors that occur in + codec processing with a replacement exception of the same type that + includes the codec name in the error message. It ensures it only does this + when the creation of the replacement exception won't lose any information. + +- Issue #19466: Clear the frames of daemon threads earlier during the + Python shutdown to call object destructors. So "unclosed file" resource + warnings are now correctly emitted for daemon threads. + +- Issue #19514: Deduplicate some _Py_IDENTIFIER declarations. + Patch by Andrei Dorian Duma. + +- Issue #17936: Fix O(n**2) behaviour when adding or removing many subclasses + of a given type. + +- Issue #19428: zipimport now handles errors when reading truncated or invalid + ZIP archive. + +- Issue #18408: Add a new PyFrame_FastToLocalsWithError() function to handle + exceptions when merging fast locals into f_locals of a frame. + PyEval_GetLocals() now raises an exception and return NULL on failure. + +- Issue #19369: Optimized the usage of __length_hint__(). + +- Issue #28026: Raise ImportError when exec_module() exists but + create_module() is missing. + +- Issue #18603: Ensure that PyOS_mystricmp and PyOS_mystrnicmp are in the + Python executable and not removed by the linker's optimizer. + +- Issue #19306: Add extra hints to the faulthandler module's stack + dumps that these are "upside down". + +Library +------- + +- Issue #3158: doctest can now find doctests in functions and methods + written in C. + +- Issue #13477: Added command line interface to the tarfile module. + Original patch by Berker Peksag. + +- Issue #19674: inspect.signature() now produces a correct signature + for some builtins. + +- Issue #19722: Added opcode.stack_effect(), which + computes the stack effect of bytecode instructions. + +- Issue #19735: Implement private function ssl._create_stdlib_context() to + create SSLContext objects in Python's stdlib module. It provides a single + configuration point and makes use of SSLContext.load_default_certs(). + +- Issue #16203: Add re.fullmatch() function and regex.fullmatch() method, + which anchor the pattern at both ends of the string to match. + Original patch by Matthew Barnett. + +- Issue #13592: Improved the repr for regular expression pattern objects. + Based on patch by Hugo Lopes Tavares. + +- Issue #19641: Added the audioop.byteswap() function to convert big-endian + samples to little-endian and vice versa. + +- Issue #15204: Deprecated the 'U' mode in file-like objects. + +- Issue #17810: Implement PEP 3154, pickle protocol 4. + +- Issue #19668: Added support for the cp1125 encoding. + +- Issue #19689: Add ssl.create_default_context() factory function. It creates + a new SSLContext object with secure default settings. + +- Issue #19727: os.utime(..., None) is now potentially more precise + under Windows. + +- Issue #17201: ZIP64 extensions now are enabled by default. Patch by + William Mallard. + +- Issue #19292: Add SSLContext.load_default_certs() to load default root CA + certificates from default stores or system stores. By default the method + loads CA certs for authentication of server certs. + +- Issue #19673: Add pathlib to the stdlib as a provisional module (PEP 428). + +- Issue #16596: pdb in a generator now properly skips over yield and + yield from rather than stepping out of the generator into its + caller. (This is essential for stepping through asyncio coroutines.) + +- Issue #17916: Added dis.Bytecode.from_traceback() and + dis.Bytecode.current_offset to easily display "current instruction" + markers in the new disassembly API (Patch by Claudiu Popa). + +- Issue #19552: venv now supports bootstrapping pip into virtual environments + +- Issue #17134: Finalize interface to Windows' certificate store. Cert and + CRL enumeration are now two functions. enum_certificates() also returns + purpose flags as set of OIDs. + +- Issue #19555: Restore sysconfig.get_config_var('SO'), (and the distutils + equivalent) with a DeprecationWarning pointing people at $EXT_SUFFIX. + +- Issue #8813: Add SSLContext.verify_flags to change the verification flags + of the context in order to enable certification revocation list (CRL) + checks or strict X509 rules. + +- Issue #18294: Fix the zlib module to make it 64-bit safe. + +- Issue #19682: Fix compatibility issue with old version of OpenSSL that + was introduced by Issue #18379. + +- Issue #14455: plistlib now supports binary plists and has an updated API. + +- Issue #19633: Fixed writing not compressed 16- and 32-bit wave files on + big-endian platforms. + +- Issue #18379: SSLSocket.getpeercert() returns CA issuer AIA fields, OCSP + and CRL distribution points. + +- Issue #18138: Implement cadata argument of SSLContext.load_verify_location() + to load CA certificates and CRL from memory. It supports PEM and DER + encoded strings. + +- Issue #18775: Add name and block_size attribute to HMAC object. They now + provide the same API elements as non-keyed cryptographic hash functions. + +- Issue #17276: MD5 as default digestmod for HMAC is deprecated. The HMAC + module supports digestmod names, e.g. hmac.HMAC('sha1'). + +- Issue #19449: in csv's writerow, handle non-string keys when generating the + error message that certain keys are not in the 'fieldnames' list. + +- Issue #13633: Added a new convert_charrefs keyword arg to HTMLParser that, + when True, automatically converts all character references. + +- Issue #2927: Added the unescape() function to the html module. + +- Issue #8402: Added the escape() function to the glob module. + +- Issue #17618: Add Base85 and Ascii85 encoding/decoding to the base64 module. + +- Issue #19634: time.strftime("%y") now raises a ValueError on AIX when given a + year before 1900. + +- Fix test.support.bind_port() to not cause an error when Python was compiled + on a system with SO_REUSEPORT defined in the headers but run on a system + with an OS kernel that does not support that reasonably new socket option. + +- Fix compilation error under gcc of the ctypes module bundled libffi for arm. + +- Issue #19448: Add private API to SSL module to lookup ASN.1 objects by OID, + NID, short name and long name. + +- Issue #19282: dbm.open now supports the context management protocol. + (Initial patch by Claudiu Popa) + +- Issue #8311: Added support for writing any bytes-like objects in the aifc, + sunau, and wave modules. + +- Issue #5202: Added support for unseekable files in the wave module. + +- Issue #19544 and Issue #1180: Restore global option to ignore + ~/.pydistutils.cfg in Distutils, accidentally removed in backout of + distutils2 changes. + +- Issue #19523: Closed FileHandler leak which occurred when delay was set. + +- Issue #19544 and Issue #6516: Restore support for --user and --group + parameters to sdist command accidentally rolled back as part of the + distutils2 rollback. + +- Issue #13674: Prevented time.strftime from crashing on Windows when given + a year before 1900 and a format of %y. + +- Issue #19406: implementation of the ensurepip module (part of PEP 453). + Patch by Donald Stufft and Nick Coghlan. + +- Issue #19544 and Issue #6286: Restore use of urllib over http allowing use + of http_proxy for Distutils upload command, a feature accidentally lost + in the rollback of distutils2. + +- Issue #19544 and Issue #7457: Restore the read_pkg_file method to + distutils.dist.DistributionMetadata accidentally removed in the undo of + distutils2. + +- Issue #16685: Added support for any bytes-like objects in the audioop module. + Removed support for strings. + +- Issue #7171: Add Windows implementation of ``inet_ntop`` and ``inet_pton`` + to socket module. Patch by Atsuo Ishimoto. + +- Issue #19261: Added support for writing 24-bit samples in the sunau module. + +- Issue #1097797: Added CP273 encoding, used on IBM mainframes in + Germany and Austria. Mapping provided by Michael Bierenfeld. + +- Issue #1575020: Fixed support of 24-bit wave files on big-endian platforms. + +- Issue #19378: Fixed a number of cases in the dis module where the new + "file" parameter was not being honoured correctly + +- Issue #19378: Removed the "dis.Bytecode.show_info" method + +- Issue #19378: Renamed the "dis.Bytecode.display_code" method to + "dis.Bytecode.dis" and converted it to returning a string rather than + printing output. + +- Issue #19378: the "line_offset" parameter in the new "dis.get_instructions" + API has been renamed to "first_line" (and the default value and usage + changed accordingly). This should reduce confusion with the more common use + of "offset" in the dis docs to refer to bytecode offsets. + +- Issue #18678: Corrected spwd struct member names in spwd module: + sp_nam->sp_namp, and sp_pwd->sp_pwdp. The old names are kept as extra + structseq members, for backward compatibility. + +- Issue #6157: Fixed tkinter.Text.debug(). tkinter.Text.bbox() now raises + TypeError instead of TclError on wrong number of arguments. Original patch + by Guilherme Polo. + +- Issue #10197: Rework subprocess.get[status]output to use subprocess + functionality and thus to work on Windows. Patch by Nick Coghlan + +- Issue #6160: The bbox() method of tkinter.Spinbox now returns a tuple of + integers instead of a string. Based on patch by Guilherme Polo. + +- Issue #19403: contextlib.redirect_stdout is now reentrant + +- Issue #19286: Directories in ``package_data`` are no longer added to + the filelist, preventing failure outlined in the ticket. + +- Issue #19480: HTMLParser now accepts all valid start-tag names as defined + by the HTML5 standard. + +- Issue #15114: The html.parser module now raises a DeprecationWarning when the + strict argument of HTMLParser or the HTMLParser.error method are used. + +- Issue #19410: Undo the special-casing removal of '' for + importlib.machinery.FileFinder. + +- Issue #19424: Fix the warnings module to accept filename containing surrogate + characters. + +- Issue #19435: Fix directory traversal attack on CGIHttpRequestHandler. + +- Issue #19227: Remove pthread_atfork() handler. The handler was added to + solve #18747 but has caused issues. + +- Issue #19420: Fix reference leak in module initialization code of + _hashopenssl.c + +- Issue #19329: Optimized compiling charsets in regular expressions. + +- Issue #19227: Try to fix deadlocks caused by re-seeding then OpenSSL + pseudo-random number generator on fork(). + +- Issue #16037: HTTPMessage.readheaders() raises an HTTPException when more than + 100 headers are read. Adapted from patch by Jyrki Pulliainen. + +- Issue #16040: CVE-2013-1752: nntplib: Limit maximum line lengths to 2048 to + prevent readline() calls from consuming too much memory. Patch by Jyrki + Pulliainen. + +- Issue #16041: CVE-2013-1752: poplib: Limit maximum line lengths to 2048 to + prevent readline() calls from consuming too much memory. Patch by Jyrki + Pulliainen. + +- Issue #17997: Change behavior of ``ssl.match_hostname()`` to follow RFC 6125, + for security reasons. It now doesn't match multiple wildcards nor wildcards + inside IDN fragments. + +- Issue #16039: CVE-2013-1752: Change use of readline in imaplib module to limit + line length. Patch by Emil Lind. + +- Issue #19330: the unnecessary wrapper functions have been removed from the + implementations of the new contextlib.redirect_stdout and + contextlib.suppress context managers, which also ensures they provide + reasonable help() output on instances + +- Issue #19393: Fix symtable.symtable function to not be confused when there are + functions or classes named "top". + +- Issue #18685: Restore re performance to pre-PEP 393 levels. + +- Issue #19339: telnetlib module is now using time.monotonic() when available + to compute timeout. + +- Issue #19399: fix sporadic test_subprocess failure. + +- Issue #13234: Fix os.listdir to work with extended paths on Windows. + Patch by Santoso Wijaya. + +- Issue #19375: The site module adding a "site-python" directory to sys.path, + if it exists, is now deprecated. + +- Issue #19379: Lazily import linecache in the warnings module, to make + startup with warnings faster until a warning gets printed. + +- Issue #19288: Fixed the "in" operator of dbm.gnu databases for string + argument. Original patch by Arfrever Frehtes Taifersar Arahesis. + +- Issue #19287: Fixed the "in" operator of dbm.ndbm databases for string + argument. Original patch by Arfrever Frehtes Taifersar Arahesis. + +- Issue #19327: Fixed the working of regular expressions with too big charset. + +- Issue #17400: New 'is_global' attribute for ipaddress to tell if an address + is allocated by IANA for global or private networks. + +- Issue #19350: Increasing the test coverage of macurl2path. Patch by Colin + Williams. + +- Issue #19365: Optimized the parsing of long replacement string in re.sub*() + functions. + +- Issue #19352: Fix unittest discovery when a module can be reached + through several paths (e.g. under Debian/Ubuntu with virtualenv). + +- Issue #15207: Fix mimetypes to read from correct part of Windows registry + Original patch by Dave Chambers + +- Issue #16595: Add prlimit() to resource module. + +- Issue #19324: Expose Linux-specific constants in resource module. + +- Load SSL's error strings in hashlib. + +- Issue #18527: Upgrade internal copy of zlib to 1.2.8. + +- Issue #19274: Add a filterfunc parameter to PyZipFile.writepy. + +- Issue #8964: fix platform._sys_version to handle IronPython 2.6+. + Patch by Martin Matusiak. + +- Issue #19413: Restore pre-3.3 reload() semantics of re-finding modules. + +- Issue #18958: Improve error message for json.load(s) while passing a string + that starts with a UTF-8 BOM. + +- Issue #19307: Improve error message for json.load(s) while passing objects + of the wrong type. + +- Issue #16038: CVE-2013-1752: ftplib: Limit amount of data read by + limiting the call to readline(). Original patch by Michał + Jastrzębski and Giampaolo Rodola. + +- Issue #17087: Improved the repr for regular expression match objects. + +Tests +----- + +- Issue #19664: test_userdict's repr test no longer depends on the order + of dict elements. + +- Issue #19440: Clean up test_capi by removing an unnecessary __future__ + import, converting from test_main to unittest.main, and running the + _testcapi module tests as subTests of a unittest TestCase method. + +- Issue #19378: the main dis module tests are now run with both stdout + redirection *and* passing an explicit file parameter + +- Issue #19378: removed the not-actually-helpful assertInstructionMatches + and assertBytecodeExactlyMatches helpers from bytecode_helper + +- Issue #18702: All skipped tests now reported as skipped. + +- Issue #19439: interpreter embedding tests are now executed on Windows + (Patch by Zachary Ware) + +- Issue #19085: Added basic tests for all tkinter widget options. + +- Issue #19384: Fix test_py_compile for root user, patch by Claudiu Popa. + +Documentation +------------- + +- Issue #18326: Clarify that list.sort's arguments are keyword-only. Also, + attempt to reduce confusion in the glossary by not saying there are + different "types" of arguments and parameters. + +Build +----- + +- Issue #19358: "make clinic" now runs the Argument Clinic preprocessor + over all CPython source files. + +- Update SQLite to 3.8.1, xz to 5.0.5, and Tcl/Tk to 8.6.1 on Windows. + +- Issue #16632: Enable DEP and ASLR on Windows. + +- Issue #17791: Drop PREFIX and EXEC_PREFIX definitions from PC/pyconfig.h + +- Add workaround for VS 2010 nmake clean issue. VS 2010 doesn't set up PATH + for nmake.exe correctly. + +- Issue #19550: Implement Windows installer changes of PEP 453 (ensurepip). + +- Issue #19520: Fix compiler warning in the _sha3 module on 32bit Windows. + +- Issue #19356: Avoid using a C variabled named "_self", it's a reserved + word in some C compilers. + +- Issue #15792: Correct build options on Win64. Patch by Jeremy Kloth. + +- Issue #19373: Apply upstream change to Tk 8.5.15 fixing OS X 10.9 + screen refresh problem for OS X installer build. + +- Issue #19649: On OS X, the same set of file names are now installed + in bin directories for all configurations: non-framework vs framework, + and single arch vs universal builds. pythonx.y-32 is now always + installed for 64-bit/32-bit universal builds. The obsolete and + undocumented pythonw* symlinks are no longer installed anywhere. + +- Issue #19553: PEP 453 - "make install" and "make altinstall" now install or + upgrade pip by default, using the bundled pip provided by the new ensurepip + module. A new configure option, --with-ensurepip[=upgrade|install|no], is + available to override the default ensurepip "--upgrade" option. The option + can also be set with "make [alt]install ENSUREPIP=[upgrade|install|no]". + +- Issue #19551: PEP 453 - the OS X installer now installs pip by default. + +- Update third-party libraries for OS X installers: xz 5.0.3 -> 5.0.5, + SQLite 3.7.13 -> 3.8.1 + +- Issue #15663: Revert OS X installer built-in Tcl/Tk support for 3.4.0b1. + Some third-party projects, such as Matplotlib and PIL/Pillow, + depended on being able to build with Tcl and Tk frameworks in + /Library/Frameworks. + +Tools/Demos +----------- + +- Issue #19730: Argument Clinic now supports all the existing PyArg + "format units" as legacy converters, as well as two new features: + "self converters" and the "version" directive. + +- Issue #19552: pyvenv now bootstraps pip into virtual environments by + default (pass --without-pip to request the old behaviour) + +- Issue #19390: Argument Clinic no longer accepts malformed Python + and C ids. + + +What's New in Python 3.4.0 Alpha 4? +=================================== + +Release date: 2013-10-20 + +Core and Builtins +----------------- + +- Issue #19301: Give classes and functions that are explicitly marked global a + global qualname. + +- Issue #19279: UTF-7 decoder no longer produces illegal strings. + +- Issue #16612: Add "Argument Clinic", a compile-time preprocessor for + C files to generate argument parsing code. (See PEP 436.) + +- Issue #18810: Shift stat calls in importlib.machinery.FileFinder such that + the code is optimistic that if something exists in a directory named exactly + like the possible package being searched for that it's in actuality a + directory. + +- Issue #18416: importlib.machinery.PathFinder now treats '' as the cwd and + importlib.machinery.FileFinder no longer special-cases '' to '.'. This leads + to modules imported from cwd to now possess an absolute file path for + __file__ (this does not affect modules specified by path on the CLI but it + does affect -m/runpy). It also allows FileFinder to be more consistent by not + having an edge case. + +- Issue #4555: All exported C symbols are now prefixed with either + "Py" or "_Py". + +- Issue #19219: Speed up marshal.loads(), and make pyc files slightly + (5% to 10%) smaller. + +- Issue #19221: Upgrade Unicode database to version 6.3.0. + +- Issue #16742: The result of the C callback PyOS_ReadlineFunctionPointer must + now be a string allocated by PyMem_RawMalloc() or PyMem_RawRealloc() (or NULL + if an error occurred), instead of a string allocated by PyMem_Malloc() or + PyMem_Realloc(). + +- Issue #19199: Remove ``PyThreadState.tick_counter`` field + +- Fix macro expansion of _PyErr_OCCURRED(), and make sure to use it in at + least one place so as to avoid regressions. + +- Issue #19087: Improve bytearray allocation in order to allow cheap popping + of data at the front (slice deletion). + +- Issue #19014: memoryview.cast() is now allowed on zero-length views. + +- Issue #18690: memoryview is now automatically registered with + collections.abc.Sequence + +- Issue #19078: memoryview now correctly supports the reversed builtin + (Patch by Claudiu Popa) + +Library +------- + +- Issue #17457: unittest test discovery now works with namespace packages. + Patch by Claudiu Popa. + +- Issue #18235: Fix the sysconfig variables LDSHARED and BLDSHARED under AIX. + Patch by David Edelsohn. + +- Issue #18606: Add the new "statistics" module (PEP 450). Contributed + by Steven D'Aprano. + +- Issue #12866: The audioop module now supports 24-bit samples. + +- Issue #19254: Provide an optimized Python implementation of pbkdf2_hmac. + +- Issues #19201, Issue #19222, Issue #19223: Add "x" mode (exclusive creation) + in opening file to bz2, gzip and lzma modules. Patches by Tim Heaney and + Vajrasky Kok. + +- Fix a reference count leak in _sre. + +- Issue #19262: Initial check in of the 'asyncio' package (a.k.a. Tulip, + a.k.a. PEP 3156). There are no docs yet, and the PEP is slightly + out of date with the code. This module will have *provisional* status + in Python 3.4. + +- Issue #19276: Fixed the wave module on 64-bit big-endian platforms. + +- Issue #19266: Rename the new-in-3.4 ``contextlib.ignore`` context manager + to ``contextlib.suppress`` in order to be more consistent with existing + descriptions of that operation elsewhere in the language and standard + library documentation (Patch by Zero Piraeus). + +- Issue #18891: Completed the new email package (provisional) API additions + by adding new classes EmailMessage, MIMEPart, and ContentManager. + +- Issue #18281: Unused stat constants removed from `tarfile`. + +- Issue #18999: Multiprocessing now supports 'contexts' with the same API + as the module, but bound to specified start methods. + +- Issue #18468: The re.split, re.findall, and re.sub functions and the group() + and groups() methods of match object now always return a string or a bytes + object. + +- Issue #18725: The textwrap module now supports truncating multiline text. + +- Issue #18776: atexit callbacks now display their full traceback when they + raise an exception. + +- Issue #17827: Add the missing documentation for ``codecs.encode`` and + ``codecs.decode``. + +- Issue #19218: Rename collections.abc to _collections_abc in order to + speed up interpreter start. + +- Issue #18582: Add 'pbkdf2_hmac' to the hashlib module. It implements PKCS#5 + password-based key derivation functions with HMAC as pseudorandom function. + +- Issue #19131: The aifc module now correctly reads and writes sampwidth of + compressed streams. + +- Issue #19209: Remove import of copyreg from the os module to speed up + interpreter startup. stat_result and statvfs_result are now hard-coded to + reside in the os module. + +- Issue #19205: Don't import the 're' module in site and sysconfig module to + speed up interpreter start. + +- Issue #9548: Add a minimal "_bootlocale" module that is imported by the + _io module instead of the full locale module. + +- Issue #18764: Remove the 'print' alias for the PDB 'p' command so that it no + longer shadows the print function. + +- Issue #19158: A rare race in BoundedSemaphore could allow .release() too + often. + +- Issue #15805: Add contextlib.redirect_stdout(). + +- Issue #18716: Deprecate the formatter module. + +- Issue #10712: 2to3 has a new "asserts" fixer that replaces deprecated names + of unittest methods (e.g. failUnlessEqual -> assertEqual). + +- Issue #18037: 2to3 now escapes ``'\u'`` and ``'\U'`` in native strings. + +- Issue #17839: base64.decodebytes and base64.encodebytes now accept any + object that exports a 1 dimensional array of bytes (this means the same + is now also true for base64_codec) + +- Issue #19132: The pprint module now supports compact mode. + +- Issue #19137: The pprint module now correctly formats instances of set and + frozenset subclasses. + +- Issue #10042: functools.total_ordering now correctly handles + NotImplemented being returned by the underlying comparison function (Patch + by Katie Miller) + +- Issue #19092: contextlib.ExitStack now correctly reraises exceptions + from the __exit__ callbacks of inner context managers (Patch by Hrvoje + Nikšić) + +- Issue #12641: Avoid passing "-mno-cygwin" to the mingw32 compiler, except + when necessary. Patch by Oscar Benjamin. + +- Issue #5845: In site.py, only load readline history from ~/.python_history + if no history has been read already. This avoids double writes to the + history file at shutdown. + +- Properly initialize all fields of a SSL object after allocation. + +- Issue #19095: SSLSocket.getpeercert() now raises ValueError when the + SSL handshake hasn't been done. + +- Issue #4366: Fix building extensions on all platforms when --enable-shared + is used. + +- Issue #19030: Fixed `inspect.getmembers` and `inspect.classify_class_attrs` + to attempt activating descriptors before falling back to a __dict__ search + for faulty descriptors. `inspect.classify_class_attrs` no longer returns + Attributes whose home class is None. + +C API +----- + +- Issue #1772673: The type of `char*` arguments now changed to `const char*`. + +- Issue #16129: Added a `Py_SetStandardStreamEncoding` pre-initialization API + to allow embedding applications like Blender to force a particular + encoding and error handler for the standard IO streams (initial patch by + Bastien Montagne) + +Tests +----- + +- Issue #19275: Fix test_site on AMD64 Snow Leopard + +- Issue #14407: Fix unittest test discovery in test_concurrent_futures. + +- Issue #18919: Unified and extended tests for audio modules: aifc, sunau and + wave. + +- Issue #18714: Added tests for ``pdb.find_function()``. + +Documentation +------------- + +- Issue #18758: Fixed and improved cross-references. + +- Issue #18972: Modernize email examples and use the argparse module in them. + +Build +----- + +- Issue #19130: Correct PCbuild/readme.txt, Python 3.3 and 3.4 require VS 2010. + +- Issue #15663: Update OS X 10.6+ installer to use Tcl/Tk 8.5.15. + +- Issue #14499: Fix several problems with OS X universal build support: + 1. ppc arch detection for extension module builds broke with Xcode 5 + 2. ppc arch detection in configure did not work on OS X 10.4 + 3. -sysroot and -arch flags were unnecessarily duplicated + 4. there was no obvious way to configure an intel-32 only build. + +- Issue #19019: Change the OS X installer build script to use CFLAGS instead + of OPT for special build options. By setting OPT, some compiler-specific + options like -fwrapv were overridden and thus not used, which could result + in broken interpreters when building with clang. + + +What's New in Python 3.4.0 Alpha 3? +=================================== + +Release date: 2013-09-29 + +Core and Builtins +----------------- + +- Issue #18818: The "encodingname" part of PYTHONIOENCODING is now optional. + +- Issue #19098: Prevent overflow in the compiler when the recursion limit is set + absurdly high. + +Library +------- + +- Issue #18929: `inspect.classify_class_attrs()` now correctly finds class + attributes returned by `dir()` that are located in the metaclass. + +- Issue #18950: Fix miscellaneous bugs in the sunau module. + Au_read.readframes() now updates current file position and reads correct + number of frames from multichannel stream. Au_write.writeframesraw() now + correctly updates current file position. Au_read.getnframes() now returns an + integer (as in Python 2). Au_read and Au_write now correctly works with file + object if start file position is not a zero. + +- Issue #18594: The fast path for collections.Counter() was never taken + due to an over-restrictive type check. + +- Issue #19053: ZipExtFile.read1() with non-zero argument no more returns empty + bytes until end of data. + +- logging: added support for Unix domain sockets to SocketHandler and + DatagramHandler. + +- Issue #18996: TestCase.assertEqual() now more cleverly shorten differing + strings in error report. + +- Issue #19034: repr() for tkinter.Tcl_Obj now exposes string reperesentation. + +- Issue #18978: ``urllib.request.Request`` now allows the method to be + indicated on the class and no longer sets it to None in ``__init__``. + +- Issue #18626: the inspect module now offers a basic command line + introspection interface (Initial patch by Claudiu Popa) + +- Issue #3015: Fixed tkinter with wantobject=False. Any Tcl command call + returned empty string. + +- Issue #19037: The mailbox module now makes all changes to maildir files + before moving them into place, to avoid race conditions with other programs + that may be accessing the maildir directory. + +- Issue #14984: On POSIX systems, when netrc is called without a filename + argument (and therefore is reading the user's $HOME/.netrc file), it now + enforces the same security rules as typical ftp clients: the .netrc file must + be owned by the user that owns the process and must not be readable by any + other user. + +- Issue #18873: The tokenize module now detects Python source code encoding + only in comment lines. + +- Issue #17764: Enable http.server to bind to a user specified network + interface. Patch contributed by Malte Swart. + +- Issue #18937: Add an assertLogs() context manager to unittest.TestCase + to ensure that a block of code emits a message using the logging module. + +- Issue #17324: Fix http.server's request handling case on trailing '/'. Patch + contributed by Vajrasky Kok. + +- Issue #19018: The heapq.merge() function no longer suppresses IndexError + in the underlying iterables. + +- Issue #18784: The uuid module no longer attempts to load libc via ctypes.CDLL + if all the necessary functions have already been found in libuuid. Patch by + Evgeny Sologubov. + +- The :envvar:`PYTHONFAULTHANDLER` environment variable now only enables the + faulthandler module if the variable is non-empty. Same behaviour than other + variables like :envvar:`PYTHONDONTWRITEBYTECODE`. + +- Issue #1565525: New function ``traceback.clear_frames`` will clear + the local variables of all the stack frames referenced by a traceback + object. + +Tests +----- + +- Issue #18952: Fix regression in support data downloads introduced when + test.support was converted to a package. Regression noticed by Zachary + Ware. + +IDLE +---- + +- Issue #18873: IDLE now detects Python source code encoding only in comment + lines. + +- Issue #18988: The "Tab" key now works when a word is already autocompleted. + +Documentation +------------- + +- Issue #17003: Unified the size argument names in the io module with common + practice. + +Build +----- + +- Issue #18596: Support the use of address sanity checking in recent versions + of clang and GCC by appropriately marking known false alarms in the small + object allocator. Patch contributed by Dhiru Kholia. + +Tools/Demos +----------- + +- Issue #18873: 2to3 and the findnocoding.py script now detect Python source + code encoding only in comment lines. + + +What's New in Python 3.4.0 Alpha 2? +=================================== + +Release date: 2013-09-09 + +Core and Builtins +----------------- + +- Issue #18942: sys._debugmallocstats() output was damaged on Windows. + +- Issue #18571: Implementation of the PEP 446: file descriptors and file + handles are now created non-inheritable; add functions + os.get/set_inheritable(), os.get/set_handle_inheritable() and + socket.socket.get/set_inheritable(). + +- Issue #11619: The parser and the import machinery do not encode Unicode + filenames anymore on Windows. + +- Issue #18808: Non-daemon threads are now automatically joined when + a sub-interpreter is shutdown (it would previously dump a fatal error). + +- Remove support for compiling on systems without getcwd(). + +- Issue #18774: Remove last bits of GNU PTH thread code and thread_pth.h. + +- Issue #18771: Add optimization to set object lookups to reduce the cost + of hash collisions. The core idea is to inspect a second key/hash pair + for each cache line retrieved. + +- Issue #16105: When a signal handler fails to write to the file descriptor + registered with ``signal.set_wakeup_fd()``, report an exception instead + of ignoring the error. + +- Issue #18722: Remove uses of the "register" keyword in C code. + +- Issue #18667: Add missing "HAVE_FCHOWNAT" symbol to posix._have_functions. + +- Issue #16499: Add command line option for isolated mode. + +- Issue #15301: Parsing fd, uid, and gid parameters for builtins + in Modules/posixmodule.c is now far more robust. + +- Issue #18368: PyOS_StdioReadline() no longer leaks memory when realloc() + fail. + +- Issue #17934: Add a clear() method to frame objects, to help clean up + expensive details (local variables) and break reference cycles. + +- Issue #18780: %-formatting codes %d, %i, and %u now treat int-subclasses + as int (displays value of int-subclass instead of str(int-subclass) ). + +Library +------- + +- Issue #18808: Thread.join() now waits for the underlying thread state to + be destroyed before returning. This prevents unpredictable aborts in + Py_EndInterpreter() when some non-daemon threads are still running. + +- Issue #18458: Prevent crashes with newer versions of libedit. Its readline + emulation has changed from 0-based indexing to 1-based like gnu readline. + +- Issue #18852: Handle case of ``readline.__doc__`` being ``None`` in the new + readline activation code in ``site.py``. + +- Issue #18672: Fixed format specifiers for Py_ssize_t in debugging output in + the _sre module. + +- Issue #18830: inspect.getclasstree() no longer produces duplicate entries even + when input list contains duplicates. + +- Issue #18878: sunau.open now supports the context management protocol. Based on + patches by Claudiu Popa and R. David Murray. + +- Issue #18909: Fix _tkinter.tkapp.interpaddr() on Windows 64-bit, don't cast + 64-bit pointer to long (32 bits). + +- Issue #18876: The FileIO.mode attribute now better reflects the actual mode + under which the file was opened. Patch by Erik Bray. + +- Issue #16853: Add new selectors module. + +- Issue #18882: Add threading.main_thread() function. + +- Issue #18901: The sunau getparams method now returns a namedtuple rather than + a plain tuple. Patch by Claudiu Popa. + +- Issue #17487: The result of the wave getparams method now is pickleable again. + Patch by Claudiu Popa. + +- Issue #18756: os.urandom() now uses a lazily-opened persistent file + descriptor, so as to avoid using many file descriptors when run in + parallel from multiple threads. + +- Issue #18418: After fork(), reinit all threads states, not only active ones. + Patch by A. Jesse Jiryu Davis. + +- Issue #17974: Switch unittest from using getopt to using argparse. + +- Issue #11798: TestSuite now drops references to own tests after execution. + +- Issue #16611: http.cookie now correctly parses the 'secure' and 'httponly' + cookie flags. + +- Issue #11973: Fix a problem in kevent. The flags and fflags fields are now + properly handled as unsigned. + +- Issue #18807: ``pyvenv`` now takes a --copies argument allowing copies + instead of symlinks even where symlinks are available and the default. + +- Issue #18538: ``python -m dis`` now uses argparse for argument processing. + Patch by Michele Orrù. + +- Issue #18394: Close cgi.FieldStorage's optional file. + +- Issue #17702: On error, os.environb now suppresses the exception context + when raising a new KeyError with the original key. + +- Issue #16809: Fixed some tkinter incompabilities with Tcl/Tk 8.6. + +- Issue #16809: Tkinter's splitlist() and split() methods now accept Tcl_Obj + argument. + +- Issue #17211: Yield a namedtuple in pkgutil. + Patch by Ramchandra Apte. + +- Issue #18324: set_payload now correctly handles binary input. This also + supersedes the previous fixes for #14360, #1717, and #16564. + +- Issue #18794: Add a fileno() method and a closed attribute to select.devpoll + objects. + +- Issue #17119: Fixed integer overflows when processing large strings and tuples + in the tkinter module. + +- Issue #15352: Rebuild frozen modules when marshal.c is changed. + +- Issue #18747: Re-seed OpenSSL's pseudo-random number generator after fork. + A pthread_atfork() parent handler is used to seed the PRNG with pid, time + and some stack data. + +- Issue #8865: Concurrent invocation of select.poll.poll() now raises a + RuntimeError exception. Patch by Christian Schubert. + +- Issue #18777: The ssl module now uses the new CRYPTO_THREADID API of + OpenSSL 1.0.0+ instead of the deprecated CRYPTO id callback function. + +- Issue #18768: Correct doc string of RAND_edg(). Patch by Vajrasky Kok. + +- Issue #18178: Fix ctypes on BSD. dlmalloc.c was compiled twice which broke + malloc weak symbols. + +- Issue #18709: Fix CVE-2013-4238. The SSL module now handles NULL bytes + inside subjectAltName correctly. Formerly the module has used OpenSSL's + GENERAL_NAME_print() function to get the string representation of ASN.1 + strings for ``rfc822Name`` (email), ``dNSName`` (DNS) and + ``uniformResourceIdentifier`` (URI). + +- Issue #18701: Remove support of old CPython versions (<3.0) from C code. + +- Issue #18756: Improve error reporting in os.urandom() when the failure + is due to something else than /dev/urandom not existing (for example, + exhausting the file descriptor limit). + +- Issue #18673: Add O_TMPFILE to os module. O_TMPFILE requires Linux kernel + 3.11 or newer. It's only defined on system with 3.11 uapi headers, too. + +- Issue #18532: Change the builtin hash algorithms' names to lower case names + as promised by hashlib's documentation. + +- Issue #8713: add new spwan and forkserver start methods, and new functions + get_all_start_methods, get_start_method, and set_start_method, to + multiprocessing. + +- Issue #18405: Improve the entropy of crypt.mksalt(). + +- Issue #12015: The tempfile module now uses a suffix of 8 random characters + instead of 6, to reduce the risk of filename collision. The entropy was + reduced when uppercase letters were removed from the charset used to generate + random characters. + +- Issue #18585: Add :func:`textwrap.shorten` to collapse and truncate a + piece of text to a given length. + +- Issue #18598: Tweak exception message for importlib.import_module() to + include the module name when a key argument is missing. + +- Issue #19151: Fix docstring and use of _get_supported_file_loaders() to + reflect 2-tuples. + +- Issue #19152: Add ExtensionFileLoader.get_filename(). + +- Issue #18676: Change 'positive' to 'non-negative' in queue.py put and get + docstrings and ValueError messages. Patch by Zhongyue Luo + +- Fix refcounting issue with extension types in tkinter. + +- Issue #8112: xlmrpc.server's DocXMLRPCServer server no longer raises an error + if methods have annotations; it now correctly displays the annotations. + +- Issue #18600: Added policy argument to email.message.Message.as_string, + and as_bytes and __bytes__ methods to Message. + +- Issue #18671: Output more information when logging exceptions occur. + +- Issue #18621: Prevent the site module's patched builtins from keeping + too many references alive for too long. + +- Issue #4885: Add weakref support to mmap objects. Patch by Valerie Lambert. + +- Issue #8860: Fixed rounding in timedelta constructor. + +- Issue #18849: Fixed a Windows-specific tempfile bug where collision with an + existing directory caused mkstemp and related APIs to fail instead of + retrying. Report and fix by Vlad Shcherbina. + +- Issue #18920: argparse's default destination for the version action (-v, + --version) has also been changed to stdout, to match the Python executable. + +Tests +----- + +- Issue #18623: Factor out the _SuppressCoreFiles context manager into + test.support. Patch by Valerie Lambert. + +- Issue #12037: Fix test_email for desktop Windows. + +- Issue #15507: test_subprocess's test_send_signal could fail if the test + runner were run in an environment where the process inherited an ignore + setting for SIGINT. Restore the SIGINT handler to the desired + KeyboardInterrupt raising one during that test. + +- Issue #16799: Switched from getopt to argparse style in regrtest's argument + parsing. Added more tests for regrtest's argument parsing. + +- Issue #18792: Use "127.0.0.1" or "::1" instead of "localhost" as much as + possible, since "localhost" goes through a DNS lookup under recent Windows + versions. + +IDLE +---- + +- Issue #18489: Add tests for SearchEngine. Original patch by Phil Webster. + +Documentation +------------- + +- Issue #18743: Fix references to non-existent "StringIO" module. + +- Issue #18783: Removed existing mentions of Python long type in docstrings, + error messages and comments. + +Build +----- + +- Issue #1584: Provide configure options to override default search paths for + Tcl and Tk when building _tkinter. + +- Issue #15663: Tcl/Tk 8.5.14 is now included with the OS X 10.6+ 64-/32-bit + installer. It is no longer necessary to install a third-party version of + Tcl/Tk 8.5 to work around the problems in the Apple-supplied Tcl/Tk 8.5 + shipped in OS X 10.6 and later releases. + +Tools/Demos +----------- + +- Issue #18922: Now The Lib/smtpd.py and Tools/i18n/msgfmt.py scripts write + their version strings to stdout, and not to sderr. + + +What's New in Python 3.4.0 Alpha 1? +=================================== + +Release date: 2013-08-03 + +Core and Builtins +----------------- + +- Issue #16741: Fix an error reporting in int(). + +- Issue #17899: Fix rare file descriptor leak in os.listdir(). + +- Issue #10241: Clear extension module dict copies at interpreter shutdown. + Patch by Neil Schemenauer, minimally modified. + +- Issue #9035: ismount now recognises volumes mounted below a drive root + on Windows. Original patch by Atsuo Ishimoto. + +- Issue #18214: Improve finalization of Python modules to avoid setting + their globals to None, in most cases. + +- Issue #18112: PEP 442 implementation (safe object finalization). + +- Issue #18552: Check return value of PyArena_AddPyObject() in + obj2ast_object(). + +- Issue #18560: Fix potential NULL pointer dereference in sum(). + +- Issue #18520: Add a new PyStructSequence_InitType2() function, same than + PyStructSequence_InitType() except that it has a return value (0 on success, + -1 on error). + +- Issue #15905: Fix theoretical buffer overflow in handling of sys.argv[0], + prefix and exec_prefix if the operation system does not obey MAXPATHLEN. + +- Issue #18408: Fix many various bugs in code handling errors, especially + on memory allocation failure (MemoryError). + +- Issue #18344: Fix potential ref-leaks in _bufferedreader_read_all(). + +- Issue #18342: Use the repr of a module name when an import fails when using + ``from ... import ...``. + +- Issue #17872: Fix a segfault in marshal.load() when input stream returns + more bytes than requested. + +- Issue #18338: `python --version` now prints version string to stdout, and + not to stderr. Patch by Berker Peksag and Michael Dickens. + +- Issue #18426: Fix NULL pointer dereference in C extension import when + PyModule_GetDef() returns an error. + +- Issue #17206: On Windows, increase the stack size from 2 MB to 4.2 MB to fix + a stack overflow in the marshal module (fix a crash in test_marshal). + Patch written by Jeremy Kloth. + +- Issue #3329: Implement the PEP 445: Add new APIs to customize Python memory + allocators. + +- Issue #18328: Reorder ops in PyThreadState_Delete*() functions. Now the + tstate is first removed from TLS and then deallocated. + +- Issue #13483: Use VirtualAlloc in obmalloc on Windows. + +- Issue #18184: PyUnicode_FromFormat() and PyUnicode_FromFormatV() now raise + OverflowError when an argument of %c format is out of range. + +- Issue #18111: The min() and max() functions now support a default argument + to be returned instead of raising a ValueError on an empty sequence. + (Contributed by Julian Berman.) + +- Issue #18137: Detect integer overflow on precision in float.__format__() + and complex.__format__(). + +- Issue #15767: Introduce ModuleNotFoundError which is raised when a module + could not be found. + +- Issue #18183: Fix various unicode operations on strings with large unicode + codepoints. + +- Issue #18180: Fix ref leak in _PyImport_GetDynLoadWindows(). + +- Issue #18038: SyntaxError raised during compilation sources with illegal + encoding now always contains an encoding name. + +- Issue #17931: Resolve confusion on Windows between pids and process + handles. + +- Tweak the exception message when the magic number or size value in a bytecode + file is truncated. + +- Issue #17932: Fix an integer overflow issue on Windows 64-bit in iterators: + change the C type of seqiterobject.it_index from long to Py_ssize_t. + +- Issue #18065: Don't set __path__ to the package name for frozen packages. + +- Issue #18088: When reloading a module, unconditionally reset all relevant + attributes on the module (e.g. __name__, __loader__, __package__, __file__, + __cached__). + +- Issue #17937: Try harder to collect cyclic garbage at shutdown. + +- Issue #12370: Prevent class bodies from interfering with the __class__ + closure. + +- Issue #17644: Fix a crash in str.format when curly braces are used in square + brackets. + +- Issue #17237: Fix crash in the ASCII decoder on m68k. + +- Issue #17927: Frame objects kept arguments alive if they had been + copied into a cell, even if the cell was cleared. + +- Issue #1545463: At shutdown, defer finalization of codec modules so + that stderr remains usable. + +- Issue #7330: Implement width and precision (ex: "%5.3s") for the format + string of PyUnicode_FromFormat() function, original patch written by Ysj Ray. + +- Issue #1545463: Global variables caught in reference cycles are now + garbage-collected at shutdown. + +- Issue #17094: Clear stale thread states after fork(). Note that this + is a potentially disruptive change since it may release some system + resources which would otherwise remain perpetually alive (e.g. database + connections kept in thread-local storage). + +- Issue #17408: Avoid using an obsolete instance of the copyreg module when + the interpreter is shutdown and then started again. + +- Issue #5845: Enable tab-completion in the interactive interpreter by + default, thanks to a new sys.__interactivehook__. + +- Issue #17115,17116: Module initialization now includes setting __package__ and + __loader__ attributes to None. + +- Issue #17853: Ensure locals of a class that shadow free variables always win + over the closures. + +- Issue #17863: In the interactive console, don't loop forever if the encoding + can't be fetched from stdin. + +- Issue #17867: Raise an ImportError if __import__ is not found in __builtins__. + +- Issue #18698: Ensure importlib.reload() returns the module out of sys.modules. + +- Issue #17857: Prevent build failures with pre-3.5.0 versions of sqlite3, + such as was shipped with Centos 5 and Mac OS X 10.4. + +- Issue #17413: sys.settrace callbacks were being passed a string instead of an + exception instance for the 'value' element of the arg tuple if the exception + originated from C code; now an exception instance is always provided. + +- Issue #17782: Fix undefined behaviour on platforms where + ``struct timespec``'s "tv_nsec" member is not a C long. + +- Issue #17722: When looking up __round__, resolve descriptors. + +- Issue #16061: Speed up str.replace() for replacing 1-character strings. + +- Issue #17715: Fix segmentation fault from raising an exception in a __trunc__ + method. + +- Issue #17643: Add __callback__ attribute to weakref.ref. + +- Issue #16447: Fixed potential segmentation fault when setting __name__ on a + class. + +- Issue #17669: Fix crash involving finalization of generators using yield from. + +- Issue #14439: Python now prints the traceback on runpy failure at startup. + +- Issue #17469: Fix _Py_GetAllocatedBlocks() and sys.getallocatedblocks() + when running on valgrind. + +- Issue #17619: Make input() check for Ctrl-C correctly on Windows. + +- Issue #17357: Add missing verbosity messages for -v/-vv that were lost during + the importlib transition. + +- Issue #17610: Don't rely on non-standard behavior of the C qsort() function. + +- Issue #17323: The "[X refs, Y blocks]" printed by debug builds has been + disabled by default. It can be re-enabled with the `-X showrefcount` option. + +- Issue #17328: Fix possible refleak in dict.setdefault. + +- Issue #17275: Corrected class name in init error messages of the C version of + BufferedWriter and BufferedRandom. + +- Issue #7963: Fixed misleading error message that issued when object is + called without arguments. + +- Issue #8745: Small speed up zipimport on Windows. Patch by Catalin Iacob. + +- Issue #5308: Raise ValueError when marshalling too large object (a sequence + with size >= 2**31), instead of producing illegal marshal data. + +- Issue #12983: Bytes literals with invalid ``\x`` escape now raise a SyntaxError + and a full traceback including line number. + +- Issue #16967: In function definition, evaluate positional defaults before + keyword-only defaults. + +- Issue #17173: Remove uses of locale-dependent C functions (isalpha() etc.) + in the interpreter. + +- Issue #17137: When a Unicode string is resized, the internal wide character + string (wstr) format is now cleared. + +- Issue #17043: The unicode-internal decoder no longer read past the end of + input buffer. + +- Issue #17098: All modules now have __loader__ set even if they pre-exist the + bootstrapping of importlib. + +- Issue #16979: Fix error handling bugs in the unicode-escape-decode decoder. + +- Issue #16772: The base argument to the int constructor no longer accepts + floats, or other non-integer objects with an __int__ method. Objects + with an __index__ method are now accepted. + +- Issue #10156: In the interpreter's initialization phase, unicode globals + are now initialized dynamically as needed. + +- Issue #16980: Fix processing of escaped non-ascii bytes in the + unicode-escape-decode decoder. + +- Issue #16975: Fix error handling bug in the escape-decode bytes decoder. + +- Issue #14850: Now a charmap decoder treats U+FFFE as "undefined mapping" + in any mapping, not only in a string. + +- Issue #16613: Add *m* argument to ``collections.Chainmap.new_child`` to + allow the new child map to be specified explicitly. + +- Issue #16730: importlib.machinery.FileFinder now no longers raises an + exception when trying to populate its cache and it finds out the directory is + unreadable or has turned into a file. Reported and diagnosed by + David Pritchard. + +- Issue #16906: Fix a logic error that prevented most static strings from being + cleared. + +- Issue #11461: Fix the incremental UTF-16 decoder. Original patch by + Amaury Forgeot d'Arc. + +- Issue #16856: Fix a segmentation fault from calling repr() on a dict with + a key whose repr raise an exception. + +- Issue #16367: Fix FileIO.readall() on Windows for files larger than 2 GB. + +- Issue #16761: Calling int() with base argument only now raises TypeError. + +- Issue #16759: Support the full DWORD (unsigned long) range in Reg2Py + when retrieving a REG_DWORD value. This corrects functions like + winreg.QueryValueEx that may have been returning truncated values. + +- Issue #14420: Support the full DWORD (unsigned long) range in Py2Reg + when passed a REG_DWORD value. Fixes OverflowError in winreg.SetValueEx. + +- Issue #11939: Set the st_dev attribute of stat_result to allow Windows to + take advantage of the os.path.samefile/sameopenfile/samestat implementations + used by other platforms. + +- Issue #16772: The int() constructor's second argument (base) no longer + accepts non integer values. Consistent with the behavior in Python 2. + +- Issue #14470: Remove w9xpopen support per PEP 11. + +- Issue #9856: Replace deprecation warning with raising TypeError + in object.__format__. Patch by Florent Xicluna. + +- Issue #16597: In buffered and text IO, call close() on the underlying stream + if invoking flush() fails. + +- Issue #16722: In the bytes() constructor, try to call __bytes__ on the + argument before __index__. + +- Issue #16421: loading multiple modules from one shared object is now + handled correctly (previously, the first module loaded from that file + was silently returned). Patch by Václav Šmilauer. + +- Issue #16602: When a weakref's target was part of a long deallocation + chain, the object could remain reachable through its weakref even though + its refcount had dropped to zero. + +- Issue #16495: Remove extraneous NULL encoding check from bytes_decode(). + +- Issue #16619: Create NameConstant AST class to represent None, True, and False + literals. As a result, these constants are never loaded at runtime from + builtins. + +- Issue #16455: On FreeBSD and Solaris, if the locale is C, the + ASCII/surrogateescape codec is now used (instead of the locale encoding) to + decode the command line arguments. This change fixes inconsistencies with + os.fsencode() and os.fsdecode(), because these operating systems announce an + ASCII locale encoding, but actually use the ISO-8859-1 encoding in practice. + +- Issue #16562: Optimize dict equality testing. Patch by Serhiy Storchaka. + +- Issue #16588: Silence unused-but-set warnings in Python/thread_pthread + +- Issue #16592: stringlib_bytes_join doesn't raise MemoryError on allocation + failure. + +- Issue #16546: Fix: ast.YieldFrom argument is now mandatory. + +- Issue #16514: Fix regression causing a traceback when sys.path[0] is None + (actually, any non-string or non-bytes type). + +- Issue #16306: Fix multiple error messages when unknown command line + parameters where passed to the interpreter. Patch by Hieu Nguyen. + +- Issue #16215: Fix potential double memory free in str.replace(). Patch + by Serhiy Storchaka. + +- Issue #16290: A float return value from the __complex__ special method is no + longer accepted in the complex() constructor. + +- Issue #16416: On Mac OS X, operating system data are now always + encoded/decoded to/from UTF-8/surrogateescape, instead of the locale encoding + (which may be ASCII if no locale environment variable is set), to avoid + inconsistencies with os.fsencode() and os.fsdecode() functions which are + already using UTF-8/surrogateescape. + +- Issue #16453: Fix equality testing of dead weakref objects. + +- Issue #9535: Fix pending signals that have been received but not yet + handled by Python to not persist after os.fork() in the child process. + +- Issue #14794: Fix slice.indices to return correct results for huge values, + rather than raising OverflowError. + +- Issue #15001: fix segfault on "del sys.modules['__main__']". Patch by Victor + Stinner. + +- Issue #8271: the utf-8 decoder now outputs the correct number of U+FFFD + characters when used with the 'replace' error handler on invalid utf-8 + sequences. Patch by Serhiy Storchaka, tests by Ezio Melotti. + +- Issue #5765: Apply a hard recursion limit in the compiler instead of + blowing the stack and segfaulting. Initial patch by Andrea Griffini. + +- Issue #16402: When slicing a range, fix shadowing of exceptions from + __index__. + +- Issue #16336: fix input checking in the surrogatepass error handler. + Patch by Serhiy Storchaka. + +- Issue #8401: assigning an int to a bytearray slice (e.g. b[3:4] = 5) now + raises an error. + +- Issue #7317: Display full tracebacks when an error occurs asynchronously. + Patch by Alon Horev with update by Alexey Kachayev. + +- Issue #16309: Make PYTHONPATH="" behavior the same as if PYTHONPATH + not set at all. + +- Issue #10189: Improve the error reporting of SyntaxErrors related to global + and nonlocal statements. + +- Fix segfaults on setting __qualname__ on builtin types and attempting to + delete it on any type. + +- Issue #14625: Rewrite the UTF-32 decoder. It is now 3x to 4x faster. Patch + written by Serhiy Storchaka. + +- Issue #16345: Fix an infinite loop when ``fromkeys`` on a dict subclass + received a nonempty dict from the constructor. + +- Issue #16271: Fix strange bugs that resulted from __qualname__ appearing in a + class's __dict__ and on type. + +- Issue #12805: Make bytes.join and bytearray.join faster when the separator + is empty. Patch by Serhiy Storchaka. + +- Issue #6074: Ensure cached bytecode files can always be updated by the + user that created them, even when the source file is read-only. + +- Issue #15958: bytes.join and bytearray.join now accept arbitrary buffer + objects. + +- Issue #14783: Improve int() docstring and switch docstrings for str(), + range(), and slice() to use multi-line signatures. + +- Issue #16160: Subclass support now works for types.SimpleNamespace. + +- Issue #16148: Implement PEP 424, adding operator.length_hint and + PyObject_LengthHint. + +- Upgrade Unicode data (UCD) to version 6.2. + +- Issue #15379: Fix passing of non-BMP characters as integers for the charmap + decoder (already working as unicode strings). Patch by Serhiy Storchaka. + +- Issue #15144: Fix possible integer overflow when handling pointers as integer + values, by using `Py_uintptr_t` instead of `size_t`. Patch by Serhiy + Storchaka. + +- Issue #15965: Explicitly cast `AT_FDCWD` as (int). Required on Solaris 10 + (which defines `AT_FDCWD` as ``0xffd19553``), harmless on other platforms. + +- Issue #15839: Convert SystemErrors in `super()` to RuntimeErrors. + +- Issue #15448: Buffered IO now frees the buffer when closed, instead + of when deallocating. + +- Issue #15846: Fix SystemError which happened when using `ast.parse()` in an + exception handler on code with syntax errors. + +- Issue #15897: zipimport.c doesn't check return value of fseek(). + Patch by Felipe Cruz. + +- Issue #15801: Make sure mappings passed to '%' formatting are actually + subscriptable. + +- Issue #15111: __import__ should propagate ImportError when raised as a + side-effect of a module triggered from using fromlist. + +- Issue #15022: Add pickle and comparison support to types.SimpleNamespace. + +Library +------- + +- Issue #4331: Added functools.partialmethod (Initial patch by Alon Horev) + +- Issue #13461: Fix a crash in the TextIOWrapper.tell method on 64-bit + platforms. Patch by Yogesh Chaudhari. + +- Issue #18681: Fix a NameError in importlib.reload() (noticed by Weizhao Li). + +- Issue #14323: Expanded the number of digits in the coefficients for the + RGB -- YIQ conversions so that they match the FCC NTSC versions. + +- Issue #17998: Fix an internal error in regular expression engine. + +- Issue #17557: Fix os.getgroups() to work with the modified behavior of + getgroups(2) on OS X 10.8. Original patch by Mateusz Lenik. + +- Issue #18608: Avoid keeping a strong reference to the locale module + inside the _io module. + +- Issue #18619: Fix atexit leaking callbacks registered from sub-interpreters, + and make it GC-aware. + +- Issue #15699: The readline module now uses PEP 3121-style module + initialization, so as to reclaim allocated resources (Python callbacks) + at shutdown. Original patch by Robin Schreiber. + +- Issue #17616: wave.open now supports the context management protocol. + +- Issue #18599: Fix name attribute of _sha1.sha1() object. It now returns + 'SHA1' instead of 'SHA'. + +- Issue #13266: Added inspect.unwrap to easily unravel __wrapped__ chains + (initial patch by Daniel Urban and Aaron Iles) + +- Issue #18561: Skip name in ctypes' _build_callargs() if name is NULL. + +- Issue #18559: Fix NULL pointer dereference error in _pickle module + +- Issue #18556: Check the return type of PyUnicode_AsWideChar() in ctype's + U_set(). + +- Issue #17818: aifc.getparams now returns a namedtuple. + +- Issue #18549: Eliminate dead code in socket_ntohl() + +- Issue #18530: Remove additional stat call from posixpath.ismount. + Patch by Alex Gaynor. + +- Issue #18514: Fix unreachable Py_DECREF() call in PyCData_FromBaseObj() + +- Issue #9177: Calling read() or write() now raises ValueError, not + AttributeError, on a closed SSL socket. Patch by Senko Rasic. + +- Issue #18513: Fix behaviour of cmath.rect w.r.t. signed zeros on OS X 10.8 + + gcc. + +- Issue #18479: Changed venv Activate.ps1 to make deactivate a function, and + removed Deactivate.ps1. + +- Issue #18480: Add missing call to PyType_Ready to the _elementtree extension. + +- Issue #17778: Fix test discovery for test_multiprocessing. (Patch by + Zachary Ware.) + +- Issue #18393: The private module _gestalt and private functions + platform._mac_ver_gestalt, platform._mac_ver_lookup and + platform._bcd2str have been removed. This does not affect the public + interface of the platform module. + +- Issue #17482: functools.update_wrapper (and functools.wraps) now set the + __wrapped__ attribute correctly even if the underlying function has a + __wrapped__ attribute set. + +- Issue #18431: The new email header parser now decodes RFC2047 encoded words + in structured headers. + +- Issue #18432: The sched module's queue method was incorrectly returning + an iterator instead of a list. + +- Issue #18044: The new email header parser was mis-parsing encoded words where + an encoded character immediately followed the '?' that follows the CTE + character, resulting in a decoding failure. They are now decoded correctly. + +- Issue #18101: Tcl.split() now process strings nested in a tuple as it + do with byte strings. + +- Issue #18116: getpass was always getting an error when testing /dev/tty, + and thus was always falling back to stdin, and would then raise an exception + if stdin could not be used (such as /dev/null). It also leaked an open file. + All of these issues are now fixed. + +- Issue #17198: Fix a NameError in the dbm module. Patch by Valentina + Mukhamedzhanova. + +- Issue #18013: Fix cgi.FieldStorage to parse the W3C sample form. + +- Issue #18020: improve html.escape speed by an order of magnitude. + Patch by Matt Bryant. + +- Issue #18347: ElementTree's html serializer now preserves the case of + closing tags. + +- Issue #17261: Ensure multiprocessing's proxies use proper address. + +- Issue #18343: faulthandler.register() now keeps the previous signal handler + when the function is called twice, so faulthandler.unregister() restores + correctly the original signal handler. + +- Issue #17097: Make multiprocessing ignore EINTR. + +- Issue #18339: Negative ints keys in unpickler.memo dict no longer cause a + segfault inside the _pickle C extension. + +- Issue #18240: The HMAC module is no longer restricted to bytes and accepts + any bytes-like object, e.g. memoryview. Original patch by Jonas Borgström. + +- Issue #18224: Removed pydoc script from created venv, as it causes problems + on Windows and adds no value over and above python -m pydoc ... + +- Issue #18155: The csv module now correctly handles csv files that use + a delimiter character that has a special meaning in regexes, instead of + throwing an exception. + +- Issue #14360: encode_quopri can now be successfully used as an encoder + when constructing a MIMEApplication object. + +- Issue #11390: Add -o and -f command line options to the doctest CLI to + specify doctest options (and convert it to using argparse). + +- Issue #18135: ssl.SSLSocket.write() now raises an OverflowError if the input + string in longer than 2 gigabytes, and ssl.SSLContext.load_cert_chain() + raises a ValueError if the password is longer than 2 gigabytes. The ssl + module does not support partial write. + +- Issue #11016: Add C implementation of the stat module as _stat. + +- Issue #18248: Fix libffi build on AIX. + +- Issue #18259: Declare sethostname in socketmodule.c for AIX + +- Issue #18147: Add diagnostic functions to ssl.SSLContext(). get_ca_list() + lists all loaded CA certificates and cert_store_stats() returns amount of + loaded X.509 certs, X.509 CA certs and CRLs. + +- Issue #18167: cgi.FieldStorage no longer fails to handle multipart/form-data + when ``\r\n`` appears at end of 65535 bytes without other newlines. + +- Issue #18076: Introduce importlib.util.decode_source(). + +- Issue #18357: add tests for dictview set difference. + Patch by Fraser Tweedale. + +- importlib.abc.SourceLoader.get_source() no longer changes SyntaxError or + UnicodeDecodeError into ImportError. + +- Issue #18058, 18057: Make the namespace package loader meet the + importlib.abc.InspectLoader ABC, allowing for namespace packages to work with + runpy. + +- Issue #17177: The imp module is pending deprecation. + +- subprocess: Prevent a possible double close of parent pipe fds when the + subprocess exec runs into an error. Prevent a regular multi-close of the + /dev/null fd when any of stdin, stdout and stderr was set to DEVNULL. + +- Issue #18194: Introduce importlib.util.cache_from_source() and + source_from_cache() while documenting the equivalent functions in imp as + deprecated. + +- Issue #17907: Document imp.new_module() as deprecated in favour of + types.ModuleType. + +- Issue #18192: Introduce importlib.util.MAGIC_NUMBER and document as deprecated + imp.get_magic(). + +- Issue #18149: Add filecmp.clear_cache() to manually clear the filecmp cache. + Patch by Mark Levitt + +- Issue #18193: Add importlib.reload(). + +- Issue #18157: Stop using imp.load_module() in pydoc. + +- Issue #16102: Make uuid._netbios_getnode() work again on Python 3. + +- Issue #17134: Add ssl.enum_cert_store() as interface to Windows' cert store. + +- Issue #18143: Implement ssl.get_default_verify_paths() in order to debug + the default locations for cafile and capath. + +- Issue #17314: Move multiprocessing.forking over to importlib. + +- Issue #11959: SMTPServer and SMTPChannel now take an optional map, use of + which avoids affecting global state. + +- Issue #18109: os.uname() now decodes fields from the locale encoding, and + socket.gethostname() now decodes the hostname from the locale encoding, + instead of using the UTF-8 encoding in strict mode. + +- Issue #18089: Implement importlib.abc.InspectLoader.load_module. + +- Issue #18088: Introduce importlib.abc.Loader.init_module_attrs for setting + module attributes. Leads to the pending deprecation of + importlib.util.module_for_loader. + +- Issue #17403: urllib.parse.robotparser normalizes the urls before adding to + ruleline. This helps in handling certain types invalid urls in a conservative + manner. Patch contributed by Mher Movsisyan. + +- Issue #18070: Have importlib.util.module_for_loader() set attributes + unconditionally in order to properly support reloading. + +- Added importlib.util.module_to_load to return a context manager to provide the + proper module object to load. + +- Issue #18025: Fixed a segfault in io.BufferedIOBase.readinto() when raw + stream's read() returns more bytes than requested. + +- Issue #18011: As was originally intended, base64.b32decode() now raises a + binascii.Error if there are non-b32-alphabet characters present in the input + string, instead of a TypeError. + +- Issue #18072: Implement importlib.abc.InspectLoader.get_code() and + importlib.abc.ExecutionLoader.get_code(). + +- Issue #8240: Set the SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER flag on SSL + sockets. + +- Issue #17269: Workaround for socket.getaddrinfo crash on MacOS X + with port None or "0" and flags AI_NUMERICSERV. + +- Issue #16986: ElementTree now correctly works with string input when the + internal XML encoding is not UTF-8 or US-ASCII. + +- Issue #17996: socket module now exposes AF_LINK constant on BSD and OSX. + +- Issue #17900: Allowed pickling of recursive OrderedDicts. Decreased pickled + size and pickling time. + +- Issue #17914: Add os.cpu_count(). Patch by Yogesh Chaudhari, based on an + initial patch by Trent Nelson. + +- Issue #17812: Fixed quadratic complexity of base64.b32encode(). + Optimize base64.b32encode() and base64.b32decode() (speed up to 3x). + +- Issue #17980: Fix possible abuse of ssl.match_hostname() for denial of + service using certificates with many wildcards (CVE-2013-2099). + +- Issue #15758: Fix FileIO.readall() so it no longer has O(n**2) complexity. + +- Issue #14596: The struct.Struct() objects now use a more compact + implementation. + +- Issue #17981: logging's SysLogHandler now closes the socket when it catches + socket OSErrors. + +- Issue #17964: Fix os.sysconf(): the return type of the C sysconf() function + is long, not int. + +- Fix typos in the multiprocessing module. + +- Issue #17754: Make ctypes.util.find_library() independent of the locale. + +- Issue #17968: Fix memory leak in os.listxattr(). + +- Issue #17606: Fixed support of encoded byte strings in the XMLGenerator + characters() and ignorableWhitespace() methods. Original patch by Sebastian + Ortiz Vasquez. + +- Issue #17732: Ignore distutils.cfg options pertaining to install paths if a + virtual environment is active. + +- Issue #17915: Fix interoperability of xml.sax with file objects returned by + codecs.open(). + +- Issue #16601: Restarting iteration over tarfile really restarts rather + than continuing from where it left off. Patch by Michael Birtwell. + +- Issue #17289: The readline module now plays nicer with external modules + or applications changing the rl_completer_word_break_characters global + variable. Initial patch by Bradley Froehle. + +- Issue #12181: select module: Fix struct kevent definition on OpenBSD 64-bit + platforms. Patch by Federico Schwindt. + +- Issue #11816: multiple improvements to the dis module: get_instructions + generator, ability to redirect output to a file, Bytecode and Instruction + abstractions. Patch by Nick Coghlan, Ryan Kelly and Thomas Kluyver. + +- Issue #13831: Embed stringification of remote traceback in local + traceback raised when pool task raises an exception. + +- Issue #15528: Add weakref.finalize to support finalization using + weakref callbacks. + +- Issue #14173: Avoid crashing when reading a signal handler during + interpreter shutdown. + +- Issue #15902: Fix imp.load_module() accepting None as a file when loading an + extension module. + +- Issue #13721: SSLSocket.getpeercert() and SSLSocket.do_handshake() now + raise an OSError with ENOTCONN, instead of an AttributeError, when the + SSLSocket is not connected. + +- Issue #14679: add an __all__ (that contains only HTMLParser) to html.parser. + +- Issue #17802: Fix an UnboundLocalError in html.parser. Initial tests by + Thomas Barlow. + +- Issue #17358: Modules loaded by imp.load_source() and load_compiled() (and by + extension load_module()) now have a better chance of working when reloaded. + +- Issue #17804: New function ``struct.iter_unpack`` allows for streaming + struct unpacking. + +- Issue #17830: When keyword.py is used to update a keyword file, it now + preserves the line endings of the original file. + +- Issue #17272: Making the urllib.request's Request.full_url a descriptor. + Fixes bugs with assignment to full_url. Patch by Demian Brecht. + +- Issue #17353: Plistlib emitted empty data tags with deeply nested datastructures + +- Issue #11714: Use 'with' statements to assure a Semaphore releases a + condition variable. Original patch by Thomas Rachel. + +- Issue #16624: `subprocess.check_output` now accepts an `input` argument, + allowing the subprocess's stdin to be provided as a (byte) string. + Patch by Zack Weinberg. + +- Issue #17795: Reverted backwards-incompatible change in SysLogHandler with + Unix domain sockets. + +- Issue #16694: Add a pure Python implementation of the operator module. + Patch by Zachary Ware. + +- Issue #11182: remove the unused and undocumented pydoc.Scanner class. + Patch by Martin Morrison. + +- Issue #17741: Add ElementTree.XMLPullParser, an event-driven parser for + non-blocking applications. + +- Issue #17555: Fix ForkAwareThreadLock so that size of after fork + registry does not grow exponentially with generation of process. + +- Issue #17707: fix regression in multiprocessing.Queue's get() method where + it did not block for short timeouts. + +- Issue #17720: Fix the Python implementation of pickle.Unpickler to correctly + process the APPENDS opcode when it is used on non-list objects. + +- Issue #17012: shutil.which() no longer falls back to the PATH environment + variable if an empty path argument is specified. Patch by Serhiy Storchaka. + +- Issue #17710: Fix pickle raising a SystemError on bogus input. + +- Issue #17341: Include the invalid name in the error messages from re about + invalid group names. + +- Issue #17702: os.environ now raises KeyError with the original environment + variable name (str on UNIX), instead of using the encoded name (bytes on + UNIX). + +- Issue #16163: Make the importlib based version of pkgutil.iter_importers + work for submodules. Initial patch by Berker Peksag. + +- Issue #16804: Fix a bug in the 'site' module that caused running + 'python -S -m site' to incorrectly throw an exception. + +- Issue #15480: Remove the deprecated and unused TYPE_INT64 code from marshal. + Initial patch by Daniel Riti. + +- Issue #2118: SMTPException is now a subclass of OSError. + +- Issue #17016: Get rid of possible pointer wraparounds and integer overflows + in the re module. Patch by Nickolai Zeldovich. + +- Issue #16658: add missing return to HTTPConnection.send(). + Patch by Jeff Knupp. + +- Issue #9556: the logging package now allows specifying a time-of-day for a + TimedRotatingFileHandler to rotate. + +- Issue #14971: unittest test discovery no longer gets confused when a function + has a different __name__ than its name in the TestCase class dictionary. + +- Issue #17487: The wave getparams method now returns a namedtuple rather than + a plain tuple. + +- Issue #17675: socket repr() provides local and remote addresses (if any). + Patch by Giampaolo Rodola' + +- Issue #17093: Make the ABCs in importlib.abc provide default values or raise + reasonable exceptions for their methods to make them more amenable to super() + calls. + +- Issue #17566: Make importlib.abc.Loader.module_repr() optional instead of an + abstractmethod; now it raises NotImplementedError so as to be ignored by default. + +- Issue #17678: Remove the use of deprecated method in http/cookiejar.py by + changing the call to get_origin_req_host() to origin_req_host. + +- Issue #17666: Fix reading gzip files with an extra field. + +- Issue #16475: Support object instancing, recursion and interned strings + in marshal + +- Issue #17502: Process DEFAULT values in mock side_effect that returns iterator. + +- Issue #16795: On the ast.arguments object, unify vararg with varargannotation + and kwarg and kwargannotation. Change the column offset of ast.Attribute to be + at the attribute name. + +- Issue #17434: Properly raise a SyntaxError when a string occurs between future + imports. + +- Issue #17117: Import and @importlib.util.set_loader now set __loader__ when + it has a value of None or the attribute doesn't exist. + +- Issue #17032: The "global" in the "NameError: global name 'x' is not defined" + error message has been removed. Patch by Ram Rachum. + +- Issue #18080: When building a C extension module on OS X, if the compiler + is overridden with the CC environment variable, use the new compiler as + the default for linking if LDSHARED is not also overridden. This restores + Distutils behavior introduced in 3.2.3 and inadvertently dropped in 3.3.0. + +- Issue #18113: Fixed a refcount leak in the curses.panel module's + set_userptr() method. Reported by Atsuo Ishimoto. + +- Implement PEP 443 "Single-dispatch generic functions". + +- Implement PEP 435 "Adding an Enum type to the Python standard library". + +- Issue #15596: Faster pickling of unicode strings. + +- Issue #17572: Avoid chained exceptions when passing bad directives to + time.strptime(). Initial patch by Claudiu Popa. + +- Issue #17435: threading.Timer's __init__ method no longer uses mutable + default values for the args and kwargs parameters. + +- Issue #17526: fix an IndexError raised while passing code without filename to + inspect.findsource(). Initial patch by Tyler Doyle. + +- Issue #17540: Added style parameter to logging formatter configuration by dict. + +- Issue #16692: The ssl module now supports TLS 1.1 and TLS 1.2. Initial + patch by Michele Orrù. + +- Issue #17025: multiprocessing: Reduce Queue and SimpleQueue contention. + +- Issue #17536: Add to webbrowser's browser list: www-browser, x-www-browser, + iceweasel, iceape. + +- Issue #17150: pprint now uses line continuations to wrap long string + literals. + +- Issue #17488: Change the subprocess.Popen bufsize parameter default value + from unbuffered (0) to buffering (-1) to match the behavior existing code + expects and match the behavior of the subprocess module in Python 2 to avoid + introducing hard to track down bugs. + +- Issue #17521: Corrected non-enabling of logger following two calls to + fileConfig(). + +- Issue #17508: Corrected logging MemoryHandler configuration in dictConfig() + where the target handler wasn't configured first. + +- Issue #17209: curses.window.get_wch() now correctly handles KeyboardInterrupt + (CTRL+c). + +- Issue #5713: smtplib now handles 421 (closing connection) error codes when + sending mail by closing the socket and reporting the 421 error code via the + exception appropriate to the command that received the error response. + +- Issue #16997: unittest.TestCase now provides a subTest() context manager + to procedurally generate, in an easy way, small test instances. + +- Issue #17485: Also delete the Request Content-Length header if the data + attribute is deleted. (Follow on to issue Issue #16464). + +- Issue #15927: CVS now correctly parses escaped newlines and carriage + when parsing with quoting turned off. + +- Issue #17467: add readline and readlines support to mock_open in + unittest.mock. + +- Issue #13248: removed deprecated and undocumented difflib.isbjunk, + isbpopular. + +- Issue #17192: Update the ctypes module's libffi to v3.0.13. This + specifically addresses a stack misalignment issue on x86 and issues on + some more recent platforms. + +- Issue #8862: Fixed curses cleanup when getkey is interrupted by a signal. + +- Issue #17443: imaplib.IMAP4_stream was using the default unbuffered IO + in subprocess, but the imap code assumes buffered IO. In Python2 this + worked by accident. IMAP4_stream now explicitly uses buffered IO. + +- Issue #17476: Fixed regression relative to Python2 in undocumented pydoc + 'allmethods'; it was missing unbound methods on the class. + +- Issue #17474: Remove the deprecated methods of Request class. + +- Issue #16709: unittest discover order is no-longer filesystem specific. Patch + by Jeff Ramnani. + +- Use the HTTPS PyPI url for upload, overriding any plain HTTP URL in pypirc. + +- Issue #5024: sndhdr.whichhdr now returns the frame count for WAV files + rather than -1. + +- Issue #17460: Remove the strict argument of HTTPConnection and removing the + DeprecationWarning being issued from 3.2 onwards. + +- Issue #16880: Do not assume _imp.load_dynamic() is defined in the imp module. + +- Issue #16389: Fixed a performance regression relative to Python 3.1 in the + caching of compiled regular expressions. + +- Added missing FeedParser and BytesFeedParser to email.parser.__all__. + +- Issue #17431: Fix missing import of BytesFeedParser in email.parser. + +- Issue #12921: http.server's send_error takes an explain argument to send more + information in response. Patch contributed by Karl. + +- Issue #17414: Add timeit, repeat, and default_timer to timeit.__all__. + +- Issue #1285086: Get rid of the refcounting hack and speed up + urllib.parse.unquote() and urllib.parse.unquote_to_bytes(). + +- Issue #17099: Have importlib.find_loader() raise ValueError when __loader__ + is not set, harmonizing with what happens when the attribute is set to None. + +- Expose the O_PATH constant in the os module if it is available. + +- Issue #17368: Fix an off-by-one error in the Python JSON decoder that caused + a failure while decoding empty object literals when object_pairs_hook was + specified. + +- Issue #17385: Fix quadratic behavior in threading.Condition. The FIFO + queue now uses a deque instead of a list. + +- Issue #15806: Add contextlib.ignore(). This creates a context manager to + ignore specified exceptions, replacing the "except SomeException: pass" idiom. + +- Issue #14645: The email generator classes now produce output using the + specified linesep throughout. Previously if the prolog, epilog, or + body were stored with a different linesep, that linesep was used. This + fix corrects an RFC non-compliance issue with smtplib.send_message. + +- Issue #17278: Fix a crash in heapq.heappush() and heapq.heappop() when + the list is being resized concurrently. + +- Issue #16962: Use getdents64 instead of the obsolete getdents syscall + in the subprocess module on Linux. + +- Issue #16935: unittest now counts the module as skipped if it raises SkipTest, + instead of counting it as an error. Patch by Zachary Ware. + +- Issue #17018: Make Process.join() retry if os.waitpid() fails with EINTR. + +- Issue #17223: array module: Fix a crasher when converting an array containing + invalid characters (outside range [U+0000; U+10ffff]) to Unicode: + repr(array), str(array) and array.tounicode(). Patch written by Manuel Jacob. + +- Issue #17197: profile/cProfile modules refactored so that code of run() and + runctx() utility functions is not duplicated in both modules. + +- Issue #14720: sqlite3: Convert datetime microseconds correctly. + Patch by Lowe Thiderman. + +- Issue #15132: Allow a list for the defaultTest argument of + unittest.TestProgram. Patch by Jyrki Pulliainen. + +- Issue #17225: JSON decoder now counts columns in the first line starting + with 1, as in other lines. + +- Issue #6623: Added explicit DeprecationWarning for ftplib.netrc, which has + been deprecated and undocumented for a long time. + +- Issue #13700: Fix byte/string handling in imaplib authentication when an + authobject is specified. + +- Issue #13153: Tkinter functions now raise TclError instead of ValueError when + a string argument contains non-BMP character. + +- Issue #9669: Protect re against infinite loops on zero-width matching in + non-greedy repeat. Patch by Matthew Barnett. + +- Issue #13169: The maximal repetition number in a regular expression has been + increased from 65534 to 2147483647 (on 32-bit platform) or 4294967294 (on + 64-bit). + +- Issue #17143: Fix a missing import in the trace module. Initial patch by + Berker Peksag. + +- Issue #15220: email.feedparser's line splitting algorithm is now simpler and + faster. + +- Issue #16743: Fix mmap overflow check on 32 bit Windows. + +- Issue #16996: webbrowser module now uses shutil.which() to find a + web-browser on the executable search path. + +- Issue #16800: tempfile.gettempdir() no longer left temporary files when + the disk is full. Original patch by Amir Szekely. + +- Issue #17192: Import libffi-3.0.12. + +- Issue #16564: Fixed regression relative to Python2 in the operation of + email.encoders.encode_7or8bit when used with binary data. + +- Issue #17052: unittest discovery should use self.testLoader. + +- Issue #4591: Uid and gid values larger than 2**31 are supported now. + +- Issue #17141: random.vonmisesvariate() no longer hangs for large kappas. + +- Issue #17149: Fix random.vonmisesvariate to always return results in + [0, 2*math.pi]. + +- Issue #1470548: XMLGenerator now works with binary output streams. + +- Issue #6975: os.path.realpath() now correctly resolves multiple nested + symlinks on POSIX platforms. + +- Issue #13773: sqlite3.connect() gets a new `uri` parameter to pass the + filename as a URI, allowing custom options to be passed. + +- Issue #16564: Fixed regression relative to Python2 in the operation of + email.encoders.encode_noop when used with binary data. + +- Issue #10355: The mode, name, encoding and newlines properties now work on + SpooledTemporaryFile objects even when they have not yet rolled over. + Obsolete method xreadline (which has never worked in Python 3) has been + removed. + +- Issue #16686: Fixed a lot of bugs in audioop module. Fixed crashes in + avgpp(), maxpp() and ratecv(). Fixed an integer overflow in add(), bias(), + and ratecv(). reverse(), lin2lin() and ratecv() no more lose precision for + 32-bit samples. max() and rms() no more returns a negative result and + various other functions now work correctly with 32-bit sample -0x80000000. + +- Issue #17073: Fix some integer overflows in sqlite3 module. + +- Issue #16723: httplib.HTTPResponse no longer marked closed when the connection + is automatically closed. + +- Issue #15359: Add CAN_BCM protocol support to the socket module. Patch by + Brian Thorne. + +- Issue #16948: Fix quoted printable body encoding for non-latin1 character + sets in the email package. + +- Issue #16811: Fix folding of headers with no value in the provisional email + policies. + +- Issue #17132: Update symbol for "yield from" grammar changes. + +- Issue #17076: Make copying of xattrs more tolerant of missing FS support. + Patch by Thomas Wouters. + +- Issue #17089: Expat parser now correctly works with string input when the + internal XML encoding is not UTF-8 or US-ASCII. It also now accepts bytes + and strings larger than 2 GiB. + +- Issue #6083: Fix multiple segmentation faults occurred when PyArg_ParseTuple + parses nested mutating sequence. + +- Issue #5289: Fix ctypes.util.find_library on Solaris. + +- Issue #17106: Fix a segmentation fault in io.TextIOWrapper when an underlying + stream or a decoder produces data of an unexpected type (i.e. when + io.TextIOWrapper initialized with text stream or use bytes-to-bytes codec). + +- Issue #17015: When it has a spec, a Mock object now inspects its signature + when matching calls, so that arguments can be matched positionally or + by name. + +- Issue #15633: httplib.HTTPResponse is now mark closed when the server + sends less than the advertised Content-Length. + +- Issue #12268: The io module file object write methods no longer abort early + when one of its write system calls is interrupted (EINTR). + +- Issue #6972: The zipfile module no longer overwrites files outside of + its destination path when extracting malicious zip files. + +- Issue #4844: ZipFile now raises BadZipFile when opens a ZIP file with an + incomplete "End of Central Directory" record. Original patch by Guilherme + Polo and Alan McIntyre. + +- Issue #17071: Signature.bind() now works when one of the keyword arguments + is named ``self``. + +- Issue #12004: Fix an internal error in PyZipFile when writing an invalid + Python file. Patch by Ben Morgan. + +- Have py_compile use importlib as much as possible to avoid code duplication. + Code now raises FileExistsError if the file path to be used for the + byte-compiled file is a symlink or non-regular file as a warning that import + will not keep the file path type if it writes to that path. + +- Issue #16972: Have site.addpackage() consider already known paths even when + none are explicitly passed in. Bug report and fix by Kirill. + +- Issue #1602133: on Mac OS X a shared library build (``--enable-shared``) + now fills the ``os.environ`` variable correctly. + +- Issue #15505: `unittest.installHandler` no longer assumes SIGINT handler is + set to a callable object. + +- Issue #13454: Fix a crash when deleting an iterator created by itertools.tee() + if all other iterators were very advanced before. + +- Issue #12411: Fix to cgi.parse_multipart to correctly use bytes boundaries + and bytes data. Patch by Jonas Wagner. + +- Issue #16957: shutil.which() no longer searches a bare file name in the + current directory on Unix and no longer searches a relative file path with + a directory part in PATH directories. Patch by Thomas Kluyver. + +- Issue #1159051: GzipFile now raises EOFError when reading a corrupted file + with truncated header or footer. + +- Issue #16993: shutil.which() now preserves the case of the path and extension + on Windows. + +- Issue #16992: On Windows in signal.set_wakeup_fd, validate the file + descriptor argument. + +- Issue #16422: For compatibility with the Python version, the C version of + decimal now uses strings instead of integers for rounding mode constants. + +- Issue #15861: tkinter now correctly works with lists and tuples containing + strings with whitespaces, backslashes or unbalanced braces. + +- Issue #9720: zipfile now writes correct local headers for files larger than + 4 GiB. + +- Issue #16955: Fix the poll() method for multiprocessing's socket + connections on Windows. + +- SSLContext.load_dh_params() now properly closes the input file. + +- Issue #15031: Refactor some .pyc management code to cut down on code + duplication. Thanks to Ronan Lamy for the report and taking an initial stab + at the problem. + +- Issue #16398: Optimize deque.rotate() so that it only moves pointers + and doesn't touch the underlying data with increfs and decrefs. + +- Issue #16900: Issue a ResourceWarning when an ssl socket is left unclosed. + +- Issue #13899: ``\A``, ``\Z``, and ``\B`` now correctly match the A, Z, + and B literals when used inside character classes (e.g. ``'[\A]'``). + Patch by Matthew Barnett. + +- Issue #15545: Fix regression in sqlite3's iterdump method where it was + failing if the connection used a row factory (such as sqlite3.Row) that + produced unsortable objects. (Regression was introduced by fix for 9750). + +- fcntl: add F_DUPFD_CLOEXEC constant, available on Linux 2.6.24+. + +- Issue #15972: Fix error messages when os functions expecting a file name or + file descriptor receive the incorrect type. + +- Issue #8109: The ssl module now has support for server-side SNI, thanks + to a :meth:`SSLContext.set_servername_callback` method. Patch by Daniel + Black. + +- Issue #16860: In tempfile, use O_CLOEXEC when available to set the + close-on-exec flag atomically. + +- Issue #16674: random.getrandbits() is now 20-40% faster for small integers. + +- Issue #16009: JSON error messages now provide more information. + +- Issue #16828: Fix error incorrectly raised by bz2.compress(b'') and + bz2.BZ2Compressor.compress(b''). Initial patch by Martin Packman. + +- Issue #16833: In http.client.HTTPConnection, do not concatenate the request + headers and body when the payload exceeds 16 KB, since it can consume more + memory for no benefit. Patch by Benno Leslie. + +- Issue #16541: tk_setPalette() now works with keyword arguments. + +- Issue #16820: In configparser, `parser.popitem()` no longer raises ValueError. + This makes `parser.clean()` work correctly. + +- Issue #16820: In configparser, ``parser['section'] = {}`` now preserves + section order within the parser. This makes `parser.update()` preserve section + order as well. + +- Issue #16820: In configparser, ``parser['DEFAULT'] = {}`` now correctly + clears previous values stored in the default section. Same goes for + ``parser.update({'DEFAULT': {}})``. + +- Issue #9586: Redefine SEM_FAILED on MacOSX to keep compiler happy. + +- Issue #16787: Increase asyncore and asynchat default output buffers size, to + decrease CPU usage and increase throughput. + +- Issue #10527: make multiprocessing use poll() instead of select() if available. + +- Issue #16688: Now regexes contained backreferences correctly work with + non-ASCII strings. Patch by Matthew Barnett. + +- Issue #16486: Make aifc files act as context managers. + +- Issue #16485: Now file descriptors are closed if file header patching failed + on closing an aifc file. + +- Issue #16640: Run less code under a lock in sched module. + +- Issue #16165: sched.scheduler.run() no longer blocks a scheduler for other + threads. + +- Issue #16641: Default values of sched.scheduler.enter() are no longer + modifiable. + +- Issue #16618: Make glob.glob match consistently across strings and bytes + regarding leading dots. Patch by Serhiy Storchaka. + +- Issue #16788: Add samestat to Lib/ntpath.py + +- Issue #16713: Parsing of 'tel' urls using urlparse separates params from + path. + +- Issue #16443: Add docstrings to regular expression match objects. + Patch by Anton Kasyanov. + +- Issue #15701: Fix HTTPError info method call to return the headers information. + +- Issue #16752: Add a missing import to modulefinder. Patch by Berker Peksag. + +- Issue #16646: ftplib.FTP.makeport() might lose socket error details. + (patch by Serhiy Storchaka) + +- Issue #16626: Fix infinite recursion in glob.glob() on Windows when the + pattern contains a wildcard in the drive or UNC path. Patch by Serhiy + Storchaka. + +- Issue #15783: Except for the number methods, the C version of decimal now + supports all None default values present in decimal.py. These values were + largely undocumented. + +- Issue #11175: argparse.FileType now accepts encoding and errors + arguments. Patch by Lucas Maystre. + +- Issue #16488: epoll() objects now support the `with` statement. Patch + by Serhiy Storchaka. + +- Issue #16298: In HTTPResponse.read(), close the socket when there is no + Content-Length and the incoming stream is finished. Patch by Eran + Rundstein. + +- Issue #16049: Add abc.ABC class to enable the use of inheritance to create + ABCs, rather than the more cumbersome metaclass=ABCMeta. Patch by Bruno + Dupuis. + +- Expose the TCP_FASTOPEN and MSG_FASTOPEN flags in socket when they're + available. + +- Issue #15701: Add a .headers attribute to urllib.error.HTTPError. Patch + contributed by Berker Peksag. + +- Issue #15872: Fix 3.3 regression introduced by the new fd-based shutil.rmtree + that caused it to not ignore certain errors when ignore_errors was set. + Patch by Alessandro Moura and Serhiy Storchaka. + +- Issue #16248: Disable code execution from the user's home directory by + tkinter when the -E flag is passed to Python. Patch by Zachary Ware. + +- Issue #13390: New function :func:`sys.getallocatedblocks()` returns the + number of memory blocks currently allocated. + +- Issue #16628: Fix a memory leak in ctypes.resize(). + +- Issue #13614: Fix setup.py register failure with invalid rst in description. + Patch by Julien Courteau and Pierre Paul Lefebvre. + +- Issue #13512: Create ~/.pypirc securely (CVE-2011-4944). Initial patch by + Philip Jenvey, tested by Mageia and Debian. + +- Issue #7719: Make distutils ignore ``.nfs*`` files instead of choking later + on. Initial patch by SilentGhost and Jeff Ramnani. + +- Issue #13120: Allow calling pdb.set_trace() from thread. + Patch by Ilya Sandler. + +- Issue #16585: Make CJK encoders support error handlers that return bytes per + PEP 383. + +- Issue #10182: The re module doesn't truncate indices to 32 bits anymore. + Patch by Serhiy Storchaka. + +- Issue #16333: use (",", ": ") as default separator in json when indent is + specified, to avoid trailing whitespace. Patch by Serhiy Storchaka. + +- Issue #16573: In 2to3, treat enumerate() like a consuming call, so superfluous + list() calls aren't added to filter(), map(), and zip() which are directly + passed enumerate(). + +- Issue #16464: Reset the Content-Length header when a urllib Request is reused + with new data. + +- Issue #12848: The pure Python pickle implementation now treats object + lengths as unsigned 32-bit integers, like the C implementation does. + Patch by Serhiy Storchaka. + +- Issue #16423: urllib.request now has support for ``data:`` URLs. Patch by + Mathias Panzenböck. + +- Issue #4473: Add a POP3.stls() to switch a clear-text POP3 session into + an encrypted POP3 session, on supported servers. Patch by Lorenzo Catucci. + +- Issue #4473: Add a POP3.capa() method to query the capabilities advertised + by the POP3 server. Patch by Lorenzo Catucci. + +- Issue #4473: Ensure the socket is shutdown cleanly in POP3.close(). + Patch by Lorenzo Catucci. + +- Issue #16522: added FAIL_FAST flag to doctest. + +- Issue #15627: Add the importlib.abc.InspectLoader.source_to_code() method. + +- Issue #16408: Fix file descriptors not being closed in error conditions + in the zipfile module. Patch by Serhiy Storchaka. + +- Issue #14631: Add a new :class:`weakref.WeakMethod` to simulate weak + references to bound methods. + +- Issue #16469: Fix exceptions from float -> Fraction and Decimal -> Fraction + conversions for special values to be consistent with those for float -> int + and Decimal -> int. Patch by Alexey Kachayev. + +- Issue #16481: multiprocessing no longer leaks process handles on Windows. + +- Issue #12428: Add a pure Python implementation of functools.partial(). + Patch by Brian Thorne. + +- Issue #16140: The subprocess module no longer double closes its child + subprocess.PIPE parent file descriptors on child error prior to exec(). + +- Remove a bare print to stdout from the subprocess module that could have + happened if the child process wrote garbage to its pre-exec error pipe. + +- The subprocess module now raises its own SubprocessError instead of a + RuntimeError in various error situations which should not normally happen. + +- Issue #16327: The subprocess module no longer leaks file descriptors + used for stdin/stdout/stderr pipes to the child when fork() fails. + +- Issue #14396: Handle the odd rare case of waitpid returning 0 when not + expected in subprocess.Popen.wait(). + +- Issue #16411: Fix a bug where zlib.decompressobj().flush() might try to access + previously-freed memory. Patch by Serhiy Storchaka. + +- Issue #16357: fix calling accept() on a SSLSocket created through + SSLContext.wrap_socket(). Original patch by Jeff McNeil. + +- Issue #16409: The reporthook callback made by the legacy + urllib.request.urlretrieve API now properly supplies a constant non-zero + block_size as it did in Python 3.2 and 2.7. This matches the behavior of + urllib.request.URLopener.retrieve. + +- Issue #16431: Use the type information when constructing a Decimal subtype + from a Decimal argument. + +- Issue #15641: Clean up deprecated classes from importlib. + Patch by Taras Lyapun. + +- Issue #16350: zlib.decompressobj().decompress() now accumulates data from + successive calls after EOF in unused_data, instead of only saving the argument + to the last call. decompressobj().flush() now correctly sets unused_data and + unconsumed_tail. A bug in the handling of MemoryError when setting the + unconsumed_tail attribute has also been fixed. Patch by Serhiy Storchaka. + +- Issue #12759: sre_parse now raises a proper error when the name of the group + is missing. Initial patch by Serhiy Storchaka. + +- Issue #16152: fix tokenize to ignore whitespace at the end of the code when + no newline is found. Patch by Ned Batchelder. + +- Issue #16284: Prevent keeping unnecessary references to worker functions + in concurrent.futures ThreadPoolExecutor. + +- Issue #16230: Fix a crash in select.select() when one of the lists changes + size while iterated on. Patch by Serhiy Storchaka. + +- Issue #16228: Fix a crash in the json module where a list changes size + while it is being encoded. Patch by Serhiy Storchaka. + +- Issue #16351: New function gc.get_stats() returns per-generation collection + statistics. + +- Issue #14897: Enhance error messages of struct.pack and + struct.pack_into. Patch by Matti Mäki. + +- Issue #16316: mimetypes now recognizes the .xz and .txz (.tar.xz) extensions. + Patch by Serhiy Storchaka. + +- Issue #12890: cgitb no longer prints spurious <p> tags in text + mode when the logdir option is specified. + +- Issue #16307: Fix multiprocessing.Pool.map_async not calling its callbacks. + Patch by Janne Karila. + +- Issue #16305: Fix a segmentation fault occurring when interrupting + math.factorial. + +- Issue #16116: Fix include and library paths to be correct when building C + extensions in venvs. + +- Issue #16245: Fix the value of a few entities in html.entities.html5. + +- Issue #16301: Fix the localhost verification in urllib/request.py for ``file://`` + urls. + +- Issue #16250: Fix the invocations of URLError which had misplaced filename + attribute for exception. + +- Issue #10836: Fix exception raised when file not found in urlretrieve + Initial patch by Ezio Melotti. + +- Issue #14398: Fix size truncation and overflow bugs in the bz2 module. + +- Issue #12692: Fix resource leak in urllib.request when talking to an HTTP + server that does not include a ``Connection: close`` header in its responses. + +- Issue #12034: Fix bogus caching of result in check_GetFinalPathNameByHandle. + Patch by Atsuo Ishimoto. + +- Improve performance of `lzma.LZMAFile` (see also issue #16034). + +- Issue #16220: wsgiref now always calls close() on an iterable response. + Patch by Brent Tubbs. + +- Issue #16270: urllib may hang when used for retrieving files via FTP by using + a context manager. Patch by Giampaolo Rodola'. + +- Issue #16461: Wave library should be able to deal with 4GB wav files, + and sample rate of 44100 Hz. + +- Issue #16176: Properly identify Windows 8 via platform.platform() + +- Issue #16088: BaseHTTPRequestHandler's send_error method includes a + Content-Length header in its response now. Patch by Antoine Pitrou. + +- Issue #16114: The subprocess module no longer provides a misleading error + message stating that args[0] did not exist when either the cwd or executable + keyword arguments specified a path that did not exist. + +- Issue #16169: Fix ctypes.WinError()'s confusion between errno and winerror. + +- Issue #16110: logging.fileConfig now accepts a pre-initialised ConfigParser + instance. + +- Issue #1492704: shutil.copyfile() raises a distinct SameFileError now if + source and destination are the same file. Patch by Atsuo Ishimoto. + +- Issue #13896: Make shelf instances work with 'with' as context managers. + Original patch by Filip Gruszczyński. + +- Issue #15417: Add support for csh and fish in venv activation scripts. + +- Issue #14377: ElementTree.write and some of the module-level functions have + a new parameter - *short_empty_elements*. It controls how elements with no + contents are emitted. + +- Issue #16089: Allow ElementTree.TreeBuilder to work again with a non-Element + element_factory (fixes a regression in SimpleTAL). + +- Issue #9650: List commonly used format codes in time.strftime and + time.strptime docsttings. Original patch by Mike Hoy. + +- Issue #15452: logging configuration socket listener now has a verify option + that allows an application to apply a verification function to the + received configuration data before it is acted upon. + +- Issue #16034: Fix performance regressions in the new `bz2.BZ2File` + implementation. Initial patch by Serhiy Storchaka. + +- `pty.spawn()` now returns the child process status returned by `os.waitpid()`. + +- Issue #15756: `subprocess.poll()` now properly handles `errno.ECHILD` to + return a returncode of 0 when the child has already exited or cannot be waited + on. + +- Issue #15323: Improve failure message of `Mock.assert_called_once_with()`. + +- Issue #16064: ``unittest -m`` claims executable is "python", not "python3". + +- Issue #12376: Pass on parameters in `TextTestResult.__init__()` super call. + +- Issue #15222: Insert blank line after each message in mbox mailboxes. + +- Issue #16013: Fix `csv.Reader` parsing issue with ending quote characters. + Patch by Serhiy Storchaka. + +- Issue #15421: Fix an OverflowError in `Calendar.itermonthdates()` after + `datetime.MAXYEAR`. Patch by Cédric Krier. + +- Issue #16112: platform.architecture does not correctly escape argument to + /usr/bin/file. Patch by David Benjamin. + +- Issue #15970: `xml.etree.ElementTree` now serializes correctly the empty HTML + elements 'meta' and 'param'. + +- Issue #15842: The `SocketIO.{readable,writable,seekable}` methods now raise + ValueError when the file-like object is closed. Patch by Alessandro Moura. + +- Issue #15876: Fix a refleak in the `curses` module: window.encoding. + +- Issue #15881: Fix `atexit` hook in `multiprocessing`. Original patch by Chris + McDonough. + +- Issue #15841: The readable(), writable() and seekable() methods of + `io.BytesIO` and `io.StringIO` objects now raise ValueError when the object + has been closed. Patch by Alessandro Moura. + +- Issue #15447: Use `subprocess.DEVNULL` in webbrowser, instead of opening + `os.devnull` explicitly and leaving it open. + +- Issue #15509: `webbrowser.UnixBrowser` no longer passes empty arguments to + Popen when ``%action`` substitutions produce empty strings. + +- Issue #12776, issue #11839: Call `argparse` type function (specified by + add_argument) only once. Before, the type function was called twice in the + case where the default was specified and the argument was given as well. This + was especially problematic for the FileType type, as a default file would + always be opened, even if a file argument was specified on the command line. + +- Issue #15906: Fix a regression in argparse caused by the preceding change, + when ``action='append'``, ``type='str'`` and ``default=[]``. + +- Issue #16113: Added sha3 module based on the Keccak reference implementation + 3.2. The `hashlib` module has four additional hash algorithms: `sha3_224`, + `sha3_256`, `sha3_384` and `sha3_512`. As part of the patch some common + code was moved from _hashopenssl.c to hashlib.h. + +- ctypes.call_commethod was removed, since its only usage was in the defunct + samples directory. + +- Issue #16692: Added TLSv1.1 and TLSv1.2 support for the ssl modules. + +- Issue #16832: add abc.get_cache_token() to expose cache validity checking + support in ABCMeta. + +IDLE +---- + +- Issue #18429: Format / Format Paragraph, now works when comment blocks + are selected. As with text blocks, this works best when the selection + only includes complete lines. + +- Issue #18226: Add docstrings and unittests for FormatParagraph.py. + Original patches by Todd Rovito and Phil Webster. + +- Issue #18279: Format - Strip trailing whitespace no longer marks a file as + changed when it has not been changed. This fix followed the addition of a + test file originally written by Phil Webster (the issue's main goal). + +- Issue #7136: In the Idle File menu, "New Window" is renamed "New File". + Patch by Tal Einat, Roget Serwy, and Todd Rovito. + +- Remove dead imports of imp. + +- Issue #18196: Avoid displaying spurious SystemExit tracebacks. + +- Issue #5492: Avoid traceback when exiting IDLE caused by a race condition. + +- Issue #17511: Keep IDLE find dialog open after clicking "Find Next". + Original patch by Sarah K. + +- Issue #18055: Move IDLE off of imp and on to importlib. + +- Issue #15392: Create a unittest framework for IDLE. + Initial patch by Rajagopalasarma Jayakrishnan. + See Lib/idlelib/idle_test/README.txt for how to run Idle tests. + +- Issue #14146: Highlight source line while debugging on Windows. + +- Issue #17838: Allow sys.stdin to be reassigned. + +- Issue #13495: Avoid loading the color delegator twice in IDLE. + +- Issue #17798: Allow IDLE to edit new files when specified on command line. + +- Issue #14735: Update IDLE docs to omit "Control-z on Windows". + +- Issue #17532: Always include Options menu for IDLE on OS X. + Patch by Guilherme Simões. + +- Issue #17585: Fixed IDLE regression. Now closes when using exit() or quit(). + +- Issue #17657: Show full Tk version in IDLE's about dialog. + Patch by Todd Rovito. + +- Issue #17613: Prevent traceback when removing syntax colorizer in IDLE. + +- Issue #1207589: Backwards-compatibility patch for right-click menu in IDLE. + +- Issue #16887: IDLE now accepts Cancel in tabify/untabify dialog box. + +- Issue #17625: In IDLE, close the replace dialog after it is used. + +- Issue #14254: IDLE now handles readline correctly across shell restarts. + +- Issue #17614: IDLE no longer raises exception when quickly closing a file. + +- Issue #6698: IDLE now opens just an editor window when configured to do so. + +- Issue #8900: Using keyboard shortcuts in IDLE to open a file no longer + raises an exception. + +- Issue #6649: Fixed missing exit status in IDLE. Patch by Guilherme Polo. + +- Issue #17114: IDLE now uses non-strict config parser. + +- Issue #9290: In IDLE the sys.std* streams now implement io.TextIOBase + interface and support all mandatory methods and properties. + +- Issue #5066: Update IDLE docs. Patch by Todd Rovito. + +- Issue #16829: IDLE printing no longer fails if there are spaces or other + special characters in the file path. + +- Issue #16491: IDLE now prints chained exception tracebacks. + +- Issue #16819: IDLE method completion now correctly works for bytes literals. + +- Issue #16504: IDLE now catches SyntaxErrors raised by tokenizer. Patch by + Roger Serwy. + +- Issue #16511: Use default IDLE width and height if config param is not valid. + Patch Serhiy Storchaka. + +- Issue #1207589: Add Cut/Copy/Paste items to IDLE right click Context Menu. + Patch by Todd Rovito. + +- Issue #16123: IDLE - deprecate running without a subprocess. + Patch by Roger Serwy. + +Tests +----- + +- Issue #1666318: Add a test that shutil.copytree() retains directory + permissions. Patch by Catherine Devlin. + +- Issue #18273: move the tests in Lib/test/json_tests to Lib/test/test_json + and make them discoverable by unittest. Patch by Zachary Ware. + +- Fix a fcntl test case on KFreeBSD, Debian #708653 (Petr Salinger). + +- Issue #18396: Fix spurious test failure in test_signal on Windows when + faulthandler is enabled (Patch by Jeremy Kloth) + +- Issue #17046: Fix broken test_executable_without_cwd in test_subprocess. + +- Issue #15415: Add new temp_dir() and change_cwd() context managers to + test.support, and refactor temp_cwd() to use them. Patch by Chris Jerdonek. + +- Issue #15494: test.support is now a package rather than a module (Initial + patch by Indra Talip) + +- Issue #17944: test_zipfile now discoverable and uses subclassing to + generate tests for different compression types. Fixed a bug with skipping + some tests due to use of exhausted iterators. + +- Issue #18266: test_largefile now works with unittest test discovery and + supports running only selected tests. Patch by Zachary Ware. + +- Issue #17767: test_locale now works with unittest test discovery. + Original patch by Zachary Ware. + +- Issue #18375: Assume --randomize when --randseed is used for running the + testsuite. + +- Issue #11185: Fix test_wait4 under AIX. Patch by Sébastien Sablé. + +- Issue #18207: Fix test_ssl for some versions of OpenSSL that ignore seconds + in ASN1_TIME fields. + +- Issue #18094: test_uuid no longer reports skipped tests as passed. + +- Issue #17992: Add timeouts to asyncore and asynchat tests so that they won't + accidentally hang. + +- Issue #17833: Fix test_gdb failures seen on machines where debug symbols + for glibc are available (seen on PPC64 Linux). + +- Issue #7855: Add tests for ctypes/winreg for issues found in IronPython. + Initial patch by Dino Viehland. + +- Issue #11078: test___all__ now checks for duplicates in __all__. + Initial patch by R. David Murray. + +- Issue #17712: Fix test_gdb failures on Ubuntu 13.04. + +- Issue #17835: Fix test_io when the default OS pipe buffer size is larger + than one million bytes. + +- Issue #17065: Use process-unique key for winreg tests to avoid failures if + test is run multiple times in parallel (eg: on a buildbot host). + +- Issue #12820: add tests for the xml.dom.minicompat module. + Patch by John Chandler and Phil Connell. + +- Issue #17691: test_univnewlines now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17790: test_set now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17789: test_random now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17779: test_osx_env now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17766: test_iterlen now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17690: test_time now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17692: test_sqlite now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #11995: test_pydoc doesn't import all sys.path modules anymore. + +- Issue #17448: test_sax now skips if there are no xml parsers available + instead of raising an ImportError. + +- Issue #11420: make test suite pass with -B/DONTWRITEBYTECODE set. + Initial patch by Thomas Wouters. + +- Issue #10652: make tcl/tk tests run after __all__ test, patch by + Zachary Ware. + +- Issue #11963: remove human verification from test_parser and test_subprocess. + +- Issue #11732: add a new suppress_crash_popup() context manager to test.support + that disables crash popups on Windows and use it in test_faulthandler and + test_capi. + +- Issue #13898: test_ssl no longer prints a spurious stack trace on Ubuntu. + +- Issue #17283: Share code between `__main__.py` and `regrtest.py` in + `Lib/test`. + +- Issue #17249: convert a test in test_capi to use unittest and reap threads. + +- Issue #17107: Test client-side SNI support in urllib.request thanks to + the new server-side SNI support in the ssl module. Initial patch by + Daniel Black. + +- Issue #17041: Fix testing when Python is configured with the + --without-doc-strings. + +- Issue #16923: Fix ResourceWarnings in test_ssl. + +- Issue #15539: Added regression tests for Tools/scripts/pindent.py. + +- Issue #17479: test_io now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17066: test_robotparser now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17334: test_index now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17333: test_imaplib now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17082: test_dbm* now work with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17079: test_ctypes now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17304: test_hash now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17303: test_future* now work with unittest test discovery. + Patch by Zachary Ware. + +- Issue #17163: test_file now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16925: test_configparser now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16918: test_codecs now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16919: test_crypt now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16910: test_bytes, test_unicode, and test_userstring now work with + unittest test discovery. Patch by Zachary Ware. + +- Issue #16905: test_warnings now works with unittest test discovery. + Initial patch by Berker Peksag. + +- Issue #16898: test_bufio now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16888: test_array now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16896: test_asyncore now works with unittest test discovery. + Patch by Zachary Ware. + +- Issue #16897: test_bisect now works with unittest test discovery. + Initial patch by Zachary Ware. + +- Issue #16852: test_genericpath, test_posixpath, test_ntpath, and test_macpath + now work with unittest test discovery. Patch by Zachary Ware. + +- Issue #16748: test_heapq now works with unittest test discovery. + +- Issue #10646: Tests rearranged for os.samefile/samestat to check for not + just symlinks but also hard links. + +- Issue #15302: Switch regrtest from using getopt to using argparse. + +- Issue #15324: Fix regrtest parsing of --fromfile, --match, and --randomize + options. + +- Issue #16702: test_urllib2_localnet tests now correctly ignores proxies for + localhost tests. + +- Issue #16664: Add regression tests for glob's behaviour concerning entries + starting with a ".". Patch by Sebastian Kreft. + +- Issue #13390: The ``-R`` option to regrtest now also checks for memory + allocation leaks, using :func:`sys.getallocatedblocks()`. + +- Issue #16559: Add more tests for the json module, including some from the + official test suite at json.org. Patch by Serhiy Storchaka. + +- Issue #16661: Fix the `os.getgrouplist()` test by not assuming that it gives + the same output as :command:`id -G`. + +- Issue #16115: Add some tests for the executable argument to + subprocess.Popen(). Initial patch by Kushal Das. + +- Issue #16126: PyErr_Format format mismatch in _testcapimodule.c. + Patch by Serhiy Storchaka. + +- Issue #15304: Fix warning message when `os.chdir()` fails inside + `test.support.temp_cwd()`. Patch by Chris Jerdonek. + +- Issue #15802: Fix test logic in `TestMaildir.test_create_tmp()`. Patch by + Serhiy Storchaka. + +- Issue #15557: Added a test suite for the webbrowser module, thanks to Anton + Barkovsky. + +- Issue #16698: Skip posix test_getgroups when built with OS X + deployment target prior to 10.6. + +Build +----- + +- Issue #16067: Add description into MSI file to replace installer's + temporary name. + +- Issue #18257: Fix readlink usage in python-config. Install the python + version again on Darwin. + +- Issue #18481: Add C coverage reporting with gcov and lcov. A new make target + "coverage-report" creates an instrumented Python build, runs unit tests + and creates a HTML. The report can be updated with "make coverage-lcov". + +- Issue #17845: Clarified the message printed when some module are not built. + +- Issue #18256: Compilation fix for recent AIX releases. Patch by + David Edelsohn. + +- Issue #17547: In configure, explicitly pass -Wformat for the benefit for GCC + 4.8. + +- Issue #15172: Document NASM 2.10+ as requirement for building OpenSSL 1.0.1 + on Windows. + +- Issue #17591: Use lowercase filenames when including Windows header files. + Patch by Roumen Petrov. + +- Issue #17550: Fix the --enable-profiling configure switch. + +- Issue #17425: Build with openssl 1.0.1d on Windows. + +- Issue #16754: Fix the incorrect shared library extension on linux. Introduce + two makefile macros SHLIB_SUFFIX and EXT_SUFFIX. SO now has the value of + SHLIB_SUFFIX again (as in 2.x and 3.1). The SO macro is removed in 3.4. + +- Issue #5033: Fix building of the sqlite3 extension module when the + SQLite library version has "beta" in it. Patch by Andreas Pelme. + +- Issue #17228: Fix building without pymalloc. + +- Issue #3718: Use AC_ARG_VAR to set MACHDEP in configure.ac. + +- Issue #16235: Implement python-config as a shell script. + +- Issue #16769: Remove outdated Visual Studio projects. + +- Issue #17031: Fix running regen in cross builds. + +- Issue #3754: fix typo in pthread AC_CACHE_VAL. + +- Issue #15484: Fix _PYTHON_PROJECT_BASE for srcdir != builddir builds; + use _PYTHON_PROJECT_BASE in distutils/sysconfig.py. + +- Drop support for Windows 2000 (changeset e52df05b496a). + +- Issue #17029: Let h2py search the multiarch system include directory. + +- Issue #16953: Fix socket module compilation on platforms with + HAVE_BROKEN_POLL. Patch by Jeffrey Armstrong. + +- Issue #16320: Remove redundant Makefile dependencies for strings and bytes. + +- Cross compiling needs host and build settings. configure no longer + creates a broken PYTHON_FOR_BUILD variable when --build is missing. + +- Fix cross compiling issue in setup.py, ensure that lib_dirs and inc_dirs are + defined in cross compiling mode, too. + +- Issue #16836: Enable IPv6 support even if IPv6 is disabled on the build host. + +- Issue #16593: Have BSD 'make -s' do the right thing, thanks to Daniel Shahaf + +- Issue #16262: fix out-of-src-tree builds, if mercurial is not installed. + +- Issue #15298: ensure _sysconfigdata is generated in build directory, not + source directory. + +- Issue #15833: Fix a regression in 3.3 that resulted in exceptions being + raised if importlib failed to write byte-compiled files. This affected + attempts to build Python out-of-tree from a read-only source directory. + +- Issue #15923: Fix a mistake in ``asdl_c.py`` that resulted in a TypeError + after 2801bf875a24 (see #15801). + +- Issue #16135: Remove OS/2 support. + +- Issue #15819: Make sure we can build Python out-of-tree from a read-only + source directory. (Somewhat related to issue #9860.) + +- Issue #15587: Enable Tk high-resolution text rendering on Macs with + Retina displays. Applies to Tkinter apps, such as IDLE, on OS X + framework builds linked with Cocoa Tk 8.5. + +- Issue #17161: make install now also installs a python3 man page. + +C-API +----- + +- Issue #18351: Fix various issues in a function in importlib provided to help + PyImport_ExecCodeModuleWithPathnames() (and thus by extension + PyImport_ExecCodeModule() and PyImport_ExecCodeModuleEx()). + +- Issue #15767: Added PyErr_SetImportErrorSubclass(). + +- PyErr_SetImportError() now sets TypeError when its msg argument is set. + +- Issue #9369: The types of `char*` arguments of PyObject_CallFunction() and + PyObject_CallMethod() now changed to `const char*`. Based on patches by + Jörg Müller and Lars Buitinck. + +- Issue #17206: Py_CLEAR(), Py_DECREF(), Py_XINCREF() and Py_XDECREF() now + expand their arguments once instead of multiple times. Patch written by Illia + Polosukhin. + +- Issue #17522: Add the PyGILState_Check() API. + +- Issue #17327: Add PyDict_SetDefault. + +- Issue #16881: Fix Py_ARRAY_LENGTH macro for GCC < 3.1. + +- Issue #16505: Remove unused Py_TPFLAGS_INT_SUBCLASS. + +- Issue #16086: PyTypeObject.tp_flags and PyType_Spec.flags are now unsigned + (unsigned long and unsigned int) to avoid an undefined behaviour with + Py_TPFLAGS_TYPE_SUBCLASS ((1 << 31). PyType_GetFlags() result type is + now unsigned too (unsigned long, instead of long). + +- Issue #16166: Add PY_LITTLE_ENDIAN and PY_BIG_ENDIAN macros and unified + endianness detection and handling. + +Documentation +------------- + +- Issue #23006: Improve the documentation and indexing of dict.__missing__. + Add an entry in the language datamodel special methods section. + Revise and index its discussion in the stdtypes mapping/dict section. + +- Issue #17701: Improving strftime documentation. + +- Issue #18440: Clarify that `hash()` can truncate the value returned from an + object's custom `__hash__()` method. + +- Issue #17844: Add links to encoders and decoders for bytes-to-bytes codecs. + +- Issue #14097: improve the "introduction" page of the tutorial. + +- Issue #17977: The documentation for the cadefault argument's default value + in urllib.request.urlopen() is fixed to match the code. + +- Issue #6696: add documentation for the Profile objects, and improve + profile/cProfile docs. Patch by Tom Pinckney. + +- Issue #15940: Specify effect of locale on time functions. + +- Issue #17538: Document XML vulnerabilties + +- Issue #16642: sched.scheduler timefunc initial default is time.monotonic. + Patch by Ramchandra Apte + +- Issue #17047: remove doubled words in docs and docstrings + reported by Serhiy Storchaka and Matthew Barnett. + +- Issue #15465: Document the versioning macros in the C API docs rather than + the standard library docs. Patch by Kushal Das. + +- Issue #16406: Combine the pages for uploading and registering to PyPI. + +- Issue #16403: Document how distutils uses the maintainer field in + PKG-INFO. Patch by Jyrki Pulliainen. + +- Issue #16695: Document how glob handles filenames starting with a + dot. Initial patch by Jyrki Pulliainen. + +- Issue #8890: Stop advertising an insecure practice by replacing uses + of the /tmp directory with better alternatives in the documentation. + Patch by Geoff Wilson. + +- Issue #17203: add long option names to unittest discovery docs. + +- Issue #13094: add "Why do lambdas defined in a loop with different values + all return the same result?" programming FAQ. + +- Issue #14901: Update portions of the Windows FAQ. + Patch by Ashish Nitin Patil. + +- Issue #16267: Better document the 3.3+ approach to combining + @abstractmethod with @staticmethod, @classmethod and @property + +- Issue #15209: Clarify exception chaining description in exceptions module + documentation + +- Issue #15990: Improve argument/parameter documentation. + +- Issue #16209: Move the documentation for the str built-in function to a new + str class entry in the "Text Sequence Type" section. + +- Issue #13538: Improve str() and object.__str__() documentation. + +- Issue #16489: Make it clearer that importlib.find_loader() needs parent + packages to be explicitly imported. + +- Issue #16400: Update the description of which versions of a given package + PyPI displays. + +- Issue #15677: Document that zlib and gzip accept a compression level of 0 to + mean 'no compression'. Patch by Brian Brazil. + +- Issue #16197: Update winreg docstrings and documentation to match code. + Patch by Zachary Ware. + +- Issue #8040: added a version switcher to the documentation. Patch by + Yury Selivanov. + +- Issue #16241: Document -X faulthandler command line option. + Patch by Marek Šuppa. + +- Additional comments and some style changes in the concurrent.futures URL + retrieval example + +- Issue #16115: Improve subprocess.Popen() documentation around args, shell, + and executable arguments. + +- Issue #13498: Clarify docs of os.makedirs()'s exist_ok argument. Done with + great native-speaker help from R. David Murray. + +- Issue #15533: Clarify docs and add tests for `subprocess.Popen()`'s cwd + argument. + +- Issue #15979: Improve timeit documentation. + +- Issue #16036: Improve documentation of built-in `int()`'s signature and + arguments. + +- Issue #15935: Clarification of `argparse` docs, re: add_argument() type and + default arguments. Patch contributed by Chris Jerdonek. + +- Issue #11964: Document a change in v3.2 to the behavior of the indent + parameter of json encoding operations. + +- Issue #15116: Remove references to appscript as it is no longer being + supported. + +Tools/Demos +----------- + +- Issue #18817: Fix a resource warning in Lib/aifc.py demo. Patch by + Vajrasky Kok. + +- Issue #18439: Make patchcheck work on Windows for ACKS, NEWS. + +- Issue #18448: Fix a typo in Tools/demo/eiffel.py. + +- Issue #18457: Fixed saving of formulas and complex numbers in + Tools/demo/ss1.py. + +- Issue #18449: Make Tools/demo/ss1.py work again on Python 3. Patch by + Févry Thibault. + +- Issue #12990: The "Python Launcher" on OSX could not launch python scripts + that have paths that include wide characters. + +- Issue #15239: Make mkstringprep.py work again on Python 3. + +- Issue #17028: Allowed Python arguments to be supplied to the Windows + launcher. + +- Issue #17156: pygettext.py now detects the encoding of source files and + correctly writes and escapes non-ascii characters. + +- Issue #15539: Fix a number of bugs in Tools/scripts/pindent.py. Now + pindent.py works with a "with" statement. pindent.py no longer produces + improper indentation. pindent.py now works with continued lines broken after + "class" or "def" keywords and with continuations at the start of line. + +- Issue #11797: Add a 2to3 fixer that maps reload() to imp.reload(). + +- Issue #10966: Remove the concept of unexpected skipped tests. + +- Issue #9893: Removed the Misc/Vim directory. + +- Removed the Misc/TextMate directory. + +- Issue #16245: Add the Tools/scripts/parse_html5_entities.py script to parse + the list of HTML5 entities and update the html.entities.html5 dictionary. + +- Issue #15378: Fix Tools/unicode/comparecodecs.py. Patch by Serhiy Storchaka. + +- Issue #16549: Make json.tool work again on Python 3 and add tests. + Initial patch by Berker Peksag and Serhiy Storchaka. + +- Issue #13301: use ast.literal_eval() instead of eval() in Tools/i18n/msgfmt.py. + Patch by Serhiy Storchaka. + +Windows +------- + +- Issue #18569: The installer now adds .py to the PATHEXT variable when extensions + are registered. Patch by Paul Moore. + + What's New in Python 3.3.0? =========================== @@ -2,8 +2,8 @@ Python News +++++++++++ -What's New in Python 3.6.0 beta 2 -================================= +What's New in Python 3.7.0 alpha 1 +================================== *Release date: XXXX-XX-XX* @@ -63,6 +63,17 @@ Build - Issue #15819: Remove redundant include search directory option for building outside the source tree. +Tools/Demos +----------- + +- Issue #15369: The pybench and pystone microbenchmark have been removed from + Tools. Please use the new Python benchmark suite + https://github.com/python/performance which is more reliable and includes a + portable version of pybench working on Python 2 and Python 3. + +- Issue #28102: The zipfile module CLI now prints usage to stderr. + Patch by Stephen J. Turnbull. + What's New in Python 3.6.0 beta 1 ================================= @@ -6155,4304 +6166,5 @@ Windows ".cp35-win32.pyd") will now be loaded in preference to those without tags. -What's New in Python 3.4.0? -=========================== - -Release date: 2014-03-16 - -Library -------- - -- Issue #20939: Fix test_geturl failure in test_urllibnet due to - new redirect of http://www.python.org/ to https://www.python.org. - -Documentation -------------- - -- Merge in all documentation changes since branching 3.4.0rc1. - - -What's New in Python 3.4.0 release candidate 3? -=============================================== - -Release date: 2014-03-09 - -Core and Builtins ------------------ - -- Issue #20786: Fix signatures for dict.__delitem__ and - property.__delete__ builtins. - -Library -------- - -- Issue #20839: Don't trigger a DeprecationWarning in the still supported - pkgutil.get_loader() API when __loader__ isn't set on a module (nor - when pkgutil.find_loader() is called directly). - -Build ------ - -- Issue #14512: Launch pydoc -b instead of pydocgui.pyw on Windows. - -- Issue #20748: Uninstalling pip does not leave behind the pyc of - the uninstaller anymore. - -- Issue #20568: The Windows installer now installs the unversioned ``pip`` - command in addition to the versioned ``pip3`` and ``pip3.4`` commands. - -- Issue #20757: The ensurepip helper for the Windows uninstaller now skips - uninstalling pip (rather than failing) if the user has updated pip to a - different version from the one bundled with ensurepip. - -- Issue #20465: Update OS X and Windows installer builds to use - SQLite 3.8.3.1. - - -What's New in Python 3.4.0 release candidate 2? -=============================================== - -Release date: 2014-02-23 - -Core and Builtins ------------------ - -- Issue #20625: Parameter names in __annotations__ were not mangled properly. - Discovered by Jonas Wielicki, patch by Yury Selivanov. - -- Issue #20261: In pickle, lookup __getnewargs__ and __getnewargs_ex__ on the - type of the object. - -- Issue #20619: Give the AST nodes of keyword-only arguments a column and line - number. - -- Issue #20526: Revert changes of issue #19466 which introduces a regression: - don't clear anymore the state of Python threads early during the Python - shutdown. - -Library -------- - -- Issue #20710: The pydoc summary line no longer displays the "self" parameter - for bound methods. - -- Issue #20566: Change asyncio.as_completed() to use a Queue, to - avoid O(N**2) behavior. - -- Issue #20704: Implement new debug API in asyncio. Add new methods - BaseEventLoop.set_debug() and BaseEventLoop.get_debug(). - Add support for setting 'asyncio.tasks._DEBUG' variable with - 'PYTHONASYNCIODEBUG' environment variable. - -- asyncio: Refactoring and fixes: BaseEventLoop.sock_connect() raises an - error if the address is not resolved; use __slots__ in Handle and - TimerHandle; as_completed() and wait() raise TypeError if the passed - list of Futures is a single Future; call_soon() and other 'call_*()' - functions raise TypeError if the passed callback is a coroutine - function; _ProactorBasePipeTransport uses _FlowControlMixin; - WriteTransport.set_write_buffer_size() calls _maybe_pause_protocol() - to consider pausing receiving if the watermark limits have changed; - fix _check_resolved_address() for IPv6 address; and other minor - improvements, along with multiple documentation updates. - -- Issue #20684: Fix inspect.getfullargspec() to not to follow __wrapped__ - chains. Make its behaviour consistent with bound methods first argument. - Patch by Nick Coghlan and Yury Selivanov. - -- Issue #20681: Add new error handling API in asyncio. New APIs: - loop.set_exception_handler(), loop.default_exception_handler(), and - loop.call_exception_handler(). - -- Issue #20673: Implement support for UNIX Domain Sockets in asyncio. - New APIs: loop.create_unix_connection(), loop.create_unix_server(), - streams.open_unix_connection(), and streams.start_unix_server(). - -- Issue #20616: Add a format() method to tracemalloc.Traceback. - -- Issue #19744: the ensurepip installation step now just prints a warning to - stderr rather than failing outright if SSL/TLS is unavailable. This allows - local installation of POSIX builds without SSL/TLS support. - -- Issue #20594: Avoid name clash with the libc function posix_close. - -Build ------ - -- Issue #20641: Run MSI custom actions (pip installation, pyc compilation) - with the NoImpersonate flag, to support elevated execution (UAC). - -- Issue #20221: Removed conflicting (or circular) hypot definition when - compiled with VS 2010 or above. Initial patch by Tabrez Mohammed. - -- Issue #20609: Restored the ability to build 64-bit Windows binaries on - 32-bit Windows, which was broken by the change in issue #19788. - - -What's New in Python 3.4.0 release candidate 1? -=============================================== - -Release date: 2014-02-10 - -Core and Builtins ------------------ - -- Issue #19255: The builtins module is restored to initial value before - cleaning other modules. The sys and builtins modules are cleaned last. - -- Issue #20588: Make Python-ast.c C89 compliant. - -- Issue #20437: Fixed 22 potential bugs when deleting object references. - -- Issue #20500: Displaying an exception at interpreter shutdown no longer - risks triggering an assertion failure in PyObject_Str. - -- Issue #20538: UTF-7 incremental decoder produced inconsistent string when - input was truncated in BASE64 section. - -- Issue #20404: io.TextIOWrapper (and hence the open() builtin) now uses the - internal codec marking system added for issue #19619 to throw LookupError - for known non-text encodings at stream construction time. The existing - output type checks remain in place to deal with unmarked third party - codecs. - -- Issue #17162: Add PyType_GetSlot. - -- Issue #20162: Fix an alignment issue in the siphash24() hash function which - caused a crash on PowerPC 64-bit (ppc64). - -Library -------- - -- Issue #20530: The signatures for slot builtins have been updated - to reflect the fact that they only accept positional-only arguments. - -- Issue #20517: Functions in the os module that accept two filenames - now register both filenames in the exception on failure. - -- Issue #20563: The ipaddress module API is now considered stable. - -- Issue #14983: email.generator now always adds a line end after each MIME - boundary marker, instead of doing so only when there is an epilogue. This - fixes an RFC compliance bug and solves an issue with signed MIME parts. - -- Issue #20540: Fix a performance regression (vs. Python 3.2) when layering - a multiprocessing Connection over a TCP socket. For small payloads, Nagle's - algorithm would introduce idle delays before the entire transmission of a - message. - -- Issue #16983: the new email header parsing code will now decode encoded words - that are (incorrectly) surrounded by quotes, and register a defect. - -- Issue #19772: email.generator no longer mutates the message object when - doing a down-transform from 8bit to 7bit CTEs. - -- Issue #20536: the statistics module now correctly handle Decimal instances - with positive exponents - -- Issue #18805: the netmask/hostmask parsing in ipaddress now more reliably - filters out illegal values and correctly allows any valid prefix length. - -- Issue #20481: For at least Python 3.4, the statistics module will require - that all inputs for a single operation be of a single consistent type, or - else a mixed of ints and a single other consistent type. This avoids - some interoperability issues that arose with the previous approach of - coercing to a suitable common type. - -- Issue #20478: the statistics module now treats collections.Counter inputs - like any other iterable. - -- Issue #17369: get_filename was raising an exception if the filename - parameter's RFC2231 encoding was broken in certain ways. This was - a regression relative to python2. - -- Issue #20013: Some imap servers disconnect if the current mailbox is - deleted, and imaplib did not handle that case gracefully. Now it - handles the 'bye' correctly. - -- Issue #20531: Revert 3.4 version of fix for #19063, and apply the 3.3 - version. That is, do *not* raise an error if unicode is passed to - email.message.Message.set_payload. - -- Issue #20476: If a non-compat32 policy is used with any of the email parsers, - EmailMessage is now used as the factory class. The factory class should - really come from the policy; that will get fixed in 3.5. - -- Issue #19920: TarFile.list() no longer fails when outputs a listing - containing non-encodable characters. Based on patch by Vajrasky Kok. - -- Issue #20515: Fix NULL pointer dereference introduced by issue #20368. - -- Issue #19186: Restore namespacing of expat symbols inside the pyexpat module. - -- Issue #20053: ensurepip (and hence venv) are no longer affected by the - settings in the default pip configuration file. - -- Issue #20426: When passing the re.DEBUG flag, re.compile() displays the - debug output every time it is called, regardless of the compilation cache. - -- Issue #20368: The null character now correctly passed from Tcl to Python. - Improved error handling in variables-related commands. - -- Issue #20435: Fix _pyio.StringIO.getvalue() to take into account newline - translation settings. - -- tracemalloc: Fix slicing traces and fix slicing a traceback. - -- Issue #20354: Fix an alignment issue in the tracemalloc module on 64-bit - platforms. Bug seen on 64-bit Linux when using "make profile-opt". - -- Issue #17159: inspect.signature now accepts duck types of functions, - which adds support for Cython functions. Initial patch by Stefan Behnel. - -- Issue #18801: Fix inspect.classify_class_attrs to correctly classify - object.__new__ and object.__init__. - -- Fixed cmath.isinf's name in its argument parsing code. - -- Issue #20311, #20452: poll and epoll now round the timeout away from zero, - instead of rounding towards zero, in select and selectors modules: - select.epoll.poll(), selectors.PollSelector.poll() and - selectors.EpollSelector.poll(). For example, a timeout of one microsecond - (1e-6) is now rounded to one millisecondi (1e-3), instead of being rounded to - zero. However, the granularity property and asyncio's resolution feature - were removed again. - -- asyncio: Some refactoring; various fixes; add write flow control to - unix pipes; Future.set_exception() instantiates the exception - argument if it is a class; improved proactor pipe transport; support - wait_for(f, None); don't log broken/disconnected pipes; use - ValueError instead of assert for forbidden subprocess_{shell,exec} - arguments; added a convenience API for subprocess management; added - StreamReader.at_eof(); properly handle duplicate coroutines/futures - in gather(), wait(), as_completed(); use a bytearray for buffering - in StreamReader; and more. - -- Issue #20288: fix handling of invalid numeric charrefs in HTMLParser. - -- Issue #20424: Python implementation of io.StringIO now supports lone surrogates. - -- Issue #20308: inspect.signature now works on classes without user-defined - __init__ or __new__ methods. - -- Issue #20372: inspect.getfile (and a bunch of other inspect functions that - use it) doesn't crash with unexpected AttributeError on classes defined in C - without __module__. - -- Issue #20356: inspect.signature formatting uses '/' to separate - positional-only parameters from others. - -- Issue #20223: inspect.signature now supports methods defined with - functools.partialmethods. - -- Issue #19456: ntpath.join() now joins relative paths correctly when a drive - is present. - -- Issue #19077: tempfile.TemporaryDirectory cleanup no longer fails when - called during shutdown. Emitting resource warning in __del__ no longer fails. - Original patch by Antoine Pitrou. - -- Issue #20394: Silence Coverity warning in audioop module. - -- Issue #20367: Fix behavior of concurrent.futures.as_completed() for - duplicate arguments. Patch by Glenn Langford. - -- Issue #8260: The read(), readline() and readlines() methods of - codecs.StreamReader returned incomplete data when were called after - readline() or read(size). Based on patch by Amaury Forgeot d'Arc. - -- Issue #20105: the codec exception chaining now correctly sets the - traceback of the original exception as its __traceback__ attribute. - -- Issue #17481: inspect.getfullargspec() now uses inspect.signature() API. - -- Issue #15304: concurrent.futures.wait() can block forever even if - Futures have completed. Patch by Glenn Langford. - -- Issue #14455: plistlib: fix serializing integers in the range - of an unsigned long long but outside of the range of signed long long for - binary plist files. - -IDLE ----- - -- Issue #20406: Use Python application icons for Idle window title bars. - Patch mostly by Serhiy Storchaka. - -- Update the python.gif icon for the Idle classbrowser and pathbowser - from the old green snake to the new blue and yellow snakes. - -- Issue #17721: Remove non-functional configuration dialog help button until we - make it actually gives some help when clicked. Patch by Guilherme Simões. - -Tests ------ - -- Issue #20532: Tests which use _testcapi now are marked as CPython only. - -- Issue #19920: Added tests for TarFile.list(). Based on patch by Vajrasky Kok. - -- Issue #19990: Added tests for the imghdr module. Based on patch by - Claudiu Popa. - -- Issue #20474: Fix test_socket "unexpected success" failures on OS X 10.7+. - -Tools/Demos ------------ - -- Issue #20530: Argument Clinic's signature format has been revised again. - The new syntax is highly human readable while still preventing false - positives. The syntax also extends Python syntax to denote "self" and - positional-only parameters, allowing inspect.Signature objects to be - totally accurate for all supported builtins in Python 3.4. - -- Issue #20456: Argument Clinic now observes the C preprocessor conditional - compilation statements of the C files it parses. When a Clinic block is - inside a conditional code, it adjusts its output to match, including - automatically generating an empty methoddef macro. - -- Issue #20456: Cloned functions in Argument Clinic now use the correct - name, not the name of the function they were cloned from, for text - strings inside generated code. - -- Issue #20456: Fixed Argument Clinic's test suite and "--converters" feature. - -- Issue #20456: Argument Clinic now allows specifying different names - for a parameter in Python and C, using "as" on the parameter line. - -- Issue #20326: Argument Clinic now uses a simple, unique signature to - annotate text signatures in docstrings, resulting in fewer false - positives. "self" parameters are also explicitly marked, allowing - inspect.Signature() to authoritatively detect (and skip) said parameters. - -- Issue #20326: Argument Clinic now generates separate checksums for the - input and output sections of the block, allowing external tools to verify - that the input has not changed (and thus the output is not out-of-date). - -Build ------ - -- Issue #20465: Update SQLite shipped with OS X installer to 3.8.3. - -C-API ------ - -- Issue #20517: Added new functions allowing OSError exceptions to reference - two filenames instead of one: PyErr_SetFromErrnoWithFilenameObjects() and - PyErr_SetExcFromWindowsErrWithFilenameObjects(). - -Documentation -------------- - -- Issue #20488: Change wording to say importlib is *the* implementation of - import instead of just *an* implementation. - -- Issue #6386: Clarify in the tutorial that specifying a symlink to execute - means the directory containing the executed script and not the symlink is - added to sys.path. - - -What's New in Python 3.4.0 Beta 3? -================================== - -Release date: 2014-01-26 - -Core and Builtins ------------------ - -- Issue #20189: Four additional builtin types (PyTypeObject, - PyMethodDescr_Type, _PyMethodWrapper_Type, and PyWrapperDescr_Type) - have been modified to provide introspection information for builtins. - -- Issue #17825: Cursor "^" is correctly positioned for SyntaxError and - IndentationError. - -- Issue #2382: SyntaxError cursor "^" is now written at correct position in most - cases when multibyte characters are in line (before "^"). This still not - works correctly with wide East Asian characters. - -- Issue #18960: The first line of Python script could be executed twice when - the source encoding was specified on the second line. Now the source encoding - declaration on the second line isn't effective if the first line contains - anything except a comment. 'python -x' works now again with files with the - source encoding declarations, and can be used to make Python batch files - on Windows. - -Library -------- - -- asyncio: Various improvements and small changes not all covered by - issues listed below. E.g. wait_for() now cancels the inner task if - the timeout occcurs; tweaked the set of exported symbols; renamed - Empty/Full to QueueEmpty/QueueFull; "with (yield from lock)" now - uses a separate context manager; readexactly() raises if not enough - data was read; PTY support tweaks. - -- Issue #20311: asyncio: Add a granularity attribute to BaseEventLoop: maximum - between the resolution of the BaseEventLoop.time() method and the resolution - of the selector. The granuarility is used in the scheduler to round time and - deadline. - -- Issue #20311: selectors: Add a resolution attribute to BaseSelector. - -- Issue #20189: unittest.mock now no longer assumes that any object for - which it could get an inspect.Signature is a callable written in Python. - Fix courtesy of Michael Foord. - -- Issue #20317: ExitStack.__exit__ could create a self-referential loop if an - exception raised by a cleanup operation already had its context set - correctly (for example, by the @contextmanager decorator). The infinite - loop this caused is now avoided by checking if the expected context is - already set before trying to fix it. - -- Issue #20374: Fix build with GNU readline >= 6.3. - -- Issue #20262: Warnings are raised now when duplicate names are added in the - ZIP file or too long ZIP file comment is truncated. - -- Issue #20165: The unittest module no longer considers tests marked with - @expectedFailure successful if they pass. - -- Issue #18574: Added missing newline in 100-Continue reply from - http.server.BaseHTTPRequestHandler. Patch by Nikolaus Rath. - -- Issue #20270: urllib.urlparse now supports empty ports. - -- Issue #20243: TarFile no longer raise ReadError when opened in write mode. - -- Issue #20238: TarFile opened with external fileobj and "w:gz" mode didn't - write complete output on close. - -- Issue #20245: The open functions in the tarfile module now correctly handle - empty mode. - -- Issue #20242: Fixed basicConfig() format strings for the alternative - formatting styles. Thanks to kespindler for the bug report and patch. - -- Issue #20246: Fix buffer overflow in socket.recvfrom_into. - -- Issues #20206 and #5803: Fix edge case in email.quoprimime.encode where it - truncated lines ending in a character needing encoding but no newline by - using a more efficient algorithm that doesn't have the bug. - -- Issue #19082: Working xmlrpc.server and xmlrpc.client examples. Both in - modules and in documentation. Initial patch contributed by Vajrasky Kok. - -- Issue #20138: The wsgiref.application_uri() and wsgiref.request_uri() - functions now conform to PEP 3333 when handle non-ASCII URLs. - -- Issue #19097: Raise the correct Exception when cgi.FieldStorage is given an - invalid fileobj. - -- Issue #20152: Ported Python/import.c over to Argument Clinic. - -- Issue #13107: argparse and optparse no longer raises an exception when output - a help on environment with too small COLUMNS. Based on patch by - Elazar Gershuni. - -- Issue #20207: Always disable SSLv2 except when PROTOCOL_SSLv2 is explicitly - asked for. - -- Issue #18960: The tokenize module now ignore the source encoding declaration - on the second line if the first line contains anything except a comment. - -- Issue #20078: Reading malformed zipfiles no longer hangs with 100% CPU - consumption. - -- Issue #20113: os.readv() and os.writev() now raise an OSError exception on - error instead of returning -1. - -- Issue #19719: Make importlib.abc.MetaPathFinder.find_module(), - PathEntryFinder.find_loader(), and Loader.load_module() use PEP 451 APIs to - help with backwards-compatibility. - -- Issue #20144: inspect.Signature now supports parsing simple symbolic - constants as parameter default values in __text_signature__. - -- Issue #20072: Fixed multiple errors in tkinter with wantobjects is False. - -- Issue #20229: Avoid plistlib deprecation warning in platform.mac_ver(). - -- Issue #14455: Fix some problems with the new binary plist support in plistlib. - -IDLE ----- - -- Issue #17390: Add Python version to Idle editor window title bar. - Original patches by Edmond Burnett and Kent Johnson. - -- Issue #18960: IDLE now ignores the source encoding declaration on the second - line if the first line contains anything except a comment. - -Tests ------ - -- Issue #20358: Tests for curses.window.overlay and curses.window.overwrite - no longer specify min{row,col} > max{row,col}. - -- Issue #19804: The test_find_mac test in test_uuid is now skipped if the - ifconfig executable is not available. - -- Issue #19886: Use better estimated memory requirements for bigmem tests. - -Tools/Demos ------------ - -- Issue #20390: Argument Clinic's "file" output preset now defaults to - "{dirname}/clinic/{basename}.h". - -- Issue #20390: Argument Clinic's "class" directive syntax has been extended - with two new required arguments: "typedef" and "type_object". - -- Issue #20390: Argument Clinic: If __new__ or __init__ functions didn't use - kwargs (or args), the PyArg_NoKeywords (or PyArg_NoPositional) calls - generated are only run when the type object is an exact match. - -- Issue #20390: Argument Clinic now fails if you have required parameters after - optional parameters. - -- Issue #20390: Argument Clinic converters now have a new template they can - inject code into: "modifiers". Code put there is run in the parsing - function after argument parsing but before the call to the impl. - -- Issue #20376: Argument Clinic now escapes backslashes in docstrings. - -- Issue #20381: Argument Clinic now sanity checks the default argument when - c_default is also specified, providing a nice failure message for - disallowed values. - -- Issue #20189: Argument Clinic now ensures that parser functions for - __new__ are always of type newfunc, the type of the tp_new slot. - Similarly, parser functions for __init__ are now always of type initproc, - the type of tp_init. - -- Issue #20189: Argument Clinic now suppresses the docstring for __new__ - and __init__ functions if no docstring is provided in the input. - -- Issue #20189: Argument Clinic now suppresses the "self" parameter in the - impl for @staticmethod functions. - -- Issue #20294: Argument Clinic now supports argument parsing for __new__ and - __init__ functions. - -- Issue #20299: Argument Clinic custom converters may now change the default - value of c_default and py_default with a class member. - -- Issue #20287: Argument Clinic's output is now configurable, allowing - delaying its output or even redirecting it to a separate file. - -- Issue #20226: Argument Clinic now permits simple expressions - (e.g. "sys.maxsize - 1") as default values for parameters. - -- Issue #19936: Added executable bits or shebang lines to Python scripts which - requires them. Disable executable bits and shebang lines in test and - benchmark files in order to prevent using a random system python, and in - source files of modules which don't provide command line interface. Fixed - shebang lines in the unittestgui and checkpip scripts. - -- Issue #20268: Argument Clinic now supports cloning the parameters and - return converter of existing functions. - -- Issue #20228: Argument Clinic now has special support for class special - methods. - -- Issue #20214: Fixed a number of small issues and documentation errors in - Argument Clinic (see issue for details). - -- Issue #20196: Fixed a bug where Argument Clinic did not generate correct - parsing code for functions with positional-only parameters where all arguments - are optional. - -- Issue #18960: 2to3 and the findnocoding.py script now ignore the source - encoding declaration on the second line if the first line contains anything - except a comment. - -- Issue #19723: The marker comments Argument Clinic uses have been changed - to improve readability. - -- Issue #20157: When Argument Clinic renames a parameter because its name - collides with a C keyword, it no longer exposes that rename to PyArg_Parse. - -- Issue #20141: Improved Argument Clinic's support for the PyArg_Parse "O!" - format unit. - -- Issue #20144: Argument Clinic now supports simple symbolic constants - as parameter default values. - -- Issue #20143: The line numbers reported in Argument Clinic errors are - now more accurate. - -- Issue #20142: Py_buffer variables generated by Argument Clinic are now - initialized with a default value. - -Build ------ - -- Issue #12837: Silence a tautological comparison warning on OS X under Clang in - socketmodule.c. - - -What's New in Python 3.4.0 Beta 2? -================================== - -Release date: 2014-01-05 - -Core and Builtins ------------------ - -- Issue #17432: Drop UCS2 from names of Unicode functions in python3.def. - -- Issue #19526: Exclude all new API from the stable ABI. Exceptions can be - made if a need is demonstrated. - -- Issue #19969: PyBytes_FromFormatV() now raises an OverflowError if "%c" - argument is not in range [0; 255]. - -- Issue #19995: %c, %o, %x, and %X now issue a DeprecationWarning on non-integer - input; reworded docs to clarify that an integer type should define both __int__ - and __index__. - -- Issue #19787: PyThread_set_key_value() now always set the value. In Python - 3.3, the function did nothing if the key already exists (if the current value - is a non-NULL pointer). - -- Issue #14432: Remove the thread state field from the frame structure. Fix a - crash when a generator is created in a C thread that is destroyed while the - generator is still used. The issue was that a generator contains a frame, and - the frame kept a reference to the Python state of the destroyed C thread. The - crash occurs when a trace function is setup. - -- Issue #19576: PyGILState_Ensure() now initializes threads. At startup, Python - has no concrete GIL. If PyGILState_Ensure() is called from a new thread for - the first time and PyEval_InitThreads() was not called yet, a GIL needs to be - created. - -- Issue #17576: Deprecation warning emitted now when __int__() or __index__() - return not int instance. - -- Issue #19932: Fix typo in import.h, missing whitespaces in function prototypes. - -- Issue #19736: Add module-level statvfs constants defined for GNU/glibc - based systems. - -- Issue #20097: Fix bad use of "self" in importlib's WindowsRegistryFinder. - -- Issue #19729: In str.format(), fix recursive expansion in format spec. - -- Issue #19638: Fix possible crash / undefined behaviour from huge (more than 2 - billion characters) input strings in _Py_dg_strtod. - -Library -------- - -- Issue #20154: Deadlock in asyncio.StreamReader.readexactly(). - -- Issue #16113: Remove sha3 module again. - -- Issue #20111: pathlib.Path.with_suffix() now sanity checks the given suffix. - -- Fix breakage in TestSuite.countTestCases() introduced by issue #11798. - -- Issue #20108: Avoid parameter name clash in inspect.getcallargs(). - -- Issue #19918: Fix PurePath.relative_to() under Windows. - -- Issue #19422: Explicitly disallow non-SOCK_STREAM sockets in the ssl - module, rather than silently let them emit clear text data. - -- Issue #20046: Locale alias table no longer contains entities which can be - calculated. Generalized support of the euro modifier. - -- Issue #20027: Fixed locale aliases for devanagari locales. - -- Issue #20067: Tkinter variables now work when wantobjects is false. - -- Issue #19020: Tkinter now uses splitlist() instead of split() in configure - methods. - -- Issue #19744: ensurepip now provides a better error message when Python is - built without SSL/TLS support (pip currently requires that support to run, - even if only operating with local wheel files) - -- Issue #19734: ensurepip now ignores all pip environment variables to avoid - odd behaviour based on user configuration settings - -- Fix TypeError on "setup.py upload --show-response". - -- Issue #20045: Fix "setup.py register --list-classifiers". - -- Issue #18879: When a method is looked up on a temporary file, avoid closing - the file before the method is possibly called. - -- Issue #20037: Avoid crashes when opening a text file late at interpreter - shutdown. - -- Issue #19967: Thanks to the PEP 442, asyncio.Future now uses a - destructor to log uncaught exceptions, instead of the dedicated - _TracebackLogger class. - -- Added a Task.current_task() class method to asyncio. - -- Issue #19850: Set SA_RESTART in asyncio when registering a signal - handler to limit EINTR occurrences. - -- Implemented write flow control in asyncio for proactor event loop (Windows). - -- Change write buffer in asyncio use to avoid O(N**2) behavior. Make - write()/sendto() accept bytearray/memoryview. - -- Issue #20034: Updated alias mapping to most recent locale.alias file - from X.org distribution using makelocalealias.py. - -- Issue #5815: Fixed support for locales with modifiers. Fixed support for - locale encodings with hyphens. - -- Issue #20026: Fix the sqlite module to handle correctly invalid isolation - level (wrong type). - -- Issue #18829: csv.Dialect() now checks type for delimiter, escapechar and - quotechar fields. Original patch by Vajrasky Kok. - -- Issue #19855: uuid.getnode() on Unix now looks on the PATH for the - executables used to find the mac address, with /sbin and /usr/sbin as - fallbacks. - -- Issue #20007: HTTPResponse.read(0) no more prematurely closes connection. - Original patch by Simon Sapin. - -- Issue #19946: multiprocessing now uses runpy to initialize __main__ in - child processes when necessary, allowing it to correctly handle scripts - without suffixes and submodules that use explicit relative imports or - otherwise rely on parent modules being correctly imported prior to - execution. - -- Issue #19921: When Path.mkdir() is called with parents=True, any missing - parent is created with the default permissions, ignoring the mode argument - (mimicking the POSIX "mkdir -p" command). - -- Issue #19887: Improve the Path.resolve() algorithm to support certain - symlink chains. - -- Issue #19912: Fixed numerous bugs in ntpath.splitunc(). - -- Issue #19911: ntpath.splitdrive() now correctly processes the 'İ' character - (U+0130, LATIN CAPITAL LETTER I WITH DOT ABOVE). - -- Issue #19532: python -m compileall with no filename/directory arguments now - respects the -f and -q flags instead of ignoring them. - -- Issue #19623: Fixed writing to unseekable files in the aifc module. - -- Issue #19946: multiprocessing.spawn now raises ImportError when the module to - be used as the main module cannot be imported. - -- Issue #17919: select.poll.register() again works with poll.POLLNVAL on AIX. - Fixed integer overflow in the eventmask parameter. - -- Issue #19063: if a Charset's body_encoding was set to None, the email - package would generate a message claiming the Content-Transfer-Encoding - was 7bit, and produce garbage output for the content. This now works. - A couple of other set_payload mishandlings of non-ASCII are also fixed. - In addition, calling set_payload with a string argument without - specifying a charset now raises an error (this is a new error in 3.4). - -- Issue #15475: Add __sizeof__ implementations for itertools objects. - -- Issue #19944: Fix importlib.find_spec() so it imports parents as needed - and move the function to importlib.util. - -- Issue #19880: Fix a reference leak in unittest.TestCase. Explicitly break - reference cycles between frames and the _Outcome instance. - -- Issue #17429: platform.linux_distribution() now decodes files from the UTF-8 - encoding with the surrogateescape error handler, instead of decoding from the - locale encoding in strict mode. It fixes the function on Fedora 19 which is - probably the first major distribution release with a non-ASCII name. Patch - written by Toshio Kuratomi. - -- Issue #19343: Expose FreeBSD-specific APIs in resource module. Original - patch by Koobs. - -- Issue #19929: Call os.read with 32768 within subprocess.Popen.communicate - rather than 4096 for efficiency. A microbenchmark shows Linux and OS X - both using ~50% less cpu time this way. - -- Issue #19506: Use a memoryview to avoid a data copy when piping data - to stdin within subprocess.Popen.communicate. 5-10% less cpu usage. - -- Issue #19876: selectors unregister() no longer raises ValueError or OSError - if the FD is closed (as long as it was registered). - -- Issue #19908: pathlib now joins relative Windows paths correctly when a drive - is present. Original patch by Antoine Pitrou. - -- Issue #19296: Silence compiler warning in dbm_open - -- Issue #6784: Strings from Python 2 can now be unpickled as bytes - objects by setting the encoding argument of Unpickler to be 'bytes'. - Initial patch by Merlijn van Deen. - -- Issue #19839: Fix regression in bz2 module's handling of non-bzip2 data at - EOF, and analogous bug in lzma module. - -- Issue #19881: Fix pickling bug where cpickle would emit bad pickle data for - large bytes string (i.e., with size greater than 2**32-1). - -- Issue #19138: doctest's IGNORE_EXCEPTION_DETAIL now allows a match when - no exception detail exists (no colon following the exception's name, or - a colon does follow but no text follows the colon). - -- Issue #19927: Add __eq__ to path-based loaders in importlib. - -- Issue #19827: On UNIX, setblocking() and settimeout() methods of - socket.socket can now avoid a second syscall if the ioctl() function can be - used, or if the non-blocking flag of the socket is unchanged. - -- Issue #19785: smtplib now supports SSLContext.check_hostname and server name - indication for TLS/SSL connections. - -- Issue #19784: poplib now supports SSLContext.check_hostname and server name - indication for TLS/SSL connections. - -- Issue #19783: nntplib now supports SSLContext.check_hostname and server name - indication for TLS/SSL connections. - -- Issue #19782: imaplib now supports SSLContext.check_hostname and server name - indication for TLS/SSL connections. - -- Issue #20123: Fix pydoc.synopsis() for "binary" modules. - -- Issue #19834: Support unpickling of exceptions pickled by Python 2. - -- Issue #19781: ftplib now supports SSLContext.check_hostname and server name - indication for TLS/SSL connections. - -- Issue #19509: Add SSLContext.check_hostname to match the peer's certificate - with server_hostname on handshake. - -- Issue #15798: Fixed subprocess.Popen() to no longer fail if file - descriptor 0, 1 or 2 is closed. - -- Issue #17897: Optimized unpickle prefetching. - -- Issue #3693: Make the error message more helpful when the array.array() - constructor is given a str. Move the array module typecode documentation to - the docstring of the constructor. - -- Issue #19088: Fixed incorrect caching of the copyreg module in - object.__reduce__() and object.__reduce_ex__(). - -- Issue #19698: Removed exec_module() methods from - importlib.machinery.BuiltinImporter and ExtensionFileLoader. - -- Issue #18864: Added a setter for ModuleSpec.has_location. - -- Fixed _pickle.Unpickler to not fail when loading empty strings as - persistent IDs. - -- Issue #11480: Fixed copy.copy to work with classes with custom metaclasses. - Patch by Daniel Urban. - -- Issue #6477: Added support for pickling the types of built-in singletons - (i.e., Ellipsis, NotImplemented, None). - -- Issue #19713: Add remaining PEP 451-related deprecations and move away - from using find_module/find_loaer/load_module. - -- Issue #19708: Update pkgutil to use the new importer APIs. - -- Issue #19703: Update pydoc to use the new importer APIs. - -- Issue #19851: Fixed a regression in reloading sub-modules. - -- ssl.create_default_context() sets OP_NO_COMPRESSION to prevent CRIME. - -- Issue #19802: Add socket.SO_PRIORITY. - -- Issue #11508: Fixed uuid.getnode() and uuid.uuid1() on environment with - virtual interface. Original patch by Kent Frazier. - -- Issue #11489: JSON decoder now accepts lone surrogates. - -- Issue #19545: Avoid chained exceptions while passing stray % to - time.strptime(). Initial patch by Claudiu Popa. - -IDLE ----- - -- Issue #20058: sys.stdin.readline() in IDLE now always returns only one line. - -- Issue #19481: print() of string subclass instance in IDLE no longer hangs. - -- Issue #18270: Prevent possible IDLE AttributeError on OS X when no initial - shell window is present. - -Tests ------ - -- Issue #20055: Fix test_shutil under Windows with symlink privileges held. - Patch by Vajrasky Kok. - -- Issue #20070: Don't run test_urllib2net when network resources are not - enabled. - -- Issue #19938: Re-enabled test_bug_1333982 in test_dis, which had been - disabled since 3.0 due to the changes in listcomp handling. - -- Issue #19320: test_tcl no longer fails when wantobjects is false. - -- Issue #19919: Fix flaky SSL test. connect_ex() sometimes returns - EWOULDBLOCK on Windows or VMs hosted on Windows. - -- Issue #19912: Added tests for ntpath.splitunc(). - -- Issue #19828: Fixed test_site when the whole suite is run with -S. - -- Issue #19928: Implemented a test for repr() of cell objects. - -- Issue #19535: Fixed test_docxmlrpc, test_functools, test_inspect, and - test_statistics when python is run with -OO. - -- Issue #19926: Removed unneeded test_main from test_abstract_numbers. - Patch by Vajrasky Kok. - -- Issue #19572: More skipped tests explicitly marked as skipped. - -- Issue #19595, #19987: Re-enabled a long-disabled test in test_winsound. - -- Issue #19588: Fixed tests in test_random that were silently skipped most - of the time. Patch by Julian Gindi. - -Build ------ - -- Issue #19728: Enable pip installation by default on Windows. - -- Issue #16136: Remove VMS support - -- Issue #18215: Add script Tools/ssl/test_multiple_versions.py to compile and - run Python's unit tests with multiple versions of OpenSSL. - -- Issue #19922: define _INCLUDE__STDC_A1_SOURCE in HP-UX to include mbstate_t - for mbrtowc(). - -- Issue #19788: kill_python(_d).exe is now run as a PreBuildEvent on the - pythoncore sub-project. This should prevent build errors due a previous - build's python(_d).exe still running. - -Documentation -------------- - -- Issue #20265: Updated some parts of the Using Windows document. - -- Issue #20266: Updated some parts of the Windows FAQ. - -- Issue #20255: Updated the about and bugs pages. - -- Issue #20253: Fixed a typo in the ipaddress docs that advertised an - illegal attribute name. Found by INADA Naoki. - -- Issue #18840: Introduce the json module in the tutorial, and de-emphasize - the pickle module. - -- Issue #19845: Updated the Compiling Python on Windows section. - -- Issue #19795: Improved markup of True/False constants. - -Tools/Demos ------------ - -- Issue #19659: Added documentation for Argument Clinic. - -- Issue #19976: Argument Clinic METH_NOARGS functions now always - take two parameters. - - -What's New in Python 3.4.0 Beta 1? -================================== - -Release date: 2013-11-24 - -Core and Builtins ------------------ - -- Use the repr of a module name in more places in import, especially - exceptions. - -- Issue #19619: str.encode, bytes.decode and bytearray.decode now use an - internal API to throw LookupError for known non-text encodings, rather - than attempting the encoding or decoding operation and then throwing a - TypeError for an unexpected output type. (The latter mechanism remains - in place for third party non-text encodings) - -- Issue #19183: Implement PEP 456 'secure and interchangeable hash algorithm'. - Python now uses SipHash24 on all major platforms. - -- Issue #12892: The utf-16* and utf-32* encoders no longer allow surrogate code - points (U+D800-U+DFFF) to be encoded. The utf-32* decoders no longer decode - byte sequences that correspond to surrogate code points. The surrogatepass - error handler now works with the utf-16* and utf-32* codecs. Based on - patches by Victor Stinner and Kang-Hao (Kenny) Lu. - -- Issue #17806: Added keyword-argument support for "tabsize" to - str/bytes.expandtabs(). - -- Issue #17828: Output type errors in str.encode(), bytes.decode() and - bytearray.decode() now direct users to codecs.encode() or codecs.decode() - as appropriate. - -- Issue #17828: The interpreter now attempts to chain errors that occur in - codec processing with a replacement exception of the same type that - includes the codec name in the error message. It ensures it only does this - when the creation of the replacement exception won't lose any information. - -- Issue #19466: Clear the frames of daemon threads earlier during the - Python shutdown to call object destructors. So "unclosed file" resource - warnings are now correctly emitted for daemon threads. - -- Issue #19514: Deduplicate some _Py_IDENTIFIER declarations. - Patch by Andrei Dorian Duma. - -- Issue #17936: Fix O(n**2) behaviour when adding or removing many subclasses - of a given type. - -- Issue #19428: zipimport now handles errors when reading truncated or invalid - ZIP archive. - -- Issue #18408: Add a new PyFrame_FastToLocalsWithError() function to handle - exceptions when merging fast locals into f_locals of a frame. - PyEval_GetLocals() now raises an exception and return NULL on failure. - -- Issue #19369: Optimized the usage of __length_hint__(). - -- Issue #28026: Raise ImportError when exec_module() exists but - create_module() is missing. - -- Issue #18603: Ensure that PyOS_mystricmp and PyOS_mystrnicmp are in the - Python executable and not removed by the linker's optimizer. - -- Issue #19306: Add extra hints to the faulthandler module's stack - dumps that these are "upside down". - -Library -------- - -- Issue #3158: doctest can now find doctests in functions and methods - written in C. - -- Issue #13477: Added command line interface to the tarfile module. - Original patch by Berker Peksag. - -- Issue #19674: inspect.signature() now produces a correct signature - for some builtins. - -- Issue #19722: Added opcode.stack_effect(), which - computes the stack effect of bytecode instructions. - -- Issue #19735: Implement private function ssl._create_stdlib_context() to - create SSLContext objects in Python's stdlib module. It provides a single - configuration point and makes use of SSLContext.load_default_certs(). - -- Issue #16203: Add re.fullmatch() function and regex.fullmatch() method, - which anchor the pattern at both ends of the string to match. - Original patch by Matthew Barnett. - -- Issue #13592: Improved the repr for regular expression pattern objects. - Based on patch by Hugo Lopes Tavares. - -- Issue #19641: Added the audioop.byteswap() function to convert big-endian - samples to little-endian and vice versa. - -- Issue #15204: Deprecated the 'U' mode in file-like objects. - -- Issue #17810: Implement PEP 3154, pickle protocol 4. - -- Issue #19668: Added support for the cp1125 encoding. - -- Issue #19689: Add ssl.create_default_context() factory function. It creates - a new SSLContext object with secure default settings. - -- Issue #19727: os.utime(..., None) is now potentially more precise - under Windows. - -- Issue #17201: ZIP64 extensions now are enabled by default. Patch by - William Mallard. - -- Issue #19292: Add SSLContext.load_default_certs() to load default root CA - certificates from default stores or system stores. By default the method - loads CA certs for authentication of server certs. - -- Issue #19673: Add pathlib to the stdlib as a provisional module (PEP 428). - -- Issue #16596: pdb in a generator now properly skips over yield and - yield from rather than stepping out of the generator into its - caller. (This is essential for stepping through asyncio coroutines.) - -- Issue #17916: Added dis.Bytecode.from_traceback() and - dis.Bytecode.current_offset to easily display "current instruction" - markers in the new disassembly API (Patch by Claudiu Popa). - -- Issue #19552: venv now supports bootstrapping pip into virtual environments - -- Issue #17134: Finalize interface to Windows' certificate store. Cert and - CRL enumeration are now two functions. enum_certificates() also returns - purpose flags as set of OIDs. - -- Issue #19555: Restore sysconfig.get_config_var('SO'), (and the distutils - equivalent) with a DeprecationWarning pointing people at $EXT_SUFFIX. - -- Issue #8813: Add SSLContext.verify_flags to change the verification flags - of the context in order to enable certification revocation list (CRL) - checks or strict X509 rules. - -- Issue #18294: Fix the zlib module to make it 64-bit safe. - -- Issue #19682: Fix compatibility issue with old version of OpenSSL that - was introduced by Issue #18379. - -- Issue #14455: plistlib now supports binary plists and has an updated API. - -- Issue #19633: Fixed writing not compressed 16- and 32-bit wave files on - big-endian platforms. - -- Issue #18379: SSLSocket.getpeercert() returns CA issuer AIA fields, OCSP - and CRL distribution points. - -- Issue #18138: Implement cadata argument of SSLContext.load_verify_location() - to load CA certificates and CRL from memory. It supports PEM and DER - encoded strings. - -- Issue #18775: Add name and block_size attribute to HMAC object. They now - provide the same API elements as non-keyed cryptographic hash functions. - -- Issue #17276: MD5 as default digestmod for HMAC is deprecated. The HMAC - module supports digestmod names, e.g. hmac.HMAC('sha1'). - -- Issue #19449: in csv's writerow, handle non-string keys when generating the - error message that certain keys are not in the 'fieldnames' list. - -- Issue #13633: Added a new convert_charrefs keyword arg to HTMLParser that, - when True, automatically converts all character references. - -- Issue #2927: Added the unescape() function to the html module. - -- Issue #8402: Added the escape() function to the glob module. - -- Issue #17618: Add Base85 and Ascii85 encoding/decoding to the base64 module. - -- Issue #19634: time.strftime("%y") now raises a ValueError on AIX when given a - year before 1900. - -- Fix test.support.bind_port() to not cause an error when Python was compiled - on a system with SO_REUSEPORT defined in the headers but run on a system - with an OS kernel that does not support that reasonably new socket option. - -- Fix compilation error under gcc of the ctypes module bundled libffi for arm. - -- Issue #19448: Add private API to SSL module to lookup ASN.1 objects by OID, - NID, short name and long name. - -- Issue #19282: dbm.open now supports the context management protocol. - (Initial patch by Claudiu Popa) - -- Issue #8311: Added support for writing any bytes-like objects in the aifc, - sunau, and wave modules. - -- Issue #5202: Added support for unseekable files in the wave module. - -- Issue #19544 and Issue #1180: Restore global option to ignore - ~/.pydistutils.cfg in Distutils, accidentally removed in backout of - distutils2 changes. - -- Issue #19523: Closed FileHandler leak which occurred when delay was set. - -- Issue #19544 and Issue #6516: Restore support for --user and --group - parameters to sdist command accidentally rolled back as part of the - distutils2 rollback. - -- Issue #13674: Prevented time.strftime from crashing on Windows when given - a year before 1900 and a format of %y. - -- Issue #19406: implementation of the ensurepip module (part of PEP 453). - Patch by Donald Stufft and Nick Coghlan. - -- Issue #19544 and Issue #6286: Restore use of urllib over http allowing use - of http_proxy for Distutils upload command, a feature accidentally lost - in the rollback of distutils2. - -- Issue #19544 and Issue #7457: Restore the read_pkg_file method to - distutils.dist.DistributionMetadata accidentally removed in the undo of - distutils2. - -- Issue #16685: Added support for any bytes-like objects in the audioop module. - Removed support for strings. - -- Issue #7171: Add Windows implementation of ``inet_ntop`` and ``inet_pton`` - to socket module. Patch by Atsuo Ishimoto. - -- Issue #19261: Added support for writing 24-bit samples in the sunau module. - -- Issue #1097797: Added CP273 encoding, used on IBM mainframes in - Germany and Austria. Mapping provided by Michael Bierenfeld. - -- Issue #1575020: Fixed support of 24-bit wave files on big-endian platforms. - -- Issue #19378: Fixed a number of cases in the dis module where the new - "file" parameter was not being honoured correctly - -- Issue #19378: Removed the "dis.Bytecode.show_info" method - -- Issue #19378: Renamed the "dis.Bytecode.display_code" method to - "dis.Bytecode.dis" and converted it to returning a string rather than - printing output. - -- Issue #19378: the "line_offset" parameter in the new "dis.get_instructions" - API has been renamed to "first_line" (and the default value and usage - changed accordingly). This should reduce confusion with the more common use - of "offset" in the dis docs to refer to bytecode offsets. - -- Issue #18678: Corrected spwd struct member names in spwd module: - sp_nam->sp_namp, and sp_pwd->sp_pwdp. The old names are kept as extra - structseq members, for backward compatibility. - -- Issue #6157: Fixed tkinter.Text.debug(). tkinter.Text.bbox() now raises - TypeError instead of TclError on wrong number of arguments. Original patch - by Guilherme Polo. - -- Issue #10197: Rework subprocess.get[status]output to use subprocess - functionality and thus to work on Windows. Patch by Nick Coghlan - -- Issue #6160: The bbox() method of tkinter.Spinbox now returns a tuple of - integers instead of a string. Based on patch by Guilherme Polo. - -- Issue #19403: contextlib.redirect_stdout is now reentrant - -- Issue #19286: Directories in ``package_data`` are no longer added to - the filelist, preventing failure outlined in the ticket. - -- Issue #19480: HTMLParser now accepts all valid start-tag names as defined - by the HTML5 standard. - -- Issue #15114: The html.parser module now raises a DeprecationWarning when the - strict argument of HTMLParser or the HTMLParser.error method are used. - -- Issue #19410: Undo the special-casing removal of '' for - importlib.machinery.FileFinder. - -- Issue #19424: Fix the warnings module to accept filename containing surrogate - characters. - -- Issue #19435: Fix directory traversal attack on CGIHttpRequestHandler. - -- Issue #19227: Remove pthread_atfork() handler. The handler was added to - solve #18747 but has caused issues. - -- Issue #19420: Fix reference leak in module initialization code of - _hashopenssl.c - -- Issue #19329: Optimized compiling charsets in regular expressions. - -- Issue #19227: Try to fix deadlocks caused by re-seeding then OpenSSL - pseudo-random number generator on fork(). - -- Issue #16037: HTTPMessage.readheaders() raises an HTTPException when more than - 100 headers are read. Adapted from patch by Jyrki Pulliainen. - -- Issue #16040: CVE-2013-1752: nntplib: Limit maximum line lengths to 2048 to - prevent readline() calls from consuming too much memory. Patch by Jyrki - Pulliainen. - -- Issue #16041: CVE-2013-1752: poplib: Limit maximum line lengths to 2048 to - prevent readline() calls from consuming too much memory. Patch by Jyrki - Pulliainen. - -- Issue #17997: Change behavior of ``ssl.match_hostname()`` to follow RFC 6125, - for security reasons. It now doesn't match multiple wildcards nor wildcards - inside IDN fragments. - -- Issue #16039: CVE-2013-1752: Change use of readline in imaplib module to limit - line length. Patch by Emil Lind. - -- Issue #19330: the unnecessary wrapper functions have been removed from the - implementations of the new contextlib.redirect_stdout and - contextlib.suppress context managers, which also ensures they provide - reasonable help() output on instances - -- Issue #19393: Fix symtable.symtable function to not be confused when there are - functions or classes named "top". - -- Issue #18685: Restore re performance to pre-PEP 393 levels. - -- Issue #19339: telnetlib module is now using time.monotonic() when available - to compute timeout. - -- Issue #19399: fix sporadic test_subprocess failure. - -- Issue #13234: Fix os.listdir to work with extended paths on Windows. - Patch by Santoso Wijaya. - -- Issue #19375: The site module adding a "site-python" directory to sys.path, - if it exists, is now deprecated. - -- Issue #19379: Lazily import linecache in the warnings module, to make - startup with warnings faster until a warning gets printed. - -- Issue #19288: Fixed the "in" operator of dbm.gnu databases for string - argument. Original patch by Arfrever Frehtes Taifersar Arahesis. - -- Issue #19287: Fixed the "in" operator of dbm.ndbm databases for string - argument. Original patch by Arfrever Frehtes Taifersar Arahesis. - -- Issue #19327: Fixed the working of regular expressions with too big charset. - -- Issue #17400: New 'is_global' attribute for ipaddress to tell if an address - is allocated by IANA for global or private networks. - -- Issue #19350: Increasing the test coverage of macurl2path. Patch by Colin - Williams. - -- Issue #19365: Optimized the parsing of long replacement string in re.sub*() - functions. - -- Issue #19352: Fix unittest discovery when a module can be reached - through several paths (e.g. under Debian/Ubuntu with virtualenv). - -- Issue #15207: Fix mimetypes to read from correct part of Windows registry - Original patch by Dave Chambers - -- Issue #16595: Add prlimit() to resource module. - -- Issue #19324: Expose Linux-specific constants in resource module. - -- Load SSL's error strings in hashlib. - -- Issue #18527: Upgrade internal copy of zlib to 1.2.8. - -- Issue #19274: Add a filterfunc parameter to PyZipFile.writepy. - -- Issue #8964: fix platform._sys_version to handle IronPython 2.6+. - Patch by Martin Matusiak. - -- Issue #19413: Restore pre-3.3 reload() semantics of re-finding modules. - -- Issue #18958: Improve error message for json.load(s) while passing a string - that starts with a UTF-8 BOM. - -- Issue #19307: Improve error message for json.load(s) while passing objects - of the wrong type. - -- Issue #16038: CVE-2013-1752: ftplib: Limit amount of data read by - limiting the call to readline(). Original patch by Michał - Jastrzębski and Giampaolo Rodola. - -- Issue #17087: Improved the repr for regular expression match objects. - -Tests ------ - -- Issue #19664: test_userdict's repr test no longer depends on the order - of dict elements. - -- Issue #19440: Clean up test_capi by removing an unnecessary __future__ - import, converting from test_main to unittest.main, and running the - _testcapi module tests as subTests of a unittest TestCase method. - -- Issue #19378: the main dis module tests are now run with both stdout - redirection *and* passing an explicit file parameter - -- Issue #19378: removed the not-actually-helpful assertInstructionMatches - and assertBytecodeExactlyMatches helpers from bytecode_helper - -- Issue #18702: All skipped tests now reported as skipped. - -- Issue #19439: interpreter embedding tests are now executed on Windows - (Patch by Zachary Ware) - -- Issue #19085: Added basic tests for all tkinter widget options. - -- Issue #19384: Fix test_py_compile for root user, patch by Claudiu Popa. - -Documentation -------------- - -- Issue #18326: Clarify that list.sort's arguments are keyword-only. Also, - attempt to reduce confusion in the glossary by not saying there are - different "types" of arguments and parameters. - -Build ------ - -- Issue #19358: "make clinic" now runs the Argument Clinic preprocessor - over all CPython source files. - -- Update SQLite to 3.8.1, xz to 5.0.5, and Tcl/Tk to 8.6.1 on Windows. - -- Issue #16632: Enable DEP and ASLR on Windows. - -- Issue #17791: Drop PREFIX and EXEC_PREFIX definitions from PC/pyconfig.h - -- Add workaround for VS 2010 nmake clean issue. VS 2010 doesn't set up PATH - for nmake.exe correctly. - -- Issue #19550: Implement Windows installer changes of PEP 453 (ensurepip). - -- Issue #19520: Fix compiler warning in the _sha3 module on 32bit Windows. - -- Issue #19356: Avoid using a C variabled named "_self", it's a reserved - word in some C compilers. - -- Issue #15792: Correct build options on Win64. Patch by Jeremy Kloth. - -- Issue #19373: Apply upstream change to Tk 8.5.15 fixing OS X 10.9 - screen refresh problem for OS X installer build. - -- Issue #19649: On OS X, the same set of file names are now installed - in bin directories for all configurations: non-framework vs framework, - and single arch vs universal builds. pythonx.y-32 is now always - installed for 64-bit/32-bit universal builds. The obsolete and - undocumented pythonw* symlinks are no longer installed anywhere. - -- Issue #19553: PEP 453 - "make install" and "make altinstall" now install or - upgrade pip by default, using the bundled pip provided by the new ensurepip - module. A new configure option, --with-ensurepip[=upgrade|install|no], is - available to override the default ensurepip "--upgrade" option. The option - can also be set with "make [alt]install ENSUREPIP=[upgrade|install|no]". - -- Issue #19551: PEP 453 - the OS X installer now installs pip by default. - -- Update third-party libraries for OS X installers: xz 5.0.3 -> 5.0.5, - SQLite 3.7.13 -> 3.8.1 - -- Issue #15663: Revert OS X installer built-in Tcl/Tk support for 3.4.0b1. - Some third-party projects, such as Matplotlib and PIL/Pillow, - depended on being able to build with Tcl and Tk frameworks in - /Library/Frameworks. - -Tools/Demos ------------ - -- Issue #19730: Argument Clinic now supports all the existing PyArg - "format units" as legacy converters, as well as two new features: - "self converters" and the "version" directive. - -- Issue #19552: pyvenv now bootstraps pip into virtual environments by - default (pass --without-pip to request the old behaviour) - -- Issue #19390: Argument Clinic no longer accepts malformed Python - and C ids. - - -What's New in Python 3.4.0 Alpha 4? -=================================== - -Release date: 2013-10-20 - -Core and Builtins ------------------ - -- Issue #19301: Give classes and functions that are explicitly marked global a - global qualname. - -- Issue #19279: UTF-7 decoder no longer produces illegal strings. - -- Issue #16612: Add "Argument Clinic", a compile-time preprocessor for - C files to generate argument parsing code. (See PEP 436.) - -- Issue #18810: Shift stat calls in importlib.machinery.FileFinder such that - the code is optimistic that if something exists in a directory named exactly - like the possible package being searched for that it's in actuality a - directory. - -- Issue #18416: importlib.machinery.PathFinder now treats '' as the cwd and - importlib.machinery.FileFinder no longer special-cases '' to '.'. This leads - to modules imported from cwd to now possess an absolute file path for - __file__ (this does not affect modules specified by path on the CLI but it - does affect -m/runpy). It also allows FileFinder to be more consistent by not - having an edge case. - -- Issue #4555: All exported C symbols are now prefixed with either - "Py" or "_Py". - -- Issue #19219: Speed up marshal.loads(), and make pyc files slightly - (5% to 10%) smaller. - -- Issue #19221: Upgrade Unicode database to version 6.3.0. - -- Issue #16742: The result of the C callback PyOS_ReadlineFunctionPointer must - now be a string allocated by PyMem_RawMalloc() or PyMem_RawRealloc() (or NULL - if an error occurred), instead of a string allocated by PyMem_Malloc() or - PyMem_Realloc(). - -- Issue #19199: Remove ``PyThreadState.tick_counter`` field - -- Fix macro expansion of _PyErr_OCCURRED(), and make sure to use it in at - least one place so as to avoid regressions. - -- Issue #19087: Improve bytearray allocation in order to allow cheap popping - of data at the front (slice deletion). - -- Issue #19014: memoryview.cast() is now allowed on zero-length views. - -- Issue #18690: memoryview is now automatically registered with - collections.abc.Sequence - -- Issue #19078: memoryview now correctly supports the reversed builtin - (Patch by Claudiu Popa) - -Library -------- - -- Issue #17457: unittest test discovery now works with namespace packages. - Patch by Claudiu Popa. - -- Issue #18235: Fix the sysconfig variables LDSHARED and BLDSHARED under AIX. - Patch by David Edelsohn. - -- Issue #18606: Add the new "statistics" module (PEP 450). Contributed - by Steven D'Aprano. - -- Issue #12866: The audioop module now supports 24-bit samples. - -- Issue #19254: Provide an optimized Python implementation of pbkdf2_hmac. - -- Issues #19201, Issue #19222, Issue #19223: Add "x" mode (exclusive creation) - in opening file to bz2, gzip and lzma modules. Patches by Tim Heaney and - Vajrasky Kok. - -- Fix a reference count leak in _sre. - -- Issue #19262: Initial check in of the 'asyncio' package (a.k.a. Tulip, - a.k.a. PEP 3156). There are no docs yet, and the PEP is slightly - out of date with the code. This module will have *provisional* status - in Python 3.4. - -- Issue #19276: Fixed the wave module on 64-bit big-endian platforms. - -- Issue #19266: Rename the new-in-3.4 ``contextlib.ignore`` context manager - to ``contextlib.suppress`` in order to be more consistent with existing - descriptions of that operation elsewhere in the language and standard - library documentation (Patch by Zero Piraeus). - -- Issue #18891: Completed the new email package (provisional) API additions - by adding new classes EmailMessage, MIMEPart, and ContentManager. - -- Issue #18281: Unused stat constants removed from `tarfile`. - -- Issue #18999: Multiprocessing now supports 'contexts' with the same API - as the module, but bound to specified start methods. - -- Issue #18468: The re.split, re.findall, and re.sub functions and the group() - and groups() methods of match object now always return a string or a bytes - object. - -- Issue #18725: The textwrap module now supports truncating multiline text. - -- Issue #18776: atexit callbacks now display their full traceback when they - raise an exception. - -- Issue #17827: Add the missing documentation for ``codecs.encode`` and - ``codecs.decode``. - -- Issue #19218: Rename collections.abc to _collections_abc in order to - speed up interpreter start. - -- Issue #18582: Add 'pbkdf2_hmac' to the hashlib module. It implements PKCS#5 - password-based key derivation functions with HMAC as pseudorandom function. - -- Issue #19131: The aifc module now correctly reads and writes sampwidth of - compressed streams. - -- Issue #19209: Remove import of copyreg from the os module to speed up - interpreter startup. stat_result and statvfs_result are now hard-coded to - reside in the os module. - -- Issue #19205: Don't import the 're' module in site and sysconfig module to - speed up interpreter start. - -- Issue #9548: Add a minimal "_bootlocale" module that is imported by the - _io module instead of the full locale module. - -- Issue #18764: Remove the 'print' alias for the PDB 'p' command so that it no - longer shadows the print function. - -- Issue #19158: A rare race in BoundedSemaphore could allow .release() too - often. - -- Issue #15805: Add contextlib.redirect_stdout(). - -- Issue #18716: Deprecate the formatter module. - -- Issue #10712: 2to3 has a new "asserts" fixer that replaces deprecated names - of unittest methods (e.g. failUnlessEqual -> assertEqual). - -- Issue #18037: 2to3 now escapes ``'\u'`` and ``'\U'`` in native strings. - -- Issue #17839: base64.decodebytes and base64.encodebytes now accept any - object that exports a 1 dimensional array of bytes (this means the same - is now also true for base64_codec) - -- Issue #19132: The pprint module now supports compact mode. - -- Issue #19137: The pprint module now correctly formats instances of set and - frozenset subclasses. - -- Issue #10042: functools.total_ordering now correctly handles - NotImplemented being returned by the underlying comparison function (Patch - by Katie Miller) - -- Issue #19092: contextlib.ExitStack now correctly reraises exceptions - from the __exit__ callbacks of inner context managers (Patch by Hrvoje - Nikšić) - -- Issue #12641: Avoid passing "-mno-cygwin" to the mingw32 compiler, except - when necessary. Patch by Oscar Benjamin. - -- Issue #5845: In site.py, only load readline history from ~/.python_history - if no history has been read already. This avoids double writes to the - history file at shutdown. - -- Properly initialize all fields of a SSL object after allocation. - -- Issue #19095: SSLSocket.getpeercert() now raises ValueError when the - SSL handshake hasn't been done. - -- Issue #4366: Fix building extensions on all platforms when --enable-shared - is used. - -- Issue #19030: Fixed `inspect.getmembers` and `inspect.classify_class_attrs` - to attempt activating descriptors before falling back to a __dict__ search - for faulty descriptors. `inspect.classify_class_attrs` no longer returns - Attributes whose home class is None. - -C API ------ - -- Issue #1772673: The type of `char*` arguments now changed to `const char*`. - -- Issue #16129: Added a `Py_SetStandardStreamEncoding` pre-initialization API - to allow embedding applications like Blender to force a particular - encoding and error handler for the standard IO streams (initial patch by - Bastien Montagne) - -Tests ------ - -- Issue #19275: Fix test_site on AMD64 Snow Leopard - -- Issue #14407: Fix unittest test discovery in test_concurrent_futures. - -- Issue #18919: Unified and extended tests for audio modules: aifc, sunau and - wave. - -- Issue #18714: Added tests for ``pdb.find_function()``. - -Documentation -------------- - -- Issue #18758: Fixed and improved cross-references. - -- Issue #18972: Modernize email examples and use the argparse module in them. - -Build ------ - -- Issue #19130: Correct PCbuild/readme.txt, Python 3.3 and 3.4 require VS 2010. - -- Issue #15663: Update OS X 10.6+ installer to use Tcl/Tk 8.5.15. - -- Issue #14499: Fix several problems with OS X universal build support: - 1. ppc arch detection for extension module builds broke with Xcode 5 - 2. ppc arch detection in configure did not work on OS X 10.4 - 3. -sysroot and -arch flags were unnecessarily duplicated - 4. there was no obvious way to configure an intel-32 only build. - -- Issue #19019: Change the OS X installer build script to use CFLAGS instead - of OPT for special build options. By setting OPT, some compiler-specific - options like -fwrapv were overridden and thus not used, which could result - in broken interpreters when building with clang. - - -What's New in Python 3.4.0 Alpha 3? -=================================== - -Release date: 2013-09-29 - -Core and Builtins ------------------ - -- Issue #18818: The "encodingname" part of PYTHONIOENCODING is now optional. - -- Issue #19098: Prevent overflow in the compiler when the recursion limit is set - absurdly high. - -Library -------- - -- Issue #18929: `inspect.classify_class_attrs()` now correctly finds class - attributes returned by `dir()` that are located in the metaclass. - -- Issue #18950: Fix miscellaneous bugs in the sunau module. - Au_read.readframes() now updates current file position and reads correct - number of frames from multichannel stream. Au_write.writeframesraw() now - correctly updates current file position. Au_read.getnframes() now returns an - integer (as in Python 2). Au_read and Au_write now correctly works with file - object if start file position is not a zero. - -- Issue #18594: The fast path for collections.Counter() was never taken - due to an over-restrictive type check. - -- Issue #19053: ZipExtFile.read1() with non-zero argument no more returns empty - bytes until end of data. - -- logging: added support for Unix domain sockets to SocketHandler and - DatagramHandler. - -- Issue #18996: TestCase.assertEqual() now more cleverly shorten differing - strings in error report. - -- Issue #19034: repr() for tkinter.Tcl_Obj now exposes string reperesentation. - -- Issue #18978: ``urllib.request.Request`` now allows the method to be - indicated on the class and no longer sets it to None in ``__init__``. - -- Issue #18626: the inspect module now offers a basic command line - introspection interface (Initial patch by Claudiu Popa) - -- Issue #3015: Fixed tkinter with wantobject=False. Any Tcl command call - returned empty string. - -- Issue #19037: The mailbox module now makes all changes to maildir files - before moving them into place, to avoid race conditions with other programs - that may be accessing the maildir directory. - -- Issue #14984: On POSIX systems, when netrc is called without a filename - argument (and therefore is reading the user's $HOME/.netrc file), it now - enforces the same security rules as typical ftp clients: the .netrc file must - be owned by the user that owns the process and must not be readable by any - other user. - -- Issue #18873: The tokenize module now detects Python source code encoding - only in comment lines. - -- Issue #17764: Enable http.server to bind to a user specified network - interface. Patch contributed by Malte Swart. - -- Issue #18937: Add an assertLogs() context manager to unittest.TestCase - to ensure that a block of code emits a message using the logging module. - -- Issue #17324: Fix http.server's request handling case on trailing '/'. Patch - contributed by Vajrasky Kok. - -- Issue #19018: The heapq.merge() function no longer suppresses IndexError - in the underlying iterables. - -- Issue #18784: The uuid module no longer attempts to load libc via ctypes.CDLL - if all the necessary functions have already been found in libuuid. Patch by - Evgeny Sologubov. - -- The :envvar:`PYTHONFAULTHANDLER` environment variable now only enables the - faulthandler module if the variable is non-empty. Same behaviour than other - variables like :envvar:`PYTHONDONTWRITEBYTECODE`. - -- Issue #1565525: New function ``traceback.clear_frames`` will clear - the local variables of all the stack frames referenced by a traceback - object. - -Tests ------ - -- Issue #18952: Fix regression in support data downloads introduced when - test.support was converted to a package. Regression noticed by Zachary - Ware. - -IDLE ----- - -- Issue #18873: IDLE now detects Python source code encoding only in comment - lines. - -- Issue #18988: The "Tab" key now works when a word is already autocompleted. - -Documentation -------------- - -- Issue #17003: Unified the size argument names in the io module with common - practice. - -Build ------ - -- Issue #18596: Support the use of address sanity checking in recent versions - of clang and GCC by appropriately marking known false alarms in the small - object allocator. Patch contributed by Dhiru Kholia. - -Tools/Demos ------------ - -- Issue #18873: 2to3 and the findnocoding.py script now detect Python source - code encoding only in comment lines. - - -What's New in Python 3.4.0 Alpha 2? -=================================== - -Release date: 2013-09-09 - -Core and Builtins ------------------ - -- Issue #18942: sys._debugmallocstats() output was damaged on Windows. - -- Issue #18571: Implementation of the PEP 446: file descriptors and file - handles are now created non-inheritable; add functions - os.get/set_inheritable(), os.get/set_handle_inheritable() and - socket.socket.get/set_inheritable(). - -- Issue #11619: The parser and the import machinery do not encode Unicode - filenames anymore on Windows. - -- Issue #18808: Non-daemon threads are now automatically joined when - a sub-interpreter is shutdown (it would previously dump a fatal error). - -- Remove support for compiling on systems without getcwd(). - -- Issue #18774: Remove last bits of GNU PTH thread code and thread_pth.h. - -- Issue #18771: Add optimization to set object lookups to reduce the cost - of hash collisions. The core idea is to inspect a second key/hash pair - for each cache line retrieved. - -- Issue #16105: When a signal handler fails to write to the file descriptor - registered with ``signal.set_wakeup_fd()``, report an exception instead - of ignoring the error. - -- Issue #18722: Remove uses of the "register" keyword in C code. - -- Issue #18667: Add missing "HAVE_FCHOWNAT" symbol to posix._have_functions. - -- Issue #16499: Add command line option for isolated mode. - -- Issue #15301: Parsing fd, uid, and gid parameters for builtins - in Modules/posixmodule.c is now far more robust. - -- Issue #18368: PyOS_StdioReadline() no longer leaks memory when realloc() - fail. - -- Issue #17934: Add a clear() method to frame objects, to help clean up - expensive details (local variables) and break reference cycles. - -- Issue #18780: %-formatting codes %d, %i, and %u now treat int-subclasses - as int (displays value of int-subclass instead of str(int-subclass) ). - -Library -------- - -- Issue #18808: Thread.join() now waits for the underlying thread state to - be destroyed before returning. This prevents unpredictable aborts in - Py_EndInterpreter() when some non-daemon threads are still running. - -- Issue #18458: Prevent crashes with newer versions of libedit. Its readline - emulation has changed from 0-based indexing to 1-based like gnu readline. - -- Issue #18852: Handle case of ``readline.__doc__`` being ``None`` in the new - readline activation code in ``site.py``. - -- Issue #18672: Fixed format specifiers for Py_ssize_t in debugging output in - the _sre module. - -- Issue #18830: inspect.getclasstree() no longer produces duplicate entries even - when input list contains duplicates. - -- Issue #18878: sunau.open now supports the context management protocol. Based on - patches by Claudiu Popa and R. David Murray. - -- Issue #18909: Fix _tkinter.tkapp.interpaddr() on Windows 64-bit, don't cast - 64-bit pointer to long (32 bits). - -- Issue #18876: The FileIO.mode attribute now better reflects the actual mode - under which the file was opened. Patch by Erik Bray. - -- Issue #16853: Add new selectors module. - -- Issue #18882: Add threading.main_thread() function. - -- Issue #18901: The sunau getparams method now returns a namedtuple rather than - a plain tuple. Patch by Claudiu Popa. - -- Issue #17487: The result of the wave getparams method now is pickleable again. - Patch by Claudiu Popa. - -- Issue #18756: os.urandom() now uses a lazily-opened persistent file - descriptor, so as to avoid using many file descriptors when run in - parallel from multiple threads. - -- Issue #18418: After fork(), reinit all threads states, not only active ones. - Patch by A. Jesse Jiryu Davis. - -- Issue #17974: Switch unittest from using getopt to using argparse. - -- Issue #11798: TestSuite now drops references to own tests after execution. - -- Issue #16611: http.cookie now correctly parses the 'secure' and 'httponly' - cookie flags. - -- Issue #11973: Fix a problem in kevent. The flags and fflags fields are now - properly handled as unsigned. - -- Issue #18807: ``pyvenv`` now takes a --copies argument allowing copies - instead of symlinks even where symlinks are available and the default. - -- Issue #18538: ``python -m dis`` now uses argparse for argument processing. - Patch by Michele Orrù. - -- Issue #18394: Close cgi.FieldStorage's optional file. - -- Issue #17702: On error, os.environb now suppresses the exception context - when raising a new KeyError with the original key. - -- Issue #16809: Fixed some tkinter incompabilities with Tcl/Tk 8.6. - -- Issue #16809: Tkinter's splitlist() and split() methods now accept Tcl_Obj - argument. - -- Issue #17211: Yield a namedtuple in pkgutil. - Patch by Ramchandra Apte. - -- Issue #18324: set_payload now correctly handles binary input. This also - supersedes the previous fixes for #14360, #1717, and #16564. - -- Issue #18794: Add a fileno() method and a closed attribute to select.devpoll - objects. - -- Issue #17119: Fixed integer overflows when processing large strings and tuples - in the tkinter module. - -- Issue #15352: Rebuild frozen modules when marshal.c is changed. - -- Issue #18747: Re-seed OpenSSL's pseudo-random number generator after fork. - A pthread_atfork() parent handler is used to seed the PRNG with pid, time - and some stack data. - -- Issue #8865: Concurrent invocation of select.poll.poll() now raises a - RuntimeError exception. Patch by Christian Schubert. - -- Issue #18777: The ssl module now uses the new CRYPTO_THREADID API of - OpenSSL 1.0.0+ instead of the deprecated CRYPTO id callback function. - -- Issue #18768: Correct doc string of RAND_edg(). Patch by Vajrasky Kok. - -- Issue #18178: Fix ctypes on BSD. dlmalloc.c was compiled twice which broke - malloc weak symbols. - -- Issue #18709: Fix CVE-2013-4238. The SSL module now handles NULL bytes - inside subjectAltName correctly. Formerly the module has used OpenSSL's - GENERAL_NAME_print() function to get the string representation of ASN.1 - strings for ``rfc822Name`` (email), ``dNSName`` (DNS) and - ``uniformResourceIdentifier`` (URI). - -- Issue #18701: Remove support of old CPython versions (<3.0) from C code. - -- Issue #18756: Improve error reporting in os.urandom() when the failure - is due to something else than /dev/urandom not existing (for example, - exhausting the file descriptor limit). - -- Issue #18673: Add O_TMPFILE to os module. O_TMPFILE requires Linux kernel - 3.11 or newer. It's only defined on system with 3.11 uapi headers, too. - -- Issue #18532: Change the builtin hash algorithms' names to lower case names - as promised by hashlib's documentation. - -- Issue #8713: add new spwan and forkserver start methods, and new functions - get_all_start_methods, get_start_method, and set_start_method, to - multiprocessing. - -- Issue #18405: Improve the entropy of crypt.mksalt(). - -- Issue #12015: The tempfile module now uses a suffix of 8 random characters - instead of 6, to reduce the risk of filename collision. The entropy was - reduced when uppercase letters were removed from the charset used to generate - random characters. - -- Issue #18585: Add :func:`textwrap.shorten` to collapse and truncate a - piece of text to a given length. - -- Issue #18598: Tweak exception message for importlib.import_module() to - include the module name when a key argument is missing. - -- Issue #19151: Fix docstring and use of _get_supported_file_loaders() to - reflect 2-tuples. - -- Issue #19152: Add ExtensionFileLoader.get_filename(). - -- Issue #18676: Change 'positive' to 'non-negative' in queue.py put and get - docstrings and ValueError messages. Patch by Zhongyue Luo - -- Fix refcounting issue with extension types in tkinter. - -- Issue #8112: xlmrpc.server's DocXMLRPCServer server no longer raises an error - if methods have annotations; it now correctly displays the annotations. - -- Issue #18600: Added policy argument to email.message.Message.as_string, - and as_bytes and __bytes__ methods to Message. - -- Issue #18671: Output more information when logging exceptions occur. - -- Issue #18621: Prevent the site module's patched builtins from keeping - too many references alive for too long. - -- Issue #4885: Add weakref support to mmap objects. Patch by Valerie Lambert. - -- Issue #8860: Fixed rounding in timedelta constructor. - -- Issue #18849: Fixed a Windows-specific tempfile bug where collision with an - existing directory caused mkstemp and related APIs to fail instead of - retrying. Report and fix by Vlad Shcherbina. - -- Issue #18920: argparse's default destination for the version action (-v, - --version) has also been changed to stdout, to match the Python executable. - -Tests ------ - -- Issue #18623: Factor out the _SuppressCoreFiles context manager into - test.support. Patch by Valerie Lambert. - -- Issue #12037: Fix test_email for desktop Windows. - -- Issue #15507: test_subprocess's test_send_signal could fail if the test - runner were run in an environment where the process inherited an ignore - setting for SIGINT. Restore the SIGINT handler to the desired - KeyboardInterrupt raising one during that test. - -- Issue #16799: Switched from getopt to argparse style in regrtest's argument - parsing. Added more tests for regrtest's argument parsing. - -- Issue #18792: Use "127.0.0.1" or "::1" instead of "localhost" as much as - possible, since "localhost" goes through a DNS lookup under recent Windows - versions. - -IDLE ----- - -- Issue #18489: Add tests for SearchEngine. Original patch by Phil Webster. - -Documentation -------------- - -- Issue #18743: Fix references to non-existent "StringIO" module. - -- Issue #18783: Removed existing mentions of Python long type in docstrings, - error messages and comments. - -Build ------ - -- Issue #1584: Provide configure options to override default search paths for - Tcl and Tk when building _tkinter. - -- Issue #15663: Tcl/Tk 8.5.14 is now included with the OS X 10.6+ 64-/32-bit - installer. It is no longer necessary to install a third-party version of - Tcl/Tk 8.5 to work around the problems in the Apple-supplied Tcl/Tk 8.5 - shipped in OS X 10.6 and later releases. - -Tools/Demos ------------ - -- Issue #18922: Now The Lib/smtpd.py and Tools/i18n/msgfmt.py scripts write - their version strings to stdout, and not to sderr. - - -What's New in Python 3.4.0 Alpha 1? -=================================== - -Release date: 2013-08-03 - -Core and Builtins ------------------ - -- Issue #16741: Fix an error reporting in int(). - -- Issue #17899: Fix rare file descriptor leak in os.listdir(). - -- Issue #10241: Clear extension module dict copies at interpreter shutdown. - Patch by Neil Schemenauer, minimally modified. - -- Issue #9035: ismount now recognises volumes mounted below a drive root - on Windows. Original patch by Atsuo Ishimoto. - -- Issue #18214: Improve finalization of Python modules to avoid setting - their globals to None, in most cases. - -- Issue #18112: PEP 442 implementation (safe object finalization). - -- Issue #18552: Check return value of PyArena_AddPyObject() in - obj2ast_object(). - -- Issue #18560: Fix potential NULL pointer dereference in sum(). - -- Issue #18520: Add a new PyStructSequence_InitType2() function, same than - PyStructSequence_InitType() except that it has a return value (0 on success, - -1 on error). - -- Issue #15905: Fix theoretical buffer overflow in handling of sys.argv[0], - prefix and exec_prefix if the operation system does not obey MAXPATHLEN. - -- Issue #18408: Fix many various bugs in code handling errors, especially - on memory allocation failure (MemoryError). - -- Issue #18344: Fix potential ref-leaks in _bufferedreader_read_all(). - -- Issue #18342: Use the repr of a module name when an import fails when using - ``from ... import ...``. - -- Issue #17872: Fix a segfault in marshal.load() when input stream returns - more bytes than requested. - -- Issue #18338: `python --version` now prints version string to stdout, and - not to stderr. Patch by Berker Peksag and Michael Dickens. - -- Issue #18426: Fix NULL pointer dereference in C extension import when - PyModule_GetDef() returns an error. - -- Issue #17206: On Windows, increase the stack size from 2 MB to 4.2 MB to fix - a stack overflow in the marshal module (fix a crash in test_marshal). - Patch written by Jeremy Kloth. - -- Issue #3329: Implement the PEP 445: Add new APIs to customize Python memory - allocators. - -- Issue #18328: Reorder ops in PyThreadState_Delete*() functions. Now the - tstate is first removed from TLS and then deallocated. - -- Issue #13483: Use VirtualAlloc in obmalloc on Windows. - -- Issue #18184: PyUnicode_FromFormat() and PyUnicode_FromFormatV() now raise - OverflowError when an argument of %c format is out of range. - -- Issue #18111: The min() and max() functions now support a default argument - to be returned instead of raising a ValueError on an empty sequence. - (Contributed by Julian Berman.) - -- Issue #18137: Detect integer overflow on precision in float.__format__() - and complex.__format__(). - -- Issue #15767: Introduce ModuleNotFoundError which is raised when a module - could not be found. - -- Issue #18183: Fix various unicode operations on strings with large unicode - codepoints. - -- Issue #18180: Fix ref leak in _PyImport_GetDynLoadWindows(). - -- Issue #18038: SyntaxError raised during compilation sources with illegal - encoding now always contains an encoding name. - -- Issue #17931: Resolve confusion on Windows between pids and process - handles. - -- Tweak the exception message when the magic number or size value in a bytecode - file is truncated. - -- Issue #17932: Fix an integer overflow issue on Windows 64-bit in iterators: - change the C type of seqiterobject.it_index from long to Py_ssize_t. - -- Issue #18065: Don't set __path__ to the package name for frozen packages. - -- Issue #18088: When reloading a module, unconditionally reset all relevant - attributes on the module (e.g. __name__, __loader__, __package__, __file__, - __cached__). - -- Issue #17937: Try harder to collect cyclic garbage at shutdown. - -- Issue #12370: Prevent class bodies from interfering with the __class__ - closure. - -- Issue #17644: Fix a crash in str.format when curly braces are used in square - brackets. - -- Issue #17237: Fix crash in the ASCII decoder on m68k. - -- Issue #17927: Frame objects kept arguments alive if they had been - copied into a cell, even if the cell was cleared. - -- Issue #1545463: At shutdown, defer finalization of codec modules so - that stderr remains usable. - -- Issue #7330: Implement width and precision (ex: "%5.3s") for the format - string of PyUnicode_FromFormat() function, original patch written by Ysj Ray. - -- Issue #1545463: Global variables caught in reference cycles are now - garbage-collected at shutdown. - -- Issue #17094: Clear stale thread states after fork(). Note that this - is a potentially disruptive change since it may release some system - resources which would otherwise remain perpetually alive (e.g. database - connections kept in thread-local storage). - -- Issue #17408: Avoid using an obsolete instance of the copyreg module when - the interpreter is shutdown and then started again. - -- Issue #5845: Enable tab-completion in the interactive interpreter by - default, thanks to a new sys.__interactivehook__. - -- Issue #17115,17116: Module initialization now includes setting __package__ and - __loader__ attributes to None. - -- Issue #17853: Ensure locals of a class that shadow free variables always win - over the closures. - -- Issue #17863: In the interactive console, don't loop forever if the encoding - can't be fetched from stdin. - -- Issue #17867: Raise an ImportError if __import__ is not found in __builtins__. - -- Issue #18698: Ensure importlib.reload() returns the module out of sys.modules. - -- Issue #17857: Prevent build failures with pre-3.5.0 versions of sqlite3, - such as was shipped with Centos 5 and Mac OS X 10.4. - -- Issue #17413: sys.settrace callbacks were being passed a string instead of an - exception instance for the 'value' element of the arg tuple if the exception - originated from C code; now an exception instance is always provided. - -- Issue #17782: Fix undefined behaviour on platforms where - ``struct timespec``'s "tv_nsec" member is not a C long. - -- Issue #17722: When looking up __round__, resolve descriptors. - -- Issue #16061: Speed up str.replace() for replacing 1-character strings. - -- Issue #17715: Fix segmentation fault from raising an exception in a __trunc__ - method. - -- Issue #17643: Add __callback__ attribute to weakref.ref. - -- Issue #16447: Fixed potential segmentation fault when setting __name__ on a - class. - -- Issue #17669: Fix crash involving finalization of generators using yield from. - -- Issue #14439: Python now prints the traceback on runpy failure at startup. - -- Issue #17469: Fix _Py_GetAllocatedBlocks() and sys.getallocatedblocks() - when running on valgrind. - -- Issue #17619: Make input() check for Ctrl-C correctly on Windows. - -- Issue #17357: Add missing verbosity messages for -v/-vv that were lost during - the importlib transition. - -- Issue #17610: Don't rely on non-standard behavior of the C qsort() function. - -- Issue #17323: The "[X refs, Y blocks]" printed by debug builds has been - disabled by default. It can be re-enabled with the `-X showrefcount` option. - -- Issue #17328: Fix possible refleak in dict.setdefault. - -- Issue #17275: Corrected class name in init error messages of the C version of - BufferedWriter and BufferedRandom. - -- Issue #7963: Fixed misleading error message that issued when object is - called without arguments. - -- Issue #8745: Small speed up zipimport on Windows. Patch by Catalin Iacob. - -- Issue #5308: Raise ValueError when marshalling too large object (a sequence - with size >= 2**31), instead of producing illegal marshal data. - -- Issue #12983: Bytes literals with invalid ``\x`` escape now raise a SyntaxError - and a full traceback including line number. - -- Issue #16967: In function definition, evaluate positional defaults before - keyword-only defaults. - -- Issue #17173: Remove uses of locale-dependent C functions (isalpha() etc.) - in the interpreter. - -- Issue #17137: When a Unicode string is resized, the internal wide character - string (wstr) format is now cleared. - -- Issue #17043: The unicode-internal decoder no longer read past the end of - input buffer. - -- Issue #17098: All modules now have __loader__ set even if they pre-exist the - bootstrapping of importlib. - -- Issue #16979: Fix error handling bugs in the unicode-escape-decode decoder. - -- Issue #16772: The base argument to the int constructor no longer accepts - floats, or other non-integer objects with an __int__ method. Objects - with an __index__ method are now accepted. - -- Issue #10156: In the interpreter's initialization phase, unicode globals - are now initialized dynamically as needed. - -- Issue #16980: Fix processing of escaped non-ascii bytes in the - unicode-escape-decode decoder. - -- Issue #16975: Fix error handling bug in the escape-decode bytes decoder. - -- Issue #14850: Now a charmap decoder treats U+FFFE as "undefined mapping" - in any mapping, not only in a string. - -- Issue #16613: Add *m* argument to ``collections.Chainmap.new_child`` to - allow the new child map to be specified explicitly. - -- Issue #16730: importlib.machinery.FileFinder now no longers raises an - exception when trying to populate its cache and it finds out the directory is - unreadable or has turned into a file. Reported and diagnosed by - David Pritchard. - -- Issue #16906: Fix a logic error that prevented most static strings from being - cleared. - -- Issue #11461: Fix the incremental UTF-16 decoder. Original patch by - Amaury Forgeot d'Arc. - -- Issue #16856: Fix a segmentation fault from calling repr() on a dict with - a key whose repr raise an exception. - -- Issue #16367: Fix FileIO.readall() on Windows for files larger than 2 GB. - -- Issue #16761: Calling int() with base argument only now raises TypeError. - -- Issue #16759: Support the full DWORD (unsigned long) range in Reg2Py - when retrieving a REG_DWORD value. This corrects functions like - winreg.QueryValueEx that may have been returning truncated values. - -- Issue #14420: Support the full DWORD (unsigned long) range in Py2Reg - when passed a REG_DWORD value. Fixes OverflowError in winreg.SetValueEx. - -- Issue #11939: Set the st_dev attribute of stat_result to allow Windows to - take advantage of the os.path.samefile/sameopenfile/samestat implementations - used by other platforms. - -- Issue #16772: The int() constructor's second argument (base) no longer - accepts non integer values. Consistent with the behavior in Python 2. - -- Issue #14470: Remove w9xpopen support per PEP 11. - -- Issue #9856: Replace deprecation warning with raising TypeError - in object.__format__. Patch by Florent Xicluna. - -- Issue #16597: In buffered and text IO, call close() on the underlying stream - if invoking flush() fails. - -- Issue #16722: In the bytes() constructor, try to call __bytes__ on the - argument before __index__. - -- Issue #16421: loading multiple modules from one shared object is now - handled correctly (previously, the first module loaded from that file - was silently returned). Patch by Václav Šmilauer. - -- Issue #16602: When a weakref's target was part of a long deallocation - chain, the object could remain reachable through its weakref even though - its refcount had dropped to zero. - -- Issue #16495: Remove extraneous NULL encoding check from bytes_decode(). - -- Issue #16619: Create NameConstant AST class to represent None, True, and False - literals. As a result, these constants are never loaded at runtime from - builtins. - -- Issue #16455: On FreeBSD and Solaris, if the locale is C, the - ASCII/surrogateescape codec is now used (instead of the locale encoding) to - decode the command line arguments. This change fixes inconsistencies with - os.fsencode() and os.fsdecode(), because these operating systems announce an - ASCII locale encoding, but actually use the ISO-8859-1 encoding in practice. - -- Issue #16562: Optimize dict equality testing. Patch by Serhiy Storchaka. - -- Issue #16588: Silence unused-but-set warnings in Python/thread_pthread - -- Issue #16592: stringlib_bytes_join doesn't raise MemoryError on allocation - failure. - -- Issue #16546: Fix: ast.YieldFrom argument is now mandatory. - -- Issue #16514: Fix regression causing a traceback when sys.path[0] is None - (actually, any non-string or non-bytes type). - -- Issue #16306: Fix multiple error messages when unknown command line - parameters where passed to the interpreter. Patch by Hieu Nguyen. - -- Issue #16215: Fix potential double memory free in str.replace(). Patch - by Serhiy Storchaka. - -- Issue #16290: A float return value from the __complex__ special method is no - longer accepted in the complex() constructor. - -- Issue #16416: On Mac OS X, operating system data are now always - encoded/decoded to/from UTF-8/surrogateescape, instead of the locale encoding - (which may be ASCII if no locale environment variable is set), to avoid - inconsistencies with os.fsencode() and os.fsdecode() functions which are - already using UTF-8/surrogateescape. - -- Issue #16453: Fix equality testing of dead weakref objects. - -- Issue #9535: Fix pending signals that have been received but not yet - handled by Python to not persist after os.fork() in the child process. - -- Issue #14794: Fix slice.indices to return correct results for huge values, - rather than raising OverflowError. - -- Issue #15001: fix segfault on "del sys.modules['__main__']". Patch by Victor - Stinner. - -- Issue #8271: the utf-8 decoder now outputs the correct number of U+FFFD - characters when used with the 'replace' error handler on invalid utf-8 - sequences. Patch by Serhiy Storchaka, tests by Ezio Melotti. - -- Issue #5765: Apply a hard recursion limit in the compiler instead of - blowing the stack and segfaulting. Initial patch by Andrea Griffini. - -- Issue #16402: When slicing a range, fix shadowing of exceptions from - __index__. - -- Issue #16336: fix input checking in the surrogatepass error handler. - Patch by Serhiy Storchaka. - -- Issue #8401: assigning an int to a bytearray slice (e.g. b[3:4] = 5) now - raises an error. - -- Issue #7317: Display full tracebacks when an error occurs asynchronously. - Patch by Alon Horev with update by Alexey Kachayev. - -- Issue #16309: Make PYTHONPATH="" behavior the same as if PYTHONPATH - not set at all. - -- Issue #10189: Improve the error reporting of SyntaxErrors related to global - and nonlocal statements. - -- Fix segfaults on setting __qualname__ on builtin types and attempting to - delete it on any type. - -- Issue #14625: Rewrite the UTF-32 decoder. It is now 3x to 4x faster. Patch - written by Serhiy Storchaka. - -- Issue #16345: Fix an infinite loop when ``fromkeys`` on a dict subclass - received a nonempty dict from the constructor. - -- Issue #16271: Fix strange bugs that resulted from __qualname__ appearing in a - class's __dict__ and on type. - -- Issue #12805: Make bytes.join and bytearray.join faster when the separator - is empty. Patch by Serhiy Storchaka. - -- Issue #6074: Ensure cached bytecode files can always be updated by the - user that created them, even when the source file is read-only. - -- Issue #15958: bytes.join and bytearray.join now accept arbitrary buffer - objects. - -- Issue #14783: Improve int() docstring and switch docstrings for str(), - range(), and slice() to use multi-line signatures. - -- Issue #16160: Subclass support now works for types.SimpleNamespace. - -- Issue #16148: Implement PEP 424, adding operator.length_hint and - PyObject_LengthHint. - -- Upgrade Unicode data (UCD) to version 6.2. - -- Issue #15379: Fix passing of non-BMP characters as integers for the charmap - decoder (already working as unicode strings). Patch by Serhiy Storchaka. - -- Issue #15144: Fix possible integer overflow when handling pointers as integer - values, by using `Py_uintptr_t` instead of `size_t`. Patch by Serhiy - Storchaka. - -- Issue #15965: Explicitly cast `AT_FDCWD` as (int). Required on Solaris 10 - (which defines `AT_FDCWD` as ``0xffd19553``), harmless on other platforms. - -- Issue #15839: Convert SystemErrors in `super()` to RuntimeErrors. - -- Issue #15448: Buffered IO now frees the buffer when closed, instead - of when deallocating. - -- Issue #15846: Fix SystemError which happened when using `ast.parse()` in an - exception handler on code with syntax errors. - -- Issue #15897: zipimport.c doesn't check return value of fseek(). - Patch by Felipe Cruz. - -- Issue #15801: Make sure mappings passed to '%' formatting are actually - subscriptable. - -- Issue #15111: __import__ should propagate ImportError when raised as a - side-effect of a module triggered from using fromlist. - -- Issue #15022: Add pickle and comparison support to types.SimpleNamespace. - -Library -------- - -- Issue #4331: Added functools.partialmethod (Initial patch by Alon Horev) - -- Issue #13461: Fix a crash in the TextIOWrapper.tell method on 64-bit - platforms. Patch by Yogesh Chaudhari. - -- Issue #18681: Fix a NameError in importlib.reload() (noticed by Weizhao Li). - -- Issue #14323: Expanded the number of digits in the coefficients for the - RGB -- YIQ conversions so that they match the FCC NTSC versions. - -- Issue #17998: Fix an internal error in regular expression engine. - -- Issue #17557: Fix os.getgroups() to work with the modified behavior of - getgroups(2) on OS X 10.8. Original patch by Mateusz Lenik. - -- Issue #18608: Avoid keeping a strong reference to the locale module - inside the _io module. - -- Issue #18619: Fix atexit leaking callbacks registered from sub-interpreters, - and make it GC-aware. - -- Issue #15699: The readline module now uses PEP 3121-style module - initialization, so as to reclaim allocated resources (Python callbacks) - at shutdown. Original patch by Robin Schreiber. - -- Issue #17616: wave.open now supports the context management protocol. - -- Issue #18599: Fix name attribute of _sha1.sha1() object. It now returns - 'SHA1' instead of 'SHA'. - -- Issue #13266: Added inspect.unwrap to easily unravel __wrapped__ chains - (initial patch by Daniel Urban and Aaron Iles) - -- Issue #18561: Skip name in ctypes' _build_callargs() if name is NULL. - -- Issue #18559: Fix NULL pointer dereference error in _pickle module - -- Issue #18556: Check the return type of PyUnicode_AsWideChar() in ctype's - U_set(). - -- Issue #17818: aifc.getparams now returns a namedtuple. - -- Issue #18549: Eliminate dead code in socket_ntohl() - -- Issue #18530: Remove additional stat call from posixpath.ismount. - Patch by Alex Gaynor. - -- Issue #18514: Fix unreachable Py_DECREF() call in PyCData_FromBaseObj() - -- Issue #9177: Calling read() or write() now raises ValueError, not - AttributeError, on a closed SSL socket. Patch by Senko Rasic. - -- Issue #18513: Fix behaviour of cmath.rect w.r.t. signed zeros on OS X 10.8 + - gcc. - -- Issue #18479: Changed venv Activate.ps1 to make deactivate a function, and - removed Deactivate.ps1. - -- Issue #18480: Add missing call to PyType_Ready to the _elementtree extension. - -- Issue #17778: Fix test discovery for test_multiprocessing. (Patch by - Zachary Ware.) - -- Issue #18393: The private module _gestalt and private functions - platform._mac_ver_gestalt, platform._mac_ver_lookup and - platform._bcd2str have been removed. This does not affect the public - interface of the platform module. - -- Issue #17482: functools.update_wrapper (and functools.wraps) now set the - __wrapped__ attribute correctly even if the underlying function has a - __wrapped__ attribute set. - -- Issue #18431: The new email header parser now decodes RFC2047 encoded words - in structured headers. - -- Issue #18432: The sched module's queue method was incorrectly returning - an iterator instead of a list. - -- Issue #18044: The new email header parser was mis-parsing encoded words where - an encoded character immediately followed the '?' that follows the CTE - character, resulting in a decoding failure. They are now decoded correctly. - -- Issue #18101: Tcl.split() now process strings nested in a tuple as it - do with byte strings. - -- Issue #18116: getpass was always getting an error when testing /dev/tty, - and thus was always falling back to stdin, and would then raise an exception - if stdin could not be used (such as /dev/null). It also leaked an open file. - All of these issues are now fixed. - -- Issue #17198: Fix a NameError in the dbm module. Patch by Valentina - Mukhamedzhanova. - -- Issue #18013: Fix cgi.FieldStorage to parse the W3C sample form. - -- Issue #18020: improve html.escape speed by an order of magnitude. - Patch by Matt Bryant. - -- Issue #18347: ElementTree's html serializer now preserves the case of - closing tags. - -- Issue #17261: Ensure multiprocessing's proxies use proper address. - -- Issue #18343: faulthandler.register() now keeps the previous signal handler - when the function is called twice, so faulthandler.unregister() restores - correctly the original signal handler. - -- Issue #17097: Make multiprocessing ignore EINTR. - -- Issue #18339: Negative ints keys in unpickler.memo dict no longer cause a - segfault inside the _pickle C extension. - -- Issue #18240: The HMAC module is no longer restricted to bytes and accepts - any bytes-like object, e.g. memoryview. Original patch by Jonas Borgström. - -- Issue #18224: Removed pydoc script from created venv, as it causes problems - on Windows and adds no value over and above python -m pydoc ... - -- Issue #18155: The csv module now correctly handles csv files that use - a delimiter character that has a special meaning in regexes, instead of - throwing an exception. - -- Issue #14360: encode_quopri can now be successfully used as an encoder - when constructing a MIMEApplication object. - -- Issue #11390: Add -o and -f command line options to the doctest CLI to - specify doctest options (and convert it to using argparse). - -- Issue #18135: ssl.SSLSocket.write() now raises an OverflowError if the input - string in longer than 2 gigabytes, and ssl.SSLContext.load_cert_chain() - raises a ValueError if the password is longer than 2 gigabytes. The ssl - module does not support partial write. - -- Issue #11016: Add C implementation of the stat module as _stat. - -- Issue #18248: Fix libffi build on AIX. - -- Issue #18259: Declare sethostname in socketmodule.c for AIX - -- Issue #18147: Add diagnostic functions to ssl.SSLContext(). get_ca_list() - lists all loaded CA certificates and cert_store_stats() returns amount of - loaded X.509 certs, X.509 CA certs and CRLs. - -- Issue #18167: cgi.FieldStorage no longer fails to handle multipart/form-data - when ``\r\n`` appears at end of 65535 bytes without other newlines. - -- Issue #18076: Introduce importlib.util.decode_source(). - -- Issue #18357: add tests for dictview set difference. - Patch by Fraser Tweedale. - -- importlib.abc.SourceLoader.get_source() no longer changes SyntaxError or - UnicodeDecodeError into ImportError. - -- Issue #18058, 18057: Make the namespace package loader meet the - importlib.abc.InspectLoader ABC, allowing for namespace packages to work with - runpy. - -- Issue #17177: The imp module is pending deprecation. - -- subprocess: Prevent a possible double close of parent pipe fds when the - subprocess exec runs into an error. Prevent a regular multi-close of the - /dev/null fd when any of stdin, stdout and stderr was set to DEVNULL. - -- Issue #18194: Introduce importlib.util.cache_from_source() and - source_from_cache() while documenting the equivalent functions in imp as - deprecated. - -- Issue #17907: Document imp.new_module() as deprecated in favour of - types.ModuleType. - -- Issue #18192: Introduce importlib.util.MAGIC_NUMBER and document as deprecated - imp.get_magic(). - -- Issue #18149: Add filecmp.clear_cache() to manually clear the filecmp cache. - Patch by Mark Levitt - -- Issue #18193: Add importlib.reload(). - -- Issue #18157: Stop using imp.load_module() in pydoc. - -- Issue #16102: Make uuid._netbios_getnode() work again on Python 3. - -- Issue #17134: Add ssl.enum_cert_store() as interface to Windows' cert store. - -- Issue #18143: Implement ssl.get_default_verify_paths() in order to debug - the default locations for cafile and capath. - -- Issue #17314: Move multiprocessing.forking over to importlib. - -- Issue #11959: SMTPServer and SMTPChannel now take an optional map, use of - which avoids affecting global state. - -- Issue #18109: os.uname() now decodes fields from the locale encoding, and - socket.gethostname() now decodes the hostname from the locale encoding, - instead of using the UTF-8 encoding in strict mode. - -- Issue #18089: Implement importlib.abc.InspectLoader.load_module. - -- Issue #18088: Introduce importlib.abc.Loader.init_module_attrs for setting - module attributes. Leads to the pending deprecation of - importlib.util.module_for_loader. - -- Issue #17403: urllib.parse.robotparser normalizes the urls before adding to - ruleline. This helps in handling certain types invalid urls in a conservative - manner. Patch contributed by Mher Movsisyan. - -- Issue #18070: Have importlib.util.module_for_loader() set attributes - unconditionally in order to properly support reloading. - -- Added importlib.util.module_to_load to return a context manager to provide the - proper module object to load. - -- Issue #18025: Fixed a segfault in io.BufferedIOBase.readinto() when raw - stream's read() returns more bytes than requested. - -- Issue #18011: As was originally intended, base64.b32decode() now raises a - binascii.Error if there are non-b32-alphabet characters present in the input - string, instead of a TypeError. - -- Issue #18072: Implement importlib.abc.InspectLoader.get_code() and - importlib.abc.ExecutionLoader.get_code(). - -- Issue #8240: Set the SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER flag on SSL - sockets. - -- Issue #17269: Workaround for socket.getaddrinfo crash on MacOS X - with port None or "0" and flags AI_NUMERICSERV. - -- Issue #16986: ElementTree now correctly works with string input when the - internal XML encoding is not UTF-8 or US-ASCII. - -- Issue #17996: socket module now exposes AF_LINK constant on BSD and OSX. - -- Issue #17900: Allowed pickling of recursive OrderedDicts. Decreased pickled - size and pickling time. - -- Issue #17914: Add os.cpu_count(). Patch by Yogesh Chaudhari, based on an - initial patch by Trent Nelson. - -- Issue #17812: Fixed quadratic complexity of base64.b32encode(). - Optimize base64.b32encode() and base64.b32decode() (speed up to 3x). - -- Issue #17980: Fix possible abuse of ssl.match_hostname() for denial of - service using certificates with many wildcards (CVE-2013-2099). - -- Issue #15758: Fix FileIO.readall() so it no longer has O(n**2) complexity. - -- Issue #14596: The struct.Struct() objects now use a more compact - implementation. - -- Issue #17981: logging's SysLogHandler now closes the socket when it catches - socket OSErrors. - -- Issue #17964: Fix os.sysconf(): the return type of the C sysconf() function - is long, not int. - -- Fix typos in the multiprocessing module. - -- Issue #17754: Make ctypes.util.find_library() independent of the locale. - -- Issue #17968: Fix memory leak in os.listxattr(). - -- Issue #17606: Fixed support of encoded byte strings in the XMLGenerator - characters() and ignorableWhitespace() methods. Original patch by Sebastian - Ortiz Vasquez. - -- Issue #17732: Ignore distutils.cfg options pertaining to install paths if a - virtual environment is active. - -- Issue #17915: Fix interoperability of xml.sax with file objects returned by - codecs.open(). - -- Issue #16601: Restarting iteration over tarfile really restarts rather - than continuing from where it left off. Patch by Michael Birtwell. - -- Issue #17289: The readline module now plays nicer with external modules - or applications changing the rl_completer_word_break_characters global - variable. Initial patch by Bradley Froehle. - -- Issue #12181: select module: Fix struct kevent definition on OpenBSD 64-bit - platforms. Patch by Federico Schwindt. - -- Issue #11816: multiple improvements to the dis module: get_instructions - generator, ability to redirect output to a file, Bytecode and Instruction - abstractions. Patch by Nick Coghlan, Ryan Kelly and Thomas Kluyver. - -- Issue #13831: Embed stringification of remote traceback in local - traceback raised when pool task raises an exception. - -- Issue #15528: Add weakref.finalize to support finalization using - weakref callbacks. - -- Issue #14173: Avoid crashing when reading a signal handler during - interpreter shutdown. - -- Issue #15902: Fix imp.load_module() accepting None as a file when loading an - extension module. - -- Issue #13721: SSLSocket.getpeercert() and SSLSocket.do_handshake() now - raise an OSError with ENOTCONN, instead of an AttributeError, when the - SSLSocket is not connected. - -- Issue #14679: add an __all__ (that contains only HTMLParser) to html.parser. - -- Issue #17802: Fix an UnboundLocalError in html.parser. Initial tests by - Thomas Barlow. - -- Issue #17358: Modules loaded by imp.load_source() and load_compiled() (and by - extension load_module()) now have a better chance of working when reloaded. - -- Issue #17804: New function ``struct.iter_unpack`` allows for streaming - struct unpacking. - -- Issue #17830: When keyword.py is used to update a keyword file, it now - preserves the line endings of the original file. - -- Issue #17272: Making the urllib.request's Request.full_url a descriptor. - Fixes bugs with assignment to full_url. Patch by Demian Brecht. - -- Issue #17353: Plistlib emitted empty data tags with deeply nested datastructures - -- Issue #11714: Use 'with' statements to assure a Semaphore releases a - condition variable. Original patch by Thomas Rachel. - -- Issue #16624: `subprocess.check_output` now accepts an `input` argument, - allowing the subprocess's stdin to be provided as a (byte) string. - Patch by Zack Weinberg. - -- Issue #17795: Reverted backwards-incompatible change in SysLogHandler with - Unix domain sockets. - -- Issue #16694: Add a pure Python implementation of the operator module. - Patch by Zachary Ware. - -- Issue #11182: remove the unused and undocumented pydoc.Scanner class. - Patch by Martin Morrison. - -- Issue #17741: Add ElementTree.XMLPullParser, an event-driven parser for - non-blocking applications. - -- Issue #17555: Fix ForkAwareThreadLock so that size of after fork - registry does not grow exponentially with generation of process. - -- Issue #17707: fix regression in multiprocessing.Queue's get() method where - it did not block for short timeouts. - -- Issue #17720: Fix the Python implementation of pickle.Unpickler to correctly - process the APPENDS opcode when it is used on non-list objects. - -- Issue #17012: shutil.which() no longer falls back to the PATH environment - variable if an empty path argument is specified. Patch by Serhiy Storchaka. - -- Issue #17710: Fix pickle raising a SystemError on bogus input. - -- Issue #17341: Include the invalid name in the error messages from re about - invalid group names. - -- Issue #17702: os.environ now raises KeyError with the original environment - variable name (str on UNIX), instead of using the encoded name (bytes on - UNIX). - -- Issue #16163: Make the importlib based version of pkgutil.iter_importers - work for submodules. Initial patch by Berker Peksag. - -- Issue #16804: Fix a bug in the 'site' module that caused running - 'python -S -m site' to incorrectly throw an exception. - -- Issue #15480: Remove the deprecated and unused TYPE_INT64 code from marshal. - Initial patch by Daniel Riti. - -- Issue #2118: SMTPException is now a subclass of OSError. - -- Issue #17016: Get rid of possible pointer wraparounds and integer overflows - in the re module. Patch by Nickolai Zeldovich. - -- Issue #16658: add missing return to HTTPConnection.send(). - Patch by Jeff Knupp. - -- Issue #9556: the logging package now allows specifying a time-of-day for a - TimedRotatingFileHandler to rotate. - -- Issue #14971: unittest test discovery no longer gets confused when a function - has a different __name__ than its name in the TestCase class dictionary. - -- Issue #17487: The wave getparams method now returns a namedtuple rather than - a plain tuple. - -- Issue #17675: socket repr() provides local and remote addresses (if any). - Patch by Giampaolo Rodola' - -- Issue #17093: Make the ABCs in importlib.abc provide default values or raise - reasonable exceptions for their methods to make them more amenable to super() - calls. - -- Issue #17566: Make importlib.abc.Loader.module_repr() optional instead of an - abstractmethod; now it raises NotImplementedError so as to be ignored by default. - -- Issue #17678: Remove the use of deprecated method in http/cookiejar.py by - changing the call to get_origin_req_host() to origin_req_host. - -- Issue #17666: Fix reading gzip files with an extra field. - -- Issue #16475: Support object instancing, recursion and interned strings - in marshal - -- Issue #17502: Process DEFAULT values in mock side_effect that returns iterator. - -- Issue #16795: On the ast.arguments object, unify vararg with varargannotation - and kwarg and kwargannotation. Change the column offset of ast.Attribute to be - at the attribute name. - -- Issue #17434: Properly raise a SyntaxError when a string occurs between future - imports. - -- Issue #17117: Import and @importlib.util.set_loader now set __loader__ when - it has a value of None or the attribute doesn't exist. - -- Issue #17032: The "global" in the "NameError: global name 'x' is not defined" - error message has been removed. Patch by Ram Rachum. - -- Issue #18080: When building a C extension module on OS X, if the compiler - is overridden with the CC environment variable, use the new compiler as - the default for linking if LDSHARED is not also overridden. This restores - Distutils behavior introduced in 3.2.3 and inadvertently dropped in 3.3.0. - -- Issue #18113: Fixed a refcount leak in the curses.panel module's - set_userptr() method. Reported by Atsuo Ishimoto. - -- Implement PEP 443 "Single-dispatch generic functions". - -- Implement PEP 435 "Adding an Enum type to the Python standard library". - -- Issue #15596: Faster pickling of unicode strings. - -- Issue #17572: Avoid chained exceptions when passing bad directives to - time.strptime(). Initial patch by Claudiu Popa. - -- Issue #17435: threading.Timer's __init__ method no longer uses mutable - default values for the args and kwargs parameters. - -- Issue #17526: fix an IndexError raised while passing code without filename to - inspect.findsource(). Initial patch by Tyler Doyle. - -- Issue #17540: Added style parameter to logging formatter configuration by dict. - -- Issue #16692: The ssl module now supports TLS 1.1 and TLS 1.2. Initial - patch by Michele Orrù. - -- Issue #17025: multiprocessing: Reduce Queue and SimpleQueue contention. - -- Issue #17536: Add to webbrowser's browser list: www-browser, x-www-browser, - iceweasel, iceape. - -- Issue #17150: pprint now uses line continuations to wrap long string - literals. - -- Issue #17488: Change the subprocess.Popen bufsize parameter default value - from unbuffered (0) to buffering (-1) to match the behavior existing code - expects and match the behavior of the subprocess module in Python 2 to avoid - introducing hard to track down bugs. - -- Issue #17521: Corrected non-enabling of logger following two calls to - fileConfig(). - -- Issue #17508: Corrected logging MemoryHandler configuration in dictConfig() - where the target handler wasn't configured first. - -- Issue #17209: curses.window.get_wch() now correctly handles KeyboardInterrupt - (CTRL+c). - -- Issue #5713: smtplib now handles 421 (closing connection) error codes when - sending mail by closing the socket and reporting the 421 error code via the - exception appropriate to the command that received the error response. - -- Issue #16997: unittest.TestCase now provides a subTest() context manager - to procedurally generate, in an easy way, small test instances. - -- Issue #17485: Also delete the Request Content-Length header if the data - attribute is deleted. (Follow on to issue Issue #16464). - -- Issue #15927: CVS now correctly parses escaped newlines and carriage - when parsing with quoting turned off. - -- Issue #17467: add readline and readlines support to mock_open in - unittest.mock. - -- Issue #13248: removed deprecated and undocumented difflib.isbjunk, - isbpopular. - -- Issue #17192: Update the ctypes module's libffi to v3.0.13. This - specifically addresses a stack misalignment issue on x86 and issues on - some more recent platforms. - -- Issue #8862: Fixed curses cleanup when getkey is interrupted by a signal. - -- Issue #17443: imaplib.IMAP4_stream was using the default unbuffered IO - in subprocess, but the imap code assumes buffered IO. In Python2 this - worked by accident. IMAP4_stream now explicitly uses buffered IO. - -- Issue #17476: Fixed regression relative to Python2 in undocumented pydoc - 'allmethods'; it was missing unbound methods on the class. - -- Issue #17474: Remove the deprecated methods of Request class. - -- Issue #16709: unittest discover order is no-longer filesystem specific. Patch - by Jeff Ramnani. - -- Use the HTTPS PyPI url for upload, overriding any plain HTTP URL in pypirc. - -- Issue #5024: sndhdr.whichhdr now returns the frame count for WAV files - rather than -1. - -- Issue #17460: Remove the strict argument of HTTPConnection and removing the - DeprecationWarning being issued from 3.2 onwards. - -- Issue #16880: Do not assume _imp.load_dynamic() is defined in the imp module. - -- Issue #16389: Fixed a performance regression relative to Python 3.1 in the - caching of compiled regular expressions. - -- Added missing FeedParser and BytesFeedParser to email.parser.__all__. - -- Issue #17431: Fix missing import of BytesFeedParser in email.parser. - -- Issue #12921: http.server's send_error takes an explain argument to send more - information in response. Patch contributed by Karl. - -- Issue #17414: Add timeit, repeat, and default_timer to timeit.__all__. - -- Issue #1285086: Get rid of the refcounting hack and speed up - urllib.parse.unquote() and urllib.parse.unquote_to_bytes(). - -- Issue #17099: Have importlib.find_loader() raise ValueError when __loader__ - is not set, harmonizing with what happens when the attribute is set to None. - -- Expose the O_PATH constant in the os module if it is available. - -- Issue #17368: Fix an off-by-one error in the Python JSON decoder that caused - a failure while decoding empty object literals when object_pairs_hook was - specified. - -- Issue #17385: Fix quadratic behavior in threading.Condition. The FIFO - queue now uses a deque instead of a list. - -- Issue #15806: Add contextlib.ignore(). This creates a context manager to - ignore specified exceptions, replacing the "except SomeException: pass" idiom. - -- Issue #14645: The email generator classes now produce output using the - specified linesep throughout. Previously if the prolog, epilog, or - body were stored with a different linesep, that linesep was used. This - fix corrects an RFC non-compliance issue with smtplib.send_message. - -- Issue #17278: Fix a crash in heapq.heappush() and heapq.heappop() when - the list is being resized concurrently. - -- Issue #16962: Use getdents64 instead of the obsolete getdents syscall - in the subprocess module on Linux. - -- Issue #16935: unittest now counts the module as skipped if it raises SkipTest, - instead of counting it as an error. Patch by Zachary Ware. - -- Issue #17018: Make Process.join() retry if os.waitpid() fails with EINTR. - -- Issue #17223: array module: Fix a crasher when converting an array containing - invalid characters (outside range [U+0000; U+10ffff]) to Unicode: - repr(array), str(array) and array.tounicode(). Patch written by Manuel Jacob. - -- Issue #17197: profile/cProfile modules refactored so that code of run() and - runctx() utility functions is not duplicated in both modules. - -- Issue #14720: sqlite3: Convert datetime microseconds correctly. - Patch by Lowe Thiderman. - -- Issue #15132: Allow a list for the defaultTest argument of - unittest.TestProgram. Patch by Jyrki Pulliainen. - -- Issue #17225: JSON decoder now counts columns in the first line starting - with 1, as in other lines. - -- Issue #6623: Added explicit DeprecationWarning for ftplib.netrc, which has - been deprecated and undocumented for a long time. - -- Issue #13700: Fix byte/string handling in imaplib authentication when an - authobject is specified. - -- Issue #13153: Tkinter functions now raise TclError instead of ValueError when - a string argument contains non-BMP character. - -- Issue #9669: Protect re against infinite loops on zero-width matching in - non-greedy repeat. Patch by Matthew Barnett. - -- Issue #13169: The maximal repetition number in a regular expression has been - increased from 65534 to 2147483647 (on 32-bit platform) or 4294967294 (on - 64-bit). - -- Issue #17143: Fix a missing import in the trace module. Initial patch by - Berker Peksag. - -- Issue #15220: email.feedparser's line splitting algorithm is now simpler and - faster. - -- Issue #16743: Fix mmap overflow check on 32 bit Windows. - -- Issue #16996: webbrowser module now uses shutil.which() to find a - web-browser on the executable search path. - -- Issue #16800: tempfile.gettempdir() no longer left temporary files when - the disk is full. Original patch by Amir Szekely. - -- Issue #17192: Import libffi-3.0.12. - -- Issue #16564: Fixed regression relative to Python2 in the operation of - email.encoders.encode_7or8bit when used with binary data. - -- Issue #17052: unittest discovery should use self.testLoader. - -- Issue #4591: Uid and gid values larger than 2**31 are supported now. - -- Issue #17141: random.vonmisesvariate() no longer hangs for large kappas. - -- Issue #17149: Fix random.vonmisesvariate to always return results in - [0, 2*math.pi]. - -- Issue #1470548: XMLGenerator now works with binary output streams. - -- Issue #6975: os.path.realpath() now correctly resolves multiple nested - symlinks on POSIX platforms. - -- Issue #13773: sqlite3.connect() gets a new `uri` parameter to pass the - filename as a URI, allowing custom options to be passed. - -- Issue #16564: Fixed regression relative to Python2 in the operation of - email.encoders.encode_noop when used with binary data. - -- Issue #10355: The mode, name, encoding and newlines properties now work on - SpooledTemporaryFile objects even when they have not yet rolled over. - Obsolete method xreadline (which has never worked in Python 3) has been - removed. - -- Issue #16686: Fixed a lot of bugs in audioop module. Fixed crashes in - avgpp(), maxpp() and ratecv(). Fixed an integer overflow in add(), bias(), - and ratecv(). reverse(), lin2lin() and ratecv() no more lose precision for - 32-bit samples. max() and rms() no more returns a negative result and - various other functions now work correctly with 32-bit sample -0x80000000. - -- Issue #17073: Fix some integer overflows in sqlite3 module. - -- Issue #16723: httplib.HTTPResponse no longer marked closed when the connection - is automatically closed. - -- Issue #15359: Add CAN_BCM protocol support to the socket module. Patch by - Brian Thorne. - -- Issue #16948: Fix quoted printable body encoding for non-latin1 character - sets in the email package. - -- Issue #16811: Fix folding of headers with no value in the provisional email - policies. - -- Issue #17132: Update symbol for "yield from" grammar changes. - -- Issue #17076: Make copying of xattrs more tolerant of missing FS support. - Patch by Thomas Wouters. - -- Issue #17089: Expat parser now correctly works with string input when the - internal XML encoding is not UTF-8 or US-ASCII. It also now accepts bytes - and strings larger than 2 GiB. - -- Issue #6083: Fix multiple segmentation faults occurred when PyArg_ParseTuple - parses nested mutating sequence. - -- Issue #5289: Fix ctypes.util.find_library on Solaris. - -- Issue #17106: Fix a segmentation fault in io.TextIOWrapper when an underlying - stream or a decoder produces data of an unexpected type (i.e. when - io.TextIOWrapper initialized with text stream or use bytes-to-bytes codec). - -- Issue #17015: When it has a spec, a Mock object now inspects its signature - when matching calls, so that arguments can be matched positionally or - by name. - -- Issue #15633: httplib.HTTPResponse is now mark closed when the server - sends less than the advertised Content-Length. - -- Issue #12268: The io module file object write methods no longer abort early - when one of its write system calls is interrupted (EINTR). - -- Issue #6972: The zipfile module no longer overwrites files outside of - its destination path when extracting malicious zip files. - -- Issue #4844: ZipFile now raises BadZipFile when opens a ZIP file with an - incomplete "End of Central Directory" record. Original patch by Guilherme - Polo and Alan McIntyre. - -- Issue #17071: Signature.bind() now works when one of the keyword arguments - is named ``self``. - -- Issue #12004: Fix an internal error in PyZipFile when writing an invalid - Python file. Patch by Ben Morgan. - -- Have py_compile use importlib as much as possible to avoid code duplication. - Code now raises FileExistsError if the file path to be used for the - byte-compiled file is a symlink or non-regular file as a warning that import - will not keep the file path type if it writes to that path. - -- Issue #16972: Have site.addpackage() consider already known paths even when - none are explicitly passed in. Bug report and fix by Kirill. - -- Issue #1602133: on Mac OS X a shared library build (``--enable-shared``) - now fills the ``os.environ`` variable correctly. - -- Issue #15505: `unittest.installHandler` no longer assumes SIGINT handler is - set to a callable object. - -- Issue #13454: Fix a crash when deleting an iterator created by itertools.tee() - if all other iterators were very advanced before. - -- Issue #12411: Fix to cgi.parse_multipart to correctly use bytes boundaries - and bytes data. Patch by Jonas Wagner. - -- Issue #16957: shutil.which() no longer searches a bare file name in the - current directory on Unix and no longer searches a relative file path with - a directory part in PATH directories. Patch by Thomas Kluyver. - -- Issue #1159051: GzipFile now raises EOFError when reading a corrupted file - with truncated header or footer. - -- Issue #16993: shutil.which() now preserves the case of the path and extension - on Windows. - -- Issue #16992: On Windows in signal.set_wakeup_fd, validate the file - descriptor argument. - -- Issue #16422: For compatibility with the Python version, the C version of - decimal now uses strings instead of integers for rounding mode constants. - -- Issue #15861: tkinter now correctly works with lists and tuples containing - strings with whitespaces, backslashes or unbalanced braces. - -- Issue #9720: zipfile now writes correct local headers for files larger than - 4 GiB. - -- Issue #16955: Fix the poll() method for multiprocessing's socket - connections on Windows. - -- SSLContext.load_dh_params() now properly closes the input file. - -- Issue #15031: Refactor some .pyc management code to cut down on code - duplication. Thanks to Ronan Lamy for the report and taking an initial stab - at the problem. - -- Issue #16398: Optimize deque.rotate() so that it only moves pointers - and doesn't touch the underlying data with increfs and decrefs. - -- Issue #16900: Issue a ResourceWarning when an ssl socket is left unclosed. - -- Issue #13899: ``\A``, ``\Z``, and ``\B`` now correctly match the A, Z, - and B literals when used inside character classes (e.g. ``'[\A]'``). - Patch by Matthew Barnett. - -- Issue #15545: Fix regression in sqlite3's iterdump method where it was - failing if the connection used a row factory (such as sqlite3.Row) that - produced unsortable objects. (Regression was introduced by fix for 9750). - -- fcntl: add F_DUPFD_CLOEXEC constant, available on Linux 2.6.24+. - -- Issue #15972: Fix error messages when os functions expecting a file name or - file descriptor receive the incorrect type. - -- Issue #8109: The ssl module now has support for server-side SNI, thanks - to a :meth:`SSLContext.set_servername_callback` method. Patch by Daniel - Black. - -- Issue #16860: In tempfile, use O_CLOEXEC when available to set the - close-on-exec flag atomically. - -- Issue #16674: random.getrandbits() is now 20-40% faster for small integers. - -- Issue #16009: JSON error messages now provide more information. - -- Issue #16828: Fix error incorrectly raised by bz2.compress(b'') and - bz2.BZ2Compressor.compress(b''). Initial patch by Martin Packman. - -- Issue #16833: In http.client.HTTPConnection, do not concatenate the request - headers and body when the payload exceeds 16 KB, since it can consume more - memory for no benefit. Patch by Benno Leslie. - -- Issue #16541: tk_setPalette() now works with keyword arguments. - -- Issue #16820: In configparser, `parser.popitem()` no longer raises ValueError. - This makes `parser.clean()` work correctly. - -- Issue #16820: In configparser, ``parser['section'] = {}`` now preserves - section order within the parser. This makes `parser.update()` preserve section - order as well. - -- Issue #16820: In configparser, ``parser['DEFAULT'] = {}`` now correctly - clears previous values stored in the default section. Same goes for - ``parser.update({'DEFAULT': {}})``. - -- Issue #9586: Redefine SEM_FAILED on MacOSX to keep compiler happy. - -- Issue #16787: Increase asyncore and asynchat default output buffers size, to - decrease CPU usage and increase throughput. - -- Issue #10527: make multiprocessing use poll() instead of select() if available. - -- Issue #16688: Now regexes contained backreferences correctly work with - non-ASCII strings. Patch by Matthew Barnett. - -- Issue #16486: Make aifc files act as context managers. - -- Issue #16485: Now file descriptors are closed if file header patching failed - on closing an aifc file. - -- Issue #16640: Run less code under a lock in sched module. - -- Issue #16165: sched.scheduler.run() no longer blocks a scheduler for other - threads. - -- Issue #16641: Default values of sched.scheduler.enter() are no longer - modifiable. - -- Issue #16618: Make glob.glob match consistently across strings and bytes - regarding leading dots. Patch by Serhiy Storchaka. - -- Issue #16788: Add samestat to Lib/ntpath.py - -- Issue #16713: Parsing of 'tel' urls using urlparse separates params from - path. - -- Issue #16443: Add docstrings to regular expression match objects. - Patch by Anton Kasyanov. - -- Issue #15701: Fix HTTPError info method call to return the headers information. - -- Issue #16752: Add a missing import to modulefinder. Patch by Berker Peksag. - -- Issue #16646: ftplib.FTP.makeport() might lose socket error details. - (patch by Serhiy Storchaka) - -- Issue #16626: Fix infinite recursion in glob.glob() on Windows when the - pattern contains a wildcard in the drive or UNC path. Patch by Serhiy - Storchaka. - -- Issue #15783: Except for the number methods, the C version of decimal now - supports all None default values present in decimal.py. These values were - largely undocumented. - -- Issue #11175: argparse.FileType now accepts encoding and errors - arguments. Patch by Lucas Maystre. - -- Issue #16488: epoll() objects now support the `with` statement. Patch - by Serhiy Storchaka. - -- Issue #16298: In HTTPResponse.read(), close the socket when there is no - Content-Length and the incoming stream is finished. Patch by Eran - Rundstein. - -- Issue #16049: Add abc.ABC class to enable the use of inheritance to create - ABCs, rather than the more cumbersome metaclass=ABCMeta. Patch by Bruno - Dupuis. - -- Expose the TCP_FASTOPEN and MSG_FASTOPEN flags in socket when they're - available. - -- Issue #15701: Add a .headers attribute to urllib.error.HTTPError. Patch - contributed by Berker Peksag. - -- Issue #15872: Fix 3.3 regression introduced by the new fd-based shutil.rmtree - that caused it to not ignore certain errors when ignore_errors was set. - Patch by Alessandro Moura and Serhiy Storchaka. - -- Issue #16248: Disable code execution from the user's home directory by - tkinter when the -E flag is passed to Python. Patch by Zachary Ware. - -- Issue #13390: New function :func:`sys.getallocatedblocks()` returns the - number of memory blocks currently allocated. - -- Issue #16628: Fix a memory leak in ctypes.resize(). - -- Issue #13614: Fix setup.py register failure with invalid rst in description. - Patch by Julien Courteau and Pierre Paul Lefebvre. - -- Issue #13512: Create ~/.pypirc securely (CVE-2011-4944). Initial patch by - Philip Jenvey, tested by Mageia and Debian. - -- Issue #7719: Make distutils ignore ``.nfs*`` files instead of choking later - on. Initial patch by SilentGhost and Jeff Ramnani. - -- Issue #13120: Allow calling pdb.set_trace() from thread. - Patch by Ilya Sandler. - -- Issue #16585: Make CJK encoders support error handlers that return bytes per - PEP 383. - -- Issue #10182: The re module doesn't truncate indices to 32 bits anymore. - Patch by Serhiy Storchaka. - -- Issue #16333: use (",", ": ") as default separator in json when indent is - specified, to avoid trailing whitespace. Patch by Serhiy Storchaka. - -- Issue #16573: In 2to3, treat enumerate() like a consuming call, so superfluous - list() calls aren't added to filter(), map(), and zip() which are directly - passed enumerate(). - -- Issue #16464: Reset the Content-Length header when a urllib Request is reused - with new data. - -- Issue #12848: The pure Python pickle implementation now treats object - lengths as unsigned 32-bit integers, like the C implementation does. - Patch by Serhiy Storchaka. - -- Issue #16423: urllib.request now has support for ``data:`` URLs. Patch by - Mathias Panzenböck. - -- Issue #4473: Add a POP3.stls() to switch a clear-text POP3 session into - an encrypted POP3 session, on supported servers. Patch by Lorenzo Catucci. - -- Issue #4473: Add a POP3.capa() method to query the capabilities advertised - by the POP3 server. Patch by Lorenzo Catucci. - -- Issue #4473: Ensure the socket is shutdown cleanly in POP3.close(). - Patch by Lorenzo Catucci. - -- Issue #16522: added FAIL_FAST flag to doctest. - -- Issue #15627: Add the importlib.abc.InspectLoader.source_to_code() method. - -- Issue #16408: Fix file descriptors not being closed in error conditions - in the zipfile module. Patch by Serhiy Storchaka. - -- Issue #14631: Add a new :class:`weakref.WeakMethod` to simulate weak - references to bound methods. - -- Issue #16469: Fix exceptions from float -> Fraction and Decimal -> Fraction - conversions for special values to be consistent with those for float -> int - and Decimal -> int. Patch by Alexey Kachayev. - -- Issue #16481: multiprocessing no longer leaks process handles on Windows. - -- Issue #12428: Add a pure Python implementation of functools.partial(). - Patch by Brian Thorne. - -- Issue #16140: The subprocess module no longer double closes its child - subprocess.PIPE parent file descriptors on child error prior to exec(). - -- Remove a bare print to stdout from the subprocess module that could have - happened if the child process wrote garbage to its pre-exec error pipe. - -- The subprocess module now raises its own SubprocessError instead of a - RuntimeError in various error situations which should not normally happen. - -- Issue #16327: The subprocess module no longer leaks file descriptors - used for stdin/stdout/stderr pipes to the child when fork() fails. - -- Issue #14396: Handle the odd rare case of waitpid returning 0 when not - expected in subprocess.Popen.wait(). - -- Issue #16411: Fix a bug where zlib.decompressobj().flush() might try to access - previously-freed memory. Patch by Serhiy Storchaka. - -- Issue #16357: fix calling accept() on a SSLSocket created through - SSLContext.wrap_socket(). Original patch by Jeff McNeil. - -- Issue #16409: The reporthook callback made by the legacy - urllib.request.urlretrieve API now properly supplies a constant non-zero - block_size as it did in Python 3.2 and 2.7. This matches the behavior of - urllib.request.URLopener.retrieve. - -- Issue #16431: Use the type information when constructing a Decimal subtype - from a Decimal argument. - -- Issue #15641: Clean up deprecated classes from importlib. - Patch by Taras Lyapun. - -- Issue #16350: zlib.decompressobj().decompress() now accumulates data from - successive calls after EOF in unused_data, instead of only saving the argument - to the last call. decompressobj().flush() now correctly sets unused_data and - unconsumed_tail. A bug in the handling of MemoryError when setting the - unconsumed_tail attribute has also been fixed. Patch by Serhiy Storchaka. - -- Issue #12759: sre_parse now raises a proper error when the name of the group - is missing. Initial patch by Serhiy Storchaka. - -- Issue #16152: fix tokenize to ignore whitespace at the end of the code when - no newline is found. Patch by Ned Batchelder. - -- Issue #16284: Prevent keeping unnecessary references to worker functions - in concurrent.futures ThreadPoolExecutor. - -- Issue #16230: Fix a crash in select.select() when one of the lists changes - size while iterated on. Patch by Serhiy Storchaka. - -- Issue #16228: Fix a crash in the json module where a list changes size - while it is being encoded. Patch by Serhiy Storchaka. - -- Issue #16351: New function gc.get_stats() returns per-generation collection - statistics. - -- Issue #14897: Enhance error messages of struct.pack and - struct.pack_into. Patch by Matti Mäki. - -- Issue #16316: mimetypes now recognizes the .xz and .txz (.tar.xz) extensions. - Patch by Serhiy Storchaka. - -- Issue #12890: cgitb no longer prints spurious <p> tags in text - mode when the logdir option is specified. - -- Issue #16307: Fix multiprocessing.Pool.map_async not calling its callbacks. - Patch by Janne Karila. - -- Issue #16305: Fix a segmentation fault occurring when interrupting - math.factorial. - -- Issue #16116: Fix include and library paths to be correct when building C - extensions in venvs. - -- Issue #16245: Fix the value of a few entities in html.entities.html5. - -- Issue #16301: Fix the localhost verification in urllib/request.py for ``file://`` - urls. - -- Issue #16250: Fix the invocations of URLError which had misplaced filename - attribute for exception. - -- Issue #10836: Fix exception raised when file not found in urlretrieve - Initial patch by Ezio Melotti. - -- Issue #14398: Fix size truncation and overflow bugs in the bz2 module. - -- Issue #12692: Fix resource leak in urllib.request when talking to an HTTP - server that does not include a ``Connection: close`` header in its responses. - -- Issue #12034: Fix bogus caching of result in check_GetFinalPathNameByHandle. - Patch by Atsuo Ishimoto. - -- Improve performance of `lzma.LZMAFile` (see also issue #16034). - -- Issue #16220: wsgiref now always calls close() on an iterable response. - Patch by Brent Tubbs. - -- Issue #16270: urllib may hang when used for retrieving files via FTP by using - a context manager. Patch by Giampaolo Rodola'. - -- Issue #16461: Wave library should be able to deal with 4GB wav files, - and sample rate of 44100 Hz. - -- Issue #16176: Properly identify Windows 8 via platform.platform() - -- Issue #16088: BaseHTTPRequestHandler's send_error method includes a - Content-Length header in its response now. Patch by Antoine Pitrou. - -- Issue #16114: The subprocess module no longer provides a misleading error - message stating that args[0] did not exist when either the cwd or executable - keyword arguments specified a path that did not exist. - -- Issue #16169: Fix ctypes.WinError()'s confusion between errno and winerror. - -- Issue #16110: logging.fileConfig now accepts a pre-initialised ConfigParser - instance. - -- Issue #1492704: shutil.copyfile() raises a distinct SameFileError now if - source and destination are the same file. Patch by Atsuo Ishimoto. - -- Issue #13896: Make shelf instances work with 'with' as context managers. - Original patch by Filip Gruszczyński. - -- Issue #15417: Add support for csh and fish in venv activation scripts. - -- Issue #14377: ElementTree.write and some of the module-level functions have - a new parameter - *short_empty_elements*. It controls how elements with no - contents are emitted. - -- Issue #16089: Allow ElementTree.TreeBuilder to work again with a non-Element - element_factory (fixes a regression in SimpleTAL). - -- Issue #9650: List commonly used format codes in time.strftime and - time.strptime docsttings. Original patch by Mike Hoy. - -- Issue #15452: logging configuration socket listener now has a verify option - that allows an application to apply a verification function to the - received configuration data before it is acted upon. - -- Issue #16034: Fix performance regressions in the new `bz2.BZ2File` - implementation. Initial patch by Serhiy Storchaka. - -- `pty.spawn()` now returns the child process status returned by `os.waitpid()`. - -- Issue #15756: `subprocess.poll()` now properly handles `errno.ECHILD` to - return a returncode of 0 when the child has already exited or cannot be waited - on. - -- Issue #15323: Improve failure message of `Mock.assert_called_once_with()`. - -- Issue #16064: ``unittest -m`` claims executable is "python", not "python3". - -- Issue #12376: Pass on parameters in `TextTestResult.__init__()` super call. - -- Issue #15222: Insert blank line after each message in mbox mailboxes. - -- Issue #16013: Fix `csv.Reader` parsing issue with ending quote characters. - Patch by Serhiy Storchaka. - -- Issue #15421: Fix an OverflowError in `Calendar.itermonthdates()` after - `datetime.MAXYEAR`. Patch by Cédric Krier. - -- Issue #16112: platform.architecture does not correctly escape argument to - /usr/bin/file. Patch by David Benjamin. - -- Issue #15970: `xml.etree.ElementTree` now serializes correctly the empty HTML - elements 'meta' and 'param'. - -- Issue #15842: The `SocketIO.{readable,writable,seekable}` methods now raise - ValueError when the file-like object is closed. Patch by Alessandro Moura. - -- Issue #15876: Fix a refleak in the `curses` module: window.encoding. - -- Issue #15881: Fix `atexit` hook in `multiprocessing`. Original patch by Chris - McDonough. - -- Issue #15841: The readable(), writable() and seekable() methods of - `io.BytesIO` and `io.StringIO` objects now raise ValueError when the object - has been closed. Patch by Alessandro Moura. - -- Issue #15447: Use `subprocess.DEVNULL` in webbrowser, instead of opening - `os.devnull` explicitly and leaving it open. - -- Issue #15509: `webbrowser.UnixBrowser` no longer passes empty arguments to - Popen when ``%action`` substitutions produce empty strings. - -- Issue #12776, issue #11839: Call `argparse` type function (specified by - add_argument) only once. Before, the type function was called twice in the - case where the default was specified and the argument was given as well. This - was especially problematic for the FileType type, as a default file would - always be opened, even if a file argument was specified on the command line. - -- Issue #15906: Fix a regression in argparse caused by the preceding change, - when ``action='append'``, ``type='str'`` and ``default=[]``. - -- Issue #16113: Added sha3 module based on the Keccak reference implementation - 3.2. The `hashlib` module has four additional hash algorithms: `sha3_224`, - `sha3_256`, `sha3_384` and `sha3_512`. As part of the patch some common - code was moved from _hashopenssl.c to hashlib.h. - -- ctypes.call_commethod was removed, since its only usage was in the defunct - samples directory. - -- Issue #16692: Added TLSv1.1 and TLSv1.2 support for the ssl modules. - -- Issue #16832: add abc.get_cache_token() to expose cache validity checking - support in ABCMeta. - -IDLE ----- - -- Issue #18429: Format / Format Paragraph, now works when comment blocks - are selected. As with text blocks, this works best when the selection - only includes complete lines. - -- Issue #18226: Add docstrings and unittests for FormatParagraph.py. - Original patches by Todd Rovito and Phil Webster. - -- Issue #18279: Format - Strip trailing whitespace no longer marks a file as - changed when it has not been changed. This fix followed the addition of a - test file originally written by Phil Webster (the issue's main goal). - -- Issue #7136: In the Idle File menu, "New Window" is renamed "New File". - Patch by Tal Einat, Roget Serwy, and Todd Rovito. - -- Remove dead imports of imp. - -- Issue #18196: Avoid displaying spurious SystemExit tracebacks. - -- Issue #5492: Avoid traceback when exiting IDLE caused by a race condition. - -- Issue #17511: Keep IDLE find dialog open after clicking "Find Next". - Original patch by Sarah K. - -- Issue #18055: Move IDLE off of imp and on to importlib. - -- Issue #15392: Create a unittest framework for IDLE. - Initial patch by Rajagopalasarma Jayakrishnan. - See Lib/idlelib/idle_test/README.txt for how to run Idle tests. - -- Issue #14146: Highlight source line while debugging on Windows. - -- Issue #17838: Allow sys.stdin to be reassigned. - -- Issue #13495: Avoid loading the color delegator twice in IDLE. - -- Issue #17798: Allow IDLE to edit new files when specified on command line. - -- Issue #14735: Update IDLE docs to omit "Control-z on Windows". - -- Issue #17532: Always include Options menu for IDLE on OS X. - Patch by Guilherme Simões. - -- Issue #17585: Fixed IDLE regression. Now closes when using exit() or quit(). - -- Issue #17657: Show full Tk version in IDLE's about dialog. - Patch by Todd Rovito. - -- Issue #17613: Prevent traceback when removing syntax colorizer in IDLE. - -- Issue #1207589: Backwards-compatibility patch for right-click menu in IDLE. - -- Issue #16887: IDLE now accepts Cancel in tabify/untabify dialog box. - -- Issue #17625: In IDLE, close the replace dialog after it is used. - -- Issue #14254: IDLE now handles readline correctly across shell restarts. - -- Issue #17614: IDLE no longer raises exception when quickly closing a file. - -- Issue #6698: IDLE now opens just an editor window when configured to do so. - -- Issue #8900: Using keyboard shortcuts in IDLE to open a file no longer - raises an exception. - -- Issue #6649: Fixed missing exit status in IDLE. Patch by Guilherme Polo. - -- Issue #17114: IDLE now uses non-strict config parser. - -- Issue #9290: In IDLE the sys.std* streams now implement io.TextIOBase - interface and support all mandatory methods and properties. - -- Issue #5066: Update IDLE docs. Patch by Todd Rovito. - -- Issue #16829: IDLE printing no longer fails if there are spaces or other - special characters in the file path. - -- Issue #16491: IDLE now prints chained exception tracebacks. - -- Issue #16819: IDLE method completion now correctly works for bytes literals. - -- Issue #16504: IDLE now catches SyntaxErrors raised by tokenizer. Patch by - Roger Serwy. - -- Issue #16511: Use default IDLE width and height if config param is not valid. - Patch Serhiy Storchaka. - -- Issue #1207589: Add Cut/Copy/Paste items to IDLE right click Context Menu. - Patch by Todd Rovito. - -- Issue #16123: IDLE - deprecate running without a subprocess. - Patch by Roger Serwy. - -Tests ------ - -- Issue #1666318: Add a test that shutil.copytree() retains directory - permissions. Patch by Catherine Devlin. - -- Issue #18273: move the tests in Lib/test/json_tests to Lib/test/test_json - and make them discoverable by unittest. Patch by Zachary Ware. - -- Fix a fcntl test case on KFreeBSD, Debian #708653 (Petr Salinger). - -- Issue #18396: Fix spurious test failure in test_signal on Windows when - faulthandler is enabled (Patch by Jeremy Kloth) - -- Issue #17046: Fix broken test_executable_without_cwd in test_subprocess. - -- Issue #15415: Add new temp_dir() and change_cwd() context managers to - test.support, and refactor temp_cwd() to use them. Patch by Chris Jerdonek. - -- Issue #15494: test.support is now a package rather than a module (Initial - patch by Indra Talip) - -- Issue #17944: test_zipfile now discoverable and uses subclassing to - generate tests for different compression types. Fixed a bug with skipping - some tests due to use of exhausted iterators. - -- Issue #18266: test_largefile now works with unittest test discovery and - supports running only selected tests. Patch by Zachary Ware. - -- Issue #17767: test_locale now works with unittest test discovery. - Original patch by Zachary Ware. - -- Issue #18375: Assume --randomize when --randseed is used for running the - testsuite. - -- Issue #11185: Fix test_wait4 under AIX. Patch by Sébastien Sablé. - -- Issue #18207: Fix test_ssl for some versions of OpenSSL that ignore seconds - in ASN1_TIME fields. - -- Issue #18094: test_uuid no longer reports skipped tests as passed. - -- Issue #17992: Add timeouts to asyncore and asynchat tests so that they won't - accidentally hang. - -- Issue #17833: Fix test_gdb failures seen on machines where debug symbols - for glibc are available (seen on PPC64 Linux). - -- Issue #7855: Add tests for ctypes/winreg for issues found in IronPython. - Initial patch by Dino Viehland. - -- Issue #11078: test___all__ now checks for duplicates in __all__. - Initial patch by R. David Murray. - -- Issue #17712: Fix test_gdb failures on Ubuntu 13.04. - -- Issue #17835: Fix test_io when the default OS pipe buffer size is larger - than one million bytes. - -- Issue #17065: Use process-unique key for winreg tests to avoid failures if - test is run multiple times in parallel (eg: on a buildbot host). - -- Issue #12820: add tests for the xml.dom.minicompat module. - Patch by John Chandler and Phil Connell. - -- Issue #17691: test_univnewlines now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17790: test_set now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17789: test_random now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17779: test_osx_env now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17766: test_iterlen now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17690: test_time now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17692: test_sqlite now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #11995: test_pydoc doesn't import all sys.path modules anymore. - -- Issue #17448: test_sax now skips if there are no xml parsers available - instead of raising an ImportError. - -- Issue #11420: make test suite pass with -B/DONTWRITEBYTECODE set. - Initial patch by Thomas Wouters. - -- Issue #10652: make tcl/tk tests run after __all__ test, patch by - Zachary Ware. - -- Issue #11963: remove human verification from test_parser and test_subprocess. - -- Issue #11732: add a new suppress_crash_popup() context manager to test.support - that disables crash popups on Windows and use it in test_faulthandler and - test_capi. - -- Issue #13898: test_ssl no longer prints a spurious stack trace on Ubuntu. - -- Issue #17283: Share code between `__main__.py` and `regrtest.py` in - `Lib/test`. - -- Issue #17249: convert a test in test_capi to use unittest and reap threads. - -- Issue #17107: Test client-side SNI support in urllib.request thanks to - the new server-side SNI support in the ssl module. Initial patch by - Daniel Black. - -- Issue #17041: Fix testing when Python is configured with the - --without-doc-strings. - -- Issue #16923: Fix ResourceWarnings in test_ssl. - -- Issue #15539: Added regression tests for Tools/scripts/pindent.py. - -- Issue #17479: test_io now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17066: test_robotparser now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17334: test_index now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17333: test_imaplib now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17082: test_dbm* now work with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17079: test_ctypes now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17304: test_hash now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17303: test_future* now work with unittest test discovery. - Patch by Zachary Ware. - -- Issue #17163: test_file now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16925: test_configparser now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16918: test_codecs now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16919: test_crypt now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16910: test_bytes, test_unicode, and test_userstring now work with - unittest test discovery. Patch by Zachary Ware. - -- Issue #16905: test_warnings now works with unittest test discovery. - Initial patch by Berker Peksag. - -- Issue #16898: test_bufio now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16888: test_array now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16896: test_asyncore now works with unittest test discovery. - Patch by Zachary Ware. - -- Issue #16897: test_bisect now works with unittest test discovery. - Initial patch by Zachary Ware. - -- Issue #16852: test_genericpath, test_posixpath, test_ntpath, and test_macpath - now work with unittest test discovery. Patch by Zachary Ware. - -- Issue #16748: test_heapq now works with unittest test discovery. - -- Issue #10646: Tests rearranged for os.samefile/samestat to check for not - just symlinks but also hard links. - -- Issue #15302: Switch regrtest from using getopt to using argparse. - -- Issue #15324: Fix regrtest parsing of --fromfile, --match, and --randomize - options. - -- Issue #16702: test_urllib2_localnet tests now correctly ignores proxies for - localhost tests. - -- Issue #16664: Add regression tests for glob's behaviour concerning entries - starting with a ".". Patch by Sebastian Kreft. - -- Issue #13390: The ``-R`` option to regrtest now also checks for memory - allocation leaks, using :func:`sys.getallocatedblocks()`. - -- Issue #16559: Add more tests for the json module, including some from the - official test suite at json.org. Patch by Serhiy Storchaka. - -- Issue #16661: Fix the `os.getgrouplist()` test by not assuming that it gives - the same output as :command:`id -G`. - -- Issue #16115: Add some tests for the executable argument to - subprocess.Popen(). Initial patch by Kushal Das. - -- Issue #16126: PyErr_Format format mismatch in _testcapimodule.c. - Patch by Serhiy Storchaka. - -- Issue #15304: Fix warning message when `os.chdir()` fails inside - `test.support.temp_cwd()`. Patch by Chris Jerdonek. - -- Issue #15802: Fix test logic in `TestMaildir.test_create_tmp()`. Patch by - Serhiy Storchaka. - -- Issue #15557: Added a test suite for the webbrowser module, thanks to Anton - Barkovsky. - -- Issue #16698: Skip posix test_getgroups when built with OS X - deployment target prior to 10.6. - -Build ------ - -- Issue #16067: Add description into MSI file to replace installer's - temporary name. - -- Issue #18257: Fix readlink usage in python-config. Install the python - version again on Darwin. - -- Issue #18481: Add C coverage reporting with gcov and lcov. A new make target - "coverage-report" creates an instrumented Python build, runs unit tests - and creates a HTML. The report can be updated with "make coverage-lcov". - -- Issue #17845: Clarified the message printed when some module are not built. - -- Issue #18256: Compilation fix for recent AIX releases. Patch by - David Edelsohn. - -- Issue #17547: In configure, explicitly pass -Wformat for the benefit for GCC - 4.8. - -- Issue #15172: Document NASM 2.10+ as requirement for building OpenSSL 1.0.1 - on Windows. - -- Issue #17591: Use lowercase filenames when including Windows header files. - Patch by Roumen Petrov. - -- Issue #17550: Fix the --enable-profiling configure switch. - -- Issue #17425: Build with openssl 1.0.1d on Windows. - -- Issue #16754: Fix the incorrect shared library extension on linux. Introduce - two makefile macros SHLIB_SUFFIX and EXT_SUFFIX. SO now has the value of - SHLIB_SUFFIX again (as in 2.x and 3.1). The SO macro is removed in 3.4. - -- Issue #5033: Fix building of the sqlite3 extension module when the - SQLite library version has "beta" in it. Patch by Andreas Pelme. - -- Issue #17228: Fix building without pymalloc. - -- Issue #3718: Use AC_ARG_VAR to set MACHDEP in configure.ac. - -- Issue #16235: Implement python-config as a shell script. - -- Issue #16769: Remove outdated Visual Studio projects. - -- Issue #17031: Fix running regen in cross builds. - -- Issue #3754: fix typo in pthread AC_CACHE_VAL. - -- Issue #15484: Fix _PYTHON_PROJECT_BASE for srcdir != builddir builds; - use _PYTHON_PROJECT_BASE in distutils/sysconfig.py. - -- Drop support for Windows 2000 (changeset e52df05b496a). - -- Issue #17029: Let h2py search the multiarch system include directory. - -- Issue #16953: Fix socket module compilation on platforms with - HAVE_BROKEN_POLL. Patch by Jeffrey Armstrong. - -- Issue #16320: Remove redundant Makefile dependencies for strings and bytes. - -- Cross compiling needs host and build settings. configure no longer - creates a broken PYTHON_FOR_BUILD variable when --build is missing. - -- Fix cross compiling issue in setup.py, ensure that lib_dirs and inc_dirs are - defined in cross compiling mode, too. - -- Issue #16836: Enable IPv6 support even if IPv6 is disabled on the build host. - -- Issue #16593: Have BSD 'make -s' do the right thing, thanks to Daniel Shahaf - -- Issue #16262: fix out-of-src-tree builds, if mercurial is not installed. - -- Issue #15298: ensure _sysconfigdata is generated in build directory, not - source directory. - -- Issue #15833: Fix a regression in 3.3 that resulted in exceptions being - raised if importlib failed to write byte-compiled files. This affected - attempts to build Python out-of-tree from a read-only source directory. - -- Issue #15923: Fix a mistake in ``asdl_c.py`` that resulted in a TypeError - after 2801bf875a24 (see #15801). - -- Issue #16135: Remove OS/2 support. - -- Issue #15819: Make sure we can build Python out-of-tree from a read-only - source directory. (Somewhat related to issue #9860.) - -- Issue #15587: Enable Tk high-resolution text rendering on Macs with - Retina displays. Applies to Tkinter apps, such as IDLE, on OS X - framework builds linked with Cocoa Tk 8.5. - -- Issue #17161: make install now also installs a python3 man page. - -C-API ------ - -- Issue #18351: Fix various issues in a function in importlib provided to help - PyImport_ExecCodeModuleWithPathnames() (and thus by extension - PyImport_ExecCodeModule() and PyImport_ExecCodeModuleEx()). - -- Issue #15767: Added PyErr_SetImportErrorSubclass(). - -- PyErr_SetImportError() now sets TypeError when its msg argument is set. - -- Issue #9369: The types of `char*` arguments of PyObject_CallFunction() and - PyObject_CallMethod() now changed to `const char*`. Based on patches by - Jörg Müller and Lars Buitinck. - -- Issue #17206: Py_CLEAR(), Py_DECREF(), Py_XINCREF() and Py_XDECREF() now - expand their arguments once instead of multiple times. Patch written by Illia - Polosukhin. - -- Issue #17522: Add the PyGILState_Check() API. - -- Issue #17327: Add PyDict_SetDefault. - -- Issue #16881: Fix Py_ARRAY_LENGTH macro for GCC < 3.1. - -- Issue #16505: Remove unused Py_TPFLAGS_INT_SUBCLASS. - -- Issue #16086: PyTypeObject.tp_flags and PyType_Spec.flags are now unsigned - (unsigned long and unsigned int) to avoid an undefined behaviour with - Py_TPFLAGS_TYPE_SUBCLASS ((1 << 31). PyType_GetFlags() result type is - now unsigned too (unsigned long, instead of long). - -- Issue #16166: Add PY_LITTLE_ENDIAN and PY_BIG_ENDIAN macros and unified - endianness detection and handling. - -Documentation -------------- - -- Issue #23006: Improve the documentation and indexing of dict.__missing__. - Add an entry in the language datamodel special methods section. - Revise and index its discussion in the stdtypes mapping/dict section. - -- Issue #17701: Improving strftime documentation. - -- Issue #18440: Clarify that `hash()` can truncate the value returned from an - object's custom `__hash__()` method. - -- Issue #17844: Add links to encoders and decoders for bytes-to-bytes codecs. - -- Issue #14097: improve the "introduction" page of the tutorial. - -- Issue #17977: The documentation for the cadefault argument's default value - in urllib.request.urlopen() is fixed to match the code. - -- Issue #6696: add documentation for the Profile objects, and improve - profile/cProfile docs. Patch by Tom Pinckney. - -- Issue #15940: Specify effect of locale on time functions. - -- Issue #17538: Document XML vulnerabilties - -- Issue #16642: sched.scheduler timefunc initial default is time.monotonic. - Patch by Ramchandra Apte - -- Issue #17047: remove doubled words in docs and docstrings - reported by Serhiy Storchaka and Matthew Barnett. - -- Issue #15465: Document the versioning macros in the C API docs rather than - the standard library docs. Patch by Kushal Das. - -- Issue #16406: Combine the pages for uploading and registering to PyPI. - -- Issue #16403: Document how distutils uses the maintainer field in - PKG-INFO. Patch by Jyrki Pulliainen. - -- Issue #16695: Document how glob handles filenames starting with a - dot. Initial patch by Jyrki Pulliainen. - -- Issue #8890: Stop advertising an insecure practice by replacing uses - of the /tmp directory with better alternatives in the documentation. - Patch by Geoff Wilson. - -- Issue #17203: add long option names to unittest discovery docs. - -- Issue #13094: add "Why do lambdas defined in a loop with different values - all return the same result?" programming FAQ. - -- Issue #14901: Update portions of the Windows FAQ. - Patch by Ashish Nitin Patil. - -- Issue #16267: Better document the 3.3+ approach to combining - @abstractmethod with @staticmethod, @classmethod and @property - -- Issue #15209: Clarify exception chaining description in exceptions module - documentation - -- Issue #15990: Improve argument/parameter documentation. - -- Issue #16209: Move the documentation for the str built-in function to a new - str class entry in the "Text Sequence Type" section. - -- Issue #13538: Improve str() and object.__str__() documentation. - -- Issue #16489: Make it clearer that importlib.find_loader() needs parent - packages to be explicitly imported. - -- Issue #16400: Update the description of which versions of a given package - PyPI displays. - -- Issue #15677: Document that zlib and gzip accept a compression level of 0 to - mean 'no compression'. Patch by Brian Brazil. - -- Issue #16197: Update winreg docstrings and documentation to match code. - Patch by Zachary Ware. - -- Issue #8040: added a version switcher to the documentation. Patch by - Yury Selivanov. - -- Issue #16241: Document -X faulthandler command line option. - Patch by Marek Šuppa. - -- Additional comments and some style changes in the concurrent.futures URL - retrieval example - -- Issue #16115: Improve subprocess.Popen() documentation around args, shell, - and executable arguments. - -- Issue #13498: Clarify docs of os.makedirs()'s exist_ok argument. Done with - great native-speaker help from R. David Murray. - -- Issue #15533: Clarify docs and add tests for `subprocess.Popen()`'s cwd - argument. - -- Issue #15979: Improve timeit documentation. - -- Issue #16036: Improve documentation of built-in `int()`'s signature and - arguments. - -- Issue #15935: Clarification of `argparse` docs, re: add_argument() type and - default arguments. Patch contributed by Chris Jerdonek. - -- Issue #11964: Document a change in v3.2 to the behavior of the indent - parameter of json encoding operations. - -- Issue #15116: Remove references to appscript as it is no longer being - supported. - -Tools/Demos ------------ - -- Issue #18817: Fix a resource warning in Lib/aifc.py demo. Patch by - Vajrasky Kok. - -- Issue #18439: Make patchcheck work on Windows for ACKS, NEWS. - -- Issue #18448: Fix a typo in Tools/demo/eiffel.py. - -- Issue #18457: Fixed saving of formulas and complex numbers in - Tools/demo/ss1.py. - -- Issue #18449: Make Tools/demo/ss1.py work again on Python 3. Patch by - Févry Thibault. - -- Issue #12990: The "Python Launcher" on OSX could not launch python scripts - that have paths that include wide characters. - -- Issue #15239: Make mkstringprep.py work again on Python 3. - -- Issue #17028: Allowed Python arguments to be supplied to the Windows - launcher. - -- Issue #17156: pygettext.py now detects the encoding of source files and - correctly writes and escapes non-ascii characters. - -- Issue #15539: Fix a number of bugs in Tools/scripts/pindent.py. Now - pindent.py works with a "with" statement. pindent.py no longer produces - improper indentation. pindent.py now works with continued lines broken after - "class" or "def" keywords and with continuations at the start of line. - -- Issue #11797: Add a 2to3 fixer that maps reload() to imp.reload(). - -- Issue #10966: Remove the concept of unexpected skipped tests. - -- Issue #9893: Removed the Misc/Vim directory. - -- Removed the Misc/TextMate directory. - -- Issue #16245: Add the Tools/scripts/parse_html5_entities.py script to parse - the list of HTML5 entities and update the html.entities.html5 dictionary. - -- Issue #15378: Fix Tools/unicode/comparecodecs.py. Patch by Serhiy Storchaka. - -- Issue #16549: Make json.tool work again on Python 3 and add tests. - Initial patch by Berker Peksag and Serhiy Storchaka. - -- Issue #13301: use ast.literal_eval() instead of eval() in Tools/i18n/msgfmt.py. - Patch by Serhiy Storchaka. - -Windows -------- - -- Issue #18569: The installer now adds .py to the PATHEXT variable when extensions - are registered. Patch by Paul Moore. **(For information about older versions, consult the HISTORY file.)** diff --git a/PC/pyconfig.h b/PC/pyconfig.h index 64e7aec..a4df5c4 100644 --- a/PC/pyconfig.h +++ b/PC/pyconfig.h @@ -290,11 +290,11 @@ Py_NO_ENABLE_SHARED to find out. Also support MS_NO_COREDLL for b/w compat */ their Makefile (other compilers are generally taken care of by distutils.) */ # if defined(_DEBUG) -# pragma comment(lib,"python36_d.lib") +# pragma comment(lib,"python37_d.lib") # elif defined(Py_LIMITED_API) # pragma comment(lib,"python3.lib") # else -# pragma comment(lib,"python36.lib") +# pragma comment(lib,"python37.lib") # endif /* _DEBUG */ # endif /* _MSC_VER */ # endif /* Py_BUILD_CORE */ diff --git a/PC/python3.def b/PC/python3.def index e8d2d8c..e687a72 100644 --- a/PC/python3.def +++ b/PC/python3.def @@ -2,713 +2,713 @@ ; It is used when building python3dll.vcxproj LIBRARY "python3" EXPORTS - PyArg_Parse=python36.PyArg_Parse - PyArg_ParseTuple=python36.PyArg_ParseTuple - PyArg_ParseTupleAndKeywords=python36.PyArg_ParseTupleAndKeywords - PyArg_UnpackTuple=python36.PyArg_UnpackTuple - PyArg_VaParse=python36.PyArg_VaParse - PyArg_VaParseTupleAndKeywords=python36.PyArg_VaParseTupleAndKeywords - PyArg_ValidateKeywordArguments=python36.PyArg_ValidateKeywordArguments - PyBaseObject_Type=python36.PyBaseObject_Type DATA - PyBool_FromLong=python36.PyBool_FromLong - PyBool_Type=python36.PyBool_Type DATA - PyByteArrayIter_Type=python36.PyByteArrayIter_Type DATA - PyByteArray_AsString=python36.PyByteArray_AsString - PyByteArray_Concat=python36.PyByteArray_Concat - PyByteArray_FromObject=python36.PyByteArray_FromObject - PyByteArray_FromStringAndSize=python36.PyByteArray_FromStringAndSize - PyByteArray_Resize=python36.PyByteArray_Resize - PyByteArray_Size=python36.PyByteArray_Size - PyByteArray_Type=python36.PyByteArray_Type DATA - PyBytesIter_Type=python36.PyBytesIter_Type DATA - PyBytes_AsString=python36.PyBytes_AsString - PyBytes_AsStringAndSize=python36.PyBytes_AsStringAndSize - PyBytes_Concat=python36.PyBytes_Concat - PyBytes_ConcatAndDel=python36.PyBytes_ConcatAndDel - PyBytes_DecodeEscape=python36.PyBytes_DecodeEscape - PyBytes_FromFormat=python36.PyBytes_FromFormat - PyBytes_FromFormatV=python36.PyBytes_FromFormatV - PyBytes_FromObject=python36.PyBytes_FromObject - PyBytes_FromString=python36.PyBytes_FromString - PyBytes_FromStringAndSize=python36.PyBytes_FromStringAndSize - PyBytes_Repr=python36.PyBytes_Repr - PyBytes_Size=python36.PyBytes_Size - PyBytes_Type=python36.PyBytes_Type DATA - PyCFunction_Call=python36.PyCFunction_Call - PyCFunction_ClearFreeList=python36.PyCFunction_ClearFreeList - PyCFunction_GetFlags=python36.PyCFunction_GetFlags - PyCFunction_GetFunction=python36.PyCFunction_GetFunction - PyCFunction_GetSelf=python36.PyCFunction_GetSelf - PyCFunction_New=python36.PyCFunction_New - PyCFunction_NewEx=python36.PyCFunction_NewEx - PyCFunction_Type=python36.PyCFunction_Type DATA - PyCallIter_New=python36.PyCallIter_New - PyCallIter_Type=python36.PyCallIter_Type DATA - PyCallable_Check=python36.PyCallable_Check - PyCapsule_GetContext=python36.PyCapsule_GetContext - PyCapsule_GetDestructor=python36.PyCapsule_GetDestructor - PyCapsule_GetName=python36.PyCapsule_GetName - PyCapsule_GetPointer=python36.PyCapsule_GetPointer - PyCapsule_Import=python36.PyCapsule_Import - PyCapsule_IsValid=python36.PyCapsule_IsValid - PyCapsule_New=python36.PyCapsule_New - PyCapsule_SetContext=python36.PyCapsule_SetContext - PyCapsule_SetDestructor=python36.PyCapsule_SetDestructor - PyCapsule_SetName=python36.PyCapsule_SetName - PyCapsule_SetPointer=python36.PyCapsule_SetPointer - PyCapsule_Type=python36.PyCapsule_Type DATA - PyClassMethodDescr_Type=python36.PyClassMethodDescr_Type DATA - PyCodec_BackslashReplaceErrors=python36.PyCodec_BackslashReplaceErrors - PyCodec_Decode=python36.PyCodec_Decode - PyCodec_Decoder=python36.PyCodec_Decoder - PyCodec_Encode=python36.PyCodec_Encode - PyCodec_Encoder=python36.PyCodec_Encoder - PyCodec_IgnoreErrors=python36.PyCodec_IgnoreErrors - PyCodec_IncrementalDecoder=python36.PyCodec_IncrementalDecoder - PyCodec_IncrementalEncoder=python36.PyCodec_IncrementalEncoder - PyCodec_KnownEncoding=python36.PyCodec_KnownEncoding - PyCodec_LookupError=python36.PyCodec_LookupError - PyCodec_Register=python36.PyCodec_Register - PyCodec_RegisterError=python36.PyCodec_RegisterError - PyCodec_ReplaceErrors=python36.PyCodec_ReplaceErrors - PyCodec_StreamReader=python36.PyCodec_StreamReader - PyCodec_StreamWriter=python36.PyCodec_StreamWriter - PyCodec_StrictErrors=python36.PyCodec_StrictErrors - PyCodec_XMLCharRefReplaceErrors=python36.PyCodec_XMLCharRefReplaceErrors - PyComplex_FromDoubles=python36.PyComplex_FromDoubles - PyComplex_ImagAsDouble=python36.PyComplex_ImagAsDouble - PyComplex_RealAsDouble=python36.PyComplex_RealAsDouble - PyComplex_Type=python36.PyComplex_Type DATA - PyDescr_NewClassMethod=python36.PyDescr_NewClassMethod - PyDescr_NewGetSet=python36.PyDescr_NewGetSet - PyDescr_NewMember=python36.PyDescr_NewMember - PyDescr_NewMethod=python36.PyDescr_NewMethod - PyDictItems_Type=python36.PyDictItems_Type DATA - PyDictIterItem_Type=python36.PyDictIterItem_Type DATA - PyDictIterKey_Type=python36.PyDictIterKey_Type DATA - PyDictIterValue_Type=python36.PyDictIterValue_Type DATA - PyDictKeys_Type=python36.PyDictKeys_Type DATA - PyDictProxy_New=python36.PyDictProxy_New - PyDictProxy_Type=python36.PyDictProxy_Type DATA - PyDictValues_Type=python36.PyDictValues_Type DATA - PyDict_Clear=python36.PyDict_Clear - PyDict_Contains=python36.PyDict_Contains - PyDict_Copy=python36.PyDict_Copy - PyDict_DelItem=python36.PyDict_DelItem - PyDict_DelItemString=python36.PyDict_DelItemString - PyDict_GetItem=python36.PyDict_GetItem - PyDict_GetItemString=python36.PyDict_GetItemString - PyDict_GetItemWithError=python36.PyDict_GetItemWithError - PyDict_Items=python36.PyDict_Items - PyDict_Keys=python36.PyDict_Keys - PyDict_Merge=python36.PyDict_Merge - PyDict_MergeFromSeq2=python36.PyDict_MergeFromSeq2 - PyDict_New=python36.PyDict_New - PyDict_Next=python36.PyDict_Next - PyDict_SetItem=python36.PyDict_SetItem - PyDict_SetItemString=python36.PyDict_SetItemString - PyDict_Size=python36.PyDict_Size - PyDict_Type=python36.PyDict_Type DATA - PyDict_Update=python36.PyDict_Update - PyDict_Values=python36.PyDict_Values - PyEllipsis_Type=python36.PyEllipsis_Type DATA - PyEnum_Type=python36.PyEnum_Type DATA - PyErr_BadArgument=python36.PyErr_BadArgument - PyErr_BadInternalCall=python36.PyErr_BadInternalCall - PyErr_CheckSignals=python36.PyErr_CheckSignals - PyErr_Clear=python36.PyErr_Clear - PyErr_Display=python36.PyErr_Display - PyErr_ExceptionMatches=python36.PyErr_ExceptionMatches - PyErr_Fetch=python36.PyErr_Fetch - PyErr_Format=python36.PyErr_Format - PyErr_FormatV=python36.PyErr_FormatV - PyErr_GivenExceptionMatches=python36.PyErr_GivenExceptionMatches - PyErr_NewException=python36.PyErr_NewException - PyErr_NewExceptionWithDoc=python36.PyErr_NewExceptionWithDoc - PyErr_NoMemory=python36.PyErr_NoMemory - PyErr_NormalizeException=python36.PyErr_NormalizeException - PyErr_Occurred=python36.PyErr_Occurred - PyErr_Print=python36.PyErr_Print - PyErr_PrintEx=python36.PyErr_PrintEx - PyErr_ProgramText=python36.PyErr_ProgramText - PyErr_Restore=python36.PyErr_Restore - PyErr_SetFromErrno=python36.PyErr_SetFromErrno - PyErr_SetFromErrnoWithFilename=python36.PyErr_SetFromErrnoWithFilename - PyErr_SetFromErrnoWithFilenameObject=python36.PyErr_SetFromErrnoWithFilenameObject - PyErr_SetInterrupt=python36.PyErr_SetInterrupt - PyErr_SetNone=python36.PyErr_SetNone - PyErr_SetObject=python36.PyErr_SetObject - PyErr_SetString=python36.PyErr_SetString - PyErr_SyntaxLocation=python36.PyErr_SyntaxLocation - PyErr_WarnEx=python36.PyErr_WarnEx - PyErr_WarnExplicit=python36.PyErr_WarnExplicit - PyErr_WarnFormat=python36.PyErr_WarnFormat - PyErr_WriteUnraisable=python36.PyErr_WriteUnraisable - PyEval_AcquireLock=python36.PyEval_AcquireLock - PyEval_AcquireThread=python36.PyEval_AcquireThread - PyEval_CallFunction=python36.PyEval_CallFunction - PyEval_CallMethod=python36.PyEval_CallMethod - PyEval_CallObjectWithKeywords=python36.PyEval_CallObjectWithKeywords - PyEval_EvalCode=python36.PyEval_EvalCode - PyEval_EvalCodeEx=python36.PyEval_EvalCodeEx - PyEval_EvalFrame=python36.PyEval_EvalFrame - PyEval_EvalFrameEx=python36.PyEval_EvalFrameEx - PyEval_GetBuiltins=python36.PyEval_GetBuiltins - PyEval_GetCallStats=python36.PyEval_GetCallStats - PyEval_GetFrame=python36.PyEval_GetFrame - PyEval_GetFuncDesc=python36.PyEval_GetFuncDesc - PyEval_GetFuncName=python36.PyEval_GetFuncName - PyEval_GetGlobals=python36.PyEval_GetGlobals - PyEval_GetLocals=python36.PyEval_GetLocals - PyEval_InitThreads=python36.PyEval_InitThreads - PyEval_ReInitThreads=python36.PyEval_ReInitThreads - PyEval_ReleaseLock=python36.PyEval_ReleaseLock - PyEval_ReleaseThread=python36.PyEval_ReleaseThread - PyEval_RestoreThread=python36.PyEval_RestoreThread - PyEval_SaveThread=python36.PyEval_SaveThread - PyEval_ThreadsInitialized=python36.PyEval_ThreadsInitialized - PyExc_ArithmeticError=python36.PyExc_ArithmeticError DATA - PyExc_AssertionError=python36.PyExc_AssertionError DATA - PyExc_AttributeError=python36.PyExc_AttributeError DATA - PyExc_BaseException=python36.PyExc_BaseException DATA - PyExc_BufferError=python36.PyExc_BufferError DATA - PyExc_BytesWarning=python36.PyExc_BytesWarning DATA - PyExc_DeprecationWarning=python36.PyExc_DeprecationWarning DATA - PyExc_EOFError=python36.PyExc_EOFError DATA - PyExc_EnvironmentError=python36.PyExc_EnvironmentError DATA - PyExc_Exception=python36.PyExc_Exception DATA - PyExc_FloatingPointError=python36.PyExc_FloatingPointError DATA - PyExc_FutureWarning=python36.PyExc_FutureWarning DATA - PyExc_GeneratorExit=python36.PyExc_GeneratorExit DATA - PyExc_IOError=python36.PyExc_IOError DATA - PyExc_ImportError=python36.PyExc_ImportError DATA - PyExc_ImportWarning=python36.PyExc_ImportWarning DATA - PyExc_IndentationError=python36.PyExc_IndentationError DATA - PyExc_IndexError=python36.PyExc_IndexError DATA - PyExc_KeyError=python36.PyExc_KeyError DATA - PyExc_KeyboardInterrupt=python36.PyExc_KeyboardInterrupt DATA - PyExc_LookupError=python36.PyExc_LookupError DATA - PyExc_MemoryError=python36.PyExc_MemoryError DATA - PyExc_MemoryErrorInst=python36.PyExc_MemoryErrorInst DATA - PyExc_NameError=python36.PyExc_NameError DATA - PyExc_NotImplementedError=python36.PyExc_NotImplementedError DATA - PyExc_OSError=python36.PyExc_OSError DATA - PyExc_OverflowError=python36.PyExc_OverflowError DATA - PyExc_PendingDeprecationWarning=python36.PyExc_PendingDeprecationWarning DATA - PyExc_RecursionErrorInst=python36.PyExc_RecursionErrorInst DATA - PyExc_ReferenceError=python36.PyExc_ReferenceError DATA - PyExc_RuntimeError=python36.PyExc_RuntimeError DATA - PyExc_RuntimeWarning=python36.PyExc_RuntimeWarning DATA - PyExc_StopIteration=python36.PyExc_StopIteration DATA - PyExc_SyntaxError=python36.PyExc_SyntaxError DATA - PyExc_SyntaxWarning=python36.PyExc_SyntaxWarning DATA - PyExc_SystemError=python36.PyExc_SystemError DATA - PyExc_SystemExit=python36.PyExc_SystemExit DATA - PyExc_TabError=python36.PyExc_TabError DATA - PyExc_TypeError=python36.PyExc_TypeError DATA - PyExc_UnboundLocalError=python36.PyExc_UnboundLocalError DATA - PyExc_UnicodeDecodeError=python36.PyExc_UnicodeDecodeError DATA - PyExc_UnicodeEncodeError=python36.PyExc_UnicodeEncodeError DATA - PyExc_UnicodeError=python36.PyExc_UnicodeError DATA - PyExc_UnicodeTranslateError=python36.PyExc_UnicodeTranslateError DATA - PyExc_UnicodeWarning=python36.PyExc_UnicodeWarning DATA - PyExc_UserWarning=python36.PyExc_UserWarning DATA - PyExc_ValueError=python36.PyExc_ValueError DATA - PyExc_Warning=python36.PyExc_Warning DATA - PyExc_ZeroDivisionError=python36.PyExc_ZeroDivisionError DATA - PyException_GetCause=python36.PyException_GetCause - PyException_GetContext=python36.PyException_GetContext - PyException_GetTraceback=python36.PyException_GetTraceback - PyException_SetCause=python36.PyException_SetCause - PyException_SetContext=python36.PyException_SetContext - PyException_SetTraceback=python36.PyException_SetTraceback - PyFile_FromFd=python36.PyFile_FromFd - PyFile_GetLine=python36.PyFile_GetLine - PyFile_WriteObject=python36.PyFile_WriteObject - PyFile_WriteString=python36.PyFile_WriteString - PyFilter_Type=python36.PyFilter_Type DATA - PyFloat_AsDouble=python36.PyFloat_AsDouble - PyFloat_FromDouble=python36.PyFloat_FromDouble - PyFloat_FromString=python36.PyFloat_FromString - PyFloat_GetInfo=python36.PyFloat_GetInfo - PyFloat_GetMax=python36.PyFloat_GetMax - PyFloat_GetMin=python36.PyFloat_GetMin - PyFloat_Type=python36.PyFloat_Type DATA - PyFrozenSet_New=python36.PyFrozenSet_New - PyFrozenSet_Type=python36.PyFrozenSet_Type DATA - PyGC_Collect=python36.PyGC_Collect - PyGILState_Ensure=python36.PyGILState_Ensure - PyGILState_GetThisThreadState=python36.PyGILState_GetThisThreadState - PyGILState_Release=python36.PyGILState_Release - PyGetSetDescr_Type=python36.PyGetSetDescr_Type DATA - PyImport_AddModule=python36.PyImport_AddModule - PyImport_AppendInittab=python36.PyImport_AppendInittab - PyImport_Cleanup=python36.PyImport_Cleanup - PyImport_ExecCodeModule=python36.PyImport_ExecCodeModule - PyImport_ExecCodeModuleEx=python36.PyImport_ExecCodeModuleEx - PyImport_ExecCodeModuleWithPathnames=python36.PyImport_ExecCodeModuleWithPathnames - PyImport_GetImporter=python36.PyImport_GetImporter - PyImport_GetMagicNumber=python36.PyImport_GetMagicNumber - PyImport_GetMagicTag=python36.PyImport_GetMagicTag - PyImport_GetModuleDict=python36.PyImport_GetModuleDict - PyImport_Import=python36.PyImport_Import - PyImport_ImportFrozenModule=python36.PyImport_ImportFrozenModule - PyImport_ImportModule=python36.PyImport_ImportModule - PyImport_ImportModuleLevel=python36.PyImport_ImportModuleLevel - PyImport_ImportModuleNoBlock=python36.PyImport_ImportModuleNoBlock - PyImport_ReloadModule=python36.PyImport_ReloadModule - PyInterpreterState_Clear=python36.PyInterpreterState_Clear - PyInterpreterState_Delete=python36.PyInterpreterState_Delete - PyInterpreterState_New=python36.PyInterpreterState_New - PyIter_Next=python36.PyIter_Next - PyListIter_Type=python36.PyListIter_Type DATA - PyListRevIter_Type=python36.PyListRevIter_Type DATA - PyList_Append=python36.PyList_Append - PyList_AsTuple=python36.PyList_AsTuple - PyList_GetItem=python36.PyList_GetItem - PyList_GetSlice=python36.PyList_GetSlice - PyList_Insert=python36.PyList_Insert - PyList_New=python36.PyList_New - PyList_Reverse=python36.PyList_Reverse - PyList_SetItem=python36.PyList_SetItem - PyList_SetSlice=python36.PyList_SetSlice - PyList_Size=python36.PyList_Size - PyList_Sort=python36.PyList_Sort - PyList_Type=python36.PyList_Type DATA - PyLongRangeIter_Type=python36.PyLongRangeIter_Type DATA - PyLong_AsDouble=python36.PyLong_AsDouble - PyLong_AsLong=python36.PyLong_AsLong - PyLong_AsLongAndOverflow=python36.PyLong_AsLongAndOverflow - PyLong_AsLongLong=python36.PyLong_AsLongLong - PyLong_AsLongLongAndOverflow=python36.PyLong_AsLongLongAndOverflow - PyLong_AsSize_t=python36.PyLong_AsSize_t - PyLong_AsSsize_t=python36.PyLong_AsSsize_t - PyLong_AsUnsignedLong=python36.PyLong_AsUnsignedLong - PyLong_AsUnsignedLongLong=python36.PyLong_AsUnsignedLongLong - PyLong_AsUnsignedLongLongMask=python36.PyLong_AsUnsignedLongLongMask - PyLong_AsUnsignedLongMask=python36.PyLong_AsUnsignedLongMask - PyLong_AsVoidPtr=python36.PyLong_AsVoidPtr - PyLong_FromDouble=python36.PyLong_FromDouble - PyLong_FromLong=python36.PyLong_FromLong - PyLong_FromLongLong=python36.PyLong_FromLongLong - PyLong_FromSize_t=python36.PyLong_FromSize_t - PyLong_FromSsize_t=python36.PyLong_FromSsize_t - PyLong_FromString=python36.PyLong_FromString - PyLong_FromUnsignedLong=python36.PyLong_FromUnsignedLong - PyLong_FromUnsignedLongLong=python36.PyLong_FromUnsignedLongLong - PyLong_FromVoidPtr=python36.PyLong_FromVoidPtr - PyLong_GetInfo=python36.PyLong_GetInfo - PyLong_Type=python36.PyLong_Type DATA - PyMap_Type=python36.PyMap_Type DATA - PyMapping_Check=python36.PyMapping_Check - PyMapping_GetItemString=python36.PyMapping_GetItemString - PyMapping_HasKey=python36.PyMapping_HasKey - PyMapping_HasKeyString=python36.PyMapping_HasKeyString - PyMapping_Items=python36.PyMapping_Items - PyMapping_Keys=python36.PyMapping_Keys - PyMapping_Length=python36.PyMapping_Length - PyMapping_SetItemString=python36.PyMapping_SetItemString - PyMapping_Size=python36.PyMapping_Size - PyMapping_Values=python36.PyMapping_Values - PyMem_Free=python36.PyMem_Free - PyMem_Malloc=python36.PyMem_Malloc - PyMem_Realloc=python36.PyMem_Realloc - PyMemberDescr_Type=python36.PyMemberDescr_Type DATA - PyMemoryView_FromObject=python36.PyMemoryView_FromObject - PyMemoryView_GetContiguous=python36.PyMemoryView_GetContiguous - PyMemoryView_Type=python36.PyMemoryView_Type DATA - PyMethodDescr_Type=python36.PyMethodDescr_Type DATA - PyModule_AddIntConstant=python36.PyModule_AddIntConstant - PyModule_AddObject=python36.PyModule_AddObject - PyModule_AddStringConstant=python36.PyModule_AddStringConstant - PyModule_Create2=python36.PyModule_Create2 - PyModule_GetDef=python36.PyModule_GetDef - PyModule_GetDict=python36.PyModule_GetDict - PyModule_GetFilename=python36.PyModule_GetFilename - PyModule_GetFilenameObject=python36.PyModule_GetFilenameObject - PyModule_GetName=python36.PyModule_GetName - PyModule_GetState=python36.PyModule_GetState - PyModule_New=python36.PyModule_New - PyModule_Type=python36.PyModule_Type DATA - PyModuleDef_Init=python36.PyModuleDef_Init - PyModuleDef_Type=python36.PyModuleDef_Type DATA - PyNullImporter_Type=python36.PyNullImporter_Type DATA - PyNumber_Absolute=python36.PyNumber_Absolute - PyNumber_Add=python36.PyNumber_Add - PyNumber_And=python36.PyNumber_And - PyNumber_AsSsize_t=python36.PyNumber_AsSsize_t - PyNumber_Check=python36.PyNumber_Check - PyNumber_Divmod=python36.PyNumber_Divmod - PyNumber_Float=python36.PyNumber_Float - PyNumber_FloorDivide=python36.PyNumber_FloorDivide - PyNumber_InPlaceAdd=python36.PyNumber_InPlaceAdd - PyNumber_InPlaceAnd=python36.PyNumber_InPlaceAnd - PyNumber_InPlaceFloorDivide=python36.PyNumber_InPlaceFloorDivide - PyNumber_InPlaceLshift=python36.PyNumber_InPlaceLshift - PyNumber_InPlaceMultiply=python36.PyNumber_InPlaceMultiply - PyNumber_InPlaceOr=python36.PyNumber_InPlaceOr - PyNumber_InPlacePower=python36.PyNumber_InPlacePower - PyNumber_InPlaceRemainder=python36.PyNumber_InPlaceRemainder - PyNumber_InPlaceRshift=python36.PyNumber_InPlaceRshift - PyNumber_InPlaceSubtract=python36.PyNumber_InPlaceSubtract - PyNumber_InPlaceTrueDivide=python36.PyNumber_InPlaceTrueDivide - PyNumber_InPlaceXor=python36.PyNumber_InPlaceXor - PyNumber_Index=python36.PyNumber_Index - PyNumber_Invert=python36.PyNumber_Invert - PyNumber_Long=python36.PyNumber_Long - PyNumber_Lshift=python36.PyNumber_Lshift - PyNumber_Multiply=python36.PyNumber_Multiply - PyNumber_Negative=python36.PyNumber_Negative - PyNumber_Or=python36.PyNumber_Or - PyNumber_Positive=python36.PyNumber_Positive - PyNumber_Power=python36.PyNumber_Power - PyNumber_Remainder=python36.PyNumber_Remainder - PyNumber_Rshift=python36.PyNumber_Rshift - PyNumber_Subtract=python36.PyNumber_Subtract - PyNumber_ToBase=python36.PyNumber_ToBase - PyNumber_TrueDivide=python36.PyNumber_TrueDivide - PyNumber_Xor=python36.PyNumber_Xor - PyOS_AfterFork=python36.PyOS_AfterFork - PyOS_InitInterrupts=python36.PyOS_InitInterrupts - PyOS_InputHook=python36.PyOS_InputHook DATA - PyOS_InterruptOccurred=python36.PyOS_InterruptOccurred - PyOS_ReadlineFunctionPointer=python36.PyOS_ReadlineFunctionPointer DATA - PyOS_double_to_string=python36.PyOS_double_to_string - PyOS_getsig=python36.PyOS_getsig - PyOS_mystricmp=python36.PyOS_mystricmp - PyOS_mystrnicmp=python36.PyOS_mystrnicmp - PyOS_setsig=python36.PyOS_setsig - PyOS_snprintf=python36.PyOS_snprintf - PyOS_string_to_double=python36.PyOS_string_to_double - PyOS_strtol=python36.PyOS_strtol - PyOS_strtoul=python36.PyOS_strtoul - PyOS_vsnprintf=python36.PyOS_vsnprintf - PyObject_ASCII=python36.PyObject_ASCII - PyObject_AsCharBuffer=python36.PyObject_AsCharBuffer - PyObject_AsFileDescriptor=python36.PyObject_AsFileDescriptor - PyObject_AsReadBuffer=python36.PyObject_AsReadBuffer - PyObject_AsWriteBuffer=python36.PyObject_AsWriteBuffer - PyObject_Bytes=python36.PyObject_Bytes - PyObject_Call=python36.PyObject_Call - PyObject_CallFunction=python36.PyObject_CallFunction - PyObject_CallFunctionObjArgs=python36.PyObject_CallFunctionObjArgs - PyObject_CallMethod=python36.PyObject_CallMethod - PyObject_CallMethodObjArgs=python36.PyObject_CallMethodObjArgs - PyObject_CallObject=python36.PyObject_CallObject - PyObject_CheckReadBuffer=python36.PyObject_CheckReadBuffer - PyObject_ClearWeakRefs=python36.PyObject_ClearWeakRefs - PyObject_DelItem=python36.PyObject_DelItem - PyObject_DelItemString=python36.PyObject_DelItemString - PyObject_Dir=python36.PyObject_Dir - PyObject_Format=python36.PyObject_Format - PyObject_Free=python36.PyObject_Free - PyObject_GC_Del=python36.PyObject_GC_Del - PyObject_GC_Track=python36.PyObject_GC_Track - PyObject_GC_UnTrack=python36.PyObject_GC_UnTrack - PyObject_GenericGetAttr=python36.PyObject_GenericGetAttr - PyObject_GenericSetAttr=python36.PyObject_GenericSetAttr - PyObject_GetAttr=python36.PyObject_GetAttr - PyObject_GetAttrString=python36.PyObject_GetAttrString - PyObject_GetItem=python36.PyObject_GetItem - PyObject_GetIter=python36.PyObject_GetIter - PyObject_HasAttr=python36.PyObject_HasAttr - PyObject_HasAttrString=python36.PyObject_HasAttrString - PyObject_Hash=python36.PyObject_Hash - PyObject_HashNotImplemented=python36.PyObject_HashNotImplemented - PyObject_Init=python36.PyObject_Init - PyObject_InitVar=python36.PyObject_InitVar - PyObject_IsInstance=python36.PyObject_IsInstance - PyObject_IsSubclass=python36.PyObject_IsSubclass - PyObject_IsTrue=python36.PyObject_IsTrue - PyObject_Length=python36.PyObject_Length - PyObject_Malloc=python36.PyObject_Malloc - PyObject_Not=python36.PyObject_Not - PyObject_Realloc=python36.PyObject_Realloc - PyObject_Repr=python36.PyObject_Repr - PyObject_RichCompare=python36.PyObject_RichCompare - PyObject_RichCompareBool=python36.PyObject_RichCompareBool - PyObject_SelfIter=python36.PyObject_SelfIter - PyObject_SetAttr=python36.PyObject_SetAttr - PyObject_SetAttrString=python36.PyObject_SetAttrString - PyObject_SetItem=python36.PyObject_SetItem - PyObject_Size=python36.PyObject_Size - PyObject_Str=python36.PyObject_Str - PyObject_Type=python36.PyObject_Type DATA - PyODict_DelItem=python36.PyODict_DelItem - PyODict_New=python36.PyODict_New - PyODict_SetItem=python36.PyODict_SetItem - PyODict_Type=python36.PyODict_Type DATA - PyODictItems_Type=python36.PyODictItems_Type DATA - PyODictIter_Type=python36.PyODictIter_Type DATA - PyODictKeys_Type=python36.PyODictKeys_Type DATA - PyODictValues_Type=python36.PyODictValues_Type DATA - PyParser_SimpleParseFileFlags=python36.PyParser_SimpleParseFileFlags - PyParser_SimpleParseStringFlags=python36.PyParser_SimpleParseStringFlags - PyProperty_Type=python36.PyProperty_Type DATA - PyRangeIter_Type=python36.PyRangeIter_Type DATA - PyRange_Type=python36.PyRange_Type DATA - PyReversed_Type=python36.PyReversed_Type DATA - PySeqIter_New=python36.PySeqIter_New - PySeqIter_Type=python36.PySeqIter_Type DATA - PySequence_Check=python36.PySequence_Check - PySequence_Concat=python36.PySequence_Concat - PySequence_Contains=python36.PySequence_Contains - PySequence_Count=python36.PySequence_Count - PySequence_DelItem=python36.PySequence_DelItem - PySequence_DelSlice=python36.PySequence_DelSlice - PySequence_Fast=python36.PySequence_Fast - PySequence_GetItem=python36.PySequence_GetItem - PySequence_GetSlice=python36.PySequence_GetSlice - PySequence_In=python36.PySequence_In - PySequence_InPlaceConcat=python36.PySequence_InPlaceConcat - PySequence_InPlaceRepeat=python36.PySequence_InPlaceRepeat - PySequence_Index=python36.PySequence_Index - PySequence_Length=python36.PySequence_Length - PySequence_List=python36.PySequence_List - PySequence_Repeat=python36.PySequence_Repeat - PySequence_SetItem=python36.PySequence_SetItem - PySequence_SetSlice=python36.PySequence_SetSlice - PySequence_Size=python36.PySequence_Size - PySequence_Tuple=python36.PySequence_Tuple - PySetIter_Type=python36.PySetIter_Type DATA - PySet_Add=python36.PySet_Add - PySet_Clear=python36.PySet_Clear - PySet_Contains=python36.PySet_Contains - PySet_Discard=python36.PySet_Discard - PySet_New=python36.PySet_New - PySet_Pop=python36.PySet_Pop - PySet_Size=python36.PySet_Size - PySet_Type=python36.PySet_Type DATA - PySlice_GetIndices=python36.PySlice_GetIndices - PySlice_GetIndicesEx=python36.PySlice_GetIndicesEx - PySlice_New=python36.PySlice_New - PySlice_Type=python36.PySlice_Type DATA - PySortWrapper_Type=python36.PySortWrapper_Type DATA - PyState_FindModule=python36.PyState_FindModule - PyState_AddModule=python36.PyState_AddModule - PyState_RemoveModule=python36.PyState_RemoveModule - PyStructSequence_GetItem=python36.PyStructSequence_GetItem - PyStructSequence_New=python36.PyStructSequence_New - PyStructSequence_NewType=python36.PyStructSequence_NewType - PyStructSequence_SetItem=python36.PyStructSequence_SetItem - PySuper_Type=python36.PySuper_Type DATA - PySys_AddWarnOption=python36.PySys_AddWarnOption - PySys_AddWarnOptionUnicode=python36.PySys_AddWarnOptionUnicode - PySys_FormatStderr=python36.PySys_FormatStderr - PySys_FormatStdout=python36.PySys_FormatStdout - PySys_GetObject=python36.PySys_GetObject - PySys_HasWarnOptions=python36.PySys_HasWarnOptions - PySys_ResetWarnOptions=python36.PySys_ResetWarnOptions - PySys_SetArgv=python36.PySys_SetArgv - PySys_SetArgvEx=python36.PySys_SetArgvEx - PySys_SetObject=python36.PySys_SetObject - PySys_SetPath=python36.PySys_SetPath - PySys_WriteStderr=python36.PySys_WriteStderr - PySys_WriteStdout=python36.PySys_WriteStdout - PyThreadState_Clear=python36.PyThreadState_Clear - PyThreadState_Delete=python36.PyThreadState_Delete - PyThreadState_DeleteCurrent=python36.PyThreadState_DeleteCurrent - PyThreadState_Get=python36.PyThreadState_Get - PyThreadState_GetDict=python36.PyThreadState_GetDict - PyThreadState_New=python36.PyThreadState_New - PyThreadState_SetAsyncExc=python36.PyThreadState_SetAsyncExc - PyThreadState_Swap=python36.PyThreadState_Swap - PyTraceBack_Here=python36.PyTraceBack_Here - PyTraceBack_Print=python36.PyTraceBack_Print - PyTraceBack_Type=python36.PyTraceBack_Type DATA - PyTupleIter_Type=python36.PyTupleIter_Type DATA - PyTuple_ClearFreeList=python36.PyTuple_ClearFreeList - PyTuple_GetItem=python36.PyTuple_GetItem - PyTuple_GetSlice=python36.PyTuple_GetSlice - PyTuple_New=python36.PyTuple_New - PyTuple_Pack=python36.PyTuple_Pack - PyTuple_SetItem=python36.PyTuple_SetItem - PyTuple_Size=python36.PyTuple_Size - PyTuple_Type=python36.PyTuple_Type DATA - PyType_ClearCache=python36.PyType_ClearCache - PyType_FromSpec=python36.PyType_FromSpec - PyType_FromSpecWithBases=python36.PyType_FromSpecWithBases - PyType_GenericAlloc=python36.PyType_GenericAlloc - PyType_GenericNew=python36.PyType_GenericNew - PyType_GetFlags=python36.PyType_GetFlags - PyType_GetSlot=python36.PyType_GetSlot - PyType_IsSubtype=python36.PyType_IsSubtype - PyType_Modified=python36.PyType_Modified - PyType_Ready=python36.PyType_Ready - PyType_Type=python36.PyType_Type DATA - PyUnicodeDecodeError_Create=python36.PyUnicodeDecodeError_Create - PyUnicodeDecodeError_GetEncoding=python36.PyUnicodeDecodeError_GetEncoding - PyUnicodeDecodeError_GetEnd=python36.PyUnicodeDecodeError_GetEnd - PyUnicodeDecodeError_GetObject=python36.PyUnicodeDecodeError_GetObject - PyUnicodeDecodeError_GetReason=python36.PyUnicodeDecodeError_GetReason - PyUnicodeDecodeError_GetStart=python36.PyUnicodeDecodeError_GetStart - PyUnicodeDecodeError_SetEnd=python36.PyUnicodeDecodeError_SetEnd - PyUnicodeDecodeError_SetReason=python36.PyUnicodeDecodeError_SetReason - PyUnicodeDecodeError_SetStart=python36.PyUnicodeDecodeError_SetStart - PyUnicodeEncodeError_GetEncoding=python36.PyUnicodeEncodeError_GetEncoding - PyUnicodeEncodeError_GetEnd=python36.PyUnicodeEncodeError_GetEnd - PyUnicodeEncodeError_GetObject=python36.PyUnicodeEncodeError_GetObject - PyUnicodeEncodeError_GetReason=python36.PyUnicodeEncodeError_GetReason - PyUnicodeEncodeError_GetStart=python36.PyUnicodeEncodeError_GetStart - PyUnicodeEncodeError_SetEnd=python36.PyUnicodeEncodeError_SetEnd - PyUnicodeEncodeError_SetReason=python36.PyUnicodeEncodeError_SetReason - PyUnicodeEncodeError_SetStart=python36.PyUnicodeEncodeError_SetStart - PyUnicodeIter_Type=python36.PyUnicodeIter_Type DATA - PyUnicodeTranslateError_GetEnd=python36.PyUnicodeTranslateError_GetEnd - PyUnicodeTranslateError_GetObject=python36.PyUnicodeTranslateError_GetObject - PyUnicodeTranslateError_GetReason=python36.PyUnicodeTranslateError_GetReason - PyUnicodeTranslateError_GetStart=python36.PyUnicodeTranslateError_GetStart - PyUnicodeTranslateError_SetEnd=python36.PyUnicodeTranslateError_SetEnd - PyUnicodeTranslateError_SetReason=python36.PyUnicodeTranslateError_SetReason - PyUnicodeTranslateError_SetStart=python36.PyUnicodeTranslateError_SetStart - PyUnicode_Append=python36.PyUnicode_Append - PyUnicode_AppendAndDel=python36.PyUnicode_AppendAndDel - PyUnicode_AsASCIIString=python36.PyUnicode_AsASCIIString - PyUnicode_AsCharmapString=python36.PyUnicode_AsCharmapString - PyUnicode_AsDecodedObject=python36.PyUnicode_AsDecodedObject - PyUnicode_AsDecodedUnicode=python36.PyUnicode_AsDecodedUnicode - PyUnicode_AsEncodedObject=python36.PyUnicode_AsEncodedObject - PyUnicode_AsEncodedString=python36.PyUnicode_AsEncodedString - PyUnicode_AsEncodedUnicode=python36.PyUnicode_AsEncodedUnicode - PyUnicode_AsLatin1String=python36.PyUnicode_AsLatin1String - PyUnicode_AsRawUnicodeEscapeString=python36.PyUnicode_AsRawUnicodeEscapeString - PyUnicode_AsUTF16String=python36.PyUnicode_AsUTF16String - PyUnicode_AsUTF32String=python36.PyUnicode_AsUTF32String - PyUnicode_AsUTF8String=python36.PyUnicode_AsUTF8String - PyUnicode_AsUnicodeEscapeString=python36.PyUnicode_AsUnicodeEscapeString - PyUnicode_AsWideChar=python36.PyUnicode_AsWideChar - PyUnicode_ClearFreelist=python36.PyUnicode_ClearFreelist - PyUnicode_Compare=python36.PyUnicode_Compare - PyUnicode_Concat=python36.PyUnicode_Concat - PyUnicode_Contains=python36.PyUnicode_Contains - PyUnicode_Count=python36.PyUnicode_Count - PyUnicode_Decode=python36.PyUnicode_Decode - PyUnicode_DecodeASCII=python36.PyUnicode_DecodeASCII - PyUnicode_DecodeCharmap=python36.PyUnicode_DecodeCharmap - PyUnicode_DecodeFSDefault=python36.PyUnicode_DecodeFSDefault - PyUnicode_DecodeFSDefaultAndSize=python36.PyUnicode_DecodeFSDefaultAndSize - PyUnicode_DecodeLatin1=python36.PyUnicode_DecodeLatin1 - PyUnicode_DecodeRawUnicodeEscape=python36.PyUnicode_DecodeRawUnicodeEscape - PyUnicode_DecodeUTF16=python36.PyUnicode_DecodeUTF16 - PyUnicode_DecodeUTF16Stateful=python36.PyUnicode_DecodeUTF16Stateful - PyUnicode_DecodeUTF32=python36.PyUnicode_DecodeUTF32 - PyUnicode_DecodeUTF32Stateful=python36.PyUnicode_DecodeUTF32Stateful - PyUnicode_DecodeUTF8=python36.PyUnicode_DecodeUTF8 - PyUnicode_DecodeUTF8Stateful=python36.PyUnicode_DecodeUTF8Stateful - PyUnicode_DecodeUnicodeEscape=python36.PyUnicode_DecodeUnicodeEscape - PyUnicode_FSConverter=python36.PyUnicode_FSConverter - PyUnicode_FSDecoder=python36.PyUnicode_FSDecoder - PyUnicode_Find=python36.PyUnicode_Find - PyUnicode_Format=python36.PyUnicode_Format - PyUnicode_FromEncodedObject=python36.PyUnicode_FromEncodedObject - PyUnicode_FromFormat=python36.PyUnicode_FromFormat - PyUnicode_FromFormatV=python36.PyUnicode_FromFormatV - PyUnicode_FromObject=python36.PyUnicode_FromObject - PyUnicode_FromOrdinal=python36.PyUnicode_FromOrdinal - PyUnicode_FromString=python36.PyUnicode_FromString - PyUnicode_FromStringAndSize=python36.PyUnicode_FromStringAndSize - PyUnicode_FromWideChar=python36.PyUnicode_FromWideChar - PyUnicode_GetDefaultEncoding=python36.PyUnicode_GetDefaultEncoding - PyUnicode_GetSize=python36.PyUnicode_GetSize - PyUnicode_IsIdentifier=python36.PyUnicode_IsIdentifier - PyUnicode_Join=python36.PyUnicode_Join - PyUnicode_Partition=python36.PyUnicode_Partition - PyUnicode_RPartition=python36.PyUnicode_RPartition - PyUnicode_RSplit=python36.PyUnicode_RSplit - PyUnicode_Replace=python36.PyUnicode_Replace - PyUnicode_Resize=python36.PyUnicode_Resize - PyUnicode_RichCompare=python36.PyUnicode_RichCompare - PyUnicode_SetDefaultEncoding=python36.PyUnicode_SetDefaultEncoding - PyUnicode_Split=python36.PyUnicode_Split - PyUnicode_Splitlines=python36.PyUnicode_Splitlines - PyUnicode_Tailmatch=python36.PyUnicode_Tailmatch - PyUnicode_Translate=python36.PyUnicode_Translate - PyUnicode_BuildEncodingMap=python36.PyUnicode_BuildEncodingMap - PyUnicode_CompareWithASCIIString=python36.PyUnicode_CompareWithASCIIString - PyUnicode_DecodeUTF7=python36.PyUnicode_DecodeUTF7 - PyUnicode_DecodeUTF7Stateful=python36.PyUnicode_DecodeUTF7Stateful - PyUnicode_EncodeFSDefault=python36.PyUnicode_EncodeFSDefault - PyUnicode_InternFromString=python36.PyUnicode_InternFromString - PyUnicode_InternImmortal=python36.PyUnicode_InternImmortal - PyUnicode_InternInPlace=python36.PyUnicode_InternInPlace - PyUnicode_Type=python36.PyUnicode_Type DATA - PyWeakref_GetObject=python36.PyWeakref_GetObject DATA - PyWeakref_NewProxy=python36.PyWeakref_NewProxy - PyWeakref_NewRef=python36.PyWeakref_NewRef - PyWrapperDescr_Type=python36.PyWrapperDescr_Type DATA - PyWrapper_New=python36.PyWrapper_New - PyZip_Type=python36.PyZip_Type DATA - Py_AddPendingCall=python36.Py_AddPendingCall - Py_AtExit=python36.Py_AtExit - Py_BuildValue=python36.Py_BuildValue - Py_CompileString=python36.Py_CompileString - Py_DecRef=python36.Py_DecRef - Py_EndInterpreter=python36.Py_EndInterpreter - Py_Exit=python36.Py_Exit - Py_FatalError=python36.Py_FatalError - Py_FileSystemDefaultEncoding=python36.Py_FileSystemDefaultEncoding DATA - Py_Finalize=python36.Py_Finalize - Py_FinalizeEx=python36.Py_FinalizeEx - Py_GetBuildInfo=python36.Py_GetBuildInfo - Py_GetCompiler=python36.Py_GetCompiler - Py_GetCopyright=python36.Py_GetCopyright - Py_GetExecPrefix=python36.Py_GetExecPrefix - Py_GetPath=python36.Py_GetPath - Py_GetPlatform=python36.Py_GetPlatform - Py_GetPrefix=python36.Py_GetPrefix - Py_GetProgramFullPath=python36.Py_GetProgramFullPath - Py_GetProgramName=python36.Py_GetProgramName - Py_GetPythonHome=python36.Py_GetPythonHome - Py_GetRecursionLimit=python36.Py_GetRecursionLimit - Py_GetVersion=python36.Py_GetVersion - Py_HasFileSystemDefaultEncoding=python36.Py_HasFileSystemDefaultEncoding DATA - Py_IncRef=python36.Py_IncRef - Py_Initialize=python36.Py_Initialize - Py_InitializeEx=python36.Py_InitializeEx - Py_IsInitialized=python36.Py_IsInitialized - Py_Main=python36.Py_Main - Py_MakePendingCalls=python36.Py_MakePendingCalls - Py_NewInterpreter=python36.Py_NewInterpreter - Py_ReprEnter=python36.Py_ReprEnter - Py_ReprLeave=python36.Py_ReprLeave - Py_SetProgramName=python36.Py_SetProgramName - Py_SetPythonHome=python36.Py_SetPythonHome - Py_SetRecursionLimit=python36.Py_SetRecursionLimit - Py_SymtableString=python36.Py_SymtableString - Py_VaBuildValue=python36.Py_VaBuildValue - _PyErr_BadInternalCall=python36._PyErr_BadInternalCall - _PyObject_CallFunction_SizeT=python36._PyObject_CallFunction_SizeT - _PyObject_CallMethod_SizeT=python36._PyObject_CallMethod_SizeT - _PyObject_GC_Malloc=python36._PyObject_GC_Malloc - _PyObject_GC_New=python36._PyObject_GC_New - _PyObject_GC_NewVar=python36._PyObject_GC_NewVar - _PyObject_GC_Resize=python36._PyObject_GC_Resize - _PyObject_New=python36._PyObject_New - _PyObject_NewVar=python36._PyObject_NewVar - _PyState_AddModule=python36._PyState_AddModule - _PyThreadState_Init=python36._PyThreadState_Init - _PyThreadState_Prealloc=python36._PyThreadState_Prealloc - _PyTrash_delete_later=python36._PyTrash_delete_later DATA - _PyTrash_delete_nesting=python36._PyTrash_delete_nesting DATA - _PyTrash_deposit_object=python36._PyTrash_deposit_object - _PyTrash_destroy_chain=python36._PyTrash_destroy_chain - _PyWeakref_CallableProxyType=python36._PyWeakref_CallableProxyType DATA - _PyWeakref_ProxyType=python36._PyWeakref_ProxyType DATA - _PyWeakref_RefType=python36._PyWeakref_RefType DATA - _Py_BuildValue_SizeT=python36._Py_BuildValue_SizeT - _Py_CheckRecursionLimit=python36._Py_CheckRecursionLimit DATA - _Py_CheckRecursiveCall=python36._Py_CheckRecursiveCall - _Py_Dealloc=python36._Py_Dealloc - _Py_EllipsisObject=python36._Py_EllipsisObject DATA - _Py_FalseStruct=python36._Py_FalseStruct DATA - _Py_NoneStruct=python36._Py_NoneStruct DATA - _Py_NotImplementedStruct=python36._Py_NotImplementedStruct DATA - _Py_SwappedOp=python36._Py_SwappedOp DATA - _Py_TrueStruct=python36._Py_TrueStruct DATA - _Py_VaBuildValue_SizeT=python36._Py_VaBuildValue_SizeT - _PyArg_Parse_SizeT=python36._PyArg_Parse_SizeT - _PyArg_ParseTuple_SizeT=python36._PyArg_ParseTuple_SizeT - _PyArg_ParseTupleAndKeywords_SizeT=python36._PyArg_ParseTupleAndKeywords_SizeT - _PyArg_VaParse_SizeT=python36._PyArg_VaParse_SizeT - _PyArg_VaParseTupleAndKeywords_SizeT=python36._PyArg_VaParseTupleAndKeywords_SizeT - _Py_BuildValue_SizeT=python36._Py_BuildValue_SizeT + PyArg_Parse=python37.PyArg_Parse + PyArg_ParseTuple=python37.PyArg_ParseTuple + PyArg_ParseTupleAndKeywords=python37.PyArg_ParseTupleAndKeywords + PyArg_UnpackTuple=python37.PyArg_UnpackTuple + PyArg_VaParse=python37.PyArg_VaParse + PyArg_VaParseTupleAndKeywords=python37.PyArg_VaParseTupleAndKeywords + PyArg_ValidateKeywordArguments=python37.PyArg_ValidateKeywordArguments + PyBaseObject_Type=python37.PyBaseObject_Type DATA + PyBool_FromLong=python37.PyBool_FromLong + PyBool_Type=python37.PyBool_Type DATA + PyByteArrayIter_Type=python37.PyByteArrayIter_Type DATA + PyByteArray_AsString=python37.PyByteArray_AsString + PyByteArray_Concat=python37.PyByteArray_Concat + PyByteArray_FromObject=python37.PyByteArray_FromObject + PyByteArray_FromStringAndSize=python37.PyByteArray_FromStringAndSize + PyByteArray_Resize=python37.PyByteArray_Resize + PyByteArray_Size=python37.PyByteArray_Size + PyByteArray_Type=python37.PyByteArray_Type DATA + PyBytesIter_Type=python37.PyBytesIter_Type DATA + PyBytes_AsString=python37.PyBytes_AsString + PyBytes_AsStringAndSize=python37.PyBytes_AsStringAndSize + PyBytes_Concat=python37.PyBytes_Concat + PyBytes_ConcatAndDel=python37.PyBytes_ConcatAndDel + PyBytes_DecodeEscape=python37.PyBytes_DecodeEscape + PyBytes_FromFormat=python37.PyBytes_FromFormat + PyBytes_FromFormatV=python37.PyBytes_FromFormatV + PyBytes_FromObject=python37.PyBytes_FromObject + PyBytes_FromString=python37.PyBytes_FromString + PyBytes_FromStringAndSize=python37.PyBytes_FromStringAndSize + PyBytes_Repr=python37.PyBytes_Repr + PyBytes_Size=python37.PyBytes_Size + PyBytes_Type=python37.PyBytes_Type DATA + PyCFunction_Call=python37.PyCFunction_Call + PyCFunction_ClearFreeList=python37.PyCFunction_ClearFreeList + PyCFunction_GetFlags=python37.PyCFunction_GetFlags + PyCFunction_GetFunction=python37.PyCFunction_GetFunction + PyCFunction_GetSelf=python37.PyCFunction_GetSelf + PyCFunction_New=python37.PyCFunction_New + PyCFunction_NewEx=python37.PyCFunction_NewEx + PyCFunction_Type=python37.PyCFunction_Type DATA + PyCallIter_New=python37.PyCallIter_New + PyCallIter_Type=python37.PyCallIter_Type DATA + PyCallable_Check=python37.PyCallable_Check + PyCapsule_GetContext=python37.PyCapsule_GetContext + PyCapsule_GetDestructor=python37.PyCapsule_GetDestructor + PyCapsule_GetName=python37.PyCapsule_GetName + PyCapsule_GetPointer=python37.PyCapsule_GetPointer + PyCapsule_Import=python37.PyCapsule_Import + PyCapsule_IsValid=python37.PyCapsule_IsValid + PyCapsule_New=python37.PyCapsule_New + PyCapsule_SetContext=python37.PyCapsule_SetContext + PyCapsule_SetDestructor=python37.PyCapsule_SetDestructor + PyCapsule_SetName=python37.PyCapsule_SetName + PyCapsule_SetPointer=python37.PyCapsule_SetPointer + PyCapsule_Type=python37.PyCapsule_Type DATA + PyClassMethodDescr_Type=python37.PyClassMethodDescr_Type DATA + PyCodec_BackslashReplaceErrors=python37.PyCodec_BackslashReplaceErrors + PyCodec_Decode=python37.PyCodec_Decode + PyCodec_Decoder=python37.PyCodec_Decoder + PyCodec_Encode=python37.PyCodec_Encode + PyCodec_Encoder=python37.PyCodec_Encoder + PyCodec_IgnoreErrors=python37.PyCodec_IgnoreErrors + PyCodec_IncrementalDecoder=python37.PyCodec_IncrementalDecoder + PyCodec_IncrementalEncoder=python37.PyCodec_IncrementalEncoder + PyCodec_KnownEncoding=python37.PyCodec_KnownEncoding + PyCodec_LookupError=python37.PyCodec_LookupError + PyCodec_Register=python37.PyCodec_Register + PyCodec_RegisterError=python37.PyCodec_RegisterError + PyCodec_ReplaceErrors=python37.PyCodec_ReplaceErrors + PyCodec_StreamReader=python37.PyCodec_StreamReader + PyCodec_StreamWriter=python37.PyCodec_StreamWriter + PyCodec_StrictErrors=python37.PyCodec_StrictErrors + PyCodec_XMLCharRefReplaceErrors=python37.PyCodec_XMLCharRefReplaceErrors + PyComplex_FromDoubles=python37.PyComplex_FromDoubles + PyComplex_ImagAsDouble=python37.PyComplex_ImagAsDouble + PyComplex_RealAsDouble=python37.PyComplex_RealAsDouble + PyComplex_Type=python37.PyComplex_Type DATA + PyDescr_NewClassMethod=python37.PyDescr_NewClassMethod + PyDescr_NewGetSet=python37.PyDescr_NewGetSet + PyDescr_NewMember=python37.PyDescr_NewMember + PyDescr_NewMethod=python37.PyDescr_NewMethod + PyDictItems_Type=python37.PyDictItems_Type DATA + PyDictIterItem_Type=python37.PyDictIterItem_Type DATA + PyDictIterKey_Type=python37.PyDictIterKey_Type DATA + PyDictIterValue_Type=python37.PyDictIterValue_Type DATA + PyDictKeys_Type=python37.PyDictKeys_Type DATA + PyDictProxy_New=python37.PyDictProxy_New + PyDictProxy_Type=python37.PyDictProxy_Type DATA + PyDictValues_Type=python37.PyDictValues_Type DATA + PyDict_Clear=python37.PyDict_Clear + PyDict_Contains=python37.PyDict_Contains + PyDict_Copy=python37.PyDict_Copy + PyDict_DelItem=python37.PyDict_DelItem + PyDict_DelItemString=python37.PyDict_DelItemString + PyDict_GetItem=python37.PyDict_GetItem + PyDict_GetItemString=python37.PyDict_GetItemString + PyDict_GetItemWithError=python37.PyDict_GetItemWithError + PyDict_Items=python37.PyDict_Items + PyDict_Keys=python37.PyDict_Keys + PyDict_Merge=python37.PyDict_Merge + PyDict_MergeFromSeq2=python37.PyDict_MergeFromSeq2 + PyDict_New=python37.PyDict_New + PyDict_Next=python37.PyDict_Next + PyDict_SetItem=python37.PyDict_SetItem + PyDict_SetItemString=python37.PyDict_SetItemString + PyDict_Size=python37.PyDict_Size + PyDict_Type=python37.PyDict_Type DATA + PyDict_Update=python37.PyDict_Update + PyDict_Values=python37.PyDict_Values + PyEllipsis_Type=python37.PyEllipsis_Type DATA + PyEnum_Type=python37.PyEnum_Type DATA + PyErr_BadArgument=python37.PyErr_BadArgument + PyErr_BadInternalCall=python37.PyErr_BadInternalCall + PyErr_CheckSignals=python37.PyErr_CheckSignals + PyErr_Clear=python37.PyErr_Clear + PyErr_Display=python37.PyErr_Display + PyErr_ExceptionMatches=python37.PyErr_ExceptionMatches + PyErr_Fetch=python37.PyErr_Fetch + PyErr_Format=python37.PyErr_Format + PyErr_FormatV=python37.PyErr_FormatV + PyErr_GivenExceptionMatches=python37.PyErr_GivenExceptionMatches + PyErr_NewException=python37.PyErr_NewException + PyErr_NewExceptionWithDoc=python37.PyErr_NewExceptionWithDoc + PyErr_NoMemory=python37.PyErr_NoMemory + PyErr_NormalizeException=python37.PyErr_NormalizeException + PyErr_Occurred=python37.PyErr_Occurred + PyErr_Print=python37.PyErr_Print + PyErr_PrintEx=python37.PyErr_PrintEx + PyErr_ProgramText=python37.PyErr_ProgramText + PyErr_Restore=python37.PyErr_Restore + PyErr_SetFromErrno=python37.PyErr_SetFromErrno + PyErr_SetFromErrnoWithFilename=python37.PyErr_SetFromErrnoWithFilename + PyErr_SetFromErrnoWithFilenameObject=python37.PyErr_SetFromErrnoWithFilenameObject + PyErr_SetInterrupt=python37.PyErr_SetInterrupt + PyErr_SetNone=python37.PyErr_SetNone + PyErr_SetObject=python37.PyErr_SetObject + PyErr_SetString=python37.PyErr_SetString + PyErr_SyntaxLocation=python37.PyErr_SyntaxLocation + PyErr_WarnEx=python37.PyErr_WarnEx + PyErr_WarnExplicit=python37.PyErr_WarnExplicit + PyErr_WarnFormat=python37.PyErr_WarnFormat + PyErr_WriteUnraisable=python37.PyErr_WriteUnraisable + PyEval_AcquireLock=python37.PyEval_AcquireLock + PyEval_AcquireThread=python37.PyEval_AcquireThread + PyEval_CallFunction=python37.PyEval_CallFunction + PyEval_CallMethod=python37.PyEval_CallMethod + PyEval_CallObjectWithKeywords=python37.PyEval_CallObjectWithKeywords + PyEval_EvalCode=python37.PyEval_EvalCode + PyEval_EvalCodeEx=python37.PyEval_EvalCodeEx + PyEval_EvalFrame=python37.PyEval_EvalFrame + PyEval_EvalFrameEx=python37.PyEval_EvalFrameEx + PyEval_GetBuiltins=python37.PyEval_GetBuiltins + PyEval_GetCallStats=python37.PyEval_GetCallStats + PyEval_GetFrame=python37.PyEval_GetFrame + PyEval_GetFuncDesc=python37.PyEval_GetFuncDesc + PyEval_GetFuncName=python37.PyEval_GetFuncName + PyEval_GetGlobals=python37.PyEval_GetGlobals + PyEval_GetLocals=python37.PyEval_GetLocals + PyEval_InitThreads=python37.PyEval_InitThreads + PyEval_ReInitThreads=python37.PyEval_ReInitThreads + PyEval_ReleaseLock=python37.PyEval_ReleaseLock + PyEval_ReleaseThread=python37.PyEval_ReleaseThread + PyEval_RestoreThread=python37.PyEval_RestoreThread + PyEval_SaveThread=python37.PyEval_SaveThread + PyEval_ThreadsInitialized=python37.PyEval_ThreadsInitialized + PyExc_ArithmeticError=python37.PyExc_ArithmeticError DATA + PyExc_AssertionError=python37.PyExc_AssertionError DATA + PyExc_AttributeError=python37.PyExc_AttributeError DATA + PyExc_BaseException=python37.PyExc_BaseException DATA + PyExc_BufferError=python37.PyExc_BufferError DATA + PyExc_BytesWarning=python37.PyExc_BytesWarning DATA + PyExc_DeprecationWarning=python37.PyExc_DeprecationWarning DATA + PyExc_EOFError=python37.PyExc_EOFError DATA + PyExc_EnvironmentError=python37.PyExc_EnvironmentError DATA + PyExc_Exception=python37.PyExc_Exception DATA + PyExc_FloatingPointError=python37.PyExc_FloatingPointError DATA + PyExc_FutureWarning=python37.PyExc_FutureWarning DATA + PyExc_GeneratorExit=python37.PyExc_GeneratorExit DATA + PyExc_IOError=python37.PyExc_IOError DATA + PyExc_ImportError=python37.PyExc_ImportError DATA + PyExc_ImportWarning=python37.PyExc_ImportWarning DATA + PyExc_IndentationError=python37.PyExc_IndentationError DATA + PyExc_IndexError=python37.PyExc_IndexError DATA + PyExc_KeyError=python37.PyExc_KeyError DATA + PyExc_KeyboardInterrupt=python37.PyExc_KeyboardInterrupt DATA + PyExc_LookupError=python37.PyExc_LookupError DATA + PyExc_MemoryError=python37.PyExc_MemoryError DATA + PyExc_MemoryErrorInst=python37.PyExc_MemoryErrorInst DATA + PyExc_NameError=python37.PyExc_NameError DATA + PyExc_NotImplementedError=python37.PyExc_NotImplementedError DATA + PyExc_OSError=python37.PyExc_OSError DATA + PyExc_OverflowError=python37.PyExc_OverflowError DATA + PyExc_PendingDeprecationWarning=python37.PyExc_PendingDeprecationWarning DATA + PyExc_RecursionErrorInst=python37.PyExc_RecursionErrorInst DATA + PyExc_ReferenceError=python37.PyExc_ReferenceError DATA + PyExc_RuntimeError=python37.PyExc_RuntimeError DATA + PyExc_RuntimeWarning=python37.PyExc_RuntimeWarning DATA + PyExc_StopIteration=python37.PyExc_StopIteration DATA + PyExc_SyntaxError=python37.PyExc_SyntaxError DATA + PyExc_SyntaxWarning=python37.PyExc_SyntaxWarning DATA + PyExc_SystemError=python37.PyExc_SystemError DATA + PyExc_SystemExit=python37.PyExc_SystemExit DATA + PyExc_TabError=python37.PyExc_TabError DATA + PyExc_TypeError=python37.PyExc_TypeError DATA + PyExc_UnboundLocalError=python37.PyExc_UnboundLocalError DATA + PyExc_UnicodeDecodeError=python37.PyExc_UnicodeDecodeError DATA + PyExc_UnicodeEncodeError=python37.PyExc_UnicodeEncodeError DATA + PyExc_UnicodeError=python37.PyExc_UnicodeError DATA + PyExc_UnicodeTranslateError=python37.PyExc_UnicodeTranslateError DATA + PyExc_UnicodeWarning=python37.PyExc_UnicodeWarning DATA + PyExc_UserWarning=python37.PyExc_UserWarning DATA + PyExc_ValueError=python37.PyExc_ValueError DATA + PyExc_Warning=python37.PyExc_Warning DATA + PyExc_ZeroDivisionError=python37.PyExc_ZeroDivisionError DATA + PyException_GetCause=python37.PyException_GetCause + PyException_GetContext=python37.PyException_GetContext + PyException_GetTraceback=python37.PyException_GetTraceback + PyException_SetCause=python37.PyException_SetCause + PyException_SetContext=python37.PyException_SetContext + PyException_SetTraceback=python37.PyException_SetTraceback + PyFile_FromFd=python37.PyFile_FromFd + PyFile_GetLine=python37.PyFile_GetLine + PyFile_WriteObject=python37.PyFile_WriteObject + PyFile_WriteString=python37.PyFile_WriteString + PyFilter_Type=python37.PyFilter_Type DATA + PyFloat_AsDouble=python37.PyFloat_AsDouble + PyFloat_FromDouble=python37.PyFloat_FromDouble + PyFloat_FromString=python37.PyFloat_FromString + PyFloat_GetInfo=python37.PyFloat_GetInfo + PyFloat_GetMax=python37.PyFloat_GetMax + PyFloat_GetMin=python37.PyFloat_GetMin + PyFloat_Type=python37.PyFloat_Type DATA + PyFrozenSet_New=python37.PyFrozenSet_New + PyFrozenSet_Type=python37.PyFrozenSet_Type DATA + PyGC_Collect=python37.PyGC_Collect + PyGILState_Ensure=python37.PyGILState_Ensure + PyGILState_GetThisThreadState=python37.PyGILState_GetThisThreadState + PyGILState_Release=python37.PyGILState_Release + PyGetSetDescr_Type=python37.PyGetSetDescr_Type DATA + PyImport_AddModule=python37.PyImport_AddModule + PyImport_AppendInittab=python37.PyImport_AppendInittab + PyImport_Cleanup=python37.PyImport_Cleanup + PyImport_ExecCodeModule=python37.PyImport_ExecCodeModule + PyImport_ExecCodeModuleEx=python37.PyImport_ExecCodeModuleEx + PyImport_ExecCodeModuleWithPathnames=python37.PyImport_ExecCodeModuleWithPathnames + PyImport_GetImporter=python37.PyImport_GetImporter + PyImport_GetMagicNumber=python37.PyImport_GetMagicNumber + PyImport_GetMagicTag=python37.PyImport_GetMagicTag + PyImport_GetModuleDict=python37.PyImport_GetModuleDict + PyImport_Import=python37.PyImport_Import + PyImport_ImportFrozenModule=python37.PyImport_ImportFrozenModule + PyImport_ImportModule=python37.PyImport_ImportModule + PyImport_ImportModuleLevel=python37.PyImport_ImportModuleLevel + PyImport_ImportModuleNoBlock=python37.PyImport_ImportModuleNoBlock + PyImport_ReloadModule=python37.PyImport_ReloadModule + PyInterpreterState_Clear=python37.PyInterpreterState_Clear + PyInterpreterState_Delete=python37.PyInterpreterState_Delete + PyInterpreterState_New=python37.PyInterpreterState_New + PyIter_Next=python37.PyIter_Next + PyListIter_Type=python37.PyListIter_Type DATA + PyListRevIter_Type=python37.PyListRevIter_Type DATA + PyList_Append=python37.PyList_Append + PyList_AsTuple=python37.PyList_AsTuple + PyList_GetItem=python37.PyList_GetItem + PyList_GetSlice=python37.PyList_GetSlice + PyList_Insert=python37.PyList_Insert + PyList_New=python37.PyList_New + PyList_Reverse=python37.PyList_Reverse + PyList_SetItem=python37.PyList_SetItem + PyList_SetSlice=python37.PyList_SetSlice + PyList_Size=python37.PyList_Size + PyList_Sort=python37.PyList_Sort + PyList_Type=python37.PyList_Type DATA + PyLongRangeIter_Type=python37.PyLongRangeIter_Type DATA + PyLong_AsDouble=python37.PyLong_AsDouble + PyLong_AsLong=python37.PyLong_AsLong + PyLong_AsLongAndOverflow=python37.PyLong_AsLongAndOverflow + PyLong_AsLongLong=python37.PyLong_AsLongLong + PyLong_AsLongLongAndOverflow=python37.PyLong_AsLongLongAndOverflow + PyLong_AsSize_t=python37.PyLong_AsSize_t + PyLong_AsSsize_t=python37.PyLong_AsSsize_t + PyLong_AsUnsignedLong=python37.PyLong_AsUnsignedLong + PyLong_AsUnsignedLongLong=python37.PyLong_AsUnsignedLongLong + PyLong_AsUnsignedLongLongMask=python37.PyLong_AsUnsignedLongLongMask + PyLong_AsUnsignedLongMask=python37.PyLong_AsUnsignedLongMask + PyLong_AsVoidPtr=python37.PyLong_AsVoidPtr + PyLong_FromDouble=python37.PyLong_FromDouble + PyLong_FromLong=python37.PyLong_FromLong + PyLong_FromLongLong=python37.PyLong_FromLongLong + PyLong_FromSize_t=python37.PyLong_FromSize_t + PyLong_FromSsize_t=python37.PyLong_FromSsize_t + PyLong_FromString=python37.PyLong_FromString + PyLong_FromUnsignedLong=python37.PyLong_FromUnsignedLong + PyLong_FromUnsignedLongLong=python37.PyLong_FromUnsignedLongLong + PyLong_FromVoidPtr=python37.PyLong_FromVoidPtr + PyLong_GetInfo=python37.PyLong_GetInfo + PyLong_Type=python37.PyLong_Type DATA + PyMap_Type=python37.PyMap_Type DATA + PyMapping_Check=python37.PyMapping_Check + PyMapping_GetItemString=python37.PyMapping_GetItemString + PyMapping_HasKey=python37.PyMapping_HasKey + PyMapping_HasKeyString=python37.PyMapping_HasKeyString + PyMapping_Items=python37.PyMapping_Items + PyMapping_Keys=python37.PyMapping_Keys + PyMapping_Length=python37.PyMapping_Length + PyMapping_SetItemString=python37.PyMapping_SetItemString + PyMapping_Size=python37.PyMapping_Size + PyMapping_Values=python37.PyMapping_Values + PyMem_Free=python37.PyMem_Free + PyMem_Malloc=python37.PyMem_Malloc + PyMem_Realloc=python37.PyMem_Realloc + PyMemberDescr_Type=python37.PyMemberDescr_Type DATA + PyMemoryView_FromObject=python37.PyMemoryView_FromObject + PyMemoryView_GetContiguous=python37.PyMemoryView_GetContiguous + PyMemoryView_Type=python37.PyMemoryView_Type DATA + PyMethodDescr_Type=python37.PyMethodDescr_Type DATA + PyModule_AddIntConstant=python37.PyModule_AddIntConstant + PyModule_AddObject=python37.PyModule_AddObject + PyModule_AddStringConstant=python37.PyModule_AddStringConstant + PyModule_Create2=python37.PyModule_Create2 + PyModule_GetDef=python37.PyModule_GetDef + PyModule_GetDict=python37.PyModule_GetDict + PyModule_GetFilename=python37.PyModule_GetFilename + PyModule_GetFilenameObject=python37.PyModule_GetFilenameObject + PyModule_GetName=python37.PyModule_GetName + PyModule_GetState=python37.PyModule_GetState + PyModule_New=python37.PyModule_New + PyModule_Type=python37.PyModule_Type DATA + PyModuleDef_Init=python37.PyModuleDef_Init + PyModuleDef_Type=python37.PyModuleDef_Type DATA + PyNullImporter_Type=python37.PyNullImporter_Type DATA + PyNumber_Absolute=python37.PyNumber_Absolute + PyNumber_Add=python37.PyNumber_Add + PyNumber_And=python37.PyNumber_And + PyNumber_AsSsize_t=python37.PyNumber_AsSsize_t + PyNumber_Check=python37.PyNumber_Check + PyNumber_Divmod=python37.PyNumber_Divmod + PyNumber_Float=python37.PyNumber_Float + PyNumber_FloorDivide=python37.PyNumber_FloorDivide + PyNumber_InPlaceAdd=python37.PyNumber_InPlaceAdd + PyNumber_InPlaceAnd=python37.PyNumber_InPlaceAnd + PyNumber_InPlaceFloorDivide=python37.PyNumber_InPlaceFloorDivide + PyNumber_InPlaceLshift=python37.PyNumber_InPlaceLshift + PyNumber_InPlaceMultiply=python37.PyNumber_InPlaceMultiply + PyNumber_InPlaceOr=python37.PyNumber_InPlaceOr + PyNumber_InPlacePower=python37.PyNumber_InPlacePower + PyNumber_InPlaceRemainder=python37.PyNumber_InPlaceRemainder + PyNumber_InPlaceRshift=python37.PyNumber_InPlaceRshift + PyNumber_InPlaceSubtract=python37.PyNumber_InPlaceSubtract + PyNumber_InPlaceTrueDivide=python37.PyNumber_InPlaceTrueDivide + PyNumber_InPlaceXor=python37.PyNumber_InPlaceXor + PyNumber_Index=python37.PyNumber_Index + PyNumber_Invert=python37.PyNumber_Invert + PyNumber_Long=python37.PyNumber_Long + PyNumber_Lshift=python37.PyNumber_Lshift + PyNumber_Multiply=python37.PyNumber_Multiply + PyNumber_Negative=python37.PyNumber_Negative + PyNumber_Or=python37.PyNumber_Or + PyNumber_Positive=python37.PyNumber_Positive + PyNumber_Power=python37.PyNumber_Power + PyNumber_Remainder=python37.PyNumber_Remainder + PyNumber_Rshift=python37.PyNumber_Rshift + PyNumber_Subtract=python37.PyNumber_Subtract + PyNumber_ToBase=python37.PyNumber_ToBase + PyNumber_TrueDivide=python37.PyNumber_TrueDivide + PyNumber_Xor=python37.PyNumber_Xor + PyOS_AfterFork=python37.PyOS_AfterFork + PyOS_InitInterrupts=python37.PyOS_InitInterrupts + PyOS_InputHook=python37.PyOS_InputHook DATA + PyOS_InterruptOccurred=python37.PyOS_InterruptOccurred + PyOS_ReadlineFunctionPointer=python37.PyOS_ReadlineFunctionPointer DATA + PyOS_double_to_string=python37.PyOS_double_to_string + PyOS_getsig=python37.PyOS_getsig + PyOS_mystricmp=python37.PyOS_mystricmp + PyOS_mystrnicmp=python37.PyOS_mystrnicmp + PyOS_setsig=python37.PyOS_setsig + PyOS_snprintf=python37.PyOS_snprintf + PyOS_string_to_double=python37.PyOS_string_to_double + PyOS_strtol=python37.PyOS_strtol + PyOS_strtoul=python37.PyOS_strtoul + PyOS_vsnprintf=python37.PyOS_vsnprintf + PyObject_ASCII=python37.PyObject_ASCII + PyObject_AsCharBuffer=python37.PyObject_AsCharBuffer + PyObject_AsFileDescriptor=python37.PyObject_AsFileDescriptor + PyObject_AsReadBuffer=python37.PyObject_AsReadBuffer + PyObject_AsWriteBuffer=python37.PyObject_AsWriteBuffer + PyObject_Bytes=python37.PyObject_Bytes + PyObject_Call=python37.PyObject_Call + PyObject_CallFunction=python37.PyObject_CallFunction + PyObject_CallFunctionObjArgs=python37.PyObject_CallFunctionObjArgs + PyObject_CallMethod=python37.PyObject_CallMethod + PyObject_CallMethodObjArgs=python37.PyObject_CallMethodObjArgs + PyObject_CallObject=python37.PyObject_CallObject + PyObject_CheckReadBuffer=python37.PyObject_CheckReadBuffer + PyObject_ClearWeakRefs=python37.PyObject_ClearWeakRefs + PyObject_DelItem=python37.PyObject_DelItem + PyObject_DelItemString=python37.PyObject_DelItemString + PyObject_Dir=python37.PyObject_Dir + PyObject_Format=python37.PyObject_Format + PyObject_Free=python37.PyObject_Free + PyObject_GC_Del=python37.PyObject_GC_Del + PyObject_GC_Track=python37.PyObject_GC_Track + PyObject_GC_UnTrack=python37.PyObject_GC_UnTrack + PyObject_GenericGetAttr=python37.PyObject_GenericGetAttr + PyObject_GenericSetAttr=python37.PyObject_GenericSetAttr + PyObject_GetAttr=python37.PyObject_GetAttr + PyObject_GetAttrString=python37.PyObject_GetAttrString + PyObject_GetItem=python37.PyObject_GetItem + PyObject_GetIter=python37.PyObject_GetIter + PyObject_HasAttr=python37.PyObject_HasAttr + PyObject_HasAttrString=python37.PyObject_HasAttrString + PyObject_Hash=python37.PyObject_Hash + PyObject_HashNotImplemented=python37.PyObject_HashNotImplemented + PyObject_Init=python37.PyObject_Init + PyObject_InitVar=python37.PyObject_InitVar + PyObject_IsInstance=python37.PyObject_IsInstance + PyObject_IsSubclass=python37.PyObject_IsSubclass + PyObject_IsTrue=python37.PyObject_IsTrue + PyObject_Length=python37.PyObject_Length + PyObject_Malloc=python37.PyObject_Malloc + PyObject_Not=python37.PyObject_Not + PyObject_Realloc=python37.PyObject_Realloc + PyObject_Repr=python37.PyObject_Repr + PyObject_RichCompare=python37.PyObject_RichCompare + PyObject_RichCompareBool=python37.PyObject_RichCompareBool + PyObject_SelfIter=python37.PyObject_SelfIter + PyObject_SetAttr=python37.PyObject_SetAttr + PyObject_SetAttrString=python37.PyObject_SetAttrString + PyObject_SetItem=python37.PyObject_SetItem + PyObject_Size=python37.PyObject_Size + PyObject_Str=python37.PyObject_Str + PyObject_Type=python37.PyObject_Type DATA + PyODict_DelItem=python37.PyODict_DelItem + PyODict_New=python37.PyODict_New + PyODict_SetItem=python37.PyODict_SetItem + PyODict_Type=python37.PyODict_Type DATA + PyODictItems_Type=python37.PyODictItems_Type DATA + PyODictIter_Type=python37.PyODictIter_Type DATA + PyODictKeys_Type=python37.PyODictKeys_Type DATA + PyODictValues_Type=python37.PyODictValues_Type DATA + PyParser_SimpleParseFileFlags=python37.PyParser_SimpleParseFileFlags + PyParser_SimpleParseStringFlags=python37.PyParser_SimpleParseStringFlags + PyProperty_Type=python37.PyProperty_Type DATA + PyRangeIter_Type=python37.PyRangeIter_Type DATA + PyRange_Type=python37.PyRange_Type DATA + PyReversed_Type=python37.PyReversed_Type DATA + PySeqIter_New=python37.PySeqIter_New + PySeqIter_Type=python37.PySeqIter_Type DATA + PySequence_Check=python37.PySequence_Check + PySequence_Concat=python37.PySequence_Concat + PySequence_Contains=python37.PySequence_Contains + PySequence_Count=python37.PySequence_Count + PySequence_DelItem=python37.PySequence_DelItem + PySequence_DelSlice=python37.PySequence_DelSlice + PySequence_Fast=python37.PySequence_Fast + PySequence_GetItem=python37.PySequence_GetItem + PySequence_GetSlice=python37.PySequence_GetSlice + PySequence_In=python37.PySequence_In + PySequence_InPlaceConcat=python37.PySequence_InPlaceConcat + PySequence_InPlaceRepeat=python37.PySequence_InPlaceRepeat + PySequence_Index=python37.PySequence_Index + PySequence_Length=python37.PySequence_Length + PySequence_List=python37.PySequence_List + PySequence_Repeat=python37.PySequence_Repeat + PySequence_SetItem=python37.PySequence_SetItem + PySequence_SetSlice=python37.PySequence_SetSlice + PySequence_Size=python37.PySequence_Size + PySequence_Tuple=python37.PySequence_Tuple + PySetIter_Type=python37.PySetIter_Type DATA + PySet_Add=python37.PySet_Add + PySet_Clear=python37.PySet_Clear + PySet_Contains=python37.PySet_Contains + PySet_Discard=python37.PySet_Discard + PySet_New=python37.PySet_New + PySet_Pop=python37.PySet_Pop + PySet_Size=python37.PySet_Size + PySet_Type=python37.PySet_Type DATA + PySlice_GetIndices=python37.PySlice_GetIndices + PySlice_GetIndicesEx=python37.PySlice_GetIndicesEx + PySlice_New=python37.PySlice_New + PySlice_Type=python37.PySlice_Type DATA + PySortWrapper_Type=python37.PySortWrapper_Type DATA + PyState_FindModule=python37.PyState_FindModule + PyState_AddModule=python37.PyState_AddModule + PyState_RemoveModule=python37.PyState_RemoveModule + PyStructSequence_GetItem=python37.PyStructSequence_GetItem + PyStructSequence_New=python37.PyStructSequence_New + PyStructSequence_NewType=python37.PyStructSequence_NewType + PyStructSequence_SetItem=python37.PyStructSequence_SetItem + PySuper_Type=python37.PySuper_Type DATA + PySys_AddWarnOption=python37.PySys_AddWarnOption + PySys_AddWarnOptionUnicode=python37.PySys_AddWarnOptionUnicode + PySys_FormatStderr=python37.PySys_FormatStderr + PySys_FormatStdout=python37.PySys_FormatStdout + PySys_GetObject=python37.PySys_GetObject + PySys_HasWarnOptions=python37.PySys_HasWarnOptions + PySys_ResetWarnOptions=python37.PySys_ResetWarnOptions + PySys_SetArgv=python37.PySys_SetArgv + PySys_SetArgvEx=python37.PySys_SetArgvEx + PySys_SetObject=python37.PySys_SetObject + PySys_SetPath=python37.PySys_SetPath + PySys_WriteStderr=python37.PySys_WriteStderr + PySys_WriteStdout=python37.PySys_WriteStdout + PyThreadState_Clear=python37.PyThreadState_Clear + PyThreadState_Delete=python37.PyThreadState_Delete + PyThreadState_DeleteCurrent=python37.PyThreadState_DeleteCurrent + PyThreadState_Get=python37.PyThreadState_Get + PyThreadState_GetDict=python37.PyThreadState_GetDict + PyThreadState_New=python37.PyThreadState_New + PyThreadState_SetAsyncExc=python37.PyThreadState_SetAsyncExc + PyThreadState_Swap=python37.PyThreadState_Swap + PyTraceBack_Here=python37.PyTraceBack_Here + PyTraceBack_Print=python37.PyTraceBack_Print + PyTraceBack_Type=python37.PyTraceBack_Type DATA + PyTupleIter_Type=python37.PyTupleIter_Type DATA + PyTuple_ClearFreeList=python37.PyTuple_ClearFreeList + PyTuple_GetItem=python37.PyTuple_GetItem + PyTuple_GetSlice=python37.PyTuple_GetSlice + PyTuple_New=python37.PyTuple_New + PyTuple_Pack=python37.PyTuple_Pack + PyTuple_SetItem=python37.PyTuple_SetItem + PyTuple_Size=python37.PyTuple_Size + PyTuple_Type=python37.PyTuple_Type DATA + PyType_ClearCache=python37.PyType_ClearCache + PyType_FromSpec=python37.PyType_FromSpec + PyType_FromSpecWithBases=python37.PyType_FromSpecWithBases + PyType_GenericAlloc=python37.PyType_GenericAlloc + PyType_GenericNew=python37.PyType_GenericNew + PyType_GetFlags=python37.PyType_GetFlags + PyType_GetSlot=python37.PyType_GetSlot + PyType_IsSubtype=python37.PyType_IsSubtype + PyType_Modified=python37.PyType_Modified + PyType_Ready=python37.PyType_Ready + PyType_Type=python37.PyType_Type DATA + PyUnicodeDecodeError_Create=python37.PyUnicodeDecodeError_Create + PyUnicodeDecodeError_GetEncoding=python37.PyUnicodeDecodeError_GetEncoding + PyUnicodeDecodeError_GetEnd=python37.PyUnicodeDecodeError_GetEnd + PyUnicodeDecodeError_GetObject=python37.PyUnicodeDecodeError_GetObject + PyUnicodeDecodeError_GetReason=python37.PyUnicodeDecodeError_GetReason + PyUnicodeDecodeError_GetStart=python37.PyUnicodeDecodeError_GetStart + PyUnicodeDecodeError_SetEnd=python37.PyUnicodeDecodeError_SetEnd + PyUnicodeDecodeError_SetReason=python37.PyUnicodeDecodeError_SetReason + PyUnicodeDecodeError_SetStart=python37.PyUnicodeDecodeError_SetStart + PyUnicodeEncodeError_GetEncoding=python37.PyUnicodeEncodeError_GetEncoding + PyUnicodeEncodeError_GetEnd=python37.PyUnicodeEncodeError_GetEnd + PyUnicodeEncodeError_GetObject=python37.PyUnicodeEncodeError_GetObject + PyUnicodeEncodeError_GetReason=python37.PyUnicodeEncodeError_GetReason + PyUnicodeEncodeError_GetStart=python37.PyUnicodeEncodeError_GetStart + PyUnicodeEncodeError_SetEnd=python37.PyUnicodeEncodeError_SetEnd + PyUnicodeEncodeError_SetReason=python37.PyUnicodeEncodeError_SetReason + PyUnicodeEncodeError_SetStart=python37.PyUnicodeEncodeError_SetStart + PyUnicodeIter_Type=python37.PyUnicodeIter_Type DATA + PyUnicodeTranslateError_GetEnd=python37.PyUnicodeTranslateError_GetEnd + PyUnicodeTranslateError_GetObject=python37.PyUnicodeTranslateError_GetObject + PyUnicodeTranslateError_GetReason=python37.PyUnicodeTranslateError_GetReason + PyUnicodeTranslateError_GetStart=python37.PyUnicodeTranslateError_GetStart + PyUnicodeTranslateError_SetEnd=python37.PyUnicodeTranslateError_SetEnd + PyUnicodeTranslateError_SetReason=python37.PyUnicodeTranslateError_SetReason + PyUnicodeTranslateError_SetStart=python37.PyUnicodeTranslateError_SetStart + PyUnicode_Append=python37.PyUnicode_Append + PyUnicode_AppendAndDel=python37.PyUnicode_AppendAndDel + PyUnicode_AsASCIIString=python37.PyUnicode_AsASCIIString + PyUnicode_AsCharmapString=python37.PyUnicode_AsCharmapString + PyUnicode_AsDecodedObject=python37.PyUnicode_AsDecodedObject + PyUnicode_AsDecodedUnicode=python37.PyUnicode_AsDecodedUnicode + PyUnicode_AsEncodedObject=python37.PyUnicode_AsEncodedObject + PyUnicode_AsEncodedString=python37.PyUnicode_AsEncodedString + PyUnicode_AsEncodedUnicode=python37.PyUnicode_AsEncodedUnicode + PyUnicode_AsLatin1String=python37.PyUnicode_AsLatin1String + PyUnicode_AsRawUnicodeEscapeString=python37.PyUnicode_AsRawUnicodeEscapeString + PyUnicode_AsUTF16String=python37.PyUnicode_AsUTF16String + PyUnicode_AsUTF32String=python37.PyUnicode_AsUTF32String + PyUnicode_AsUTF8String=python37.PyUnicode_AsUTF8String + PyUnicode_AsUnicodeEscapeString=python37.PyUnicode_AsUnicodeEscapeString + PyUnicode_AsWideChar=python37.PyUnicode_AsWideChar + PyUnicode_ClearFreelist=python37.PyUnicode_ClearFreelist + PyUnicode_Compare=python37.PyUnicode_Compare + PyUnicode_Concat=python37.PyUnicode_Concat + PyUnicode_Contains=python37.PyUnicode_Contains + PyUnicode_Count=python37.PyUnicode_Count + PyUnicode_Decode=python37.PyUnicode_Decode + PyUnicode_DecodeASCII=python37.PyUnicode_DecodeASCII + PyUnicode_DecodeCharmap=python37.PyUnicode_DecodeCharmap + PyUnicode_DecodeFSDefault=python37.PyUnicode_DecodeFSDefault + PyUnicode_DecodeFSDefaultAndSize=python37.PyUnicode_DecodeFSDefaultAndSize + PyUnicode_DecodeLatin1=python37.PyUnicode_DecodeLatin1 + PyUnicode_DecodeRawUnicodeEscape=python37.PyUnicode_DecodeRawUnicodeEscape + PyUnicode_DecodeUTF16=python37.PyUnicode_DecodeUTF16 + PyUnicode_DecodeUTF16Stateful=python37.PyUnicode_DecodeUTF16Stateful + PyUnicode_DecodeUTF32=python37.PyUnicode_DecodeUTF32 + PyUnicode_DecodeUTF32Stateful=python37.PyUnicode_DecodeUTF32Stateful + PyUnicode_DecodeUTF8=python37.PyUnicode_DecodeUTF8 + PyUnicode_DecodeUTF8Stateful=python37.PyUnicode_DecodeUTF8Stateful + PyUnicode_DecodeUnicodeEscape=python37.PyUnicode_DecodeUnicodeEscape + PyUnicode_FSConverter=python37.PyUnicode_FSConverter + PyUnicode_FSDecoder=python37.PyUnicode_FSDecoder + PyUnicode_Find=python37.PyUnicode_Find + PyUnicode_Format=python37.PyUnicode_Format + PyUnicode_FromEncodedObject=python37.PyUnicode_FromEncodedObject + PyUnicode_FromFormat=python37.PyUnicode_FromFormat + PyUnicode_FromFormatV=python37.PyUnicode_FromFormatV + PyUnicode_FromObject=python37.PyUnicode_FromObject + PyUnicode_FromOrdinal=python37.PyUnicode_FromOrdinal + PyUnicode_FromString=python37.PyUnicode_FromString + PyUnicode_FromStringAndSize=python37.PyUnicode_FromStringAndSize + PyUnicode_FromWideChar=python37.PyUnicode_FromWideChar + PyUnicode_GetDefaultEncoding=python37.PyUnicode_GetDefaultEncoding + PyUnicode_GetSize=python37.PyUnicode_GetSize + PyUnicode_IsIdentifier=python37.PyUnicode_IsIdentifier + PyUnicode_Join=python37.PyUnicode_Join + PyUnicode_Partition=python37.PyUnicode_Partition + PyUnicode_RPartition=python37.PyUnicode_RPartition + PyUnicode_RSplit=python37.PyUnicode_RSplit + PyUnicode_Replace=python37.PyUnicode_Replace + PyUnicode_Resize=python37.PyUnicode_Resize + PyUnicode_RichCompare=python37.PyUnicode_RichCompare + PyUnicode_SetDefaultEncoding=python37.PyUnicode_SetDefaultEncoding + PyUnicode_Split=python37.PyUnicode_Split + PyUnicode_Splitlines=python37.PyUnicode_Splitlines + PyUnicode_Tailmatch=python37.PyUnicode_Tailmatch + PyUnicode_Translate=python37.PyUnicode_Translate + PyUnicode_BuildEncodingMap=python37.PyUnicode_BuildEncodingMap + PyUnicode_CompareWithASCIIString=python37.PyUnicode_CompareWithASCIIString + PyUnicode_DecodeUTF7=python37.PyUnicode_DecodeUTF7 + PyUnicode_DecodeUTF7Stateful=python37.PyUnicode_DecodeUTF7Stateful + PyUnicode_EncodeFSDefault=python37.PyUnicode_EncodeFSDefault + PyUnicode_InternFromString=python37.PyUnicode_InternFromString + PyUnicode_InternImmortal=python37.PyUnicode_InternImmortal + PyUnicode_InternInPlace=python37.PyUnicode_InternInPlace + PyUnicode_Type=python37.PyUnicode_Type DATA + PyWeakref_GetObject=python37.PyWeakref_GetObject DATA + PyWeakref_NewProxy=python37.PyWeakref_NewProxy + PyWeakref_NewRef=python37.PyWeakref_NewRef + PyWrapperDescr_Type=python37.PyWrapperDescr_Type DATA + PyWrapper_New=python37.PyWrapper_New + PyZip_Type=python37.PyZip_Type DATA + Py_AddPendingCall=python37.Py_AddPendingCall + Py_AtExit=python37.Py_AtExit + Py_BuildValue=python37.Py_BuildValue + Py_CompileString=python37.Py_CompileString + Py_DecRef=python37.Py_DecRef + Py_EndInterpreter=python37.Py_EndInterpreter + Py_Exit=python37.Py_Exit + Py_FatalError=python37.Py_FatalError + Py_FileSystemDefaultEncoding=python37.Py_FileSystemDefaultEncoding DATA + Py_Finalize=python37.Py_Finalize + Py_FinalizeEx=python37.Py_FinalizeEx + Py_GetBuildInfo=python37.Py_GetBuildInfo + Py_GetCompiler=python37.Py_GetCompiler + Py_GetCopyright=python37.Py_GetCopyright + Py_GetExecPrefix=python37.Py_GetExecPrefix + Py_GetPath=python37.Py_GetPath + Py_GetPlatform=python37.Py_GetPlatform + Py_GetPrefix=python37.Py_GetPrefix + Py_GetProgramFullPath=python37.Py_GetProgramFullPath + Py_GetProgramName=python37.Py_GetProgramName + Py_GetPythonHome=python37.Py_GetPythonHome + Py_GetRecursionLimit=python37.Py_GetRecursionLimit + Py_GetVersion=python37.Py_GetVersion + Py_HasFileSystemDefaultEncoding=python37.Py_HasFileSystemDefaultEncoding DATA + Py_IncRef=python37.Py_IncRef + Py_Initialize=python37.Py_Initialize + Py_InitializeEx=python37.Py_InitializeEx + Py_IsInitialized=python37.Py_IsInitialized + Py_Main=python37.Py_Main + Py_MakePendingCalls=python37.Py_MakePendingCalls + Py_NewInterpreter=python37.Py_NewInterpreter + Py_ReprEnter=python37.Py_ReprEnter + Py_ReprLeave=python37.Py_ReprLeave + Py_SetProgramName=python37.Py_SetProgramName + Py_SetPythonHome=python37.Py_SetPythonHome + Py_SetRecursionLimit=python37.Py_SetRecursionLimit + Py_SymtableString=python37.Py_SymtableString + Py_VaBuildValue=python37.Py_VaBuildValue + _PyErr_BadInternalCall=python37._PyErr_BadInternalCall + _PyObject_CallFunction_SizeT=python37._PyObject_CallFunction_SizeT + _PyObject_CallMethod_SizeT=python37._PyObject_CallMethod_SizeT + _PyObject_GC_Malloc=python37._PyObject_GC_Malloc + _PyObject_GC_New=python37._PyObject_GC_New + _PyObject_GC_NewVar=python37._PyObject_GC_NewVar + _PyObject_GC_Resize=python37._PyObject_GC_Resize + _PyObject_New=python37._PyObject_New + _PyObject_NewVar=python37._PyObject_NewVar + _PyState_AddModule=python37._PyState_AddModule + _PyThreadState_Init=python37._PyThreadState_Init + _PyThreadState_Prealloc=python37._PyThreadState_Prealloc + _PyTrash_delete_later=python37._PyTrash_delete_later DATA + _PyTrash_delete_nesting=python37._PyTrash_delete_nesting DATA + _PyTrash_deposit_object=python37._PyTrash_deposit_object + _PyTrash_destroy_chain=python37._PyTrash_destroy_chain + _PyWeakref_CallableProxyType=python37._PyWeakref_CallableProxyType DATA + _PyWeakref_ProxyType=python37._PyWeakref_ProxyType DATA + _PyWeakref_RefType=python37._PyWeakref_RefType DATA + _Py_BuildValue_SizeT=python37._Py_BuildValue_SizeT + _Py_CheckRecursionLimit=python37._Py_CheckRecursionLimit DATA + _Py_CheckRecursiveCall=python37._Py_CheckRecursiveCall + _Py_Dealloc=python37._Py_Dealloc + _Py_EllipsisObject=python37._Py_EllipsisObject DATA + _Py_FalseStruct=python37._Py_FalseStruct DATA + _Py_NoneStruct=python37._Py_NoneStruct DATA + _Py_NotImplementedStruct=python37._Py_NotImplementedStruct DATA + _Py_SwappedOp=python37._Py_SwappedOp DATA + _Py_TrueStruct=python37._Py_TrueStruct DATA + _Py_VaBuildValue_SizeT=python37._Py_VaBuildValue_SizeT + _PyArg_Parse_SizeT=python37._PyArg_Parse_SizeT + _PyArg_ParseTuple_SizeT=python37._PyArg_ParseTuple_SizeT + _PyArg_ParseTupleAndKeywords_SizeT=python37._PyArg_ParseTupleAndKeywords_SizeT + _PyArg_VaParse_SizeT=python37._PyArg_VaParse_SizeT + _PyArg_VaParseTupleAndKeywords_SizeT=python37._PyArg_VaParseTupleAndKeywords_SizeT + _Py_BuildValue_SizeT=python37._Py_BuildValue_SizeT diff --git a/PCbuild/prepare_ssl.bat b/PCbuild/prepare_ssl.bat index 2f41ae8..33f878e 100644 --- a/PCbuild/prepare_ssl.bat +++ b/PCbuild/prepare_ssl.bat @@ -3,10 +3,10 @@ if not defined HOST_PYTHON ( if "%1" EQU "Debug" (
shift
set HOST_PYTHON=python_d.exe
- if not exist python36_d.dll exit 1
+ if not exist python37_d.dll exit 1
) ELSE (
set HOST_PYTHON=python.exe
- if not exist python36.dll exit 1
+ if not exist python37.dll exit 1
)
)
%HOST_PYTHON% "%~dp0prepare_ssl.py" %1
diff --git a/PCbuild/readme.txt b/PCbuild/readme.txt index 34c2efe..f3a8ba6 100644 --- a/PCbuild/readme.txt +++ b/PCbuild/readme.txt @@ -48,7 +48,7 @@ Debug Used to build Python with extra debugging capabilities, equivalent
to using ./configure --with-pydebug on UNIX. All binaries built
using this configuration have "_d" added to their name:
- python36_d.dll, python_d.exe, parser_d.pyd, and so on. Both the
+ python37_d.dll, python_d.exe, parser_d.pyd, and so on. Both the
build and rt (run test) batch files in this directory accept a -d
option for debug builds. If you are building Python to help with
development of CPython, you will most likely use this configuration.
@@ -1,5 +1,5 @@ -This is Python version 3.6.0 beta 1 -=================================== +This is Python version 3.7.0 alpha 1 +==================================== Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016 Python Software Foundation. All rights reserved. @@ -89,9 +89,9 @@ What's New ---------- We have a comprehensive overview of the changes in the "What's New in -Python 3.6" document, found at +Python 3.7" document, found at - https://docs.python.org/3.6/whatsnew/3.6.html + https://docs.python.org/3.7/whatsnew/3.7.html For a more detailed change log, read Misc/NEWS (though this file, too, is incomplete, and also doesn't list anything merged in from the 2.7 @@ -104,9 +104,9 @@ entitled "Installing multiple versions". Documentation ------------- -Documentation for Python 3.6 is online, updated daily: +Documentation for Python 3.7 is online, updated daily: - https://docs.python.org/3.6/ + https://docs.python.org/3.7/ It can also be downloaded in many formats for faster access. The documentation is downloadable in HTML, PDF, and reStructuredText formats; the latter version @@ -131,7 +131,7 @@ backported versions of certain key Python 3.x features. A source-to-source translation tool, "2to3", can take care of the mundane task of converting large amounts of source code. It is not a complete solution but is complemented by the deprecation warnings in 2.6. See -https://docs.python.org/3.6/library/2to3.html for more information. +https://docs.python.org/3.7/library/2to3.html for more information. Testing @@ -170,7 +170,7 @@ same prefix you must decide which version (if any) is your "primary" version. Install that version using "make install". Install all other versions using "make altinstall". -For example, if you want to install Python 2.6, 2.7 and 3.6 with 2.7 being the +For example, if you want to install Python 2.6, 2.7 and 3.7 with 2.7 being the primary version, you would execute "make install" in your 2.7 build directory and "make altinstall" in the others. diff --git a/Tools/README b/Tools/README index 0d961de..73ce6a7 100644 --- a/Tools/README +++ b/Tools/README @@ -23,8 +23,6 @@ msi Support for packaging Python as an MSI package on Windows. parser Un-parsing tool to generate code from an AST. -pybench Low-level benchmarking for the Python evaluation loop. (*) - pynche A Tkinter-based color editor. scripts A number of useful single-file programs, e.g. tabnanny.py diff --git a/Tools/msi/buildrelease.bat b/Tools/msi/buildrelease.bat index 710acac..43ac7a8 100644 --- a/Tools/msi/buildrelease.bat +++ b/Tools/msi/buildrelease.bat @@ -78,7 +78,7 @@ where hg /q || echo Cannot find Mercurial on PATH && exit /B 1 where dlltool /q && goto skipdlltoolsearch
set _DLLTOOL_PATH=
-where /R "%EXTERNALS%\" dlltool > "%TEMP%\dlltool.loc" 2> nul && set /P _DLLTOOL_PATH= < "%TEMP%\dlltool.loc" & del "%TEMP%\dlltool.loc"
+where /R "%EXTERNALS%\" dlltool > "%TEMP%\dlltool.loc" 2> nul && set /P _DLLTOOL_PATH= < "%TEMP%\dlltool.loc" & del "%TEMP%\dlltool.loc"
if not exist "%_DLLTOOL_PATH%" echo Cannot find binutils on PATH or in external && exit /B 1
for %%f in (%_DLLTOOL_PATH%) do set PATH=%PATH%;%%~dpf
set _DLLTOOL_PATH=
@@ -143,13 +143,13 @@ if not "%SKIPBUILD%" EQU "1" ( @if errorlevel 1 exit /B
@rem build.bat turns echo back on, so we disable it again
@echo off
-
+
if "%PGO%" EQU "" (
@call "%PCBUILD%build.bat" -e -p %BUILD_PLAT% -t %TARGET% %CERTOPTS%
) else (
@call "%PCBUILD%build.bat" -e -p %BUILD_PLAT% -c PGInstrument -t %TARGET% %CERTOPTS%
@if errorlevel 1 exit /B
-
+
@del "%BUILD%*.pgc"
if "%PGO%" EQU "default" (
"%BUILD%python.exe" -m test -q --pgo
@@ -158,12 +158,10 @@ if not "%SKIPBUILD%" EQU "1" ( "%BUILD%python.exe" -m test -r -q --pgo
) else if "%PGO%" EQU "default10" (
for /L %%i in (0, 1, 9) do "%BUILD%python.exe" -m test -q -r --pgo
- ) else if "%PGO%" EQU "pybench" (
- "%BUILD%python.exe" "%PCBUILD%..\Tools\pybench\pybench.py"
) else (
"%BUILD%python.exe" %PGO%
)
-
+
@call "%PCBUILD%build.bat" -e -p %BUILD_PLAT% -c PGUpdate -t Build %CERTOPTS%
)
@if errorlevel 1 exit /B
@@ -214,7 +212,6 @@ echo Shortcut Description echo default Test suite with --pgo
echo default2 2x test suite with --pgo and randomized test order
echo default10 10x test suite with --pgo and randomized test order
-echo pybench pybench script
echo.
echo The following substitutions will be applied to the download URL:
echo Variable Description Example
diff --git a/Tools/pybench/Arithmetic.py b/Tools/pybench/Arithmetic.py deleted file mode 100644 index d4766a7..0000000 --- a/Tools/pybench/Arithmetic.py +++ /dev/null @@ -1,777 +0,0 @@ -from pybench import Test - -class SimpleIntegerArithmetic(Test): - - version = 2.0 - operations = 5 * (3 + 5 + 5 + 3 + 3 + 3) - rounds = 120000 - - def test(self): - - for i in range(self.rounds): - - a = 2 - b = 3 - c = 3 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - def calibrate(self): - - for i in range(self.rounds): - pass - -class SimpleFloatArithmetic(Test): - - version = 2.0 - operations = 5 * (3 + 5 + 5 + 3 + 3 + 3) - rounds = 120000 - - def test(self): - - for i in range(self.rounds): - - a = 2.1 - b = 3.3332 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2.1 - b = 3.3332 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2.1 - b = 3.3332 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2.1 - b = 3.3332 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2.1 - b = 3.3332 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - def calibrate(self): - - for i in range(self.rounds): - pass - -class SimpleIntFloatArithmetic(Test): - - version = 2.0 - operations = 5 * (3 + 5 + 5 + 3 + 3 + 3) - rounds = 120000 - - def test(self): - - for i in range(self.rounds): - - a = 2 - b = 3 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 - b = 3 - c = 3.14159 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class SimpleLongArithmetic(Test): - - version = 2.0 - operations = 5 * (3 + 5 + 5 + 3 + 3 + 3) - rounds = 60000 - - def test(self): - - for i in range(self.rounds): - - a = 2220001 - b = 100001 - c = 30005 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2220001 - b = 100001 - c = 30005 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2220001 - b = 100001 - c = 30005 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2220001 - b = 100001 - c = 30005 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2220001 - b = 100001 - c = 30005 - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - def calibrate(self): - - for i in range(self.rounds): - pass - -class SimpleComplexArithmetic(Test): - - version = 2.0 - operations = 5 * (3 + 5 + 5 + 3 + 3 + 3) - rounds = 80000 - - def test(self): - - for i in range(self.rounds): - - a = 2 + 3j - b = 2.5 + 4.5j - c = 1.2 + 6.2j - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 + 3j - b = 2.5 + 4.5j - c = 1.2 + 6.2j - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 + 3j - b = 2.5 + 4.5j - c = 1.2 + 6.2j - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 + 3j - b = 2.5 + 4.5j - c = 1.2 + 6.2j - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - a = 2 + 3j - b = 2.5 + 4.5j - c = 1.2 + 6.2j - - c = a + b - c = b + c - c = c + a - c = a + b - c = b + c - - c = c - a - c = a - b - c = b - c - c = c - a - c = b - c - - c = a / b - c = b / a - c = c / b - - c = a * b - c = b * a - c = c * b - - c = a / b - c = b / a - c = c / b - - def calibrate(self): - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Calls.py b/Tools/pybench/Calls.py deleted file mode 100644 index 2e6da18..0000000 --- a/Tools/pybench/Calls.py +++ /dev/null @@ -1,560 +0,0 @@ -from pybench import Test - -class PythonFunctionCalls(Test): - - version = 2.1 - operations = 5*(1+4+4+2) - rounds = 60000 - - def test(self): - - global f,f1,g,h - - # define functions - def f(): - pass - - def f1(x): - pass - - def g(a,b,c): - return a,b,c - - def h(a,b,c,d=1,e=2,f=3): - return d,e,f - - # do calls - for i in range(self.rounds): - - f() - f1(i) - f1(i) - f1(i) - f1(i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - h(i,i,3,i,i) - h(i,i,i,2,i,3) - - f() - f1(i) - f1(i) - f1(i) - f1(i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - h(i,i,3,i,i) - h(i,i,i,2,i,3) - - f() - f1(i) - f1(i) - f1(i) - f1(i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - h(i,i,3,i,i) - h(i,i,i,2,i,3) - - f() - f1(i) - f1(i) - f1(i) - f1(i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - h(i,i,3,i,i) - h(i,i,i,2,i,3) - - f() - f1(i) - f1(i) - f1(i) - f1(i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - g(i,i,i) - h(i,i,3,i,i) - h(i,i,i,2,i,3) - - def calibrate(self): - - global f,f1,g,h - - # define functions - def f(): - pass - - def f1(x): - pass - - def g(a,b,c): - return a,b,c - - def h(a,b,c,d=1,e=2,f=3): - return d,e,f - - # do calls - for i in range(self.rounds): - pass - -### - -class ComplexPythonFunctionCalls(Test): - - version = 2.0 - operations = 4*5 - rounds = 100000 - - def test(self): - - # define functions - def f(a,b,c,d=1,e=2,f=3): - return f - - args = 1,2 - kwargs = dict(c=3,d=4,e=5) - - # do calls - for i in range(self.rounds): - f(a=i,b=i,c=i) - f(f=i,e=i,d=i,c=2,b=i,a=3) - f(1,b=i,**kwargs) - f(*args,**kwargs) - - f(a=i,b=i,c=i) - f(f=i,e=i,d=i,c=2,b=i,a=3) - f(1,b=i,**kwargs) - f(*args,**kwargs) - - f(a=i,b=i,c=i) - f(f=i,e=i,d=i,c=2,b=i,a=3) - f(1,b=i,**kwargs) - f(*args,**kwargs) - - f(a=i,b=i,c=i) - f(f=i,e=i,d=i,c=2,b=i,a=3) - f(1,b=i,**kwargs) - f(*args,**kwargs) - - f(a=i,b=i,c=i) - f(f=i,e=i,d=i,c=2,b=i,a=3) - f(1,b=i,**kwargs) - f(*args,**kwargs) - - - def calibrate(self): - - # define functions - def f(a,b,c,d=1,e=2,f=3): - return f - - args = 1,2 - kwargs = dict(c=3,d=4,e=5) - - # do calls - for i in range(self.rounds): - pass - -### - -class BuiltinFunctionCalls(Test): - - version = 2.0 - operations = 5*(2+5+5+5) - rounds = 60000 - - def test(self): - - # localize functions - f0 = globals - f1 = hash - f2 = divmod - f3 = max - - # do calls - for i in range(self.rounds): - - f0() - f0() - f1(i) - f1(i) - f1(i) - f1(i) - f1(i) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - - f0() - f0() - f1(i) - f1(i) - f1(i) - f1(i) - f1(i) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - - f0() - f0() - f1(i) - f1(i) - f1(i) - f1(i) - f1(i) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - - f0() - f0() - f1(i) - f1(i) - f1(i) - f1(i) - f1(i) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - - f0() - f0() - f1(i) - f1(i) - f1(i) - f1(i) - f1(i) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f2(1,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - f3(1,3,2) - - def calibrate(self): - - # localize functions - f0 = dir - f1 = hash - f2 = divmod - f3 = max - - # do calls - for i in range(self.rounds): - pass - -### - -class PythonMethodCalls(Test): - - version = 2.0 - operations = 5*(6 + 5 + 4) - rounds = 30000 - - def test(self): - - class c: - - x = 2 - s = 'string' - - def f(self): - - return self.x - - def j(self,a,b): - - self.y = a - self.t = b - return self.y - - def k(self,a,b,c=3): - - self.y = a - self.s = b - self.t = c - - o = c() - - for i in range(self.rounds): - - o.f() - o.f() - o.f() - o.f() - o.f() - o.f() - o.j(i,i) - o.j(i,i) - o.j(i,2) - o.j(i,2) - o.j(2,2) - o.k(i,i) - o.k(i,2) - o.k(i,2,3) - o.k(i,i,c=4) - - o.f() - o.f() - o.f() - o.f() - o.f() - o.f() - o.j(i,i) - o.j(i,i) - o.j(i,2) - o.j(i,2) - o.j(2,2) - o.k(i,i) - o.k(i,2) - o.k(i,2,3) - o.k(i,i,c=4) - - o.f() - o.f() - o.f() - o.f() - o.f() - o.f() - o.j(i,i) - o.j(i,i) - o.j(i,2) - o.j(i,2) - o.j(2,2) - o.k(i,i) - o.k(i,2) - o.k(i,2,3) - o.k(i,i,c=4) - - o.f() - o.f() - o.f() - o.f() - o.f() - o.f() - o.j(i,i) - o.j(i,i) - o.j(i,2) - o.j(i,2) - o.j(2,2) - o.k(i,i) - o.k(i,2) - o.k(i,2,3) - o.k(i,i,c=4) - - o.f() - o.f() - o.f() - o.f() - o.f() - o.f() - o.j(i,i) - o.j(i,i) - o.j(i,2) - o.j(i,2) - o.j(2,2) - o.k(i,i) - o.k(i,2) - o.k(i,2,3) - o.k(i,i,c=4) - - def calibrate(self): - - class c: - - x = 2 - s = 'string' - - def f(self): - - return self.x - - def j(self,a,b): - - self.y = a - self.t = b - - def k(self,a,b,c=3): - - self.y = a - self.s = b - self.t = c - - o = c - - for i in range(self.rounds): - pass - -### - -class Recursion(Test): - - version = 2.0 - operations = 5 - rounds = 100000 - - def test(self): - - global f - - def f(x): - - if x > 1: - return f(x-1) - return 1 - - for i in range(self.rounds): - f(10) - f(10) - f(10) - f(10) - f(10) - - def calibrate(self): - - global f - - def f(x): - - if x > 0: - return f(x-1) - return 1 - - for i in range(self.rounds): - pass - - -### Test to make Fredrik happy... - -if __name__ == '__main__': - import timeit - if 0: - timeit.TestClass = PythonFunctionCalls - timeit.main(['-s', 'test = TestClass(); test.rounds = 1000', - 'test.test()']) - else: - setup = """\ -global f,f1,g,h - -# define functions -def f(): - pass - -def f1(x): - pass - -def g(a,b,c): - return a,b,c - -def h(a,b,c,d=1,e=2,f=3): - return d,e,f - -i = 1 -""" - test = """\ -f() -f1(i) -f1(i) -f1(i) -f1(i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -h(i,i,3,i,i) -h(i,i,i,2,i,3) - -f() -f1(i) -f1(i) -f1(i) -f1(i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -h(i,i,3,i,i) -h(i,i,i,2,i,3) - -f() -f1(i) -f1(i) -f1(i) -f1(i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -h(i,i,3,i,i) -h(i,i,i,2,i,3) - -f() -f1(i) -f1(i) -f1(i) -f1(i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -h(i,i,3,i,i) -h(i,i,i,2,i,3) - -f() -f1(i) -f1(i) -f1(i) -f1(i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -g(i,i,i) -h(i,i,3,i,i) -h(i,i,i,2,i,3) -""" - - timeit.main(['-s', setup, - test]) diff --git a/Tools/pybench/CommandLine.py b/Tools/pybench/CommandLine.py deleted file mode 100644 index 54a8ba7..0000000 --- a/Tools/pybench/CommandLine.py +++ /dev/null @@ -1,642 +0,0 @@ -""" CommandLine - Get and parse command line options - - NOTE: This still is very much work in progress !!! - - Different version are likely to be incompatible. - - TODO: - - * Incorporate the changes made by (see Inbox) - * Add number range option using srange() - -""" - -from __future__ import print_function - -__copyright__ = """\ -Copyright (c), 1997-2006, Marc-Andre Lemburg (mal@lemburg.com) -Copyright (c), 2000-2006, eGenix.com Software GmbH (info@egenix.com) -See the documentation for further information on copyrights, -or contact the author. All Rights Reserved. -""" - -__version__ = '1.2' - -import sys, getopt, glob, os, re, traceback - -### Helpers - -def _getopt_flags(options): - - """ Convert the option list to a getopt flag string and long opt - list - - """ - s = [] - l = [] - for o in options: - if o.prefix == '-': - # short option - s.append(o.name) - if o.takes_argument: - s.append(':') - else: - # long option - if o.takes_argument: - l.append(o.name+'=') - else: - l.append(o.name) - return ''.join(s), l - -def invisible_input(prompt='>>> '): - - """ Get raw input from a terminal without echoing the characters to - the terminal, e.g. for password queries. - - """ - import getpass - entry = getpass.getpass(prompt) - if entry is None: - raise KeyboardInterrupt - return entry - -def fileopen(name, mode='wb', encoding=None): - - """ Open a file using mode. - - Default mode is 'wb' meaning to open the file for writing in - binary mode. If encoding is given, I/O to and from the file is - transparently encoded using the given encoding. - - Files opened for writing are chmod()ed to 0600. - - """ - if name == 'stdout': - return sys.stdout - elif name == 'stderr': - return sys.stderr - elif name == 'stdin': - return sys.stdin - else: - if encoding is not None: - import codecs - f = codecs.open(name, mode, encoding) - else: - f = open(name, mode) - if 'w' in mode: - os.chmod(name, 0o600) - return f - -def option_dict(options): - - """ Return a dictionary mapping option names to Option instances. - """ - d = {} - for option in options: - d[option.name] = option - return d - -# Alias -getpasswd = invisible_input - -_integerRE = re.compile(r'\s*(-?\d+)\s*$') -_integerRangeRE = re.compile(r'\s*(-?\d+)\s*-\s*(-?\d+)\s*$') - -def srange(s, - - integer=_integerRE, - integerRange=_integerRangeRE): - - """ Converts a textual representation of integer numbers and ranges - to a Python list. - - Supported formats: 2,3,4,2-10,-1 - -3, 5 - -2 - - Values are appended to the created list in the order specified - in the string. - - """ - l = [] - append = l.append - for entry in s.split(','): - m = integer.match(entry) - if m: - append(int(m.groups()[0])) - continue - m = integerRange.match(entry) - if m: - start,end = map(int,m.groups()) - l[len(l):] = range(start,end+1) - return l - -def abspath(path, - - expandvars=os.path.expandvars,expanduser=os.path.expanduser, - join=os.path.join,getcwd=os.getcwd): - - """ Return the corresponding absolute path for path. - - path is expanded in the usual shell ways before - joining it with the current working directory. - - """ - try: - path = expandvars(path) - except AttributeError: - pass - try: - path = expanduser(path) - except AttributeError: - pass - return join(getcwd(), path) - -### Option classes - -class Option: - - """ Option base class. Takes no argument. - - """ - default = None - helptext = '' - prefix = '-' - takes_argument = 0 - has_default = 0 - tab = 15 - - def __init__(self,name,help=None): - - if not name[:1] == '-': - raise TypeError('option names must start with "-"') - if name[1:2] == '-': - self.prefix = '--' - self.name = name[2:] - else: - self.name = name[1:] - if help: - self.help = help - - def __str__(self): - - o = self - name = o.prefix + o.name - if o.takes_argument: - name = name + ' arg' - if len(name) > self.tab: - name = name + '\n' + ' ' * (self.tab + 1 + len(o.prefix)) - else: - name = '%-*s ' % (self.tab, name) - description = o.help - if o.has_default: - description = description + ' (%s)' % o.default - return '%s %s' % (name, description) - -class ArgumentOption(Option): - - """ Option that takes an argument. - - An optional default argument can be given. - - """ - def __init__(self,name,help=None,default=None): - - # Basemethod - Option.__init__(self,name,help) - - if default is not None: - self.default = default - self.has_default = 1 - self.takes_argument = 1 - -class SwitchOption(Option): - - """ Options that can be on or off. Has an optional default value. - - """ - def __init__(self,name,help=None,default=None): - - # Basemethod - Option.__init__(self,name,help) - - if default is not None: - self.default = default - self.has_default = 1 - -### Application baseclass - -class Application: - - """ Command line application interface with builtin argument - parsing. - - """ - # Options the program accepts (Option instances) - options = [] - - # Standard settings; these are appended to options in __init__ - preset_options = [SwitchOption('-v', - 'generate verbose output'), - SwitchOption('-h', - 'show this help text'), - SwitchOption('--help', - 'show this help text'), - SwitchOption('--debug', - 'enable debugging'), - SwitchOption('--copyright', - 'show copyright'), - SwitchOption('--examples', - 'show examples of usage')] - - # The help layout looks like this: - # [header] - defaults to '' - # - # [synopsis] - formatted as '<self.name> %s' % self.synopsis - # - # options: - # [options] - formatted from self.options - # - # [version] - formatted as 'Version:\n %s' % self.version, if given - # - # [about] - defaults to '' - # - # Note: all fields that do not behave as template are formatted - # using the instances dictionary as substitution namespace, - # e.g. %(name)s will be replaced by the applications name. - # - - # Header (default to program name) - header = '' - - # Name (defaults to program name) - name = '' - - # Synopsis (%(name)s is replaced by the program name) - synopsis = '%(name)s [option] files...' - - # Version (optional) - version = '' - - # General information printed after the possible options (optional) - about = '' - - # Examples of usage to show when the --examples option is given (optional) - examples = '' - - # Copyright to show - copyright = __copyright__ - - # Apply file globbing ? - globbing = 1 - - # Generate debug output ? - debug = 0 - - # Generate verbose output ? - verbose = 0 - - # Internal errors to catch - InternalError = BaseException - - # Instance variables: - values = None # Dictionary of passed options (or default values) - # indexed by the options name, e.g. '-h' - files = None # List of passed filenames - optionlist = None # List of passed options - - def __init__(self,argv=None): - - # Setup application specs - if argv is None: - argv = sys.argv - self.filename = os.path.split(argv[0])[1] - if not self.name: - self.name = os.path.split(self.filename)[1] - else: - self.name = self.name - if not self.header: - self.header = self.name - else: - self.header = self.header - - # Init .arguments list - self.arguments = argv[1:] - - # Setup Option mapping - self.option_map = option_dict(self.options) - - # Append preset options - for option in self.preset_options: - if not option.name in self.option_map: - self.add_option(option) - - # Init .files list - self.files = [] - - # Start Application - rc = 0 - try: - # Process startup - rc = self.startup() - if rc is not None: - raise SystemExit(rc) - - # Parse command line - rc = self.parse() - if rc is not None: - raise SystemExit(rc) - - # Start application - rc = self.main() - if rc is None: - rc = 0 - - except SystemExit as rcException: - rc = rcException - pass - - except KeyboardInterrupt: - print() - print('* User Break') - print() - rc = 1 - - except self.InternalError: - print() - print('* Internal Error (use --debug to display the traceback)') - if self.debug: - print() - traceback.print_exc(20, sys.stdout) - elif self.verbose: - print(' %s: %s' % sys.exc_info()[:2]) - print() - rc = 1 - - raise SystemExit(rc) - - def add_option(self, option): - - """ Add a new Option instance to the Application dynamically. - - Note that this has to be done *before* .parse() is being - executed. - - """ - self.options.append(option) - self.option_map[option.name] = option - - def startup(self): - - """ Set user defined instance variables. - - If this method returns anything other than None, the - process is terminated with the return value as exit code. - - """ - return None - - def exit(self, rc=0): - - """ Exit the program. - - rc is used as exit code and passed back to the calling - program. It defaults to 0 which usually means: OK. - - """ - raise SystemExit(rc) - - def parse(self): - - """ Parse the command line and fill in self.values and self.files. - - After having parsed the options, the remaining command line - arguments are interpreted as files and passed to .handle_files() - for processing. - - As final step the option handlers are called in the order - of the options given on the command line. - - """ - # Parse arguments - self.values = values = {} - for o in self.options: - if o.has_default: - values[o.prefix+o.name] = o.default - else: - values[o.prefix+o.name] = 0 - flags,lflags = _getopt_flags(self.options) - try: - optlist,files = getopt.getopt(self.arguments,flags,lflags) - if self.globbing: - l = [] - for f in files: - gf = glob.glob(f) - if not gf: - l.append(f) - else: - l[len(l):] = gf - files = l - self.optionlist = optlist - self.files = files + self.files - except getopt.error as why: - self.help(why) - sys.exit(1) - - # Call file handler - rc = self.handle_files(self.files) - if rc is not None: - sys.exit(rc) - - # Call option handlers - for optionname, value in optlist: - - # Try to convert value to integer - try: - value = int(value) - except ValueError: - pass - - # Find handler and call it (or count the number of option - # instances on the command line) - handlername = 'handle' + optionname.replace('-', '_') - try: - handler = getattr(self, handlername) - except AttributeError: - if value == '': - # count the number of occurrences - if optionname in values: - values[optionname] = values[optionname] + 1 - else: - values[optionname] = 1 - else: - values[optionname] = value - else: - rc = handler(value) - if rc is not None: - raise SystemExit(rc) - - # Apply final file check (for backward compatibility) - rc = self.check_files(self.files) - if rc is not None: - sys.exit(rc) - - def check_files(self,filelist): - - """ Apply some user defined checks on the files given in filelist. - - This may modify filelist in place. A typical application - is checking that at least n files are given. - - If this method returns anything other than None, the - process is terminated with the return value as exit code. - - """ - return None - - def help(self,note=''): - - self.print_header() - if self.synopsis: - print('Synopsis:') - # To remain backward compatible: - try: - synopsis = self.synopsis % self.name - except (NameError, KeyError, TypeError): - synopsis = self.synopsis % self.__dict__ - print(' ' + synopsis) - print() - self.print_options() - if self.version: - print('Version:') - print(' %s' % self.version) - print() - if self.about: - about = self.about % self.__dict__ - print(about.strip()) - print() - if note: - print('-'*72) - print('Note:',note) - print() - - def notice(self,note): - - print('-'*72) - print('Note:',note) - print('-'*72) - print() - - def print_header(self): - - print('-'*72) - print(self.header % self.__dict__) - print('-'*72) - print() - - def print_options(self): - - options = self.options - print('Options and default settings:') - if not options: - print(' None') - return - int = [x for x in options if x.prefix == '--'] - short = [x for x in options if x.prefix == '-'] - items = short + int - for o in options: - print(' ',o) - print() - - # - # Example handlers: - # - # If a handler returns anything other than None, processing stops - # and the return value is passed to sys.exit() as argument. - # - - # File handler - def handle_files(self,files): - - """ This may process the files list in place. - """ - return None - - # Short option handler - def handle_h(self,arg): - - self.help() - return 0 - - def handle_v(self, value): - - """ Turn on verbose output. - """ - self.verbose = 1 - - # Handlers for long options have two underscores in their name - def handle__help(self,arg): - - self.help() - return 0 - - def handle__debug(self,arg): - - self.debug = 1 - # We don't want to catch internal errors: - class NoErrorToCatch(Exception): pass - self.InternalError = NoErrorToCatch - - def handle__copyright(self,arg): - - self.print_header() - copyright = self.copyright % self.__dict__ - print(copyright.strip()) - print() - return 0 - - def handle__examples(self,arg): - - self.print_header() - if self.examples: - print('Examples:') - print() - examples = self.examples % self.__dict__ - print(examples.strip()) - print() - else: - print('No examples available.') - print() - return 0 - - def main(self): - - """ Override this method as program entry point. - - The return value is passed to sys.exit() as argument. If - it is None, 0 is assumed (meaning OK). Unhandled - exceptions are reported with exit status code 1 (see - __init__ for further details). - - """ - return None - -# Alias -CommandLine = Application - -def _test(): - - class MyApplication(Application): - header = 'Test Application' - version = __version__ - options = [Option('-v','verbose')] - - def handle_v(self,arg): - print('VERBOSE, Yeah !') - - cmd = MyApplication() - if not cmd.values['-h']: - cmd.help() - print('files:',cmd.files) - print('Bye...') - -if __name__ == '__main__': - _test() diff --git a/Tools/pybench/Constructs.py b/Tools/pybench/Constructs.py deleted file mode 100644 index 7273b87..0000000 --- a/Tools/pybench/Constructs.py +++ /dev/null @@ -1,564 +0,0 @@ -from pybench import Test - -class IfThenElse(Test): - - version = 2.0 - operations = 30*3 # hard to say... - rounds = 150000 - - def test(self): - - a,b,c = 1,2,3 - for i in range(self.rounds): - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - if a == 1: - if b == 2: - if c != 3: - c = 3 - b = 3 - else: - c = 2 - elif b == 3: - b = 2 - a = 2 - elif a == 2: - a = 3 - else: - a = 1 - - def calibrate(self): - - a,b,c = 1,2,3 - for i in range(self.rounds): - pass - -class NestedForLoops(Test): - - version = 2.0 - operations = 1000*10*5 - rounds = 300 - - def test(self): - - l1 = range(1000) - l2 = range(10) - l3 = range(5) - for i in range(self.rounds): - for i in l1: - for j in l2: - for k in l3: - pass - - def calibrate(self): - - l1 = range(1000) - l2 = range(10) - l3 = range(5) - for i in range(self.rounds): - pass - -class ForLoops(Test): - - version = 2.0 - operations = 5 * 5 - rounds = 10000 - - def test(self): - - l1 = range(100) - for i in range(self.rounds): - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - for i in l1: - pass - - def calibrate(self): - - l1 = range(1000) - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Dict.py b/Tools/pybench/Dict.py deleted file mode 100644 index 575758b..0000000 --- a/Tools/pybench/Dict.py +++ /dev/null @@ -1,504 +0,0 @@ -from pybench import Test - -class DictCreation(Test): - - version = 2.0 - operations = 5*(5 + 5) - rounds = 80000 - - def test(self): - - for i in range(self.rounds): - - d1 = {} - d2 = {} - d3 = {} - d4 = {} - d5 = {} - - d1 = {1:2,3:4,5:6} - d2 = {2:3,4:5,6:7} - d3 = {3:4,5:6,7:8} - d4 = {4:5,6:7,8:9} - d5 = {6:7,8:9,10:11} - - d1 = {} - d2 = {} - d3 = {} - d4 = {} - d5 = {} - - d1 = {1:2,3:4,5:6} - d2 = {2:3,4:5,6:7} - d3 = {3:4,5:6,7:8} - d4 = {4:5,6:7,8:9} - d5 = {6:7,8:9,10:11} - - d1 = {} - d2 = {} - d3 = {} - d4 = {} - d5 = {} - - d1 = {1:2,3:4,5:6} - d2 = {2:3,4:5,6:7} - d3 = {3:4,5:6,7:8} - d4 = {4:5,6:7,8:9} - d5 = {6:7,8:9,10:11} - - d1 = {} - d2 = {} - d3 = {} - d4 = {} - d5 = {} - - d1 = {1:2,3:4,5:6} - d2 = {2:3,4:5,6:7} - d3 = {3:4,5:6,7:8} - d4 = {4:5,6:7,8:9} - d5 = {6:7,8:9,10:11} - - d1 = {} - d2 = {} - d3 = {} - d4 = {} - d5 = {} - - d1 = {1:2,3:4,5:6} - d2 = {2:3,4:5,6:7} - d3 = {3:4,5:6,7:8} - d4 = {4:5,6:7,8:9} - d5 = {6:7,8:9,10:11} - - def calibrate(self): - - for i in range(self.rounds): - pass - -class DictWithStringKeys(Test): - - version = 2.0 - operations = 5*(6 + 6) - rounds = 200000 - - def test(self): - - d = {} - - for i in range(self.rounds): - - d['abc'] = 1 - d['def'] = 2 - d['ghi'] = 3 - d['jkl'] = 4 - d['mno'] = 5 - d['pqr'] = 6 - - d['abc'] - d['def'] - d['ghi'] - d['jkl'] - d['mno'] - d['pqr'] - - d['abc'] = 1 - d['def'] = 2 - d['ghi'] = 3 - d['jkl'] = 4 - d['mno'] = 5 - d['pqr'] = 6 - - d['abc'] - d['def'] - d['ghi'] - d['jkl'] - d['mno'] - d['pqr'] - - d['abc'] = 1 - d['def'] = 2 - d['ghi'] = 3 - d['jkl'] = 4 - d['mno'] = 5 - d['pqr'] = 6 - - d['abc'] - d['def'] - d['ghi'] - d['jkl'] - d['mno'] - d['pqr'] - - d['abc'] = 1 - d['def'] = 2 - d['ghi'] = 3 - d['jkl'] = 4 - d['mno'] = 5 - d['pqr'] = 6 - - d['abc'] - d['def'] - d['ghi'] - d['jkl'] - d['mno'] - d['pqr'] - - d['abc'] = 1 - d['def'] = 2 - d['ghi'] = 3 - d['jkl'] = 4 - d['mno'] = 5 - d['pqr'] = 6 - - d['abc'] - d['def'] - d['ghi'] - d['jkl'] - d['mno'] - d['pqr'] - - def calibrate(self): - - d = {} - - for i in range(self.rounds): - pass - -class DictWithFloatKeys(Test): - - version = 2.0 - operations = 5*(6 + 6) - rounds = 150000 - - def test(self): - - d = {} - - for i in range(self.rounds): - - d[1.234] = 1 - d[2.345] = 2 - d[3.456] = 3 - d[4.567] = 4 - d[5.678] = 5 - d[6.789] = 6 - - d[1.234] - d[2.345] - d[3.456] - d[4.567] - d[5.678] - d[6.789] - - d[1.234] = 1 - d[2.345] = 2 - d[3.456] = 3 - d[4.567] = 4 - d[5.678] = 5 - d[6.789] = 6 - - d[1.234] - d[2.345] - d[3.456] - d[4.567] - d[5.678] - d[6.789] - - d[1.234] = 1 - d[2.345] = 2 - d[3.456] = 3 - d[4.567] = 4 - d[5.678] = 5 - d[6.789] = 6 - - d[1.234] - d[2.345] - d[3.456] - d[4.567] - d[5.678] - d[6.789] - - d[1.234] = 1 - d[2.345] = 2 - d[3.456] = 3 - d[4.567] = 4 - d[5.678] = 5 - d[6.789] = 6 - - d[1.234] - d[2.345] - d[3.456] - d[4.567] - d[5.678] - d[6.789] - - d[1.234] = 1 - d[2.345] = 2 - d[3.456] = 3 - d[4.567] = 4 - d[5.678] = 5 - d[6.789] = 6 - - d[1.234] - d[2.345] - d[3.456] - d[4.567] - d[5.678] - d[6.789] - - def calibrate(self): - - d = {} - - for i in range(self.rounds): - pass - -class DictWithIntegerKeys(Test): - - version = 2.0 - operations = 5*(6 + 6) - rounds = 200000 - - def test(self): - - d = {} - - for i in range(self.rounds): - - d[1] = 1 - d[2] = 2 - d[3] = 3 - d[4] = 4 - d[5] = 5 - d[6] = 6 - - d[1] - d[2] - d[3] - d[4] - d[5] - d[6] - - d[1] = 1 - d[2] = 2 - d[3] = 3 - d[4] = 4 - d[5] = 5 - d[6] = 6 - - d[1] - d[2] - d[3] - d[4] - d[5] - d[6] - - d[1] = 1 - d[2] = 2 - d[3] = 3 - d[4] = 4 - d[5] = 5 - d[6] = 6 - - d[1] - d[2] - d[3] - d[4] - d[5] - d[6] - - d[1] = 1 - d[2] = 2 - d[3] = 3 - d[4] = 4 - d[5] = 5 - d[6] = 6 - - d[1] - d[2] - d[3] - d[4] - d[5] - d[6] - - d[1] = 1 - d[2] = 2 - d[3] = 3 - d[4] = 4 - d[5] = 5 - d[6] = 6 - - d[1] - d[2] - d[3] - d[4] - d[5] - d[6] - - def calibrate(self): - - d = {} - - for i in range(self.rounds): - pass - -class SimpleDictManipulation(Test): - - version = 2.0 - operations = 5*(6 + 6 + 6 + 6) - rounds = 100000 - - def test(self): - - d = {} - has_key = lambda key: key in d - - for i in range(self.rounds): - - d[0] = 3 - d[1] = 4 - d[2] = 5 - d[3] = 3 - d[4] = 4 - d[5] = 5 - - x = d[0] - x = d[1] - x = d[2] - x = d[3] - x = d[4] - x = d[5] - - has_key(0) - has_key(2) - has_key(4) - has_key(6) - has_key(8) - has_key(10) - - del d[0] - del d[1] - del d[2] - del d[3] - del d[4] - del d[5] - - d[0] = 3 - d[1] = 4 - d[2] = 5 - d[3] = 3 - d[4] = 4 - d[5] = 5 - - x = d[0] - x = d[1] - x = d[2] - x = d[3] - x = d[4] - x = d[5] - - has_key(0) - has_key(2) - has_key(4) - has_key(6) - has_key(8) - has_key(10) - - del d[0] - del d[1] - del d[2] - del d[3] - del d[4] - del d[5] - - d[0] = 3 - d[1] = 4 - d[2] = 5 - d[3] = 3 - d[4] = 4 - d[5] = 5 - - x = d[0] - x = d[1] - x = d[2] - x = d[3] - x = d[4] - x = d[5] - - has_key(0) - has_key(2) - has_key(4) - has_key(6) - has_key(8) - has_key(10) - - del d[0] - del d[1] - del d[2] - del d[3] - del d[4] - del d[5] - - d[0] = 3 - d[1] = 4 - d[2] = 5 - d[3] = 3 - d[4] = 4 - d[5] = 5 - - x = d[0] - x = d[1] - x = d[2] - x = d[3] - x = d[4] - x = d[5] - - has_key(0) - has_key(2) - has_key(4) - has_key(6) - has_key(8) - has_key(10) - - del d[0] - del d[1] - del d[2] - del d[3] - del d[4] - del d[5] - - d[0] = 3 - d[1] = 4 - d[2] = 5 - d[3] = 3 - d[4] = 4 - d[5] = 5 - - x = d[0] - x = d[1] - x = d[2] - x = d[3] - x = d[4] - x = d[5] - - has_key(0) - has_key(2) - has_key(4) - has_key(6) - has_key(8) - has_key(10) - - del d[0] - del d[1] - del d[2] - del d[3] - del d[4] - del d[5] - - def calibrate(self): - - d = {} - has_key = lambda key: key in d - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Exceptions.py b/Tools/pybench/Exceptions.py deleted file mode 100644 index c321b2e..0000000 --- a/Tools/pybench/Exceptions.py +++ /dev/null @@ -1,699 +0,0 @@ -from pybench import Test - -class TryRaiseExcept(Test): - - version = 2.0 - operations = 2 + 3 + 3 - rounds = 80000 - - def test(self): - - error = ValueError - - for i in range(self.rounds): - try: - raise error - except: - pass - try: - raise error - except: - pass - try: - raise error("something") - except: - pass - try: - raise error("something") - except: - pass - try: - raise error("something") - except: - pass - try: - raise error("something") - except: - pass - try: - raise error("something") - except: - pass - try: - raise error("something") - except: - pass - - def calibrate(self): - - error = ValueError - - for i in range(self.rounds): - pass - - -class TryExcept(Test): - - version = 2.0 - operations = 15 * 10 - rounds = 150000 - - def test(self): - - for i in range(self.rounds): - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - try: - pass - except: - pass - - def calibrate(self): - - for i in range(self.rounds): - pass - -### Test to make Fredrik happy... - -if __name__ == '__main__': - import timeit - timeit.TestClass = TryRaiseExcept - timeit.main(['-s', 'test = TestClass(); test.rounds = 1000', - 'test.test()']) diff --git a/Tools/pybench/Imports.py b/Tools/pybench/Imports.py deleted file mode 100644 index 399ba17..0000000 --- a/Tools/pybench/Imports.py +++ /dev/null @@ -1,138 +0,0 @@ -from pybench import Test - -# First imports: -import os -import package.submodule - -class SecondImport(Test): - - version = 2.0 - operations = 5 * 5 - rounds = 40000 - - def test(self): - - for i in range(self.rounds): - import os - import os - import os - import os - import os - - import os - import os - import os - import os - import os - - import os - import os - import os - import os - import os - - import os - import os - import os - import os - import os - - import os - import os - import os - import os - import os - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class SecondPackageImport(Test): - - version = 2.0 - operations = 5 * 5 - rounds = 40000 - - def test(self): - - for i in range(self.rounds): - import package - import package - import package - import package - import package - - import package - import package - import package - import package - import package - - import package - import package - import package - import package - import package - - import package - import package - import package - import package - import package - - import package - import package - import package - import package - import package - - def calibrate(self): - - for i in range(self.rounds): - pass - -class SecondSubmoduleImport(Test): - - version = 2.0 - operations = 5 * 5 - rounds = 40000 - - def test(self): - - for i in range(self.rounds): - import package.submodule - import package.submodule - import package.submodule - import package.submodule - import package.submodule - - import package.submodule - import package.submodule - import package.submodule - import package.submodule - import package.submodule - - import package.submodule - import package.submodule - import package.submodule - import package.submodule - import package.submodule - - import package.submodule - import package.submodule - import package.submodule - import package.submodule - import package.submodule - - import package.submodule - import package.submodule - import package.submodule - import package.submodule - import package.submodule - - def calibrate(self): - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Instances.py b/Tools/pybench/Instances.py deleted file mode 100644 index 0a09b7b..0000000 --- a/Tools/pybench/Instances.py +++ /dev/null @@ -1,66 +0,0 @@ -from pybench import Test - -class CreateInstances(Test): - - version = 2.0 - operations = 3 + 7 + 4 - rounds = 80000 - - def test(self): - - class c: - pass - - class d: - def __init__(self,a,b,c): - self.a = a - self.b = b - self.c = c - - class e: - def __init__(self,a,b,c=4): - self.a = a - self.b = b - self.c = c - self.d = a - self.e = b - self.f = c - - for i in range(self.rounds): - o = c() - o1 = c() - o2 = c() - p = d(i,i,3) - p1 = d(i,i,3) - p2 = d(i,3,3) - p3 = d(3,i,3) - p4 = d(i,i,i) - p5 = d(3,i,3) - p6 = d(i,i,i) - q = e(i,i,3) - q1 = e(i,i,3) - q2 = e(i,i,3) - q3 = e(i,i) - - def calibrate(self): - - class c: - pass - - class d: - def __init__(self,a,b,c): - self.a = a - self.b = b - self.c = c - - class e: - def __init__(self,a,b,c=4): - self.a = a - self.b = b - self.c = c - self.d = a - self.e = b - self.f = c - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/LICENSE b/Tools/pybench/LICENSE deleted file mode 100644 index 17c6a6b..0000000 --- a/Tools/pybench/LICENSE +++ /dev/null @@ -1,25 +0,0 @@ -pybench License ---------------- - -This copyright notice and license applies to all files in the pybench -directory of the pybench distribution. - -Copyright (c), 1997-2006, Marc-Andre Lemburg (mal@lemburg.com) -Copyright (c), 2000-2006, eGenix.com Software GmbH (info@egenix.com) - - All Rights Reserved. - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee or royalty is hereby -granted, provided that the above copyright notice appear in all copies -and that both that copyright notice and this permission notice appear -in supporting documentation or portions thereof, including -modifications, that you make. - -THE AUTHOR MARC-ANDRE LEMBURG DISCLAIMS ALL WARRANTIES WITH REGARD TO -THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND -FITNESS, IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, -INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING -FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, -NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE ! diff --git a/Tools/pybench/Lists.py b/Tools/pybench/Lists.py deleted file mode 100644 index 29dabef..0000000 --- a/Tools/pybench/Lists.py +++ /dev/null @@ -1,350 +0,0 @@ -from pybench import Test - -class SimpleListManipulation(Test): - - version = 2.0 - operations = 5* (6 + 6 + 6) - rounds = 130000 - - def test(self): - - l = [] - append = l.append - - for i in range(self.rounds): - - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - x = l[0] - x = l[1] - x = l[2] - x = l[3] - x = l[4] - x = l[5] - - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - x = l[0] - x = l[1] - x = l[2] - x = l[3] - x = l[4] - x = l[5] - - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - x = l[0] - x = l[1] - x = l[2] - x = l[3] - x = l[4] - x = l[5] - - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - x = l[0] - x = l[1] - x = l[2] - x = l[3] - x = l[4] - x = l[5] - - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - x = l[0] - x = l[1] - x = l[2] - x = l[3] - x = l[4] - x = l[5] - - if len(l) > 10000: - # cut down the size - del l[:] - - def calibrate(self): - - l = [] - append = l.append - - for i in range(self.rounds): - pass - -class ListSlicing(Test): - - version = 2.0 - operations = 25*(3+1+2+1) - rounds = 800 - - def test(self): - - n = list(range(100)) - r = list(range(25)) - - for i in range(self.rounds): - - l = n[:] - - for j in r: - - m = l[50:] - m = l[:25] - m = l[50:55] - l[:3] = n - m = l[:-1] - m = l[1:] - l[-1:] = n - - def calibrate(self): - - n = list(range(100)) - r = list(range(25)) - - for i in range(self.rounds): - for j in r: - pass - -class SmallLists(Test): - - version = 2.0 - operations = 5*(1+ 6 + 6 + 3 + 1) - rounds = 80000 - - def test(self): - - for i in range(self.rounds): - - l = [] - - append = l.append - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - l[:3] = [1,2,3] - m = l[:-1] - m = l[1:] - - l[-1:] = [4,5,6] - - l = [] - - append = l.append - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - l[:3] = [1,2,3] - m = l[:-1] - m = l[1:] - - l[-1:] = [4,5,6] - - l = [] - - append = l.append - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - l[:3] = [1,2,3] - m = l[:-1] - m = l[1:] - - l[-1:] = [4,5,6] - - l = [] - - append = l.append - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - l[:3] = [1,2,3] - m = l[:-1] - m = l[1:] - - l[-1:] = [4,5,6] - - l = [] - - append = l.append - append(2) - append(3) - append(4) - append(2) - append(3) - append(4) - - l[0] = 3 - l[1] = 4 - l[2] = 5 - l[3] = 3 - l[4] = 4 - l[5] = 5 - - l[:3] = [1,2,3] - m = l[:-1] - m = l[1:] - - l[-1:] = [4,5,6] - - def calibrate(self): - - for i in range(self.rounds): - pass - -class SimpleListComprehensions(Test): - - version = 2.0 - operations = 6 - rounds = 20000 - - def test(self): - - n = list(range(10)) * 10 - - for i in range(self.rounds): - l = [x for x in n] - l = [x for x in n if x] - l = [x for x in n if not x] - - l = [x for x in n] - l = [x for x in n if x] - l = [x for x in n if not x] - - def calibrate(self): - - n = list(range(10)) * 10 - - for i in range(self.rounds): - pass - -class NestedListComprehensions(Test): - - version = 2.0 - operations = 6 - rounds = 20000 - - def test(self): - - m = list(range(10)) - n = list(range(10)) - - for i in range(self.rounds): - l = [x for x in n for y in m] - l = [y for x in n for y in m] - - l = [x for x in n for y in m if y] - l = [y for x in n for y in m if x] - - l = [x for x in n for y in m if not y] - l = [y for x in n for y in m if not x] - - def calibrate(self): - - m = list(range(10)) - n = list(range(10)) - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Lookups.py b/Tools/pybench/Lookups.py deleted file mode 100644 index 5bf9e76..0000000 --- a/Tools/pybench/Lookups.py +++ /dev/null @@ -1,945 +0,0 @@ -from pybench import Test - -class SpecialClassAttribute(Test): - - version = 2.0 - operations = 5*(12 + 12) - rounds = 100000 - - def test(self): - - class c: - pass - - for i in range(self.rounds): - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - c.__a = 2 - c.__b = 3 - c.__c = 4 - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - x = c.__a - x = c.__b - x = c.__c - - def calibrate(self): - - class c: - pass - - for i in range(self.rounds): - pass - -class NormalClassAttribute(Test): - - version = 2.0 - operations = 5*(12 + 12) - rounds = 100000 - - def test(self): - - class c: - pass - - for i in range(self.rounds): - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - c.a = 2 - c.b = 3 - c.c = 4 - - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - x = c.a - x = c.b - x = c.c - - def calibrate(self): - - class c: - pass - - for i in range(self.rounds): - pass - -class SpecialInstanceAttribute(Test): - - version = 2.0 - operations = 5*(12 + 12) - rounds = 100000 - - def test(self): - - class c: - pass - o = c() - - for i in range(self.rounds): - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - o.__a__ = 2 - o.__b__ = 3 - o.__c__ = 4 - - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - x = o.__a__ - x = o.__b__ - x = o.__c__ - - def calibrate(self): - - class c: - pass - o = c() - - for i in range(self.rounds): - pass - -class NormalInstanceAttribute(Test): - - version = 2.0 - operations = 5*(12 + 12) - rounds = 100000 - - def test(self): - - class c: - pass - o = c() - - for i in range(self.rounds): - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - o.a = 2 - o.b = 3 - o.c = 4 - - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - x = o.a - x = o.b - x = o.c - - def calibrate(self): - - class c: - pass - o = c() - - for i in range(self.rounds): - pass - -class BuiltinMethodLookup(Test): - - version = 2.0 - operations = 5*(3*5 + 3*5) - rounds = 70000 - - def test(self): - - l = [] - d = {} - - for i in range(self.rounds): - - l.append - l.append - l.append - l.append - l.append - - l.insert - l.insert - l.insert - l.insert - l.insert - - l.sort - l.sort - l.sort - l.sort - l.sort - - # d.has_key - # d.has_key - # d.has_key - # d.has_key - # d.has_key - - d.items - d.items - d.items - d.items - d.items - - d.get - d.get - d.get - d.get - d.get - - l.append - l.append - l.append - l.append - l.append - - l.insert - l.insert - l.insert - l.insert - l.insert - - l.sort - l.sort - l.sort - l.sort - l.sort - - # d.has_key - # d.has_key - # d.has_key - # d.has_key - # d.has_key - - d.items - d.items - d.items - d.items - d.items - - d.get - d.get - d.get - d.get - d.get - - l.append - l.append - l.append - l.append - l.append - - l.insert - l.insert - l.insert - l.insert - l.insert - - l.sort - l.sort - l.sort - l.sort - l.sort - - # d.has_key - # d.has_key - # d.has_key - # d.has_key - # d.has_key - - d.items - d.items - d.items - d.items - d.items - - d.get - d.get - d.get - d.get - d.get - - l.append - l.append - l.append - l.append - l.append - - l.insert - l.insert - l.insert - l.insert - l.insert - - l.sort - l.sort - l.sort - l.sort - l.sort - - # d.has_key - # d.has_key - # d.has_key - # d.has_key - # d.has_key - - d.items - d.items - d.items - d.items - d.items - - d.get - d.get - d.get - d.get - d.get - - l.append - l.append - l.append - l.append - l.append - - l.insert - l.insert - l.insert - l.insert - l.insert - - l.sort - l.sort - l.sort - l.sort - l.sort - - # d.has_key - # d.has_key - # d.has_key - # d.has_key - # d.has_key - - d.items - d.items - d.items - d.items - d.items - - d.get - d.get - d.get - d.get - d.get - - def calibrate(self): - - l = [] - d = {} - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/NewInstances.py b/Tools/pybench/NewInstances.py deleted file mode 100644 index 9506da4..0000000 --- a/Tools/pybench/NewInstances.py +++ /dev/null @@ -1,75 +0,0 @@ -from pybench import Test - -# Check for new-style class support: -try: - class c(object): - pass -except NameError: - raise ImportError - -### - -class CreateNewInstances(Test): - - version = 2.0 - operations = 3 + 7 + 4 - rounds = 60000 - - def test(self): - - class c(object): - pass - - class d(object): - def __init__(self,a,b,c): - self.a = a - self.b = b - self.c = c - - class e(object): - def __init__(self,a,b,c=4): - self.a = a - self.b = b - self.c = c - self.d = a - self.e = b - self.f = c - - for i in range(self.rounds): - o = c() - o1 = c() - o2 = c() - p = d(i,i,3) - p1 = d(i,i,3) - p2 = d(i,3,3) - p3 = d(3,i,3) - p4 = d(i,i,i) - p5 = d(3,i,3) - p6 = d(i,i,i) - q = e(i,i,3) - q1 = e(i,i,3) - q2 = e(i,i,3) - q3 = e(i,i) - - def calibrate(self): - - class c(object): - pass - - class d(object): - def __init__(self,a,b,c): - self.a = a - self.b = b - self.c = c - - class e(object): - def __init__(self,a,b,c=4): - self.a = a - self.b = b - self.c = c - self.d = a - self.e = b - self.f = c - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Numbers.py b/Tools/pybench/Numbers.py deleted file mode 100644 index 1b21673..0000000 --- a/Tools/pybench/Numbers.py +++ /dev/null @@ -1,784 +0,0 @@ -from pybench import Test - -class CompareIntegers(Test): - - version = 2.0 - operations = 30 * 5 - rounds = 120000 - - def test(self): - - for i in range(self.rounds): - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - 2 < 3 - 2 > 3 - 2 == 3 - 2 > 3 - 2 < 3 - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class CompareFloats(Test): - - version = 2.0 - operations = 30 * 5 - rounds = 80000 - - def test(self): - - for i in range(self.rounds): - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - 2.1 < 3.31 - 2.1 > 3.31 - 2.1 == 3.31 - 2.1 > 3.31 - 2.1 < 3.31 - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class CompareFloatsIntegers(Test): - - version = 2.0 - operations = 30 * 5 - rounds = 60000 - - def test(self): - - for i in range(self.rounds): - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - 2.1 < 4 - 2.1 > 4 - 2.1 == 4 - 2.1 > 4 - 2.1 < 4 - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class CompareLongs(Test): - - version = 2.0 - operations = 30 * 5 - rounds = 70000 - - def test(self): - - for i in range(self.rounds): - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - 1234567890 < 3456789012345 - 1234567890 > 3456789012345 - 1234567890 == 3456789012345 - 1234567890 > 3456789012345 - 1234567890 < 3456789012345 - - def calibrate(self): - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/README b/Tools/pybench/README deleted file mode 100644 index 40f7eec..0000000 --- a/Tools/pybench/README +++ /dev/null @@ -1,371 +0,0 @@ -________________________________________________________________________ - -PYBENCH - A Python Benchmark Suite -________________________________________________________________________ - - Extendable suite of low-level benchmarks for measuring - the performance of the Python implementation - (interpreter, compiler or VM). - -pybench is a collection of tests that provides a standardized way to -measure the performance of Python implementations. It takes a very -close look at different aspects of Python programs and let's you -decide which factors are more important to you than others, rather -than wrapping everything up in one number, like the other performance -tests do (e.g. pystone which is included in the Python Standard -Library). - -pybench has been used in the past by several Python developers to -track down performance bottlenecks or to demonstrate the impact of -optimizations and new features in Python. - -The command line interface for pybench is the file pybench.py. Run -this script with option '--help' to get a listing of the possible -options. Without options, pybench will simply execute the benchmark -and then print out a report to stdout. - - -Micro-Manual ------------- - -Run 'pybench.py -h' to see the help screen. Run 'pybench.py' to run -the benchmark suite using default settings and 'pybench.py -f <file>' -to have it store the results in a file too. - -It is usually a good idea to run pybench.py multiple times to see -whether the environment, timers and benchmark run-times are suitable -for doing benchmark tests. - -You can use the comparison feature of pybench.py ('pybench.py -c -<file>') to check how well the system behaves in comparison to a -reference run. - -If the differences are well below 10% for each test, then you have a -system that is good for doing benchmark testings. Of you get random -differences of more than 10% or significant differences between the -values for minimum and average time, then you likely have some -background processes running which cause the readings to become -inconsistent. Examples include: web-browsers, email clients, RSS -readers, music players, backup programs, etc. - -If you are only interested in a few tests of the whole suite, you can -use the filtering option, e.g. 'pybench.py -t string' will only -run/show the tests that have 'string' in their name. - -This is the current output of pybench.py --help: - -""" ------------------------------------------------------------------------- -PYBENCH - a benchmark test suite for Python interpreters/compilers. ------------------------------------------------------------------------- - -Synopsis: - pybench.py [option] files... - -Options and default settings: - -n arg number of rounds (10) - -f arg save benchmark to file arg () - -c arg compare benchmark with the one in file arg () - -s arg show benchmark in file arg, then exit () - -w arg set warp factor to arg (10) - -t arg run only tests with names matching arg () - -C arg set the number of calibration runs to arg (20) - -d hide noise in comparisons (0) - -v verbose output (not recommended) (0) - --with-gc enable garbage collection (0) - --with-syscheck use default sys check interval (0) - --timer arg use given timer (time.time) - -h show this help text - --help show this help text - --debug enable debugging - --copyright show copyright - --examples show examples of usage - -Version: - 2.1 - -The normal operation is to run the suite and display the -results. Use -f to save them for later reuse or comparisons. - -Available timers: - - time.time - time.clock - systimes.processtime - -Examples: - -python3.0 pybench.py -f p30.pybench -python3.1 pybench.py -f p31.pybench -python pybench.py -s p31.pybench -c p30.pybench -""" - -License -------- - -See LICENSE file. - - -Sample output -------------- - -""" -------------------------------------------------------------------------------- -PYBENCH 2.1 -------------------------------------------------------------------------------- -* using CPython 3.0 -* disabled garbage collection -* system check interval set to maximum: 2147483647 -* using timer: time.time - -Calibrating tests. Please wait... - -Running 10 round(s) of the suite at warp factor 10: - -* Round 1 done in 6.388 seconds. -* Round 2 done in 6.485 seconds. -* Round 3 done in 6.786 seconds. -... -* Round 10 done in 6.546 seconds. - -------------------------------------------------------------------------------- -Benchmark: 2006-06-12 12:09:25 -------------------------------------------------------------------------------- - - Rounds: 10 - Warp: 10 - Timer: time.time - - Machine Details: - Platform ID: Linux-2.6.8-24.19-default-x86_64-with-SuSE-9.2-x86-64 - Processor: x86_64 - - Python: - Implementation: CPython - Executable: /usr/local/bin/python - Version: 3.0 - Compiler: GCC 3.3.4 (pre 3.3.5 20040809) - Bits: 64bit - Build: Oct 1 2005 15:24:35 (#1) - Unicode: UCS2 - - -Test minimum average operation overhead -------------------------------------------------------------------------------- - BuiltinFunctionCalls: 126ms 145ms 0.28us 0.274ms - BuiltinMethodLookup: 124ms 130ms 0.12us 0.316ms - CompareFloats: 109ms 110ms 0.09us 0.361ms - CompareFloatsIntegers: 100ms 104ms 0.12us 0.271ms - CompareIntegers: 137ms 138ms 0.08us 0.542ms - CompareInternedStrings: 124ms 127ms 0.08us 1.367ms - CompareLongs: 100ms 104ms 0.10us 0.316ms - CompareStrings: 111ms 115ms 0.12us 0.929ms - CompareUnicode: 108ms 128ms 0.17us 0.693ms - ConcatStrings: 142ms 155ms 0.31us 0.562ms - ConcatUnicode: 119ms 127ms 0.42us 0.384ms - CreateInstances: 123ms 128ms 1.14us 0.367ms - CreateNewInstances: 121ms 126ms 1.49us 0.335ms - CreateStringsWithConcat: 130ms 135ms 0.14us 0.916ms - CreateUnicodeWithConcat: 130ms 135ms 0.34us 0.361ms - DictCreation: 108ms 109ms 0.27us 0.361ms - DictWithFloatKeys: 149ms 153ms 0.17us 0.678ms - DictWithIntegerKeys: 124ms 126ms 0.11us 0.915ms - DictWithStringKeys: 114ms 117ms 0.10us 0.905ms - ForLoops: 110ms 111ms 4.46us 0.063ms - IfThenElse: 118ms 119ms 0.09us 0.685ms - ListSlicing: 116ms 120ms 8.59us 0.103ms - NestedForLoops: 125ms 137ms 0.09us 0.019ms - NormalClassAttribute: 124ms 136ms 0.11us 0.457ms - NormalInstanceAttribute: 110ms 117ms 0.10us 0.454ms - PythonFunctionCalls: 107ms 113ms 0.34us 0.271ms - PythonMethodCalls: 140ms 149ms 0.66us 0.141ms - Recursion: 156ms 166ms 3.32us 0.452ms - SecondImport: 112ms 118ms 1.18us 0.180ms - SecondPackageImport: 118ms 127ms 1.27us 0.180ms - SecondSubmoduleImport: 140ms 151ms 1.51us 0.180ms - SimpleComplexArithmetic: 128ms 139ms 0.16us 0.361ms - SimpleDictManipulation: 134ms 136ms 0.11us 0.452ms - SimpleFloatArithmetic: 110ms 113ms 0.09us 0.571ms - SimpleIntFloatArithmetic: 106ms 111ms 0.08us 0.548ms - SimpleIntegerArithmetic: 106ms 109ms 0.08us 0.544ms - SimpleListManipulation: 103ms 113ms 0.10us 0.587ms - SimpleLongArithmetic: 112ms 118ms 0.18us 0.271ms - SmallLists: 105ms 116ms 0.17us 0.366ms - SmallTuples: 108ms 128ms 0.24us 0.406ms - SpecialClassAttribute: 119ms 136ms 0.11us 0.453ms - SpecialInstanceAttribute: 143ms 155ms 0.13us 0.454ms - StringMappings: 115ms 121ms 0.48us 0.405ms - StringPredicates: 120ms 129ms 0.18us 2.064ms - StringSlicing: 111ms 127ms 0.23us 0.781ms - TryExcept: 125ms 126ms 0.06us 0.681ms - TryRaiseExcept: 133ms 137ms 2.14us 0.361ms - TupleSlicing: 117ms 120ms 0.46us 0.066ms - UnicodeMappings: 156ms 160ms 4.44us 0.429ms - UnicodePredicates: 117ms 121ms 0.22us 2.487ms - UnicodeProperties: 115ms 153ms 0.38us 2.070ms - UnicodeSlicing: 126ms 129ms 0.26us 0.689ms -------------------------------------------------------------------------------- -Totals: 6283ms 6673ms -""" -________________________________________________________________________ - -Writing New Tests -________________________________________________________________________ - -pybench tests are simple modules defining one or more pybench.Test -subclasses. - -Writing a test essentially boils down to providing two methods: -.test() which runs .rounds number of .operations test operations each -and .calibrate() which does the same except that it doesn't actually -execute the operations. - - -Here's an example: ------------------- - -from pybench import Test - -class IntegerCounting(Test): - - # Version number of the test as float (x.yy); this is important - # for comparisons of benchmark runs - tests with unequal version - # number will not get compared. - version = 1.0 - - # The number of abstract operations done in each round of the - # test. An operation is the basic unit of what you want to - # measure. The benchmark will output the amount of run-time per - # operation. Note that in order to raise the measured timings - # significantly above noise level, it is often required to repeat - # sets of operations more than once per test round. The measured - # overhead per test round should be less than 1 second. - operations = 20 - - # Number of rounds to execute per test run. This should be - # adjusted to a figure that results in a test run-time of between - # 1-2 seconds (at warp 1). - rounds = 100000 - - def test(self): - - """ Run the test. - - The test needs to run self.rounds executing - self.operations number of operations each. - - """ - # Init the test - a = 1 - - # Run test rounds - # - for i in range(self.rounds): - - # Repeat the operations per round to raise the run-time - # per operation significantly above the noise level of the - # for-loop overhead. - - # Execute 20 operations (a += 1): - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - a += 1 - - def calibrate(self): - - """ Calibrate the test. - - This method should execute everything that is needed to - setup and run the test - except for the actual operations - that you intend to measure. pybench uses this method to - measure the test implementation overhead. - - """ - # Init the test - a = 1 - - # Run test rounds (without actually doing any operation) - for i in range(self.rounds): - - # Skip the actual execution of the operations, since we - # only want to measure the test's administration overhead. - pass - -Registering a new test module ------------------------------ - -To register a test module with pybench, the classes need to be -imported into the pybench.Setup module. pybench will then scan all the -symbols defined in that module for subclasses of pybench.Test and -automatically add them to the benchmark suite. - - -Breaking Comparability ----------------------- - -If a change is made to any individual test that means it is no -longer strictly comparable with previous runs, the '.version' class -variable should be updated. Therefafter, comparisons with previous -versions of the test will list as "n/a" to reflect the change. - - -Version History ---------------- - - 2.1: made some minor changes for compatibility with Python 3.0: - - replaced cmp with divmod and range with max in Calls.py - (cmp no longer exists in 3.0, and range is a list in - Python 2.x and an iterator in Python 3.x) - - 2.0: rewrote parts of pybench which resulted in more repeatable - timings: - - made timer a parameter - - changed the platform default timer to use high-resolution - timers rather than process timers (which have a much lower - resolution) - - added option to select timer - - added process time timer (using systimes.py) - - changed to use min() as timing estimator (average - is still taken as well to provide an idea of the difference) - - garbage collection is turned off per default - - sys check interval is set to the highest possible value - - calibration is now a separate step and done using - a different strategy that allows measuring the test - overhead more accurately - - modified the tests to each give a run-time of between - 100-200ms using warp 10 - - changed default warp factor to 10 (from 20) - - compared results with timeit.py and confirmed measurements - - bumped all test versions to 2.0 - - updated platform.py to the latest version - - changed the output format a bit to make it look - nicer - - refactored the APIs somewhat - 1.3+: Steve Holden added the NewInstances test and the filtering - option during the NeedForSpeed sprint; this also triggered a long - discussion on how to improve benchmark timing and finally - resulted in the release of 2.0 - 1.3: initial checkin into the Python SVN repository - - -Have fun, --- -Marc-Andre Lemburg -mal@lemburg.com diff --git a/Tools/pybench/Setup.py b/Tools/pybench/Setup.py deleted file mode 100755 index 21e654a..0000000 --- a/Tools/pybench/Setup.py +++ /dev/null @@ -1,43 +0,0 @@ -#!python - -# Setup file for pybench -# -# This file has to import all tests to be run; it is executed as -# Python source file, so you can do all kinds of manipulations here -# rather than having to edit the tests themselves. -# -# Note: Please keep this module compatible to Python 1.5.2. -# -# Tests may include features in later Python versions, but these -# should then be embedded in try-except clauses in this configuration -# module. - -# Defaults -Number_of_rounds = 10 -Warp_factor = 10 - -# Import tests -from Arithmetic import * -from Calls import * -from Constructs import * -from Lookups import * -from Instances import * -try: - from NewInstances import * -except ImportError: - pass -from Lists import * -from Tuples import * -from Dict import * -from Exceptions import * -try: - from With import * -except SyntaxError: - pass -from Imports import * -from Strings import * -from Numbers import * -try: - from Unicode import * -except (ImportError, SyntaxError): - pass diff --git a/Tools/pybench/Strings.py b/Tools/pybench/Strings.py deleted file mode 100644 index 8e3d702..0000000 --- a/Tools/pybench/Strings.py +++ /dev/null @@ -1,568 +0,0 @@ -from pybench import Test -import sys - -try: - intern -except NameError: - intern = sys.intern - - -class ConcatStrings(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 100000 - - def test(self): - - # Make sure the strings are *not* interned - s = ''.join(map(str,range(100))) - t = ''.join(map(str,range(1,101))) - - for i in range(self.rounds): - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - def calibrate(self): - - s = ''.join(map(str,range(100))) - t = ''.join(map(str,range(1,101))) - - for i in range(self.rounds): - pass - - -class CompareStrings(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 200000 - - def test(self): - - # Make sure the strings are *not* interned - s = ''.join(map(str,range(10))) - t = ''.join(map(str,range(10))) + "abc" - - for i in range(self.rounds): - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - def calibrate(self): - - s = ''.join(map(str,range(10))) - t = ''.join(map(str,range(10))) + "abc" - - for i in range(self.rounds): - pass - - -class CompareInternedStrings(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 300000 - - def test(self): - - # Make sure the strings *are* interned - s = intern(''.join(map(str,range(10)))) - t = s - - for i in range(self.rounds): - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - t == s - t == s - t >= s - t > s - t < s - - def calibrate(self): - - s = intern(''.join(map(str,range(10)))) - t = s - - for i in range(self.rounds): - pass - - -class CreateStringsWithConcat(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 200000 - - def test(self): - - for i in range(self.rounds): - s = 'om' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - s = s + 'xax' - s = s + 'xbx' - s = s + 'xcx' - s = s + 'xdx' - s = s + 'xex' - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class StringSlicing(Test): - - version = 2.0 - operations = 5 * 7 - rounds = 160000 - - def test(self): - - s = ''.join(map(str,range(100))) - - for i in range(self.rounds): - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - def calibrate(self): - - s = ''.join(map(str,range(100))) - - for i in range(self.rounds): - pass - -### String methods - -if hasattr('', 'lower'): - - class StringMappings(Test): - - version = 2.0 - operations = 3 * (5 + 4 + 2 + 1) - rounds = 70000 - - def test(self): - - s = ''.join(map(chr,range(20))) - t = ''.join(map(chr,range(50))) - u = ''.join(map(chr,range(100))) - v = ''.join(map(chr,range(256))) - - for i in range(self.rounds): - - s.lower() - s.lower() - s.lower() - s.lower() - s.lower() - - s.upper() - s.upper() - s.upper() - s.upper() - s.upper() - - s.title() - s.title() - s.title() - s.title() - s.title() - - t.lower() - t.lower() - t.lower() - t.lower() - - t.upper() - t.upper() - t.upper() - t.upper() - - t.title() - t.title() - t.title() - t.title() - - u.lower() - u.lower() - - u.upper() - u.upper() - - u.title() - u.title() - - v.lower() - - v.upper() - - v.title() - - def calibrate(self): - - s = ''.join(map(chr,range(20))) - t = ''.join(map(chr,range(50))) - u = ''.join(map(chr,range(100))) - v = ''.join(map(chr,range(256))) - - for i in range(self.rounds): - pass - - class StringPredicates(Test): - - version = 2.0 - operations = 10 * 7 - rounds = 100000 - - def test(self): - - data = ('abc', '123', ' ', '\xe4\xf6\xfc', '\xdf'*10) - len_data = len(data) - - for i in range(self.rounds): - s = data[i % len_data] - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdigit() - s.islower() - s.isspace() - s.istitle() - s.isupper() - - def calibrate(self): - - data = ('abc', '123', ' ', '\u1234\u2345\u3456', '\uFFFF'*10) - data = ('abc', '123', ' ', '\xe4\xf6\xfc', '\xdf'*10) - len_data = len(data) - - for i in range(self.rounds): - s = data[i % len_data] diff --git a/Tools/pybench/Tuples.py b/Tools/pybench/Tuples.py deleted file mode 100644 index d93802c..0000000 --- a/Tools/pybench/Tuples.py +++ /dev/null @@ -1,360 +0,0 @@ -from pybench import Test - -class TupleSlicing(Test): - - version = 2.0 - operations = 3 * 25 * 10 * 7 - rounds = 500 - - def test(self): - - r = range(25) - t = tuple(range(100)) - - for i in range(self.rounds): - - for j in r: - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - m = t[50:] - m = t[:25] - m = t[50:55] - m = t[:-1] - m = t[1:] - m = t[-10:] - m = t[:10] - - def calibrate(self): - - r = range(25) - t = tuple(range(100)) - - for i in range(self.rounds): - for j in r: - pass - -class SmallTuples(Test): - - version = 2.0 - operations = 5*(1 + 3 + 6 + 2) - rounds = 90000 - - def test(self): - - for i in range(self.rounds): - - t = (1,2,3,4,5,6) - - a,b,c,d,e,f = t - a,b,c,d,e,f = t - a,b,c,d,e,f = t - - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - - l = list(t) - t = tuple(l) - - t = (1,2,3,4,5,6) - - a,b,c,d,e,f = t - a,b,c,d,e,f = t - a,b,c,d,e,f = t - - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - - l = list(t) - t = tuple(l) - - t = (1,2,3,4,5,6) - - a,b,c,d,e,f = t - a,b,c,d,e,f = t - a,b,c,d,e,f = t - - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - - l = list(t) - t = tuple(l) - - t = (1,2,3,4,5,6) - - a,b,c,d,e,f = t - a,b,c,d,e,f = t - a,b,c,d,e,f = t - - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - - l = list(t) - t = tuple(l) - - t = (1,2,3,4,5,6) - - a,b,c,d,e,f = t - a,b,c,d,e,f = t - a,b,c,d,e,f = t - - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - a,b,c = t[:3] - - l = list(t) - t = tuple(l) - - def calibrate(self): - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/Unicode.py b/Tools/pybench/Unicode.py deleted file mode 100644 index b17a7c3..0000000 --- a/Tools/pybench/Unicode.py +++ /dev/null @@ -1,541 +0,0 @@ -try: - unicode -except NameError: - raise ImportError - -from pybench import Test - -class ConcatUnicode(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 60000 - - def test(self): - - # Make sure the strings are *not* interned - s = unicode(u''.join(map(str,range(100)))) - t = unicode(u''.join(map(str,range(1,101)))) - - for i in range(self.rounds): - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - t + s - t + s - t + s - t + s - t + s - - def calibrate(self): - - s = unicode(u''.join(map(str,range(100)))) - t = unicode(u''.join(map(str,range(1,101)))) - - for i in range(self.rounds): - pass - - -class CompareUnicode(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 150000 - - def test(self): - - # Make sure the strings are *not* interned - s = unicode(u''.join(map(str,range(10)))) - t = unicode(u''.join(map(str,range(10))) + "abc") - - for i in range(self.rounds): - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - t < s - t > s - t == s - t > s - t < s - - def calibrate(self): - - s = unicode(u''.join(map(str,range(10)))) - t = unicode(u''.join(map(str,range(10))) + "abc") - - for i in range(self.rounds): - pass - - -class CreateUnicodeWithConcat(Test): - - version = 2.0 - operations = 10 * 5 - rounds = 80000 - - def test(self): - - for i in range(self.rounds): - s = u'om' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - s = s + u'xax' - s = s + u'xbx' - s = s + u'xcx' - s = s + u'xdx' - s = s + u'xex' - - def calibrate(self): - - for i in range(self.rounds): - pass - - -class UnicodeSlicing(Test): - - version = 2.0 - operations = 5 * 7 - rounds = 140000 - - def test(self): - - s = unicode(u''.join(map(str,range(100)))) - - for i in range(self.rounds): - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - s[50:] - s[:25] - s[50:55] - s[-1:] - s[:1] - s[2:] - s[11:-11] - - def calibrate(self): - - s = unicode(u''.join(map(str,range(100)))) - - for i in range(self.rounds): - pass - -### String methods - -class UnicodeMappings(Test): - - version = 2.0 - operations = 3 * (5 + 4 + 2 + 1) - rounds = 10000 - - def test(self): - - s = u''.join(map(unichr,range(20))) - t = u''.join(map(unichr,range(100))) - u = u''.join(map(unichr,range(500))) - v = u''.join(map(unichr,range(1000))) - - for i in range(self.rounds): - - s.lower() - s.lower() - s.lower() - s.lower() - s.lower() - - s.upper() - s.upper() - s.upper() - s.upper() - s.upper() - - s.title() - s.title() - s.title() - s.title() - s.title() - - t.lower() - t.lower() - t.lower() - t.lower() - - t.upper() - t.upper() - t.upper() - t.upper() - - t.title() - t.title() - t.title() - t.title() - - u.lower() - u.lower() - - u.upper() - u.upper() - - u.title() - u.title() - - v.lower() - - v.upper() - - v.title() - - def calibrate(self): - - s = u''.join(map(unichr,range(20))) - t = u''.join(map(unichr,range(100))) - u = u''.join(map(unichr,range(500))) - v = u''.join(map(unichr,range(1000))) - - for i in range(self.rounds): - pass - -class UnicodePredicates(Test): - - version = 2.0 - operations = 5 * 9 - rounds = 120000 - - def test(self): - - data = (u'abc', u'123', u' ', u'\u1234\u2345\u3456', u'\uFFFF'*10) - len_data = len(data) - - for i in range(self.rounds): - s = data[i % len_data] - - s.isalnum() - s.isalpha() - s.isdecimal() - s.isdigit() - s.islower() - s.isnumeric() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdecimal() - s.isdigit() - s.islower() - s.isnumeric() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdecimal() - s.isdigit() - s.islower() - s.isnumeric() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdecimal() - s.isdigit() - s.islower() - s.isnumeric() - s.isspace() - s.istitle() - s.isupper() - - s.isalnum() - s.isalpha() - s.isdecimal() - s.isdigit() - s.islower() - s.isnumeric() - s.isspace() - s.istitle() - s.isupper() - - def calibrate(self): - - data = (u'abc', u'123', u' ', u'\u1234\u2345\u3456', u'\uFFFF'*10) - len_data = len(data) - - for i in range(self.rounds): - s = data[i % len_data] - -try: - import unicodedata -except ImportError: - pass -else: - class UnicodeProperties(Test): - - version = 2.0 - operations = 5 * 8 - rounds = 100000 - - def test(self): - - data = (u'a', u'1', u' ', u'\u1234', u'\uFFFF') - len_data = len(data) - digit = unicodedata.digit - numeric = unicodedata.numeric - decimal = unicodedata.decimal - category = unicodedata.category - bidirectional = unicodedata.bidirectional - decomposition = unicodedata.decomposition - mirrored = unicodedata.mirrored - combining = unicodedata.combining - - for i in range(self.rounds): - - c = data[i % len_data] - - digit(c, None) - numeric(c, None) - decimal(c, None) - category(c) - bidirectional(c) - decomposition(c) - mirrored(c) - combining(c) - - digit(c, None) - numeric(c, None) - decimal(c, None) - category(c) - bidirectional(c) - decomposition(c) - mirrored(c) - combining(c) - - digit(c, None) - numeric(c, None) - decimal(c, None) - category(c) - bidirectional(c) - decomposition(c) - mirrored(c) - combining(c) - - digit(c, None) - numeric(c, None) - decimal(c, None) - category(c) - bidirectional(c) - decomposition(c) - mirrored(c) - combining(c) - - digit(c, None) - numeric(c, None) - decimal(c, None) - category(c) - bidirectional(c) - decomposition(c) - mirrored(c) - combining(c) - - def calibrate(self): - - data = (u'a', u'1', u' ', u'\u1234', u'\uFFFF') - len_data = len(data) - digit = unicodedata.digit - numeric = unicodedata.numeric - decimal = unicodedata.decimal - category = unicodedata.category - bidirectional = unicodedata.bidirectional - decomposition = unicodedata.decomposition - mirrored = unicodedata.mirrored - combining = unicodedata.combining - - for i in range(self.rounds): - - c = data[i % len_data] diff --git a/Tools/pybench/With.py b/Tools/pybench/With.py deleted file mode 100644 index 30cd3c2..0000000 --- a/Tools/pybench/With.py +++ /dev/null @@ -1,189 +0,0 @@ -from pybench import Test - -class WithFinally(Test): - - version = 2.0 - operations = 20 - rounds = 80000 - - class ContextManager(object): - def __enter__(self): - pass - def __exit__(self, exc, val, tb): - pass - - def test(self): - - cm = self.ContextManager() - - for i in range(self.rounds): - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - with cm: pass - - def calibrate(self): - - cm = self.ContextManager() - - for i in range(self.rounds): - pass - - -class TryFinally(Test): - - version = 2.0 - operations = 20 - rounds = 80000 - - class ContextManager(object): - def __enter__(self): - pass - def __exit__(self): - # "Context manager" objects used just for their cleanup - # actions in finally blocks usually don't have parameters. - pass - - def test(self): - - cm = self.ContextManager() - - for i in range(self.rounds): - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - cm.__enter__() - try: pass - finally: cm.__exit__() - - def calibrate(self): - - cm = self.ContextManager() - - for i in range(self.rounds): - pass - - -class WithRaiseExcept(Test): - - version = 2.0 - operations = 2 + 3 + 3 - rounds = 100000 - - class BlockExceptions(object): - def __enter__(self): - pass - def __exit__(self, exc, val, tb): - return True - - def test(self): - - error = ValueError - be = self.BlockExceptions() - - for i in range(self.rounds): - with be: raise error - with be: raise error - with be: raise error("something") - with be: raise error("something") - with be: raise error("something") - with be: raise error("something") - with be: raise error("something") - with be: raise error("something") - - def calibrate(self): - - error = ValueError - be = self.BlockExceptions() - - for i in range(self.rounds): - pass diff --git a/Tools/pybench/clockres.py b/Tools/pybench/clockres.py deleted file mode 100755 index d7f1ac8..0000000 --- a/Tools/pybench/clockres.py +++ /dev/null @@ -1,42 +0,0 @@ -#!/usr/bin/env python - -""" clockres - calculates the resolution in seconds of a given timer. - - Copyright (c) 2006, Marc-Andre Lemburg (mal@egenix.com). See the - documentation for further information on copyrights, or contact - the author. All Rights Reserved. - -""" -import time - -TEST_TIME = 1.0 - -def clockres(timer): - d = {} - wallclock = time.time - start = wallclock() - stop = wallclock() + TEST_TIME - spin_loops = range(1000) - while 1: - now = wallclock() - if now >= stop: - break - for i in spin_loops: - d[timer()] = 1 - values = sorted(d.keys()) - min_diff = TEST_TIME - for i in range(len(values) - 1): - diff = values[i+1] - values[i] - if diff < min_diff: - min_diff = diff - return min_diff - -if __name__ == '__main__': - print('Clock resolution of various timer implementations:') - print('time.clock: %10.3fus' % (clockres(time.clock) * 1e6)) - print('time.time: %10.3fus' % (clockres(time.time) * 1e6)) - try: - import systimes - print('systimes.processtime: %10.3fus' % (clockres(systimes.processtime) * 1e6)) - except ImportError: - pass diff --git a/Tools/pybench/package/__init__.py b/Tools/pybench/package/__init__.py deleted file mode 100644 index e69de29..0000000 --- a/Tools/pybench/package/__init__.py +++ /dev/null diff --git a/Tools/pybench/package/submodule.py b/Tools/pybench/package/submodule.py deleted file mode 100644 index e69de29..0000000 --- a/Tools/pybench/package/submodule.py +++ /dev/null diff --git a/Tools/pybench/pybench.py b/Tools/pybench/pybench.py deleted file mode 100755 index 942f56d..0000000 --- a/Tools/pybench/pybench.py +++ /dev/null @@ -1,974 +0,0 @@ -#!/usr/local/bin/python -O - -""" A Python Benchmark Suite - -""" -# Note: Please keep this module compatible to Python 2.6. -# -# Tests may include features in later Python versions, but these -# should then be embedded in try-except clauses in the configuration -# module Setup.py. -# - -from __future__ import print_function - -# pybench Copyright -__copyright__ = """\ -Copyright (c), 1997-2006, Marc-Andre Lemburg (mal@lemburg.com) -Copyright (c), 2000-2006, eGenix.com Software GmbH (info@egenix.com) - - All Rights Reserved. - -Permission to use, copy, modify, and distribute this software and its -documentation for any purpose and without fee or royalty is hereby -granted, provided that the above copyright notice appear in all copies -and that both that copyright notice and this permission notice appear -in supporting documentation or portions thereof, including -modifications, that you make. - -THE AUTHOR MARC-ANDRE LEMBURG DISCLAIMS ALL WARRANTIES WITH REGARD TO -THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND -FITNESS, IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, -INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING -FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, -NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION -WITH THE USE OR PERFORMANCE OF THIS SOFTWARE ! -""" - -import sys -import time -import platform -from CommandLine import * - -try: - import cPickle - pickle = cPickle -except ImportError: - import pickle - -# Version number; version history: see README file ! -__version__ = '2.1' - -### Constants - -# Second fractions -MILLI_SECONDS = 1e3 -MICRO_SECONDS = 1e6 - -# Percent unit -PERCENT = 100 - -# Horizontal line length -LINE = 79 - -# Minimum test run-time -MIN_TEST_RUNTIME = 1e-3 - -# Number of calibration runs to use for calibrating the tests -CALIBRATION_RUNS = 20 - -# Number of calibration loops to run for each calibration run -CALIBRATION_LOOPS = 20 - -# Allow skipping calibration ? -ALLOW_SKIPPING_CALIBRATION = 1 - -# Timer types -TIMER_TIME_TIME = 'time.time' -TIMER_TIME_PROCESS_TIME = 'time.process_time' -TIMER_TIME_PERF_COUNTER = 'time.perf_counter' -TIMER_TIME_CLOCK = 'time.clock' -TIMER_SYSTIMES_PROCESSTIME = 'systimes.processtime' - -# Choose platform default timer -if hasattr(time, 'perf_counter'): - TIMER_PLATFORM_DEFAULT = TIMER_TIME_PERF_COUNTER -elif sys.platform[:3] == 'win': - # On WinXP this has 2.5ms resolution - TIMER_PLATFORM_DEFAULT = TIMER_TIME_CLOCK -else: - # On Linux this has 1ms resolution - TIMER_PLATFORM_DEFAULT = TIMER_TIME_TIME - -# Print debug information ? -_debug = 0 - -### Helpers - -def get_timer(timertype): - - if timertype == TIMER_TIME_TIME: - return time.time - elif timertype == TIMER_TIME_PROCESS_TIME: - return time.process_time - elif timertype == TIMER_TIME_PERF_COUNTER: - return time.perf_counter - elif timertype == TIMER_TIME_CLOCK: - return time.clock - elif timertype == TIMER_SYSTIMES_PROCESSTIME: - import systimes - return systimes.processtime - else: - raise TypeError('unknown timer type: %s' % timertype) - -def get_machine_details(): - - if _debug: - print('Getting machine details...') - buildno, builddate = platform.python_build() - python = platform.python_version() - # XXX this is now always UCS4, maybe replace it with 'PEP393' in 3.3+? - if sys.maxunicode == 65535: - # UCS2 build (standard) - unitype = 'UCS2' - else: - # UCS4 build (most recent Linux distros) - unitype = 'UCS4' - bits, linkage = platform.architecture() - return { - 'platform': platform.platform(), - 'processor': platform.processor(), - 'executable': sys.executable, - 'implementation': getattr(platform, 'python_implementation', - lambda:'n/a')(), - 'python': platform.python_version(), - 'compiler': platform.python_compiler(), - 'buildno': buildno, - 'builddate': builddate, - 'unicode': unitype, - 'bits': bits, - } - -def print_machine_details(d, indent=''): - - l = ['Machine Details:', - ' Platform ID: %s' % d.get('platform', 'n/a'), - ' Processor: %s' % d.get('processor', 'n/a'), - '', - 'Python:', - ' Implementation: %s' % d.get('implementation', 'n/a'), - ' Executable: %s' % d.get('executable', 'n/a'), - ' Version: %s' % d.get('python', 'n/a'), - ' Compiler: %s' % d.get('compiler', 'n/a'), - ' Bits: %s' % d.get('bits', 'n/a'), - ' Build: %s (#%s)' % (d.get('builddate', 'n/a'), - d.get('buildno', 'n/a')), - ' Unicode: %s' % d.get('unicode', 'n/a'), - ] - joiner = '\n' + indent - print(indent + joiner.join(l) + '\n') - -### Test baseclass - -class Test: - - """ All test must have this class as baseclass. It provides - the necessary interface to the benchmark machinery. - - The tests must set .rounds to a value high enough to let the - test run between 20-50 seconds. This is needed because - clock()-timing only gives rather inaccurate values (on Linux, - for example, it is accurate to a few hundreths of a - second). If you don't want to wait that long, use a warp - factor larger than 1. - - It is also important to set the .operations variable to a - value representing the number of "virtual operations" done per - call of .run(). - - If you change a test in some way, don't forget to increase - its version number. - - """ - - ### Instance variables that each test should override - - # Version number of the test as float (x.yy); this is important - # for comparisons of benchmark runs - tests with unequal version - # number will not get compared. - version = 2.1 - - # The number of abstract operations done in each round of the - # test. An operation is the basic unit of what you want to - # measure. The benchmark will output the amount of run-time per - # operation. Note that in order to raise the measured timings - # significantly above noise level, it is often required to repeat - # sets of operations more than once per test round. The measured - # overhead per test round should be less than 1 second. - operations = 1 - - # Number of rounds to execute per test run. This should be - # adjusted to a figure that results in a test run-time of between - # 1-2 seconds. - rounds = 100000 - - ### Internal variables - - # Mark this class as implementing a test - is_a_test = 1 - - # Last timing: (real, run, overhead) - last_timing = (0.0, 0.0, 0.0) - - # Warp factor to use for this test - warp = 1 - - # Number of calibration runs to use - calibration_runs = CALIBRATION_RUNS - - # List of calibration timings - overhead_times = None - - # List of test run timings - times = [] - - # Timer used for the benchmark - timer = TIMER_PLATFORM_DEFAULT - - def __init__(self, warp=None, calibration_runs=None, timer=None): - - # Set parameters - if warp is not None: - self.rounds = int(self.rounds / warp) - if self.rounds == 0: - raise ValueError('warp factor set too high') - self.warp = warp - if calibration_runs is not None: - if (not ALLOW_SKIPPING_CALIBRATION and - calibration_runs < 1): - raise ValueError('at least one calibration run is required') - self.calibration_runs = calibration_runs - if timer is not None: - self.timer = timer - - # Init variables - self.times = [] - self.overhead_times = [] - - # We want these to be in the instance dict, so that pickle - # saves them - self.version = self.version - self.operations = self.operations - self.rounds = self.rounds - - def get_timer(self): - - """ Return the timer function to use for the test. - - """ - return get_timer(self.timer) - - def compatible(self, other): - - """ Return 1/0 depending on whether the test is compatible - with the other Test instance or not. - - """ - if self.version != other.version: - return 0 - if self.rounds != other.rounds: - return 0 - return 1 - - def calibrate_test(self): - - if self.calibration_runs == 0: - self.overhead_times = [0.0] - return - - calibrate = self.calibrate - timer = self.get_timer() - calibration_loops = range(CALIBRATION_LOOPS) - - # Time the calibration loop overhead - prep_times = [] - for i in range(self.calibration_runs): - t = timer() - for i in calibration_loops: - pass - t = timer() - t - prep_times.append(t / CALIBRATION_LOOPS) - min_prep_time = min(prep_times) - if _debug: - print() - print('Calib. prep time = %.6fms' % ( - min_prep_time * MILLI_SECONDS)) - - # Time the calibration runs (doing CALIBRATION_LOOPS loops of - # .calibrate() method calls each) - for i in range(self.calibration_runs): - t = timer() - for i in calibration_loops: - calibrate() - t = timer() - t - self.overhead_times.append(t / CALIBRATION_LOOPS - - min_prep_time) - - # Check the measured times - min_overhead = min(self.overhead_times) - max_overhead = max(self.overhead_times) - if _debug: - print('Calib. overhead time = %.6fms' % ( - min_overhead * MILLI_SECONDS)) - if min_overhead < 0.0: - raise ValueError('calibration setup did not work') - if max_overhead - min_overhead > 0.1: - raise ValueError( - 'overhead calibration timing range too inaccurate: ' - '%r - %r' % (min_overhead, max_overhead)) - - def run(self): - - """ Run the test in two phases: first calibrate, then - do the actual test. Be careful to keep the calibration - timing low w/r to the test timing. - - """ - test = self.test - timer = self.get_timer() - - # Get calibration - min_overhead = min(self.overhead_times) - - # Test run - t = timer() - test() - t = timer() - t - if t < MIN_TEST_RUNTIME: - raise ValueError('warp factor too high: ' - 'test times are < 10ms') - eff_time = t - min_overhead - if eff_time < 0: - raise ValueError('wrong calibration') - self.last_timing = (eff_time, t, min_overhead) - self.times.append(eff_time) - - def calibrate(self): - - """ Calibrate the test. - - This method should execute everything that is needed to - setup and run the test - except for the actual operations - that you intend to measure. pybench uses this method to - measure the test implementation overhead. - - """ - return - - def test(self): - - """ Run the test. - - The test needs to run self.rounds executing - self.operations number of operations each. - - """ - return - - def stat(self): - - """ Return test run statistics as tuple: - - (minimum run time, - average run time, - total run time, - average time per operation, - minimum overhead time) - - """ - runs = len(self.times) - if runs == 0: - return 0.0, 0.0, 0.0, 0.0 - min_time = min(self.times) - total_time = sum(self.times) - avg_time = total_time / float(runs) - operation_avg = total_time / float(runs - * self.rounds - * self.operations) - if self.overhead_times: - min_overhead = min(self.overhead_times) - else: - min_overhead = self.last_timing[2] - return min_time, avg_time, total_time, operation_avg, min_overhead - -### Load Setup - -# This has to be done after the definition of the Test class, since -# the Setup module will import subclasses using this class. - -import Setup - -### Benchmark base class - -class Benchmark: - - # Name of the benchmark - name = '' - - # Number of benchmark rounds to run - rounds = 1 - - # Warp factor use to run the tests - warp = 1 # Warp factor - - # Average benchmark round time - roundtime = 0 - - # Benchmark version number as float x.yy - version = 2.1 - - # Produce verbose output ? - verbose = 0 - - # Dictionary with the machine details - machine_details = None - - # Timer used for the benchmark - timer = TIMER_PLATFORM_DEFAULT - - def __init__(self, name, verbose=None, timer=None, warp=None, - calibration_runs=None): - - if name: - self.name = name - else: - self.name = '%04i-%02i-%02i %02i:%02i:%02i' % \ - (time.localtime(time.time())[:6]) - if verbose is not None: - self.verbose = verbose - if timer is not None: - self.timer = timer - if warp is not None: - self.warp = warp - if calibration_runs is not None: - self.calibration_runs = calibration_runs - - # Init vars - self.tests = {} - if _debug: - print('Getting machine details...') - self.machine_details = get_machine_details() - - # Make .version an instance attribute to have it saved in the - # Benchmark pickle - self.version = self.version - - def get_timer(self): - - """ Return the timer function to use for the test. - - """ - return get_timer(self.timer) - - def compatible(self, other): - - """ Return 1/0 depending on whether the benchmark is - compatible with the other Benchmark instance or not. - - """ - if self.version != other.version: - return 0 - if (self.machine_details == other.machine_details and - self.timer != other.timer): - return 0 - if (self.calibration_runs == 0 and - other.calibration_runs != 0): - return 0 - if (self.calibration_runs != 0 and - other.calibration_runs == 0): - return 0 - return 1 - - def load_tests(self, setupmod, limitnames=None): - - # Add tests - if self.verbose: - print('Searching for tests ...') - print('--------------------------------------') - for testclass in setupmod.__dict__.values(): - if not hasattr(testclass, 'is_a_test'): - continue - name = testclass.__name__ - if name == 'Test': - continue - if (limitnames is not None and - limitnames.search(name) is None): - continue - self.tests[name] = testclass( - warp=self.warp, - calibration_runs=self.calibration_runs, - timer=self.timer) - l = sorted(self.tests) - if self.verbose: - for name in l: - print(' %s' % name) - print('--------------------------------------') - print(' %i tests found' % len(l)) - print() - - def calibrate(self): - - print('Calibrating tests. Please wait...', end=' ') - sys.stdout.flush() - if self.verbose: - print() - print() - print('Test min max') - print('-' * LINE) - tests = sorted(self.tests.items()) - for i in range(len(tests)): - name, test = tests[i] - test.calibrate_test() - if self.verbose: - print('%30s: %6.3fms %6.3fms' % \ - (name, - min(test.overhead_times) * MILLI_SECONDS, - max(test.overhead_times) * MILLI_SECONDS)) - if self.verbose: - print() - print('Done with the calibration.') - else: - print('done.') - print() - - def run(self): - - tests = sorted(self.tests.items()) - timer = self.get_timer() - print('Running %i round(s) of the suite at warp factor %i:' % \ - (self.rounds, self.warp)) - print() - self.roundtimes = [] - for i in range(self.rounds): - if self.verbose: - print(' Round %-25i effective absolute overhead' % (i+1)) - total_eff_time = 0.0 - for j in range(len(tests)): - name, test = tests[j] - if self.verbose: - print('%30s:' % name, end=' ') - test.run() - (eff_time, abs_time, min_overhead) = test.last_timing - total_eff_time = total_eff_time + eff_time - if self.verbose: - print(' %5.0fms %5.0fms %7.3fms' % \ - (eff_time * MILLI_SECONDS, - abs_time * MILLI_SECONDS, - min_overhead * MILLI_SECONDS)) - self.roundtimes.append(total_eff_time) - if self.verbose: - print(' ' - ' ------------------------------') - print(' ' - ' Totals: %6.0fms' % - (total_eff_time * MILLI_SECONDS)) - print() - else: - print('* Round %i done in %.3f seconds.' % (i+1, - total_eff_time)) - print() - - def stat(self): - - """ Return benchmark run statistics as tuple: - - (minimum round time, - average round time, - maximum round time) - - XXX Currently not used, since the benchmark does test - statistics across all rounds. - - """ - runs = len(self.roundtimes) - if runs == 0: - return 0.0, 0.0 - min_time = min(self.roundtimes) - total_time = sum(self.roundtimes) - avg_time = total_time / float(runs) - max_time = max(self.roundtimes) - return (min_time, avg_time, max_time) - - def print_header(self, title='Benchmark'): - - print('-' * LINE) - print('%s: %s' % (title, self.name)) - print('-' * LINE) - print() - print(' Rounds: %s' % self.rounds) - print(' Warp: %s' % self.warp) - print(' Timer: %s' % self.timer) - print() - if self.machine_details: - print_machine_details(self.machine_details, indent=' ') - print() - - def print_benchmark(self, hidenoise=0, limitnames=None): - - print('Test ' - ' minimum average operation overhead') - print('-' * LINE) - tests = sorted(self.tests.items()) - total_min_time = 0.0 - total_avg_time = 0.0 - for name, test in tests: - if (limitnames is not None and - limitnames.search(name) is None): - continue - (min_time, - avg_time, - total_time, - op_avg, - min_overhead) = test.stat() - total_min_time = total_min_time + min_time - total_avg_time = total_avg_time + avg_time - print('%30s: %5.0fms %5.0fms %6.2fus %7.3fms' % \ - (name, - min_time * MILLI_SECONDS, - avg_time * MILLI_SECONDS, - op_avg * MICRO_SECONDS, - min_overhead *MILLI_SECONDS)) - print('-' * LINE) - print('Totals: ' - ' %6.0fms %6.0fms' % - (total_min_time * MILLI_SECONDS, - total_avg_time * MILLI_SECONDS, - )) - print() - - def print_comparison(self, compare_to, hidenoise=0, limitnames=None): - - # Check benchmark versions - if compare_to.version != self.version: - print('* Benchmark versions differ: ' - 'cannot compare this benchmark to "%s" !' % - compare_to.name) - print() - self.print_benchmark(hidenoise=hidenoise, - limitnames=limitnames) - return - - # Print header - compare_to.print_header('Comparing with') - print('Test ' - ' minimum run-time average run-time') - print(' ' - ' this other diff this other diff') - print('-' * LINE) - - # Print test comparisons - tests = sorted(self.tests.items()) - total_min_time = other_total_min_time = 0.0 - total_avg_time = other_total_avg_time = 0.0 - benchmarks_compatible = self.compatible(compare_to) - tests_compatible = 1 - for name, test in tests: - if (limitnames is not None and - limitnames.search(name) is None): - continue - (min_time, - avg_time, - total_time, - op_avg, - min_overhead) = test.stat() - total_min_time = total_min_time + min_time - total_avg_time = total_avg_time + avg_time - try: - other = compare_to.tests[name] - except KeyError: - other = None - if other is None: - # Other benchmark doesn't include the given test - min_diff, avg_diff = 'n/a', 'n/a' - other_min_time = 0.0 - other_avg_time = 0.0 - tests_compatible = 0 - else: - (other_min_time, - other_avg_time, - other_total_time, - other_op_avg, - other_min_overhead) = other.stat() - other_total_min_time = other_total_min_time + other_min_time - other_total_avg_time = other_total_avg_time + other_avg_time - if (benchmarks_compatible and - test.compatible(other)): - # Both benchmark and tests are comparable - min_diff = ((min_time * self.warp) / - (other_min_time * other.warp) - 1.0) - avg_diff = ((avg_time * self.warp) / - (other_avg_time * other.warp) - 1.0) - if hidenoise and abs(min_diff) < 10.0: - min_diff = '' - else: - min_diff = '%+5.1f%%' % (min_diff * PERCENT) - if hidenoise and abs(avg_diff) < 10.0: - avg_diff = '' - else: - avg_diff = '%+5.1f%%' % (avg_diff * PERCENT) - else: - # Benchmark or tests are not comparable - min_diff, avg_diff = 'n/a', 'n/a' - tests_compatible = 0 - print('%30s: %5.0fms %5.0fms %7s %5.0fms %5.0fms %7s' % \ - (name, - min_time * MILLI_SECONDS, - other_min_time * MILLI_SECONDS * compare_to.warp / self.warp, - min_diff, - avg_time * MILLI_SECONDS, - other_avg_time * MILLI_SECONDS * compare_to.warp / self.warp, - avg_diff)) - print('-' * LINE) - - # Summarise test results - if not benchmarks_compatible or not tests_compatible: - min_diff, avg_diff = 'n/a', 'n/a' - else: - if other_total_min_time != 0.0: - min_diff = '%+5.1f%%' % ( - ((total_min_time * self.warp) / - (other_total_min_time * compare_to.warp) - 1.0) * PERCENT) - else: - min_diff = 'n/a' - if other_total_avg_time != 0.0: - avg_diff = '%+5.1f%%' % ( - ((total_avg_time * self.warp) / - (other_total_avg_time * compare_to.warp) - 1.0) * PERCENT) - else: - avg_diff = 'n/a' - print('Totals: ' - ' %5.0fms %5.0fms %7s %5.0fms %5.0fms %7s' % - (total_min_time * MILLI_SECONDS, - (other_total_min_time * compare_to.warp/self.warp - * MILLI_SECONDS), - min_diff, - total_avg_time * MILLI_SECONDS, - (other_total_avg_time * compare_to.warp/self.warp - * MILLI_SECONDS), - avg_diff - )) - print() - print('(this=%s, other=%s)' % (self.name, - compare_to.name)) - print() - -class PyBenchCmdline(Application): - - header = ("PYBENCH - a benchmark test suite for Python " - "interpreters/compilers.") - - version = __version__ - - debug = _debug - - options = [ArgumentOption('-n', - 'number of rounds', - Setup.Number_of_rounds), - ArgumentOption('-f', - 'save benchmark to file arg', - ''), - ArgumentOption('-c', - 'compare benchmark with the one in file arg', - ''), - ArgumentOption('-s', - 'show benchmark in file arg, then exit', - ''), - ArgumentOption('-w', - 'set warp factor to arg', - Setup.Warp_factor), - ArgumentOption('-t', - 'run only tests with names matching arg', - ''), - ArgumentOption('-C', - 'set the number of calibration runs to arg', - CALIBRATION_RUNS), - SwitchOption('-d', - 'hide noise in comparisons', - 0), - SwitchOption('-v', - 'verbose output (not recommended)', - 0), - SwitchOption('--with-gc', - 'enable garbage collection', - 0), - SwitchOption('--with-syscheck', - 'use default sys check interval', - 0), - ArgumentOption('--timer', - 'use given timer', - TIMER_PLATFORM_DEFAULT), - ] - - about = """\ -The normal operation is to run the suite and display the -results. Use -f to save them for later reuse or comparisons. - -Available timers: - - time.time - time.clock - systimes.processtime - -Examples: - -python2.1 pybench.py -f p21.pybench -python2.5 pybench.py -f p25.pybench -python pybench.py -s p25.pybench -c p21.pybench -""" - copyright = __copyright__ - - def main(self): - - rounds = self.values['-n'] - reportfile = self.values['-f'] - show_bench = self.values['-s'] - compare_to = self.values['-c'] - hidenoise = self.values['-d'] - warp = int(self.values['-w']) - withgc = self.values['--with-gc'] - limitnames = self.values['-t'] - if limitnames: - if _debug: - print('* limiting test names to one with substring "%s"' % \ - limitnames) - limitnames = re.compile(limitnames, re.I) - else: - limitnames = None - verbose = self.verbose - withsyscheck = self.values['--with-syscheck'] - calibration_runs = self.values['-C'] - timer = self.values['--timer'] - - print('-' * LINE) - print('PYBENCH %s' % __version__) - print('-' * LINE) - print('* using %s %s' % ( - getattr(platform, 'python_implementation', lambda:'Python')(), - ' '.join(sys.version.split()))) - - # Switch off garbage collection - if not withgc: - try: - import gc - except ImportError: - print('* Python version doesn\'t support garbage collection') - else: - try: - gc.disable() - except NotImplementedError: - print('* Python version doesn\'t support gc.disable') - else: - print('* disabled garbage collection') - - # "Disable" sys check interval - if not withsyscheck: - # Too bad the check interval uses an int instead of a long... - value = 2147483647 - try: - sys.setcheckinterval(value) - except (AttributeError, NotImplementedError): - print('* Python version doesn\'t support sys.setcheckinterval') - else: - print('* system check interval set to maximum: %s' % value) - - if timer == TIMER_SYSTIMES_PROCESSTIME: - import systimes - print('* using timer: systimes.processtime (%s)' % \ - systimes.SYSTIMES_IMPLEMENTATION) - else: - # Check that the clock function does exist - try: - get_timer(timer) - except TypeError: - print("* Error: Unknown timer: %s" % timer) - return - - print('* using timer: %s' % timer) - if hasattr(time, 'get_clock_info'): - info = time.get_clock_info(timer[5:]) - print('* timer: resolution=%s, implementation=%s' - % (info.resolution, info.implementation)) - - print() - - if compare_to: - try: - f = open(compare_to,'rb') - bench = pickle.load(f) - bench.name = compare_to - f.close() - compare_to = bench - except IOError as reason: - print('* Error opening/reading file %s: %s' % ( - repr(compare_to), - reason)) - compare_to = None - - if show_bench: - try: - f = open(show_bench,'rb') - bench = pickle.load(f) - bench.name = show_bench - f.close() - bench.print_header() - if compare_to: - bench.print_comparison(compare_to, - hidenoise=hidenoise, - limitnames=limitnames) - else: - bench.print_benchmark(hidenoise=hidenoise, - limitnames=limitnames) - except IOError as reason: - print('* Error opening/reading file %s: %s' % ( - repr(show_bench), - reason)) - print() - return - - if reportfile: - print('Creating benchmark: %s (rounds=%i, warp=%i)' % \ - (reportfile, rounds, warp)) - print() - - # Create benchmark object - bench = Benchmark(reportfile, - verbose=verbose, - timer=timer, - warp=warp, - calibration_runs=calibration_runs) - bench.rounds = rounds - bench.load_tests(Setup, limitnames=limitnames) - try: - bench.calibrate() - bench.run() - except KeyboardInterrupt: - print() - print('*** KeyboardInterrupt -- Aborting') - print() - return - bench.print_header() - if compare_to: - bench.print_comparison(compare_to, - hidenoise=hidenoise, - limitnames=limitnames) - else: - bench.print_benchmark(hidenoise=hidenoise, - limitnames=limitnames) - - # Ring bell - sys.stderr.write('\007') - - if reportfile: - try: - f = open(reportfile,'wb') - bench.name = reportfile - pickle.dump(bench,f) - f.close() - except IOError as reason: - print('* Error opening/writing reportfile %s: %s' % ( - reportfile, - reason)) - print() - -if __name__ == '__main__': - PyBenchCmdline() diff --git a/Tools/pybench/systimes.py b/Tools/pybench/systimes.py deleted file mode 100755 index 5e00891..0000000 --- a/Tools/pybench/systimes.py +++ /dev/null @@ -1,214 +0,0 @@ -#!/usr/bin/env python - -""" systimes() user and system timer implementations for use by - pybench. - - This module implements various different strategies for measuring - performance timings. It tries to choose the best available method - based on the platform and available tools. - - On Windows, it is recommended to have the Mark Hammond win32 - package installed. Alternatively, the Thomas Heller ctypes - packages can also be used. - - On Unix systems, the standard resource module provides the highest - resolution timings. Unfortunately, it is not available on all Unix - platforms. - - If no supported timing methods based on process time can be found, - the module reverts to the highest resolution wall-clock timer - instead. The system time part will then always be 0.0. - - The module exports one public API: - - def systimes(): - - Return the current timer values for measuring user and system - time as tuple of seconds (user_time, system_time). - - Copyright (c) 2006, Marc-Andre Lemburg (mal@egenix.com). See the - documentation for further information on copyrights, or contact - the author. All Rights Reserved. - -""" - -from __future__ import print_function - -import time, sys - -# -# Note: Please keep this module compatible to Python 1.5.2. -# -# TODOs: -# -# * Add ctypes wrapper for new clock_gettime() real-time POSIX APIs; -# these will then provide nano-second resolution where available. -# -# * Add a function that returns the resolution of systimes() -# values, ie. systimesres(). -# - -### Choose an implementation - -SYSTIMES_IMPLEMENTATION = None -USE_CTYPES_GETPROCESSTIMES = 'ctypes GetProcessTimes() wrapper' -USE_WIN32PROCESS_GETPROCESSTIMES = 'win32process.GetProcessTimes()' -USE_RESOURCE_GETRUSAGE = 'resource.getrusage()' -USE_PROCESS_TIME_CLOCK = 'time.clock() (process time)' -USE_WALL_TIME_CLOCK = 'time.clock() (wall-clock)' -USE_WALL_TIME_TIME = 'time.time() (wall-clock)' - -if sys.platform[:3] == 'win': - # Windows platform - try: - import win32process - except ImportError: - try: - import ctypes - except ImportError: - # Use the wall-clock implementation time.clock(), since this - # is the highest resolution clock available on Windows - SYSTIMES_IMPLEMENTATION = USE_WALL_TIME_CLOCK - else: - SYSTIMES_IMPLEMENTATION = USE_CTYPES_GETPROCESSTIMES - else: - SYSTIMES_IMPLEMENTATION = USE_WIN32PROCESS_GETPROCESSTIMES -else: - # All other platforms - try: - import resource - except ImportError: - pass - else: - SYSTIMES_IMPLEMENTATION = USE_RESOURCE_GETRUSAGE - -# Fall-back solution -if SYSTIMES_IMPLEMENTATION is None: - # Check whether we can use time.clock() as approximation - # for systimes() - start = time.clock() - time.sleep(0.1) - stop = time.clock() - if stop - start < 0.001: - # Looks like time.clock() is usable (and measures process - # time) - SYSTIMES_IMPLEMENTATION = USE_PROCESS_TIME_CLOCK - else: - # Use wall-clock implementation time.time() since this provides - # the highest resolution clock on most systems - SYSTIMES_IMPLEMENTATION = USE_WALL_TIME_TIME - -### Implementations - -def getrusage_systimes(): - return resource.getrusage(resource.RUSAGE_SELF)[:2] - -def process_time_clock_systimes(): - return (time.clock(), 0.0) - -def wall_clock_clock_systimes(): - return (time.clock(), 0.0) - -def wall_clock_time_systimes(): - return (time.time(), 0.0) - -# Number of clock ticks per second for the values returned -# by GetProcessTimes() on Windows. -# -# Note: Ticks returned by GetProcessTimes() are 100ns intervals on -# Windows XP. However, the process times are only updated with every -# clock tick and the frequency of these is somewhat lower: depending -# on the OS version between 10ms and 15ms. Even worse, the process -# time seems to be allocated to process currently running when the -# clock interrupt arrives, ie. it is possible that the current time -# slice gets accounted to a different process. - -WIN32_PROCESS_TIMES_TICKS_PER_SECOND = 1e7 - -def win32process_getprocesstimes_systimes(): - d = win32process.GetProcessTimes(win32process.GetCurrentProcess()) - return (d['UserTime'] / WIN32_PROCESS_TIMES_TICKS_PER_SECOND, - d['KernelTime'] / WIN32_PROCESS_TIMES_TICKS_PER_SECOND) - -def ctypes_getprocesstimes_systimes(): - creationtime = ctypes.c_ulonglong() - exittime = ctypes.c_ulonglong() - kerneltime = ctypes.c_ulonglong() - usertime = ctypes.c_ulonglong() - rc = ctypes.windll.kernel32.GetProcessTimes( - ctypes.windll.kernel32.GetCurrentProcess(), - ctypes.byref(creationtime), - ctypes.byref(exittime), - ctypes.byref(kerneltime), - ctypes.byref(usertime)) - if not rc: - raise TypeError('GetProcessTimes() returned an error') - return (usertime.value / WIN32_PROCESS_TIMES_TICKS_PER_SECOND, - kerneltime.value / WIN32_PROCESS_TIMES_TICKS_PER_SECOND) - -# Select the default for the systimes() function - -if SYSTIMES_IMPLEMENTATION is USE_RESOURCE_GETRUSAGE: - systimes = getrusage_systimes - -elif SYSTIMES_IMPLEMENTATION is USE_PROCESS_TIME_CLOCK: - systimes = process_time_clock_systimes - -elif SYSTIMES_IMPLEMENTATION is USE_WALL_TIME_CLOCK: - systimes = wall_clock_clock_systimes - -elif SYSTIMES_IMPLEMENTATION is USE_WALL_TIME_TIME: - systimes = wall_clock_time_systimes - -elif SYSTIMES_IMPLEMENTATION is USE_WIN32PROCESS_GETPROCESSTIMES: - systimes = win32process_getprocesstimes_systimes - -elif SYSTIMES_IMPLEMENTATION is USE_CTYPES_GETPROCESSTIMES: - systimes = ctypes_getprocesstimes_systimes - -else: - raise TypeError('no suitable systimes() implementation found') - -def processtime(): - - """ Return the total time spent on the process. - - This is the sum of user and system time as returned by - systimes(). - - """ - user, system = systimes() - return user + system - -### Testing - -def some_workload(): - x = 0 - for i in range(10000000): - x = x + 1 - -def test_workload(): - print('Testing systimes() under load conditions') - t0 = systimes() - some_workload() - t1 = systimes() - print('before:', t0) - print('after:', t1) - print('differences:', (t1[0] - t0[0], t1[1] - t0[1])) - print() - -def test_idle(): - print('Testing systimes() under idle conditions') - t0 = systimes() - time.sleep(1) - t1 = systimes() - print('before:', t0) - print('after:', t1) - print('differences:', (t1[0] - t0[0], t1[1] - t0[1])) - print() - -if __name__ == '__main__': - print('Using %s as timer' % SYSTIMES_IMPLEMENTATION) - print() - test_workload() - test_idle() diff --git a/Tools/scripts/google.py b/Tools/scripts/google.py index 12152bb..82fb287 100755 --- a/Tools/scripts/google.py +++ b/Tools/scripts/google.py @@ -1,23 +1,25 @@ #! /usr/bin/env python3 -import sys, webbrowser +"""Script to search with Google -def main(): - args = sys.argv[1:] - if not args: - print("Usage: %s querystring" % sys.argv[0]) - return - list = [] - for arg in args: - if '+' in arg: - arg = arg.replace('+', '%2B') +Usage: + python3 google.py [search terms] +""" + +import sys +import urllib.parse +import webbrowser + + +def main(args): + def quote(arg): if ' ' in arg: arg = '"%s"' % arg - arg = arg.replace(' ', '+') - list.append(arg) - s = '+'.join(list) - url = "http://www.google.com/search?q=%s" % s + return urllib.parse.quote_plus(arg) + + qstring = '+'.join(quote(arg) for arg in args) + url = urllib.parse.urljoin('https://www.google.com/search', '?q=' + qstring) webbrowser.open(url) if __name__ == '__main__': - main() + main(sys.argv[1:]) @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.69 for python 3.6. +# Generated by GNU Autoconf 2.69 for python 3.7. # # Report bugs to <https://bugs.python.org/>. # @@ -580,8 +580,8 @@ MAKEFLAGS= # Identity of this package. PACKAGE_NAME='python' PACKAGE_TARNAME='python' -PACKAGE_VERSION='3.6' -PACKAGE_STRING='python 3.6' +PACKAGE_VERSION='3.7' +PACKAGE_STRING='python 3.7' PACKAGE_BUGREPORT='https://bugs.python.org/' PACKAGE_URL='' @@ -1407,7 +1407,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures python 3.6 to adapt to many kinds of systems. +\`configure' configures python 3.7 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1474,7 +1474,7 @@ fi if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of python 3.6:";; + short | recursive ) echo "Configuration of python 3.7:";; esac cat <<\_ACEOF @@ -1632,7 +1632,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -python configure 3.6 +python configure 3.7 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. @@ -2341,7 +2341,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by python $as_me 3.6, which was +It was created by python $as_me 3.7, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ @@ -2968,7 +2968,7 @@ rm confdefs.h mv confdefs.h.new confdefs.h -VERSION=3.6 +VERSION=3.7 # Version number of Python's own shared library file. @@ -17092,7 +17092,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by python $as_me 3.6, which was +This file was extended by python $as_me 3.7, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -17154,7 +17154,7 @@ _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ -python config.status 3.6 +python config.status 3.7 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" diff --git a/configure.ac b/configure.ac index 0a140db..767eacc 100644 --- a/configure.ac +++ b/configure.ac @@ -3,7 +3,7 @@ dnl * Please run autoreconf to test your changes! * dnl *********************************************** # Set VERSION so we only need to edit in one place (i.e., here) -m4_define(PYTHON_VERSION, 3.6) +m4_define(PYTHON_VERSION, 3.7) AC_PREREQ(2.65) |