From solipsis at pitrou.net Sat Jul 1 05:07:35 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sat, 01 Jul 2017 09:07:35 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=0 Message-ID: <20170701090735.95724.4CC3F2DD27FD705D@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 3, 0] memory blocks, sum=3 test_collections leaked [0, 0, -7] memory blocks, sum=-7 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogMImdCm', '--timeout', '7200'] From noreply at github.com Sat Jul 1 08:14:47 2017 From: noreply at github.com (GitHub) Date: Sat, 01 Jul 2017 05:14:47 -0700 Subject: [Python-checkins] [python/cpython] 85f643: bpo-30695: Add set_nomemory(start, stop) to _testc... Message-ID: <59579237131a4_6f333fdcc47b5c2479876@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 85f643023fed3d4e2fb8e399f9ad57f3a65ef237 https://github.com/python/cpython/commit/85f643023fed3d4e2fb8e399f9ad57f3a65ef237 Author: xdegaye Date: 2017-07-01 (Sat, 01 Jul 2017) Changed paths: M Lib/test/test_capi.py A Misc/NEWS.d/next/Tests/2017-06-30-11-20-20.bpo-30695.lo7FQX.rst M Modules/_testcapimodule.c Log Message: ----------- bpo-30695: Add set_nomemory(start, stop) to _testcapi (GH-2406) From noreply at github.com Sat Jul 1 13:12:07 2017 From: noreply at github.com (GitHub) Date: Sat, 01 Jul 2017 10:12:07 -0700 Subject: [Python-checkins] [python/cpython] 3024c0: [3.6] bpo-30703: Improve signal delivery (GH-2415)... Message-ID: <5957d7e75bf42_43d93f8f4dbf5c2c1205f0@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 3024c0529077f5cff0b32dc84b5923c8fba99a87 https://github.com/python/cpython/commit/3024c0529077f5cff0b32dc84b5923c8fba99a87 Author: Antoine Pitrou Date: 2017-07-01 (Sat, 01 Jul 2017) Changed paths: M Include/ceval.h M Lib/test/test_signal.py A Misc/NEWS.d/next/Core and Builtins/2017-06-28-21-07-32.bpo-30703.ULCdFp.rst M Modules/signalmodule.c M Python/ceval.c Log Message: ----------- [3.6] bpo-30703: Improve signal delivery (GH-2415) (#2527) * [3.6] bpo-30703: Improve signal delivery (GH-2415) * Improve signal delivery Avoid using Py_AddPendingCall from signal handler, to avoid calling signal-unsafe functions. * Remove unused function * Improve comments * Add stress test * Adapt for --without-threads * Add second stress test * Add NEWS blurb * Address comments @haypo. (cherry picked from commit c08177a1ccad2ed0d50898c2731b518c631aed14) * bpo-30796: Fix failures in signal delivery stress test (#2488) * bpo-30796: Fix failures in signal delivery stress test setitimer() can have a poor minimum resolution on some machines, this would make the test reach its deadline (and a stray signal could then kill a subsequent test). * Make sure to clear the itimer after the test From noreply at github.com Sat Jul 1 13:34:46 2017 From: noreply at github.com (GitHub) Date: Sat, 01 Jul 2017 10:34:46 -0700 Subject: [Python-checkins] [python/cpython] 8a8d28: bpo-30441: Fix bug when modifying os.environ while... Message-ID: <5957dd36a6939_49583fb36e1f5c28162164@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 8a8d28501fc8ce25926d168f1c657656c809fd4c https://github.com/python/cpython/commit/8a8d28501fc8ce25926d168f1c657656c809fd4c Author: Osvaldo Santana Neto Date: 2017-07-01 (Sat, 01 Jul 2017) Changed paths: M Lib/os.py M Lib/test/test_os.py M Misc/ACKS A Misc/NEWS.d/next/Library/2017-06-29-14-25-14.bpo-30441.3Wh9kc.rst Log Message: ----------- bpo-30441: Fix bug when modifying os.environ while iterating over it (#2409) From noreply at github.com Sat Jul 1 22:47:57 2017 From: noreply at github.com (GitHub) Date: Sat, 01 Jul 2017 19:47:57 -0700 Subject: [Python-checkins] [python/cpython] 4685e5: [3.5] bpo-29933: Improve set_write_buffer_limits d... Message-ID: <59585eddda966_50593f8a7cb2fc281297fc@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 4685e56596f9f332e402c79c913a73b19f4411e1 https://github.com/python/cpython/commit/4685e56596f9f332e402c79c913a73b19f4411e1 Author: Kojo Idrissa Date: 2017-07-01 (Sat, 01 Jul 2017) Changed paths: M Doc/library/asyncio-protocol.rst Log Message: ----------- [3.5] bpo-29933: Improve set_write_buffer_limits description (GH-2262) (GH-2533) Improve the description of the high and low parameters for set_write_buffer_limits. Also fixed a small grammatical issue. (cherry picked from commit 5200a7c7f9ea65a96330c5f276f4acc6ec70854e) From noreply at github.com Sat Jul 1 22:48:09 2017 From: noreply at github.com (GitHub) Date: Sat, 01 Jul 2017 19:48:09 -0700 Subject: [Python-checkins] [python/cpython] 03af42: [3.6] bpo-29933: Improve set_write_buffer_limits d... Message-ID: <59585ee961fe0_6c953fe284eabc341569e4@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 03af4282423b1c287a194664f90496cfc9cf20c7 https://github.com/python/cpython/commit/03af4282423b1c287a194664f90496cfc9cf20c7 Author: Kojo Idrissa Date: 2017-07-01 (Sat, 01 Jul 2017) Changed paths: M Doc/library/asyncio-protocol.rst Log Message: ----------- [3.6] bpo-29933: Improve set_write_buffer_limits description (GH-2262) (GH-2532) Improve the description of the high and low parameters for set_write_buffer_limits. Also fixed a small grammatical issue. (cherry picked from commit 5200a7c7f9ea65a96330c5f276f4acc6ec70854e) From solipsis at pitrou.net Sun Jul 2 05:06:49 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sun, 02 Jul 2017 09:06:49 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=14 Message-ID: <20170702090648.31018.998269C4703C33E4@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 0, 3] memory blocks, sum=3 test_collections leaked [0, 7, 0] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogLUuHF7', '--timeout', '7200'] From noreply at github.com Sun Jul 2 08:46:06 2017 From: noreply at github.com (GitHub) Date: Sun, 02 Jul 2017 05:46:06 -0700 Subject: [Python-checkins] [python/cpython] 98b6bc: bpo-30822: Fix testing of datetime module. (#2530) Message-ID: <5958eb0e1ef31_4c503ff634b99c30142035@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 98b6bc3bf72532b784a1c1fa76eaa6026a663e44 https://github.com/python/cpython/commit/98b6bc3bf72532b784a1c1fa76eaa6026a663e44 Author: Utkarsh Upadhyay Date: 2017-07-02 (Sun, 02 Jul 2017) Changed paths: M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Misc/ACKS Log Message: ----------- bpo-30822: Fix testing of datetime module. (#2530) Only C implementation was tested. From noreply at github.com Sun Jul 2 15:36:13 2017 From: noreply at github.com (GitHub) Date: Sun, 02 Jul 2017 12:36:13 -0700 Subject: [Python-checkins] [python/cpython] 34b548: bpo-30822: Deduplicate ZoneInfoTest classes in tes... Message-ID: <59594b2d6769b_7f7b3fa86f681c24111138@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 34b54873b51a1ebee2a3c57b7205537b4f33128d https://github.com/python/cpython/commit/34b54873b51a1ebee2a3c57b7205537b4f33128d Author: Serhiy Storchaka Date: 2017-07-02 (Sun, 02 Jul 2017) Changed paths: M Lib/test/test_datetime.py Log Message: ----------- bpo-30822: Deduplicate ZoneInfoTest classes in test_datetime. (#2534) From noreply at github.com Mon Jul 3 03:49:51 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 00:49:51 -0700 Subject: [Python-checkins] [python/cpython] bfdc6f: [3.6] bpo-30597: Show expected input in custom 'pr... Message-ID: <5959f71fdc6ce_55ce3fe54e2c5c2c113286@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: bfdc6fdc0e76204caf2261f9cfa9d232fc23906a https://github.com/python/cpython/commit/bfdc6fdc0e76204caf2261f9cfa9d232fc23906a Author: Nick Coghlan Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Lib/test/test_print.py M Misc/NEWS M Objects/exceptions.c Log Message: ----------- [3.6] bpo-30597: Show expected input in custom 'print' error message. (GH-2531) (cherry picked from commit 3a7f03584ab75afbf5507970711c87042e423bb4) From solipsis at pitrou.net Mon Jul 3 05:07:36 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Mon, 03 Jul 2017 09:07:36 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=-2 Message-ID: <20170703090736.46397.C2C01BC1A953037E@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [-7, 1, 0] memory blocks, sum=-6 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_spawn leaked [0, -2, 2] memory blocks, sum=0 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflog3wz1br', '--timeout', '7200'] From noreply at github.com Mon Jul 3 05:16:02 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 02:16:02 -0700 Subject: [Python-checkins] [python/cpython] 5e8759: bpo-30764: Fix regrtest --fail-env-changed --forev... Message-ID: <595a0b5267992_6bdc3fd92a713c28158920@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 5e87592fd12e0b7c41edc11d4885ed7298d5063b https://github.com/python/cpython/commit/5e87592fd12e0b7c41edc11d4885ed7298d5063b Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Lib/test/libregrtest/main.py Log Message: ----------- bpo-30764: Fix regrtest --fail-env-changed --forever (#2536) --forever now stops if a fail changes the environment. From noreply at github.com Mon Jul 3 06:50:38 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 03:50:38 -0700 Subject: [Python-checkins] [python/cpython] 4132ad: bpo-30764: Fix regrtest --fail-env-changed --forev... Message-ID: <595a217ec7a0_27b63fcfa7b5dc3413369c@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 4132adb4b8f90893d8f19ff46edff56f189faca0 https://github.com/python/cpython/commit/4132adb4b8f90893d8f19ff46edff56f189faca0 Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Lib/test/libregrtest/main.py Log Message: ----------- bpo-30764: Fix regrtest --fail-env-changed --forever (#2536) (#2539) --forever now stops if a fail changes the environment. (cherry picked from commit 5e87592fd12e0b7c41edc11d4885ed7298d5063b) From noreply at github.com Mon Jul 3 07:16:59 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 04:16:59 -0700 Subject: [Python-checkins] [python/cpython] 0b1210: [3.5] bpo-29512, bpo-30764, bpo-30776: Backport re... Message-ID: <595a27abb8848_18d03fcad6d99c3018208a@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 0b1210739d12c26e4a161ffd494bd572d49b2483 https://github.com/python/cpython/commit/0b1210739d12c26e4a161ffd494bd572d49b2483 Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: A Lib/test/bisect.py M Lib/test/regrtest.py Log Message: ----------- [3.5] bpo-29512, bpo-30764, bpo-30776: Backport regrtest enhancements from 3.6 to 3.5 (#2540) * [3.6] bpo-29512, bpo-30776: Backport regrtest enhancements from master to 3.6 (#2513) * bpo-29512: Add test.bisect, bisect failing tests (#2452) Add a new "python3 -m test.bisect" tool to bisect failing tests. It can be used to find which test method(s) leak references, leak files, etc. (cherry picked from commit 84d9d14a1fa395fbd21262ba195490be25a7b3bc) * bpo-30776: regrtest: reduce memleak false positive (#2484) Only report a leak if each run leaks at least one memory block. (cherry picked from commit beeca6e1e5fd01531b1db7059498b13d07dca525) (cherry picked from commit a3ca94d0504157a112a1f89bfe8be1307116fc73) * bpo-30764: Fix regrtest --fail-env-changed --forever (#2536) (#2539) --forever now stops if a fail changes the environment. (cherry picked from commit 5e87592fd12e0b7c41edc11d4885ed7298d5063b) (cherry picked from commit 4132adb4b8f90893d8f19ff46edff56f189faca0) From noreply at github.com Mon Jul 3 07:34:40 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 04:34:40 -0700 Subject: [Python-checkins] [python/cpython] aa0aa0: bpo-30832: Remove own implementation for thread-lo... Message-ID: <595a2bd036a7c_6c783fb206ef7c28125292@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: aa0aa0492c5fffe750a26d2ab13737a1a6d7d63c https://github.com/python/cpython/commit/aa0aa0492c5fffe750a26d2ab13737a1a6d7d63c Author: Masayuki Yamamoto Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: A Misc/NEWS.d/next/C API/2017-07-03-17-25-40.bpo-30832.PcTAEP.rst M Python/thread.c M Python/thread_nt.h M Python/thread_pthread.h Log Message: ----------- bpo-30832: Remove own implementation for thread-local storage (#2537) * bpo-30832: Remove own implementation for thread-local storage CPython has provided the own implementation for thread-local storage (TLS) on Python/thread.c, it's used in the case which a platform has not supplied native TLS. However, currently all supported platforms (NT and pthreads) have provided native TLS and defined the Py_HAVE_NATIVE_TLS macro with unconditional in any case. * bpo-30832: replace NT with Windows * bpo-30832: change to directive chain * bpo-30832: remove comemnt which making no sense From noreply at github.com Mon Jul 3 09:07:56 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 06:07:56 -0700 Subject: [Python-checkins] [python/cpython] d7955b: [2.7] bpo-29512, bpo-30764: Backport regrtest enha... Message-ID: <595a41ac38c5_24903ff0250b3c2c1448f6@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: d7955b8196578306e9d86f6c61c9cb3ee72edab0 https://github.com/python/cpython/commit/d7955b8196578306e9d86f6c61c9cb3ee72edab0 Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: A Lib/test/bisect.py M Lib/test/regrtest.py M Lib/test/test_bisect.py Log Message: ----------- [2.7] bpo-29512, bpo-30764: Backport regrtest enhancements from 3.5 to 2.7 (#2541) * bpo-29512, bpo-30764: Backport regrtest enhancements from 3.5 to 2.7 * bpo-29512: Add test.bisect, bisect failing tests (#2452) Add a new "python3 -m test.bisect" tool to bisect failing tests. It can be used to find which test method(s) leak references, leak files, etc. * bpo-30764: Fix regrtest --fail-env-changed --forever (#2536) (#2539) --forever now stops if a fail changes the environment. * Fix test_bisect: use absolute import From noreply at github.com Mon Jul 3 14:20:16 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 11:20:16 -0700 Subject: [Python-checkins] [python/cpython] 6969ea: bpo-29464: Rename METH_FASTCALL to METH_FASTCALL|M... Message-ID: <595a8ae0ea7f9_157c13fef2893fc2c20674d@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 6969eaf4682beb01bc95eeb14f5ce6c01312e297 https://github.com/python/cpython/commit/6969eaf4682beb01bc95eeb14f5ce6c01312e297 Author: Serhiy Storchaka Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Include/methodobject.h M Modules/_collectionsmodule.c M Modules/_elementtree.c M Modules/_hashopenssl.c M Modules/_io/clinic/_iomodule.c.h M Modules/_io/clinic/bufferedio.c.h M Modules/_io/clinic/bytesio.c.h M Modules/_io/clinic/fileio.c.h M Modules/_io/clinic/iobase.c.h M Modules/_io/clinic/stringio.c.h M Modules/_io/clinic/textio.c.h M Modules/_io/clinic/winconsoleio.c.h M Modules/_sha3/clinic/sha3module.c.h M Modules/_struct.c M Modules/cjkcodecs/clinic/multibytecodec.c.h M Modules/clinic/_asynciomodule.c.h M Modules/clinic/_bz2module.c.h M Modules/clinic/_codecsmodule.c.h M Modules/clinic/_cryptmodule.c.h M Modules/clinic/_datetimemodule.c.h M Modules/clinic/_dbmmodule.c.h M Modules/clinic/_elementtree.c.h M Modules/clinic/_gdbmmodule.c.h M Modules/clinic/_hashopenssl.c.h M Modules/clinic/_lzmamodule.c.h M Modules/clinic/_opcode.c.h M Modules/clinic/_operator.c.h M Modules/clinic/_pickle.c.h M Modules/clinic/_sre.c.h M Modules/clinic/_ssl.c.h M Modules/clinic/_struct.c.h M Modules/clinic/_tkinter.c.h M Modules/clinic/_tracemalloc.c.h M Modules/clinic/_weakref.c.h M Modules/clinic/_winapi.c.h M Modules/clinic/arraymodule.c.h M Modules/clinic/audioop.c.h M Modules/clinic/binascii.c.h M Modules/clinic/cmathmodule.c.h M Modules/clinic/fcntlmodule.c.h M Modules/clinic/gcmodule.c.h M Modules/clinic/grpmodule.c.h M Modules/clinic/mathmodule.c.h M Modules/clinic/md5module.c.h M Modules/clinic/posixmodule.c.h M Modules/clinic/pyexpat.c.h M Modules/clinic/resource.c.h M Modules/clinic/sha1module.c.h M Modules/clinic/sha256module.c.h M Modules/clinic/sha512module.c.h M Modules/clinic/signalmodule.c.h M Modules/clinic/symtablemodule.c.h M Modules/clinic/unicodedata.c.h M Modules/clinic/zlibmodule.c.h M Objects/call.c M Objects/clinic/bytearrayobject.c.h M Objects/clinic/bytesobject.c.h M Objects/clinic/dictobject.c.h M Objects/clinic/floatobject.c.h M Objects/clinic/listobject.c.h M Objects/clinic/longobject.c.h M Objects/clinic/odictobject.c.h M Objects/clinic/tupleobject.c.h M Objects/clinic/unicodeobject.c.h M Objects/dictobject.c M Objects/typeobject.c M PC/clinic/_testconsole.c.h M PC/clinic/msvcrtmodule.c.h M PC/clinic/winreg.c.h M PC/clinic/winsound.c.h M Python/bltinmodule.c M Python/clinic/_warnings.c.h M Python/clinic/bltinmodule.c.h M Python/clinic/import.c.h M Python/clinic/marshal.c.h M Tools/clinic/clinic.py Log Message: ----------- bpo-29464: Rename METH_FASTCALL to METH_FASTCALL|METH_KEYWORDS and make (#1955) the bare METH_FASTCALL be used for functions with positional-only parameters. From noreply at github.com Mon Jul 3 16:01:58 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 13:01:58 -0700 Subject: [Python-checkins] [python/cpython] c51a8e: [2.7] Rename test_ file that is really a support f... Message-ID: <595aa2b6c0e74_4fb23fd59c725c3497973@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: c51a8e907227591f74015eaeed5ddb37e7883a66 https://github.com/python/cpython/commit/c51a8e907227591f74015eaeed5ddb37e7883a66 Author: Serhiy Storchaka Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: A Lib/test/multibytecodec_support.py M Lib/test/test_codecencodings_cn.py M Lib/test/test_codecencodings_hk.py M Lib/test/test_codecencodings_iso2022.py M Lib/test/test_codecencodings_jp.py M Lib/test/test_codecencodings_kr.py M Lib/test/test_codecencodings_tw.py M Lib/test/test_codecmaps_cn.py M Lib/test/test_codecmaps_hk.py M Lib/test/test_codecmaps_jp.py M Lib/test/test_codecmaps_kr.py M Lib/test/test_codecmaps_tw.py R Lib/test/test_multibytecodec_support.py Log Message: ----------- [2.7] Rename test_ file that is really a support file to remove test_ prefix. (#2548) I thought I had run the full test suite before the last checkin, but obviously I didn't. test_multibytecodec_support.py isn't really a test file, it is a support file that contains a base test class. Rename it to multibytecodec_support so that regrtest test discovery doesn't think it is a test file that should be run.. (cherry picked from commit 75d9aca97ad3c3d823d2f2211f579454b3216f51) From noreply at github.com Mon Jul 3 16:18:30 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 13:18:30 -0700 Subject: [Python-checkins] [python/cpython] 1e4fcb: regrtest: fix --list-cases --verbose (#2547) Message-ID: <595aa696bb6d_4fa33f99549afc2c168313@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 1e4fcb3edd9b6bde302f8aa96c83507ae01b7e4e https://github.com/python/cpython/commit/1e4fcb3edd9b6bde302f8aa96c83507ae01b7e4e Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Lib/test/regrtest.py Log Message: ----------- regrtest: fix --list-cases --verbose (#2547) Write header and "Using seed ..." after checking for --list-cases and --list-tests. From lp_benchmark_robot at intel.com Mon Jul 3 17:24:54 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Mon, 3 Jul 2017 14:24:54 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-03 Message-ID: Results for project python/master, build date: 2017-07-03 03:03:31-07:00. - commit: 5e87592 - previous commit: b903067 - revision date: 2017-07-03 11:15:58+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.164% | +0.026% | +5.229% | +6.622% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 2.158% | -0.728% | +20.231% | +16.854% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 0.510% | +0.155% | +21.900% | +13.796% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.398% | +0.137% | +20.331% | +14.284% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.755% | +1.025% | +5.510% | +11.501% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.642% | +0.223% | +11.382% | +7.558% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.048% | -0.097% | +6.743% | +10.842% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.382% | -0.133% | +3.230% | +7.290% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 2.337% | +0.110% | +10.970% | +15.362% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.302% | +0.780% | +10.396% | +13.214% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.060% | +0.226% | +3.814% | +6.854% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.638% | -0.103% | +4.838% | +6.837% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.907% | -0.202% | +3.904% | +5.358% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 0.879% | +0.411% | +9.575% | +11.224% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.481% | -0.646% | +8.331% | +8.730% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.854% | -0.071% | +7.386% | +10.511% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.313% | -0.028% | +8.949% | +11.674% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.413% | +0.180% | +8.409% | +9.226% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.850% | -0.136% | +4.120% | +9.471% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 6.438% | +0.561% | +2.064% | +11.774% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.835% | -0.378% | +6.326% | +11.444% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.458% | +0.913% | +12.770% | +12.627% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.615% | +0.611% | +8.422% | +11.516% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.795% | -0.003% | +17.830% | +12.263% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 4.173% | +1.597% | +5.248% | +12.943% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.615% | +0.415% | +3.518% | +5.469% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.516% | -0.586% | -3.020% | +3.588% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.576% | +0.366% | +1.542% | +8.571% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.107% | +0.917% | +3.768% | +10.629% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 3.106% | -0.380% | +0.382% | +24.422% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.880% | +0.423% | +2.502% | +22.844% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.840% | -0.354% | +4.789% | +19.237% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 4.836% | -0.088% | +12.062% | +10.757% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.179% | -0.077% | +0.265% | +9.622% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.114% | +0.053% | +9.573% | +4.245% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.084% | +0.140% | +1.318% | +4.226% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.111% | +0.231% | +9.564% | +12.713% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.569% | -3.136% | -12.431% | +14.581% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.941% | -0.130% | -1.962% | +11.673% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.454% | +0.848% | -2.458% | +7.183% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.710% | +1.358% | +10.564% | +3.464% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.308% | -0.110% | +8.962% | +13.294% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.382% | +0.360% | +0.718% | +0.617% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.606% | -0.765% | +25.747% | +9.917% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.499% | -0.350% | +5.433% | +4.984% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.839% | -0.044% | +15.011% | +8.203% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 0.474% | -0.186% | -1.156% | +0.729% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.719% | +0.327% | +5.793% | +0.367% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.559% | +0.093% | +6.116% | +7.448% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.303% | -0.057% | +4.722% | +4.242% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.150% | +1.073% | +0.987% | +10.327% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.544% | -0.268% | +12.754% | +8.492% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.829% | +0.176% | +10.273% | +7.064% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.880% | -0.283% | +11.881% | +9.785% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.160% | +0.974% | +14.163% | +8.753% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.010% | +0.379% | +22.666% | +9.746% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.215% | +0.169% | +6.481% | +5.896% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.655% | +0.400% | +2.730% | -0.058% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.792% | -0.399% | +9.258% | +19.742% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 2.304% | +0.361% | -1.509% | +18.611% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.866% | -0.085% | +7.834% | +7.096% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.009% | +0.147% | +6.250% | +7.598% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.283% | -0.289% | +2.188% | +6.238% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.838% | +0.277% | -7.043% | +9.506% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.369% | +0.298% | +6.714% | +7.486% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-03 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Mon Jul 3 17:37:16 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 14:37:16 -0700 Subject: [Python-checkins] [python/cpython] d1b474: Tools/buildbot/test.bat: add --slowest option (#25... Message-ID: <595ab90c37e64_2b4e3f8f3fa33c301387d4@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: d1b474cfd782ead35c8cb1be4680639ad0682413 https://github.com/python/cpython/commit/d1b474cfd782ead35c8cb1be4680639ad0682413 Author: Victor Stinner Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Tools/buildbot/test.bat Log Message: ----------- Tools/buildbot/test.bat: add --slowest option (#2552) From noreply at github.com Mon Jul 3 21:31:26 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 18:31:26 -0700 Subject: [Python-checkins] [python/cpython] 246ff3: bpo-6691: Pyclbr now reports nested classes and fu... Message-ID: <595aefeed6908_6a513fcc81f0dc402523cd@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 246ff3bd00f97658e567a7087645a6b76e056491 https://github.com/python/cpython/commit/246ff3bd00f97658e567a7087645a6b76e056491 Author: csabella Date: 2017-07-03 (Mon, 03 Jul 2017) Changed paths: M Doc/library/pyclbr.rst M Lib/pyclbr.py M Lib/test/test_pyclbr.py Log Message: ----------- bpo-6691: Pyclbr now reports nested classes and functions. (#2503) Original patch by Guilherme Polo. Revisions by Cheryl Sabella. From noreply at github.com Tue Jul 4 00:55:33 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 21:55:33 -0700 Subject: [Python-checkins] [python/cpython] bebd2c: [3.6] bpo-30441: Fix bug when modifying os.environ... Message-ID: <595b1fc573cec_3503fbf44c13c2814817f@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: bebd2cfa5f21811dd0ee4f3b1a1b85d379b83436 https://github.com/python/cpython/commit/bebd2cfa5f21811dd0ee4f3b1a1b85d379b83436 Author: Serhiy Storchaka Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/os.py M Lib/test/test_os.py M Misc/ACKS A Misc/NEWS.d/next/Library/2017-06-29-14-25-14.bpo-30441.3Wh9kc.rst Log Message: ----------- [3.6] bpo-30441: Fix bug when modifying os.environ while iterating over it (GH-2409). (#2556) (cherry picked from commit 8a8d28501fc8ce25926d168f1c657656c809fd4c) From noreply at github.com Tue Jul 4 00:55:47 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 21:55:47 -0700 Subject: [Python-checkins] [python/cpython] 1a3bc5: [3.5] bpo-30441: Fix bug when modifying os.environ... Message-ID: <595b1fd33f5f8_ef23fc766f67c38110379@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 1a3bc5546aa27f01426ad76618a9b2c3b698ae68 https://github.com/python/cpython/commit/1a3bc5546aa27f01426ad76618a9b2c3b698ae68 Author: Serhiy Storchaka Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/os.py M Lib/test/test_os.py M Misc/ACKS A Misc/NEWS.d/next/Library/2017-06-29-14-25-14.bpo-30441.3Wh9kc.rst Log Message: ----------- [3.5] bpo-30441: Fix bug when modifying os.environ while iterating over it (GH-2409). (#2557) (cherry picked from commit 8a8d28501fc8ce25926d168f1c657656c809fd4c) From noreply at github.com Tue Jul 4 02:13:12 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 23:13:12 -0700 Subject: [Python-checkins] [python/cpython] d3ed28: Remove outdated FOX from GUI FAQ (GH-2538) Message-ID: <595b31f85445b_ea23fa27ae3fc40131426@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: d3ed2877a798d07df75422afe136b4727e500c99 https://github.com/python/cpython/commit/d3ed2877a798d07df75422afe136b4727e500c99 Author: Berker Peksag Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Doc/faq/gui.rst Log Message: ----------- Remove outdated FOX from GUI FAQ (GH-2538) FXpy doesn't have a Python 3 port and it only supports Python 2.2 and older versions. Reported by Alex Walters on docs at p.o. From noreply at github.com Tue Jul 4 02:27:37 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 23:27:37 -0700 Subject: [Python-checkins] [python/cpython] 23e2c3: Remove outdated FOX from GUI FAQ (GH-2538) Message-ID: <595b35594167e_7f813fef3c35bc34103524@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 23e2c3d193eafa8d16d895a2e59b6f6571e50cd3 https://github.com/python/cpython/commit/23e2c3d193eafa8d16d895a2e59b6f6571e50cd3 Author: Berker Peksag Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Doc/faq/gui.rst Log Message: ----------- Remove outdated FOX from GUI FAQ (GH-2538) FXpy doesn't have a Python 3 port and it only supports Python 2.2 and older versions. Reported by Alex Walters on docs at p.o. (cherry picked from commit d3ed2877a798d07df75422afe136b4727e500c99) From noreply at github.com Tue Jul 4 02:27:49 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 23:27:49 -0700 Subject: [Python-checkins] [python/cpython] 2e5867: Remove outdated FOX from GUI FAQ (GH-2538) Message-ID: <595b3565e899c_13ae3fc31ecd3c342068a8@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 2e5867d93ab2717f55e0b0622a38d917b00c05e3 https://github.com/python/cpython/commit/2e5867d93ab2717f55e0b0622a38d917b00c05e3 Author: Berker Peksag Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Doc/faq/gui.rst Log Message: ----------- Remove outdated FOX from GUI FAQ (GH-2538) FXpy doesn't have a Python 3 port and it only supports Python 2.2 and older versions. Reported by Alex Walters on docs at p.o. (cherry picked from commit d3ed2877a798d07df75422afe136b4727e500c99) From noreply at github.com Tue Jul 4 02:28:03 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 23:28:03 -0700 Subject: [Python-checkins] [python/cpython] ebf7d2: Remove outdated FOX from GUI FAQ (GH-2538) Message-ID: <595b3573cf701_5ba3fa6e15a1c301370eb@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: ebf7d21129300aaee71f9a295ab15d09fe027e4e https://github.com/python/cpython/commit/ebf7d21129300aaee71f9a295ab15d09fe027e4e Author: Berker Peksag Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Doc/faq/gui.rst Log Message: ----------- Remove outdated FOX from GUI FAQ (GH-2538) FXpy doesn't have a Python 3 port and it only supports Python 2.2 and older versions. Reported by Alex Walters on docs at p.o. (cherry picked from commit d3ed2877a798d07df75422afe136b4727e500c99) From noreply at github.com Tue Jul 4 02:59:23 2017 From: noreply at github.com (GitHub) Date: Mon, 03 Jul 2017 23:59:23 -0700 Subject: [Python-checkins] [python/cpython] 483504: bpo-29293: multiprocessing.Condition.notify() lack... Message-ID: <595b3ccbed1f5_21a43feae7b85c381057b1@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 48350412b70c76fa51f488cfc736c80d59b5e8eb https://github.com/python/cpython/commit/48350412b70c76fa51f488cfc736c80d59b5e8eb Author: Antoine Pitrou Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/multiprocessing/managers.py M Lib/multiprocessing/synchronize.py M Lib/test/_test_multiprocessing.py A Misc/NEWS.d/next/Library/2017-06-29-00-07-22.bpo-29293.Z6WZjD.rst Log Message: ----------- bpo-29293: multiprocessing.Condition.notify() lacks parameter `n` (#2480) * bpo-29293: multiprocessing.Condition.notify() lacks parameter `n` * Add NEWS blurb From solipsis at pitrou.net Tue Jul 4 05:08:11 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Tue, 04 Jul 2017 09:08:11 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=14 Message-ID: <20170704090810.46947.B5ADE81EBB288508@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [3, 0, 0] memory blocks, sum=3 test_collections leaked [0, 0, 7] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogHAeLlD', '--timeout', '7200'] From noreply at github.com Tue Jul 4 05:36:17 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 02:36:17 -0700 Subject: [Python-checkins] [python/cpython] 1fef01: bpo-29796: test_weakref: Fix collect_in_thread() o... Message-ID: <595b619189372_7fab3f91e1571c341041d4@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 1fef0154d97bd7f01c5bc59954a278bacf1a3f0e https://github.com/python/cpython/commit/1fef0154d97bd7f01c5bc59954a278bacf1a3f0e Author: Victor Stinner Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/test/test_weakref.py Log Message: ----------- bpo-29796: test_weakref: Fix collect_in_thread() on Windows (#2553) Sleep 1 ms instead of 0.1 ms to workaround a rounding issue on Windows. On Windows, time.sleep(0.0001) sleeps 0 ms, so collect_in_thread() calls gc.collect() in a loop and tests using this thread takes too long. Sleep 1 ms so time.sleep() sleeps 15.6 ms on Windows. From noreply at github.com Tue Jul 4 05:45:05 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 02:45:05 -0700 Subject: [Python-checkins] [python/cpython] 28b72b: bpo-30843: Rename Lib/test/bisect.py to Lib/test/b... Message-ID: <595b63a1b8861_9a23fd8fccf1c2c132610@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 28b72baf3c1e57af0c9338fb41c89d62aa47a355 https://github.com/python/cpython/commit/28b72baf3c1e57af0c9338fb41c89d62aa47a355 Author: Victor Stinner Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: R Lib/test/bisect.py A Lib/test/bisectcmd.py M Lib/test/test_bisect.py Log Message: ----------- bpo-30843: Rename Lib/test/bisect.py to Lib/test/bisectcmd.py (#2563) Revert test_bisect.py change: remove "from __future__ import absolute_import". From noreply at github.com Tue Jul 4 07:14:06 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 04:14:06 -0700 Subject: [Python-checkins] [python/cpython] 3df9de: bpo-30845: Enhance test_concurrent_futures cleanup... Message-ID: <595b787e7674e_241f3ffa3e5adc3c100231@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 3df9dec425b0254df1cdf41922fd8d6b08bf47e4 https://github.com/python/cpython/commit/3df9dec425b0254df1cdf41922fd8d6b08bf47e4 Author: Victor Stinner Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/test/support/__init__.py M Lib/test/test_concurrent_futures.py Log Message: ----------- bpo-30845: Enhance test_concurrent_futures cleanup (#2564) * bpo-30845: reap_children() now logs warnings * bpo-30845: Enhance test_concurrent_futures cleanup In setUp() and tearDown() methods of test_concurrent_futures tests, make sure that tests don't leak threads nor processes. Clear explicitly the reference to the executor to make it that it's destroyed (to prevent "dangling threads" warning). From noreply at github.com Tue Jul 4 08:06:17 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 05:06:17 -0700 Subject: [Python-checkins] [python/cpython] 378ebb: bpo-30789: Use a single memory block for co_extra.... Message-ID: <595b84b98683e_3353f985377bc2863949@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 378ebb6578b9d709f38b888d23874c0b18125249 https://github.com/python/cpython/commit/378ebb6578b9d709f38b888d23874c0b18125249 Author: Serhiy Storchaka Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Objects/codeobject.c Log Message: ----------- bpo-30789: Use a single memory block for co_extra. (#2555) * bpo-30789: Use a single memory block for co_extra. * Address review comments. From noreply at github.com Tue Jul 4 10:20:07 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 07:20:07 -0700 Subject: [Python-checkins] [python/cpython] 67e147: bpo-30319: socket.close() now ignores ECONNRESET (... Message-ID: <595ba41798042_50aa3f8bdeb01c3425181f@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 67e1478dba6efe60b8e1890192014b8b06dd6bd9 https://github.com/python/cpython/commit/67e1478dba6efe60b8e1890192014b8b06dd6bd9 Author: Victor Stinner Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-04-13-48-21.bpo-30319.hg_3TX.rst M Modules/socketmodule.c Log Message: ----------- bpo-30319: socket.close() now ignores ECONNRESET (#2565) socket.close() was modified in Python 3.6 to raise OSError on failure: see bpo-26685. From noreply at github.com Tue Jul 4 10:46:11 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 07:46:11 -0700 Subject: [Python-checkins] [python/cpython] 580cd5: bpo-30319: socket.close() now ignores ECONNRESET (... Message-ID: <595baa337d25a_2953f985c23bc288921e@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 580cd5cd3603317d294a881628880a92ea221334 https://github.com/python/cpython/commit/580cd5cd3603317d294a881628880a92ea221334 Author: Victor Stinner Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-04-13-48-21.bpo-30319.hg_3TX.rst M Modules/socketmodule.c Log Message: ----------- bpo-30319: socket.close() now ignores ECONNRESET (#2565) (#2566) socket.close() was modified in Python 3.6 to raise OSError on failure: see bpo-26685. (cherry picked from commit 67e1478dba6efe60b8e1890192014b8b06dd6bd9) From noreply at github.com Tue Jul 4 14:38:48 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 11:38:48 -0700 Subject: [Python-checkins] [python/cpython] d02c84: [3.6] bpo-30726: Also fix pyexpat.vcxproj (GH-2375... Message-ID: <595be0b8880bf_56c93f80a1291c2c18044c@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: d02c8416fe1b29b3322004b73133bf6c8a2e353a https://github.com/python/cpython/commit/d02c8416fe1b29b3322004b73133bf6c8a2e353a Author: Segev Finer Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M PCbuild/pyexpat.vcxproj Log Message: ----------- [3.6] bpo-30726: Also fix pyexpat.vcxproj (GH-2375) (#2570) (cherry picked from commit 7526cadd64566725ffc56071a7208828a46ddbd8) From noreply at github.com Tue Jul 4 14:39:30 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 11:39:30 -0700 Subject: [Python-checkins] [python/cpython] 320ee6: [3.5] bpo-30726: Also fix pyexpat.vcxproj (GH-2375... Message-ID: <595be0e25d381_67f93f9b7b50bc242019e@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 320ee67f981f766ff55c55ef87d5ef17ce297824 https://github.com/python/cpython/commit/320ee67f981f766ff55c55ef87d5ef17ce297824 Author: Segev Finer Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M PCbuild/pyexpat.vcxproj Log Message: ----------- [3.5] bpo-30726: Also fix pyexpat.vcxproj (GH-2375) (#2571) (cherry picked from commit 7526cadd64566725ffc56071a7208828a46ddbd8) From noreply at github.com Tue Jul 4 14:40:05 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 11:40:05 -0700 Subject: [Python-checkins] [python/cpython] d0ae4b: bpo-30726: Add _CRT_SECURE_NO_WARNINGS to _element... Message-ID: <595be105565f7_723f3fe80c463c441126f6@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: d0ae4be443332d63fafb304944842fbaece734a3 https://github.com/python/cpython/commit/d0ae4be443332d63fafb304944842fbaece734a3 Author: Segev Finer Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M PC/VS9.0/_elementtree.vcproj M PC/VS9.0/pyexpat.vcproj M PCbuild/_elementtree.vcxproj M PCbuild/pyexpat.vcxproj Log Message: ----------- bpo-30726: Add _CRT_SECURE_NO_WARNINGS to _elementtree and pyexpat projects (#2572) From noreply at github.com Tue Jul 4 21:31:02 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 18:31:02 -0700 Subject: [Python-checkins] [python/cpython] 7eb588: bpo-30777: IDLE: configdialog - add docstrings and... Message-ID: <595c4156268af_613e3fa9bbb3dc347672c@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 7eb5883ac59833bf63f0e1f7fb95671a1ac1ee08 https://github.com/python/cpython/commit/7eb5883ac59833bf63f0e1f7fb95671a1ac1ee08 Author: csabella Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py Log Message: ----------- bpo-30777: IDLE: configdialog - add docstrings and improve comments (#2440) Patch by Cheryl Sabella. From noreply at github.com Tue Jul 4 22:41:15 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 19:41:15 -0700 Subject: [Python-checkins] [python/cpython] 200015: bpo-21624: IDLE -- minor htest fixes (#2575) Message-ID: <595c51cb53e03_21ce3fb74c487c34119267@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 2000150c569941584994ec4ec59171961209bec3 https://github.com/python/cpython/commit/2000150c569941584994ec4ec59171961209bec3 Author: terryjreedy Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: M Lib/idlelib/browser.py M Lib/idlelib/config_key.py Log Message: ----------- bpo-21624: IDLE -- minor htest fixes (#2575) From noreply at github.com Tue Jul 4 23:00:10 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 20:00:10 -0700 Subject: [Python-checkins] [python/cpython] aaa917: NEWS for 30777 (#2576) Message-ID: <595c563a9c140_526e3ff86a6bdc381508cb@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: aaa917ff38f9869eeebe3bc9469bfee64089d826 https://github.com/python/cpython/commit/aaa917ff38f9869eeebe3bc9469bfee64089d826 Author: terryjreedy Date: 2017-07-04 (Tue, 04 Jul 2017) Changed paths: A Misc/NEWS.d/next/IDLE/2017-07-04-22-45-46.bpo-30777.uxzlMB.rst Log Message: ----------- NEWS for 30777 (#2576) From noreply at github.com Wed Jul 5 00:54:57 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 21:54:57 -0700 Subject: [Python-checkins] [python/cpython] e5bb11: [3.6] bpo-30777: IDLE: configdialog - add docstrin... Message-ID: <595c7121a73c4_1621e3ff8a5d2dc2c9543a@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: e5bb112ba2048cb3ea19481a7b38fe1433c5a7ef https://github.com/python/cpython/commit/e5bb112ba2048cb3ea19481a7b38fe1433c5a7ef Author: terryjreedy Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py Log Message: ----------- [3.6] bpo-30777: IDLE: configdialog - add docstrings and improve comments (GH-2440) (#2577) Patch by Cheryl Sabella. (cherry picked from commit 7eb5883) From noreply at github.com Wed Jul 5 00:55:30 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 21:55:30 -0700 Subject: [Python-checkins] [python/cpython] 1278d2: [3.6] bpo-21624: IDLE -- minor htest fixes (GH-257... Message-ID: <595c7142777d9_62f83fb6ad561c301138cb@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 1278d29000794085f1d9e25f2dadbf70b9076e30 https://github.com/python/cpython/commit/1278d29000794085f1d9e25f2dadbf70b9076e30 Author: terryjreedy Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/idlelib/browser.py M Lib/idlelib/config_key.py Log Message: ----------- [3.6] bpo-21624: IDLE -- minor htest fixes (GH-2575) (#2578) (cherry picked from commit 2000150) From noreply at github.com Wed Jul 5 00:56:01 2017 From: noreply at github.com (GitHub) Date: Tue, 04 Jul 2017 21:56:01 -0700 Subject: [Python-checkins] [python/cpython] 0884c4: [3.6] NEWS for 30777 (GH-2576) (#2579) Message-ID: <595c716128864_3d423f9e4dbb1c34101526@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 0884c40603be59cc40dd2af510a4c008dfac85f2 https://github.com/python/cpython/commit/0884c40603be59cc40dd2af510a4c008dfac85f2 Author: terryjreedy Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: A Misc/NEWS.d/next/IDLE/2017-07-04-22-45-46.bpo-30777.uxzlMB.rst Log Message: ----------- [3.6] NEWS for 30777 (GH-2576) (#2579) (cherry picked from commit aaa917f) From noreply at github.com Wed Jul 5 03:16:48 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 00:16:48 -0700 Subject: [Python-checkins] [python/cpython] 305098: bpo-30843: regrtest fixes sys.path, restore test.b... Message-ID: <595c9260a5e74_3ddc3fced6d17c402018aa@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 3050987d85d7cf8cdd4b3c053e673d13cd8dfb12 https://github.com/python/cpython/commit/3050987d85d7cf8cdd4b3c053e673d13cd8dfb12 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: A Lib/test/bisect.py R Lib/test/bisectcmd.py M Lib/test/regrtest.py M Lib/test/test_bisect.py Log Message: ----------- bpo-30843: regrtest fixes sys.path, restore test.bisect (#2567) * Rename again Lib/test/bisectcmd.py to Lib/test/bisect.py * regrtest now removes '' and Lib/test/ from sys.path * Use absolute import in test_bisect From noreply at github.com Wed Jul 5 04:00:35 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 01:00:35 -0700 Subject: [Python-checkins] [python/cpython] 668489: bpo-30759: Copy test_robotparser from master (#254... Message-ID: <595c9ca361352_14db3f8b4aba5c24229721@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 668489a6d5a5b124aea35820ca90cb5e3b2b3ecd https://github.com/python/cpython/commit/668489a6d5a5b124aea35820ca90cb5e3b2b3ecd Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/test/test_robotparser.py Log Message: ----------- bpo-30759: Copy test_robotparser from master (#2546) Copy Lib/test/test_robotparser.py from master to 2.7 and adapt it for Python 2.7: * Replace urllib.robotparser with robotparser * Adjust HTTPServer import * Replace io.StringIO with StringIO.StringIO * Remove tests on crawl_delay() and request_rate() since these methods were added to Python 3 * Remove subTest() * Add test_main() which explicitly lists all test cases Patch based on the commit 4da0fd06ce49132d5c2e0525c4a31f807690a9ed written by Berker Peksag. Co-Authored-By: Berker Peksag From noreply at github.com Wed Jul 5 04:39:19 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 01:39:19 -0700 Subject: [Python-checkins] [python/cpython] 0c3116: bpo-30854: Fix compile error when --without-thread... Message-ID: <595ca5b79a8d_5fd63f908bf53c2c13878b@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 0c3116309307ad2c7f8e2d2096612f4ab33cbb62 https://github.com/python/cpython/commit/0c3116309307ad2c7f8e2d2096612f4ab33cbb62 Author: Masayuki Yamamoto Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: A Misc/NEWS.d/next/Build/2017-07-05-16-54-59.bpo-30854.sPADRI.rst M Python/ceval.c Log Message: ----------- bpo-30854: Fix compile error when --without-threads (#2581) * bpo-30854: Fix compile error when --without-threads * bpo-30854: fix news From noreply at github.com Wed Jul 5 04:52:08 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 01:52:08 -0700 Subject: [Python-checkins] [python/cpython] 8767de: bpo-30759: regrtest: list_cases() now unload modul... Message-ID: <595ca8b8ec376_212d3fc24ec3dc3c9606f@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 8767de2f776e0c8c7404680cdacad83e5d902955 https://github.com/python/cpython/commit/8767de2f776e0c8c7404680cdacad83e5d902955 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/test/regrtest.py Log Message: ----------- bpo-30759: regrtest: list_cases() now unload modules (#2582) list_cases() now unload modules, as the test runner does, to prevent a failure in test_xpickle about test.pickletester loaded after loading test_cpickle: ./python -m test --list-cases test_cpickle test_xpickle From solipsis at pitrou.net Wed Jul 5 05:08:41 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Wed, 05 Jul 2017 09:08:41 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=2 Message-ID: <20170705090840.49397.2DD4F370FF6C8C0C@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 3, 0] memory blocks, sum=3 test_collections leaked [-7, 1, 0] memory blocks, sum=-6 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [2, 0, -1] memory blocks, sum=1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogEDNawH', '--timeout', '7200'] From noreply at github.com Wed Jul 5 05:24:48 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 02:24:48 -0700 Subject: [Python-checkins] [python/cpython] e3a0ff: [3.6] bpo-30854: Fix compile error when --without-... Message-ID: <595cb060a8ad3_9203f988fafdc34187118@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: e3a0ff0d76b9e7a994afa7f2c54b19a63f1bb57d https://github.com/python/cpython/commit/e3a0ff0d76b9e7a994afa7f2c54b19a63f1bb57d Author: Masayuki Yamamoto Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: A Misc/NEWS.d/next/Build/2017-07-05-16-54-59.bpo-30854.sPADRI.rst M Python/ceval.c Log Message: ----------- [3.6] bpo-30854: Fix compile error when --without-threads (GH-2581) (#2583) * bpo-30854: Fix compile error when --without-threads * bpo-30854: fix news (cherry picked from commit 0c3116309307ad2c7f8e2d2096612f4ab33cbb62) From noreply at github.com Wed Jul 5 08:09:37 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 05:09:37 -0700 Subject: [Python-checkins] [python/cpython] 2b92cd: bpo-30850: Use specialized assert methods in bsddb... Message-ID: <595cd7019461e_718a3f96ae1f9c3816849b@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 2b92cd3b16ba83aaaf11a91a19845ca6804663d9 https://github.com/python/cpython/commit/2b92cd3b16ba83aaaf11a91a19845ca6804663d9 Author: Serhiy Storchaka Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/bsddb/test/test_associate.py M Lib/bsddb/test/test_basics.py M Lib/bsddb/test/test_dbenv.py M Lib/bsddb/test/test_dbshelve.py M Lib/bsddb/test/test_dbtables.py M Lib/bsddb/test/test_distributed_transactions.py M Lib/bsddb/test/test_lock.py M Lib/bsddb/test/test_misc.py M Lib/bsddb/test/test_recno.py M Lib/bsddb/test/test_replication.py M Lib/bsddb/test/test_sequence.py M Lib/bsddb/test/test_thread.py M Lib/test/test_bsddb.py Log Message: ----------- bpo-30850: Use specialized assert methods in bsddb tests. (#2584) This provides more information on test failures. From noreply at github.com Wed Jul 5 08:43:58 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 05:43:58 -0700 Subject: [Python-checkins] [python/cpython] 431890: Revert "bpo-30854: Fix compile error when --withou... Message-ID: <595cdf0e38189_9263f96af227c4018728d@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/revert-2530-bpo-30822 Home: https://github.com/python/cpython Commit: 431890ddd9b827683985c470cbe4048617e2fdf2 https://github.com/python/cpython/commit/431890ddd9b827683985c470cbe4048617e2fdf2 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30854: Fix compile error when --without-threads (#2581)" This reverts commit 0c3116309307ad2c7f8e2d2096612f4ab33cbb62. Commit: 02126d823d89a90c5d6a776cb035dcf9b971d5c5 https://github.com/python/cpython/commit/02126d823d89a90c5d6a776cb035dcf9b971d5c5 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "NEWS for 30777 (#2576)" This reverts commit aaa917ff38f9869eeebe3bc9469bfee64089d826. Commit: a73af89100bc9ddc55b173ffeb0996868d8f64cb https://github.com/python/cpython/commit/a73af89100bc9ddc55b173ffeb0996868d8f64cb Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-21624: IDLE -- minor htest fixes (#2575)" This reverts commit 2000150c569941584994ec4ec59171961209bec3. Commit: 5dace3a55c461b5e5a77372e572e184437a8a5ea https://github.com/python/cpython/commit/5dace3a55c461b5e5a77372e572e184437a8a5ea Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30777: IDLE: configdialog - add docstrings and improve comments (#2440)" This reverts commit 7eb5883ac59833bf63f0e1f7fb95671a1ac1ee08. Commit: be9e61f3cd300d8f8654d13fef3388fb58f56486 https://github.com/python/cpython/commit/be9e61f3cd300d8f8654d13fef3388fb58f56486 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30319: socket.close() now ignores ECONNRESET (#2565)" This reverts commit 67e1478dba6efe60b8e1890192014b8b06dd6bd9. Commit: e2dde1344797d5a155cdc9872c1282bfd9e047bc https://github.com/python/cpython/commit/e2dde1344797d5a155cdc9872c1282bfd9e047bc Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30789: Use a single memory block for co_extra. (#2555)" This reverts commit 378ebb6578b9d709f38b888d23874c0b18125249. Commit: 232c174ce4bca50bf364fc53e882d2ef38897741 https://github.com/python/cpython/commit/232c174ce4bca50bf364fc53e882d2ef38897741 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30845: Enhance test_concurrent_futures cleanup (#2564)" This reverts commit 3df9dec425b0254df1cdf41922fd8d6b08bf47e4. Commit: eefb178a6ceff1b4bf3cc94f6208a0f9634e6f2e https://github.com/python/cpython/commit/eefb178a6ceff1b4bf3cc94f6208a0f9634e6f2e Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-29293: multiprocessing.Condition.notify() lacks parameter `n` (#2480)" This reverts commit 48350412b70c76fa51f488cfc736c80d59b5e8eb. Commit: 7d444a63eb074e1a8ebfb4a80f5f96109f40a2e3 https://github.com/python/cpython/commit/7d444a63eb074e1a8ebfb4a80f5f96109f40a2e3 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "Remove outdated FOX from GUI FAQ (GH-2538)" This reverts commit d3ed2877a798d07df75422afe136b4727e500c99. Commit: 957a410e3274b408607c93fa8d6c9d1332418598 https://github.com/python/cpython/commit/957a410e3274b408607c93fa8d6c9d1332418598 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-6691: Pyclbr now reports nested classes and functions. (#2503)" This reverts commit 246ff3bd00f97658e567a7087645a6b76e056491. Commit: 5af7f2eaf250f1b46115fac7475eedf9278911b9 https://github.com/python/cpython/commit/5af7f2eaf250f1b46115fac7475eedf9278911b9 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-29464: Rename METH_FASTCALL to METH_FASTCALL|METH_KEYWORDS and make (#1955)" This reverts commit 6969eaf4682beb01bc95eeb14f5ce6c01312e297. Commit: 74e1e199b7323906df3c41ba23704e361a64664a https://github.com/python/cpython/commit/74e1e199b7323906df3c41ba23704e361a64664a Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30832: Remove own implementation for thread-local storage (#2537)" This reverts commit aa0aa0492c5fffe750a26d2ab13737a1a6d7d63c. Commit: 92b6e586d10f623563a1754810a8aa800307ff06 https://github.com/python/cpython/commit/92b6e586d10f623563a1754810a8aa800307ff06 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30764: Fix regrtest --fail-env-changed --forever (#2536)" This reverts commit 5e87592fd12e0b7c41edc11d4885ed7298d5063b. Commit: bc551d3020b0fcef73275233c9f1cf10ff6e64b7 https://github.com/python/cpython/commit/bc551d3020b0fcef73275233c9f1cf10ff6e64b7 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Log Message: ----------- Revert "bpo-30822: Deduplicate ZoneInfoTest classes in test_datetime. (#2534)" This reverts commit 34b54873b51a1ebee2a3c57b7205537b4f33128d. Commit: f7149afcd387fb01c56fff9a365a23d5712d84ac https://github.com/python/cpython/commit/f7149afcd387fb01c56fff9a365a23d5712d84ac Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Misc/ACKS Log Message: ----------- Revert "bpo-30822: Fix testing of datetime module. (#2530)" This reverts commit 98b6bc3bf72532b784a1c1fa76eaa6026a663e44. Compare: https://github.com/python/cpython/compare/431890ddd9b8^...f7149afcd387 From noreply at github.com Wed Jul 5 09:44:56 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 06:44:56 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <595ced5890877_3cdc3fb84c379c3810548a@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/revert-2530-bpo-30822 Home: https://github.com/python/cpython From noreply at github.com Wed Jul 5 09:44:54 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 06:44:54 -0700 Subject: [Python-checkins] [python/cpython] 8207c1: Revert "bpo-30822: Fix testing of datetime module.... Message-ID: <595ced56da856_77853fb988581c282242aa@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 8207c17486baece8ed0ac42d9f8d69ecec4ba7e4 https://github.com/python/cpython/commit/8207c17486baece8ed0ac42d9f8d69ecec4ba7e4 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Misc/ACKS Log Message: ----------- Revert "bpo-30822: Fix testing of datetime module." (#2588) * Revert "bpo-30854: Fix compile error when --without-threads (#2581)" This reverts commit 0c3116309307ad2c7f8e2d2096612f4ab33cbb62. * Revert "NEWS for 30777 (#2576)" This reverts commit aaa917ff38f9869eeebe3bc9469bfee64089d826. * Revert "bpo-21624: IDLE -- minor htest fixes (#2575)" This reverts commit 2000150c569941584994ec4ec59171961209bec3. * Revert "bpo-30777: IDLE: configdialog - add docstrings and improve comments (#2440)" This reverts commit 7eb5883ac59833bf63f0e1f7fb95671a1ac1ee08. * Revert "bpo-30319: socket.close() now ignores ECONNRESET (#2565)" This reverts commit 67e1478dba6efe60b8e1890192014b8b06dd6bd9. * Revert "bpo-30789: Use a single memory block for co_extra. (#2555)" This reverts commit 378ebb6578b9d709f38b888d23874c0b18125249. * Revert "bpo-30845: Enhance test_concurrent_futures cleanup (#2564)" This reverts commit 3df9dec425b0254df1cdf41922fd8d6b08bf47e4. * Revert "bpo-29293: multiprocessing.Condition.notify() lacks parameter `n` (#2480)" This reverts commit 48350412b70c76fa51f488cfc736c80d59b5e8eb. * Revert "Remove outdated FOX from GUI FAQ (GH-2538)" This reverts commit d3ed2877a798d07df75422afe136b4727e500c99. * Revert "bpo-6691: Pyclbr now reports nested classes and functions. (#2503)" This reverts commit 246ff3bd00f97658e567a7087645a6b76e056491. * Revert "bpo-29464: Rename METH_FASTCALL to METH_FASTCALL|METH_KEYWORDS and make (#1955)" This reverts commit 6969eaf4682beb01bc95eeb14f5ce6c01312e297. * Revert "bpo-30832: Remove own implementation for thread-local storage (#2537)" This reverts commit aa0aa0492c5fffe750a26d2ab13737a1a6d7d63c. * Revert "bpo-30764: Fix regrtest --fail-env-changed --forever (#2536)" This reverts commit 5e87592fd12e0b7c41edc11d4885ed7298d5063b. * Revert "bpo-30822: Deduplicate ZoneInfoTest classes in test_datetime. (#2534)" This reverts commit 34b54873b51a1ebee2a3c57b7205537b4f33128d. * Revert "bpo-30822: Fix testing of datetime module. (#2530)" This reverts commit 98b6bc3bf72532b784a1c1fa76eaa6026a663e44. From noreply at github.com Wed Jul 5 09:58:25 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 06:58:25 -0700 Subject: [Python-checkins] [python/cpython] c48a00: [3.5] bpo-30855: Trying to fix test_use on Windows... Message-ID: <595cf081e62df_dce3fea8963fc2813463f@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: c48a000c74b48586742c4b7eb42bba93f15953a9 https://github.com/python/cpython/commit/c48a000c74b48586742c4b7eb42bba93f15953a9 Author: Victor Stinner Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/tkinter/__init__.py M Lib/tkinter/test/test_tkinter/test_widgets.py Log Message: ----------- [3.5] bpo-30855: Trying to fix test_use on Windows. (#2585) * bpo-30855: Trying to fix test_use on Windows. Avoid possible weird behavior of WideInt convertion. "winfo id" always returns string hexadecimal representation. (cherry picked from commit b9d672491d5082c541bf267eb7bb99fdc6529324) * bpo-30855: Trying to fix test_use on Windows. (cherry picked from commit 29a2f7c6b38e5a6ed891aa72af38974a1ff2d372) From lp_benchmark_robot at intel.com Wed Jul 5 10:41:30 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Wed, 5 Jul 2017 07:41:30 -0700 Subject: [Python-checkins] [1 down, 2 up, 62 flat] Results for Python (master branch) 2017-07-04 Message-ID: <7611b09b-2a21-422f-bcd0-bca75684c6be@orsmsx102.amr.corp.intel.com> Results for project python/master, build date: 2017-07-04 03:03:32-07:00. - commit: 4835041 - previous commit: 5e87592 - revision date: 2017-07-04 08:59:22+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 0.730% | -0.128% | +5.107% | +7.146% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 0.528% | -1.332% | +19.169% | +15.487% | +-----+------------------------+--------+------------+------------+------------+ | :-( | call_method_slots| 0.646% | -2.547% | +19.911% | +14.611% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.138% | -2.117% | +18.644% | +14.802% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 2.447% | -3.706% | +2.008% | +15.326% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.653% | -0.187% | +11.216% | +11.521% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.856% | +0.245% | +6.971% | +10.887% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.567% | +0.644% | +3.852% | +6.309% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 2.649% | -3.537% | +7.822% | +17.672% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.817% | +0.332% | +10.693% | +11.825% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.221% | -0.386% | +3.443% | +6.678% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.596% | +0.282% | +5.106% | +5.619% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.190% | -0.673% | +3.257% | +6.580% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.425% | -0.451% | +9.167% | +10.320% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.034% | -1.049% | +7.370% | +7.642% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.764% | -2.477% | +5.092% | +12.257% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.793% | +0.635% | +9.528% | +12.198% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.263% | -0.468% | +7.980% | +10.399% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.708% | -1.377% | +2.800% | +9.863% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 2.925% | +2.397% | +4.412% | +8.714% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.514% | +2.264% | +8.447% | +8.210% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.691% | -1.212% | +11.712% | +13.040% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.658% | -0.266% | +8.179% | +11.261% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.565% | +1.577% | +19.126% | +11.723% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 4.432% | +1.548% | +6.714% | +12.505% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 3.153% | +1.389% | +4.858% | +4.130% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.965% | +0.988% | -2.002% | +2.972% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.636% | -0.199% | +1.346% | +8.578% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.325% | -1.573% | +2.254% | +11.571% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.311% | +0.942% | +1.321% | +20.971% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.390% | +1.412% | +3.878% | +14.767% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.765% | +1.345% | +6.069% | +15.885% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 5.432% | -0.992% | +11.189% | +11.490% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.342% | -0.073% | +0.192% | +9.806% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.132% | +0.144% | +9.704% | +4.210% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.088% | +0.136% | +1.453% | +4.329% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.019% | -0.273% | +9.318% | +12.886% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.030% | +2.895% | -9.176% | +11.640% | +-----+------------------------+--------+------------+------------+------------+ | :-) | regex_dna| 0.423% | +4.070% | +2.187% | +7.900% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.106% | +2.725% | +0.334% | +5.076% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.916% | +0.028% | +10.589% | +3.868% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.213% | -1.963% | +7.175% | +15.606% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.712% | -0.364% | +0.357% | +2.816% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.901% | +0.439% | +26.073% | +11.165% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.917% | -1.165% | +4.331% | +5.871% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.283% | +0.793% | +15.685% | +7.431% | +-----+------------------------+--------+------------+------------+------------+ | :-) | scimark_sparse_mat_mult| 0.358% | +4.746% | +3.645% | -6.644% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.726% | +0.961% | +6.699% | +0.701% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.743% | +0.011% | +6.126% | +7.380% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 2.497% | +0.407% | +5.110% | +4.246% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.243% | +1.548% | +2.521% | +7.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 1.817% | -0.726% | +12.121% | +9.272% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.747% | -0.505% | +9.820% | +7.706% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.752% | -0.531% | +11.413% | +10.281% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.626% | -1.994% | +12.452% | +11.198% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.781% | -2.311% | +20.879% | +14.613% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.197% | -0.643% | +5.879% | +5.857% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.794% | -0.106% | +2.627% | +0.668% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.828% | -2.252% | +7.214% | +22.172% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 2.802% | -0.604% | -2.122% | +21.170% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 3.051% | +0.084% | +7.911% | +7.266% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.852% | -0.541% | +5.743% | +8.816% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.804% | -1.724% | +0.502% | +9.082% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.992% | -2.333% | -9.540% | +14.396% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.266% | -0.361% | +6.377% | +8.860% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-down-2-up-62-flat-results-for-python-master-branch-2017-07-04 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Wed Jul 5 11:17:36 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 08:17:36 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <595d0310a5fad_4cd33fc7b9e2fc3c90131@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/buildbot-custom Home: https://github.com/python/cpython From noreply at github.com Wed Jul 5 13:32:04 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 10:32:04 -0700 Subject: [Python-checkins] [python/cpython] 833a3b: bpo-30828: Fix out of bounds write in `asyncio.CFu... Message-ID: <595d2294e4444_4f1f3fd7fba5bc302438ce@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 833a3b0d3707200daeaccdd218e8f18a190284aa https://github.com/python/cpython/commit/833a3b0d3707200daeaccdd218e8f18a190284aa Author: Yury Selivanov Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/test/test_asyncio/test_futures.py A Misc/NEWS.d/next/Library/2017-07-04-13-10-52.bpo-30828.CLvEvV.rst M Modules/_asynciomodule.c Log Message: ----------- bpo-30828: Fix out of bounds write in `asyncio.CFuture.remove_done_callback() (#2569) From noreply at github.com Wed Jul 5 13:33:47 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 10:33:47 -0700 Subject: [Python-checkins] [python/cpython] cd3fe1: [3.6] bpo-30828: Fix out of bounds write in `async... Message-ID: <595d22fb5a8c0_7f663fdd4e539c2c2498f6@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/backport-833a3b0-3.6 Home: https://github.com/python/cpython Commit: cd3fe16656e8188f0e047f51e2ea0e141215212c https://github.com/python/cpython/commit/cd3fe16656e8188f0e047f51e2ea0e141215212c Author: Yury Selivanov Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/test/test_asyncio/test_futures.py A Misc/NEWS.d/next/Library/2017-07-04-13-10-52.bpo-30828.CLvEvV.rst M Modules/_asynciomodule.c Log Message: ----------- [3.6] bpo-30828: Fix out of bounds write in `asyncio.CFuture.remove_done_callback() (GH-2569) (cherry picked from commit 833a3b0d3707200daeaccdd218e8f18a190284aa) From noreply at github.com Wed Jul 5 14:03:13 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 11:03:13 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <595d29e19b8e1_61e33feb79fcdc40142878@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/backport-833a3b0-3.6 Home: https://github.com/python/cpython From noreply at github.com Wed Jul 5 14:03:12 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 11:03:12 -0700 Subject: [Python-checkins] [python/cpython] aaa4f9: [3.6] bpo-30828: Fix out of bounds write in `async... Message-ID: <595d29e02734c_509b3fbfc0a2dc34247565@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: aaa4f991518611d101fba1ef3ecb18d7b385ad5b https://github.com/python/cpython/commit/aaa4f991518611d101fba1ef3ecb18d7b385ad5b Author: Yury Selivanov Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/test/test_asyncio/test_futures.py A Misc/NEWS.d/next/Library/2017-07-04-13-10-52.bpo-30828.CLvEvV.rst M Modules/_asynciomodule.c Log Message: ----------- [3.6] bpo-30828: Fix out of bounds write in `asyncio.CFuture.remove_done_callback() (GH-2569) (#2590) (cherry picked from commit 833a3b0d3707200daeaccdd218e8f18a190284aa) From lp_benchmark_robot at intel.com Wed Jul 5 19:01:50 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Wed, 5 Jul 2017 16:01:50 -0700 Subject: [Python-checkins] [3 down, 1 up, 61 flat] Results for Python (master branch) 2017-07-05 Message-ID: <3d4a21d5-0fc0-4c91-8411-d1b707507e14@orsmsx151.amr.corp.intel.com> Results for project python/master, build date: 2017-07-05 03:03:31-07:00. - commit: 0c31163 - previous commit: 4835041 - revision date: 2017-07-05 10:39:17+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.125% | -0.375% | +4.752% | +7.305% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 0.472% | +0.634% | +19.681% | +15.540% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.688% | +1.728% | +21.295% | +15.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.898% | +0.550% | +19.092% | +15.615% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 2.220% | -0.839% | +1.186% | +17.783% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.084% | +0.836% | +11.959% | +9.071% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.873% | -0.485% | +6.520% | +9.862% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.510% | +0.597% | +4.427% | +6.323% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.894% | +0.336% | +8.132% | +18.670% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.522% | -1.386% | +9.455% | +14.390% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.236% | -0.211% | +3.239% | +5.799% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.427% | +0.506% | +5.586% | +5.420% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.953% | +0.232% | +3.482% | +5.999% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 0.996% | -0.209% | +8.977% | +11.290% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.309% | -1.183% | +6.274% | +9.207% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.881% | -0.239% | +4.866% | +12.639% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.743% | -0.048% | +9.484% | +12.435% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.633% | +0.226% | +8.189% | +10.191% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.629% | +0.703% | +3.483% | +10.211% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 3.396% | -0.174% | +4.246% | +9.481% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.741% | -2.273% | +6.365% | +12.236% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.656% | +0.777% | +12.399% | +13.416% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.559% | +0.366% | +8.515% | +11.842% | +-----+------------------------+--------+------------+------------+------------+ | :-( | mako| 0.844% | -2.439% | +17.153% | +12.581% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 4.411% | +1.189% | +7.823% | +12.362% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.758% | +0.289% | +5.133% | +4.766% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.394% | -1.594% | -3.628% | +4.435% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.607% | +0.482% | +1.821% | +8.057% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.447% | -1.545% | +0.744% | +14.104% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.169% | -0.324% | +1.001% | +22.733% | +-----+------------------------+--------+------------+------------+------------+ | :-) | pickle_dict| 0.234% | +3.557% | +7.297% | +10.654% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.949% | +0.519% | +6.557% | +14.487% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 2.420% | +1.016% | +12.091% | +10.433% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.061% | +0.262% | +0.454% | +9.375% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.128% | -0.167% | +9.553% | +4.754% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.088% | -0.144% | +1.310% | +4.762% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.458% | -0.212% | +9.126% | +13.109% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.887% | -1.195% | -10.481% | +13.754% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 1.515% | -2.237% | -0.001% | +10.982% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.334% | -2.996% | -2.652% | +8.597% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.893% | -0.485% | +10.155% | +4.691% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.586% | +1.149% | +8.242% | +14.711% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.370% | +0.795% | +1.149% | +2.174% | +-----+------------------------+--------+------------+------------+------------+ | :-( | scimark_lu| 1.720% | -6.195% | +21.493% | +16.123% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.958% | +1.701% | +5.958% | +4.228% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.672% | +0.060% | +15.735% | +8.895% | +-----+------------------------+--------+------------+------------+------------+ | :-( | scimark_sparse_mat_mult| 2.004% | -4.937% | -1.112% | +2.419% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.674% | -0.493% | +6.239% | +1.962% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.642% | +0.058% | +6.181% | +7.810% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 2.630% | -0.022% | +5.089% | +5.560% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.160% | -0.991% | +1.554% | +8.186% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.336% | +0.252% | +12.343% | +9.113% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.786% | +0.408% | +10.187% | +7.016% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.408% | -0.239% | +11.202% | +10.447% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.444% | +1.192% | +13.496% | +10.083% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.301% | +3.454% | +23.612% | +7.928% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.108% | +0.074% | +5.949% | +6.691% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.052% | -0.021% | +2.607% | -1.568% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.230% | -0.356% | +6.883% | +21.661% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 3.540% | +0.402% | -1.711% | +19.604% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.892% | +0.385% | +8.266% | +7.142% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.104% | +0.000% | +5.743% | +8.607% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.497% | +0.712% | +1.210% | +7.112% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 3.403% | -0.859% | -10.480% | +12.952% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.310% | +0.313% | +6.670% | +8.744% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/3-down-1-up-61-flat-results-for-python-master-branch-2017-07-05 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Wed Jul 5 19:36:50 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 16:36:50 -0700 Subject: [Python-checkins] [python/cpython] 1ccbad: Update idlelib/NEWS.txt with merges upto 2017 Jul ... Message-ID: <595d78122d7b5_6aa13facb83a1c3c1698a9@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 1ccbad9c95cf5782a1329eeaecba6e3eb0c37cb8 https://github.com/python/cpython/commit/1ccbad9c95cf5782a1329eeaecba6e3eb0c37cb8 Author: terryjreedy Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/idlelib/NEWS.txt Log Message: ----------- Update idlelib/NEWS.txt with merges upto 2017 Jul 5. (#2595) From noreply at github.com Wed Jul 5 23:55:20 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 20:55:20 -0700 Subject: [Python-checkins] [python/cpython] 10df96: Fix trivial typo in json module docstring (GH-2274... Message-ID: <595db4a8efc69_13073f89dc9d9c341079f7@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 10df96affd0f3e21a7750db98038f8419b91db95 https://github.com/python/cpython/commit/10df96affd0f3e21a7750db98038f8419b91db95 Author: Mariatta Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/json/__init__.py Log Message: ----------- Fix trivial typo in json module docstring (GH-2274) (GH-2431) (cherry picked from commit 76c567ee27342d76f631a35c8291b715b2a61f3e) From noreply at github.com Wed Jul 5 23:55:31 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 20:55:31 -0700 Subject: [Python-checkins] [python/cpython] af6c54: Fix trivial typo in json module docstring (GH-2274... Message-ID: <595db4b3d8120_51983fc6463a5c2c1136b8@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: af6c5474cc133665d719f25281b10ecf0b303545 https://github.com/python/cpython/commit/af6c5474cc133665d719f25281b10ecf0b303545 Author: Mariatta Date: 2017-07-05 (Wed, 05 Jul 2017) Changed paths: M Lib/json/__init__.py Log Message: ----------- Fix trivial typo in json module docstring (GH-2274) (GH-2432) (cherry picked from commit 76c567ee27342d76f631a35c8291b715b2a61f3e) From noreply at github.com Thu Jul 6 01:09:04 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 22:09:04 -0700 Subject: [Python-checkins] [python/cpython] b4baac: bpo-30814: Fixed a race condition when import a su... Message-ID: <595dc5f082b6a_306d3f94afb65c3c3180@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: b4baacee1adc06edbe30ac7574d17a8cd168e2e0 https://github.com/python/cpython/commit/b4baacee1adc06edbe30ac7574d17a8cd168e2e0 Author: Serhiy Storchaka Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Lib/test/test_import/__init__.py A Lib/test/test_import/data/package/__init__.py A Lib/test/test_import/data/package/submodule.py M Misc/NEWS M Python/import.c M Python/importlib.h Log Message: ----------- bpo-30814: Fixed a race condition when import a submodule from a package. (#2580) From noreply at github.com Thu Jul 6 01:38:26 2017 From: noreply at github.com (GitHub) Date: Wed, 05 Jul 2017 22:38:26 -0700 Subject: [Python-checkins] [python/cpython] 03b0e8: [3.6] bpo-30814: Fixed a race condition when impor... Message-ID: <595dccd27bcf9_50aa3f8bdeb01c3427628c@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 03b0e8374b2ea93adf8fb6a48db2916f3b0388cc https://github.com/python/cpython/commit/03b0e8374b2ea93adf8fb6a48db2916f3b0388cc Author: Serhiy Storchaka Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Lib/test/test_import/__init__.py A Lib/test/test_import/data/package/__init__.py A Lib/test/test_import/data/package/submodule.py M Misc/NEWS M Python/import.c M Python/importlib.h Log Message: ----------- [3.6] bpo-30814: Fixed a race condition when import a submodule from a package. (GH-2580). (#2598) (cherry picked from commit b4baacee1adc06edbe30ac7574d17a8cd168e2e0) From noreply at github.com Thu Jul 6 04:22:53 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 01:22:53 -0700 Subject: [Python-checkins] [python/cpython] f6d648: [2.7] bpo-30855: Trying to fix test_use on Windows... Message-ID: <595df35db96aa_2ff3fcf657c1c341515a3@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: f6d6480b93eca6f353784579108957108750c004 https://github.com/python/cpython/commit/f6d6480b93eca6f353784579108957108750c004 Author: Victor Stinner Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/lib-tk/Tkinter.py M Lib/lib-tk/test/test_tkinter/test_widgets.py Log Message: ----------- [2.7] bpo-30855: Trying to fix test_use on Windows. (#2586) * bpo-30855: Trying to fix test_use on Windows. Avoid possible weird behavior of WideInt convertion. "winfo id" always returns string hexadecimal representation. (cherry picked from commit b9d672491d5082c541bf267eb7bb99fdc6529324) * bpo-30855: Trying to fix test_use on Windows. (cherry picked from commit 29a2f7c6b38e5a6ed891aa72af38974a1ff2d372) (subTest() removed since it was introduced in Python 3) From solipsis at pitrou.net Thu Jul 6 05:07:57 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Thu, 06 Jul 2017 09:07:57 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170706090756.32014.7E6C3FD8A5989117@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [7, 0, -7] memory blocks, sum=0 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogIDlMoX', '--timeout', '7200'] From noreply at github.com Thu Jul 6 12:51:30 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 09:51:30 -0700 Subject: [Python-checkins] [python/cpython] 0653fb: bpo-30862: Updated Logger.setLevel documentation. ... Message-ID: <595e6a923c9a0_564a3fba10ec9c30282841@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 0653fba51c03d20fa4381ba0836acd17fd05b04b https://github.com/python/cpython/commit/0653fba51c03d20fa4381ba0836acd17fd05b04b Author: Vinay Sajip Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Doc/library/logging.rst Log Message: ----------- bpo-30862: Updated Logger.setLevel documentation. (GH-2604) From noreply at github.com Thu Jul 6 15:29:37 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 12:29:37 -0700 Subject: [Python-checkins] [python/cpython] d01264: [3.6] Update idlelib/NEWS.txt with merges upto 201... Message-ID: <595e8fa128a91_5c303f828ae3dc342058bb@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: d0126481292e4699a14e162e5ac7f53d5d590c8f https://github.com/python/cpython/commit/d0126481292e4699a14e162e5ac7f53d5d590c8f Author: terryjreedy Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/idlelib/NEWS.txt Log Message: ----------- [3.6] Update idlelib/NEWS.txt with merges upto 2017 Jul 5. (GH-2595) (#2596) (cherry picked from commit 1ccbad9c95cf5782a1329eeaecba6e3eb0c37cb8) From noreply at github.com Thu Jul 6 15:30:59 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 12:30:59 -0700 Subject: [Python-checkins] [python/cpython] 67ba4f: bpo-26506: hex() documentation: mention %x % int (... Message-ID: <595e8ff3e13e2_65923f9ee0325c44969db@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 67ba4fa467ffff825d6a0c0a21cc54ff1df2ed1b https://github.com/python/cpython/commit/67ba4fa467ffff825d6a0c0a21cc54ff1df2ed1b Author: Manvisha Kodali Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Doc/library/functions.rst Log Message: ----------- bpo-26506: hex() documentation: mention %x % int (GH-2525) From noreply at github.com Thu Jul 6 16:43:39 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 13:43:39 -0700 Subject: [Python-checkins] [python/cpython] be5ebe: Fix case in .gitignore (GH-2607) Message-ID: <595ea0fb43f71_7f6a3fd67dcddc302141fa@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: be5ebe58776a02d53bcf5e43ab946b555c0e025f https://github.com/python/cpython/commit/be5ebe58776a02d53bcf5e43ab946b555c0e025f Author: Segev Finer Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M .gitignore Log Message: ----------- Fix case in .gitignore (GH-2607) From noreply at github.com Thu Jul 6 17:08:31 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 14:08:31 -0700 Subject: [Python-checkins] [python/cpython] 5d2550: [3.6] Fix case in .gitignore (GH-2607) (GH-2608) Message-ID: <595ea6cf1d653_6663f9be16a7c34799d2@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 5d2550cd2ef26c3f5625ab5a1afe3269e44dcb8f https://github.com/python/cpython/commit/5d2550cd2ef26c3f5625ab5a1afe3269e44dcb8f Author: Segev Finer Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M .gitignore Log Message: ----------- [3.6] Fix case in .gitignore (GH-2607) (GH-2608) (cherry picked from commit be5ebe58776a02d53bcf5e43ab946b555c0e025f) From noreply at github.com Thu Jul 6 17:08:42 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 14:08:42 -0700 Subject: [Python-checkins] [python/cpython] 710cc7: [3.5] Fix case in .gitignore (GH-2607) (GH-2609) Message-ID: <595ea6da9ee49_ea23fa27ae3fc4019277c@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 710cc7667c27955272725729775cb39c40cca113 https://github.com/python/cpython/commit/710cc7667c27955272725729775cb39c40cca113 Author: Segev Finer Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M .gitignore Log Message: ----------- [3.5] Fix case in .gitignore (GH-2607) (GH-2609) (cherry picked from commit be5ebe58776a02d53bcf5e43ab946b555c0e025f) From noreply at github.com Thu Jul 6 17:28:25 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 14:28:25 -0700 Subject: [Python-checkins] [python/cpython] c60d2f: bpo-30532: Fix whitespace folding in certain cases... Message-ID: <595eab79e735_58423fd7636d3c2c13744e@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: c60d2f5e8609b040ab58c498fde23928fe9dbef5 https://github.com/python/cpython/commit/c60d2f5e8609b040ab58c498fde23928fe9dbef5 Author: Joel Hillacre Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/email/_header_value_parser.py M Lib/test/test_email/test__header_value_parser.py M Misc/ACKS A Misc/NEWS.d/next/Library/2017-06-26-11-01-59.bpo-30532.qTeL1o.rst Log Message: ----------- bpo-30532: Fix whitespace folding in certain cases (#2591) Leading whitespace was incorrectly dropped during folding of certain lines in the _header_value_parser's folding algorithm. This makes the whitespace handling code consistent. From noreply at github.com Thu Jul 6 17:29:11 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 14:29:11 -0700 Subject: [Python-checkins] [python/cpython] 3bbdf9: bpo-30532: Fix whitespace folding in certain cases... Message-ID: <595eaba74558d_4f043fd885371c3c987e5@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 3bbdf990a2c1b0b303b950058e3177a1bd5f697a https://github.com/python/cpython/commit/3bbdf990a2c1b0b303b950058e3177a1bd5f697a Author: Joel Hillacre Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/email/_header_value_parser.py M Lib/test/test_email/test__header_value_parser.py M Misc/ACKS A Misc/NEWS.d/next/Library/2017-06-26-11-01-59.bpo-30532.qTeL1o.rst Log Message: ----------- bpo-30532: Fix whitespace folding in certain cases (#2592) Leading whitespace was incorrectly dropped during folding of certain lines in the _header_value_parser's folding algorithm. This makes the whitespace handling code consistent. From lp_benchmark_robot at intel.com Thu Jul 6 18:57:55 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Thu, 6 Jul 2017 15:57:55 -0700 Subject: [Python-checkins] [1 down, 64 flat] Results for Python (master branch) 2017-07-06 Message-ID: <7739948b-4889-4028-b731-22391c9618d3@orsmsx152.amr.corp.intel.com> Results for project python/master, build date: 2017-07-06 03:03:30-07:00. - commit: b4baace - previous commit: 0c31163 - revision date: 2017-07-06 08:09:03+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.070% | +0.205% | +4.947% | +7.241% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 0.479% | +0.002% | +19.683% | +10.936% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 0.434% | +0.611% | +21.776% | +9.640% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.319% | +0.336% | +19.364% | +9.466% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 2.732% | +0.557% | +1.737% | +13.999% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.536% | -0.760% | +11.290% | +11.151% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.558% | +0.726% | +7.199% | +9.571% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.662% | +0.272% | +4.687% | +4.867% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.748% | -2.277% | +6.040% | +18.397% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.841% | +0.901% | +10.271% | +11.151% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.158% | +0.298% | +3.527% | +6.924% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.607% | -0.141% | +5.453% | +5.601% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.699% | -0.096% | +3.389% | +6.875% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.102% | +0.425% | +9.365% | +10.813% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.920% | +1.285% | +7.478% | +9.153% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.724% | +0.134% | +4.993% | +12.132% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.023% | +0.038% | +9.518% | +12.051% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.203% | +0.051% | +8.236% | +8.634% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.453% | +0.128% | +3.607% | +9.467% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 5.011% | -0.759% | +3.519% | +10.304% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 2.106% | -0.181% | +6.195% | +10.228% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.275% | +0.279% | +12.644% | +12.742% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.487% | -0.825% | +7.760% | +9.988% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.909% | +1.326% | +18.251% | +11.887% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.740% | -1.248% | +6.673% | +13.079% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.943% | +0.105% | +5.233% | +4.939% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.810% | +0.407% | -3.206% | +5.123% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.830% | -0.150% | +1.673% | +8.397% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.608% | +0.103% | +0.846% | +12.244% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.523% | -0.166% | +0.836% | +23.017% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.875% | +0.025% | +7.321% | +13.976% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.662% | -0.288% | +6.288% | +16.538% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 4.810% | -0.460% | +11.687% | +11.080% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.155% | -0.031% | +0.423% | +10.027% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.114% | -0.110% | +9.454% | +4.332% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.087% | +0.131% | +1.439% | +4.425% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.022% | +0.189% | +9.298% | +11.587% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.121% | +1.393% | -8.943% | +12.528% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.215% | -1.728% | -1.729% | +12.531% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.012% | +0.158% | -2.490% | +8.456% | +-----+------------------------+--------+------------+------------+------------+ | :-( | regex_v8| 1.474% | -5.354% | +5.345% | +5.358% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.831% | +0.733% | +8.915% | +13.176% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.780% | -0.037% | +1.112% | +3.168% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.303% | -1.910% | +19.993% | +11.091% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.871% | -0.838% | +5.170% | +5.576% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.616% | -0.097% | +15.654% | +8.225% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.068% | -0.020% | -1.133% | -0.232% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.668% | -0.380% | +5.882% | +3.350% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.766% | +0.515% | +6.664% | +6.569% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.161% | -0.744% | +4.383% | +4.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.366% | +0.374% | +1.923% | +10.199% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.535% | +0.168% | +12.490% | +8.366% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.838% | +0.198% | +10.365% | +6.181% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.716% | +1.101% | +12.180% | +8.723% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.533% | +0.145% | +13.621% | +9.008% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 1.800% | +1.699% | +24.909% | +8.364% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.105% | +0.331% | +6.260% | +3.823% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 7.170% | -2.208% | +0.456% | +1.842% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 6.604% | +1.716% | +8.482% | +21.524% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.883% | +0.689% | -1.010% | +18.789% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.567% | -0.126% | +8.150% | +7.398% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.923% | +0.030% | +5.771% | +7.202% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.665% | -0.254% | +0.959% | +8.253% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.399% | +2.982% | -7.186% | +12.001% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.292% | -0.196% | +6.487% | +7.814% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-down-64-flat-results-for-python-master-branch-2017-07-06 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Thu Jul 6 20:11:28 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 17:11:28 -0700 Subject: [Python-checkins] [python/cpython] 529746: Make test_shutil test_disk_usage not depend on the... Message-ID: <595ed1b0bb781_265d43f8201ecdc3c1473f2@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 529746c90584069270cd122920270bd7be38bca3 https://github.com/python/cpython/commit/529746c90584069270cd122920270bd7be38bca3 Author: Gregory P. Smith Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/test/test_shutil.py Log Message: ----------- Make test_shutil test_disk_usage not depend on the cwd fs (#2597) Make test_shutil test_disk_usage not depend on the current working directory's filesystem. From noreply at github.com Thu Jul 6 22:19:14 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 19:19:14 -0700 Subject: [Python-checkins] [python/cpython] 25a420: bpo-30780: Fix error in idlelib.test_idle.test_con... Message-ID: <595eefa2b6c25_62d23fd37083bc281255fe@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 25a4206c243e3b1fa6f5b1c72a11b409b007694d https://github.com/python/cpython/commit/25a4206c243e3b1fa6f5b1c72a11b409b007694d Author: terryjreedy Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- bpo-30780: Fix error in idlelib.test_idle.test_configdialog (#2606) From noreply at github.com Thu Jul 6 23:16:32 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 20:16:32 -0700 Subject: [Python-checkins] [python/cpython] df0f99: [3.6] bpo-30780: Fix error in idlelib.test_idle.te... Message-ID: <595efd10cd2c2_c5f3fbadee85c3c26594c@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: df0f99329843c10701ffaefbd3948ac698c12220 https://github.com/python/cpython/commit/df0f99329843c10701ffaefbd3948ac698c12220 Author: terryjreedy Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- [3.6] bpo-30780: Fix error in idlelib.test_idle.test_configdialog (GH-2606) (#2613) (cherry picked from commit 25a4206) From noreply at github.com Fri Jul 7 01:31:45 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 22:31:45 -0700 Subject: [Python-checkins] [python/cpython] 05b72e: bpo-30797, bpo-30694: Avoid _GNU_SOURCE redefined ... Message-ID: <595f1cc1532fd_12b43fde093b9c389293c@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 05b72ede95521b2d897cb4c7b034139b5437c592 https://github.com/python/cpython/commit/05b72ede95521b2d897cb4c7b034139b5437c592 Author: Ned Deily Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- bpo-30797, bpo-30694: Avoid _GNU_SOURCE redefined warning in xmlparse.c (#2615) From noreply at github.com Fri Jul 7 02:10:47 2017 From: noreply at github.com (GitHub) Date: Thu, 06 Jul 2017 23:10:47 -0700 Subject: [Python-checkins] [python/cpython] fae8f4: bpo-29854: Fix segfault in call_readline() (GH-728... Message-ID: <595f25e76c629_7753fc7f4e9bc302772e1@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: fae8f4a9cb88a68eb14750cbb8ddf8740fd67b8b https://github.com/python/cpython/commit/fae8f4a9cb88a68eb14750cbb8ddf8740fd67b8b Author: Nir Soffer Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/test/test_readline.py A Misc/NEWS.d/next/Library/2017-07-07-02-18-57.bpo-29854.J8wKb_.rst M Modules/readline.c Log Message: ----------- bpo-29854: Fix segfault in call_readline() (GH-728) If history-length is set in .inputrc, and the history file is double the history size (or more), history_get(N) returns NULL, and python segfaults. Fix that by checking for NULL return value. It seems that the root cause is incorrect handling of bigger history in readline, but Python should not segfault even if readline returns unexpected value. This issue affects only GNU readline. When using libedit emulation system history size option does not work. From solipsis at pitrou.net Fri Jul 7 05:07:31 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Fri, 07 Jul 2017 09:07:31 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170707090730.58514.E3CF3D77492BBAF6@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [-1, 2, -1] memory blocks, sum=0 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogzVS7lh', '--timeout', '7200'] From noreply at github.com Fri Jul 7 10:07:00 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 07:07:00 -0700 Subject: [Python-checkins] [python/cpython] 1881be: bpo-29854: test_readline logs versions (#2619) Message-ID: <595f9584510ae_cfc3fe3510f3c2c3009cf@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 1881befb905553618f1e7ad2cef8f6ff07e1b8ef https://github.com/python/cpython/commit/1881befb905553618f1e7ad2cef8f6ff07e1b8ef Author: Victor Stinner Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/test/test_readline.py M Modules/readline.c Log Message: ----------- bpo-29854: test_readline logs versions (#2619) * test_readline logs the versions of libreadline when run in verbose mode * Add also readline._READLINE_LIBRARY_VERSION From noreply at github.com Fri Jul 7 16:00:59 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 13:00:59 -0700 Subject: [Python-checkins] [python/cpython] 349abd: bpo-30779: IDLE -- Factor ConfigChanges class from... Message-ID: <595fe87b2f502_40303fca9a079c302275e8@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 349abd9e37dfdc077bc21f19e6ed2292c767f0e8 https://github.com/python/cpython/commit/349abd9e37dfdc077bc21f19e6ed2292c767f0e8 Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_config.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- bpo-30779: IDLE -- Factor ConfigChanges class from configdialog, put in config; test. (#2612) * In config, put dump test code in a function; run it and unittest in 'if __name__ == '__main__'. * Add class config.ConfigChanges based on changes_class_v4.py on bpo issue. * Add class test_config.ChangesTest, partly based on configdialog_tests_v1.py on bpo issue. * Revise configdialog to use ConfigChanges, mostly as specified in tracker msg297804. * Revise test_configdialog to match configdialog changes. All tests pass in both files. * Remove configdialog functions unused or moved to ConfigChanges. Cheryl Sabella contributed parts of the patch. From noreply at github.com Fri Jul 7 16:37:40 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 13:37:40 -0700 Subject: [Python-checkins] [python/cpython] edc034: [3.6] bpo-30779: IDLE -- Factor ConfigChanges clas... Message-ID: <595ff1147b1e2_6a513fcc81f0dc40348540@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: edc034221f878b437748cef0f05c782d8190499d https://github.com/python/cpython/commit/edc034221f878b437748cef0f05c782d8190499d Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_config.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- [3.6] bpo-30779: IDLE -- Factor ConfigChanges class from configdialog, put in config; test. (GH-2612) (#2625) * In config, put dump test code in a function; run it and unittest in 'if __name__ == '__main__'. * Add class config.ConfigChanges based on changes_class_v4.py on bpo issue. * Add class test_config.ChangesTest, partly based on configdialog_tests_v1.py on bpo issue. * Revise configdialog to use ConfigChanges, mostly as specified in tracker msg297804. * Revise test_configdialog to match configdialog changes. All tests pass in both files. * Remove configdialog functions unused or moved to ConfigChanges. Cheryl Sabella contributed parts of the patch. (cherry picked from commit 349abd9) From lp_benchmark_robot at intel.com Fri Jul 7 18:18:17 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Fri, 7 Jul 2017 15:18:17 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-07 Message-ID: Results for project python/master, build date: 2017-07-07 03:03:39-07:00. - commit: fae8f4a - previous commit: b4baace - revision date: 2017-07-07 09:10:46+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.040% | -0.098% | +4.854% | +7.329% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 0.433% | +0.028% | +19.706% | +14.166% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 0.823% | -0.032% | +21.751% | +12.896% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.576% | -0.084% | +19.296% | +10.677% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 1.888% | -0.385% | +1.358% | +16.857% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.194% | -0.329% | +10.998% | +11.159% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.426% | -0.365% | +6.860% | +9.680% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.400% | -0.042% | +4.647% | +5.779% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.360% | -0.047% | +5.997% | +19.586% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 2.827% | +0.467% | +10.690% | +11.957% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.410% | -0.317% | +3.222% | +7.163% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.651% | -0.119% | +5.341% | +6.444% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.132% | -0.168% | +3.227% | +5.776% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.314% | -0.152% | +9.227% | +11.519% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.312% | -0.321% | +7.181% | +10.020% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.723% | -0.014% | +4.980% | +12.104% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.529% | +0.214% | +9.712% | +11.412% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.045% | +0.064% | +8.294% | +8.691% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.398% | +0.144% | +3.745% | +9.136% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 4.662% | +0.242% | +3.752% | +9.760% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.661% | -0.463% | +5.761% | +11.692% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.327% | -0.244% | +12.431% | +12.167% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.691% | -0.912% | +6.919% | +13.356% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.747% | +0.048% | +18.291% | +12.967% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.064% | +0.228% | +6.885% | +11.371% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 3.027% | +0.169% | +5.393% | +4.004% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.456% | +0.068% | -3.136% | +5.228% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.966% | -0.012% | +1.662% | +7.496% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.094% | +0.190% | +1.034% | +12.208% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 0.844% | +0.191% | +1.026% | +22.247% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.163% | +0.131% | +7.442% | +17.632% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.064% | -0.100% | +6.194% | +18.101% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 1.634% | +1.152% | +12.705% | +10.288% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.258% | -0.023% | +0.400% | +9.797% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.123% | -0.231% | +9.245% | +4.784% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.084% | -0.099% | +1.342% | +4.763% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.444% | -0.137% | +9.174% | +12.804% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.482% | +0.577% | -8.314% | +11.396% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.333% | -0.059% | -1.789% | +12.296% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.349% | -0.930% | -3.443% | +9.542% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.885% | +0.332% | +5.659% | +5.003% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 2.511% | -0.705% | +8.272% | +13.459% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.456% | +0.128% | +1.239% | +3.479% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.166% | +0.980% | +20.777% | +15.851% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 2.221% | +0.232% | +5.390% | +2.257% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.493% | +0.084% | +15.724% | +7.385% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 0.162% | +0.303% | -0.826% | +3.578% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.709% | +0.059% | +5.938% | +2.627% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.737% | -0.502% | +6.195% | +7.053% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 2.718% | +1.112% | +5.447% | +3.481% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.607% | -1.272% | +0.676% | +10.334% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.332% | -0.240% | +12.280% | +8.995% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.156% | +0.372% | +10.698% | +6.458% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.364% | -0.089% | +12.102% | +9.901% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.835% | -0.376% | +13.296% | +9.928% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.165% | -2.468% | +23.056% | +8.824% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.105% | -0.234% | +6.041% | +5.895% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.975% | +1.162% | +1.613% | -0.094% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 4.830% | +0.738% | +9.157% | +19.450% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.071% | +0.030% | -0.979% | +17.879% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.203% | +0.148% | +8.286% | +7.029% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.718% | +0.146% | +5.909% | +7.719% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.664% | +0.281% | +1.238% | +8.485% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.809% | -0.399% | -7.614% | +13.024% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.214% | -0.008% | +6.480% | +8.093% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-07 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Fri Jul 7 20:49:39 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 17:49:39 -0700 Subject: [Python-checkins] [python/cpython] 24f2e1: bpo-30779: News (#2627) Message-ID: <59602c234737b_21fd3ff94df87c401013d2@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 24f2e19d68cc6ca563d2be5944d11d5f55a46918 https://github.com/python/cpython/commit/24f2e19d68cc6ca563d2be5944d11d5f55a46918 Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: A Misc/NEWS.d/next/IDLE/2017-07-07-20-26-37.bpo-30779.8KXEXN.rst Log Message: ----------- bpo-30779: News (#2627) From noreply at github.com Fri Jul 7 22:26:54 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 19:26:54 -0700 Subject: [Python-checkins] [python/cpython] 9d8abf: [3.6] bpo-30779: News (GH-2627) (#2630) Message-ID: <596042ee7049b_3b1a3fe6decb7c30109136@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 9d8abf31c430dd83d073660cc92f1fe4ca6f2cd4 https://github.com/python/cpython/commit/9d8abf31c430dd83d073660cc92f1fe4ca6f2cd4 Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: A Misc/NEWS.d/next/IDLE/2017-07-07-20-26-37.bpo-30779.8KXEXN.rst Log Message: ----------- [3.6] bpo-30779: News (GH-2627) (#2630) (cherry picked from commit 24f2e19) From noreply at github.com Fri Jul 7 22:28:07 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 19:28:07 -0700 Subject: [Python-checkins] [python/cpython] 223c7e: bpo-8231: Call idlelib.IdleConf.GetUserCfgDir only... Message-ID: <596043377634d_42d33fe4b4381c3c2463b0@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 223c7e70e48eb6eed4aab3906fbe32b098faafe3 https://github.com/python/cpython/commit/223c7e70e48eb6eed4aab3906fbe32b098faafe3 Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/editor.py M Lib/idlelib/pyshell.py A Misc/NEWS.d/next/IDLE/2017-07-07-21-10-55.bpo-8231.yEge3L.rst Log Message: ----------- bpo-8231: Call idlelib.IdleConf.GetUserCfgDir only once. (#2629) From noreply at github.com Fri Jul 7 22:47:39 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 19:47:39 -0700 Subject: [Python-checkins] [python/cpython] 552f26: [3.6] bpo-8231: Call idlelib.IdleConf.GetUserCfgDi... Message-ID: <596047cbcd87_564a3fba10ec9c303144e@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 552f26680d3806df7c27dd7161fd7d57ac815f78 https://github.com/python/cpython/commit/552f26680d3806df7c27dd7161fd7d57ac815f78 Author: terryjreedy Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/editor.py M Lib/idlelib/pyshell.py A Misc/NEWS.d/next/IDLE/2017-07-07-21-10-55.bpo-8231.yEge3L.rst Log Message: ----------- [3.6] bpo-8231: Call idlelib.IdleConf.GetUserCfgDir only once. (GH-2629) (#2631) (cherry picked from commit 223c7e7) From noreply at github.com Sat Jul 8 00:51:38 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 21:51:38 -0700 Subject: [Python-checkins] [python/cpython] 00134f: bpo-30687: Fixes build scripts to find msbuild.exe... Message-ID: <596064da2593c_5be83fbcbaac7c34603e2@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 00134f64d982561750f57f1a0bb7bb073f9f237c https://github.com/python/cpython/commit/00134f64d982561750f57f1a0bb7bb073f9f237c Author: Steve Dower Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Misc/NEWS M PC/bdist_wininst/bdist_wininst.vcxproj M PC/bdist_wininst/build.bat M PCbuild/build.bat A PCbuild/find_msbuild.bat M PCbuild/python.vcxproj M Tools/msi/build.bat M Tools/msi/buildrelease.bat M Tools/msi/uploadrelease.bat M Tools/nuget/build.bat Log Message: ----------- bpo-30687: Fixes build scripts to find msbuild.exe and stop relying on vcvarsall.bat (#2252) (#2280) * Fixes build scripts to find msbuild.exe and stop relying on vcvarsall.bat Also fixes bdist_wininst.vcxproj to use correct version in generated name. (cherry picked from commit 06d6e3d0bb5b8a3d3105289034953a8014356a0b) Commit: b0fba8874a4bd6bf4773e6efdbd8fa762e9f05bd https://github.com/python/cpython/commit/b0fba8874a4bd6bf4773e6efdbd8fa762e9f05bd Author: Victor Stinner Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/test/test_urlparse.py M Lib/urllib/parse.py M Misc/ACKS M Misc/NEWS Log Message: ----------- bpo-30500: urllib: Simplify splithost by calling into urlparse. (#1849) (#2289) The current regex based splitting produces a wrong result. For example:: http://abc#@def Web browsers parse that URL as ``http://abc/#@def``, that is, the host is ``abc``, the path is ``/``, and the fragment is ``#@def``. (cherry picked from commit 90e01e50ef8a9e6c91f30d965563c378a4ad26de) (cherry picked from commit 536c1f1246f4faa302f9f5613fc3444e7ae09b4a) Commit: ea1ab803ddc14ab02ffed50ecc5089897f259623 https://github.com/python/cpython/commit/ea1ab803ddc14ab02ffed50ecc5089897f259623 Author: Victor Stinner Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Misc/NEWS M Modules/expat/COPYING M Modules/expat/expat.h M Modules/expat/expat_external.h A Modules/expat/siphash.h M Modules/expat/winconfig.h M Modules/expat/xmlparse.c M Modules/expat/xmlrole.c M Modules/expat/xmltok.c Log Message: ----------- bpo-30694: Upgrade Modules/expat/ to libexpat 2.2.1 (#2300) (#2313) New file: Modules/expat/siphash.h. (cherry picked from commit 5ff7132313eb651107b179d20218dfe5d4e47f13) (cherry picked from commit 4a66524006852fc982aebafa277f2c043d9ad149) Commit: 5777e79ecbd1f2adf36456e09f210608ee221691 https://github.com/python/cpython/commit/5777e79ecbd1f2adf36456e09f210608ee221691 Author: Victor Stinner Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M PCbuild/_elementtree.vcxproj Log Message: ----------- [3.6] bpo-30726: PCbuild _elementtree: remove duplicate defines (#2348) (#2349) * bpo-30726: PCbuild _elementtree: remove duplicate defines (#2348) bpo-30726, bpo-29591: libexpat 2.2.1 of Modules/expat/ now uses a winconfig.h configuration file which already defines: * XML_NS * XML_DTD * BYTEORDER=1234 * XML_CONTEXT_BYTES=1024 * HAVE_MEMMOVE Remove these defines from PCbuild/_elementtree.vcxproj to prevent compiler warnings. Co-Authored-By: Jeremy Kloth (cherry picked from commit c8fb58bd7917151e63398587a7fc2126db7c26de) * bpo-30726: Fix elementtree warnings on Windows due to expat upgrade (#2319) * bpo-30726: Fix elementtree warnings on Windows Caused by usage of `getenv` which should be safe. And a few integer truncations which should also be ok. * bpo-30726: Don't ignore libexpat warnings which haypo intends to fix upstream (cherry picked from commit 87c65550730a8f85ce339ba197bce4fb7e836619) (cherry picked from commit d32a05953130fb5cc2d3c0c9fcb20ad0859353f3) Commit: b6012f982fabed6029d7e2db2a509a8b28b4f6e1 https://github.com/python/cpython/commit/b6012f982fabed6029d7e2db2a509a8b28b4f6e1 Author: Segev Finer Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M PCbuild/pyexpat.vcxproj Log Message: ----------- [3.6] bpo-30726: Also fix pyexpat.vcxproj (GH-2375) (#2570) (cherry picked from commit 7526cadd64566725ffc56071a7208828a46ddbd8) (cherry picked from commit d02c8416fe1b29b3322004b73133bf6c8a2e353a) Commit: c794b643c9172d69afa46f85982befd82511d9df https://github.com/python/cpython/commit/c794b643c9172d69afa46f85982befd82511d9df Author: Victor Stinner Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Objects/codeobject.c Log Message: ----------- bpo-30704, bpo-30604: Fix memleak in code_dealloc() (#2455) (#2456) Free also co_extra->ce_extras, not only co_extra. (cherry picked from commit 23e7944eba1968bb8432fdc4cc96d4fdd2c1a230) (cherry picked from commit 26daad4ee14693381d84a5235709d22aed1c22ed) Commit: a9b16cff35811f88cdfeb4f50758140dfff36ebc https://github.com/python/cpython/commit/a9b16cff35811f88cdfeb4f50758140dfff36ebc Author: Serhiy Storchaka Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Lib/subprocess.py M Lib/test/test_subprocess.py M Misc/NEWS M Modules/_winapi.c M Objects/abstract.c Log Message: ----------- [3.6] bpo-30730: Prevent environment variables injection in subprocess on Windows. (GH-2325) (#2360) Prevent passing other invalid environment variables and command arguments.. (cherry picked from commit d174d24a5d37d1516b885dc7c82f71ecd5930700) (cherry picked from commit e7135751b8e48af80665e40ac8fa6d0073e5affe) Commit: d1d65015fca44b8d1f0b1df78694310270f03a6d https://github.com/python/cpython/commit/d1d65015fca44b8d1f0b1df78694310270f03a6d Author: Serhiy Storchaka Date: 2017-07-06 (Thu, 06 Jul 2017) Changed paths: M Modules/_winapi.c Log Message: ----------- [3.6] bpo-30745: Fix compiler warnings introduced in bpo-30730. (GH-2376) (#2378) (cherry picked from commit 0ee32c1) (cherry picked from commit 0e1f9e8d3ea82262cbb9a403b70a884da5e6a6ac) Commit: bdabd7666032ce356d550da21c35e4bee5b3448c https://github.com/python/cpython/commit/bdabd7666032ce356d550da21c35e4bee5b3448c Author: Ned Deily Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- bpo-30797, bpo-30694: Avoid _GNU_SOURCE redefined warning in xmlparse.c (#2615) (cherry picked from commit 05b72ede95521b2d897cb4c7b034139b5437c592) Commit: 891331134516784ff1c5ad8d1720fdc2d056a15f https://github.com/python/cpython/commit/891331134516784ff1c5ad8d1720fdc2d056a15f Author: Ned Deily Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Include/patchlevel.h M Misc/NEWS M README.rst Log Message: ----------- Version bump to 3.6.2rc2 Commit: b79d58ec250c69cf113167b96e9c0c7bf2e29633 https://github.com/python/cpython/commit/b79d58ec250c69cf113167b96e9c0c7bf2e29633 Author: Ned Deily Date: 2017-07-08 (Sat, 08 Jul 2017) Log Message: ----------- Merge tag 'v3.6.2rc2' into 3.6 Tag v3.6.2rc2 Commit: 03e0df66b8ce0a8d980eb2092b7c6464d26db14e https://github.com/python/cpython/commit/03e0df66b8ce0a8d980eb2092b7c6464d26db14e Author: Ned Deily Date: 2017-07-08 (Sat, 08 Jul 2017) Changed paths: M Include/patchlevel.h M Misc/NEWS Log Message: ----------- Update for post-3.6.2rc2 Compare: https://github.com/python/cpython/compare/552f26680d38...03e0df66b8ce From noreply at github.com Sat Jul 8 00:52:00 2017 From: noreply at github.com (GitHub) Date: Fri, 07 Jul 2017 21:52:00 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <596064f09942e_593f3fa61daa1c2c29787@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/tags/v3.6.2rc2 Home: https://github.com/python/cpython From solipsis at pitrou.net Sat Jul 8 05:07:04 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sat, 08 Jul 2017 09:07:04 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=12 Message-ID: <20170708090704.85237.DD3673EF2AA5C15C@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 7, 0] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [0, -1, 2] memory blocks, sum=1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogAO5_bb', '--timeout', '7200'] From noreply at github.com Sat Jul 8 10:34:29 2017 From: noreply at github.com (GitHub) Date: Sat, 08 Jul 2017 07:34:29 -0700 Subject: [Python-checkins] [python/cpython] aa6a4d: bpo-29854: Skip history-size test on older readlin... Message-ID: <5960ed7526e37_254e3f8a39273c44424e8@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: aa6a4d6ed881f79c51fb91dd928ed9496737b420 https://github.com/python/cpython/commit/aa6a4d6ed881f79c51fb91dd928ed9496737b420 Author: Nir Soffer Date: 2017-07-08 (Sat, 08 Jul 2017) Changed paths: M Lib/test/test_readline.py Log Message: ----------- bpo-29854: Skip history-size test on older readline (GH-2621) Turns out that history-size was added in readline 6.0. This explain why this tests fail on FreeBSD when using readline 5.2. We skip now the history size if readline does not support it. See https://cnswww.cns.cwru.edu/php/chet/readline/CHANGES for details. From noreply at github.com Sat Jul 8 14:51:22 2017 From: noreply at github.com (GitHub) Date: Sat, 08 Jul 2017 11:51:22 -0700 Subject: [Python-checkins] [python/cpython] 04f77d: [3.6] bpo-29854: Fix segfault in call_readline() (... Message-ID: <596129aae8bc4_11efa3f95d7fc9c3c414fe@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 04f77d4677e7508b6ec8de9d0331fdabbcd11d30 https://github.com/python/cpython/commit/04f77d4677e7508b6ec8de9d0331fdabbcd11d30 Author: Nir Soffer Date: 2017-07-08 (Sat, 08 Jul 2017) Changed paths: M Lib/test/test_readline.py A Misc/NEWS.d/next/Library/2017-07-07-02-18-57.bpo-29854.J8wKb_.rst M Modules/readline.c Log Message: ----------- [3.6] bpo-29854: Fix segfault in call_readline() (GH-728) If history-length is set in .inputrc, and the history file is double the history size (or more), history_get(N) returns NULL, and python segfaults. Fix that by checking for NULL return value. It seems that the root cause is incorrect handling of bigger history in readline, but Python should not segfault even if readline returns unexpected value. This issue affects only GNU readline. When using libedit emulation system history size option does not work. From noreply at github.com Sat Jul 8 23:45:07 2017 From: noreply at github.com (GitHub) Date: Sat, 08 Jul 2017 20:45:07 -0700 Subject: [Python-checkins] [python/cpython] 964808: bpo-30878: Fix error message when keyword argument... Message-ID: <5961a6c3e2062_65613f99a065bc281418d3@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 9648088e6ccd6d0cc04f450f55628fd8eda3784c https://github.com/python/cpython/commit/9648088e6ccd6d0cc04f450f55628fd8eda3784c Author: Sylvain Date: 2017-07-09 (Sun, 09 Jul 2017) Changed paths: M Lib/test/test_call.py M Objects/funcobject.c Log Message: ----------- bpo-30878: Fix error message when keyword arguments are passed (#2635) to staticmethod() and classmethod(). From solipsis at pitrou.net Sun Jul 9 05:08:19 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sun, 09 Jul 2017 09:08:19 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170709090819.102626.6221487AF17850C7@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogvUCuWs', '--timeout', '7200'] From noreply at github.com Sun Jul 9 06:42:38 2017 From: noreply at github.com (GitHub) Date: Sun, 09 Jul 2017 03:42:38 -0700 Subject: [Python-checkins] [python/cpython] 68c372: [3.5] bpo-29854: Fix segfault in call_readline() (... Message-ID: <5962089ed1336_2f353f868dd01c3813691a@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 68c3724651776f4ae90ed24d70cef6fd45bc7db5 https://github.com/python/cpython/commit/68c3724651776f4ae90ed24d70cef6fd45bc7db5 Author: Nir Soffer Date: 2017-07-09 (Sun, 09 Jul 2017) Changed paths: M Lib/test/test_readline.py A Misc/NEWS.d/next/Library/2017-07-07-02-18-57.bpo-29854.J8wKb_.rst M Modules/readline.c Log Message: ----------- [3.5] bpo-29854: Fix segfault in call_readline() (GH-728) If history-length is set in .inputrc, and the history file is double the history size (or more), history_get(N) returns NULL, and python segfaults. Fix that by checking for NULL return value. It seems that the root cause is incorrect handling of bigger history in readline, but Python should not segfault even if readline returns unexpected value. This issue affects only GNU readline. When using libedit emulation system history size option does not work. From noreply at github.com Sun Jul 9 18:57:20 2017 From: noreply at github.com (GitHub) Date: Sun, 09 Jul 2017 15:57:20 -0700 Subject: [Python-checkins] [python/cpython] bb2bae: bpo-30870: IDLE: Change sample font when select by... Message-ID: <5962b4d054be9_207f3fdd3fc31c3c25786f@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: bb2bae84d6b29f991b757b46430c3c15c60059e9 https://github.com/python/cpython/commit/bb2bae84d6b29f991b757b46430c3c15c60059e9 Author: Louie Lu Date: 2017-07-09 (Sun, 09 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-08-17-57-04.bpo-30870.IcR2pf.rst Log Message: ----------- bpo-30870: IDLE: Change sample font when select by key-up/down (#2617) Patch by Louie Lu. From noreply at github.com Sun Jul 9 19:26:34 2017 From: noreply at github.com (GitHub) Date: Sun, 09 Jul 2017 16:26:34 -0700 Subject: [Python-checkins] [python/cpython] 7ab334: [3.6] bpo-30870: IDLE: Change sample font when sel... Message-ID: <5962bbaa6a9_254e3f8a39273c44486e8@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 7ab334233394070a25344d481c8de1402fa12b29 https://github.com/python/cpython/commit/7ab334233394070a25344d481c8de1402fa12b29 Author: terryjreedy Date: 2017-07-09 (Sun, 09 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-08-17-57-04.bpo-30870.IcR2pf.rst Log Message: ----------- [3.6] bpo-30870: IDLE: Change sample font when select by key-up/down (GH-2617) (#2640) Patch by Louie Lu. (cherry picked from commit bb2bae8) From noreply at github.com Mon Jul 10 04:25:58 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 01:25:58 -0700 Subject: [Python-checkins] [python/cpython] 7e6019: Remove _PyArg_NoStackKeywords(). (#2641) Message-ID: <59633a161308d_54e23fc611b7dc2c2349b9@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 7e60192fe0dfd763b0d458cf0898ba4f7ac7d81a https://github.com/python/cpython/commit/7e60192fe0dfd763b0d458cf0898ba4f7ac7d81a Author: Serhiy Storchaka Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Include/modsupport.h M Modules/_hashopenssl.c M Python/getargs.c Log Message: ----------- Remove _PyArg_NoStackKeywords(). (#2641) From solipsis at pitrou.net Mon Jul 10 05:07:02 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Mon, 10 Jul 2017 09:07:02 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=5 Message-ID: <20170710090701.85463.3815200BAF6B3B97@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [7, -7, 1] memory blocks, sum=1 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflog2W1CDj', '--timeout', '7200'] From noreply at github.com Mon Jul 10 06:45:25 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 03:45:25 -0700 Subject: [Python-checkins] [python/cpython] 3b69d9: bpo-30886: Fix multiprocessing.Queue.join_thread()... Message-ID: <59635ac51d430_37473f8e4770dc347647b@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 3b69d911c57ef591ac0c0f47a66dbcad8337f33a https://github.com/python/cpython/commit/3b69d911c57ef591ac0c0f47a66dbcad8337f33a Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/multiprocessing/queues.py A Misc/NEWS.d/next/Library/2017-07-10-12-14-22.bpo-30886.nqQj34.rst Log Message: ----------- bpo-30886: Fix multiprocessing.Queue.join_thread() (#2642) multiprocessing.Queue.join_thread() now waits until the thread completes, even if the thread was started by the same process which created the queue. Fix the following warning which occurs randomly when running test_handle_called_with_mp_queue of test_logging.QueueListenerTest: Warning -- threading_cleanup() failed to cleanup -1 threads after 4 sec (count: 0, dangling: 1) From noreply at github.com Mon Jul 10 07:43:18 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 04:43:18 -0700 Subject: [Python-checkins] [python/cpython] 69e418: bpo-30886: Fix multiprocessing.Queue.join_thread()... Message-ID: <59636856e1f89_47633f91048fbc3414451c@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 69e41807f0851ff1107f949dcdc94dbb0af32acd https://github.com/python/cpython/commit/69e41807f0851ff1107f949dcdc94dbb0af32acd Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/multiprocessing/queues.py A Misc/NEWS.d/next/Library/2017-07-10-12-14-22.bpo-30886.nqQj34.rst Log Message: ----------- bpo-30886: Fix multiprocessing.Queue.join_thread() (#2642) (#2644) multiprocessing.Queue.join_thread() now waits until the thread completes, even if the thread was started by the same process which created the queue. Fix the following warning which occurs randomly when running test_handle_called_with_mp_queue of test_logging.QueueListenerTest: Warning -- threading_cleanup() failed to cleanup -1 threads after 4 sec (count: 0, dangling: 1) (cherry picked from commit 3b69d911c57ef591ac0c0f47a66dbcad8337f33a) From noreply at github.com Mon Jul 10 07:43:21 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 04:43:21 -0700 Subject: [Python-checkins] [python/cpython] 7f3d65: bpo-30886: Fix multiprocessing.Queue.join_thread()... Message-ID: <596368598e4ca_5cd43f854b429c34237795@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 7f3d65d6e4f8bebaaf996efb1c1adb67eb1724cb https://github.com/python/cpython/commit/7f3d65d6e4f8bebaaf996efb1c1adb67eb1724cb Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/multiprocessing/queues.py A Misc/NEWS.d/next/Library/2017-07-10-12-14-22.bpo-30886.nqQj34.rst Log Message: ----------- bpo-30886: Fix multiprocessing.Queue.join_thread() (#2642) (#2643) multiprocessing.Queue.join_thread() now waits until the thread completes, even if the thread was started by the same process which created the queue. Fix the following warning which occurs randomly when running test_handle_called_with_mp_queue of test_logging.QueueListenerTest: Warning -- threading_cleanup() failed to cleanup -1 threads after 4 sec (count: 0, dangling: 1) (cherry picked from commit 3b69d911c57ef591ac0c0f47a66dbcad8337f33a) From noreply at github.com Mon Jul 10 08:37:51 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 05:37:51 -0700 Subject: [Python-checkins] [python/cpython] 64fa44: bpo-30866: Add _testcapi.stack_pointer() (#2601) Message-ID: <5963751fce54_5fad3f9d44ad7c3c263af@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 64fa449f559b0e7b0480a177000419a78ebcf3ff https://github.com/python/cpython/commit/64fa449f559b0e7b0480a177000419a78ebcf3ff Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Modules/_testcapimodule.c Log Message: ----------- bpo-30866: Add _testcapi.stack_pointer() (#2601) From noreply at github.com Mon Jul 10 13:50:47 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 10:50:47 -0700 Subject: [Python-checkins] [python/cpython] aa8d0a: bpo-30851: IDLE: Remove unused tk variables in con... Message-ID: <5963be77f133d_1e983fcfb333bc34477eb@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: aa8d0a24694bea05061f1920ec3f944a9e6799d5 https://github.com/python/cpython/commit/aa8d0a24694bea05061f1920ec3f944a9e6799d5 Author: csabella Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-09-23-53-00.bpo-30851.AHXBYa.rst Log Message: ----------- bpo-30851: IDLE: Remove unused tk variables in configdialog. (#2626) One is a duplicate, one is set but cannot be altered by users. Patch by Cheryl Sabella. From noreply at github.com Mon Jul 10 15:11:49 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 12:11:49 -0700 Subject: [Python-checkins] [python/cpython] 8e3f73: [3.6] bpo-30851: IDLE: Remove unused tk variables ... Message-ID: <5963d175c09d_490a3fdc31e29c3841633@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 8e3f73e5499a5bc575a5e7ad4ee0f16b1aaae829 https://github.com/python/cpython/commit/8e3f73e5499a5bc575a5e7ad4ee0f16b1aaae829 Author: terryjreedy Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-09-23-53-00.bpo-30851.AHXBYa.rst Log Message: ----------- [3.6] bpo-30851: IDLE: Remove unused tk variables in configdialog. (GH-2626) (#2648) One is a duplicate, one is set but cannot be altered by users. Patch by Cheryl Sabella. (cherry picked from commit aa8d0a2) From noreply at github.com Mon Jul 10 16:05:27 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 13:05:27 -0700 Subject: [Python-checkins] [python/cpython] 5d1554: json Docs: Trivial update to the code example (GH-... Message-ID: <5963de07cfc48_756b3fc6ca9fbc3c3659d@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 5d1554a2eb00938f3d5a3e18b6244dd023fc9339 https://github.com/python/cpython/commit/5d1554a2eb00938f3d5a3e18b6244dd023fc9339 Author: Kit Sunde Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Doc/library/json.rst Log Message: ----------- json Docs: Trivial update to the code example (GH-2465) Replace `dumps` with `json.dumps` From noreply at github.com Mon Jul 10 16:28:05 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 13:28:05 -0700 Subject: [Python-checkins] [python/cpython] b136f1: bpo-30892: Fix _elementtree module initialization ... Message-ID: <5963e355a967e_700f3f846c07dc3c50199@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: b136f11f3a51f9282ae992bac68f170ca5563b55 https://github.com/python/cpython/commit/b136f11f3a51f9282ae992bac68f170ca5563b55 Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Modules/_elementtree.c Log Message: ----------- bpo-30892: Fix _elementtree module initialization (#2647) Handle getattr(copy, 'deepcopy') error in _elementtree module initialization. From noreply at github.com Mon Jul 10 16:52:33 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 13:52:33 -0700 Subject: [Python-checkins] [python/cpython] 4f9a44: bpo-30891: Fix importlib _find_and_load() race con... Message-ID: <5963e91196996_3cb53f7e69c33c2413090@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 4f9a446f3fb42f800e73cd9414dd1eccb3ca4fa7 https://github.com/python/cpython/commit/4f9a446f3fb42f800e73cd9414dd1eccb3ca4fa7 Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Python/import.c M Python/importlib.h Log Message: ----------- bpo-30891: Fix importlib _find_and_load() race condition (#2646) * Rewrite importlib _get_module_lock(): it is now responsible to hold the imp lock directly. * _find_and_load() now holds the module lock to check if name is in sys.modules to prevent a race condition From noreply at github.com Mon Jul 10 17:06:59 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 14:06:59 -0700 Subject: [Python-checkins] [python/cpython] bfa4fe: [2.7] bpo-29854: Fix segfault in call_readline() (... Message-ID: <5963ec7319a0c_3d513f8484781c3c397ab@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: bfa4fe4f39dd8b5ce1a0b649cedd36857859081a https://github.com/python/cpython/commit/bfa4fe4f39dd8b5ce1a0b649cedd36857859081a Author: Nir Soffer Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-07-02-18-57.bpo-29854.J8wKb_.rst M Modules/readline.c Log Message: ----------- [2.7] bpo-29854: Fix segfault in call_readline() (GH-728) If history-length is set in .inputrc, and the history file is double the history size (or more), history_get(N) returns NULL, and python segfaults. Fix that by checking for NULL return value. It seems that the root cause is incorrect handling of bigger history in readline, but Python should not segfault even if readline returns unexpected value. This issue affects only GNU readline. When using libedit emulation system history size option does not work. This is a backport of the actual fix from master without the test, since the test depends on new run_pty() helper which is not available in 2.7. From noreply at github.com Mon Jul 10 17:12:39 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 14:12:39 -0700 Subject: [Python-checkins] [python/cpython] 044e15: bpo-30892: Fix _elementtree module initialization ... Message-ID: <5963edc72029b_70ae3ff5eb6cfc3469ac@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 044e156426825acac8b6c6d1ce14d5b7bcb20bc9 https://github.com/python/cpython/commit/044e156426825acac8b6c6d1ce14d5b7bcb20bc9 Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Modules/_elementtree.c Log Message: ----------- bpo-30892: Fix _elementtree module initialization (#2647) (#2649) Handle getattr(copy, 'deepcopy') error in _elementtree module initialization. (cherry picked from commit b136f11f3a51f9282ae992bac68f170ca5563b55) From noreply at github.com Mon Jul 10 17:13:50 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 14:13:50 -0700 Subject: [Python-checkins] [python/cpython] 7f567e: bpo-30892: Fix _elementtree module initialization ... Message-ID: <5963ee0ecfb50_46d23fb378defc2c218d6@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 7f567e7472dd6c3d066eec1c204301df251484b5 https://github.com/python/cpython/commit/7f567e7472dd6c3d066eec1c204301df251484b5 Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Modules/_elementtree.c Log Message: ----------- bpo-30892: Fix _elementtree module initialization (#2647) (#2650) Handle getattr(copy, 'deepcopy') error in _elementtree module initialization. (cherry picked from commit b136f11f3a51f9282ae992bac68f170ca5563b55) From noreply at github.com Mon Jul 10 17:16:28 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 14:16:28 -0700 Subject: [Python-checkins] [python/cpython] fe6e68: bpo-30891: Fix importlib _find_and_load() race con... Message-ID: <5963eeacceff1_25343f98edba9c24481a6@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: fe6e686c27ce3a3ecdf03803cff7e230dee5530d https://github.com/python/cpython/commit/fe6e686c27ce3a3ecdf03803cff7e230dee5530d Author: Victor Stinner Date: 2017-07-10 (Mon, 10 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Python/import.c M Python/importlib.h Log Message: ----------- bpo-30891: Fix importlib _find_and_load() race condition (#2646) (#2651) * Rewrite importlib _get_module_lock(): it is now responsible to hold the imp lock directly. * _find_and_load() now holds the module lock to check if name is in sys.modules to prevent a race condition (cherry picked from commit 4f9a446f3fb42f800e73cd9414dd1eccb3ca4fa7) From lp_benchmark_robot at intel.com Mon Jul 10 19:56:29 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Mon, 10 Jul 2017 16:56:29 -0700 Subject: [Python-checkins] [1 down, 3 up, 61 flat] Results for Python (master branch) 2017-07-10 Message-ID: Results for project python/master, build date: 2017-07-10 03:03:30-07:00. - commit: 7e60192 - previous commit: fae8f4a - revision date: 2017-07-10 10:25:34+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.010% | -0.903% | +3.995% | +7.187% | +-----+------------------------+--------+------------+------------+------------+ | :-) | call_method| 0.810% | +4.322% | +23.176% | +7.036% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.365% | +1.706% | +23.086% | +8.182% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.034% | +2.553% | +21.357% | +7.838% | +-----+------------------------+--------+------------+------------+------------+ | :-) | call_simple| 2.953% | +5.991% | +7.267% | +6.180% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.076% | -0.004% | +10.994% | +10.377% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.928% | +0.229% | +7.073% | +8.875% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.475% | -0.609% | +4.067% | +5.690% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.525% | +2.335% | +8.191% | +16.861% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.623% | -0.578% | +10.174% | +10.277% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.159% | +0.653% | +3.854% | +7.243% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.514% | +0.358% | +5.680% | +5.185% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.854% | +1.070% | +4.262% | +5.519% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.248% | +0.087% | +9.306% | +11.265% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.774% | +0.182% | +7.350% | +7.992% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 1.026% | +1.068% | +5.994% | +10.027% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.090% | +0.304% | +9.986% | +10.362% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.515% | -1.109% | +7.277% | +9.612% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.321% | +0.272% | +4.007% | +8.250% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.333% | -0.449% | +3.319% | +9.982% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.268% | +0.783% | +6.499% | +9.910% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.780% | +0.597% | +12.954% | +10.695% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.250% | +0.224% | +7.128% | +10.476% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.505% | +0.122% | +18.390% | +11.812% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.712% | -3.532% | +3.597% | +14.563% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.601% | -2.170% | +3.340% | +5.823% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.632% | -1.522% | -4.706% | +6.400% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.991% | +0.358% | +2.015% | +6.354% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.102% | -0.493% | +0.546% | +12.592% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.331% | +1.093% | +2.107% | +22.870% | +-----+------------------------+--------+------------+------------+------------+ | :-( | pickle_dict| 0.639% | -5.789% | +2.084% | +21.231% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.703% | -2.203% | +4.128% | +20.041% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.271% | +0.357% | +13.016% | +7.963% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.135% | -0.187% | +0.214% | +9.957% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.129% | +0.269% | +9.489% | +4.125% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.089% | +0.188% | +1.528% | +4.214% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 0.865% | +1.351% | +10.400% | +10.596% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.566% | -1.011% | -9.409% | +10.645% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.417% | +0.017% | -1.771% | +9.135% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.654% | -0.113% | -3.560% | +3.913% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.308% | +0.500% | +6.131% | +4.994% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.702% | +0.511% | +8.741% | +14.028% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 1.408% | +0.226% | +1.462% | +1.266% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 5.082% | +5.499% | +25.134% | +10.728% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 2.686% | -0.747% | +4.684% | +4.812% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.713% | -0.240% | +15.522% | +6.578% | +-----+------------------------+--------+------------+------------+------------+ | :-) | scimark_sparse_mat_mult| 1.285% | +3.058% | +2.257% | -3.699% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.640% | +0.315% | +6.234% | +1.738% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.087% | -1.769% | +4.536% | +5.586% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.058% | -1.021% | +4.481% | +2.871% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.411% | +2.073% | +2.735% | +7.312% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.241% | +0.582% | +12.790% | +6.719% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.519% | +0.346% | +11.008% | +4.581% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.936% | -0.608% | +11.567% | +8.130% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.520% | -0.558% | +12.812% | +8.105% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 2.536% | +2.680% | +25.119% | +6.997% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.198% | -0.138% | +5.911% | +4.257% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 2.243% | -0.605% | +1.018% | +0.919% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 6.584% | -0.193% | +8.982% | +20.580% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 2.034% | -2.820% | -3.827% | +19.584% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 0.974% | +0.487% | +8.732% | +5.746% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.036% | -1.040% | +4.930% | +8.856% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 1.804% | +2.694% | +3.899% | +5.339% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.850% | +2.405% | -5.026% | +11.491% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.380% | -0.157% | +6.333% | +8.537% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-down-3-up-61-flat-results-for-python-master-branch-2017-07-10 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Mon Jul 10 23:36:47 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 20:36:47 -0700 Subject: [Python-checkins] [python/cpython] 1180e5: bpo-30879: os.listdir() and os.scandir() now emit ... Message-ID: <596447cfeae7e_3f8e3fb29964fc2c70193@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 1180e5a51871fa53ca6892e83fd2e69dc2600447 https://github.com/python/cpython/commit/1180e5a51871fa53ca6892e83fd2e69dc2600447 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/test/test_os.py M Lib/test/test_posix.py M Misc/NEWS M Modules/posixmodule.c Log Message: ----------- bpo-30879: os.listdir() and os.scandir() now emit bytes names when (#2634) called with bytes-like argument. From noreply at github.com Mon Jul 10 23:55:26 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 20:55:26 -0700 Subject: [Python-checkins] [python/cpython] 64e461: bpo-22207: Add checks for possible integer overflo... Message-ID: <59644c2e83e61_76e33fedaea6dc2837993@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 64e461be09e23705ecbab43a8b01722186641f71 https://github.com/python/cpython/commit/64e461be09e23705ecbab43a8b01722186641f71 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Objects/unicodeobject.c Log Message: ----------- bpo-22207: Add checks for possible integer overflows in unicodeobject.c. (#2623) Based on patch by Victor Stinner. From noreply at github.com Tue Jul 11 00:16:12 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 21:16:12 -0700 Subject: [Python-checkins] [python/cpython] ecfe4f: [3.6] bpo-30879: os.listdir() and os.scandir() now... Message-ID: <5964510c768c3_20a613ffd06a97c3c5052e@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: ecfe4f678bfb0e3c19c90fd7db79c5f3c76023e4 https://github.com/python/cpython/commit/ecfe4f678bfb0e3c19c90fd7db79c5f3c76023e4 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/test/test_os.py M Lib/test/test_posix.py M Misc/NEWS M Modules/posixmodule.c Log Message: ----------- [3.6] bpo-30879: os.listdir() and os.scandir() now emit bytes names when (GH-2634) (#2656) called with bytes-like argument.. (cherry picked from commit 1180e5a51871fa53ca6892e83fd2e69dc2600447) From noreply at github.com Tue Jul 11 00:27:58 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 21:27:58 -0700 Subject: [Python-checkins] [python/cpython] 82a907: [3.6] bpo-22207: Add checks for possible integer o... Message-ID: <596453ce3777a_25343f98edba9c24525fd@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 82a907560011c7b784badccc78082cef70ea7128 https://github.com/python/cpython/commit/82a907560011c7b784badccc78082cef70ea7128 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Objects/unicodeobject.c Log Message: ----------- [3.6] bpo-22207: Add checks for possible integer overflows in unicodeobject.c. (GH-2623) (#2658) Based on patch by Victor Stinner. (cherry picked from commit 64e461b) From noreply at github.com Tue Jul 11 00:43:15 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 21:43:15 -0700 Subject: [Python-checkins] [python/cpython] 7527c3: [3.5] bpo-30879: os.listdir() and os.scandir() now... Message-ID: <5964576389e6b_1ca63fe3252c1c381021a@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 7527c32f5fedc3260d767900f1014495c0a1b7a5 https://github.com/python/cpython/commit/7527c32f5fedc3260d767900f1014495c0a1b7a5 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/test/test_os.py M Lib/test/test_posix.py M Misc/NEWS M Modules/posixmodule.c Log Message: ----------- [3.5] bpo-30879: os.listdir() and os.scandir() now emit bytes names when (GH-2634) (#2657) called with bytes-like argument. (cherry picked from commit 1180e5a51871fa53ca6892e83fd2e69dc2600447) From noreply at github.com Tue Jul 11 00:43:37 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 21:43:37 -0700 Subject: [Python-checkins] [python/cpython] 44eb51: [3.5] bpo-22207: Add checks for possible integer o... Message-ID: <596457799bc51_468c3fd24ce4bc3c77521@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 44eb51e6fcf45f3c2bf21c16e18c4da48a23d2d3 https://github.com/python/cpython/commit/44eb51e6fcf45f3c2bf21c16e18c4da48a23d2d3 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Objects/unicodeobject.c Log Message: ----------- [3.5] bpo-22207: Add checks for possible integer overflows in unicodeobject.c. (GH-2623) (#2659) Based on patch by Victor Stinner. (cherry picked from commit 64e461be09e23705ecbab43a8b01722186641f71) From noreply at github.com Tue Jul 11 01:58:06 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 22:58:06 -0700 Subject: [Python-checkins] [python/cpython] 5b62b3: bpo-30870: IDLE -- fix logic error in eae2537. (#2... Message-ID: <596468ee228ed_64f73ff8614edc2c16212@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 5b62b35e6fcba488da2f809965a5f349a4170b02 https://github.com/python/cpython/commit/5b62b35e6fcba488da2f809965a5f349a4170b02 Author: terryjreedy Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py Log Message: ----------- bpo-30870: IDLE -- fix logic error in eae2537. (#2660) From noreply at github.com Tue Jul 11 02:16:42 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 23:16:42 -0700 Subject: [Python-checkins] [python/cpython] 953e52: [3.6] bpo-30870: IDLE -- fix logic error in eae253... Message-ID: <59646d4aa0ef6_70693f8f4c20fc2c7932c@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 953e527763f5af293668135acdf5f0a20c3f6f4f https://github.com/python/cpython/commit/953e527763f5af293668135acdf5f0a20c3f6f4f Author: terryjreedy Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py Log Message: ----------- [3.6] bpo-30870: IDLE -- fix logic error in eae2537. (GH-2660) (#2661) (cherry picked from commit 5b62b35) From noreply at github.com Tue Jul 11 02:34:02 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 23:34:02 -0700 Subject: [Python-checkins] [python/cpython] ba3522: bpo-30881: IDLE: add docstrings to browser.py (#26... Message-ID: <5964715a80737_64ad3fbc259bfc3c48087@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: ba352270b724d67fc938c335c605acdee7474308 https://github.com/python/cpython/commit/ba352270b724d67fc938c335c605acdee7474308 Author: csabella Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/browser.py A Misc/NEWS.d/next/IDLE/2017-07-11-02-21-42.bpo-30881.4KAq_9.rst Log Message: ----------- bpo-30881: IDLE: add docstrings to browser.py (#2638) Patch by Cheryl Sabella. From noreply at github.com Tue Jul 11 02:53:33 2017 From: noreply at github.com (GitHub) Date: Mon, 10 Jul 2017 23:53:33 -0700 Subject: [Python-checkins] [python/cpython] 675c1a: [3.6] bpo-30881: IDLE: add docstrings to browser.p... Message-ID: <596475eda2dba_791d3f8b4efa5c442008c@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 675c1adfe5c87573e81fb295ccad7b6cfa03a3ee https://github.com/python/cpython/commit/675c1adfe5c87573e81fb295ccad7b6cfa03a3ee Author: terryjreedy Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/browser.py A Misc/NEWS.d/next/IDLE/2017-07-11-02-21-42.bpo-30881.4KAq_9.rst Log Message: ----------- [3.6] bpo-30881: IDLE: add docstrings to browser.py (GH-2638) (#2663) Patch by Cheryl Sabella. (cherry picked from commit ba35227) From solipsis at pitrou.net Tue Jul 11 05:07:30 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Tue, 11 Jul 2017 09:07:30 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=-5 Message-ID: <20170711090730.59198.3391B404E92F0FC3@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 0, -7] memory blocks, sum=-7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [-1, 1, -2] memory blocks, sum=-2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogrd3BC_', '--timeout', '7200'] From noreply at github.com Tue Jul 11 06:24:12 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 03:24:12 -0700 Subject: [Python-checkins] [python/cpython] fe82c4: [security][3.4] bpo-30730: Prevent environment var... Message-ID: <5964a74c21142_43f13fd2b9b45c3c25569@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.4 Home: https://github.com/python/cpython Commit: fe82c46327effc124ff166e1fa1e611579e1176b https://github.com/python/cpython/commit/fe82c46327effc124ff166e1fa1e611579e1176b Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/subprocess.py M Lib/test/test_subprocess.py M Misc/NEWS M Modules/_winapi.c M Objects/abstract.c Log Message: ----------- [security][3.4] bpo-30730: Prevent environment variables injection in subprocess on Windows. (GH-2325) (#2362) * [3.4] bpo-30730: Prevent environment variables injection in subprocess on Windows. (GH-2325) Prevent passing other invalid environment variables and command arguments.. (cherry picked from commit d174d24a5d37d1516b885dc7c82f71ecd5930700) * Update NEWS From noreply at github.com Tue Jul 11 09:30:23 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 06:30:23 -0700 Subject: [Python-checkins] [python/cpython] f73447: [3.4] [3.5] bpo-27945: Fixed various segfaults wit... Message-ID: <5964d2ef23cf8_46553f8fd2dcbc38100437@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.4 Home: https://github.com/python/cpython Commit: f7344798e57da6b9c4ed9372e8eaecde80989c86 https://github.com/python/cpython/commit/f7344798e57da6b9c4ed9372e8eaecde80989c86 Author: Serhiy Storchaka Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/test/test_dict.py M Misc/ACKS M Misc/NEWS M Objects/dictobject.c Log Message: ----------- [3.4] [3.5] bpo-27945: Fixed various segfaults with dict. (GH-1657) (GH-1678) (#2248) Based on patches by Duane Griffin and Tim Mitchell. (cherry picked from commit 753bca3934a7618a4fa96e107ad1c5c18633a683). (cherry picked from commit 2f7f533cf6fb57fcedcbc7bd454ac59fbaf2c655) From noreply at github.com Tue Jul 11 15:47:05 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 12:47:05 -0700 Subject: [Python-checkins] [python/cpython] f52325: Avoid _GNU_SOURCE redefined warning in xmlparse.c ... Message-ID: <59652b3963ce6_6d263faef5d43c383926b@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: f52325598e7a9683787d76a42009fc16790a0089 https://github.com/python/cpython/commit/f52325598e7a9683787d76a42009fc16790a0089 Author: Segev Finer Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- Avoid _GNU_SOURCE redefined warning in xmlparse.c (#2670) From noreply at github.com Tue Jul 11 18:16:29 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 15:16:29 -0700 Subject: [Python-checkins] [python/cpython] 884c4c: [2.7] bpo-30797: Avoid _GNU_SOURCE redefined warni... Message-ID: <59654e3dea0c7_184e3fa7a7befc385094b@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 884c4ca33ab84b9fc57338cf59f79e0436d3da43 https://github.com/python/cpython/commit/884c4ca33ab84b9fc57338cf59f79e0436d3da43 Author: Segev Finer Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- [2.7] bpo-30797: Avoid _GNU_SOURCE redefined warning in xmlparse.c (GH-2670) (#2672) * [2.7] Avoid _GNU_SOURCE redefined warning in xmlparse.c (GH-2670) (cherry picked from commit f52325598e7a9683787d76a42009fc16790a0089) * [2.7] Avoid _GNU_SOURCE redefined warning in xmlparse.c (GH-2670). (cherry picked from commit f52325598e7a9683787d76a42009fc16790a0089) From noreply at github.com Tue Jul 11 18:16:32 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 15:16:32 -0700 Subject: [Python-checkins] [python/cpython] 31d8c0: [3.5] Avoid _GNU_SOURCE redefined warning in xmlpa... Message-ID: <59654e40eb5d2_75dc3fda96ee9c3c9201e@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 31d8c0da60f07f5eea430ce2f471a67c3d60f394 https://github.com/python/cpython/commit/31d8c0da60f07f5eea430ce2f471a67c3d60f394 Author: Segev Finer Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- [3.5] Avoid _GNU_SOURCE redefined warning in xmlparse.c (GH-2670) (#2671) (cherry picked from commit f52325598e7a9683787d76a42009fc16790a0089) From noreply at github.com Tue Jul 11 19:09:45 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 16:09:45 -0700 Subject: [Python-checkins] [python/cpython] 6d13b2: bpo-30779: IDLE: fix changes.delete_section calls ... Message-ID: <59655ab9d51a8_69cf3fac3dde3c34886c9@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 6d13b22e3ab262c6b1f068259aebd705e7da316c https://github.com/python/cpython/commit/6d13b22e3ab262c6b1f068259aebd705e7da316c Author: csabella Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_config.py Log Message: ----------- bpo-30779: IDLE: fix changes.delete_section calls in configdialog (#2667) Also improve test of config.ConfigChanges.delete_section. Original patch by Cheryl Sabella. From lp_benchmark_robot at intel.com Tue Jul 11 19:45:51 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Tue, 11 Jul 2017 16:45:51 -0700 Subject: [Python-checkins] [1 up, 64 flat] Results for Python (master branch) 2017-07-11 Message-ID: <8a9fd496-086c-41da-b74a-7014da692b1d@orsmsx156.amr.corp.intel.com> Results for project python/master, build date: 2017-07-11 03:03:30-07:00. - commit: ba35227 - previous commit: 7e60192 - revision date: 2017-07-11 02:34:01-04:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.052% | +0.642% | +4.611% | +6.998% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 2.302% | -0.831% | +22.538% | +13.165% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.670% | -0.220% | +22.916% | +13.543% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.637% | +0.104% | +21.439% | +12.633% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.431% | -1.240% | +6.117% | +11.315% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.321% | -0.731% | +10.344% | +11.855% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.964% | -0.029% | +7.046% | +9.451% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.444% | -0.212% | +3.863% | +5.335% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.873% | +1.030% | +9.137% | +17.380% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 2.539% | +0.582% | +10.696% | +10.938% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.110% | +0.216% | +4.061% | +6.025% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.464% | -0.235% | +5.458% | +4.531% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.628% | +0.326% | +4.575% | +4.828% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.416% | +0.622% | +9.870% | +10.655% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 3.034% | -0.873% | +6.542% | +8.634% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.933% | +0.592% | +6.551% | +10.500% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.468% | +0.811% | +10.716% | +9.753% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.419% | +1.444% | +8.616% | +8.103% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 0.758% | +0.337% | +4.331% | +8.854% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.736% | +1.428% | +4.700% | +7.550% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.592% | +0.645% | +7.102% | +8.972% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.488% | +0.522% | +13.408% | +11.305% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.720% | +0.845% | +7.913% | +10.222% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.627% | -0.451% | +18.022% | +12.181% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.142% | -0.021% | +3.576% | +14.863% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.060% | +0.485% | +3.809% | +5.355% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.260% | +0.013% | -4.692% | +6.437% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.595% | +0.629% | +2.631% | +6.081% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.282% | +0.432% | +0.975% | +11.366% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.144% | -0.144% | +1.966% | +23.193% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.447% | +1.735% | +3.783% | +21.119% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.780% | +0.204% | +4.323% | +20.209% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 4.373% | -0.415% | +12.655% | +9.359% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.369% | -0.212% | +0.002% | +9.562% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.131% | +0.246% | +9.712% | +4.019% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.089% | -0.049% | +1.480% | +4.163% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.072% | +0.221% | +10.598% | +10.340% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.076% | +3.091% | -6.028% | +7.699% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.264% | +0.024% | -1.747% | +9.897% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.032% | -0.990% | -4.585% | +9.280% | +-----+------------------------+--------+------------+------------+------------+ | :-) | regex_v8| 1.613% | +4.819% | +10.655% | +5.568% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.706% | +0.431% | +9.135% | +13.794% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.660% | +0.100% | +1.560% | +0.972% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.487% | +1.377% | +26.165% | +8.589% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.887% | +1.178% | +5.807% | +3.484% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.957% | -0.395% | +15.189% | +6.021% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.425% | -0.340% | +1.925% | -3.955% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.964% | -0.292% | +5.960% | -0.337% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.100% | +0.464% | +4.979% | +6.042% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 2.709% | +0.433% | +4.895% | +3.646% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.345% | -1.238% | +1.531% | +10.339% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.263% | -0.151% | +12.659% | +7.227% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.857% | -0.519% | +10.546% | +5.465% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.754% | +0.639% | +12.132% | +7.870% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 5.152% | -0.654% | +12.243% | +9.573% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 3.593% | -2.045% | +23.588% | +10.405% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.244% | +0.323% | +6.215% | +4.988% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.133% | +0.765% | +1.775% | +0.654% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 4.564% | +2.541% | +11.295% | +18.528% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.406% | +1.268% | -2.511% | +19.272% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.535% | -0.189% | +8.560% | +6.177% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.796% | +0.939% | +5.823% | +8.531% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.270% | -1.176% | +2.769% | +5.446% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.759% | -0.497% | -5.549% | +12.092% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.230% | +0.045% | +6.375% | +8.673% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-up-64-flat-results-for-python-master-branch-2017-07-11 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Tue Jul 11 19:50:12 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 16:50:12 -0700 Subject: [Python-checkins] [python/cpython] c01794: [3.6] bpo-30779: IDLE: fix changes.delete_section ... Message-ID: <59656434176d3_64bb3fb89f5d3c383146a@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: c0179483f13be81910ed73889dcad92528e20ef2 https://github.com/python/cpython/commit/c0179483f13be81910ed73889dcad92528e20ef2 Author: terryjreedy Date: 2017-07-11 (Tue, 11 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_config.py Log Message: ----------- [3.6] bpo-30779: IDLE: fix changes.delete_section calls in configdialog (GH-2667) (#2674) Also improve test of config.ConfigChanges.delete_section. Original patch by Cheryl Sabella. (cherry picked from commit 6d13b22) From noreply at github.com Tue Jul 11 23:24:38 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 20:24:38 -0700 Subject: [Python-checkins] [python/cpython] b24def: Update traceback.rst Message-ID: <5965967662f27_36573fa1baacfc24232bf@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/zhangyangyu-traceback-doc Home: https://github.com/python/cpython Commit: b24deffe3a8ff620538a5bdbc827cc7eca581bba https://github.com/python/cpython/commit/b24deffe3a8ff620538a5bdbc827cc7eca581bba Author: Xiang Zhang Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Doc/library/traceback.rst Log Message: ----------- Update traceback.rst From noreply at github.com Tue Jul 11 23:41:35 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 20:41:35 -0700 Subject: [Python-checkins] [python/cpython] a948d4: Add a missing asterisk in traceback doc to complet... Message-ID: <59659a6f272d3_44373fe677001c3c4939f@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: a948d4f7531beb9e29ac77aaf4311353679e4949 https://github.com/python/cpython/commit/a948d4f7531beb9e29ac77aaf4311353679e4949 Author: Xiang Zhang Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Doc/library/traceback.rst Log Message: ----------- Add a missing asterisk in traceback doc to complete formatting (#2675) From noreply at github.com Tue Jul 11 23:41:37 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 20:41:37 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <59659a7146bed_6bca3f8fbf23dc3046779@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/zhangyangyu-traceback-doc Home: https://github.com/python/cpython From noreply at github.com Tue Jul 11 23:50:04 2017 From: noreply at github.com (GitHub) Date: Tue, 11 Jul 2017 20:50:04 -0700 Subject: [Python-checkins] [python/cpython] 8a9cd2: bpo-30876: Relative import from unloaded package n... Message-ID: <59659c6c7d823_211b53ff09db5dc2c379be@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 8a9cd20edca7d01b68292036029ae3735ce65edd https://github.com/python/cpython/commit/8a9cd20edca7d01b68292036029ae3735ce65edd Author: Serhiy Storchaka Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Lib/test/test_import/__init__.py A Lib/test/test_import/data/package2/submodule1.py A Lib/test/test_import/data/package2/submodule2.py M Lib/test/test_importlib/import_/test___package__.py A Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst M Python/import.c M Python/importlib.h Log Message: ----------- bpo-30876: Relative import from unloaded package now reimports the package (#2639) instead of failing with SystemError. Relative import from non-package now fails with ImportError rather than SystemError. From solipsis at pitrou.net Wed Jul 12 05:08:24 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Wed, 12 Jul 2017 09:08:24 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=0 Message-ID: <20170712090823.23305.0429875DAA3662A9@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [-7, 1, 0] memory blocks, sum=-6 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [2, 0, 0] memory blocks, sum=2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogxHX3ul', '--timeout', '7200'] From noreply at github.com Wed Jul 12 08:41:35 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 05:41:35 -0700 Subject: [Python-checkins] [python/cpython] 71572b: [3.4] bpo-29591, bpo-30694: Upgrade Modules/expat ... Message-ID: <596618ffb73dd_72ee3f8334ad3c38117725@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.4 Home: https://github.com/python/cpython Commit: 71572bbe82aa0836c036d44d41c8269ba6a321be https://github.com/python/cpython/commit/71572bbe82aa0836c036d44d41c8269ba6a321be Author: Victor Stinner Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: A Misc/NEWS.d/next/Security/2017-07-11-22-25-24.bpo-30694.oOf3Er.rst A Misc/NEWS.d/next/Security/2017-07-11-22-26-48.bpo-29591.cOeMX-.rst M Modules/expat/COPYING R Modules/expat/amigaconfig.h M Modules/expat/expat.h M Modules/expat/expat_external.h M Modules/expat/internal.h R Modules/expat/macconfig.h A Modules/expat/siphash.h R Modules/expat/watcomconfig.h M Modules/expat/winconfig.h M Modules/expat/xmlparse.c M Modules/expat/xmlrole.c M Modules/expat/xmltok.c M Modules/expat/xmltok.h M Modules/expat/xmltok_impl.c M Modules/pyexpat.c M PCbuild/_elementtree.vcxproj Log Message: ----------- [3.4] bpo-29591, bpo-30694: Upgrade Modules/expat to libexpat 2.2.1 (#2164) (#2203) * bpo-29591: Upgrade Modules/expat to libexpat 2.2 (#2164) * bpo-29591: Upgrade Modules/expat to libexpat 2.2 * bpo-29591: Restore Python changes on expat * bpo-29591: Remove expat config of unsupported platforms Remove the configuration (Modules/expat/*config.h) of unsupported platforms: * Amiga * MacOS Classic on PPC32 * Open Watcom * bpo-29591: Remove useless XML_HAS_SET_HASH_SALT The XML_HAS_SET_HASH_SALT define of Modules/expat/expat.h became useless since our local expat copy was upgrade to expat 2.1 (it's now expat 2.2.0). (cherry picked from commit 23ec4b57e1359f9c539b8defc317542173ae087e) * bpo-30694: Upgrade Modules/expat/ to libexpat 2.2.1 (#2300) New file: Modules/expat/siphash.h. (cherry picked from commit 5ff7132313eb651107b179d20218dfe5d4e47f13) * bpo-30726: PCbuild _elementtree: remove duplicate defines (#2348) bpo-30726, bpo-29591: libexpat 2.2.1 of Modules/expat/ now uses a winconfig.h configuration file which already defines: * XML_NS * XML_DTD * BYTEORDER=1234 * XML_CONTEXT_BYTES=1024 * HAVE_MEMMOVE Remove these defines from PCbuild/_elementtree.vcxproj to prevent compiler warnings. Co-Authored-By: Jeremy Kloth (cherry picked from commit c8fb58bd7917151e63398587a7fc2126db7c26de) * bpo-30726: Fix elementtree warnings on Windows due to expat upgrade (#2319) * bpo-30726: Fix elementtree warnings on Windows Caused by usage of `getenv` which should be safe. And a few integer truncations which should also be ok. * bpo-30726: Don't ignore libexpat warnings which haypo intends to fix upstream (cherry picked from commit 87c65550730a8f85ce339ba197bce4fb7e836619) From noreply at github.com Wed Jul 12 08:51:47 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 05:51:47 -0700 Subject: [Python-checkins] [python/cpython] cc54c1: bpo-30500: urllib: Simplify splithost by calling i... Message-ID: <59661b6389be7_6fc73feb3b23fc3894913@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.4 Home: https://github.com/python/cpython Commit: cc54c1c0d2d05fe7404ba64c53df4b1352ed2262 https://github.com/python/cpython/commit/cc54c1c0d2d05fe7404ba64c53df4b1352ed2262 Author: Victor Stinner Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/test/test_urlparse.py M Lib/urllib/parse.py M Misc/ACKS A Misc/NEWS.d/next/Security/2017-07-11-22-02-51.bpo-30500.wXUrkQ.rst Log Message: ----------- bpo-30500: urllib: Simplify splithost by calling into urlparse. (#1849) (#2291) The current regex based splitting produces a wrong result. For example:: http://abc#@def Web browsers parse that URL as ``http://abc/#@def``, that is, the host is ``abc``, the path is ``/``, and the fragment is ``#@def``. (cherry picked from commit 90e01e50ef8a9e6c91f30d965563c378a4ad26de) From noreply at github.com Wed Jul 12 08:52:06 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 05:52:06 -0700 Subject: [Python-checkins] [python/cpython] 6f6bc1: bpo-26657: Fix Windows directory traversal vulnera... Message-ID: <59661b766f7a0_1c113fb793bcdc2c88857@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.4 Home: https://github.com/python/cpython Commit: 6f6bc1da8aaae52664e7747e328d26eb59c0e74f https://github.com/python/cpython/commit/6f6bc1da8aaae52664e7747e328d26eb59c0e74f Author: Victor Stinner Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/http/server.py M Lib/test/test_httpservers.py A Misc/NEWS.d/next/Security/2017-07-11-22-07-03.bpo-26657.wvpzFD.rst Log Message: ----------- bpo-26657: Fix Windows directory traversal vulnerability with http.server (#782) Based on patch by Philipp Hagemeister. This fixes a regression caused by revision f4377699fd47. (cherry picked from commit d274b3f1f1e2d8811733fb952c9f18d7da3a376a) From noreply at github.com Wed Jul 12 10:05:44 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 07:05:44 -0700 Subject: [Python-checkins] [python/cpython] d1cc03: bpo-30908: Fix dangling thread in test_os.TestSend... Message-ID: <59662cb8a0e45_50c23fa5d404bc308578c@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: d1cc037d1442cc35d1b194ec8e50901514360949 https://github.com/python/cpython/commit/d1cc037d1442cc35d1b194ec8e50901514360949 Author: Victor Stinner Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/test/test_os.py Log Message: ----------- bpo-30908: Fix dangling thread in test_os.TestSendfile (#2680) tearDown() now clears explicitly the self.server variable to make sure that the thread is completely cleared when tearDownClass() checks if all threads have been cleaned up. Fix the following warning: $ ./python -m test --fail-env-changed -m test.test_os.TestSendfile.test_keywords -R 3:1 test_os (...) Warning -- threading_cleanup() failed to cleanup 0 threads after 3 sec (count: 0, dangling: 2) (...) Tests result: ENV CHANGED From noreply at github.com Wed Jul 12 13:02:31 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 10:02:31 -0700 Subject: [Python-checkins] [python/cpython] 0ffd6c: Fix a spelling mistake and tweak tense of output Message-ID: <5966562762ed5_44af3fea01413c341266cc@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/bisect-wording-tweaks Home: https://github.com/python/cpython Commit: 0ffd6caf9092d81d40d89b5aea8b00ebf770b576 https://github.com/python/cpython/commit/0ffd6caf9092d81d40d89b5aea8b00ebf770b576 Author: Brett Cannon Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/test/bisect.py Log Message: ----------- Fix a spelling mistake and tweak tense of output Changed "subbset" to "subset". Also made the sentences read like things were happening instead of stating what the code should do (IOW more descriptive than prescriptive). From noreply at github.com Wed Jul 12 14:05:34 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 11:05:34 -0700 Subject: [Python-checkins] [python/cpython] 50c943: bpo-30899: Add unittests, 100% coverage, for IDLE'... Message-ID: <596664ee53872_46283fd7e4e4dc3889129@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 50c9435c9b73b39fcf79cc3e58edc58bb943d0ed https://github.com/python/cpython/commit/50c9435c9b73b39fcf79cc3e58edc58bb943d0ed Author: Louie Lu Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/idle_test/test_config.py M Lib/test/cfgparser.1 A Misc/NEWS.d/next/IDLE/2017-07-11-02-26-17.bpo-30899.SQmVO8.rst Log Message: ----------- bpo-30899: Add unittests, 100% coverage, for IDLE's two ConfigParser subclasses. (#2662) Patch by Louie Lu. From noreply at github.com Wed Jul 12 14:42:41 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 11:42:41 -0700 Subject: [Python-checkins] [python/cpython] a9bf62: [3.6] bpo-30899: Add unittests, 100% coverage, for... Message-ID: <59666da199a55_46553f8fd2dcbc3813189f@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: a9bf62cadf6ccd55b84a8d4f353529b02a537830 https://github.com/python/cpython/commit/a9bf62cadf6ccd55b84a8d4f353529b02a537830 Author: terryjreedy Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/idle_test/test_config.py M Lib/test/cfgparser.1 A Misc/NEWS.d/next/IDLE/2017-07-11-02-26-17.bpo-30899.SQmVO8.rst Log Message: ----------- [3.6] bpo-30899: Add unittests, 100% coverage, for IDLE's two ConfigParser subclasses. (GH-2662) (#2685) Patch by Louie Lu. (cherry picked from commit 50c9435) From noreply at github.com Wed Jul 12 15:04:26 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 12:04:26 -0700 Subject: [Python-checkins] [python/cpython] ab025e: Fix a spelling mistake and tweak tense of output f... Message-ID: <596672ba85f44_43f43fb29959bc2c114362@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: ab025e31abbf9fdb37599dab94507ec429dc3b30 https://github.com/python/cpython/commit/ab025e31abbf9fdb37599dab94507ec429dc3b30 Author: Brett Cannon Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Lib/test/bisect.py Log Message: ----------- Fix a spelling mistake and tweak tense of output for test.bisect (GH-2683) Changed "subbset" to "subset". Also made the sentences read like things were happening instead of stating what the code should do (in other words more descriptive than prescriptive). From noreply at github.com Wed Jul 12 15:04:28 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 12:04:28 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <596672bc4d06d_746c3f9b9a6c1c34645cc@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/bisect-wording-tweaks Home: https://github.com/python/cpython From lp_benchmark_robot at intel.com Wed Jul 12 20:11:23 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Wed, 12 Jul 2017 17:11:23 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-12 Message-ID: Results for project python/master, build date: 2017-07-12 03:03:30-07:00. - commit: 8a9cd20 - previous commit: ba35227 - revision date: 2017-07-12 06:50:03+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.089% | -0.460% | +4.172% | +7.252% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.171% | +0.259% | +22.738% | +11.525% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 2.410% | -0.634% | +22.427% | +11.823% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.716% | -0.100% | +21.360% | +9.306% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.203% | +0.501% | +6.588% | +11.427% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.904% | +1.149% | +11.374% | +10.354% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.343% | -0.179% | +6.880% | +9.060% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 1.154% | -0.284% | +3.590% | +5.830% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.787% | -0.625% | +8.569% | +15.714% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.427% | +0.055% | +10.745% | +11.342% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.298% | -0.064% | +4.000% | +6.920% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.542% | -0.013% | +5.446% | +3.995% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.758% | -0.054% | +4.524% | +4.457% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.252% | -0.463% | +9.452% | +10.240% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.179% | -0.255% | +6.304% | +9.729% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 1.013% | -0.277% | +6.291% | +9.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.806% | -0.320% | +10.430% | +9.507% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.668% | -0.528% | +8.134% | +8.480% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 2.251% | -0.991% | +3.382% | +9.958% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.895% | +0.283% | +4.969% | +5.072% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.524% | +0.639% | +7.696% | +9.596% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.921% | -1.063% | +12.488% | +9.889% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.419% | -0.228% | +7.702% | +11.598% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.781% | +0.404% | +18.353% | +11.969% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.175% | +0.810% | +4.357% | +13.741% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.988% | -0.379% | +3.445% | +4.483% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.558% | -0.060% | -4.755% | +5.114% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.931% | -0.434% | +2.208% | +7.381% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.333% | +0.501% | +1.472% | +13.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 0.809% | +0.839% | +2.788% | +21.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.207% | +0.128% | +3.906% | +17.357% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.839% | -0.332% | +4.006% | +19.082% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 6.207% | -1.335% | +11.489% | +10.337% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.175% | +0.086% | +0.088% | +10.411% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.118% | -0.015% | +9.699% | +4.269% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.089% | +0.117% | +1.595% | +4.494% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 0.764% | -0.238% | +10.385% | +10.127% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.316% | -2.600% | -8.785% | +11.291% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.797% | -0.549% | -2.305% | +11.378% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.101% | -0.369% | -4.971% | +9.889% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.802% | +1.082% | +11.621% | +3.751% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 2.051% | -0.779% | +8.427% | +12.744% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 1.028% | -0.016% | +1.544% | +2.077% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.806% | +0.496% | +26.532% | +9.160% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.897% | +0.009% | +5.815% | +3.349% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.453% | +0.565% | +15.668% | +5.371% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 8.028% | -1.043% | +0.902% | -1.661% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.821% | +0.010% | +5.969% | +1.673% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.137% | -0.160% | +4.827% | +6.389% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.352% | -0.776% | +4.156% | +4.429% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.546% | +0.758% | +2.278% | +9.511% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.104% | -0.377% | +12.330% | +6.933% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.676% | +0.109% | +10.643% | +5.188% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.880% | -0.125% | +12.022% | +7.897% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.993% | -0.819% | +11.524% | +10.131% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.514% | -0.795% | +22.980% | +10.046% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.070% | +0.030% | +6.243% | +5.536% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.009% | +0.229% | +2.001% | +0.139% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 5.932% | -1.474% | +9.988% | +18.600% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 2.479% | -1.193% | -3.734% | +20.488% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.262% | -0.148% | +8.425% | +5.893% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.353% | -0.138% | +5.693% | +8.301% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.397% | +0.334% | +3.093% | +4.805% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.328% | +0.282% | -5.251% | +9.742% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.265% | +0.229% | +6.590% | +8.325% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-12 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Wed Jul 12 22:30:39 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 19:30:39 -0700 Subject: [Python-checkins] [python/cpython] 3fbd70: bpo-30466: Add brief explanation of classes to tut... Message-ID: <5966db4fef036_1ed43fcffedbbc2c94485@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 3fbd70018f835edd33250de2f79b7a7ef45f8359 https://github.com/python/cpython/commit/3fbd70018f835edd33250de2f79b7a7ef45f8359 Author: Trey Hunner Date: 2017-07-12 (Wed, 12 Jul 2017) Changed paths: M Doc/tutorial/classes.rst Log Message: ----------- bpo-30466: Add brief explanation of classes to tutorial (GH-1804) From noreply at github.com Thu Jul 13 01:52:10 2017 From: noreply at github.com (GitHub) Date: Wed, 12 Jul 2017 22:52:10 -0700 Subject: [Python-checkins] [python/cpython] 541bd2: bpo-30911: Fix a crash in json on platforms with u... Message-ID: <59670a8a13e2a_7ad43f8deadbbc2889976@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 541bd28941af407f2329e6a540d6367e5625b115 https://github.com/python/cpython/commit/541bd28941af407f2329e6a540d6367e5625b115 Author: Segev Finer Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Modules/_json.c Log Message: ----------- bpo-30911: Fix a crash in json on platforms with unsigned char (#2684) when pass bad strict argument. From noreply at github.com Thu Jul 13 03:14:13 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 00:14:13 -0700 Subject: [Python-checkins] [python/cpython] d3aaa2: bpo-30911: Add tests for bad boolean arguments for... Message-ID: <59671dc528652_6f223fabfdb9dc30666f0@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: d3aaa2f1496aae0809c9ec9623fa528d3a2c16c2 https://github.com/python/cpython/commit/d3aaa2f1496aae0809c9ec9623fa528d3a2c16c2 Author: Serhiy Storchaka Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py Log Message: ----------- bpo-30911: Add tests for bad boolean arguments for accelerated json (#2690) encoder and decoder. From noreply at github.com Thu Jul 13 04:40:27 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 01:40:27 -0700 Subject: [Python-checkins] [python/cpython] 7d0a99: [3.6] bpo-30911: Add tests for bad boolean argumen... Message-ID: <596731fb480c5_46d23fb378defc2c6609c@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 7d0a99582050ccac2e7126484d23072be342f317 https://github.com/python/cpython/commit/7d0a99582050ccac2e7126484d23072be342f317 Author: Serhiy Storchaka Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py Log Message: ----------- [3.6] bpo-30911: Add tests for bad boolean arguments for accelerated json (GH-2690) (#2692) encoder and decoder. (cherry picked from commit d3aaa2f) From noreply at github.com Thu Jul 13 04:57:33 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 01:57:33 -0700 Subject: [Python-checkins] [python/cpython] 2ec2c5: [3.5] bpo-30911: Add tests for bad boolean argumen... Message-ID: <596735fdb8613_1ca63fe3252c1c38498b1@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 2ec2c5f0b05efdcb7919c477591f1cb48bfb0aa9 https://github.com/python/cpython/commit/2ec2c5f0b05efdcb7919c477591f1cb48bfb0aa9 Author: Serhiy Storchaka Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py Log Message: ----------- [3.5] bpo-30911: Add tests for bad boolean arguments for accelerated json (GH-2690) (#2693) encoder and decoder. (cherry picked from commit d3aaa2f) From noreply at github.com Thu Jul 13 05:03:19 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 02:03:19 -0700 Subject: [Python-checkins] [python/cpython] b6dae2: [2.7] bpo-30911: Add tests for bad boolean argumen... Message-ID: <59673757cd94e_34e33fbde6101c2c837da@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: b6dae2e40d14436d77d3f0bfe6a5b4ae73c83c6e https://github.com/python/cpython/commit/b6dae2e40d14436d77d3f0bfe6a5b4ae73c83c6e Author: Serhiy Storchaka Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/json/tests/test_speedups.py Log Message: ----------- [2.7] bpo-30911: Add tests for bad boolean arguments for accelerated json (GH-2690) (#2694) encoder and decoder.. (cherry picked from commit d3aaa2f1496aae0809c9ec9623fa528d3a2c16c2) From solipsis at pitrou.net Thu Jul 13 05:08:02 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Thu, 13 Jul 2017 09:08:02 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=3 Message-ID: <20170713090749.110020.B2FBE550E7D6F15E@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [-1, -1, 2] memory blocks, sum=0 test_multiprocessing_spawn leaked [0, -2, 1] memory blocks, sum=-1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogtGCd4e', '--timeout', '7200'] From noreply at github.com Thu Jul 13 14:54:22 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 11:54:22 -0700 Subject: [Python-checkins] [python/cpython] 72b543: bpo-30923: Suppress fall-through warnings in libmp... Message-ID: <5967c1de18caf_38fe3fef441d5c2c668e6@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 72b543308ee3087e3fa247981f5cb4be1138c515 https://github.com/python/cpython/commit/72b543308ee3087e3fa247981f5cb4be1138c515 Author: Stefan Krah Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M setup.py Log Message: ----------- bpo-30923: Suppress fall-through warnings in libmpdec. (#2698) From noreply at github.com Thu Jul 13 15:34:44 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 12:34:44 -0700 Subject: [Python-checkins] [python/cpython] c40ad0: bpo-30731: python.manifest fix (#2328) Message-ID: <5967cb5422965_23d83fd4a0857c30399c@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: c40ad03bf2693b4af539978f1274e57b85367547 https://github.com/python/cpython/commit/c40ad03bf2693b4af539978f1274e57b85367547 Author: Segev Finer Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: A Misc/NEWS.d/next/Windows/2017-07-13-11-22-53.bpo-30731.nmMDwI.rst M PC/python.manifest Log Message: ----------- bpo-30731: python.manifest fix (#2328) bpo-30731: python.manifest fix From noreply at github.com Thu Jul 13 15:51:51 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 12:51:51 -0700 Subject: [Python-checkins] [python/cpython] d8e522: bpo-30731: python.manifest fix (#2328) (#2699) Message-ID: <5967cf5765ebd_4c373f8e9bf1fc3475b8@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: d8e522f7cf8d59993acae9409b6af0ee9a35038f https://github.com/python/cpython/commit/d8e522f7cf8d59993acae9409b6af0ee9a35038f Author: Steve Dower Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: A Misc/NEWS.d/next/Windows/2017-07-13-11-22-53.bpo-30731.nmMDwI.rst M PC/python.manifest Log Message: ----------- bpo-30731: python.manifest fix (#2328) (#2699) bpo-30731: python.manifest fix From lp_benchmark_robot at intel.com Thu Jul 13 19:55:10 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Thu, 13 Jul 2017 16:55:10 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-13 Message-ID: <556ca3fd-cfdd-4d39-9e56-1bcfa760d8a3@orsmsx109.amr.corp.intel.com> Results for project python/master, build date: 2017-07-13 03:03:29-07:00. - commit: d3aaa2f - previous commit: 8a9cd20 - revision date: 2017-07-13 10:14:11+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.130% | -0.070% | +4.105% | +7.641% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.683% | -0.401% | +22.429% | +11.186% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 2.063% | +0.038% | +22.457% | +11.124% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.848% | -0.107% | +21.276% | +10.522% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.054% | +0.504% | +7.059% | +11.764% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.239% | -0.725% | +10.732% | +10.299% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.106% | +0.315% | +7.173% | +9.516% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.492% | +0.140% | +3.725% | +5.428% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 4.075% | +0.386% | +8.922% | +16.078% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.662% | -0.461% | +10.334% | +10.139% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 0.898% | +0.358% | +4.344% | +7.086% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.609% | +0.068% | +5.510% | +4.809% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.767% | +0.234% | +4.747% | +5.343% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.001% | -0.135% | +9.330% | +10.828% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.378% | +0.474% | +6.748% | +9.964% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.797% | +0.396% | +6.662% | +10.139% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.922% | -0.012% | +10.420% | +10.513% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.559% | -0.034% | +8.103% | +8.645% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.925% | +0.290% | +3.663% | +8.129% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.065% | +0.330% | +5.283% | +7.632% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.648% | -0.753% | +7.001% | +9.312% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.027% | +1.020% | +13.381% | +11.738% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.409% | -0.756% | +7.005% | +12.518% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.587% | -0.021% | +18.336% | +12.189% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.809% | -2.389% | +2.071% | +15.911% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.858% | +0.520% | +3.947% | +5.943% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.680% | -0.079% | -4.838% | +8.492% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.703% | +0.395% | +2.595% | +7.128% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.082% | +0.849% | +2.308% | +11.534% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.331% | -0.539% | +2.265% | +20.745% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.370% | -0.028% | +3.879% | +16.527% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.665% | -0.142% | +3.870% | +18.093% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 6.766% | -0.361% | +11.169% | +9.423% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.249% | -0.028% | +0.061% | +10.436% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.119% | +0.141% | +9.826% | +4.285% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.088% | +0.049% | +1.644% | +4.183% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.364% | +0.006% | +10.390% | +10.728% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.106% | +0.776% | -7.940% | +11.459% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 1.146% | -0.072% | -2.378% | +11.554% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.065% | +0.658% | -4.280% | +8.488% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 2.037% | -0.403% | +11.265% | +3.744% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.799% | +0.479% | +8.866% | +13.152% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.460% | +0.163% | +1.704% | +2.168% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.098% | -0.369% | +26.260% | +8.789% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.368% | -0.299% | +5.534% | +5.058% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.556% | -0.044% | +15.631% | +7.933% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.663% | +1.068% | +1.961% | +0.327% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.608% | +0.117% | +6.079% | +2.962% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.145% | +0.270% | +5.085% | +6.080% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.148% | +0.509% | +4.644% | +3.877% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.043% | -0.739% | +1.556% | +9.174% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.061% | +0.412% | +12.691% | +7.085% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.616% | +0.176% | +10.800% | +5.732% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.897% | +0.412% | +12.384% | +8.229% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.507% | +1.280% | +12.657% | +10.176% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.111% | +0.224% | +23.153% | +10.114% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.052% | -0.116% | +6.134% | +5.282% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.957% | +0.115% | +2.114% | -1.488% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 6.711% | -0.123% | +9.877% | +20.045% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.851% | +0.843% | -2.859% | +19.181% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.528% | +0.227% | +8.632% | +6.175% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.064% | -0.079% | +5.618% | +8.766% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.110% | -0.170% | +2.928% | +5.612% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.608% | +0.546% | -4.676% | +9.747% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.228% | +0.009% | +6.598% | +8.352% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-13 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Thu Jul 13 20:35:49 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 17:35:49 -0700 Subject: [Python-checkins] [python/cpython] 9b622f: bpo-30870: IDLE: Add configdialog fontlist selecti... Message-ID: <596811e5cd258_19bc3f90cea47c2c102426@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 9b622fb90331f259894e6edb29b5c64b9366491a https://github.com/python/cpython/commit/9b622fb90331f259894e6edb29b5c64b9366491a Author: Louie Lu Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/mock_idle.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- bpo-30870: IDLE: Add configdialog fontlist selection unittest (#2666) Initial patch by Louie Lu. From noreply at github.com Thu Jul 13 22:24:57 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 19:24:57 -0700 Subject: [Python-checkins] [python/cpython] 42abf7: [3.6] bpo-30870: IDLE: Add configdialog fontlist s... Message-ID: <59682b795fd4c_2fbd3fbe9ade3c3829488@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 42abf7f9737f78a5da311a42945d781dfcd6c6c0 https://github.com/python/cpython/commit/42abf7f9737f78a5da311a42945d781dfcd6c6c0 Author: terryjreedy Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/mock_idle.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- [3.6] bpo-30870: IDLE: Add configdialog fontlist selection unittest (GH-2666) (#2701) Initial patch by Louie Lu. (cherry picked from commit 9b622fb) From noreply at github.com Thu Jul 13 23:32:02 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 20:32:02 -0700 Subject: [Python-checkins] [python/cpython] 36329a: bpo-30913: IDLE: Document tk vars, attributes, and... Message-ID: <59683b32db5e8_79f83f803cbe5c342277@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 36329a4dd85c03e2060a306e86ac5ddec6fd2549 https://github.com/python/cpython/commit/36329a4dd85c03e2060a306e86ac5ddec6fd2549 Author: csabella Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-13-23-07-33.bpo-30913.aezn_e.rst Log Message: ----------- bpo-30913: IDLE: Document tk vars, attributes, and methods for ConfigDialog (#2697) The will help writing dialog improvements and splitting the class into multiple classes. Original patch by Cheryl Sabella. From noreply at github.com Thu Jul 13 23:53:31 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 20:53:31 -0700 Subject: [Python-checkins] [python/cpython] 9a09c6: [3.6] bpo-30913: IDLE: Document tk vars, attribute... Message-ID: <5968403b79355_19e53fd8d6d27c30380cf@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 9a09c667cf133e722a3e7ed2185f3e9e5af25a99 https://github.com/python/cpython/commit/9a09c667cf133e722a3e7ed2185f3e9e5af25a99 Author: terryjreedy Date: 2017-07-13 (Thu, 13 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-13-23-07-33.bpo-30913.aezn_e.rst Log Message: ----------- [3.6] bpo-30913: IDLE: Document tk vars, attributes, and methods for ConfigDialog (GH-2697) (#2702) The will help writing dialog improvements and splitting the class into multiple classes. Original patch by Cheryl Sabella. (cherry picked from commit 36329a4) From noreply at github.com Fri Jul 14 00:14:11 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 21:14:11 -0700 Subject: [Python-checkins] [python/cpython] 0d0a32: Update idlelib/NEWS.txt. (#2703) Message-ID: <596845138faa9_1ffc3fd924fd7c3425820@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 0d0a32fb91cdfea1626e6c6b77a9bc44e15a2b8a https://github.com/python/cpython/commit/0d0a32fb91cdfea1626e6c6b77a9bc44e15a2b8a Author: terryjreedy Date: 2017-07-14 (Fri, 14 Jul 2017) Changed paths: M Lib/idlelib/NEWS.txt Log Message: ----------- Update idlelib/NEWS.txt. (#2703) From noreply at github.com Fri Jul 14 00:29:07 2017 From: noreply at github.com (GitHub) Date: Thu, 13 Jul 2017 21:29:07 -0700 Subject: [Python-checkins] [python/cpython] 1aafd9: [3.6] Update idlelib/NEWS.txt. (GH-2703) (#2704) Message-ID: <596848936bed0_2fb93f8bccb77c34112fc@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 1aafd9c8bd10b44f62d05428e0e99ed50b5f5d39 https://github.com/python/cpython/commit/1aafd9c8bd10b44f62d05428e0e99ed50b5f5d39 Author: terryjreedy Date: 2017-07-14 (Fri, 14 Jul 2017) Changed paths: M Lib/idlelib/NEWS.txt Log Message: ----------- [3.6] Update idlelib/NEWS.txt. (GH-2703) (#2704) (cherry picked from commit 0d0a32f) From solipsis at pitrou.net Fri Jul 14 05:08:20 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Fri, 14 Jul 2017 09:08:20 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170714090820.7564.C7870B757EE951C8@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [-1, -1, 2] memory blocks, sum=0 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflog3LTt26', '--timeout', '7200'] From noreply at github.com Fri Jul 14 10:46:01 2017 From: noreply at github.com (GitHub) Date: Fri, 14 Jul 2017 07:46:01 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <5968d9296c47e_7e5d3f9483281c3c541e6@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/selectors-bare-except-3.6 Home: https://github.com/python/cpython From noreply at github.com Fri Jul 14 15:23:41 2017 From: noreply at github.com (GitHub) Date: Fri, 14 Jul 2017 12:23:41 -0700 Subject: [Python-checkins] [python/cpython] be37be: Doc that 'sorted' args are keyword-only, fix 'reve... Message-ID: <59691a3d378cc_39263fc02e019c3447e8@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: be37beb05f5f2cff18e41440453e79aa17b239f9 https://github.com/python/cpython/commit/be37beb05f5f2cff18e41440453e79aa17b239f9 Author: ?ukasz Rogalski Date: 2017-07-14 (Fri, 14 Jul 2017) Changed paths: M Doc/library/functions.rst M Doc/library/stdtypes.rst Log Message: ----------- Doc that 'sorted' args are keyword-only, fix 'reverse' default (#2706) From noreply at github.com Fri Jul 14 15:57:20 2017 From: noreply at github.com (GitHub) Date: Fri, 14 Jul 2017 12:57:20 -0700 Subject: [Python-checkins] [python/cpython] ea9cbe: Doc that 'sorted' args are keyword-only, fix 'reve... Message-ID: <59692220a4177_34493fc3c1779c406859a@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: ea9cbe0a5cc4d35643939c6ddee7fc96dbfff211 https://github.com/python/cpython/commit/ea9cbe0a5cc4d35643939c6ddee7fc96dbfff211 Author: ?ukasz Rogalski Date: 2017-07-14 (Fri, 14 Jul 2017) Changed paths: M Doc/library/functions.rst M Doc/library/stdtypes.rst Log Message: ----------- Doc that 'sorted' args are keyword-only, fix 'reverse' default (#2709) backport From lp_benchmark_robot at intel.com Fri Jul 14 17:37:44 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Fri, 14 Jul 2017 14:37:44 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-14 Message-ID: <8c69ddbc-214a-4679-8c53-f90c70faefbd@orsmsx110.amr.corp.intel.com> Results for project python/master, build date: 2017-07-14 03:03:34-07:00. - commit: 0d0a32f - previous commit: d3aaa2f - revision date: 2017-07-14 00:14:10-04:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.117% | +0.077% | +4.179% | +8.152% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.088% | +0.231% | +22.608% | +12.575% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.906% | +0.603% | +22.924% | +12.200% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.158% | -0.409% | +20.954% | +11.906% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.293% | -1.044% | +6.088% | +12.839% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.520% | +0.951% | +11.581% | +8.591% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.748% | +0.217% | +7.375% | +9.194% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.840% | -0.026% | +3.700% | +5.958% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.802% | +0.192% | +9.098% | +16.824% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.263% | -0.133% | +10.214% | +12.255% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.483% | -0.391% | +3.970% | +6.368% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.551% | +0.039% | +5.547% | +4.501% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.664% | -0.077% | +4.674% | +4.347% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.046% | +0.065% | +9.389% | +11.043% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.996% | +0.327% | +7.053% | +9.913% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.923% | -0.054% | +6.612% | +10.505% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.676% | -0.173% | +10.264% | +10.063% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.743% | -0.344% | +7.787% | +9.399% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.405% | +0.128% | +3.786% | +9.693% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 2.632% | -0.425% | +4.881% | +8.263% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.244% | +0.687% | +7.640% | +10.063% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.301% | -0.311% | +13.112% | +12.016% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.760% | +0.556% | +7.522% | +11.947% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.513% | +0.172% | +18.477% | +12.048% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 7.705% | +1.839% | +3.873% | +15.494% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.307% | -0.350% | +3.611% | +6.425% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.854% | -0.052% | -4.892% | +4.040% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.355% | -0.229% | +2.372% | +6.451% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.263% | -0.123% | +2.188% | +12.928% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.211% | +0.461% | +2.716% | +22.486% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.480% | -0.012% | +3.867% | +19.766% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.611% | +0.346% | +4.202% | +20.694% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 6.355% | +0.368% | +11.496% | +10.422% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.147% | +0.018% | +0.078% | +10.150% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.132% | +0.079% | +9.897% | +4.303% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.084% | +0.110% | +1.752% | +4.371% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.769% | -0.328% | +10.096% | +11.022% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.782% | -0.403% | -8.375% | +12.268% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.395% | +0.117% | -2.258% | +11.961% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.130% | +0.381% | -3.883% | +8.286% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.210% | +0.381% | +11.603% | +4.205% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.741% | -0.095% | +8.779% | +13.420% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.773% | -0.210% | +1.498% | +1.272% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.624% | +0.705% | +26.780% | +8.322% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.962% | +0.609% | +6.109% | +4.683% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.658% | +0.054% | +15.676% | +7.105% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.720% | +0.014% | +1.974% | -2.873% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.901% | -0.352% | +5.748% | +3.237% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.343% | -0.405% | +4.701% | +7.791% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.029% | -0.181% | +4.471% | +5.285% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.186% | +0.852% | +2.395% | +8.710% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.121% | -0.353% | +12.383% | +8.350% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.282% | +0.284% | +11.053% | +5.919% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.557% | -1.147% | +11.380% | +10.103% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.427% | -0.094% | +12.574% | +11.268% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.373% | +0.517% | +23.550% | +7.209% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.180% | -0.021% | +6.114% | +4.492% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.942% | +0.128% | +2.239% | -0.642% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.624% | -0.667% | +9.276% | +20.809% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.360% | -0.213% | -3.078% | +17.757% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 0.797% | +0.234% | +8.846% | +5.551% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.887% | +0.411% | +6.006% | +8.577% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.181% | -0.139% | +2.794% | +6.346% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.912% | -0.309% | -5.000% | +10.343% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.295% | -0.016% | +6.583% | +8.465% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-14 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Fri Jul 14 22:20:11 2017 From: noreply at github.com (GitHub) Date: Fri, 14 Jul 2017 19:20:11 -0700 Subject: [Python-checkins] [python/cpython] 286e1c: Null merge so github sees fork as synchronized wit... Message-ID: <59697bdb2cf2_784b3fcd17c9dc4439711@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 286e1c15ceb28a76d8ef4fe7111718317c9ccaf5 https://github.com/python/cpython/commit/286e1c15ceb28a76d8ef4fe7111718317c9ccaf5 Author: terryjreedy Date: 2017-07-14 (Fri, 14 Jul 2017) Log Message: ----------- Null merge so github sees fork as synchronized with python (#2710) From solipsis at pitrou.net Sat Jul 15 05:08:14 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sat, 15 Jul 2017 09:08:14 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=6 Message-ID: <20170715090814.128628.E48F3A253AD60529@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 0, 3] memory blocks, sum=3 test_collections leaked [7, -7, 1] memory blocks, sum=1 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [-2, 2, 0] memory blocks, sum=0 test_multiprocessing_forkserver leaked [-1, 1, -2] memory blocks, sum=-2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogTxV9TD', '--timeout', '7200'] From noreply at github.com Sat Jul 15 06:46:40 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 03:46:40 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <5969f2904238c_40223ff56358dc3c587e6@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/buildbot-custom Home: https://github.com/python/cpython From noreply at github.com Sat Jul 15 07:41:14 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 04:41:14 -0700 Subject: [Python-checkins] [python/cpython] 5f7d23: bpo-30836: fix test_c_locale_coercion on AIX Message-ID: <5969ff5a67605_28753fb67724fc3028354@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/buildbot-custom Home: https://github.com/python/cpython Commit: 5f7d23a325b521bfb41d27825f0ff1e83b3eb050 https://github.com/python/cpython/commit/5f7d23a325b521bfb41d27825f0ff1e83b3eb050 Author: Nick Coghlan Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Lib/test/test_c_locale_coercion.py Log Message: ----------- bpo-30836: fix test_c_locale_coercion on AIX AIX uses latin-1 in the C locale, not ASCII AIX doesn't currently provide any of the locale coercion locales, but we leave locale coercion enabled in case one gets added in the future. From noreply at github.com Sat Jul 15 08:12:30 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 05:12:30 -0700 Subject: [Python-checkins] [python/cpython] 21f043: Use correct locale name Message-ID: <596a06ae88a79_26333fa8015f1c3c107856@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/buildbot-custom Home: https://github.com/python/cpython Commit: 21f043ea6e33dc91c18baddf506da1e66619dc6f https://github.com/python/cpython/commit/21f043ea6e33dc91c18baddf506da1e66619dc6f Author: Nick Coghlan Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Lib/test/test_c_locale_coercion.py Log Message: ----------- Use correct locale name From noreply at github.com Sat Jul 15 08:51:07 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 05:51:07 -0700 Subject: [Python-checkins] [python/cpython] f0b6a2: bpo-30836: fix test_c_locale_coercion on AIX (GH-2... Message-ID: <596a0fbb43a47_139ed3fcf9ae53c345437@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: f0b6a261bb8cbede42296e0cc70956fb3b9a6cf7 https://github.com/python/cpython/commit/f0b6a261bb8cbede42296e0cc70956fb3b9a6cf7 Author: Nick Coghlan Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Lib/test/test_c_locale_coercion.py Log Message: ----------- bpo-30836: fix test_c_locale_coercion on AIX (GH-2713) AIX uses iso8859-1 in the C locale, not ASCII AIX doesn't currently provide any of the locale coercion locales, but we leave locale coercion enabled in case one gets added in the future. From noreply at github.com Sat Jul 15 08:53:53 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 05:53:53 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <596a1061425e3_7ed73fa451729c34699ea@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/buildbot-custom Home: https://github.com/python/cpython From noreply at github.com Sat Jul 15 15:28:03 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 12:28:03 -0700 Subject: [Python-checkins] [python/cpython] 50f581: bpo-30939: Avoid Sphinx deprecation warning in doc... Message-ID: <596a6cc35fc3f_20f3fb3c23dbc2865719@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 50f58163a69abe2f35e91044d1df165ee7bdbb42 https://github.com/python/cpython/commit/50f58163a69abe2f35e91044d1df165ee7bdbb42 Author: Ned Deily Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Doc/tools/extensions/pyspecific.py Log Message: ----------- bpo-30939: Avoid Sphinx deprecation warning in docs build. (#2721) From noreply at github.com Sat Jul 15 16:56:15 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 13:56:15 -0700 Subject: [Python-checkins] [python/cpython] bbd0f4: bpo-30939: Avoid Sphinx deprecation warning in doc... Message-ID: <596a816f1cd48_29913f9528671c34146c0@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: bbd0f423d2a19c6a4a9cda6914fc60b87e17250b https://github.com/python/cpython/commit/bbd0f423d2a19c6a4a9cda6914fc60b87e17250b Author: Ned Deily Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Doc/tools/extensions/pyspecific.py Log Message: ----------- bpo-30939: Avoid Sphinx deprecation warning in docs build. (#2721) (#2722) (cherry picked from commit 50f58163a69abe2f35e91044d1df165ee7bdbb42) From noreply at github.com Sat Jul 15 17:01:57 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 14:01:57 -0700 Subject: [Python-checkins] [python/cpython] ada3f3: bpo-30939: Avoid Sphinx deprecation warning in doc... Message-ID: <596a82c59ca42_46d03f8b0aab7c448777f@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: ada3f31365d0634d0cd8eeacfacd98291e34a8cc https://github.com/python/cpython/commit/ada3f31365d0634d0cd8eeacfacd98291e34a8cc Author: Ned Deily Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Doc/tools/extensions/pyspecific.py Log Message: ----------- bpo-30939: Avoid Sphinx deprecation warning in docs build. (#2721) (#2723) (cherry picked from commit 50f58163a69abe2f35e91044d1df165ee7bdbb42) From noreply at github.com Sat Jul 15 23:06:58 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 20:06:58 -0700 Subject: [Python-checkins] [python/cpython] 64a9f3: bpo-30939: Avoid Sphinx deprecation warning in doc... Message-ID: <596ad852767a9_26333fa8015f1c3c1110ce@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 64a9f3d961084819335ea011063eb8cb41733882 https://github.com/python/cpython/commit/64a9f3d961084819335ea011063eb8cb41733882 Author: Ned Deily Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: M Doc/tools/extensions/pyspecific.py Log Message: ----------- bpo-30939: Avoid Sphinx deprecation warning in docs build. (#2721) (#2725) (cherry picked from commit 50f58163a69abe2f35e91044d1df165ee7bdbb42) From noreply at github.com Sun Jul 16 00:07:37 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:07:37 -0700 Subject: [Python-checkins] [python/cpython] 95bebb: bpo-30934: Document coverage details for idlelib t... Message-ID: <596ae689b4b55_3fff3fe615419c28826cd@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 95bebb7264afad88f31f7cdc3b28bacde7c46f93 https://github.com/python/cpython/commit/95bebb7264afad88f31f7cdc3b28bacde7c46f93 Author: terryjreedy Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/idlelib/idle_test/README.txt A Misc/NEWS.d/next/IDLE/2017-07-15-22-26-57.bpo-30934.BanuSB.rst Log Message: ----------- bpo-30934: Document coverage details for idlelib tests (#2711) * Add section to idlelib/idle-test/README.txt. * Include check that branches are taken both ways. * Exclude IDLE-specific code that does not run during unit tests. From noreply at github.com Sun Jul 16 00:29:18 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:29:18 -0700 Subject: [Python-checkins] [python/cpython] 49f644: bpo-30936: Fix a reference leak in json when fail ... Message-ID: <596aeb9e34a70_2acd3fbc39c05c306257b@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 49f6449ef4b81537c19b82329caaf60596c516c2 https://github.com/python/cpython/commit/49f6449ef4b81537c19b82329caaf60596c516c2 Author: Serhiy Storchaka Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py M Modules/_json.c Log Message: ----------- bpo-30936: Fix a reference leak in json when fail to sort keys. (#2712) From noreply at github.com Sun Jul 16 00:40:01 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:40:01 -0700 Subject: [Python-checkins] [python/cpython] 65de1f: [3.6] bpo-30934: Document coverage details for idl... Message-ID: <596aee2157290_22683fb51d397c387981d@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 65de1f3672fd0a1e3ec34b654ef5213e15a03e26 https://github.com/python/cpython/commit/65de1f3672fd0a1e3ec34b654ef5213e15a03e26 Author: terryjreedy Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/idlelib/idle_test/README.txt A Misc/NEWS.d/next/IDLE/2017-07-15-22-26-57.bpo-30934.BanuSB.rst Log Message: ----------- [3.6] bpo-30934: Document coverage details for idlelib tests (GH-2711) (#2726) * Add section to idlelib/idle-test/README.txt. * Include check that branches are taken both ways. * Exclude IDLE-specific code that does not run during unit tests. (cherry picked from commit 95bebb7) From noreply at github.com Sun Jul 16 00:44:26 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:44:26 -0700 Subject: [Python-checkins] [python/cpython] 28343e: [3.6] bpo-30876: Relative import from unloaded pac... Message-ID: <596aef2a7674a_2dcb3ff721445c34101424@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 28343e3392ca7b1ec7151f68d4d92c90efb91e50 https://github.com/python/cpython/commit/28343e3392ca7b1ec7151f68d4d92c90efb91e50 Author: Serhiy Storchaka Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Lib/test/test_import/__init__.py A Lib/test/test_import/data/package2/submodule1.py A Lib/test/test_import/data/package2/submodule2.py M Lib/test/test_importlib/import_/test___package__.py A Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst M Python/import.c M Python/importlib.h Log Message: ----------- [3.6] bpo-30876: Relative import from unloaded package now reimports the package (GH-2639) (#2676) instead of failing with SystemError. Relative import from non-package now fails with ImportError rather than SystemError. (cherry picked from commit 8a9cd20edca7d01b68292036029ae3735ce65edd) From noreply at github.com Sun Jul 16 00:48:10 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:48:10 -0700 Subject: [Python-checkins] [python/cpython] a819e5: [3.6] bpo-30936: Fix a reference leak in json when... Message-ID: <596af00a9359_75e43fef4b467c2c762d6@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: a819e5e1e66a1a5f9a7073c8a1ff3c3f304c917b https://github.com/python/cpython/commit/a819e5e1e66a1a5f9a7073c8a1ff3c3f304c917b Author: Serhiy Storchaka Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py M Modules/_json.c Log Message: ----------- [3.6] bpo-30936: Fix a reference leak in json when fail to sort keys. (GH-2712). (#2727) (cherry picked from commit 49f6449ef4b81537c19b82329caaf60596c516c2) From noreply at github.com Sun Jul 16 00:50:38 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:50:38 -0700 Subject: [Python-checkins] [python/cpython] 45c471: [3.5] bpo-30936: Fix a reference leak in json when... Message-ID: <596af09ec8645_409b3fd211f73c30851f7@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 45c471c04553d7e4cb5c328ea1ab02d6716f2bab https://github.com/python/cpython/commit/45c471c04553d7e4cb5c328ea1ab02d6716f2bab Author: Serhiy Storchaka Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/test/test_json/test_speedups.py M Modules/_json.c Log Message: ----------- [3.5] bpo-30936: Fix a reference leak in json when fail to sort keys. (GH-2712). (#2728) (cherry picked from commit 49f6449ef4b81537c19b82329caaf60596c516c2) From noreply at github.com Sun Jul 16 00:51:04 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 21:51:04 -0700 Subject: [Python-checkins] [python/cpython] 3dbe11: [2.7] bpo-30911: Add tests for bad boolean argumen... Message-ID: <596af0b8df6a6_2bcd3ff70acffc3823599@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 3dbe11a1219d148e4a133449a86ac5d157e35d35 https://github.com/python/cpython/commit/3dbe11a1219d148e4a133449a86ac5d157e35d35 Author: Serhiy Storchaka Date: 2017-07-16 (Sun, 16 Jul 2017) Log Message: ----------- [2.7] bpo-30911: Add tests for bad boolean arguments for accelerated json (GH-2690) (#2729) encoder and decoder. (cherry picked from commit d3aaa2f1496aae0809c9ec9623fa528d3a2c16c2) From noreply at github.com Sun Jul 16 01:51:58 2017 From: noreply at github.com (GitHub) Date: Sat, 15 Jul 2017 22:51:58 -0700 Subject: [Python-checkins] [python/cpython] 5cadde: Bump PY_VERSION to 3.3.6+ Message-ID: <596afefe65bf8_1e293fc1acae3c44336ba@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: 5caddeaab89840d498457ad0cc3f28f3f5cd87c1 https://github.com/python/cpython/commit/5caddeaab89840d498457ad0cc3f28f3f5cd87c1 Author: Ned Deily Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Include/patchlevel.h Log Message: ----------- Bump PY_VERSION to 3.3.6+ From noreply at github.com Sun Jul 16 03:34:46 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 00:34:46 -0700 Subject: [Python-checkins] [python/cpython] b0c089: Fix distutils test_upload failure Message-ID: <596b1716c46a8_2edc3fcda8b7fc2c843fc@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: b0c0898d66dacf59416a33d7531bcdbdabef4fee https://github.com/python/cpython/commit/b0c0898d66dacf59416a33d7531bcdbdabef4fee Author: Ned Deily Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/distutils/tests/test_upload.py Log Message: ----------- Fix distutils test_upload failure Commit: 8fb577e351040a18c1250bd1c4b2abc458725d5f https://github.com/python/cpython/commit/8fb577e351040a18c1250bd1c4b2abc458725d5f Author: Ned Deily Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Lib/site.py Log Message: ----------- Fix test_site test_license_exists_at_url Compare: https://github.com/python/cpython/compare/5caddeaab898...8fb577e35104 From noreply at github.com Sun Jul 16 03:58:13 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 00:58:13 -0700 Subject: [Python-checkins] [python/cpython] b52c00: bpo-23844: Fix test_dh_params failure Message-ID: <596b1c95903d6_4a8a3fea36be7c281063a2@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: b52c0075511f8330f57c81520ee0287241d3653f https://github.com/python/cpython/commit/b52c0075511f8330f57c81520ee0287241d3653f Author: Ned Deily Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: A Lib/test/dh1024.pem R Lib/test/dh512.pem M Lib/test/test_ssl.py Log Message: ----------- bpo-23844: Fix test_dh_params failure From noreply at github.com Sun Jul 16 04:48:06 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 01:48:06 -0700 Subject: [Python-checkins] [python/cpython] ab9098: [3.3] bpo-29591, bpo-30694: Upgrade Modules/expat ... Message-ID: <596b284658fca_427f3fa50dc67c3495173@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: ab90986600ba7dea2aa41e5c1773791070725453 https://github.com/python/cpython/commit/ab90986600ba7dea2aa41e5c1773791070725453 Author: Victor Stinner Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Misc/NEWS M Modules/expat/COPYING R Modules/expat/amigaconfig.h M Modules/expat/expat.h M Modules/expat/expat_external.h M Modules/expat/internal.h R Modules/expat/macconfig.h M Modules/expat/pyexpatns.h A Modules/expat/siphash.h R Modules/expat/watcomconfig.h M Modules/expat/winconfig.h M Modules/expat/xmlparse.c M Modules/expat/xmlrole.c M Modules/expat/xmltok.c M Modules/expat/xmltok.h M Modules/expat/xmltok_impl.c M PCbuild/_elementtree.vcxproj Log Message: ----------- [3.3] bpo-29591, bpo-30694: Upgrade Modules/expat to libexpat 2.2.1 (#2164) (#2204) * bpo-29591: Upgrade Modules/expat to libexpat 2.2 (#2164) * bpo-29591: Upgrade Modules/expat to libexpat 2.2 * bpo-29591: Restore Python changes on expat * bpo-29591: Remove expat config of unsupported platforms Remove the configuration (Modules/expat/*config.h) of unsupported platforms: * Amiga * MacOS Classic on PPC32 * Open Watcom * bpo-29591: Remove useless XML_HAS_SET_HASH_SALT The XML_HAS_SET_HASH_SALT define of Modules/expat/expat.h became useless since our local expat copy was upgrade to expat 2.1 (it's now expat 2.2.0). (cherry picked from commit 23ec4b57e1359f9c539b8defc317542173ae087e) * bpo-30694: Upgrade Modules/expat/ to libexpat 2.2.1 (#2300) New file: Modules/expat/siphash.h. (cherry picked from commit 5ff7132313eb651107b179d20218dfe5d4e47f13) * bpo-30726: PCbuild _elementtree: remove duplicate defines (#2348) bpo-30726, bpo-29591: libexpat 2.2.1 of Modules/expat/ now uses a winconfig.h configuration file which already defines: * XML_NS * XML_DTD * BYTEORDER=1234 * XML_CONTEXT_BYTES=1024 * HAVE_MEMMOVE Remove these defines from PCbuild/_elementtree.vcxproj to prevent compiler warnings. Co-Authored-By: Jeremy Kloth (cherry picked from commit c8fb58bd7917151e63398587a7fc2126db7c26de) * bpo-30726: Fix elementtree warnings on Windows due to expat upgrade (#2319) * bpo-30726: Fix elementtree warnings on Windows Caused by usage of `getenv` which should be safe. And a few integer truncations which should also be ok. * bpo-30726: Don't ignore libexpat warnings which haypo intends to fix upstream (cherry picked from commit 87c65550730a8f85ce339ba197bce4fb7e836619) From noreply at github.com Sun Jul 16 04:52:35 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 01:52:35 -0700 Subject: [Python-checkins] [python/cpython] 4956dd: Avoid _GNU_SOURCE redefined warning in xmlparse.c ... Message-ID: <596b29539263a_135283fdf13979c30939db@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: 4956dd2ec039d274ec7a63600175e1d5c624f5f3 https://github.com/python/cpython/commit/4956dd2ec039d274ec7a63600175e1d5c624f5f3 Author: Segev Finer Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Modules/expat/xmlparse.c Log Message: ----------- Avoid _GNU_SOURCE redefined warning in xmlparse.c (#2670) (cherry picked from commit f52325598e7a9683787d76a42009fc16790a0089) From solipsis at pitrou.net Sun Jul 16 05:07:18 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sun, 16 Jul 2017 09:07:18 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=11 Message-ID: <20170716090718.56334.17EEB0E9BBA29CBB@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 0, 7] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [1, 0, -2] memory blocks, sum=-1 test_multiprocessing_forkserver leaked [1, -2, 2] memory blocks, sum=1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogy_cUMP', '--timeout', '7200'] From noreply at github.com Sun Jul 16 09:52:56 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 06:52:56 -0700 Subject: [Python-checkins] [python/cpython] b5ae22: Perform 'blurb split' for master. Message-ID: <596b6fb881320_13d1d3fd88b6ebc408642f@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/blurb-split-master Home: https://github.com/python/cpython Commit: b5ae2202ebd40bc0f0e03dc71ee538f23f9d9442 https://github.com/python/cpython/commit/b5ae2202ebd40bc0f0e03dc71ee538f23f9d9442 Author: Larry Hastings Date: 2017-07-15 (Sat, 15 Jul 2017) Changed paths: R Misc/NEWS A Misc/NEWS.d/3.5.0.rst A Misc/NEWS.d/3.5.0a1.rst A Misc/NEWS.d/3.5.0a2.rst A Misc/NEWS.d/3.5.0a3.rst A Misc/NEWS.d/3.5.0a4.rst A Misc/NEWS.d/3.5.0b1.rst A Misc/NEWS.d/3.5.0b2.rst A Misc/NEWS.d/3.5.0b3.rst A Misc/NEWS.d/3.5.0b4.rst A Misc/NEWS.d/3.5.0rc1.rst A Misc/NEWS.d/3.5.0rc2.rst A Misc/NEWS.d/3.5.0rc3.rst A Misc/NEWS.d/3.5.0rc4.rst A Misc/NEWS.d/3.5.1.rst A Misc/NEWS.d/3.5.1rc1.rst A Misc/NEWS.d/3.5.2.rst A Misc/NEWS.d/3.5.2rc1.rst A Misc/NEWS.d/3.5.3.rst A Misc/NEWS.d/3.5.3rc1.rst A Misc/NEWS.d/3.6.0.rst A Misc/NEWS.d/3.6.0a1.rst A Misc/NEWS.d/3.6.0a2.rst A Misc/NEWS.d/3.6.0a3.rst A Misc/NEWS.d/3.6.0a4.rst A Misc/NEWS.d/3.6.0b1.rst A Misc/NEWS.d/3.6.0b2.rst A Misc/NEWS.d/3.6.0b3.rst A Misc/NEWS.d/3.6.0b4.rst A Misc/NEWS.d/3.6.0rc1.rst A Misc/NEWS.d/3.6.0rc2.rst A Misc/NEWS.d/3.6.1rc1.rst A Misc/NEWS.d/next/Build/0019.bpo-28676.Wxf6Ds.rst A Misc/NEWS.d/next/Build/0020.bpo-15819.QVDr3E.rst A Misc/NEWS.d/next/Build/0021.bpo-27979.fR0KgM.rst A Misc/NEWS.d/next/Build/0022.bpo-26661.Z_HNbs.rst A Misc/NEWS.d/next/Build/0023.bpo-28258.iKtAHd.rst A Misc/NEWS.d/next/Build/0024.bpo-21085.2VvyUF.rst A Misc/NEWS.d/next/Build/0025.bpo-13756.sslhpC.rst A Misc/NEWS.d/next/Build/0026.bpo-21124.1bbArU.rst A Misc/NEWS.d/next/Build/0027.bpo-28248.KY_-en.rst A Misc/NEWS.d/next/Build/0028.bpo-28208.DtoP1i.rst A Misc/NEWS.d/next/Build/0029.bpo-28444.zkc9nT.rst A Misc/NEWS.d/next/Build/0030.bpo-26359.CLz6qy.rst A Misc/NEWS.d/next/Build/0031.bpo-10656.pR8FFU.rst A Misc/NEWS.d/next/Build/0032.bpo-28849.AzRRF5.rst A Misc/NEWS.d/next/Build/0033.bpo-20211.gpNptI.rst A Misc/NEWS.d/next/Build/0034.bpo-28538.FqtN7v.rst A Misc/NEWS.d/next/Build/0035.bpo-28762.Ru0YN_.rst A Misc/NEWS.d/next/Build/0036.bpo-23903.JXJ889.rst A Misc/NEWS.d/next/Build/0037.bpo-29080.b3qLQT.rst A Misc/NEWS.d/next/Build/0038.bpo-28768.b9_a6E.rst A Misc/NEWS.d/next/Build/0039.bpo-26851.R5243g.rst A Misc/NEWS.d/next/Build/0040.bpo-29384.v3IqBE.rst A Misc/NEWS.d/next/Build/0041.bpo-27659.i8UzRC.rst A Misc/NEWS.d/next/Build/0042.bpo-29572.iZ1XKK.rst A Misc/NEWS.d/next/Build/0043.bpo-27593.v87xEr.rst A Misc/NEWS.d/next/Build/0044.bpo-29643.4WLIJQ.rst A Misc/NEWS.d/next/Build/0045.bpo-23404.PdYVWg.rst A Misc/NEWS.d/next/Build/0046.bpo-29243.WDK4hT.rst A Misc/NEWS.d/next/Build/0047.bpo-28787.vhH_6a.rst A Misc/NEWS.d/next/Build/0048.bpo-29941.ylh45A.rst A Misc/NEWS.d/next/Build/0049.bpo-20210.MN_n-r.rst A Misc/NEWS.d/next/Build/0050.bpo-30687.8mqHnu.rst A Misc/NEWS.d/next/C API/0061.bpo-28426.zPwvbI.rst A Misc/NEWS.d/next/C API/0062.bpo-19569.IPke0J.rst A Misc/NEWS.d/next/C API/0063.bpo-28748.AMgb_G.rst A Misc/NEWS.d/next/C API/0064.bpo-28761.iOgCoX.rst A Misc/NEWS.d/next/C API/0065.bpo-28808.A03X6r.rst A Misc/NEWS.d/next/C API/0066.bpo-28822.gMqwvb.rst A Misc/NEWS.d/next/C API/0067.bpo-29058.0wNVP8.rst A Misc/NEWS.d/next/C API/0068.bpo-28769.Ecmtn8.rst A Misc/NEWS.d/next/C API/0069.bpo-29083.tGTjr_.rst A Misc/NEWS.d/next/C API/0070.bpo-27867.J-8CGo.rst A Misc/NEWS.d/next/C API/0071.bpo-6532.qcH6k1.rst A Misc/NEWS.d/next/C API/0072.bpo-16500.lRpooa.rst A Misc/NEWS.d/next/C API/0073.bpo-30708.np-l1j.rst A Misc/NEWS.d/next/Core and Builtins/0352.bpo-26110.KRaID6.rst A Misc/NEWS.d/next/Core and Builtins/0353.bpo-28721.BO9BUF.rst A Misc/NEWS.d/next/Core and Builtins/0354.bpo-26182.a8JXK2.rst A Misc/NEWS.d/next/Core and Builtins/0355.bpo-26182.jYlqTO.rst A Misc/NEWS.d/next/Core and Builtins/0356.bpo-28120.e5xc1i.rst A Misc/NEWS.d/next/Core and Builtins/0357.bpo-28126.Qf6-uQ.rst A Misc/NEWS.d/next/Core and Builtins/0358.bpo-28131.owq0wW.rst A Misc/NEWS.d/next/Core and Builtins/0359.bpo-0.9EbOiD.rst A Misc/NEWS.d/next/Core and Builtins/0360.bpo-27222.74PvFk.rst A Misc/NEWS.d/next/Core and Builtins/0361.bpo-27441.scPKax.rst A Misc/NEWS.d/next/Core and Builtins/0362.bpo-28192.eR6stU.rst A Misc/NEWS.d/next/Core and Builtins/0363.bpo-27955.HC4pZ4.rst A Misc/NEWS.d/next/Core and Builtins/0364.bpo-28214.zQF8Em.rst A Misc/NEWS.d/next/Core and Builtins/0365.bpo-28086.JsQPMQ.rst A Misc/NEWS.d/next/Core and Builtins/0366.bpo-28203.LRn5vp.rst A Misc/NEWS.d/next/Core and Builtins/0367.bpo-21578.GI1bhj.rst A Misc/NEWS.d/next/Core and Builtins/0368.bpo-28289.l1kHlV.rst A Misc/NEWS.d/next/Core and Builtins/0369.bpo-27942.ZGuhns.rst A Misc/NEWS.d/next/Core and Builtins/0370.bpo-26617.Gh5LvN.rst A Misc/NEWS.d/next/Core and Builtins/0371.bpo-28350.8M5Eg9.rst A Misc/NEWS.d/next/Core and Builtins/0372.bpo-28201.GWUxAy.rst A Misc/NEWS.d/next/Core and Builtins/0373.bpo-24098.XqlP_1.rst A Misc/NEWS.d/next/Core and Builtins/0374.bpo-18287.k6jffS.rst A Misc/NEWS.d/next/Core and Builtins/0375.bpo-26906.YBjcwI.rst A Misc/NEWS.d/next/Core and Builtins/0376.bpo-28376.yTEhEo.rst A Misc/NEWS.d/next/Core and Builtins/0377.bpo-28376.oPD-5D.rst A Misc/NEWS.d/next/Core and Builtins/0378.bpo-28379.DuXlco.rst A Misc/NEWS.d/next/Core and Builtins/0379.bpo-26081._x5vjl.rst A Misc/NEWS.d/next/Core and Builtins/0380.bpo-28183.MJZeNd.rst A Misc/NEWS.d/next/Core and Builtins/0381.bpo-23782.lonDzj.rst A Misc/NEWS.d/next/Core and Builtins/0382.bpo-28214.6ECJox.rst A Misc/NEWS.d/next/Core and Builtins/0383.bpo-28517.ExPkm9.rst A Misc/NEWS.d/next/Core and Builtins/0384.bpo-28426.E_quyK.rst A Misc/NEWS.d/next/Core and Builtins/0385.bpo-28509._Fa4Uq.rst A Misc/NEWS.d/next/Core and Builtins/0386.bpo-28128.Lc2sFu.rst A Misc/NEWS.d/next/Core and Builtins/0387.bpo-28583.F-QAx1.rst A Misc/NEWS.d/next/Core and Builtins/0388.bpo-28580.8bqBmG.rst A Misc/NEWS.d/next/Core and Builtins/0389.bpo-28621.eCD7n-.rst A Misc/NEWS.d/next/Core and Builtins/0390.bpo-19398.RYbEGH.rst A Misc/NEWS.d/next/Core and Builtins/0391.bpo-28665.v4nx86.rst A Misc/NEWS.d/next/Core and Builtins/0392.bpo-28648.z7B52W.rst A Misc/NEWS.d/next/Core and Builtins/0393.bpo-26920.1URwGb.rst A Misc/NEWS.d/next/Core and Builtins/0394.bpo-28746.r5MXdB.rst A Misc/NEWS.d/next/Core and Builtins/0395.bpo-27100.poVjXq.rst A Misc/NEWS.d/next/Core and Builtins/0396.bpo-28532.KEYJny.rst A Misc/NEWS.d/next/Core and Builtins/0397.bpo-28731.oNF59u.rst A Misc/NEWS.d/next/Core and Builtins/0398.bpo-28774.cEehAr.rst A Misc/NEWS.d/next/Core and Builtins/0399.bpo-28782.foJV_E.rst A Misc/NEWS.d/next/Core and Builtins/0400.bpo-12844.pdr3gY.rst A Misc/NEWS.d/next/Core and Builtins/0401.bpo-28799.cP6V1N.rst A Misc/NEWS.d/next/Core and Builtins/0402.bpo-28797._A0_Z5.rst A Misc/NEWS.d/next/Core and Builtins/0403.bpo-23722.e8BH5h.rst A Misc/NEWS.d/next/Core and Builtins/0404.bpo-28918.SFVuPz.rst A Misc/NEWS.d/next/Core and Builtins/0405.bpo-28512.i-pv6d.rst A Misc/NEWS.d/next/Core and Builtins/0406.bpo-28739.w1fvhk.rst A Misc/NEWS.d/next/Core and Builtins/0407.bpo-28147.CnK_xf.rst A Misc/NEWS.d/next/Core and Builtins/0408.bpo-28991.lGA0FK.rst A Misc/NEWS.d/next/Core and Builtins/0409.bpo-26919.Cm7MSa.rst A Misc/NEWS.d/next/Core and Builtins/0410.bpo-22257.2a8zxB.rst A Misc/NEWS.d/next/Core and Builtins/0411.bpo-28596.snIJRd.rst A Misc/NEWS.d/next/Core and Builtins/0412.bpo-18896.Pqe0bg.rst A Misc/NEWS.d/next/Core and Builtins/0413.bpo-29000.K6wQ-3.rst A Misc/NEWS.d/next/Core and Builtins/0414.bpo-25677.RWhZrb.rst A Misc/NEWS.d/next/Core and Builtins/0415.bpo-28932.QnLx8A.rst A Misc/NEWS.d/next/Core and Builtins/0416.bpo-28927.9fxf6y.rst A Misc/NEWS.d/next/Core and Builtins/0417.bpo-29049.KpVXBw.rst A Misc/NEWS.d/next/Core and Builtins/0418.bpo-29159.gEn_kP.rst A Misc/NEWS.d/next/Core and Builtins/0419.bpo-29034.7-uEDT.rst A Misc/NEWS.d/next/Core and Builtins/0420.bpo-29327.XXQarW.rst A Misc/NEWS.d/next/Core and Builtins/0421.bpo-29337.bjX8AE.rst A Misc/NEWS.d/next/Core and Builtins/0422.bpo-29319.KLDUZf.rst A Misc/NEWS.d/next/Core and Builtins/0423.bpo-29478.rTQ-qy.rst A Misc/NEWS.d/next/Core and Builtins/0424.bpo-29546.O1rmG_.rst A Misc/NEWS.d/next/Core and Builtins/0425.bpo-29546.PS1I1T.rst A Misc/NEWS.d/next/Core and Builtins/0426.bpo-29438.IKxD6I.rst A Misc/NEWS.d/next/Core and Builtins/0427.bpo-29463.h2bg8A.rst A Misc/NEWS.d/next/Core and Builtins/0428.bpo-29347.1RPPGN.rst A Misc/NEWS.d/next/Core and Builtins/0429.bpo-29602.qyyskC.rst A Misc/NEWS.d/next/Core and Builtins/0430.bpo-29607.7NvBA1.rst A Misc/NEWS.d/next/Core and Builtins/0431.bpo-28598.QxbzQn.rst A Misc/NEWS.d/next/Core and Builtins/0432.bpo-29684.wTgEoh.rst A Misc/NEWS.d/next/Core and Builtins/0433.bpo-29683.G5iS-P.rst A Misc/NEWS.d/next/Core and Builtins/0434.bpo-28876.cU-sGT.rst A Misc/NEWS.d/next/Core and Builtins/0435.bpo-28893.WTKnpj.rst A Misc/NEWS.d/next/Core and Builtins/0436.bpo-29695.z75xXa.rst A Misc/NEWS.d/next/Core and Builtins/0437.bpo-29714.z-BhVd.rst A Misc/NEWS.d/next/Core and Builtins/0438.bpo-29568.3EtOC-.rst A Misc/NEWS.d/next/Core and Builtins/0439.bpo-29723.M5omgP.rst A Misc/NEWS.d/next/Core and Builtins/0440.bpo-28856.AFRmo4.rst A Misc/NEWS.d/next/Core and Builtins/0441.bpo-29849.hafvBD.rst A Misc/NEWS.d/next/Core and Builtins/0442.bpo-29859.Z1MLcA.rst A Misc/NEWS.d/next/Core and Builtins/0443.bpo-29894.Vev6t-.rst A Misc/NEWS.d/next/Core and Builtins/0444.bpo-29102.AW4YPj.rst A Misc/NEWS.d/next/Core and Builtins/0445.bpo-24821.4DINGV.rst A Misc/NEWS.d/next/Core and Builtins/0446.bpo-29816.0H75Nl.rst A Misc/NEWS.d/next/Core and Builtins/0447.bpo-29935.vgjdJo.rst A Misc/NEWS.d/next/Core and Builtins/0448.bpo-29949.DevGPS.rst A Misc/NEWS.d/next/Core and Builtins/0449.bpo-29914.nqFSRR.rst A Misc/NEWS.d/next/Core and Builtins/0450.bpo-11913.5uiMX9.rst A Misc/NEWS.d/next/Core and Builtins/0451.bpo-29839.rUmfay.rst A Misc/NEWS.d/next/Core and Builtins/0452.bpo-12414.T9ix8O.rst A Misc/NEWS.d/next/Core and Builtins/0453.bpo-30024.kSOlED.rst A Misc/NEWS.d/next/Core and Builtins/0454.bpo-28974.jVewS0.rst A Misc/NEWS.d/next/Core and Builtins/0455.bpo-30039.e0u4DG.rst A Misc/NEWS.d/next/Core and Builtins/0456.bpo-25794.xfPwqm.rst A Misc/NEWS.d/next/Core and Builtins/0457.bpo-27945.p29r3O.rst A Misc/NEWS.d/next/Core and Builtins/0458.bpo-29104.u26yCx.rst A Misc/NEWS.d/next/Core and Builtins/0459.bpo-25324.l12VjO.rst A Misc/NEWS.d/next/Core and Builtins/0460.bpo-30537.sGC27r.rst A Misc/NEWS.d/next/Core and Builtins/0461.bpo-30486.KZi3nB.rst A Misc/NEWS.d/next/Core and Builtins/0462.bpo-28180.f_IHor.rst A Misc/NEWS.d/next/Core and Builtins/0463.bpo-30501.BWJByG.rst A Misc/NEWS.d/next/Core and Builtins/0464.bpo-30682.zZm88E.rst A Misc/NEWS.d/next/Core and Builtins/0465.bpo-30597.7erHiP.rst A Misc/NEWS.d/next/Core and Builtins/0466.bpo-30604.zGPGoX.rst A Misc/NEWS.d/next/Core and Builtins/0467.bpo-30736.kA4J9v.rst A Misc/NEWS.d/next/Core and Builtins/0468.bpo-30814.HcYsfM.rst A Misc/NEWS.d/next/Documentation/0051.bpo-28513.L3joAz.rst A Misc/NEWS.d/next/Documentation/0052.bpo-23722.nFjY3C.rst A Misc/NEWS.d/next/Documentation/0053.bpo-29349.PjSo-t.rst A Misc/NEWS.d/next/Documentation/0054.bpo-26355.SDq_8Y.rst A Misc/NEWS.d/next/Documentation/0055.bpo-25008.CeIzyU.rst A Misc/NEWS.d/next/Documentation/0056.bpo-28929.Md7kb0.rst A Misc/NEWS.d/next/Documentation/0057.bpo-19824.We9an6.rst A Misc/NEWS.d/next/Documentation/0058.bpo-26985.NB5_9S.rst A Misc/NEWS.d/next/Documentation/0059.bpo-30052.TpmpaF.rst A Misc/NEWS.d/next/Documentation/0060.bpo-30176.VivmCg.rst A Misc/NEWS.d/next/IDLE/0089.bpo-28572.1_duKY.rst A Misc/NEWS.d/next/IDLE/0090.bpo-29071.FCOpJn.rst A Misc/NEWS.d/next/IDLE/0091.bpo-30303.2L2F-4.rst A Misc/NEWS.d/next/IDLE/0092.bpo-30290.fZ3kod.rst A Misc/NEWS.d/next/IDLE/0093.bpo-30495.I3i5vL.rst A Misc/NEWS.d/next/IDLE/0094.bpo-30642.3Zujzt.rst A Misc/NEWS.d/next/IDLE/0095.bpo-25514.882pXa.rst A Misc/NEWS.d/next/IDLE/0096.bpo-15786._XRbaR.rst A Misc/NEWS.d/next/Library/0097.bpo-30177.JGIJNL.rst A Misc/NEWS.d/next/Library/0098.bpo-25532.ey4Yez.rst A Misc/NEWS.d/next/Library/0099.bpo-29581.gHCrxP.rst A Misc/NEWS.d/next/Library/0100.bpo-24142.IrZnFs.rst A Misc/NEWS.d/next/Library/0101.bpo-27972.ZK-GFm.rst A Misc/NEWS.d/next/Library/0102.bpo-28399.QKIqRX.rst A Misc/NEWS.d/next/Library/0103.bpo-28372.njcIPk.rst A Misc/NEWS.d/next/Library/0104.bpo-28371.U9Zqdk.rst A Misc/NEWS.d/next/Library/0105.bpo-28370.18jBuZ.rst A Misc/NEWS.d/next/Library/0106.bpo-28369.8DTANe.rst A Misc/NEWS.d/next/Library/0107.bpo-28368.n594X4.rst A Misc/NEWS.d/next/Library/0108.bpo-28325.wAHmnK.rst A Misc/NEWS.d/next/Library/0109.bpo-27759.qpMDGq.rst A Misc/NEWS.d/next/Library/0110.bpo-28176.sU8R6L.rst A Misc/NEWS.d/next/Library/0111.bpo-26909.ASiakT.rst A Misc/NEWS.d/next/Library/0112.bpo-26654.XtzTE9.rst A Misc/NEWS.d/next/Library/0113.bpo-28174.CV1UdI.rst A Misc/NEWS.d/next/Library/0114.bpo-27906.TBBXrv.rst A Misc/NEWS.d/next/Library/0115.bpo-27599.itvm8T.rst A Misc/NEWS.d/next/Library/0116.bpo-28114.gmFXsA.rst A Misc/NEWS.d/next/Library/0117.bpo-25895.j92qoQ.rst A Misc/NEWS.d/next/Library/0118.bpo-28181.NGc4Yv.rst A Misc/NEWS.d/next/Library/0119.bpo-25270.jrZruM.rst A Misc/NEWS.d/next/Library/0120.bpo-22493.Mv_hZf.rst A Misc/NEWS.d/next/Library/0121.bpo-28075.aLiUs9.rst A Misc/NEWS.d/next/Library/0122.bpo-0.iPpjqX.rst A Misc/NEWS.d/next/Library/0123.bpo-27932.mtgl-6.rst A Misc/NEWS.d/next/Library/0124.bpo-25400.d9Qn0E.rst A Misc/NEWS.d/next/Library/0125.bpo-28200.4IEbr7.rst A Misc/NEWS.d/next/Library/0126.bpo-27778.Yyo1aP.rst A Misc/NEWS.d/next/Library/0127.bpo-25651.3UhyPo.rst A Misc/NEWS.d/next/Library/0128.bpo-27348.tDx7Vw.rst A Misc/NEWS.d/next/Library/0129.bpo-27611.A_ArH_.rst A Misc/NEWS.d/next/Library/0130.bpo-18893.osiX5c.rst A Misc/NEWS.d/next/Library/0131.bpo-18844.fQsEdn.rst A Misc/NEWS.d/next/Library/0132.bpo-27897.I0Ppmx.rst A Misc/NEWS.d/next/Library/0133.bpo-28275.EhWIsz.rst A Misc/NEWS.d/next/Library/0134.bpo-28253.aLfmhe.rst A Misc/NEWS.d/next/Library/0135.bpo-28148.Flzndx.rst A Misc/NEWS.d/next/Library/0136.bpo-28314.N7YrkN.rst A Misc/NEWS.d/next/Library/0137.bpo-28226.nMXiwU.rst A Misc/NEWS.d/next/Library/0138.bpo-28228.1qBwdM.rst A Misc/NEWS.d/next/Library/0139.bpo-28322.l9hzap.rst A Misc/NEWS.d/next/Library/0140.bpo-28257.SVD_IH.rst A Misc/NEWS.d/next/Library/0141.bpo-27358.t288Iv.rst A Misc/NEWS.d/next/Library/0142.bpo-28332.Ed8fNk.rst A Misc/NEWS.d/next/Library/0143.bpo-28227.7lUz8i.rst A Misc/NEWS.d/next/Library/0144.bpo-28225.6N28nu.rst A Misc/NEWS.d/next/Library/0145.bpo-28321.bQ-IIX.rst A Misc/NEWS.d/next/Library/0146.bpo-28229.BKAxcS.rst A Misc/NEWS.d/next/Library/0147.bpo-28380.jKPMzH.rst A Misc/NEWS.d/next/Library/0148.bpo-28317.LgHleA.rst A Misc/NEWS.d/next/Library/0149.bpo-27998.CPhy4H.rst A Misc/NEWS.d/next/Library/0150.bpo-20766.4kvCzx.rst A Misc/NEWS.d/next/Library/0151.bpo-24452.pVsjt0.rst A Misc/NEWS.d/next/Library/0152.bpo-0.5Y0ngw.rst A Misc/NEWS.d/next/Library/0153.bpo-28240.cXljq-.rst A Misc/NEWS.d/next/Library/0154.bpo-28240.IwQMgd.rst A Misc/NEWS.d/next/Library/0155.bpo-28240.hqzQvS.rst A Misc/NEWS.d/next/Library/0156.bpo-28480.9lHw6m.rst A Misc/NEWS.d/next/Library/0157.bpo-23214.-4Q5Z7.rst A Misc/NEWS.d/next/Library/0158.bpo-28448.5bduWe.rst A Misc/NEWS.d/next/Library/0159.bpo-18219.1ANQN1.rst A Misc/NEWS.d/next/Library/0160.bpo-28115.4FIjIE.rst A Misc/NEWS.d/next/Library/0161.bpo-28469.QZW1Np.rst A Misc/NEWS.d/next/Library/0162.bpo-25953.EKKJAQ.rst A Misc/NEWS.d/next/Library/0163.bpo-28488.TgO112.rst A Misc/NEWS.d/next/Library/0164.bpo-25464.HDUTCu.rst A Misc/NEWS.d/next/Library/0165.bpo-27025.foAViS.rst A Misc/NEWS.d/next/Library/0166.bpo-28430.4MiEYT.rst A Misc/NEWS.d/next/Library/0167.bpo-28353.sKGbLL.rst A Misc/NEWS.d/next/Library/0168.bpo-20491.ObgnQ2.rst A Misc/NEWS.d/next/Library/0169.bpo-28255.fHNZu0.rst A Misc/NEWS.d/next/Library/0170.bpo-28255.G3iOPm.rst A Misc/NEWS.d/next/Library/0171.bpo-27939.mTfADV.rst A Misc/NEWS.d/next/Library/0172.bpo-24241.y7N12p.rst A Misc/NEWS.d/next/Library/0173.bpo-23262.6EVB7N.rst A Misc/NEWS.d/next/Library/0174.bpo-28449.5JK6ES.rst A Misc/NEWS.d/next/Library/0175.bpo-28549.ShnM2y.rst A Misc/NEWS.d/next/Library/0176.bpo-27517.1CYM8A.rst A Misc/NEWS.d/next/Library/0177.bpo-28387.1clJu7.rst A Misc/NEWS.d/next/Library/0178.bpo-28563.iweEiw.rst A Misc/NEWS.d/next/Library/0179.bpo-19717.HXCAIz.rst A Misc/NEWS.d/next/Library/0180.bpo-28548.IeNrnG.rst A Misc/NEWS.d/next/Library/0181.bpo-25659.lE2IlT.rst A Misc/NEWS.d/next/Library/0182.bpo-20572.NCRmvz.rst A Misc/NEWS.d/next/Library/0183.bpo-28727.ubZP_b.rst A Misc/NEWS.d/next/Library/0184.bpo-28752.Q-4oRE.rst A Misc/NEWS.d/next/Library/0185.bpo-26273.ilNIWN.rst A Misc/NEWS.d/next/Library/0186.bpo-28740.rY8kz-.rst A Misc/NEWS.d/next/Library/0187.bpo-27172.mVKfLT.rst A Misc/NEWS.d/next/Library/0188.bpo-28835.Fv7Dr1.rst A Misc/NEWS.d/next/Library/0189.bpo-27030.GoGlFH.rst A Misc/NEWS.d/next/Library/0190.bpo-28847.GiWd9w.rst A Misc/NEWS.d/next/Library/0191.bpo-26937.c9kgiA.rst A Misc/NEWS.d/next/Library/0192.bpo-28779.t-mjED.rst A Misc/NEWS.d/next/Library/0193.bpo-16255.p2YA85.rst A Misc/NEWS.d/next/Library/0194.bpo-20191.Q7uZCS.rst A Misc/NEWS.d/next/Library/0195.bpo-19542.5tCkaK.rst A Misc/NEWS.d/next/Library/0196.bpo-28871.cPMXCJ.rst A Misc/NEWS.d/next/Library/0197.bpo-28923.naVULD.rst A Misc/NEWS.d/next/Library/0198.bpo-28427.vUd-va.rst A Misc/NEWS.d/next/Library/0199.bpo-9770.WJJnwP.rst A Misc/NEWS.d/next/Library/0200.bpo-13051.YzC1Te.rst A Misc/NEWS.d/next/Library/0201.bpo-29079.g4YLix.rst A Misc/NEWS.d/next/Library/0202.bpo-28985.TMWJFg.rst A Misc/NEWS.d/next/Library/0203.bpo-15812.R1U-Ec.rst A Misc/NEWS.d/next/Library/0204.bpo-28961.Rt93vg.rst A Misc/NEWS.d/next/Library/0205.bpo-29142.xo6kAv.rst A Misc/NEWS.d/next/Library/0206.bpo-20804.XyZhvi.rst A Misc/NEWS.d/next/Library/0207.bpo-28969.j3HJYO.rst A Misc/NEWS.d/next/Library/0208.bpo-29195.vK5LjU.rst A Misc/NEWS.d/next/Library/0209.bpo-29193.CgcjEx.rst A Misc/NEWS.d/next/Library/0210.bpo-29192.mY31H8.rst A Misc/NEWS.d/next/Library/0211.bpo-29219.kxui7t.rst A Misc/NEWS.d/next/Library/0212.bpo-29210.y1UHWf.rst A Misc/NEWS.d/next/Library/0213.bpo-29197.sZssFZ.rst A Misc/NEWS.d/next/Library/0214.bpo-28735.admHLO.rst A Misc/NEWS.d/next/Library/0215.bpo-29290.XBqptF.rst A Misc/NEWS.d/next/Library/0216.bpo-29335._KC7IK.rst A Misc/NEWS.d/next/Library/0217.bpo-29338.EpvQJl.rst A Misc/NEWS.d/next/Library/0218.bpo-29368.nTtA_V.rst A Misc/NEWS.d/next/Library/0219.bpo-29218.-Qoti0.rst A Misc/NEWS.d/next/Library/0220.bpo-29377.4AvSrC.rst A Misc/NEWS.d/next/Library/0221.bpo-29444.cEwgmk.rst A Misc/NEWS.d/next/Library/0222.bpo-29416.KJGyI_.rst A Misc/NEWS.d/next/Library/0223.bpo-29100.LAAERS.rst A Misc/NEWS.d/next/Library/0224.bpo-28556.p6967e.rst A Misc/NEWS.d/next/Library/0225.bpo-29851.jqs_5s.rst A Misc/NEWS.d/next/Library/0226.bpo-10379.mRlZsT.rst A Misc/NEWS.d/next/Library/0227.bpo-29534.Ug3HPU.rst A Misc/NEWS.d/next/Library/0228.bpo-29576.F-b8_5.rst A Misc/NEWS.d/next/Library/0229.bpo-22807.VmoSkZ.rst A Misc/NEWS.d/next/Library/0230.bpo-29110.wmE-_T.rst A Misc/NEWS.d/next/Library/0231.bpo-29532.YCwVQn.rst A Misc/NEWS.d/next/Library/0232.bpo-16285.4f5gbp.rst A Misc/NEWS.d/next/Library/0233.bpo-29742.8hqfEO.rst A Misc/NEWS.d/next/Library/0234.bpo-28518.o-Q2Nw.rst A Misc/NEWS.d/next/Library/0235.bpo-28624.43TJib.rst A Misc/NEWS.d/next/Library/0236.bpo-29376.rrJhJy.rst A Misc/NEWS.d/next/Library/0237.bpo-7769.xGRJWh.rst A Misc/NEWS.d/next/Library/0238.bpo-29615.OpFKzg.rst A Misc/NEWS.d/next/Library/0239.bpo-29703.ZdsPCR.rst A Misc/NEWS.d/next/Library/0240.bpo-29271.y8Vj2v.rst A Misc/NEWS.d/next/Library/0241.bpo-29704.WHbx27.rst A Misc/NEWS.d/next/Library/0242.bpo-28963.tPl8dq.rst A Misc/NEWS.d/next/Library/0243.bpo-9303.kDZRSd.rst A Misc/NEWS.d/next/Library/0244.bpo-29623.D3-NP2.rst A Misc/NEWS.d/next/Library/0245.bpo-29728.37jMwb.rst A Misc/NEWS.d/next/Library/0246.bpo-28682.hUxdej.rst A Misc/NEWS.d/next/Library/0247.bpo-26915.qShJZO.rst A Misc/NEWS.d/next/Library/0248.bpo-28231.MG1X09.rst A Misc/NEWS.d/next/Library/0249.bpo-29645.XCxTHM.rst A Misc/NEWS.d/next/Library/0250.bpo-28298.PNOPsT.rst A Misc/NEWS.d/next/Library/0251.bpo-29619.WIGVxO.rst A Misc/NEWS.d/next/Library/0252.bpo-26121.LX-pQA.rst A Misc/NEWS.d/next/Library/0253.bpo-28692.CDt-Gb.rst A Misc/NEWS.d/next/Library/0254.bpo-8256.jAwGQH.rst A Misc/NEWS.d/next/Library/0255.bpo-29800.d2xASa.rst A Misc/NEWS.d/next/Library/0256.bpo-25455.ZsahHN.rst A Misc/NEWS.d/next/Library/0257.bpo-29884.kWXR8W.rst A Misc/NEWS.d/next/Library/0258.bpo-19930.QCjO6A.rst A Misc/NEWS.d/next/Library/0259.bpo-29861.t2ZoRK.rst A Misc/NEWS.d/next/Library/0260.bpo-25803.CPDR0W.rst A Misc/NEWS.d/next/Library/0261.bpo-29901.QdgMvW.rst A Misc/NEWS.d/next/Library/0262.bpo-23890.GCFAAZ.rst A Misc/NEWS.d/next/Library/0263.bpo-28699.wZztZP.rst A Misc/NEWS.d/next/Library/0264.bpo-25996.L2_giP.rst A Misc/NEWS.d/next/Library/0265.bpo-27863.pPYHHI.rst A Misc/NEWS.d/next/Library/0266.bpo-29204.8Hbqn2.rst A Misc/NEWS.d/next/Library/0267.bpo-10030.ZdhU3k.rst A Misc/NEWS.d/next/Library/0268.bpo-29942.CsGNuT.rst A Misc/NEWS.d/next/Library/0269.bpo-29953.Q1hSt-.rst A Misc/NEWS.d/next/Library/0270.bpo-29931.tfcTwK.rst A Misc/NEWS.d/next/Library/0271.bpo-29654.xRFPge.rst A Misc/NEWS.d/next/Library/0272.bpo-29649.2eIxQ8.rst A Misc/NEWS.d/next/Library/0273.bpo-29962.r-ibsN.rst A Misc/NEWS.d/next/Library/0274.bpo-29995.b3mOqx.rst A Misc/NEWS.d/next/Library/0275.bpo-29998.poeIKD.rst A Misc/NEWS.d/next/Library/0276.bpo-30017.cKBuhU.rst A Misc/NEWS.d/next/Library/0277.bpo-26187.aViyiR.rst A Misc/NEWS.d/next/Library/0278.bpo-29692.oyWrAE.rst A Misc/NEWS.d/next/Library/0279.bpo-29694.LWKxb1.rst A Misc/NEWS.d/next/Library/0280.bpo-30068.n4q47r.rst A Misc/NEWS.d/next/Library/0281.bpo-10076.qCnwly.rst A Misc/NEWS.d/next/Library/0282.bpo-30218.ab5oIg.rst A Misc/NEWS.d/next/Library/0283.bpo-30061.2w_dX9.rst A Misc/NEWS.d/next/Library/0284.bpo-22352.gIQ5qC.rst A Misc/NEWS.d/next/Library/0285.bpo-30070.XM_B41.rst A Misc/NEWS.d/next/Library/0286.bpo-29960.g0wr3r.rst A Misc/NEWS.d/next/Library/0287.bpo-29822.G7dX13.rst A Misc/NEWS.d/next/Library/0288.bpo-30101.hxUqSL.rst A Misc/NEWS.d/next/Library/0289.bpo-30190.5E7Hyb.rst A Misc/NEWS.d/next/Library/0290.bpo-30228.nF8Ov4.rst A Misc/NEWS.d/next/Library/0291.bpo-30205.BsxO34.rst A Misc/NEWS.d/next/Library/0292.bpo-28556.51gjbP.rst A Misc/NEWS.d/next/Library/0293.bpo-30103.mmPjf5.rst A Misc/NEWS.d/next/Library/0294.bpo-30185.Tiu1n8.rst A Misc/NEWS.d/next/Library/0295.bpo-30215.SY8738.rst A Misc/NEWS.d/next/Library/0296.bpo-30243.RHQt0v.rst A Misc/NEWS.d/next/Library/0297.bpo-29979.jGBMyE.rst A Misc/NEWS.d/next/Library/0298.bpo-29990.HWV6KE.rst A Misc/NEWS.d/next/Library/0299.bpo-30285.s1vpsO.rst A Misc/NEWS.d/next/Library/0300.bpo-30298.ZN-bWo.rst A Misc/NEWS.d/next/Library/0301.bpo-30340.kvtGm-.rst A Misc/NEWS.d/next/Library/0302.bpo-30266.YJzHAH.rst A Misc/NEWS.d/next/Library/0303.bpo-30048.ELRx8R.rst A Misc/NEWS.d/next/Library/0304.bpo-30299.O-5d4A.rst A Misc/NEWS.d/next/Library/0305.bpo-9850.c6SMxt.rst A Misc/NEWS.d/next/Library/0306.bpo-29196.qBq9eB.rst A Misc/NEWS.d/next/Library/0307.bpo-30329.EuT36N.rst A Misc/NEWS.d/next/Library/0308.bpo-30375.9c8qM7.rst A Misc/NEWS.d/next/Library/0309.bpo-30301.ywOkjN.rst A Misc/NEWS.d/next/Library/0310.bpo-30436.b3zqE7.rst A Misc/NEWS.d/next/Library/0311.bpo-30149.hE649r.rst A Misc/NEWS.d/next/Library/0312.bpo-30003.BOl9HE.rst A Misc/NEWS.d/next/Library/0313.bpo-30414.jGl1Lb.rst A Misc/NEWS.d/next/Library/0314.bpo-30470.wAYhUc.rst A Misc/NEWS.d/next/Library/0315.bpo-16500.9ypo9k.rst A Misc/NEWS.d/next/Library/0316.bpo-30378.R_19_5.rst A Misc/NEWS.d/next/Library/0317.bpo-30245.Xoa_8Y.rst A Misc/NEWS.d/next/Library/0318.bpo-30526.7zTG30.rst A Misc/NEWS.d/next/Library/0319.bpo-30557.uykrLf.rst A Misc/NEWS.d/next/Library/0320.bpo-30520.VYzaSn.rst A Misc/NEWS.d/next/Library/0321.bpo-30463.CdOuSl.rst A Misc/NEWS.d/next/Library/0322.bpo-30418.EwISQm.rst A Misc/NEWS.d/next/Library/0323.bpo-30014.x7Yx6o.rst A Misc/NEWS.d/next/Library/0324.bpo-27585.0Ugqqu.rst A Misc/NEWS.d/next/Library/0325.bpo-29743.en2P4s.rst A Misc/NEWS.d/next/Library/0326.bpo-29870.p960Ih.rst A Misc/NEWS.d/next/Library/0327.bpo-30605.XqGz1r.rst A Misc/NEWS.d/next/Library/0328.bpo-28556.mESP7G.rst A Misc/NEWS.d/next/Library/0329.bpo-30595.dWE6NM.rst A Misc/NEWS.d/next/Library/0330.bpo-30624.g5oVSn.rst A Misc/NEWS.d/next/Library/0331.bpo-11822.GQmKw3.rst A Misc/NEWS.d/next/Library/0332.bpo-30645.xihJ4Y.rst A Misc/NEWS.d/next/Library/0333.bpo-30508.wNWRS2.rst A Misc/NEWS.d/next/Library/0334.bpo-28994.9vzun1.rst A Misc/NEWS.d/next/Library/0335.bpo-30589.xyZGM0.rst A Misc/NEWS.d/next/Library/0336.bpo-24484.vFem8K.rst A Misc/NEWS.d/next/Library/0337.bpo-24744.NKxUj3.rst A Misc/NEWS.d/next/Library/0339.bpo-23894.k2pADV.rst A Misc/NEWS.d/next/Library/0340.bpo-30038.vb4DWk.rst A Misc/NEWS.d/next/Library/0341.bpo-30616.I2mDTz.rst A Misc/NEWS.d/next/Library/0343.bpo-29755.diQcY_.rst A Misc/NEWS.d/next/Library/0345.bpo-29212.HmTdef.rst A Misc/NEWS.d/next/Library/0346.bpo-21071.Sw37rs.rst A Misc/NEWS.d/next/Library/0348.bpo-30664.oyqiUl.rst A Misc/NEWS.d/next/Library/0349.bpo-30746.7drQI0.rst A Misc/NEWS.d/next/Library/0350.bpo-30879.N3KI-o.rst A Misc/NEWS.d/next/Library/0351.bpo-29169.8ypApm.rst A Misc/NEWS.d/next/Security/0338.bpo-29591.ExKblw.rst A Misc/NEWS.d/next/Security/0342.bpo-30500.1VG7R-.rst A Misc/NEWS.d/next/Security/0344.bpo-30694.WkMWM_.rst A Misc/NEWS.d/next/Security/0347.bpo-30730.rJsyTH.rst A Misc/NEWS.d/next/Tests/0001.bpo-26939.7j_W5R.rst A Misc/NEWS.d/next/Tests/0002.bpo-28217.Y37OKV.rst A Misc/NEWS.d/next/Tests/0003.bpo-28409.Q2IlxJ.rst A Misc/NEWS.d/next/Tests/0004.bpo-26944.ChZ_BO.rst A Misc/NEWS.d/next/Tests/0005.bpo-23839.zsT_L9.rst A Misc/NEWS.d/next/Tests/0006.bpo-28666.RtTk-4.rst A Misc/NEWS.d/next/Tests/0007.bpo-26936.XSZSVS.rst A Misc/NEWS.d/next/Tests/0008.bpo-28683.Fp-Hdq.rst A Misc/NEWS.d/next/Tests/0009.bpo-28950.1W8Glo.rst A Misc/NEWS.d/next/Tests/0010.bpo-24932.XLTzvR.rst A Misc/NEWS.d/next/Tests/0011.bpo-30197.c5wRfu.rst A Misc/NEWS.d/next/Tests/0012.bpo-30357.n4CPEa.rst A Misc/NEWS.d/next/Tools-Demos/0013.bpo-28102.5fKaek.rst A Misc/NEWS.d/next/Tools-Demos/0014.bpo-15369.bdZ3n-.rst A Misc/NEWS.d/next/Tools-Demos/0015.bpo-28023.4gzSGp.rst A Misc/NEWS.d/next/Tools-Demos/0016.bpo-29367.4dOKL0.rst A Misc/NEWS.d/next/Tools-Demos/0017.bpo-24037.KPFC7o.rst A Misc/NEWS.d/next/Tools-Demos/0018.bpo-29748.6pV6s9.rst A Misc/NEWS.d/next/Windows/0074.bpo-28138.pNdv64.rst A Misc/NEWS.d/next/Windows/0075.bpo-28137.C1uvzY.rst A Misc/NEWS.d/next/Windows/0076.bpo-28164.5MfN0J.rst A Misc/NEWS.d/next/Windows/0077.bpo-28163.-DUgJw.rst A Misc/NEWS.d/next/Windows/0078.bpo-28162.3FHPVD.rst A Misc/NEWS.d/next/Windows/0079.bpo-28161.hF91LI.rst A Misc/NEWS.d/next/Windows/0080.bpo-28110.cnkP5F.rst A Misc/NEWS.d/next/Windows/0081.bpo-28251.tR_AFs.rst A Misc/NEWS.d/next/Windows/0082.bpo-28333.KnpeO4.rst A Misc/NEWS.d/next/Windows/0083.bpo-28402.v9zETJ.rst A Misc/NEWS.d/next/Windows/0084.bpo-28522.XHMQa7.rst A Misc/NEWS.d/next/Windows/0085.bpo-28896.qOcBBL.rst A Misc/NEWS.d/next/Windows/0086.bpo-25778.8uKJ82.rst A Misc/NEWS.d/next/Windows/0087.bpo-29579.07B-FQ.rst A Misc/NEWS.d/next/Windows/0088.bpo-30450.qsaK8y.rst Log Message: ----------- Perform 'blurb split' for master. Commit: 38c8fde4708fb7d6b37e245b3c4f02c645f23126 https://github.com/python/cpython/commit/38c8fde4708fb7d6b37e245b3c4f02c645f23126 Author: Larry Hastings Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Doc/tools/extensions/pyspecific.py M Lib/idlelib/idle_test/README.txt M Lib/test/test_json/test_speedups.py A Misc/NEWS.d/next/IDLE/2017-07-15-22-26-57.bpo-30934.BanuSB.rst M Modules/_json.c Log Message: ----------- Merge branch 'master' of https://github.com/python/cpython into blurb-split-master Commit: dc85bd943123e83d89c1d9d319093611a898a9a5 https://github.com/python/cpython/commit/dc85bd943123e83d89c1d9d319093611a898a9a5 Author: Larry Hastings Date: 2017-07-16 (Sun, 16 Jul 2017) Changed paths: M Doc/Makefile M Doc/whatsnew/changelog.rst Log Message: ----------- Fix Doc build for use with blurb. Compare: https://github.com/python/cpython/compare/b5ae2202ebd4^...dc85bd943123 From noreply at github.com Sun Jul 16 09:55:53 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 06:55:53 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <596b70692f78d_2ecf3fac84065c3c24614@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/blurb-split-master Home: https://github.com/python/cpython From noreply at github.com Mon Jul 17 00:45:09 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 21:45:09 -0700 Subject: [Python-checkins] [python/cpython] 5fd33b: Version bump to 3.6.2final Message-ID: <596c40d5619b5_4a1b3f9286f0fc3c2419e@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 5fd33b5926eb8c9352bf5718369b4a8d72c4bb44 https://github.com/python/cpython/commit/5fd33b5926eb8c9352bf5718369b4a8d72c4bb44 Author: Ned Deily Date: 2017-07-07 (Fri, 07 Jul 2017) Changed paths: M Include/patchlevel.h M Misc/NEWS M README.rst Log Message: ----------- Version bump to 3.6.2final Commit: 05217f2ead9fbf4677487611d0160180d47b1152 https://github.com/python/cpython/commit/05217f2ead9fbf4677487611d0160180d47b1152 Author: Ned Deily Date: 2017-07-17 (Mon, 17 Jul 2017) Log Message: ----------- Merge tag 'v3.6.2' into 3.6 Version v3.6.2 Compare: https://github.com/python/cpython/compare/a819e5e1e66a...05217f2ead9f From noreply at github.com Mon Jul 17 00:45:16 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 21:45:16 -0700 Subject: [Python-checkins] [python/cpython] Message-ID: <596c40dca1f34_6da3fc2b5ff5c3c843f4@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/tags/v3.6.2 Home: https://github.com/python/cpython From noreply at github.com Mon Jul 17 00:54:20 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 21:54:20 -0700 Subject: [Python-checkins] [python/cpython] a61089: Bump to v3.6.2+ Message-ID: <596c42fc553d8_409b3fd211f73c3091546@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: a61089f57337130710b20c71e5c33f873e842fcc https://github.com/python/cpython/commit/a61089f57337130710b20c71e5c33f873e842fcc Author: Ned Deily Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: M Include/patchlevel.h M Misc/NEWS Log Message: ----------- Bump to v3.6.2+ From noreply at github.com Mon Jul 17 00:59:17 2017 From: noreply at github.com (GitHub) Date: Sun, 16 Jul 2017 21:59:17 -0700 Subject: [Python-checkins] [python/cpython] 8663c4: Also bump README.rst Message-ID: <596c44258d4d2_4df83fe548f57c34294d5@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 8663c4549109cda14e039a4b22b85343a20793aa https://github.com/python/cpython/commit/8663c4549109cda14e039a4b22b85343a20793aa Author: Ned Deily Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: M README.rst Log Message: ----------- Also bump README.rst From solipsis at pitrou.net Mon Jul 17 05:08:59 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Mon, 17 Jul 2017 09:08:59 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170717090859.56659.B87741D51DD4C368@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflog1VWzMX', '--timeout', '7200'] From noreply at github.com Mon Jul 17 05:15:52 2017 From: noreply at github.com (GitHub) Date: Mon, 17 Jul 2017 02:15:52 -0700 Subject: [Python-checkins] [python/cpython] 68d663: [bpo-30916] Pre-build OpenSSL and Tcl/Tk for Windo... Message-ID: <596c8048ae27_4c163fa07c2afc408615f@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 68d663cf85d1ac5eaf83482eed39c0a6f8093601 https://github.com/python/cpython/commit/68d663cf85d1ac5eaf83482eed39c0a6f8093601 Author: Steve Dower Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: M Doc/make.bat M Lib/test/test_ssl.py A Misc/NEWS.d/next/Windows/2017-07-15-00-40-12.bpo-30916.BpCrro.rst M Modules/_ssl.c M PCbuild/_hashlib.vcxproj M PCbuild/_ssl.vcxproj M PCbuild/_ssl.vcxproj.filters M PCbuild/_tkinter.vcxproj M PCbuild/build.bat M PCbuild/find_msbuild.bat A PCbuild/find_python.bat M PCbuild/get_externals.bat R PCbuild/libeay.vcxproj M PCbuild/openssl.props A PCbuild/openssl.vcxproj M PCbuild/pcbuild.proj M PCbuild/pcbuild.sln M PCbuild/prepare_ssl.bat M PCbuild/prepare_ssl.py A PCbuild/prepare_tcltk.bat M PCbuild/pyproject.props M PCbuild/python.props R PCbuild/ssleay.vcxproj M PCbuild/tcl.vcxproj M PCbuild/tcltk.props M PCbuild/tix.vcxproj M PCbuild/tk.vcxproj M Tools/msi/buildrelease.bat M Tools/msi/exe/exe.wixproj M Tools/msi/get_externals.bat M Tools/msi/lib/lib_files.wxs M Tools/msi/tcltk/tcltk.wixproj M Tools/msi/tcltk/tcltk_d.wxs M Tools/msi/tcltk/tcltk_files.wxs Log Message: ----------- [bpo-30916] Pre-build OpenSSL and Tcl/Tk for Windows (#2688) Updates ssl and tkinter projects to use pre-built externals From noreply at github.com Mon Jul 17 06:25:20 2017 From: noreply at github.com (GitHub) Date: Mon, 17 Jul 2017 03:25:20 -0700 Subject: [Python-checkins] [python/cpython] 2c8a5e: bpo-30808: Use _Py_atomic API for concurrency-sens... Message-ID: <596c9090c29a2_486e3f9f03449c38900ce@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 2c8a5e4c968217f9672340e520942c4ed788d8de https://github.com/python/cpython/commit/2c8a5e4c968217f9672340e520942c4ed788d8de Author: Antoine Pitrou Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: A Misc/NEWS.d/next/Core and Builtins/2017-07-17-12-12-59.bpo-30808.bA3zOv.rst M Modules/signalmodule.c Log Message: ----------- bpo-30808: Use _Py_atomic API for concurrency-sensitive signal state (#2417) * Improve signal delivery Avoid using Py_AddPendingCall from signal handler, to avoid calling signal-unsafe functions. * Remove unused function * Improve comments * Use _Py_atomic API for concurrency-sensitive signal state * Add blurb From noreply at github.com Mon Jul 17 08:55:30 2017 From: noreply at github.com (GitHub) Date: Mon, 17 Jul 2017 05:55:30 -0700 Subject: [Python-checkins] [python/cpython] 588836: bpo-30450: Adds alternate download approach for nu... Message-ID: <596cb3c245fd0_236c3fe6c7051c3c3188d@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 588836d3e646c2bcb3473cda7c5f6a1e0ff2c2e9 https://github.com/python/cpython/commit/588836d3e646c2bcb3473cda7c5f6a1e0ff2c2e9 Author: Steve Dower Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: M PCbuild/find_python.bat A PCbuild/urlretrieve.py Log Message: ----------- bpo-30450: Adds alternate download approach for nuget.exe (#2737) * bpo-30450: Adds alternate download approach for nuget.exe * Whitespace fix. From noreply at github.com Mon Jul 17 09:43:58 2017 From: noreply at github.com (GitHub) Date: Mon, 17 Jul 2017 06:43:58 -0700 Subject: [Python-checkins] [python/cpython] efa26b: bpo-30450: Fall back to git.exe if no Python is fo... Message-ID: <596cbf1e4d42_51c3ff227e91c3c56597@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: efa26bcd5085279fc4e9ae96d052272a5214c2bd https://github.com/python/cpython/commit/efa26bcd5085279fc4e9ae96d052272a5214c2bd Author: Steve Dower Date: 2017-07-17 (Mon, 17 Jul 2017) Changed paths: M PCbuild/get_externals.bat Log Message: ----------- bpo-30450: Fall back to git.exe if no Python is found. (#2739) * bpo-30450: Fall back to git.exe if no Python is found. * Also check whether git.exe is on PATH if it will be used. From lp_benchmark_robot at intel.com Mon Jul 17 19:48:54 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Mon, 17 Jul 2017 16:48:54 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-17 Message-ID: <773800e0-3837-47ed-a3cf-8f6368fb3e6f@orsmsx102.amr.corp.intel.com> Results for project python/master, build date: 2017-07-17 03:03:31-07:00. - commit: 68d663c - previous commit: 0d0a32f - revision date: 2017-07-17 11:15:48+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.081% | +0.272% | +4.439% | +7.845% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.821% | -0.303% | +22.373% | +7.480% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.769% | -0.188% | +22.779% | +6.781% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.857% | +0.296% | +21.188% | +5.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 2.919% | +1.608% | +7.598% | +6.897% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.958% | +0.017% | +11.596% | +10.543% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.029% | +0.062% | +7.432% | +9.601% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.501% | +0.158% | +3.852% | +4.475% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.886% | -0.502% | +8.641% | +17.536% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.574% | -0.340% | +9.909% | +13.001% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.453% | +0.238% | +4.198% | +6.058% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.574% | +0.003% | +5.550% | +3.381% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.668% | +0.042% | +4.714% | +4.839% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.549% | -0.375% | +9.049% | +10.109% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.405% | -0.133% | +6.929% | +7.831% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.923% | -0.153% | +6.469% | +10.855% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.100% | +0.091% | +10.346% | +11.428% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.411% | +0.545% | +8.289% | +10.587% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 2.113% | -0.489% | +3.316% | +10.109% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.952% | -0.280% | +4.615% | +7.637% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.484% | +0.323% | +7.938% | +10.409% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.327% | +0.274% | +13.350% | +11.718% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.734% | +0.352% | +7.848% | +13.045% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.522% | -0.068% | +18.421% | +11.546% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.202% | -1.857% | +2.087% | +16.848% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.968% | +0.187% | +3.791% | +5.746% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.278% | +0.250% | -4.630% | +4.790% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.225% | -0.225% | +2.152% | +7.167% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.265% | +0.357% | +2.537% | +12.415% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.463% | -0.460% | +2.268% | +22.478% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.507% | -0.017% | +3.851% | +16.244% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.985% | -0.244% | +3.968% | +18.056% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 5.232% | +0.908% | +12.299% | +10.096% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.110% | +0.021% | +0.099% | +9.635% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.117% | -0.078% | +9.827% | +4.208% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.092% | -0.085% | +1.668% | +4.292% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.334% | +0.486% | +10.534% | +10.661% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.964% | +1.133% | -7.147% | +10.629% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.379% | +0.058% | -2.199% | +12.360% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.169% | -0.609% | -4.515% | +9.224% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.633% | -0.257% | +11.375% | +4.059% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.439% | +0.217% | +8.977% | +13.857% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.504% | +0.233% | +1.727% | +0.050% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.578% | -0.083% | +26.720% | +9.446% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.607% | -0.195% | +5.926% | +3.996% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.628% | -0.184% | +15.521% | +6.577% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.276% | -0.004% | +1.970% | -11.294% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.788% | +0.045% | +5.791% | -0.322% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.046% | +0.597% | +5.270% | +8.512% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.305% | +0.087% | +4.555% | +4.887% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 2.637% | +0.110% | +2.502% | +9.897% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.159% | +0.059% | +12.435% | +8.599% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.572% | -0.255% | +10.826% | +5.905% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.957% | +0.639% | +11.946% | +9.574% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.754% | -0.751% | +11.918% | +11.217% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.510% | -0.600% | +23.092% | +10.119% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.211% | -0.055% | +6.063% | +6.070% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.993% | +0.181% | +2.415% | -1.374% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.801% | -0.126% | +9.162% | +20.667% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.670% | -0.186% | -3.270% | +18.237% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.514% | -0.246% | +8.622% | +7.125% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.989% | -0.278% | +5.745% | +7.749% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.148% | +0.528% | +3.307% | +5.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.872% | +0.085% | -4.910% | +9.312% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.271% | +0.189% | +6.760% | +7.682% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-17 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From solipsis at pitrou.net Tue Jul 18 05:08:22 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Tue, 18 Jul 2017 09:08:22 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=3 Message-ID: <20170718090821.127649.57F459A24A630A33@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [-2, 2, -1] memory blocks, sum=-1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogq_N4WB', '--timeout', '7200'] From noreply at github.com Tue Jul 18 11:05:08 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 08:05:08 -0700 Subject: [Python-checkins] [python/cpython] f474c5: bpo-30946: Remove obsolete fallback code in readli... Message-ID: <596e23a44d370_28753fb67724fc306578a@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: f474c5a3f3c1fbc0383800b88e8518d43a52d1d1 https://github.com/python/cpython/commit/f474c5a3f3c1fbc0383800b88e8518d43a52d1d1 Author: Antoine Pitrou Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M Include/fileobject.h A Misc/NEWS.d/next/Library/2017-07-17-12-32-47.bpo-30946.DUo-uA.rst M Modules/readline.c M PC/pyconfig.h M configure M configure.ac M pyconfig.h.in Log Message: ----------- bpo-30946: Remove obsolete fallback code in readline module (#2738) * Remove obsolete fallback code in readline module * Add NEWS * Remove obsolete include * Fix macro on Windows From noreply at github.com Tue Jul 18 11:34:25 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 08:34:25 -0700 Subject: [Python-checkins] [python/cpython] ba75af: bpo-30794: added kill() method to multiprocessing.... Message-ID: <596e2a8176bb7_4e783fb6010c1c40937b9@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: ba75af713078966cc594fc7f0809ed53c532c58f https://github.com/python/cpython/commit/ba75af713078966cc594fc7f0809ed53c532c58f Author: Vitor Pereira Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M Doc/library/multiprocessing.rst M Lib/multiprocessing/popen_fork.py M Lib/multiprocessing/popen_spawn_win32.py M Lib/multiprocessing/process.py M Lib/test/_test_multiprocessing.py A Misc/NEWS.d/next/Library/2017-07-04-22-00-20.bpo-30794.qFwozm.rst Log Message: ----------- bpo-30794: added kill() method to multiprocessing.Process (#2528) * bpo-30794: added kill() method to multiprocessing.Process * Added entries to documentation and NEWS * Refactored test_terminate and test_kill * Fix SIGTERM and SIGKILL being used on Windows for the tests * Added "versionadded" marker to the documentation * Fix trailing whitespace in doc From noreply at github.com Tue Jul 18 12:33:32 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 09:33:32 -0700 Subject: [Python-checkins] [python/cpython] 4ed5ad: bpo-30961: Fix decrementing a borrowed reference i... Message-ID: <596e385c1ee9b_12df23f899ee9fc34658bb@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 4ed5ad79ec6c6270e6018bd0a55656305ee60907 https://github.com/python/cpython/commit/4ed5ad79ec6c6270e6018bd0a55656305ee60907 Author: Xiang Zhang Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-18-23-47-51.bpo-30961.064jz0.rst M Modules/_tracemalloc.c Log Message: ----------- bpo-30961: Fix decrementing a borrowed reference in tracemalloc. (#2747) From noreply at github.com Tue Jul 18 12:50:53 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 09:50:53 -0700 Subject: [Python-checkins] [python/cpython] 241c4a: bpo-30961: Fix decrementing a borrowed reference i... Message-ID: <596e3c6dd2872_46963fdcd85dfc389513a@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 241c4a28d9fec7f2beffc9cbd21f156999959a9d https://github.com/python/cpython/commit/241c4a28d9fec7f2beffc9cbd21f156999959a9d Author: Xiang Zhang Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-18-23-47-51.bpo-30961.064jz0.rst M Modules/_tracemalloc.c Log Message: ----------- bpo-30961: Fix decrementing a borrowed reference in tracemalloc. (#2747) (#2748) (cherry picked from commit 4ed5ad79ec6c6270e6018bd0a55656305ee60907) From noreply at github.com Tue Jul 18 12:51:59 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 09:51:59 -0700 Subject: [Python-checkins] [python/cpython] cb3f02: bpo-30961: Fix decrementing a borrowed reference i... Message-ID: <596e3cafb1baa_6433fef767f1c3c641ef@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: cb3f024f3ac91e468d581f0682e63685c977c80d https://github.com/python/cpython/commit/cb3f024f3ac91e468d581f0682e63685c977c80d Author: Xiang Zhang Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: A Misc/NEWS.d/next/Library/2017-07-18-23-47-51.bpo-30961.064jz0.rst M Modules/_tracemalloc.c Log Message: ----------- bpo-30961: Fix decrementing a borrowed reference in tracemalloc. (#2747) (#2749) (cherry picked from commit 4ed5ad79ec6c6270e6018bd0a55656305ee60907) From noreply at github.com Tue Jul 18 13:31:54 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 10:31:54 -0700 Subject: [Python-checkins] [python/cpython] 5feda3: bpo-30450: Fix logic for retrying nuget.exe downlo... Message-ID: <596e460a56484_13dd03ff9c6573c3096827@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 5feda33a35d9413e2073411b848dc49d94c57497 https://github.com/python/cpython/commit/5feda33a35d9413e2073411b848dc49d94c57497 Author: Steve Dower Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M .github/appveyor.yml M PCbuild/find_python.bat Log Message: ----------- bpo-30450: Fix logic for retrying nuget.exe download (#2744) Fix logic for retrying nuget.exe download with Python. Add support for HOST_PYTHON variable. Clear internal environment variables used in find_python.bat Use HOST_PYTHON as the actual Python if it is recent enough. Adds HOST_PYTHON variable to AppVeyor configuration From noreply at github.com Tue Jul 18 17:17:57 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 14:17:57 -0700 Subject: [Python-checkins] [python/cpython] f776eb: bpo-30917: IDLE: Add config.IdleConf unittests (#2... Message-ID: <596e7b05b773d_4e553fb11027bc348688c@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: f776eb0f0e046f2fa3a96540bb42d8cf970f6c55 https://github.com/python/cpython/commit/f776eb0f0e046f2fa3a96540bb42d8cf970f6c55 Author: Louie Lu Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/idle_test/test_config.py A Misc/NEWS.d/next/IDLE/2017-07-17-23-35-57.bpo-30917.hSiuuO.rst Log Message: ----------- bpo-30917: IDLE: Add config.IdleConf unittests (#2691) Patch by Louie Lu. From noreply at github.com Tue Jul 18 20:44:39 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 17:44:39 -0700 Subject: [Python-checkins] [python/cpython] 3625f7: [3.3] bpo-30585: [security] raise an error when ST... Message-ID: <596eab77b5219_2a883f8508529c441252c0@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: 3625f7fd11679ecb390ffa58ef36d487acc8159b https://github.com/python/cpython/commit/3625f7fd11679ecb390ffa58ef36d487acc8159b Author: Victor Stinner Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M Lib/smtplib.py M Misc/NEWS Log Message: ----------- [3.3] bpo-30585: [security] raise an error when STARTTLS fails (#225) (cherry picked from commit 46b32f307c48bcb999b22eebf65ffe8ed5cca544) From lp_benchmark_robot at intel.com Tue Jul 18 21:22:49 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Tue, 18 Jul 2017 18:22:49 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-18 Message-ID: <40d9fa43-2ae5-46b8-ba71-fb04e22cc4dc@orsmsx110.amr.corp.intel.com> Results for project python/master, build date: 2017-07-18 03:03:33-07:00. - commit: efa26bc - previous commit: 68d663c - revision date: 2017-07-17 15:43:55+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.039% | +0.215% | +4.645% | +7.231% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.681% | +0.820% | +23.010% | +7.105% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.976% | +2.282% | +24.541% | +7.171% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.951% | +1.487% | +22.359% | +6.946% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.181% | -4.125% | +3.787% | +13.195% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.512% | +0.313% | +11.873% | +11.942% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.988% | -0.442% | +7.023% | +9.894% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.456% | +0.047% | +3.898% | +5.027% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.691% | -1.089% | +7.647% | +18.301% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.997% | -0.162% | +9.763% | +14.302% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.098% | -0.593% | +3.630% | +7.056% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.590% | +0.696% | +6.207% | +3.512% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.079% | -0.437% | +4.298% | +4.531% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.235% | +0.502% | +9.505% | +11.104% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.961% | +0.995% | +7.855% | +9.021% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.745% | +0.713% | +7.136% | +9.051% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.186% | -0.840% | +9.592% | +10.070% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.403% | -0.207% | +8.099% | +9.111% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.771% | +0.540% | +3.837% | +8.420% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 5.923% | -0.464% | +4.172% | +8.104% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.547% | -0.408% | +7.562% | +10.499% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.415% | -0.783% | +12.671% | +11.730% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.831% | +0.444% | +8.257% | +11.406% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.953% | -0.683% | +17.864% | +12.774% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.613% | +3.267% | +5.287% | +14.925% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.604% | +0.332% | +4.111% | +5.498% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.282% | -0.077% | -4.710% | +5.479% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.932% | -0.219% | +1.938% | +7.178% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.287% | +0.522% | +3.046% | +11.790% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.512% | -0.333% | +1.943% | +22.440% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.314% | -0.962% | +2.926% | +17.836% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.816% | +1.695% | +5.596% | +18.146% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 7.822% | -2.508% | +10.100% | +12.835% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.074% | +0.306% | +0.405% | +10.104% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.126% | -0.165% | +9.678% | +4.252% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.092% | -0.158% | +1.512% | +4.380% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.049% | -1.429% | +9.255% | +11.696% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.910% | -0.977% | -8.194% | +11.422% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.832% | +0.304% | -1.888% | +10.657% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.024% | -0.453% | -4.989% | +9.971% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.678% | -0.755% | +10.706% | +4.847% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.472% | +0.352% | +9.297% | +13.412% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.490% | -0.683% | +1.056% | +2.721% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.915% | +0.396% | +27.010% | +7.431% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.706% | -0.290% | +5.653% | +4.174% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.461% | -0.379% | +15.202% | +8.667% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 0.435% | +0.901% | +2.853% | -2.166% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 1.079% | -0.851% | +4.989% | +2.714% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 0.993% | +0.015% | +5.284% | +5.368% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.651% | -1.388% | +3.230% | +6.754% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.780% | -0.985% | +1.542% | +9.114% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.183% | -0.030% | +12.408% | +7.014% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.717% | -0.062% | +10.771% | +5.937% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.024% | -0.266% | +11.711% | +8.553% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 5.005% | +0.818% | +12.639% | +9.349% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.197% | -1.162% | +22.198% | +12.300% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.153% | +0.138% | +6.193% | +5.973% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.865% | -0.105% | +2.313% | -1.358% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 5.999% | +1.306% | +10.348% | +18.966% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.074% | +2.277% | -0.919% | +18.339% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.266% | -0.546% | +8.123% | +6.851% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.992% | -0.089% | +5.661% | +8.362% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 1.986% | +0.301% | +3.598% | +4.795% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.730% | -0.658% | -5.600% | +10.101% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.149% | -0.201% | +6.572% | +8.596% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-18 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Tue Jul 18 22:27:25 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 19:27:25 -0700 Subject: [Python-checkins] [python/cpython] d81bea: Use pythontest.net instead of debian.org in test_u... Message-ID: <596ec38d52f0b_138173faba19e7c30103539@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: d81bea6520892e0428aec61c73e0631a69db11bb https://github.com/python/cpython/commit/d81bea6520892e0428aec61c73e0631a69db11bb Author: Ammar Askar Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: M Lib/test/test_urllib2net.py Log Message: ----------- Use pythontest.net instead of debian.org in test_urllib2net (GH-2755) From noreply at github.com Tue Jul 18 22:40:11 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 19:40:11 -0700 Subject: [Python-checkins] [python/cpython] e46f1c: [security][3.3] bpo-30730: Prevent environment var... Message-ID: <596ec68be2234_499e3fede032dc38154980@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: e46f1c19642ea1882f427d8246987ba49351a97d https://github.com/python/cpython/commit/e46f1c19642ea1882f427d8246987ba49351a97d Author: Serhiy Storchaka Date: 2017-07-18 (Tue, 18 Jul 2017) Changed paths: M Lib/subprocess.py M Lib/test/test_subprocess.py M Misc/NEWS M Modules/_winapi.c M Objects/abstract.c Log Message: ----------- [security][3.3] bpo-30730: Prevent environment variables injection in subprocess on Windows. (GH-2325) (#2363) From noreply at github.com Wed Jul 19 00:07:50 2017 From: noreply at github.com (GitHub) Date: Tue, 18 Jul 2017 21:07:50 -0700 Subject: [Python-checkins] [python/cpython] a73900: [2.7] bpo-30883: Use pythontest.net instead of deb... Message-ID: <596edb16bd764_1e4c3f7fb71e1c2c4851c@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: a739000db55ef55e69a53ca6966ea8657cac4354 https://github.com/python/cpython/commit/a739000db55ef55e69a53ca6966ea8657cac4354 Author: Ammar Askar Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: M Lib/test/test_urllib2net.py Log Message: ----------- [2.7] bpo-30883: Use pythontest.net instead of debian.org in test_urllib2net (GH-2755) From noreply at github.com Wed Jul 19 03:11:10 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 00:11:10 -0700 Subject: [Python-checkins] [python/cpython] e99d3a: [3.6] bpo-30450: Improved logic for obtaining depe... Message-ID: <596f060e73995_1cce3f8f14a43c3c15517a@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: e99d3a52a50b3f836fb9fb88f317aacddd494858 https://github.com/python/cpython/commit/e99d3a52a50b3f836fb9fb88f317aacddd494858 Author: Steve Dower Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: M .github/appveyor.yml M Doc/make.bat M PCbuild/build.bat A PCbuild/find_python.bat M PCbuild/get_externals.bat A PCbuild/urlretrieve.py M Tools/msi/buildrelease.bat M Tools/msi/get_externals.bat Log Message: ----------- [3.6] bpo-30450: Improved logic for obtaining dependencies (#2751) Adds alternate download approach for nuget.exe Fall back to git.exe if no Python is found. (#2739) Also check whether git.exe is on PATH if it will be used. Add support for HOST_PYTHON variable. Clear internal environment variables used in find_python.bat Use HOST_PYTHON as the actual Python if it is recent enough. Adds HOST_PYTHON variable to AppVeyor configuration From solipsis at pitrou.net Wed Jul 19 05:07:55 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Wed, 19 Jul 2017 09:07:55 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=-4 Message-ID: <20170719090754.127028.14B71B62970067B5@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [-7, 1, 0] memory blocks, sum=-6 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [1, -2, 1] memory blocks, sum=0 test_multiprocessing_spawn leaked [0, 0, -2] memory blocks, sum=-2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogVwixzD', '--timeout', '7200'] From lp_benchmark_robot at intel.com Wed Jul 19 18:46:04 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Wed, 19 Jul 2017 15:46:04 -0700 Subject: [Python-checkins] [1 up, 64 flat] Results for Python (master branch) 2017-07-19 Message-ID: <6584a48c-7738-400b-a6ae-19636be72aa6@orsmsx153.amr.corp.intel.com> Results for project python/master, build date: 2017-07-19 03:04:28-07:00. - commit: d81bea6 - previous commit: efa26bc - revision date: 2017-07-19 05:27:24+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.101% | -0.071% | +4.578% | +7.153% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.450% | +2.074% | +24.607% | +8.853% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 3.255% | +0.745% | +25.103% | +8.755% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.626% | +0.305% | +22.596% | +8.101% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 4.230% | +2.404% | +6.100% | +11.979% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.007% | -0.692% | +11.263% | +11.416% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.963% | +0.559% | +7.543% | +8.358% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.572% | +1.444% | +5.285% | +4.672% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.417% | -1.074% | +6.655% | +17.765% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.951% | -0.998% | +8.862% | +13.567% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.221% | +0.181% | +3.804% | +6.183% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.968% | -1.423% | +4.872% | +5.825% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.447% | -0.793% | +3.539% | +5.225% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.343% | -0.246% | +9.282% | +11.037% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.726% | -1.071% | +6.868% | +9.632% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.979% | +0.375% | +7.484% | +9.700% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.653% | +0.968% | +10.467% | +9.446% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.396% | +1.157% | +9.162% | +8.197% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 3.204% | -0.882% | +2.990% | +9.837% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 2.218% | -2.376% | +1.895% | +11.646% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.594% | +0.237% | +7.781% | +10.044% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 1.781% | -3.911% | +9.255% | +15.524% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.408% | +0.290% | +8.524% | +11.848% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.561% | +0.634% | +18.385% | +12.917% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.774% | -0.350% | +4.955% | +13.701% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.809% | +0.759% | +4.838% | +4.774% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.592% | +1.840% | -2.784% | +5.398% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.721% | +0.757% | +2.680% | +6.756% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.348% | -0.445% | +2.615% | +11.185% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.799% | +1.123% | +3.044% | +22.213% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.323% | -0.574% | +2.369% | +21.142% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.046% | +0.196% | +5.781% | +19.350% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.930% | +2.951% | +12.753% | +10.006% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.148% | -0.042% | +0.363% | +9.775% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.129% | +0.042% | +9.716% | +4.131% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.093% | -0.113% | +1.401% | +4.321% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.237% | +0.831% | +10.009% | +11.659% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.854% | -0.101% | -8.303% | +11.265% | +-----+------------------------+--------+------------+------------+------------+ | :-) | regex_dna| 1.418% | +3.751% | +1.935% | +7.670% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.077% | +2.410% | -2.458% | +7.147% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.268% | +0.965% | +11.568% | +3.992% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.491% | +0.584% | +9.827% | +12.318% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.410% | +0.343% | +1.396% | +3.809% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.439% | +0.384% | +27.290% | +7.700% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.225% | +0.382% | +6.013% | +4.506% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.941% | +1.087% | +16.123% | +7.117% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.646% | -1.651% | +1.249% | +0.354% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.692% | +1.672% | +6.578% | +1.769% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.194% | +0.112% | +5.391% | +6.411% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.385% | +1.131% | +4.324% | +4.581% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.294% | +1.172% | +2.695% | +8.652% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.359% | +0.314% | +12.684% | +7.727% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.682% | -0.504% | +10.321% | +6.560% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.897% | +0.171% | +11.863% | +9.327% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.874% | -0.262% | +12.410% | +10.415% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.918% | -0.310% | +21.957% | +9.688% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.138% | +0.759% | +6.904% | +5.598% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 2.173% | -0.406% | +1.916% | -1.407% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 4.357% | -1.189% | +9.282% | +17.486% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.687% | +0.189% | -0.728% | +15.917% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.674% | -1.231% | +6.992% | +8.214% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.197% | +0.166% | +5.818% | +7.962% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.975% | -1.894% | +1.772% | +6.938% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.396% | -0.745% | -6.387% | +11.747% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 2.230% | -0.109% | +6.470% | +8.414% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-up-64-flat-results-for-python-master-branch-2017-07-19 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Wed Jul 19 19:27:07 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 16:27:07 -0700 Subject: [Python-checkins] [python/cpython] ed014f: bpo-30917: IDLE: Fix mock_config deepcopy to read_... Message-ID: <596feacb70200_79b33fdc7eeb9c3c39334@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: ed014f7e135fe021837208960237d6c37afde5be https://github.com/python/cpython/commit/ed014f7e135fe021837208960237d6c37afde5be Author: Louie Lu Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: M Lib/idlelib/idle_test/test_config.py Log Message: ----------- bpo-30917: IDLE: Fix mock_config deepcopy to read_string (#2754) Patch by LouieLu. From noreply at github.com Wed Jul 19 20:01:15 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 17:01:15 -0700 Subject: [Python-checkins] [python/cpython] 856cbc: bpo-29403: Fix mock's broken autospec behavior on ... Message-ID: <596ff2cb8bab7_56333f955d613c309527f@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10 https://github.com/python/cpython/commit/856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10 Author: Aaron Gallagher Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Lib/unittest/mock.py M Lib/unittest/test/testmock/testhelpers.py A Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst Log Message: ----------- bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Cython will, in the right circumstances, offer a MethodType instance where im_func is a builtin function. Any instance of MethodType is automatically assumed to be a Python-defined function (more specifically, a function that has an inspectable signature), but _set_signature was still conservative in its assumptions. As a result _set_signature would return early with None instead of a mock since the im_func had no inspectable signature. This causes problems deeper inside mock, as _set_signature is assumed to _always_ return a mock, and nothing checked its return value. In similar corner cases, autospec will simply not check the spec of the function, so _set_signature is amended to now return early with the original, not-wrapped mock object. Patch by Aaron Gallagher. From noreply at github.com Wed Jul 19 20:20:40 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 17:20:40 -0700 Subject: [Python-checkins] [python/cpython] aca493: [3.5] bpo-30883: Use pythontest.net instead of deb... Message-ID: <596ff758644f2_264d3f9ec392dc30928df@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: aca493b7a337338fa20395fbc2d1895cb8093826 https://github.com/python/cpython/commit/aca493b7a337338fa20395fbc2d1895cb8093826 Author: Ammar Askar Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Lib/test/test_urllib2net.py Log Message: ----------- [3.5] bpo-30883: Use pythontest.net instead of debian.org in test_urllib2net (GH-2755) From noreply at github.com Wed Jul 19 20:21:10 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 17:21:10 -0700 Subject: [Python-checkins] [python/cpython] ae4dca: [3.6] bpo-30883: Use pythontest.net instead of deb... Message-ID: <596ff776bee7e_79b33fdc7eeb9c3c397ad@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: ae4dca7701ca77a37aa8c956450ff8e21fe6883e https://github.com/python/cpython/commit/ae4dca7701ca77a37aa8c956450ff8e21fe6883e Author: Ammar Askar Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Lib/test/test_urllib2net.py Log Message: ----------- [3.6] bpo-30883: Use pythontest.net instead of debian.org in test_urllib2net (GH-2755) From noreply at github.com Wed Jul 19 20:45:37 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 17:45:37 -0700 Subject: [Python-checkins] [python/cpython] 9f9192: bpo-30968: Fix test_get_font in IDLE's test_conf... Message-ID: <596ffd31a8ce5_24d73fbf0cc1bc30137165@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 9f9192afbb4e45d09f0d3d717b457d157dc46398 https://github.com/python/cpython/commit/9f9192afbb4e45d09f0d3d717b457d157dc46398 Author: terryjreedy Date: 2017-07-19 (Wed, 19 Jul 2017) Changed paths: M Lib/idlelib/idle_test/test_config.py Log Message: ----------- bpo-30968: Fix test_get_font in IDLE's test_config. (#2769) From noreply at github.com Thu Jul 20 01:23:01 2017 From: noreply at github.com (GitHub) Date: Wed, 19 Jul 2017 22:23:01 -0700 Subject: [Python-checkins] [python/cpython] 65c24c: [3.6] bpo-30917: IDLE: Add config.IdleConf unittes... Message-ID: <59703e35989cd_12def3fd72f2d7c381192b9@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 65c24c846797b93d7adb72fc400f95a570f43fa9 https://github.com/python/cpython/commit/65c24c846797b93d7adb72fc400f95a570f43fa9 Author: terryjreedy Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Lib/idlelib/config.py M Lib/idlelib/idle_test/test_config.py A Misc/NEWS.d/next/IDLE/2017-07-17-23-35-57.bpo-30917.hSiuuO.rst Log Message: ----------- [3.6] bpo-30917: IDLE: Add config.IdleConf unittests (GH-2691) (#2753) Patch by Louie Lu. (cherry picked from commit f776eb0) (includes diffs of ed014f7 and 9f9192a) * fix config reset from pr 2754 * Fix test_get_font (from pr 2769) From noreply at github.com Thu Jul 20 03:58:47 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 00:58:47 -0700 Subject: [Python-checkins] [python/cpython] 5bffcf: Update doc download files size estimates. (#2771) Message-ID: <597062b7deb8f_1cb0a3f89ea1d7c30405b5@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 5bffcf38aae9b2f42f4e39ff5be8c406bbdf6684 https://github.com/python/cpython/commit/5bffcf38aae9b2f42f4e39ff5be8c406bbdf6684 Author: Ned Deily Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/tools/templates/download.html Log Message: ----------- Update doc download files size estimates. (#2771) From noreply at github.com Thu Jul 20 04:19:24 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 01:19:24 -0700 Subject: [Python-checkins] [python/cpython] e0d306: Update doc download files size estimates. (#2771) ... Message-ID: <5970678caa480_3f403fb6f15dbc44437ad@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: e0d306f682816df352b903c9b785d684ac8a87a5 https://github.com/python/cpython/commit/e0d306f682816df352b903c9b785d684ac8a87a5 Author: Ned Deily Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/tools/templates/download.html Log Message: ----------- Update doc download files size estimates. (#2771) (#2772) From noreply at github.com Thu Jul 20 04:34:18 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 01:34:18 -0700 Subject: [Python-checkins] [python/cpython] 6b1a77: Update doc download files size estimates. (#2771) ... Message-ID: <59706b0a74928_1cec73fbf43b9fc3477489@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 6b1a777b58e66e4763913e9468995070ecf21982 https://github.com/python/cpython/commit/6b1a777b58e66e4763913e9468995070ecf21982 Author: Ned Deily Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/tools/templates/download.html Log Message: ----------- Update doc download files size estimates. (#2771) (#2773) From noreply at github.com Thu Jul 20 04:45:43 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 01:45:43 -0700 Subject: [Python-checkins] [python/cpython] 3b1e72: Update doc download files size estimates. (#2774) Message-ID: <59706db7a87b8_3ca33fcf09f87c409686@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 3b1e72662ac36cd980d2a74c87b88ce7c2e8c1b6 https://github.com/python/cpython/commit/3b1e72662ac36cd980d2a74c87b88ce7c2e8c1b6 Author: Ned Deily Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/tools/templates/download.html Log Message: ----------- Update doc download files size estimates. (#2774) From solipsis at pitrou.net Thu Jul 20 05:07:16 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Thu, 20 Jul 2017 09:07:16 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=12 Message-ID: <20170720090714.75771.6C78447DDD9744E0@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 0, 7] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [0, -1, 2] memory blocks, sum=1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogapE33J', '--timeout', '7200'] From noreply at github.com Thu Jul 20 09:46:34 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 06:46:34 -0700 Subject: [Python-checkins] [python/cpython] 5b392b: bpo-30822: Exclude tzdata from regrtest --all (#27... Message-ID: <5970b43a69063_1b053fdeb0423c4441423@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 5b392bbaeb9d9b1db961ecfc7315d8c8662c27f6 https://github.com/python/cpython/commit/5b392bbaeb9d9b1db961ecfc7315d8c8662c27f6 Author: Victor Stinner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M .travis.yml M Lib/test/libregrtest/__init__.py M Lib/test/libregrtest/cmdline.py M Lib/test/test_regrtest.py A Misc/NEWS.d/next/Tests/2017-07-20-14-29-54.bpo-30822.X0wREo.rst Log Message: ----------- bpo-30822: Exclude tzdata from regrtest --all (#2775) When running the test suite using --use=all / -u all, exclude tzdata since it makes test_datetime too slow (15-20 min on some buildbots) which then times out on some buildbots. -u tzdata must now be enabled explicitly, -u tzdata or -u all,tzdata, to run all test_datetime tests. Fix also regrtest command line parser to allow passing -u extralargefile to run test_zipfile64. Travis CI: remove -tzdata. Replace -u all,-tzdata,-cpu with -u all,-cpu since tzdata is now excluded from -u all. From noreply at github.com Thu Jul 20 09:58:42 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 06:58:42 -0700 Subject: [Python-checkins] [python/cpython] fff2a2: Fix typo in Turtle Docs: yingyang -> yinyang (GH-2... Message-ID: <5970b712421cd_29ee3fbfb4cf5c34639bf@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: fff2a21057b98732562098e3bdd65980551f0135 https://github.com/python/cpython/commit/fff2a21057b98732562098e3bdd65980551f0135 Author: ?? <260893248 at qq.com> Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/library/turtle.rst Log Message: ----------- Fix typo in Turtle Docs: yingyang -> yinyang (GH-2770) From noreply at github.com Thu Jul 20 10:14:06 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 07:14:06 -0700 Subject: [Python-checkins] [python/cpython] 7f5899: [3.6] Fix typo in Turtle Docs: yingyang -> yinyang... Message-ID: <5970baaeb045a_5a1d3ff5eb8a1c38227ce@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 7f58994842d930ed5f92386579997871d2a3bb48 https://github.com/python/cpython/commit/7f58994842d930ed5f92386579997871d2a3bb48 Author: Mariatta Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/library/turtle.rst Log Message: ----------- [3.6] Fix typo in Turtle Docs: yingyang -> yinyang (GH-2770) (GH-2778) (cherry picked from commit fff2a21057b98732562098e3bdd65980551f0135) From noreply at github.com Thu Jul 20 10:14:20 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 07:14:20 -0700 Subject: [Python-checkins] [python/cpython] 71d9b5: [3.5] Fix typo in Turtle Docs: yingyang -> yinyang... Message-ID: <5970babc9143_50a33f840f0e1c44126d0@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 71d9b52aa3b3f1e390c56da8ea2d8685f23946c4 https://github.com/python/cpython/commit/71d9b52aa3b3f1e390c56da8ea2d8685f23946c4 Author: Mariatta Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/library/turtle.rst Log Message: ----------- [3.5] Fix typo in Turtle Docs: yingyang -> yinyang (GH-2770) (GH-2779) (cherry picked from commit fff2a21057b98732562098e3bdd65980551f0135) From noreply at github.com Thu Jul 20 10:14:47 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 07:14:47 -0700 Subject: [Python-checkins] [python/cpython] 598f26: [2.7] Fix typo in Turtle Docs: yingyang -> yinyang... Message-ID: <5970bad7e76de_161f3fe1f067bc3864144@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 598f26b788ef666cced17a118d6a65d6210e3ccc https://github.com/python/cpython/commit/598f26b788ef666cced17a118d6a65d6210e3ccc Author: Mariatta Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/library/turtle.rst Log Message: ----------- [2.7] Fix typo in Turtle Docs: yingyang -> yinyang (GH-2770) (GH-2780) (cherry picked from commit fff2a21057b98732562098e3bdd65980551f0135) From noreply at github.com Thu Jul 20 11:08:53 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 08:08:53 -0700 Subject: [Python-checkins] [python/cpython] 645e50: bpo-30822: Exclude tzdata from regrtest --all (#27... Message-ID: <5970c785a26e2_29af3fe74f3e9c2c10042b@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: 645e503ba58086c7f51eda4d025743f2afc05a2a https://github.com/python/cpython/commit/645e503ba58086c7f51eda4d025743f2afc05a2a Author: Victor Stinner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: A Lib/test/libregrtest/__init__.py M Lib/test/regrtest.py M Lib/test/test_regrtest.py A Misc/NEWS.d/next/Tests/2017-07-20-14-29-54.bpo-30822.X0wREo.rst Log Message: ----------- bpo-30822: Exclude tzdata from regrtest --all (#2775) (#2781) When running the test suite using --use=all / -u all, exclude tzdata since it makes test_datetime too slow (15-20 min on some buildbots) which then times out on some buildbots. -u tzdata must now be enabled explicitly, -u tzdata or -u all,tzdata, to run all test_datetime tests. Fix also regrtest command line parser to allow passing -u extralargefile to run test_zipfile64. Travis CI: remove -tzdata. Replace -u all,-tzdata,-cpu with -u all,-cpu since tzdata is now excluded from -u all. (cherry picked from commit 5b392bbaeb9d9b1db961ecfc7315d8c8662c27f6) From noreply at github.com Thu Jul 20 11:08:50 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 08:08:50 -0700 Subject: [Python-checkins] [python/cpython] 96ef06: bpo-30822: Exclude tzdata from regrtest --all (#27... Message-ID: <5970c782419e4_28453fb99bcdbc2c1875e@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 96ef06f3979023fd69ed8796d0b1d88885d3ae4d https://github.com/python/cpython/commit/96ef06f3979023fd69ed8796d0b1d88885d3ae4d Author: Victor Stinner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M .travis.yml M Lib/test/libregrtest/__init__.py M Lib/test/libregrtest/cmdline.py M Lib/test/test_regrtest.py A Misc/NEWS.d/next/Tests/2017-07-20-14-29-54.bpo-30822.X0wREo.rst Log Message: ----------- bpo-30822: Exclude tzdata from regrtest --all (#2775) (#2777) When running the test suite using --use=all / -u all, exclude tzdata since it makes test_datetime too slow (15-20 min on some buildbots) which then times out on some buildbots. -u tzdata must now be enabled explicitly, -u tzdata or -u all,tzdata, to run all test_datetime tests. Fix also regrtest command line parser to allow passing -u extralargefile to run test_zipfile64. Travis CI: remove -tzdata. Replace -u all,-tzdata,-cpu with -u all,-cpu since tzdata is now excluded from -u all. (cherry picked from commit 5b392bbaeb9d9b1db961ecfc7315d8c8662c27f6) From noreply at github.com Thu Jul 20 12:08:56 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 09:08:56 -0700 Subject: [Python-checkins] [python/cpython] bf3a1e: bpo-30822: regrtest: remove tzdata (#2782) Message-ID: <5970d598a39c4_659e3f96866b3c3859916@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: bf3a1e973b49236e6f267cca135d36290568e6a4 https://github.com/python/cpython/commit/bf3a1e973b49236e6f267cca135d36290568e6a4 Author: Victor Stinner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: R Lib/test/libregrtest/__init__.py M Lib/test/regrtest.py M Lib/test/test_regrtest.py M Misc/NEWS.d/next/Tests/2017-07-20-14-29-54.bpo-30822.X0wREo.rst Log Message: ----------- bpo-30822: regrtest: remove tzdata (#2782) * Oops, tzdata was introduced in Python 3.6: remove it from regrtest * Remove also Lib/test/libregrtest/__init__.py file: add by mistake on a backport. From noreply at github.com Thu Jul 20 14:04:51 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 11:04:51 -0700 Subject: [Python-checkins] [python/cpython] b5f20e: [3.3] Backport CI config from master and remove sk... Message-ID: <5970f0c39ed3a_74bd3fc06810dc3c60468@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.3 Home: https://github.com/python/cpython Commit: b5f20ea91ec4d9dc7e1c31629903888c651bd02c https://github.com/python/cpython/commit/b5f20ea91ec4d9dc7e1c31629903888c651bd02c Author: Victor Stinner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: A .travis.yml M Lib/test/test_imaplib.py Log Message: ----------- [3.3] Backport CI config from master and remove skipped imaplib tests (#2481) * Backport Travis CI config from master Add .travis.yml for Travis CI. * bpo-30231: Remove skipped test_imaplib tests (#1419) (#2193) The public cyrus.andrew.cmu.edu IMAP server (port 993) doesn't accept TLS connection using our self-signed x509 certificate. Remove the two tests which are already skipped. (cherry picked from commit 7895a0585b4b6a1c8082d17227307c6ce2c8bb8b) From lp_benchmark_robot at intel.com Thu Jul 20 19:05:19 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Thu, 20 Jul 2017 16:05:19 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-20 Message-ID: Results for project python/master, build date: 2017-07-20 03:04:27-07:00. - commit: 5bffcf3 - previous commit: d81bea6 - revision date: 2017-07-20 03:58:46-04:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.159% | +0.305% | +4.868% | +6.856% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.958% | -0.252% | +24.417% | +4.080% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 3.238% | -1.009% | +24.348% | +3.634% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.183% | +0.395% | +22.902% | +0.553% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.364% | -0.030% | +6.072% | +9.548% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.966% | +0.070% | +11.325% | +10.065% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 2.719% | +0.386% | +7.900% | +8.285% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.474% | +0.108% | +5.387% | +4.275% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 4.412% | -0.553% | +6.138% | +18.141% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 5.167% | +0.972% | +9.748% | +11.836% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.160% | +0.256% | +4.050% | +5.974% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.803% | +0.103% | +4.971% | +6.294% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.251% | -0.036% | +3.504% | +4.483% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.448% | +0.307% | +9.561% | +9.871% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.687% | -0.232% | +6.652% | +9.343% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.972% | +0.205% | +7.674% | +7.751% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.480% | +0.075% | +10.534% | +10.079% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.610% | +0.776% | +9.867% | +8.056% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.456% | +0.434% | +3.411% | +9.379% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 5.346% | -0.449% | +1.454% | +12.337% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.376% | +0.978% | +8.683% | +7.856% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.071% | +0.213% | +9.449% | +13.508% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.961% | +0.237% | +8.740% | +9.817% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.654% | -0.254% | +18.178% | +12.316% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.935% | -1.378% | +3.645% | +15.423% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.384% | -0.199% | +4.649% | +4.650% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 1.316% | -0.067% | -2.853% | +3.565% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.728% | -0.148% | +2.537% | +7.513% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.402% | +0.549% | +3.150% | +10.591% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.517% | +0.142% | +3.182% | +20.995% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.343% | -0.086% | +2.284% | +20.655% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.833% | +0.392% | +6.150% | +18.829% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 2.536% | +0.173% | +12.904% | +8.112% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.317% | -0.033% | +0.329% | +10.040% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.121% | +0.080% | +9.788% | +4.112% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.089% | +0.043% | +1.444% | +3.987% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.407% | +0.136% | +10.131% | +10.343% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.015% | +1.018% | -7.201% | +10.202% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.298% | +0.308% | +2.237% | +9.062% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.104% | +0.041% | -2.417% | +4.632% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.443% | -0.048% | +11.526% | +3.911% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.282% | +0.502% | +10.279% | +10.210% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 1.369% | -0.397% | +1.004% | +2.240% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 3.214% | -0.843% | +26.677% | +8.925% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.509% | -0.048% | +5.968% | +3.319% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.644% | +0.106% | +16.212% | +5.857% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.804% | -0.170% | +1.081% | -4.536% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.689% | -0.033% | +6.548% | +1.937% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 0.997% | +0.020% | +5.409% | +6.930% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.041% | +0.337% | +4.647% | +4.741% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.078% | -0.692% | +2.022% | +8.717% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.383% | +0.025% | +12.706% | +8.152% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.775% | +0.366% | +10.649% | +5.645% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.409% | +0.478% | +12.284% | +8.982% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.967% | -0.492% | +11.979% | +11.226% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.436% | -0.792% | +21.339% | +11.365% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.039% | +0.100% | +6.997% | +2.357% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.225% | +0.078% | +1.993% | -1.736% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.163% | -1.684% | +7.754% | +21.907% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.006% | -0.294% | -1.024% | +19.277% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.618% | +0.025% | +7.015% | +7.375% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.881% | +0.191% | +5.998% | +7.530% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.582% | -0.270% | +1.507% | +6.443% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.938% | +0.506% | -5.849% | +10.122% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.395% | +0.205% | +6.662% | +7.456% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-20 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Thu Jul 20 20:12:17 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 17:12:17 -0700 Subject: [Python-checkins] [python/cpython] 80ebc4: bpo-30822: regrtest: fix -u extralargefile (#2788) Message-ID: <597146e140982_6da53fba728b5c3892136@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 80ebc438ed377f8c6491e8887425526c6787c0e7 https://github.com/python/cpython/commit/80ebc438ed377f8c6491e8887425526c6787c0e7 Author: Victor Stinner Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/test/regrtest.py A Misc/NEWS.d/next/Tests/2017-07-20-14-29-54.bpo-30822.X0wREo.rst Log Message: ----------- bpo-30822: regrtest: fix -u extralargefile (#2788) Fix also regrtest command line parser to allow passing -u extralargefile to run test_zipfile64. From noreply at github.com Thu Jul 20 20:14:56 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 17:14:56 -0700 Subject: [Python-checkins] [python/cpython] 287c55: bpo-30822: Fix testing of datetime module. (#2530)... Message-ID: <5971478010147_1fa1f3fab09531c38300f9@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 287c5594edc1ca08db64d1f4739cc36bfe75ae75 https://github.com/python/cpython/commit/287c5594edc1ca08db64d1f4739cc36bfe75ae75 Author: Utkarsh Upadhyay Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Misc/ACKS Log Message: ----------- bpo-30822: Fix testing of datetime module. (#2530) (#2783) Only C implementation was tested. From noreply at github.com Thu Jul 20 23:10:57 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 20:10:57 -0700 Subject: [Python-checkins] [python/cpython] ef4231: bpo-30466: Add brief explanation of classes to tut... Message-ID: <597170c1e9058_1c283fbd030f7c381063de@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: ef4231adb7aa6b323c94e854ac3dc3bebc841115 https://github.com/python/cpython/commit/ef4231adb7aa6b323c94e854ac3dc3bebc841115 Author: Trey Hunner Date: 2017-07-20 (Thu, 20 Jul 2017) Changed paths: M Doc/tutorial/classes.rst Log Message: ----------- bpo-30466: Add brief explanation of classes to tutorial (GH-1804) (GH-2700) From noreply at github.com Thu Jul 20 23:51:56 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 20:51:56 -0700 Subject: [Python-checkins] [python/cpython] b3527b: bpo-30964: Mention ensurepip in package installati... Message-ID: <59717a5ce0a48_762e3fd191f5dc44186bb@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: b3527bfefd7a0188d43a2d7515ac6addd97a8202 https://github.com/python/cpython/commit/b3527bfefd7a0188d43a2d7515ac6addd97a8202 Author: Nicholas Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Doc/installing/index.rst M Misc/ACKS Log Message: ----------- bpo-30964: Mention ensurepip in package installation docs (GH-2786) Adds a new 'Pip not installed' section that covers running `ensurepip` manually, and also references the relevant section of the Python Packaging User Guide. From noreply at github.com Fri Jul 21 01:06:59 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 22:06:59 -0700 Subject: [Python-checkins] [python/cpython] a54a8f: bpo-28523: IDLE: Use 'color' instead of 'colour'. ... Message-ID: <59718bf3c1660_20003fa56b369c3c2842e@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: a54a8f188a803cd41bdc8758c10d34ba3328c566 https://github.com/python/cpython/commit/a54a8f188a803cd41bdc8758c10d34ba3328c566 Author: Terry Jan Reedy Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-21-00-54-52.bpo-28523.OPcqYJ.rst Log Message: ----------- bpo-28523: IDLE: Use 'color' instead of 'colour'. (#2787) From noreply at github.com Fri Jul 21 01:29:11 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 22:29:11 -0700 Subject: [Python-checkins] [python/cpython] ac5c1e: [3.6] bpo-28523: IDLE: Use 'color' instead of 'col... Message-ID: <597191275a298_382a3f977d341c38885bc@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: ac5c1e2ea311d11714f89476c86936f9388d19a4 https://github.com/python/cpython/commit/ac5c1e2ea311d11714f89476c86936f9388d19a4 Author: Terry Jan Reedy Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-21-00-54-52.bpo-28523.OPcqYJ.rst Log Message: ----------- [3.6] bpo-28523: IDLE: Use 'color' instead of 'colour'. (GH-2787) (#2791) (cherry picked from commit a54a8f1) From noreply at github.com Fri Jul 21 02:20:47 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 23:20:47 -0700 Subject: [Python-checkins] [python/cpython] d0969d: bpo-30981: IDLE -- Add more configdialog font page... Message-ID: <59719d3fa721f_35e33f8a6e429c3495761@hookshot-fe3-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: d0969d69245d9c4eea3498ba4bde4b4cd676ad7f https://github.com/python/cpython/commit/d0969d69245d9c4eea3498ba4bde4b4cd676ad7f Author: Terry Jan Reedy Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst Log Message: ----------- bpo-30981: IDLE -- Add more configdialog font page tests. (#2794) From noreply at github.com Fri Jul 21 02:29:45 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 23:29:45 -0700 Subject: [Python-checkins] [python/cpython] 82a77d: [2.7] bpo-30964: Mention ensurepip in package inst... Message-ID: <59719f59b7625_65273ff2fe247c38921b3@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/2.7 Home: https://github.com/python/cpython Commit: 82a77d38d6dc7df740e7b01b66aeff433730e9ca https://github.com/python/cpython/commit/82a77d38d6dc7df740e7b01b66aeff433730e9ca Author: Nicholas Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Doc/installing/index.rst M Misc/ACKS Log Message: ----------- [2.7] bpo-30964: Mention ensurepip in package installation docs (GH-2795) Adds a new 'Pip not installed' section that covers running `ensurepip` manually, and also references the relevant section of the Python Packaging User Guide. (cherry picked from commit b3527bfefd7a0188d43a2d7515ac6addd97a8202) From noreply at github.com Fri Jul 21 02:44:44 2017 From: noreply at github.com (GitHub) Date: Thu, 20 Jul 2017 23:44:44 -0700 Subject: [Python-checkins] [python/cpython] df5837: [3.6] bpo-30964: Mention ensurepip in package inst... Message-ID: <5971a2dca5845_1b0c3f86088bfc2c5155f@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: df5837b5a916aac645087ae02c44e88ff77024ef https://github.com/python/cpython/commit/df5837b5a916aac645087ae02c44e88ff77024ef Author: Nicholas Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Doc/installing/index.rst M Misc/ACKS Log Message: ----------- [3.6] bpo-30964: Mention ensurepip in package installation docs (GH-2797) Adds a new 'Pip not installed' section that covers running `ensurepip` manually, and also references the relevant section of the Python Packaging User Guide. (cherry picked from commit b3527bfefd7a0188d43a2d7515ac6addd97a8202) From noreply at github.com Fri Jul 21 03:47:02 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 00:47:02 -0700 Subject: [Python-checkins] [python/cpython] 7c5798: bpo-30981: temporarity skip failing IDLE test clas... Message-ID: <5971b176aea24_1fbe83fd2a246bc34243ed@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 7c5798ebfa9b822d6cedf1fc8c034f6ea90644dc https://github.com/python/cpython/commit/7c5798ebfa9b822d6cedf1fc8c034f6ea90644dc Author: Terry Jan Reedy Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- bpo-30981: temporarity skip failing IDLE test class (#2798) From solipsis at pitrou.net Fri Jul 21 05:14:36 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Fri, 21 Jul 2017 09:14:36 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=4 Message-ID: <20170721090928.82378.F6018A56902D9305@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogIsVVPg', '--timeout', '7200'] From noreply at github.com Fri Jul 21 06:35:34 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 03:35:34 -0700 Subject: [Python-checkins] [python/cpython] 3913ba: bpo-19896: Add typecodes 'q' and 'Q' to multiproce... Message-ID: <5971d8f694080_747b3fd7979cdc284216e@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 3913bad4957ac30e58a7ffe9279333ad176a8eea https://github.com/python/cpython/commit/3913bad4957ac30e58a7ffe9279333ad176a8eea Author: Gareth Rees Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/multiprocessing/sharedctypes.py M Lib/test/_test_multiprocessing.py A Misc/NEWS.d/next/Library/2017-07-18-13-24-50.bpo-19896.-S0IWu.rst Log Message: ----------- bpo-19896: Add typecodes 'q' and 'Q' to multiprocessing.sharedctypes (#2741) * bpo-19896: Add typcodes 'q' and 'Q' to multiprocessing.sharedctypes. Patch by Antony Lee. * Add NEWS entry. * Slightly tweak NEWS entry Make it clear this is more of a fix rather than a new feature. From noreply at github.com Fri Jul 21 07:00:48 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 04:00:48 -0700 Subject: [Python-checkins] [python/cpython] e72b13: bpo-30891: Fix again importlib _find_and_load() (#... Message-ID: <5971dee03d0f4_7f593fcfa9d07c2c417fa@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: e72b1359f81d1dd42bd8a5c5cc2b3928b74f8023 https://github.com/python/cpython/commit/e72b1359f81d1dd42bd8a5c5cc2b3928b74f8023 Author: Victor Stinner Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Python/importlib.h Log Message: ----------- bpo-30891: Fix again importlib _find_and_load() (#2665) Use sys.modules.get() in the "with _ModuleLockManager(name):" block to protect the dictionary key with the module lock and use an atomic get to prevent race condition. Remove also _bootstrap._POPULATE since it was unused (_bootstrap_external now has its own _POPULATE object), add a new _SENTINEL object instead. From noreply at github.com Fri Jul 21 07:24:07 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 04:24:07 -0700 Subject: [Python-checkins] [python/cpython] ff92ff: Fix test failure without ctypes (#2802) Message-ID: <5971e457195e9_2f273ff089b73c3436472@hookshot-fe5-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: ff92ff53665b1606a17231972b48ad894459f761 https://github.com/python/cpython/commit/ff92ff53665b1606a17231972b48ad894459f761 Author: Antoine Pitrou Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/test/_test_multiprocessing.py Log Message: ----------- Fix test failure without ctypes (#2802) From noreply at github.com Fri Jul 21 07:28:57 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 04:28:57 -0700 Subject: [Python-checkins] [python/cpython] bb323b: bpo-30891: Fix again importlib _find_and_load() (#... Message-ID: <5971e57966577_1f9083fdb0d7e1c384772f@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: bb323b261d0f41ad6998d3a16c41b29b3bb8e982 https://github.com/python/cpython/commit/bb323b261d0f41ad6998d3a16c41b29b3bb8e982 Author: Victor Stinner Date: 2017-07-21 (Fri, 21 Jul 2017) Changed paths: M Lib/importlib/_bootstrap.py M Python/importlib.h Log Message: ----------- bpo-30891: Fix again importlib _find_and_load() (#2665) (#2801) Use sys.modules.get() in the "with _ModuleLockManager(name):" block to protect the dictionary key with the module lock and use an atomic get to prevent race condition. Remove also _bootstrap._POPULATE since it was unused (_bootstrap_external now has its own _POPULATE object), add a new _SENTINEL object instead. (cherry picked from commit e72b1359f81d1dd42bd8a5c5cc2b3928b74f8023) From lp_benchmark_robot at intel.com Fri Jul 21 18:07:21 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Fri, 21 Jul 2017 15:07:21 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-21 Message-ID: <9b52eac8-23be-4101-a264-f2429d8db625@orsmsx102.amr.corp.intel.com> Results for project python/master, build date: 2017-07-21 03:04:30-07:00. - commit: 7c5798e - previous commit: 5bffcf3 - revision date: 2017-07-21 03:47:01-04:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.105% | +0.093% | +4.957% | +6.344% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.894% | -0.340% | +24.160% | +10.873% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 2.888% | +0.685% | +24.866% | +10.339% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.522% | -0.653% | +22.398% | +8.511% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.543% | -0.583% | +5.524% | +11.245% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.241% | +0.370% | +11.653% | +10.342% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.790% | +0.633% | +8.483% | +8.052% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.577% | +0.094% | +5.476% | +4.885% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.893% | +0.673% | +6.769% | +18.738% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.199% | -0.021% | +9.729% | +11.983% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.031% | +0.085% | +4.131% | +6.259% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 1.258% | -0.109% | +4.867% | +4.810% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.751% | +0.176% | +3.674% | +6.077% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 2.399% | -0.269% | +9.317% | +11.284% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.556% | +0.179% | +6.819% | +10.960% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.831% | -0.138% | +7.547% | +9.425% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.432% | +0.224% | +10.735% | +9.809% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.663% | -0.455% | +9.457% | +7.392% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.626% | -0.209% | +3.209% | +10.369% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 2.432% | +0.473% | +1.920% | +9.153% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.929% | -1.455% | +7.355% | +9.759% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.152% | -0.572% | +8.931% | +15.836% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.807% | -0.467% | +8.314% | +10.612% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.608% | +0.079% | +18.243% | +12.377% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.832% | -0.160% | +3.491% | +15.690% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.880% | -0.388% | +4.279% | +5.522% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.630% | +0.026% | -2.826% | +2.329% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.981% | -0.400% | +2.147% | +7.383% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.013% | -0.035% | +3.116% | +12.571% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 1.272% | +0.382% | +3.552% | +20.613% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.628% | -0.116% | +2.171% | +15.788% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.689% | -0.180% | +5.981% | +16.122% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.676% | +0.030% | +12.930% | +8.008% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.334% | -0.024% | +0.306% | +10.157% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.127% | -0.030% | +9.760% | +4.053% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.091% | -0.011% | +1.432% | +4.188% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.616% | +0.085% | +10.208% | +12.160% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.158% | -1.833% | -9.166% | +10.712% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 2.044% | -0.777% | +1.478% | +8.012% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.121% | +0.866% | -1.529% | +3.373% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.603% | +0.749% | +12.189% | +3.739% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 2.585% | -1.262% | +9.147% | +12.835% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.498% | +0.154% | +1.157% | +1.023% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.015% | +0.256% | +26.865% | +8.071% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.833% | -0.250% | +5.732% | +5.773% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.903% | +0.008% | +16.219% | +7.314% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 0.989% | +0.535% | +1.611% | -6.971% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.579% | -0.030% | +6.520% | +0.972% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.180% | +0.326% | +5.718% | +5.507% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.647% | -0.423% | +4.243% | +4.594% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.389% | -0.184% | +1.841% | +8.720% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.127% | +0.793% | +13.398% | +6.350% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.794% | -0.182% | +10.486% | +5.589% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.576% | +0.730% | +12.924% | +7.178% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.767% | +1.560% | +13.352% | +8.221% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 3.497% | +1.783% | +22.741% | +8.913% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.120% | +0.033% | +7.028% | +4.761% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.171% | +0.081% | +2.072% | -0.573% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 6.167% | +0.857% | +8.545% | +20.817% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.997% | -0.077% | -1.102% | +18.153% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.624% | -0.290% | +6.746% | +8.120% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.971% | -0.178% | +5.831% | +7.724% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.686% | -0.284% | +1.227% | +7.212% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.051% | +0.119% | -5.723% | +10.401% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.241% | +0.189% | +6.838% | +7.272% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-21 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From noreply at github.com Fri Jul 21 18:31:05 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 15:31:05 -0700 Subject: [Python-checkins] [python/cpython] 64b9a1: [3.6] bpo-29403: Fix mock's broken autospec behavi... Message-ID: <597280a9c288a_201fa3fad28e4bc441170@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 64b9a15886840df422c5203fad25c9801b4cf61e https://github.com/python/cpython/commit/64b9a15886840df422c5203fad25c9801b4cf61e Author: Berker Peksag Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/unittest/mock.py M Lib/unittest/test/testmock/testhelpers.py A Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst Log Message: ----------- [3.6] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Cython will, in the right circumstances, offer a MethodType instance where im_func is a builtin function. Any instance of MethodType is automatically assumed to be a Python-defined function (more specifically, a function that has an inspectable signature), but _set_signature was still conservative in its assumptions. As a result _set_signature would return early with None instead of a mock since the im_func had no inspectable signature. This causes problems deeper inside mock, as _set_signature is assumed to _always_ return a mock, and nothing checked its return value. In similar corner cases, autospec will simply not check the spec of the function, so _set_signature is amended to now return early with the original, not-wrapped mock object. Patch by Aaron Gallagher. (cherry picked from commit 856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10) From webhook-mailer at python.org Fri Jul 21 18:31:07 2017 From: webhook-mailer at python.org (Berker Peksag) Date: Fri, 21 Jul 2017 22:31:07 -0000 Subject: [Python-checkins] [3.6] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Message-ID: https://github.com/python/cpython/commit/64b9a15886840df422c5203fad25c9801b4cf61e commit: 64b9a15886840df422c5203fad25c9801b4cf61e branch: 3.6 author: Berker Peksag committer: GitHub date: 2017-07-22T01:31:04+03:00 summary: [3.6] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Cython will, in the right circumstances, offer a MethodType instance where im_func is a builtin function. Any instance of MethodType is automatically assumed to be a Python-defined function (more specifically, a function that has an inspectable signature), but _set_signature was still conservative in its assumptions. As a result _set_signature would return early with None instead of a mock since the im_func had no inspectable signature. This causes problems deeper inside mock, as _set_signature is assumed to _always_ return a mock, and nothing checked its return value. In similar corner cases, autospec will simply not check the spec of the function, so _set_signature is amended to now return early with the original, not-wrapped mock object. Patch by Aaron Gallagher. (cherry picked from commit 856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10) files: A Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst M Lib/unittest/mock.py M Lib/unittest/test/testmock/testhelpers.py diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py index 5f97728de28..6be7bb4f065 100644 --- a/Lib/unittest/mock.py +++ b/Lib/unittest/mock.py @@ -165,7 +165,7 @@ def _set_signature(mock, original, instance=False): skipfirst = isinstance(original, type) result = _get_signature_object(original, instance, skipfirst) if result is None: - return + return mock func, sig = result def checksig(*args, **kwargs): sig.bind(*args, **kwargs) diff --git a/Lib/unittest/test/testmock/testhelpers.py b/Lib/unittest/test/testmock/testhelpers.py index d2202a7b413..7919482ae99 100644 --- a/Lib/unittest/test/testmock/testhelpers.py +++ b/Lib/unittest/test/testmock/testhelpers.py @@ -1,3 +1,5 @@ +import time +import types import unittest from unittest.mock import ( @@ -856,6 +858,19 @@ def check_data_descriptor(mock_attr): check_data_descriptor(foo.desc) + def test_autospec_on_bound_builtin_function(self): + meth = types.MethodType(time.ctime, time.time()) + self.assertIsInstance(meth(), str) + mocked = create_autospec(meth) + + # no signature, so no spec to check against + mocked() + mocked.assert_called_once_with() + mocked.reset_mock() + mocked(4, 5, 6) + mocked.assert_called_once_with(4, 5, 6) + + class TestCallList(unittest.TestCase): def test_args_list_contains_call_list(self): diff --git a/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst b/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst new file mode 100644 index 00000000000..95bcd1007de --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst @@ -0,0 +1,2 @@ +Fix ``unittest.mock``'s autospec to not fail on method-bound builtin +functions. Patch by Aaron Gallagher. From webhook-mailer at python.org Fri Jul 21 19:27:20 2017 From: webhook-mailer at python.org (Berker Peksag) Date: Fri, 21 Jul 2017 23:27:20 -0000 Subject: [Python-checkins] [3.5] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Message-ID: https://github.com/python/cpython/commit/e78dc0aaf03cd98373910150c2d35418cf938254 commit: e78dc0aaf03cd98373910150c2d35418cf938254 branch: 3.5 author: Berker Peksag committer: GitHub date: 2017-07-22T02:27:17+03:00 summary: [3.5] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Cython will, in the right circumstances, offer a MethodType instance where im_func is a builtin function. Any instance of MethodType is automatically assumed to be a Python-defined function (more specifically, a function that has an inspectable signature), but _set_signature was still conservative in its assumptions. As a result _set_signature would return early with None instead of a mock since the im_func had no inspectable signature. This causes problems deeper inside mock, as _set_signature is assumed to _always_ return a mock, and nothing checked its return value. In similar corner cases, autospec will simply not check the spec of the function, so _set_signature is amended to now return early with the original, not-wrapped mock object. Patch by Aaron Gallagher. (cherry picked from commit 856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10) files: A Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst M Lib/unittest/mock.py M Lib/unittest/test/testmock/testhelpers.py diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py index 99658d47a35..067df81a841 100644 --- a/Lib/unittest/mock.py +++ b/Lib/unittest/mock.py @@ -177,7 +177,7 @@ def _set_signature(mock, original, instance=False): skipfirst = isinstance(original, type) result = _get_signature_object(original, instance, skipfirst) if result is None: - return + return mock func, sig = result def checksig(*args, **kwargs): sig.bind(*args, **kwargs) diff --git a/Lib/unittest/test/testmock/testhelpers.py b/Lib/unittest/test/testmock/testhelpers.py index d2202a7b413..7919482ae99 100644 --- a/Lib/unittest/test/testmock/testhelpers.py +++ b/Lib/unittest/test/testmock/testhelpers.py @@ -1,3 +1,5 @@ +import time +import types import unittest from unittest.mock import ( @@ -856,6 +858,19 @@ def check_data_descriptor(mock_attr): check_data_descriptor(foo.desc) + def test_autospec_on_bound_builtin_function(self): + meth = types.MethodType(time.ctime, time.time()) + self.assertIsInstance(meth(), str) + mocked = create_autospec(meth) + + # no signature, so no spec to check against + mocked() + mocked.assert_called_once_with() + mocked.reset_mock() + mocked(4, 5, 6) + mocked.assert_called_once_with(4, 5, 6) + + class TestCallList(unittest.TestCase): def test_args_list_contains_call_list(self): diff --git a/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst b/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst new file mode 100644 index 00000000000..95bcd1007de --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst @@ -0,0 +1,2 @@ +Fix ``unittest.mock``'s autospec to not fail on method-bound builtin +functions. Patch by Aaron Gallagher. From noreply at github.com Fri Jul 21 19:27:18 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 16:27:18 -0700 Subject: [Python-checkins] [python/cpython] e78dc0: [3.5] bpo-29403: Fix mock's broken autospec behavi... Message-ID: <59728dd689317_1fc003fa6fb76bc2c7224f@hookshot-fe-6dbb0c4.cp1-iad.github.net.mail> Branch: refs/heads/3.5 Home: https://github.com/python/cpython Commit: e78dc0aaf03cd98373910150c2d35418cf938254 https://github.com/python/cpython/commit/e78dc0aaf03cd98373910150c2d35418cf938254 Author: Berker Peksag Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/unittest/mock.py M Lib/unittest/test/testmock/testhelpers.py A Misc/NEWS.d/next/Library/2017-07-20-02-29-49.bpo-29403.3RinCV.rst Log Message: ----------- [3.5] bpo-29403: Fix mock's broken autospec behavior on method-bound builtin functions (GH-3) Cython will, in the right circumstances, offer a MethodType instance where im_func is a builtin function. Any instance of MethodType is automatically assumed to be a Python-defined function (more specifically, a function that has an inspectable signature), but _set_signature was still conservative in its assumptions. As a result _set_signature would return early with None instead of a mock since the im_func had no inspectable signature. This causes problems deeper inside mock, as _set_signature is assumed to _always_ return a mock, and nothing checked its return value. In similar corner cases, autospec will simply not check the spec of the function, so _set_signature is amended to now return early with the original, not-wrapped mock object. Patch by Aaron Gallagher. (cherry picked from commit 856cbcc12f2e4cca93af5dc7ed6bcea4dd942f10) From webhook-mailer at python.org Sat Jul 22 00:36:15 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 22 Jul 2017 04:36:15 -0000 Subject: [Python-checkins] bpo-30981: IDLE: Augment one configdialog font page test (#2810) Message-ID: https://github.com/python/cpython/commit/616ecf18f3aacbd8d172e01673877b22fe946e54 commit: 616ecf18f3aacbd8d172e01673877b22fe946e54 branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-22T00:36:13-04:00 summary: bpo-30981: IDLE: Augment one configdialog font page test (#2810) Remove broken test of bold_toggle and test it along with its command, set_samples. This has been incorporated into 3.6 backport PR-2796. files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 59822fc8b37..c1db76817c1 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -153,6 +153,14 @@ def create_action_buttons(self): def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. + Enable users to provisionally change font face, size, or + boldness and to see the consequence of proposed choices. Each + action set 3 options in changes structuree and changes the + corresponding aspect of the font sample on this page and + highlight sample on highlight page. + + Enable users to change spaces entered for indent tabs. + Tk Variables: font_name: Font face. font_size: Font size. @@ -161,7 +169,7 @@ def create_page_font_tab(self): space_num: Indentation width. Data Attribute: - edit_font: Font widget with default font name, size, and weight. + edit_font: Font with default font name, size, and weight. Methods: load_font_cfg: Set vars and fontlist. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index d3002a99161..171fa3d309c 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -45,14 +45,17 @@ def tearDownModule(): del root - at unittest.skip("skip failing tests until fixed") class FontTabTest(unittest.TestCase): + "Test that font widget enable users to make font changes." + def setUp(self): changes.clear() def test_font_set(self): - # Set values guaranteed not to be defaults. + # Test that setting a font Variable results in 3 provisional + # change entries. Use values sure to not be defaults. + # Other font tests verify that user actions set Variables. default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' @@ -74,22 +77,29 @@ def test_font_set(self): 'font-bold': str(not default_bold)}} self.assertEqual(mainpage, expected) - def test_bold_toggle(self): - d = dialog - d.set_samples = Func() - d.bold_toggle.toggle() - self.assertEqual(d.set_samples.called, 1) - del d.set_samples - - def test_set_samples(self): + def test_set_samples_bold_toggle(self): + # Set up. d = dialog - d.font_sample, d.highlight_sample = {}, {} + d.font_sample, d.highlight_sample = {}, {} # Must undo this. d.font_name.set('test') d.font_size.set('5') d.font_bold.set(1) + expected0 = {'font': ('test', '5', 'normal')} + expected1 = {'font': ('test', '5', 'bold')} + + # Test set_samples. d.set_samples() - expected = {'font': ('test', '5', 'bold')} - self.assertTrue(d.font_sample == d.highlight_sample == expected) + self.assertTrue(d.font_sample == d.highlight_sample == expected1) + + # Test bold_toggle. + d.bold_toggle.invoke() + self.assertFalse(d.font_bold.get()) + self.assertTrue(d.font_sample == d.highlight_sample == expected0) + d.bold_toggle.invoke() + self.assertTrue(d.font_bold.get()) + self.assertTrue(d.font_sample == d.highlight_sample == expected1) + + # Clean up. del d.font_sample, d.highlight_sample def test_tabspace(self): From noreply at github.com Sat Jul 22 00:36:14 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 21:36:14 -0700 Subject: [Python-checkins] [python/cpython] 616ecf: bpo-30981: IDLE: Augment one configdialog font pag... Message-ID: <5972d63e889e9_5afe3f96f65abc44891a7@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 616ecf18f3aacbd8d172e01673877b22fe946e54 https://github.com/python/cpython/commit/616ecf18f3aacbd8d172e01673877b22fe946e54 Author: Terry Jan Reedy Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py Log Message: ----------- bpo-30981: IDLE: Augment one configdialog font page test (#2810) Remove broken test of bold_toggle and test it along with its command, set_samples. This has been incorporated into 3.6 backport PR-2796. From webhook-mailer at python.org Sat Jul 22 00:56:21 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 22 Jul 2017 04:56:21 -0000 Subject: [Python-checkins] =?utf-8?q?=5B3=2E6=5D_bpo-30981=3A_IDLE_--_Add?= =?utf-8?q?_more_configdialog_font_page_tests=2E_=28GH-=E2=80=A6_=28=23279?= =?utf-8?q?6=29?= Message-ID: https://github.com/python/cpython/commit/04864b491e3ce0f022e918ad344fb53a99ce2a1b commit: 04864b491e3ce0f022e918ad344fb53a99ce2a1b branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-22T00:56:18-04:00 summary: [3.6] bpo-30981: IDLE -- Add more configdialog font page tests. (GH-? (#2796) Verify that clicking the bold checkbutton and calling its command, set_samples, changes the bold setting of both samples. Simplify some names in configdialog. (cherry picked from commit d0969d6) (Incorporates changes and fixes from PRs 2798, 7c5798e, and 2810, 616ecf1) * Fix broken test with PR2798 and PR2810 changes. files: A Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index e1c3923caed..c1db76817c1 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -153,22 +153,29 @@ def create_action_buttons(self): def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. + Enable users to provisionally change font face, size, or + boldness and to see the consequence of proposed choices. Each + action set 3 options in changes structuree and changes the + corresponding aspect of the font sample on this page and + highlight sample on highlight page. + + Enable users to change spaces entered for indent tabs. + Tk Variables: + font_name: Font face. font_size: Font size. font_bold: Select font bold or not. - font_name: Font face. Note: these 3 share var_changed_font callback. space_num: Indentation width. Data Attribute: - edit_font: Font widget with default font name, size, and weight. + edit_font: Font with default font name, size, and weight. Methods: load_font_cfg: Set vars and fontlist. on_fontlist_select: Bound to fontlist button release or key release. - set_font_sample: Command for opt_menu_font_size and - check_font_bold. + set_samples: Notify both samples of any font change. load_tab_cfg: Get current. Widget Structure: (*) widgets bound to self @@ -181,7 +188,7 @@ def create_page_font_tab(self): frame_font_param: Frame font_size_title: Label (*)opt_menu_font_size: DynOptionMenu - font_size - check_font_bold: Checkbutton - font_bold + (*)bold_toggle: Checkbutton - font_bold frame_font_sample: Frame (*)font_sample: Label frame_indent: LabelFrame @@ -190,9 +197,9 @@ def create_page_font_tab(self): (*)scale_indent_size: Scale - space_num """ parent = self.parent + self.font_name = StringVar(parent) self.font_size = StringVar(parent) self.font_bold = BooleanVar(parent) - self.font_name = StringVar(parent) self.space_num = IntVar(parent) self.edit_font = tkFont.Font(parent, ('courier', 10, 'normal')) @@ -218,10 +225,10 @@ def create_page_font_tab(self): self.fontlist.config(yscrollcommand=scroll_font.set) font_size_title = Label(frame_font_param, text='Size :') self.opt_menu_font_size = DynOptionMenu( - frame_font_param, self.font_size, None, command=self.set_font_sample) - check_font_bold = Checkbutton( + frame_font_param, self.font_size, None, command=self.set_samples) + self.bold_toggle = Checkbutton( frame_font_param, variable=self.font_bold, onvalue=1, - offvalue=0, text='Bold', command=self.set_font_sample) + offvalue=0, text='Bold', command=self.set_samples) frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) self.font_sample = Label( frame_font_sample, justify=LEFT, font=self.edit_font, @@ -247,7 +254,7 @@ def create_page_font_tab(self): scroll_font.pack(side=LEFT, fill=Y) font_size_title.pack(side=LEFT, anchor=W) self.opt_menu_font_size.pack(side=LEFT, anchor=W) - check_font_bold.pack(side=LEFT, anchor=W, padx=20) + self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) self.font_sample.pack(expand=TRUE, fill=BOTH) # frame_indent @@ -292,7 +299,7 @@ def create_page_highlight(self): Widget Structure: (*) widgets bound to self frame frame_custom: LabelFrame - (*)text_highlight_sample: Text + (*)highlight_sample: Text (*)frame_color_set: Frame button_set_color: Button (*)opt_menu_highlight_target: DynOptionMenu - highlight_target @@ -342,11 +349,11 @@ def create_page_highlight(self): frame_theme = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Highlighting Theme ') #frame_custom - self.text_highlight_sample=Text( + self.highlight_sample=Text( frame_custom, relief=SOLID, borderwidth=1, font=('courier', 12, ''), cursor='hand2', width=21, height=11, takefocus=FALSE, highlightthickness=0, wrap=NONE) - text=self.text_highlight_sample + text=self.highlight_sample text.bind('', lambda e: 'break') text.bind('', lambda e: 'break') text_and_tags=( @@ -416,7 +423,7 @@ def tem(event, elem=element): #frame_custom self.frame_color_set.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=X) frame_fg_bg_toggle.pack(side=TOP, padx=5, pady=0) - self.text_highlight_sample.pack( + self.highlight_sample.pack( side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) button_set_color.pack(side=TOP, expand=TRUE, fill=X, padx=8, pady=4) self.opt_menu_highlight_target.pack( @@ -1142,7 +1149,7 @@ def on_new_color_set(self): self.frame_color_set.config(bg=new_color) # Set sample. plane ='foreground' if self.fg_bg_toggle.get() else 'background' sample_element = self.theme_elements[self.highlight_target.get()][0] - self.text_highlight_sample.tag_config(sample_element, **{plane:new_color}) + self.highlight_sample.tag_config(sample_element, **{plane:new_color}) theme = self.custom_theme.get() theme_element = sample_element + '-' + plane changes.add_option('highlight', theme, theme_element, new_color) @@ -1210,41 +1217,25 @@ def on_fontlist_select(self, event): """Handle selecting a font from the list. Event can result from either mouse click or Up or Down key. - Set font_name and example display to selection. - - Attributes updated: - font_name: Set to name selected from fontlist. - - Methods: - set_font_sample + Set font_name and example displays to selection. """ font = self.fontlist.get( ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) self.font_name.set(font.lower()) - self.set_font_sample() - - def set_font_sample(self, event=None): - """Update the screen samples with the font settings from the dialog. - - Attributes accessed: - font_name - font_bold - font_size + self.set_samples() - Attributes updated: - font_sample: Set to selected font name, size, and weight. - text_highlight_sample: Set to selected font name, size, and weight. + def set_samples(self, event=None): + """Update update both screen samples with the font settings. - Called from: - handler for opt_menu_font_size and check_font_bold - on_fontlist_select - load_font_cfg + Called on font initialization and change events. + Accesses font_name, font_size, and font_bold Variables. + Updates font_sample and hightlight page highlight_sample. """ font_name = self.font_name.get() font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL new_font = (font_name, self.font_size.get(), font_weight) - self.font_sample.config(font=new_font) - self.text_highlight_sample.configure(font=new_font) + self.font_sample['font'] = new_font + self.highlight_sample['font'] = new_font def set_highlight_target(self): """Set fg/bg toggle and color based on highlight tag target. @@ -1289,7 +1280,7 @@ def set_color_sample(self): theme_elements highlight_target fg_bg_toggle - text_highlight_sample + highlight_sample Attributes updated: frame_color_set @@ -1297,7 +1288,7 @@ def set_color_sample(self): # Set the color sample area. tag = self.theme_elements[self.highlight_target.get()][0] plane = 'foreground' if self.fg_bg_toggle.get() else 'background' - color = self.text_highlight_sample.tag_cget(tag, plane) + color = self.highlight_sample.tag_cget(tag, plane) self.frame_color_set.config(bg=color) def paint_theme_sample(self): @@ -1310,7 +1301,7 @@ def paint_theme_sample(self): custom_theme Attributes updated: - text_highlight_sample: Set the tag elements to the theme. + highlight_sample: Set the tag elements to the theme. Methods: set_color_sample @@ -1337,7 +1328,7 @@ def paint_theme_sample(self): colors['foreground'] = theme_dict[element + '-foreground'] if element + '-background' in theme_dict: colors['background'] = theme_dict[element + '-background'] - self.text_highlight_sample.tag_config(element, **colors) + self.highlight_sample.tag_config(element, **colors) self.set_color_sample() def help_source_selected(self, event): @@ -1424,7 +1415,7 @@ def load_font_cfg(self): font_bold: Set to current font weight. Methods: - set_font_sample + set_samples """ # Set base editor font selection list. fonts = list(tkFont.families(self)) @@ -1452,7 +1443,7 @@ def load_font_cfg(self): # Set font weight. self.font_bold.set(font_bold) # Set font sample. - self.set_font_sample() + self.set_samples() def load_tab_cfg(self): """Load current configuration settings for the tab options. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 4f1f9af180a..171fa3d309c 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -28,18 +28,12 @@ highpage = changes['highlight'] keyspage = changes['keys'] - -class TestDialog(ConfigDialog): - pass # Delete? - - def setUpModule(): global root, dialog idleConf.userCfg = testcfg root = Tk() # root.withdraw() # Comment out, see issue 30870 - dialog = TestDialog(root, 'Test', _utest=True) - + dialog = ConfigDialog(root, 'Test', _utest=True) def tearDownModule(): global root, dialog @@ -52,12 +46,16 @@ def tearDownModule(): class FontTabTest(unittest.TestCase): + "Test that font widget enable users to make font changes." + def setUp(self): changes.clear() - def test_font(self): - # Set values guaranteed not to be defaults. + def test_font_set(self): + # Test that setting a font Variable results in 3 provisional + # change entries. Use values sure to not be defaults. + # Other font tests verify that user actions set Variables. default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' @@ -79,9 +77,30 @@ def test_font(self): 'font-bold': str(not default_bold)}} self.assertEqual(mainpage, expected) - def test_set_sample(self): - # Set_font_sample also sets highlight_sample. - pass + def test_set_samples_bold_toggle(self): + # Set up. + d = dialog + d.font_sample, d.highlight_sample = {}, {} # Must undo this. + d.font_name.set('test') + d.font_size.set('5') + d.font_bold.set(1) + expected0 = {'font': ('test', '5', 'normal')} + expected1 = {'font': ('test', '5', 'bold')} + + # Test set_samples. + d.set_samples() + self.assertTrue(d.font_sample == d.highlight_sample == expected1) + + # Test bold_toggle. + d.bold_toggle.invoke() + self.assertFalse(d.font_bold.get()) + self.assertTrue(d.font_sample == d.highlight_sample == expected0) + d.bold_toggle.invoke() + self.assertTrue(d.font_bold.get()) + self.assertTrue(d.font_sample == d.highlight_sample == expected1) + + # Clean up. + del d.font_sample, d.highlight_sample def test_tabspace(self): dialog.space_num.set(6) @@ -90,7 +109,7 @@ def test_tabspace(self): class FontSelectTest(unittest.TestCase): # These two functions test that selecting a new font in the - # list of fonts changes font_name and calls set_font_sample. + # list of fonts changes font_name and calls set_samples. # The fontlist widget and on_fontlist_select event handler # are tested here together. @@ -98,14 +117,14 @@ class FontSelectTest(unittest.TestCase): def setUpClass(cls): if dialog.fontlist.size() < 2: cls.skipTest('need at least 2 fonts') - dialog.set_font_sample = Func() # Mask instance method. + dialog.set_samples = Func() # Mask instance method. @classmethod def tearDownClass(cls): - del dialog.set_font_sample # Unmask instance method. + del dialog.set_samples # Unmask instance method. def setUp(self): - dialog.set_font_sample.called = 0 + dialog.set_samples.called = 0 changes.clear() def test_select_font_key(self): @@ -124,7 +143,7 @@ def test_select_font_key(self): down_font = fontlist.get('active') self.assertNotEqual(down_font, font) self.assertIn(dialog.font_name.get(), down_font.lower()) - self.assertEqual(dialog.set_font_sample.called, 1) + self.assertEqual(dialog.set_samples.called, 1) # Test Up key. fontlist.focus_force() @@ -135,7 +154,7 @@ def test_select_font_key(self): up_font = fontlist.get('active') self.assertEqual(up_font, font) self.assertIn(dialog.font_name.get(), up_font.lower()) - self.assertEqual(dialog.set_font_sample.called, 2) + self.assertEqual(dialog.set_samples.called, 2) def test_select_font_mouse(self): # Click on item should select that item. @@ -157,7 +176,7 @@ def test_select_font_mouse(self): select_font = fontlist.get('anchor') self.assertEqual(select_font, font1) self.assertIn(dialog.font_name.get(), font1.lower()) - self.assertEqual(dialog.set_font_sample.called, 1) + self.assertEqual(dialog.set_samples.called, 1) class HighlightTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst b/Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst new file mode 100644 index 00000000000..48d477ed2e1 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst @@ -0,0 +1 @@ +IDLE -- Add more configdialog font page tests. From noreply at github.com Sat Jul 22 00:56:19 2017 From: noreply at github.com (GitHub) Date: Fri, 21 Jul 2017 21:56:19 -0700 Subject: [Python-checkins] [python/cpython] 04864b: [3.6] bpo-30981: IDLE -- Add more configdialog fon... Message-ID: <5972daf3d8af4_17de3fdcbeef7c2c316b7@hookshot-fe6-cp1-prd.iad.github.net.mail> Branch: refs/heads/3.6 Home: https://github.com/python/cpython Commit: 04864b491e3ce0f022e918ad344fb53a99ce2a1b https://github.com/python/cpython/commit/04864b491e3ce0f022e918ad344fb53a99ce2a1b Author: Terry Jan Reedy Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py A Misc/NEWS.d/next/IDLE/2017-07-21-01-55-14.bpo-30981.ZFvQPt.rst Log Message: ----------- [3.6] bpo-30981: IDLE -- Add more configdialog font page tests. (GH-? (#2796) Verify that clicking the bold checkbutton and calling its command, set_samples, changes the bold setting of both samples. Simplify some names in configdialog. (cherry picked from commit d0969d6) (Incorporates changes and fixes from PRs 2798, 7c5798e, and 2810, 616ecf1) * Fix broken test with PR2798 and PR2810 changes. From solipsis at pitrou.net Sat Jul 22 05:07:12 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sat, 22 Jul 2017 09:07:12 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=0 Message-ID: <20170722090712.79076.C82C6DEAEC920AAD@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 3, 0] memory blocks, sum=3 test_collections leaked [0, -7, 1] memory blocks, sum=-6 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_spawn leaked [0, -2, 1] memory blocks, sum=-1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogF0bXH0', '--timeout', '7200'] From webhook-mailer at python.org Sat Jul 22 07:22:57 2017 From: webhook-mailer at python.org (Antoine Pitrou) Date: Sat, 22 Jul 2017 11:22:57 -0000 Subject: [Python-checkins] bpo-26732: fix too many fds in processes started with the "forkserver" method (#2813) Message-ID: https://github.com/python/cpython/commit/896145d9d266ee2758cfcd7691238cbc1f9e1ab8 commit: 896145d9d266ee2758cfcd7691238cbc1f9e1ab8 branch: master author: Antoine Pitrou committer: GitHub date: 2017-07-22T13:22:54+02:00 summary: bpo-26732: fix too many fds in processes started with the "forkserver" method (#2813) * bpo-26732: fix too many fds in processes started with the "forkserver" method A child process would inherit as many fds as the number of still-running children. * Add blurb and test comment files: A Misc/NEWS.d/next/Library/2017-07-22-12-12-42.bpo-26732.lYLWBH.rst M Lib/multiprocessing/forkserver.py M Lib/test/_test_multiprocessing.py M Lib/test/libregrtest/refleak.py M Lib/test/support/__init__.py diff --git a/Lib/multiprocessing/forkserver.py b/Lib/multiprocessing/forkserver.py index b9f9b9dd8b5..69b842aa939 100644 --- a/Lib/multiprocessing/forkserver.py +++ b/Lib/multiprocessing/forkserver.py @@ -236,8 +236,11 @@ def sigchld_handler(*_unused): code = 1 try: listener.close() + selector.close() + unused_fds = [alive_r, child_w, sig_r, sig_w] + unused_fds.extend(pid_to_fd.values()) code = _serve_one(child_r, fds, - (alive_r, child_w, sig_r, sig_w), + unused_fds, old_handlers) except Exception: sys.excepthook(*sys.exc_info()) diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index 329a6d29aca..a14fa7422e7 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -494,6 +494,40 @@ def test_lose_target_ref(self): self.assertIs(wr(), None) self.assertEqual(q.get(), 5) + @classmethod + def _test_child_fd_inflation(self, evt, q): + q.put(test.support.fd_count()) + evt.wait() + + def test_child_fd_inflation(self): + # Number of fds in child processes should not grow with the + # number of running children. + if self.TYPE == 'threads': + self.skipTest('test not appropriate for {}'.format(self.TYPE)) + + sm = multiprocessing.get_start_method() + if sm == 'fork': + # The fork method by design inherits all fds from the parent, + # trying to go against it is a lost battle + self.skipTest('test not appropriate for {}'.format(sm)) + + N = 5 + evt = self.Event() + q = self.Queue() + + procs = [self.Process(target=self._test_child_fd_inflation, args=(evt, q)) + for i in range(N)] + for p in procs: + p.start() + + try: + fd_counts = [q.get() for i in range(N)] + self.assertEqual(len(set(fd_counts)), 1, fd_counts) + + finally: + evt.set() + for p in procs: + p.join() # # diff --git a/Lib/test/libregrtest/refleak.py b/Lib/test/libregrtest/refleak.py index 8e93816d965..efe52107cb4 100644 --- a/Lib/test/libregrtest/refleak.py +++ b/Lib/test/libregrtest/refleak.py @@ -7,36 +7,6 @@ from test import support -try: - MAXFD = os.sysconf("SC_OPEN_MAX") -except Exception: - MAXFD = 256 - - -def fd_count(): - """Count the number of open file descriptors""" - if sys.platform.startswith(('linux', 'freebsd')): - try: - names = os.listdir("/proc/self/fd") - return len(names) - except FileNotFoundError: - pass - - count = 0 - for fd in range(MAXFD): - try: - # Prefer dup() over fstat(). fstat() can require input/output - # whereas dup() doesn't. - fd2 = os.dup(fd) - except OSError as e: - if e.errno != errno.EBADF: - raise - else: - os.close(fd2) - count += 1 - return count - - def dash_R(the_module, test, indirect_test, huntrleaks): """Run a test multiple times, looking for reference leaks. @@ -174,7 +144,7 @@ def dash_R_cleanup(fs, ps, pic, zdc, abcs): func1 = sys.getallocatedblocks func2 = sys.gettotalrefcount gc.collect() - return func1(), func2(), fd_count() + return func1(), func2(), support.fd_count() def clear_caches(): diff --git a/Lib/test/support/__init__.py b/Lib/test/support/__init__.py index 313c23004ed..3a4d27e6b88 100644 --- a/Lib/test/support/__init__.py +++ b/Lib/test/support/__init__.py @@ -107,7 +107,7 @@ "check_warnings", "check_no_resource_warning", "EnvironmentVarGuard", "run_with_locale", "swap_item", "swap_attr", "Matcher", "set_memlimit", "SuppressCrashReport", "sortdict", - "run_with_tz", "PGO", "missing_compiler_executable", + "run_with_tz", "PGO", "missing_compiler_executable", "fd_count", ] class Error(Exception): @@ -2647,3 +2647,34 @@ def disable_faulthandler(): finally: if is_enabled: faulthandler.enable(file=fd, all_threads=True) + + +try: + MAXFD = os.sysconf("SC_OPEN_MAX") +except Exception: + MAXFD = 256 + + +def fd_count(): + """Count the number of open file descriptors. + """ + if sys.platform.startswith(('linux', 'freebsd')): + try: + names = os.listdir("/proc/self/fd") + return len(names) + except FileNotFoundError: + pass + + count = 0 + for fd in range(MAXFD): + try: + # Prefer dup() over fstat(). fstat() can require input/output + # whereas dup() doesn't. + fd2 = os.dup(fd) + except OSError as e: + if e.errno != errno.EBADF: + raise + else: + os.close(fd2) + count += 1 + return count diff --git a/Misc/NEWS.d/next/Library/2017-07-22-12-12-42.bpo-26732.lYLWBH.rst b/Misc/NEWS.d/next/Library/2017-07-22-12-12-42.bpo-26732.lYLWBH.rst new file mode 100644 index 00000000000..cff0f9ad6ab --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-22-12-12-42.bpo-26732.lYLWBH.rst @@ -0,0 +1,4 @@ +Fix too many fds in processes started with the "forkserver" method. + +A child process would inherit as many fds as the number of still-running +children. From noreply at github.com Sat Jul 22 07:22:56 2017 From: noreply at github.com (GitHub) Date: Sat, 22 Jul 2017 04:22:56 -0700 Subject: [Python-checkins] [python/cpython] 896145: bpo-26732: fix too many fds in processes started w... Message-ID: <59733590a4847_5c883fd0e8901c3c303c4@hookshot-fe1-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 896145d9d266ee2758cfcd7691238cbc1f9e1ab8 https://github.com/python/cpython/commit/896145d9d266ee2758cfcd7691238cbc1f9e1ab8 Author: Antoine Pitrou Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/multiprocessing/forkserver.py M Lib/test/_test_multiprocessing.py M Lib/test/libregrtest/refleak.py M Lib/test/support/__init__.py A Misc/NEWS.d/next/Library/2017-07-22-12-12-42.bpo-26732.lYLWBH.rst Log Message: ----------- bpo-26732: fix too many fds in processes started with the "forkserver" method (#2813) * bpo-26732: fix too many fds in processes started with the "forkserver" method A child process would inherit as many fds as the number of still-running children. * Add blurb and test comment From webhook-mailer at python.org Sat Jul 22 13:20:25 2017 From: webhook-mailer at python.org (Giampaolo Rodola) Date: Sat, 22 Jul 2017 17:20:25 -0000 Subject: [Python-checkins] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) Message-ID: https://github.com/python/cpython/commit/2b1e6e9696cb433c0e0da11145157d54275d119f commit: 2b1e6e9696cb433c0e0da11145157d54275d119f branch: master author: Dong-hee Na committer: Giampaolo Rodola date: 2017-07-22T19:20:22+02:00 summary: bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) files: M Lib/ftplib.py M Lib/test/test_ftplib.py M Misc/NEWS diff --git a/Lib/ftplib.py b/Lib/ftplib.py index 8f36f537e8a..a02e595cb02 100644 --- a/Lib/ftplib.py +++ b/Lib/ftplib.py @@ -186,6 +186,8 @@ def sanitize(self, s): # Internal: send one line to the server, appending CRLF def putline(self, line): + if '\r' in line or '\n' in line: + raise ValueError('an illegal newline character should not be contained') line = line + CRLF if self.debugging > 1: print('*put*', self.sanitize(line)) diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index 6571816bfdf..24ea382ff29 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -485,6 +485,9 @@ def test_sanitize(self): self.assertEqual(self.client.sanitize('PASS 12345'), repr('PASS *****')) def test_exceptions(self): + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r0') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 400') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 499') self.assertRaises(ftplib.error_perm, self.client.sendcmd, 'echo 500') @@ -493,7 +496,8 @@ def test_exceptions(self): def test_all_errors(self): exceptions = (ftplib.error_reply, ftplib.error_temp, ftplib.error_perm, - ftplib.error_proto, ftplib.Error, OSError, EOFError) + ftplib.error_proto, ftplib.Error, OSError, + EOFError) for x in exceptions: try: raise x('exception not included in all_errors set') diff --git a/Misc/NEWS b/Misc/NEWS index ce4874ac36d..38449c0409f 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -376,6 +376,9 @@ Extension Modules Library ------- +- bpo-30119: ftplib.FTP.putline() now throws ValueError on commands that contains + CR or LF. Patch by Dong-hee Na. + - bpo-30879: os.listdir() and os.scandir() now emit bytes names when called with bytes-like argument. From noreply at github.com Sat Jul 22 13:20:24 2017 From: noreply at github.com (GitHub) Date: Sat, 22 Jul 2017 10:20:24 -0700 Subject: [Python-checkins] [python/cpython] 2b1e6e: bpo-30119: fix ftplib.FTP.putline() to throw an er... Message-ID: <597389583e33a_284b3feff5525c2c405c8@hookshot-fe2-cp1-prd.iad.github.net.mail> Branch: refs/heads/master Home: https://github.com/python/cpython Commit: 2b1e6e9696cb433c0e0da11145157d54275d119f https://github.com/python/cpython/commit/2b1e6e9696cb433c0e0da11145157d54275d119f Author: Dong-hee Na Date: 2017-07-22 (Sat, 22 Jul 2017) Changed paths: M Lib/ftplib.py M Lib/test/test_ftplib.py M Misc/NEWS Log Message: ----------- bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) From webhook-mailer at python.org Sun Jul 23 02:00:42 2017 From: webhook-mailer at python.org (Gregory P. Smith) Date: Sun, 23 Jul 2017 06:00:42 -0000 Subject: [Python-checkins] [3.6] Make test_shutil test_disk_usage not depend on the cwd fs (GH-2597) (#2820) Message-ID: https://github.com/python/cpython/commit/8de48fe04633974318d48d0abf29e552e7c742c0 commit: 8de48fe04633974318d48d0abf29e552e7c742c0 branch: 3.6 author: Gregory P. Smith committer: GitHub date: 2017-07-22T23:00:39-07:00 summary: [3.6] Make test_shutil test_disk_usage not depend on the cwd fs (GH-2597) (#2820) Make test_shutil test_disk_usage not depend on the current working directory's filesystem. (cherry picked from commit 529746c90584069270cd122920270bd7be38bca3) files: M Lib/test/test_shutil.py diff --git a/Lib/test/test_shutil.py b/Lib/test/test_shutil.py index 2ad3a21c86d..b2ab1af296d 100644 --- a/Lib/test/test_shutil.py +++ b/Lib/test/test_shutil.py @@ -1294,7 +1294,7 @@ def _boo(filename, extract_dir, extra): @unittest.skipUnless(hasattr(shutil, 'disk_usage'), "disk_usage not available on this platform") def test_disk_usage(self): - usage = shutil.disk_usage(os.getcwd()) + usage = shutil.disk_usage(os.path.dirname(__file__)) self.assertGreater(usage.total, 0) self.assertGreater(usage.used, 0) self.assertGreaterEqual(usage.free, 0) From webhook-mailer at python.org Sun Jul 23 02:44:08 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Sun, 23 Jul 2017 06:44:08 -0000 Subject: [Python-checkins] [3.5] Backport bpo-30876 (GH-2639), bpo-18018 and bpo-26367. (#2677) Message-ID: https://github.com/python/cpython/commit/c824cc8426a16dd9f3949a3ed135523d37787bae commit: c824cc8426a16dd9f3949a3ed135523d37787bae branch: 3.5 author: Serhiy Storchaka committer: GitHub date: 2017-07-23T09:44:05+03:00 summary: [3.5] Backport bpo-30876 (GH-2639), bpo-18018 and bpo-26367. (#2677) * bpo-30876: Relative import from unloaded package now reimports the package instead of failing with SystemError. Relative import from non-package now fails with ImportError rather than SystemError. (cherry picked from commit 8a9cd20edca7d01b68292036029ae3735ce65edd) * bpo-18018: Import raises ImportError instead of SystemError if a relative import is attempted without a known parent package. * bpo-26367: importlib.__init__() raises ImportError like builtins.__import__() when ``level`` is specified but without an accompanying package specified. files: A Lib/test/test_import/data/package2/submodule1.py A Lib/test/test_import/data/package2/submodule2.py A Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst M Lib/importlib/_bootstrap.py M Lib/test/test_import/__init__.py M Lib/test/test_importlib/import_/test___package__.py M Lib/test/test_importlib/import_/test_relative_imports.py M Python/import.c M Python/importlib.h diff --git a/Lib/importlib/_bootstrap.py b/Lib/importlib/_bootstrap.py index 9eecbfe9672..02fe05b639f 100644 --- a/Lib/importlib/_bootstrap.py +++ b/Lib/importlib/_bootstrap.py @@ -925,10 +925,9 @@ def _sanity_check(name, package, level): if level > 0: if not isinstance(package, str): raise TypeError('__package__ not set to a string') - elif package not in sys.modules: - msg = ('Parent module {!r} not loaded, cannot perform relative ' - 'import') - raise SystemError(msg.format(package)) + elif not package: + raise ImportError('attempted relative import with no known parent ' + 'package') if not name and level == 0: raise ValueError('Empty module name') diff --git a/Lib/test/test_import/__init__.py b/Lib/test/test_import/__init__.py index 5d8b5621a37..6ef9bd568c2 100644 --- a/Lib/test/test_import/__init__.py +++ b/Lib/test/test_import/__init__.py @@ -22,8 +22,9 @@ EnvironmentVarGuard, TESTFN, check_warnings, forget, is_jython, make_legacy_pyc, rmtree, run_unittest, swap_attr, swap_item, temp_umask, unlink, unload, create_empty_file, cpython_only, TESTFN_UNENCODABLE, - temp_dir) + temp_dir, DirsOnSysPath) from test.support import script_helper +from test.test_importlib.util import uncache skip_if_dont_write_bytecode = unittest.skipIf( @@ -600,11 +601,11 @@ def check_relative(): # Check relative import fails with only __package__ wrong ns = dict(__package__='foo', __name__='test.notarealmodule') - self.assertRaises(SystemError, check_relative) + self.assertRaises(ImportError, check_relative) # Check relative import fails with __package__ and __name__ wrong ns = dict(__package__='foo', __name__='notarealpkg.notarealmodule') - self.assertRaises(SystemError, check_relative) + self.assertRaises(ImportError, check_relative) # Check relative import fails with package set to a non-string ns = dict(__package__=object()) @@ -619,6 +620,20 @@ def test_absolute_import_without_future(self): self.fail("explicit relative import triggered an " "implicit absolute import") + def test_import_from_non_package(self): + path = os.path.join(os.path.dirname(__file__), 'data', 'package2') + with uncache('submodule1', 'submodule2'), DirsOnSysPath(path): + with self.assertRaises(ImportError): + import submodule1 + self.assertNotIn('submodule1', sys.modules) + self.assertNotIn('submodule2', sys.modules) + + def test_import_from_unloaded_package(self): + with uncache('package2', 'package2.submodule1', 'package2.submodule2'), \ + DirsOnSysPath(os.path.join(os.path.dirname(__file__), 'data')): + import package2.submodule1 + package2.submodule1.submodule2 + class OverridingImportBuiltinTests(unittest.TestCase): def test_override_builtin(self): diff --git a/Lib/test/test_import/data/package2/submodule1.py b/Lib/test/test_import/data/package2/submodule1.py new file mode 100644 index 00000000000..0698ed6de2a --- /dev/null +++ b/Lib/test/test_import/data/package2/submodule1.py @@ -0,0 +1,3 @@ +import sys +sys.modules.pop(__package__, None) +from . import submodule2 diff --git a/Lib/test/test_import/data/package2/submodule2.py b/Lib/test/test_import/data/package2/submodule2.py new file mode 100644 index 00000000000..e69de29bb2d diff --git a/Lib/test/test_importlib/import_/test___package__.py b/Lib/test/test_importlib/import_/test___package__.py index c7d3a2a2048..9a704050d89 100644 --- a/Lib/test/test_importlib/import_/test___package__.py +++ b/Lib/test/test_importlib/import_/test___package__.py @@ -61,7 +61,7 @@ def test_None_as___package__(self): def test_bad__package__(self): globals = {'__package__': ''} - with self.assertRaises(SystemError): + with self.assertRaises(ImportError): self.__import__('', globals, {}, ['relimport'], 1) def test_bunk__package__(self): diff --git a/Lib/test/test_importlib/import_/test_relative_imports.py b/Lib/test/test_importlib/import_/test_relative_imports.py index 3bb819f906d..717fc5b1bed 100644 --- a/Lib/test/test_importlib/import_/test_relative_imports.py +++ b/Lib/test/test_importlib/import_/test_relative_imports.py @@ -207,8 +207,13 @@ def test_relative_import_no_globals(self): with self.assertRaises(KeyError): self.__import__('sys', level=1) + def test_relative_import_no_package(self): + with self.assertRaises(ImportError): + self.__import__('a', {'__package__': '', '__spec__': None}, + level=1) + def test_relative_import_no_package_exists_absolute(self): - with self.assertRaises(SystemError): + with self.assertRaises(ImportError): self.__import__('sys', {'__package__': '', '__spec__': None}, level=1) diff --git a/Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst b/Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst new file mode 100644 index 00000000000..4f3f4d29190 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/2017-07-11-06-31-32.bpo-30876.x35jZX.rst @@ -0,0 +1,3 @@ +Relative import from unloaded package now reimports the package instead of +failing with SystemError. Relative import from non-package now fails with +ImportError rather than SystemError. diff --git a/Python/import.c b/Python/import.c index 4f08d5ebb77..9d54d59ea66 100644 --- a/Python/import.c +++ b/Python/import.c @@ -1461,11 +1461,9 @@ PyImport_ImportModuleLevelObject(PyObject *name, PyObject *given_globals, Py_DECREF(partition); } } - - if (PyDict_GetItem(interp->modules, package) == NULL) { - PyErr_Format(PyExc_SystemError, - "Parent module %R not loaded, cannot perform relative " - "import", package); + if (PyUnicode_GET_LENGTH(package) == 0) { + PyErr_SetString(PyExc_ImportError, + "attempted relative import with no known parent package"); goto error; } } diff --git a/Python/importlib.h b/Python/importlib.h index a5fc936a28c..aba15fdcd4b 100644 --- a/Python/importlib.h +++ b/Python/importlib.h @@ -1610,379 +1610,376 @@ const unsigned char _Py_M__importlib[] = { 1,10,1,3,1,13,1,13,1,18,1,12,1,8,2,25, 1,12,2,22,1,13,1,3,1,13,1,13,4,9,2,12, 1,4,2,7,2,8,2,114,176,0,0,0,99,3,0,0, - 0,0,0,0,0,4,0,0,0,4,0,0,0,67,0,0, - 0,115,185,0,0,0,116,0,0,124,0,0,116,1,0,131, + 0,0,0,0,0,3,0,0,0,4,0,0,0,67,0,0, + 0,115,161,0,0,0,116,0,0,124,0,0,116,1,0,131, 2,0,115,42,0,116,2,0,100,1,0,106,3,0,116,4, 0,124,0,0,131,1,0,131,1,0,131,1,0,130,1,0, 124,2,0,100,2,0,107,0,0,114,66,0,116,5,0,100, 3,0,131,1,0,130,1,0,124,2,0,100,2,0,107,4, - 0,114,150,0,116,0,0,124,1,0,116,1,0,131,2,0, + 0,114,126,0,116,0,0,124,1,0,116,1,0,131,2,0, 115,108,0,116,2,0,100,4,0,131,1,0,130,1,0,110, - 42,0,124,1,0,116,6,0,106,7,0,107,7,0,114,150, - 0,100,5,0,125,3,0,116,8,0,124,3,0,106,3,0, - 124,1,0,131,1,0,131,1,0,130,1,0,124,0,0,12, - 114,181,0,124,2,0,100,2,0,107,2,0,114,181,0,116, - 5,0,100,6,0,131,1,0,130,1,0,100,7,0,83,41, - 8,122,28,86,101,114,105,102,121,32,97,114,103,117,109,101, - 110,116,115,32,97,114,101,32,34,115,97,110,101,34,46,122, - 31,109,111,100,117,108,101,32,110,97,109,101,32,109,117,115, - 116,32,98,101,32,115,116,114,44,32,110,111,116,32,123,125, - 114,33,0,0,0,122,18,108,101,118,101,108,32,109,117,115, - 116,32,98,101,32,62,61,32,48,122,31,95,95,112,97,99, - 107,97,103,101,95,95,32,110,111,116,32,115,101,116,32,116, - 111,32,97,32,115,116,114,105,110,103,122,61,80,97,114,101, - 110,116,32,109,111,100,117,108,101,32,123,33,114,125,32,110, - 111,116,32,108,111,97,100,101,100,44,32,99,97,110,110,111, - 116,32,112,101,114,102,111,114,109,32,114,101,108,97,116,105, - 118,101,32,105,109,112,111,114,116,122,17,69,109,112,116,121, - 32,109,111,100,117,108,101,32,110,97,109,101,78,41,9,218, - 10,105,115,105,110,115,116,97,110,99,101,218,3,115,116,114, - 218,9,84,121,112,101,69,114,114,111,114,114,50,0,0,0, - 114,13,0,0,0,114,168,0,0,0,114,14,0,0,0,114, - 21,0,0,0,218,11,83,121,115,116,101,109,69,114,114,111, - 114,41,4,114,15,0,0,0,114,169,0,0,0,114,170,0, - 0,0,114,147,0,0,0,114,10,0,0,0,114,10,0,0, - 0,114,11,0,0,0,218,13,95,115,97,110,105,116,121,95, - 99,104,101,99,107,151,3,0,0,115,24,0,0,0,0,2, - 15,1,27,1,12,1,12,1,12,1,15,1,15,1,15,1, - 6,2,21,1,19,1,114,181,0,0,0,122,16,78,111,32, - 109,111,100,117,108,101,32,110,97,109,101,100,32,122,4,123, - 33,114,125,99,2,0,0,0,0,0,0,0,8,0,0,0, - 12,0,0,0,67,0,0,0,115,40,1,0,0,100,0,0, - 125,2,0,124,0,0,106,0,0,100,1,0,131,1,0,100, - 2,0,25,125,3,0,124,3,0,114,175,0,124,3,0,116, - 1,0,106,2,0,107,7,0,114,59,0,116,3,0,124,1, - 0,124,3,0,131,2,0,1,124,0,0,116,1,0,106,2, - 0,107,6,0,114,85,0,116,1,0,106,2,0,124,0,0, - 25,83,116,1,0,106,2,0,124,3,0,25,125,4,0,121, - 13,0,124,4,0,106,4,0,125,2,0,87,110,61,0,4, - 116,5,0,107,10,0,114,174,0,1,1,1,116,6,0,100, - 3,0,23,106,7,0,124,0,0,124,3,0,131,2,0,125, - 5,0,116,8,0,124,5,0,100,4,0,124,0,0,131,1, - 1,100,0,0,130,2,0,89,110,1,0,88,116,9,0,124, - 0,0,124,2,0,131,2,0,125,6,0,124,6,0,100,0, - 0,107,8,0,114,232,0,116,8,0,116,6,0,106,7,0, - 124,0,0,131,1,0,100,4,0,124,0,0,131,1,1,130, - 1,0,110,12,0,116,10,0,124,6,0,131,1,0,125,7, - 0,124,3,0,114,36,1,116,1,0,106,2,0,124,3,0, - 25,125,4,0,116,11,0,124,4,0,124,0,0,106,0,0, - 100,1,0,131,1,0,100,5,0,25,124,7,0,131,3,0, - 1,124,7,0,83,41,6,78,114,121,0,0,0,114,33,0, - 0,0,122,23,59,32,123,33,114,125,32,105,115,32,110,111, - 116,32,97,32,112,97,99,107,97,103,101,114,15,0,0,0, - 114,140,0,0,0,41,12,114,122,0,0,0,114,14,0,0, - 0,114,21,0,0,0,114,65,0,0,0,114,131,0,0,0, - 114,96,0,0,0,218,8,95,69,82,82,95,77,83,71,114, - 50,0,0,0,114,77,0,0,0,114,176,0,0,0,114,149, - 0,0,0,114,5,0,0,0,41,8,114,15,0,0,0,218, - 7,105,109,112,111,114,116,95,114,152,0,0,0,114,123,0, - 0,0,90,13,112,97,114,101,110,116,95,109,111,100,117,108, - 101,114,147,0,0,0,114,88,0,0,0,114,89,0,0,0, + 18,0,124,1,0,115,126,0,116,6,0,100,5,0,131,1, + 0,130,1,0,124,0,0,12,114,157,0,124,2,0,100,2, + 0,107,2,0,114,157,0,116,5,0,100,6,0,131,1,0, + 130,1,0,100,7,0,83,41,8,122,28,86,101,114,105,102, + 121,32,97,114,103,117,109,101,110,116,115,32,97,114,101,32, + 34,115,97,110,101,34,46,122,31,109,111,100,117,108,101,32, + 110,97,109,101,32,109,117,115,116,32,98,101,32,115,116,114, + 44,32,110,111,116,32,123,125,114,33,0,0,0,122,18,108, + 101,118,101,108,32,109,117,115,116,32,98,101,32,62,61,32, + 48,122,31,95,95,112,97,99,107,97,103,101,95,95,32,110, + 111,116,32,115,101,116,32,116,111,32,97,32,115,116,114,105, + 110,103,122,54,97,116,116,101,109,112,116,101,100,32,114,101, + 108,97,116,105,118,101,32,105,109,112,111,114,116,32,119,105, + 116,104,32,110,111,32,107,110,111,119,110,32,112,97,114,101, + 110,116,32,112,97,99,107,97,103,101,122,17,69,109,112,116, + 121,32,109,111,100,117,108,101,32,110,97,109,101,78,41,7, + 218,10,105,115,105,110,115,116,97,110,99,101,218,3,115,116, + 114,218,9,84,121,112,101,69,114,114,111,114,114,50,0,0, + 0,114,13,0,0,0,114,168,0,0,0,114,77,0,0,0, + 41,3,114,15,0,0,0,114,169,0,0,0,114,170,0,0, + 0,114,10,0,0,0,114,10,0,0,0,114,11,0,0,0, + 218,13,95,115,97,110,105,116,121,95,99,104,101,99,107,151, + 3,0,0,115,22,0,0,0,0,2,15,1,27,1,12,1, + 12,1,12,1,15,1,15,1,6,1,12,2,19,1,114,180, + 0,0,0,122,16,78,111,32,109,111,100,117,108,101,32,110, + 97,109,101,100,32,122,4,123,33,114,125,99,2,0,0,0, + 0,0,0,0,8,0,0,0,12,0,0,0,67,0,0,0, + 115,40,1,0,0,100,0,0,125,2,0,124,0,0,106,0, + 0,100,1,0,131,1,0,100,2,0,25,125,3,0,124,3, + 0,114,175,0,124,3,0,116,1,0,106,2,0,107,7,0, + 114,59,0,116,3,0,124,1,0,124,3,0,131,2,0,1, + 124,0,0,116,1,0,106,2,0,107,6,0,114,85,0,116, + 1,0,106,2,0,124,0,0,25,83,116,1,0,106,2,0, + 124,3,0,25,125,4,0,121,13,0,124,4,0,106,4,0, + 125,2,0,87,110,61,0,4,116,5,0,107,10,0,114,174, + 0,1,1,1,116,6,0,100,3,0,23,106,7,0,124,0, + 0,124,3,0,131,2,0,125,5,0,116,8,0,124,5,0, + 100,4,0,124,0,0,131,1,1,100,0,0,130,2,0,89, + 110,1,0,88,116,9,0,124,0,0,124,2,0,131,2,0, + 125,6,0,124,6,0,100,0,0,107,8,0,114,232,0,116, + 8,0,116,6,0,106,7,0,124,0,0,131,1,0,100,4, + 0,124,0,0,131,1,1,130,1,0,110,12,0,116,10,0, + 124,6,0,131,1,0,125,7,0,124,3,0,114,36,1,116, + 1,0,106,2,0,124,3,0,25,125,4,0,116,11,0,124, + 4,0,124,0,0,106,0,0,100,1,0,131,1,0,100,5, + 0,25,124,7,0,131,3,0,1,124,7,0,83,41,6,78, + 114,121,0,0,0,114,33,0,0,0,122,23,59,32,123,33, + 114,125,32,105,115,32,110,111,116,32,97,32,112,97,99,107, + 97,103,101,114,15,0,0,0,114,140,0,0,0,41,12,114, + 122,0,0,0,114,14,0,0,0,114,21,0,0,0,114,65, + 0,0,0,114,131,0,0,0,114,96,0,0,0,218,8,95, + 69,82,82,95,77,83,71,114,50,0,0,0,114,77,0,0, + 0,114,176,0,0,0,114,149,0,0,0,114,5,0,0,0, + 41,8,114,15,0,0,0,218,7,105,109,112,111,114,116,95, + 114,152,0,0,0,114,123,0,0,0,90,13,112,97,114,101, + 110,116,95,109,111,100,117,108,101,114,147,0,0,0,114,88, + 0,0,0,114,89,0,0,0,114,10,0,0,0,114,10,0, + 0,0,114,11,0,0,0,218,23,95,102,105,110,100,95,97, + 110,100,95,108,111,97,100,95,117,110,108,111,99,107,101,100, + 170,3,0,0,115,42,0,0,0,0,1,6,1,19,1,6, + 1,15,1,13,2,15,1,11,1,13,1,3,1,13,1,13, + 1,22,1,26,1,15,1,12,1,30,2,12,1,6,2,13, + 1,29,1,114,183,0,0,0,99,2,0,0,0,0,0,0, + 0,2,0,0,0,10,0,0,0,67,0,0,0,115,37,0, + 0,0,116,0,0,124,0,0,131,1,0,143,18,0,1,116, + 1,0,124,0,0,124,1,0,131,2,0,83,87,100,1,0, + 81,82,88,100,1,0,83,41,2,122,54,70,105,110,100,32, + 97,110,100,32,108,111,97,100,32,116,104,101,32,109,111,100, + 117,108,101,44,32,97,110,100,32,114,101,108,101,97,115,101, + 32,116,104,101,32,105,109,112,111,114,116,32,108,111,99,107, + 46,78,41,2,114,54,0,0,0,114,183,0,0,0,41,2, + 114,15,0,0,0,114,182,0,0,0,114,10,0,0,0,114, + 10,0,0,0,114,11,0,0,0,218,14,95,102,105,110,100, + 95,97,110,100,95,108,111,97,100,197,3,0,0,115,4,0, + 0,0,0,2,13,1,114,184,0,0,0,114,33,0,0,0, + 99,3,0,0,0,0,0,0,0,5,0,0,0,4,0,0, + 0,67,0,0,0,115,166,0,0,0,116,0,0,124,0,0, + 124,1,0,124,2,0,131,3,0,1,124,2,0,100,1,0, + 107,4,0,114,46,0,116,1,0,124,0,0,124,1,0,124, + 2,0,131,3,0,125,0,0,116,2,0,106,3,0,131,0, + 0,1,124,0,0,116,4,0,106,5,0,107,7,0,114,84, + 0,116,6,0,124,0,0,116,7,0,131,2,0,83,116,4, + 0,106,5,0,124,0,0,25,125,3,0,124,3,0,100,2, + 0,107,8,0,114,152,0,116,2,0,106,8,0,131,0,0, + 1,100,3,0,106,9,0,124,0,0,131,1,0,125,4,0, + 116,10,0,124,4,0,100,4,0,124,0,0,131,1,1,130, + 1,0,116,11,0,124,0,0,131,1,0,1,124,3,0,83, + 41,5,97,50,1,0,0,73,109,112,111,114,116,32,97,110, + 100,32,114,101,116,117,114,110,32,116,104,101,32,109,111,100, + 117,108,101,32,98,97,115,101,100,32,111,110,32,105,116,115, + 32,110,97,109,101,44,32,116,104,101,32,112,97,99,107,97, + 103,101,32,116,104,101,32,99,97,108,108,32,105,115,10,32, + 32,32,32,98,101,105,110,103,32,109,97,100,101,32,102,114, + 111,109,44,32,97,110,100,32,116,104,101,32,108,101,118,101, + 108,32,97,100,106,117,115,116,109,101,110,116,46,10,10,32, + 32,32,32,84,104,105,115,32,102,117,110,99,116,105,111,110, + 32,114,101,112,114,101,115,101,110,116,115,32,116,104,101,32, + 103,114,101,97,116,101,115,116,32,99,111,109,109,111,110,32, + 100,101,110,111,109,105,110,97,116,111,114,32,111,102,32,102, + 117,110,99,116,105,111,110,97,108,105,116,121,10,32,32,32, + 32,98,101,116,119,101,101,110,32,105,109,112,111,114,116,95, + 109,111,100,117,108,101,32,97,110,100,32,95,95,105,109,112, + 111,114,116,95,95,46,32,84,104,105,115,32,105,110,99,108, + 117,100,101,115,32,115,101,116,116,105,110,103,32,95,95,112, + 97,99,107,97,103,101,95,95,32,105,102,10,32,32,32,32, + 116,104,101,32,108,111,97,100,101,114,32,100,105,100,32,110, + 111,116,46,10,10,32,32,32,32,114,33,0,0,0,78,122, + 40,105,109,112,111,114,116,32,111,102,32,123,125,32,104,97, + 108,116,101,100,59,32,78,111,110,101,32,105,110,32,115,121, + 115,46,109,111,100,117,108,101,115,114,15,0,0,0,41,12, + 114,180,0,0,0,114,171,0,0,0,114,57,0,0,0,114, + 145,0,0,0,114,14,0,0,0,114,21,0,0,0,114,184, + 0,0,0,218,11,95,103,99,100,95,105,109,112,111,114,116, + 114,58,0,0,0,114,50,0,0,0,114,77,0,0,0,114, + 63,0,0,0,41,5,114,15,0,0,0,114,169,0,0,0, + 114,170,0,0,0,114,89,0,0,0,114,74,0,0,0,114, + 10,0,0,0,114,10,0,0,0,114,11,0,0,0,114,185, + 0,0,0,203,3,0,0,115,28,0,0,0,0,9,16,1, + 12,1,18,1,10,1,15,1,13,1,13,1,12,1,10,1, + 6,1,9,1,18,1,10,1,114,185,0,0,0,99,3,0, + 0,0,0,0,0,0,6,0,0,0,17,0,0,0,67,0, + 0,0,115,239,0,0,0,116,0,0,124,0,0,100,1,0, + 131,2,0,114,235,0,100,2,0,124,1,0,107,6,0,114, + 83,0,116,1,0,124,1,0,131,1,0,125,1,0,124,1, + 0,106,2,0,100,2,0,131,1,0,1,116,0,0,124,0, + 0,100,3,0,131,2,0,114,83,0,124,1,0,106,3,0, + 124,0,0,106,4,0,131,1,0,1,120,149,0,124,1,0, + 68,93,141,0,125,3,0,116,0,0,124,0,0,124,3,0, + 131,2,0,115,90,0,100,4,0,106,5,0,124,0,0,106, + 6,0,124,3,0,131,2,0,125,4,0,121,17,0,116,7, + 0,124,2,0,124,4,0,131,2,0,1,87,113,90,0,4, + 116,8,0,107,10,0,114,230,0,1,125,5,0,1,122,47, + 0,116,9,0,124,5,0,131,1,0,106,10,0,116,11,0, + 131,1,0,114,209,0,124,5,0,106,12,0,124,4,0,107, + 2,0,114,209,0,119,90,0,130,0,0,87,89,100,5,0, + 100,5,0,125,5,0,126,5,0,88,113,90,0,88,113,90, + 0,87,124,0,0,83,41,6,122,238,70,105,103,117,114,101, + 32,111,117,116,32,119,104,97,116,32,95,95,105,109,112,111, + 114,116,95,95,32,115,104,111,117,108,100,32,114,101,116,117, + 114,110,46,10,10,32,32,32,32,84,104,101,32,105,109,112, + 111,114,116,95,32,112,97,114,97,109,101,116,101,114,32,105, + 115,32,97,32,99,97,108,108,97,98,108,101,32,119,104,105, + 99,104,32,116,97,107,101,115,32,116,104,101,32,110,97,109, + 101,32,111,102,32,109,111,100,117,108,101,32,116,111,10,32, + 32,32,32,105,109,112,111,114,116,46,32,73,116,32,105,115, + 32,114,101,113,117,105,114,101,100,32,116,111,32,100,101,99, + 111,117,112,108,101,32,116,104,101,32,102,117,110,99,116,105, + 111,110,32,102,114,111,109,32,97,115,115,117,109,105,110,103, + 32,105,109,112,111,114,116,108,105,98,39,115,10,32,32,32, + 32,105,109,112,111,114,116,32,105,109,112,108,101,109,101,110, + 116,97,116,105,111,110,32,105,115,32,100,101,115,105,114,101, + 100,46,10,10,32,32,32,32,114,131,0,0,0,250,1,42, + 218,7,95,95,97,108,108,95,95,122,5,123,125,46,123,125, + 78,41,13,114,4,0,0,0,114,130,0,0,0,218,6,114, + 101,109,111,118,101,218,6,101,120,116,101,110,100,114,187,0, + 0,0,114,50,0,0,0,114,1,0,0,0,114,65,0,0, + 0,114,77,0,0,0,114,178,0,0,0,114,71,0,0,0, + 218,15,95,69,82,82,95,77,83,71,95,80,82,69,70,73, + 88,114,15,0,0,0,41,6,114,89,0,0,0,218,8,102, + 114,111,109,108,105,115,116,114,182,0,0,0,218,1,120,90, + 9,102,114,111,109,95,110,97,109,101,90,3,101,120,99,114, + 10,0,0,0,114,10,0,0,0,114,11,0,0,0,218,16, + 95,104,97,110,100,108,101,95,102,114,111,109,108,105,115,116, + 227,3,0,0,115,34,0,0,0,0,10,15,1,12,1,12, + 1,13,1,15,1,16,1,13,1,15,1,21,1,3,1,17, + 1,18,4,21,1,15,1,3,1,26,1,114,193,0,0,0, + 99,1,0,0,0,0,0,0,0,2,0,0,0,2,0,0, + 0,67,0,0,0,115,72,0,0,0,124,0,0,106,0,0, + 100,1,0,131,1,0,125,1,0,124,1,0,100,2,0,107, + 8,0,114,68,0,124,0,0,100,3,0,25,125,1,0,100, + 4,0,124,0,0,107,7,0,114,68,0,124,1,0,106,1, + 0,100,5,0,131,1,0,100,6,0,25,125,1,0,124,1, + 0,83,41,7,122,167,67,97,108,99,117,108,97,116,101,32, + 119,104,97,116,32,95,95,112,97,99,107,97,103,101,95,95, + 32,115,104,111,117,108,100,32,98,101,46,10,10,32,32,32, + 32,95,95,112,97,99,107,97,103,101,95,95,32,105,115,32, + 110,111,116,32,103,117,97,114,97,110,116,101,101,100,32,116, + 111,32,98,101,32,100,101,102,105,110,101,100,32,111,114,32, + 99,111,117,108,100,32,98,101,32,115,101,116,32,116,111,32, + 78,111,110,101,10,32,32,32,32,116,111,32,114,101,112,114, + 101,115,101,110,116,32,116,104,97,116,32,105,116,115,32,112, + 114,111,112,101,114,32,118,97,108,117,101,32,105,115,32,117, + 110,107,110,111,119,110,46,10,10,32,32,32,32,114,134,0, + 0,0,78,114,1,0,0,0,114,131,0,0,0,114,121,0, + 0,0,114,33,0,0,0,41,2,114,42,0,0,0,114,122, + 0,0,0,41,2,218,7,103,108,111,98,97,108,115,114,169, + 0,0,0,114,10,0,0,0,114,10,0,0,0,114,11,0, + 0,0,218,17,95,99,97,108,99,95,95,95,112,97,99,107, + 97,103,101,95,95,3,4,0,0,115,12,0,0,0,0,7, + 15,1,12,1,10,1,12,1,19,1,114,195,0,0,0,99, + 5,0,0,0,0,0,0,0,9,0,0,0,5,0,0,0, + 67,0,0,0,115,227,0,0,0,124,4,0,100,1,0,107, + 2,0,114,27,0,116,0,0,124,0,0,131,1,0,125,5, + 0,110,54,0,124,1,0,100,2,0,107,9,0,114,45,0, + 124,1,0,110,3,0,105,0,0,125,6,0,116,1,0,124, + 6,0,131,1,0,125,7,0,116,0,0,124,0,0,124,7, + 0,124,4,0,131,3,0,125,5,0,124,3,0,115,207,0, + 124,4,0,100,1,0,107,2,0,114,122,0,116,0,0,124, + 0,0,106,2,0,100,3,0,131,1,0,100,1,0,25,131, + 1,0,83,124,0,0,115,132,0,124,5,0,83,116,3,0, + 124,0,0,131,1,0,116,3,0,124,0,0,106,2,0,100, + 3,0,131,1,0,100,1,0,25,131,1,0,24,125,8,0, + 116,4,0,106,5,0,124,5,0,106,6,0,100,2,0,116, + 3,0,124,5,0,106,6,0,131,1,0,124,8,0,24,133, + 2,0,25,25,83,110,16,0,116,7,0,124,5,0,124,3, + 0,116,0,0,131,3,0,83,100,2,0,83,41,4,97,215, + 1,0,0,73,109,112,111,114,116,32,97,32,109,111,100,117, + 108,101,46,10,10,32,32,32,32,84,104,101,32,39,103,108, + 111,98,97,108,115,39,32,97,114,103,117,109,101,110,116,32, + 105,115,32,117,115,101,100,32,116,111,32,105,110,102,101,114, + 32,119,104,101,114,101,32,116,104,101,32,105,109,112,111,114, + 116,32,105,115,32,111,99,99,117,114,114,105,110,103,32,102, + 114,111,109,10,32,32,32,32,116,111,32,104,97,110,100,108, + 101,32,114,101,108,97,116,105,118,101,32,105,109,112,111,114, + 116,115,46,32,84,104,101,32,39,108,111,99,97,108,115,39, + 32,97,114,103,117,109,101,110,116,32,105,115,32,105,103,110, + 111,114,101,100,46,32,84,104,101,10,32,32,32,32,39,102, + 114,111,109,108,105,115,116,39,32,97,114,103,117,109,101,110, + 116,32,115,112,101,99,105,102,105,101,115,32,119,104,97,116, + 32,115,104,111,117,108,100,32,101,120,105,115,116,32,97,115, + 32,97,116,116,114,105,98,117,116,101,115,32,111,110,32,116, + 104,101,32,109,111,100,117,108,101,10,32,32,32,32,98,101, + 105,110,103,32,105,109,112,111,114,116,101,100,32,40,101,46, + 103,46,32,96,96,102,114,111,109,32,109,111,100,117,108,101, + 32,105,109,112,111,114,116,32,60,102,114,111,109,108,105,115, + 116,62,96,96,41,46,32,32,84,104,101,32,39,108,101,118, + 101,108,39,10,32,32,32,32,97,114,103,117,109,101,110,116, + 32,114,101,112,114,101,115,101,110,116,115,32,116,104,101,32, + 112,97,99,107,97,103,101,32,108,111,99,97,116,105,111,110, + 32,116,111,32,105,109,112,111,114,116,32,102,114,111,109,32, + 105,110,32,97,32,114,101,108,97,116,105,118,101,10,32,32, + 32,32,105,109,112,111,114,116,32,40,101,46,103,46,32,96, + 96,102,114,111,109,32,46,46,112,107,103,32,105,109,112,111, + 114,116,32,109,111,100,96,96,32,119,111,117,108,100,32,104, + 97,118,101,32,97,32,39,108,101,118,101,108,39,32,111,102, + 32,50,41,46,10,10,32,32,32,32,114,33,0,0,0,78, + 114,121,0,0,0,41,8,114,185,0,0,0,114,195,0,0, + 0,218,9,112,97,114,116,105,116,105,111,110,114,167,0,0, + 0,114,14,0,0,0,114,21,0,0,0,114,1,0,0,0, + 114,193,0,0,0,41,9,114,15,0,0,0,114,194,0,0, + 0,218,6,108,111,99,97,108,115,114,191,0,0,0,114,170, + 0,0,0,114,89,0,0,0,90,8,103,108,111,98,97,108, + 115,95,114,169,0,0,0,90,7,99,117,116,95,111,102,102, 114,10,0,0,0,114,10,0,0,0,114,11,0,0,0,218, - 23,95,102,105,110,100,95,97,110,100,95,108,111,97,100,95, - 117,110,108,111,99,107,101,100,171,3,0,0,115,42,0,0, - 0,0,1,6,1,19,1,6,1,15,1,13,2,15,1,11, - 1,13,1,3,1,13,1,13,1,22,1,26,1,15,1,12, - 1,30,2,12,1,6,2,13,1,29,1,114,184,0,0,0, - 99,2,0,0,0,0,0,0,0,2,0,0,0,10,0,0, - 0,67,0,0,0,115,37,0,0,0,116,0,0,124,0,0, - 131,1,0,143,18,0,1,116,1,0,124,0,0,124,1,0, - 131,2,0,83,87,100,1,0,81,82,88,100,1,0,83,41, - 2,122,54,70,105,110,100,32,97,110,100,32,108,111,97,100, - 32,116,104,101,32,109,111,100,117,108,101,44,32,97,110,100, - 32,114,101,108,101,97,115,101,32,116,104,101,32,105,109,112, - 111,114,116,32,108,111,99,107,46,78,41,2,114,54,0,0, - 0,114,184,0,0,0,41,2,114,15,0,0,0,114,183,0, + 10,95,95,105,109,112,111,114,116,95,95,18,4,0,0,115, + 26,0,0,0,0,11,12,1,15,2,24,1,12,1,18,1, + 6,3,12,1,23,1,6,1,4,4,35,3,40,2,114,198, + 0,0,0,99,1,0,0,0,0,0,0,0,2,0,0,0, + 3,0,0,0,67,0,0,0,115,53,0,0,0,116,0,0, + 106,1,0,124,0,0,131,1,0,125,1,0,124,1,0,100, + 0,0,107,8,0,114,43,0,116,2,0,100,1,0,124,0, + 0,23,131,1,0,130,1,0,116,3,0,124,1,0,131,1, + 0,83,41,2,78,122,25,110,111,32,98,117,105,108,116,45, + 105,110,32,109,111,100,117,108,101,32,110,97,109,101,100,32, + 41,4,114,150,0,0,0,114,154,0,0,0,114,77,0,0, + 0,114,149,0,0,0,41,2,114,15,0,0,0,114,88,0, 0,0,114,10,0,0,0,114,10,0,0,0,114,11,0,0, - 0,218,14,95,102,105,110,100,95,97,110,100,95,108,111,97, - 100,198,3,0,0,115,4,0,0,0,0,2,13,1,114,185, - 0,0,0,114,33,0,0,0,99,3,0,0,0,0,0,0, - 0,5,0,0,0,4,0,0,0,67,0,0,0,115,166,0, - 0,0,116,0,0,124,0,0,124,1,0,124,2,0,131,3, - 0,1,124,2,0,100,1,0,107,4,0,114,46,0,116,1, - 0,124,0,0,124,1,0,124,2,0,131,3,0,125,0,0, - 116,2,0,106,3,0,131,0,0,1,124,0,0,116,4,0, - 106,5,0,107,7,0,114,84,0,116,6,0,124,0,0,116, - 7,0,131,2,0,83,116,4,0,106,5,0,124,0,0,25, - 125,3,0,124,3,0,100,2,0,107,8,0,114,152,0,116, - 2,0,106,8,0,131,0,0,1,100,3,0,106,9,0,124, - 0,0,131,1,0,125,4,0,116,10,0,124,4,0,100,4, - 0,124,0,0,131,1,1,130,1,0,116,11,0,124,0,0, - 131,1,0,1,124,3,0,83,41,5,97,50,1,0,0,73, - 109,112,111,114,116,32,97,110,100,32,114,101,116,117,114,110, - 32,116,104,101,32,109,111,100,117,108,101,32,98,97,115,101, - 100,32,111,110,32,105,116,115,32,110,97,109,101,44,32,116, - 104,101,32,112,97,99,107,97,103,101,32,116,104,101,32,99, - 97,108,108,32,105,115,10,32,32,32,32,98,101,105,110,103, - 32,109,97,100,101,32,102,114,111,109,44,32,97,110,100,32, - 116,104,101,32,108,101,118,101,108,32,97,100,106,117,115,116, - 109,101,110,116,46,10,10,32,32,32,32,84,104,105,115,32, - 102,117,110,99,116,105,111,110,32,114,101,112,114,101,115,101, - 110,116,115,32,116,104,101,32,103,114,101,97,116,101,115,116, - 32,99,111,109,109,111,110,32,100,101,110,111,109,105,110,97, - 116,111,114,32,111,102,32,102,117,110,99,116,105,111,110,97, - 108,105,116,121,10,32,32,32,32,98,101,116,119,101,101,110, - 32,105,109,112,111,114,116,95,109,111,100,117,108,101,32,97, - 110,100,32,95,95,105,109,112,111,114,116,95,95,46,32,84, - 104,105,115,32,105,110,99,108,117,100,101,115,32,115,101,116, - 116,105,110,103,32,95,95,112,97,99,107,97,103,101,95,95, - 32,105,102,10,32,32,32,32,116,104,101,32,108,111,97,100, - 101,114,32,100,105,100,32,110,111,116,46,10,10,32,32,32, - 32,114,33,0,0,0,78,122,40,105,109,112,111,114,116,32, - 111,102,32,123,125,32,104,97,108,116,101,100,59,32,78,111, - 110,101,32,105,110,32,115,121,115,46,109,111,100,117,108,101, - 115,114,15,0,0,0,41,12,114,181,0,0,0,114,171,0, - 0,0,114,57,0,0,0,114,145,0,0,0,114,14,0,0, - 0,114,21,0,0,0,114,185,0,0,0,218,11,95,103,99, - 100,95,105,109,112,111,114,116,114,58,0,0,0,114,50,0, - 0,0,114,77,0,0,0,114,63,0,0,0,41,5,114,15, - 0,0,0,114,169,0,0,0,114,170,0,0,0,114,89,0, - 0,0,114,74,0,0,0,114,10,0,0,0,114,10,0,0, - 0,114,11,0,0,0,114,186,0,0,0,204,3,0,0,115, - 28,0,0,0,0,9,16,1,12,1,18,1,10,1,15,1, - 13,1,13,1,12,1,10,1,6,1,9,1,18,1,10,1, - 114,186,0,0,0,99,3,0,0,0,0,0,0,0,6,0, - 0,0,17,0,0,0,67,0,0,0,115,239,0,0,0,116, - 0,0,124,0,0,100,1,0,131,2,0,114,235,0,100,2, - 0,124,1,0,107,6,0,114,83,0,116,1,0,124,1,0, - 131,1,0,125,1,0,124,1,0,106,2,0,100,2,0,131, - 1,0,1,116,0,0,124,0,0,100,3,0,131,2,0,114, - 83,0,124,1,0,106,3,0,124,0,0,106,4,0,131,1, - 0,1,120,149,0,124,1,0,68,93,141,0,125,3,0,116, - 0,0,124,0,0,124,3,0,131,2,0,115,90,0,100,4, - 0,106,5,0,124,0,0,106,6,0,124,3,0,131,2,0, - 125,4,0,121,17,0,116,7,0,124,2,0,124,4,0,131, - 2,0,1,87,113,90,0,4,116,8,0,107,10,0,114,230, - 0,1,125,5,0,1,122,47,0,116,9,0,124,5,0,131, - 1,0,106,10,0,116,11,0,131,1,0,114,209,0,124,5, - 0,106,12,0,124,4,0,107,2,0,114,209,0,119,90,0, - 130,0,0,87,89,100,5,0,100,5,0,125,5,0,126,5, - 0,88,113,90,0,88,113,90,0,87,124,0,0,83,41,6, - 122,238,70,105,103,117,114,101,32,111,117,116,32,119,104,97, - 116,32,95,95,105,109,112,111,114,116,95,95,32,115,104,111, - 117,108,100,32,114,101,116,117,114,110,46,10,10,32,32,32, - 32,84,104,101,32,105,109,112,111,114,116,95,32,112,97,114, - 97,109,101,116,101,114,32,105,115,32,97,32,99,97,108,108, - 97,98,108,101,32,119,104,105,99,104,32,116,97,107,101,115, - 32,116,104,101,32,110,97,109,101,32,111,102,32,109,111,100, - 117,108,101,32,116,111,10,32,32,32,32,105,109,112,111,114, - 116,46,32,73,116,32,105,115,32,114,101,113,117,105,114,101, - 100,32,116,111,32,100,101,99,111,117,112,108,101,32,116,104, - 101,32,102,117,110,99,116,105,111,110,32,102,114,111,109,32, - 97,115,115,117,109,105,110,103,32,105,109,112,111,114,116,108, - 105,98,39,115,10,32,32,32,32,105,109,112,111,114,116,32, - 105,109,112,108,101,109,101,110,116,97,116,105,111,110,32,105, - 115,32,100,101,115,105,114,101,100,46,10,10,32,32,32,32, - 114,131,0,0,0,250,1,42,218,7,95,95,97,108,108,95, - 95,122,5,123,125,46,123,125,78,41,13,114,4,0,0,0, - 114,130,0,0,0,218,6,114,101,109,111,118,101,218,6,101, - 120,116,101,110,100,114,188,0,0,0,114,50,0,0,0,114, - 1,0,0,0,114,65,0,0,0,114,77,0,0,0,114,178, - 0,0,0,114,71,0,0,0,218,15,95,69,82,82,95,77, - 83,71,95,80,82,69,70,73,88,114,15,0,0,0,41,6, - 114,89,0,0,0,218,8,102,114,111,109,108,105,115,116,114, - 183,0,0,0,218,1,120,90,9,102,114,111,109,95,110,97, - 109,101,90,3,101,120,99,114,10,0,0,0,114,10,0,0, - 0,114,11,0,0,0,218,16,95,104,97,110,100,108,101,95, - 102,114,111,109,108,105,115,116,228,3,0,0,115,34,0,0, - 0,0,10,15,1,12,1,12,1,13,1,15,1,16,1,13, - 1,15,1,21,1,3,1,17,1,18,4,21,1,15,1,3, - 1,26,1,114,194,0,0,0,99,1,0,0,0,0,0,0, - 0,2,0,0,0,2,0,0,0,67,0,0,0,115,72,0, - 0,0,124,0,0,106,0,0,100,1,0,131,1,0,125,1, - 0,124,1,0,100,2,0,107,8,0,114,68,0,124,0,0, - 100,3,0,25,125,1,0,100,4,0,124,0,0,107,7,0, - 114,68,0,124,1,0,106,1,0,100,5,0,131,1,0,100, - 6,0,25,125,1,0,124,1,0,83,41,7,122,167,67,97, - 108,99,117,108,97,116,101,32,119,104,97,116,32,95,95,112, - 97,99,107,97,103,101,95,95,32,115,104,111,117,108,100,32, - 98,101,46,10,10,32,32,32,32,95,95,112,97,99,107,97, - 103,101,95,95,32,105,115,32,110,111,116,32,103,117,97,114, - 97,110,116,101,101,100,32,116,111,32,98,101,32,100,101,102, - 105,110,101,100,32,111,114,32,99,111,117,108,100,32,98,101, - 32,115,101,116,32,116,111,32,78,111,110,101,10,32,32,32, - 32,116,111,32,114,101,112,114,101,115,101,110,116,32,116,104, - 97,116,32,105,116,115,32,112,114,111,112,101,114,32,118,97, - 108,117,101,32,105,115,32,117,110,107,110,111,119,110,46,10, - 10,32,32,32,32,114,134,0,0,0,78,114,1,0,0,0, - 114,131,0,0,0,114,121,0,0,0,114,33,0,0,0,41, - 2,114,42,0,0,0,114,122,0,0,0,41,2,218,7,103, - 108,111,98,97,108,115,114,169,0,0,0,114,10,0,0,0, - 114,10,0,0,0,114,11,0,0,0,218,17,95,99,97,108, - 99,95,95,95,112,97,99,107,97,103,101,95,95,4,4,0, - 0,115,12,0,0,0,0,7,15,1,12,1,10,1,12,1, - 19,1,114,196,0,0,0,99,5,0,0,0,0,0,0,0, - 9,0,0,0,5,0,0,0,67,0,0,0,115,227,0,0, - 0,124,4,0,100,1,0,107,2,0,114,27,0,116,0,0, - 124,0,0,131,1,0,125,5,0,110,54,0,124,1,0,100, - 2,0,107,9,0,114,45,0,124,1,0,110,3,0,105,0, - 0,125,6,0,116,1,0,124,6,0,131,1,0,125,7,0, - 116,0,0,124,0,0,124,7,0,124,4,0,131,3,0,125, - 5,0,124,3,0,115,207,0,124,4,0,100,1,0,107,2, - 0,114,122,0,116,0,0,124,0,0,106,2,0,100,3,0, - 131,1,0,100,1,0,25,131,1,0,83,124,0,0,115,132, - 0,124,5,0,83,116,3,0,124,0,0,131,1,0,116,3, - 0,124,0,0,106,2,0,100,3,0,131,1,0,100,1,0, - 25,131,1,0,24,125,8,0,116,4,0,106,5,0,124,5, - 0,106,6,0,100,2,0,116,3,0,124,5,0,106,6,0, - 131,1,0,124,8,0,24,133,2,0,25,25,83,110,16,0, - 116,7,0,124,5,0,124,3,0,116,0,0,131,3,0,83, - 100,2,0,83,41,4,97,215,1,0,0,73,109,112,111,114, - 116,32,97,32,109,111,100,117,108,101,46,10,10,32,32,32, - 32,84,104,101,32,39,103,108,111,98,97,108,115,39,32,97, - 114,103,117,109,101,110,116,32,105,115,32,117,115,101,100,32, - 116,111,32,105,110,102,101,114,32,119,104,101,114,101,32,116, - 104,101,32,105,109,112,111,114,116,32,105,115,32,111,99,99, - 117,114,114,105,110,103,32,102,114,111,109,10,32,32,32,32, - 116,111,32,104,97,110,100,108,101,32,114,101,108,97,116,105, - 118,101,32,105,109,112,111,114,116,115,46,32,84,104,101,32, - 39,108,111,99,97,108,115,39,32,97,114,103,117,109,101,110, - 116,32,105,115,32,105,103,110,111,114,101,100,46,32,84,104, - 101,10,32,32,32,32,39,102,114,111,109,108,105,115,116,39, - 32,97,114,103,117,109,101,110,116,32,115,112,101,99,105,102, - 105,101,115,32,119,104,97,116,32,115,104,111,117,108,100,32, - 101,120,105,115,116,32,97,115,32,97,116,116,114,105,98,117, - 116,101,115,32,111,110,32,116,104,101,32,109,111,100,117,108, - 101,10,32,32,32,32,98,101,105,110,103,32,105,109,112,111, - 114,116,101,100,32,40,101,46,103,46,32,96,96,102,114,111, - 109,32,109,111,100,117,108,101,32,105,109,112,111,114,116,32, - 60,102,114,111,109,108,105,115,116,62,96,96,41,46,32,32, - 84,104,101,32,39,108,101,118,101,108,39,10,32,32,32,32, - 97,114,103,117,109,101,110,116,32,114,101,112,114,101,115,101, - 110,116,115,32,116,104,101,32,112,97,99,107,97,103,101,32, - 108,111,99,97,116,105,111,110,32,116,111,32,105,109,112,111, - 114,116,32,102,114,111,109,32,105,110,32,97,32,114,101,108, - 97,116,105,118,101,10,32,32,32,32,105,109,112,111,114,116, - 32,40,101,46,103,46,32,96,96,102,114,111,109,32,46,46, - 112,107,103,32,105,109,112,111,114,116,32,109,111,100,96,96, - 32,119,111,117,108,100,32,104,97,118,101,32,97,32,39,108, - 101,118,101,108,39,32,111,102,32,50,41,46,10,10,32,32, - 32,32,114,33,0,0,0,78,114,121,0,0,0,41,8,114, - 186,0,0,0,114,196,0,0,0,218,9,112,97,114,116,105, - 116,105,111,110,114,167,0,0,0,114,14,0,0,0,114,21, - 0,0,0,114,1,0,0,0,114,194,0,0,0,41,9,114, - 15,0,0,0,114,195,0,0,0,218,6,108,111,99,97,108, - 115,114,192,0,0,0,114,170,0,0,0,114,89,0,0,0, - 90,8,103,108,111,98,97,108,115,95,114,169,0,0,0,90, - 7,99,117,116,95,111,102,102,114,10,0,0,0,114,10,0, - 0,0,114,11,0,0,0,218,10,95,95,105,109,112,111,114, - 116,95,95,19,4,0,0,115,26,0,0,0,0,11,12,1, - 15,2,24,1,12,1,18,1,6,3,12,1,23,1,6,1, - 4,4,35,3,40,2,114,199,0,0,0,99,1,0,0,0, - 0,0,0,0,2,0,0,0,3,0,0,0,67,0,0,0, - 115,53,0,0,0,116,0,0,106,1,0,124,0,0,131,1, - 0,125,1,0,124,1,0,100,0,0,107,8,0,114,43,0, - 116,2,0,100,1,0,124,0,0,23,131,1,0,130,1,0, - 116,3,0,124,1,0,131,1,0,83,41,2,78,122,25,110, - 111,32,98,117,105,108,116,45,105,110,32,109,111,100,117,108, - 101,32,110,97,109,101,100,32,41,4,114,150,0,0,0,114, - 154,0,0,0,114,77,0,0,0,114,149,0,0,0,41,2, - 114,15,0,0,0,114,88,0,0,0,114,10,0,0,0,114, - 10,0,0,0,114,11,0,0,0,218,18,95,98,117,105,108, - 116,105,110,95,102,114,111,109,95,110,97,109,101,54,4,0, - 0,115,8,0,0,0,0,1,15,1,12,1,16,1,114,200, - 0,0,0,99,2,0,0,0,0,0,0,0,12,0,0,0, - 12,0,0,0,67,0,0,0,115,74,1,0,0,124,1,0, - 97,0,0,124,0,0,97,1,0,116,2,0,116,1,0,131, - 1,0,125,2,0,120,123,0,116,1,0,106,3,0,106,4, - 0,131,0,0,68,93,106,0,92,2,0,125,3,0,125,4, - 0,116,5,0,124,4,0,124,2,0,131,2,0,114,40,0, - 124,3,0,116,1,0,106,6,0,107,6,0,114,91,0,116, - 7,0,125,5,0,110,27,0,116,0,0,106,8,0,124,3, - 0,131,1,0,114,40,0,116,9,0,125,5,0,110,3,0, - 113,40,0,116,10,0,124,4,0,124,5,0,131,2,0,125, - 6,0,116,11,0,124,6,0,124,4,0,131,2,0,1,113, - 40,0,87,116,1,0,106,3,0,116,12,0,25,125,7,0, - 120,73,0,100,5,0,68,93,65,0,125,8,0,124,8,0, - 116,1,0,106,3,0,107,7,0,114,206,0,116,13,0,124, - 8,0,131,1,0,125,9,0,110,13,0,116,1,0,106,3, - 0,124,8,0,25,125,9,0,116,14,0,124,7,0,124,8, - 0,124,9,0,131,3,0,1,113,170,0,87,121,16,0,116, - 13,0,100,2,0,131,1,0,125,10,0,87,110,24,0,4, - 116,15,0,107,10,0,114,25,1,1,1,1,100,3,0,125, - 10,0,89,110,1,0,88,116,14,0,124,7,0,100,2,0, - 124,10,0,131,3,0,1,116,13,0,100,4,0,131,1,0, - 125,11,0,116,14,0,124,7,0,100,4,0,124,11,0,131, - 3,0,1,100,3,0,83,41,6,122,250,83,101,116,117,112, - 32,105,109,112,111,114,116,108,105,98,32,98,121,32,105,109, - 112,111,114,116,105,110,103,32,110,101,101,100,101,100,32,98, - 117,105,108,116,45,105,110,32,109,111,100,117,108,101,115,32, - 97,110,100,32,105,110,106,101,99,116,105,110,103,32,116,104, - 101,109,10,32,32,32,32,105,110,116,111,32,116,104,101,32, - 103,108,111,98,97,108,32,110,97,109,101,115,112,97,99,101, - 46,10,10,32,32,32,32,65,115,32,115,121,115,32,105,115, - 32,110,101,101,100,101,100,32,102,111,114,32,115,121,115,46, - 109,111,100,117,108,101,115,32,97,99,99,101,115,115,32,97, - 110,100,32,95,105,109,112,32,105,115,32,110,101,101,100,101, - 100,32,116,111,32,108,111,97,100,32,98,117,105,108,116,45, - 105,110,10,32,32,32,32,109,111,100,117,108,101,115,44,32, - 116,104,111,115,101,32,116,119,111,32,109,111,100,117,108,101, - 115,32,109,117,115,116,32,98,101,32,101,120,112,108,105,99, - 105,116,108,121,32,112,97,115,115,101,100,32,105,110,46,10, - 10,32,32,32,32,114,141,0,0,0,114,34,0,0,0,78, - 114,62,0,0,0,41,1,114,141,0,0,0,41,16,114,57, - 0,0,0,114,14,0,0,0,114,13,0,0,0,114,21,0, - 0,0,218,5,105,116,101,109,115,114,177,0,0,0,114,76, - 0,0,0,114,150,0,0,0,114,82,0,0,0,114,160,0, - 0,0,114,132,0,0,0,114,137,0,0,0,114,1,0,0, - 0,114,200,0,0,0,114,5,0,0,0,114,77,0,0,0, - 41,12,218,10,115,121,115,95,109,111,100,117,108,101,218,11, - 95,105,109,112,95,109,111,100,117,108,101,90,11,109,111,100, - 117,108,101,95,116,121,112,101,114,15,0,0,0,114,89,0, - 0,0,114,99,0,0,0,114,88,0,0,0,90,11,115,101, - 108,102,95,109,111,100,117,108,101,90,12,98,117,105,108,116, - 105,110,95,110,97,109,101,90,14,98,117,105,108,116,105,110, - 95,109,111,100,117,108,101,90,13,116,104,114,101,97,100,95, - 109,111,100,117,108,101,90,14,119,101,97,107,114,101,102,95, - 109,111,100,117,108,101,114,10,0,0,0,114,10,0,0,0, - 114,11,0,0,0,218,6,95,115,101,116,117,112,61,4,0, - 0,115,50,0,0,0,0,9,6,1,6,3,12,1,28,1, - 15,1,15,1,9,1,15,1,9,2,3,1,15,1,17,3, - 13,1,13,1,15,1,15,2,13,1,20,3,3,1,16,1, - 13,2,11,1,16,3,12,1,114,204,0,0,0,99,2,0, - 0,0,0,0,0,0,3,0,0,0,3,0,0,0,67,0, - 0,0,115,87,0,0,0,116,0,0,124,0,0,124,1,0, - 131,2,0,1,116,1,0,106,2,0,106,3,0,116,4,0, - 131,1,0,1,116,1,0,106,2,0,106,3,0,116,5,0, - 131,1,0,1,100,1,0,100,2,0,108,6,0,125,2,0, - 124,2,0,97,7,0,124,2,0,106,8,0,116,1,0,106, - 9,0,116,10,0,25,131,1,0,1,100,2,0,83,41,3, - 122,50,73,110,115,116,97,108,108,32,105,109,112,111,114,116, - 108,105,98,32,97,115,32,116,104,101,32,105,109,112,108,101, - 109,101,110,116,97,116,105,111,110,32,111,102,32,105,109,112, - 111,114,116,46,114,33,0,0,0,78,41,11,114,204,0,0, - 0,114,14,0,0,0,114,174,0,0,0,114,113,0,0,0, - 114,150,0,0,0,114,160,0,0,0,218,26,95,102,114,111, - 122,101,110,95,105,109,112,111,114,116,108,105,98,95,101,120, - 116,101,114,110,97,108,114,119,0,0,0,218,8,95,105,110, - 115,116,97,108,108,114,21,0,0,0,114,1,0,0,0,41, - 3,114,202,0,0,0,114,203,0,0,0,114,205,0,0,0, - 114,10,0,0,0,114,10,0,0,0,114,11,0,0,0,114, - 206,0,0,0,108,4,0,0,115,12,0,0,0,0,2,13, - 2,16,1,16,3,12,1,6,1,114,206,0,0,0,41,51, - 114,3,0,0,0,114,119,0,0,0,114,12,0,0,0,114, - 16,0,0,0,114,17,0,0,0,114,59,0,0,0,114,41, - 0,0,0,114,48,0,0,0,114,31,0,0,0,114,32,0, - 0,0,114,53,0,0,0,114,54,0,0,0,114,56,0,0, - 0,114,63,0,0,0,114,65,0,0,0,114,75,0,0,0, - 114,81,0,0,0,114,84,0,0,0,114,90,0,0,0,114, - 101,0,0,0,114,102,0,0,0,114,106,0,0,0,114,85, - 0,0,0,218,6,111,98,106,101,99,116,90,9,95,80,79, - 80,85,76,65,84,69,114,132,0,0,0,114,137,0,0,0, - 114,144,0,0,0,114,97,0,0,0,114,86,0,0,0,114, - 148,0,0,0,114,149,0,0,0,114,87,0,0,0,114,150, - 0,0,0,114,160,0,0,0,114,165,0,0,0,114,171,0, - 0,0,114,173,0,0,0,114,176,0,0,0,114,181,0,0, - 0,114,191,0,0,0,114,182,0,0,0,114,184,0,0,0, - 114,185,0,0,0,114,186,0,0,0,114,194,0,0,0,114, - 196,0,0,0,114,199,0,0,0,114,200,0,0,0,114,204, - 0,0,0,114,206,0,0,0,114,10,0,0,0,114,10,0, - 0,0,114,10,0,0,0,114,11,0,0,0,218,8,60,109, - 111,100,117,108,101,62,8,0,0,0,115,96,0,0,0,6, - 17,6,2,12,8,12,4,19,20,6,2,6,3,22,4,19, - 68,19,21,19,19,12,19,12,19,12,11,18,8,12,11,12, - 12,12,16,12,36,19,27,19,101,24,26,9,3,18,45,18, - 60,12,18,12,17,12,25,12,29,12,23,12,16,19,73,19, - 77,19,13,12,9,12,9,15,40,12,17,6,1,10,2,12, - 27,12,6,18,24,12,32,12,15,24,35,12,7,12,47, + 0,218,18,95,98,117,105,108,116,105,110,95,102,114,111,109, + 95,110,97,109,101,53,4,0,0,115,8,0,0,0,0,1, + 15,1,12,1,16,1,114,199,0,0,0,99,2,0,0,0, + 0,0,0,0,12,0,0,0,12,0,0,0,67,0,0,0, + 115,74,1,0,0,124,1,0,97,0,0,124,0,0,97,1, + 0,116,2,0,116,1,0,131,1,0,125,2,0,120,123,0, + 116,1,0,106,3,0,106,4,0,131,0,0,68,93,106,0, + 92,2,0,125,3,0,125,4,0,116,5,0,124,4,0,124, + 2,0,131,2,0,114,40,0,124,3,0,116,1,0,106,6, + 0,107,6,0,114,91,0,116,7,0,125,5,0,110,27,0, + 116,0,0,106,8,0,124,3,0,131,1,0,114,40,0,116, + 9,0,125,5,0,110,3,0,113,40,0,116,10,0,124,4, + 0,124,5,0,131,2,0,125,6,0,116,11,0,124,6,0, + 124,4,0,131,2,0,1,113,40,0,87,116,1,0,106,3, + 0,116,12,0,25,125,7,0,120,73,0,100,5,0,68,93, + 65,0,125,8,0,124,8,0,116,1,0,106,3,0,107,7, + 0,114,206,0,116,13,0,124,8,0,131,1,0,125,9,0, + 110,13,0,116,1,0,106,3,0,124,8,0,25,125,9,0, + 116,14,0,124,7,0,124,8,0,124,9,0,131,3,0,1, + 113,170,0,87,121,16,0,116,13,0,100,2,0,131,1,0, + 125,10,0,87,110,24,0,4,116,15,0,107,10,0,114,25, + 1,1,1,1,100,3,0,125,10,0,89,110,1,0,88,116, + 14,0,124,7,0,100,2,0,124,10,0,131,3,0,1,116, + 13,0,100,4,0,131,1,0,125,11,0,116,14,0,124,7, + 0,100,4,0,124,11,0,131,3,0,1,100,3,0,83,41, + 6,122,250,83,101,116,117,112,32,105,109,112,111,114,116,108, + 105,98,32,98,121,32,105,109,112,111,114,116,105,110,103,32, + 110,101,101,100,101,100,32,98,117,105,108,116,45,105,110,32, + 109,111,100,117,108,101,115,32,97,110,100,32,105,110,106,101, + 99,116,105,110,103,32,116,104,101,109,10,32,32,32,32,105, + 110,116,111,32,116,104,101,32,103,108,111,98,97,108,32,110, + 97,109,101,115,112,97,99,101,46,10,10,32,32,32,32,65, + 115,32,115,121,115,32,105,115,32,110,101,101,100,101,100,32, + 102,111,114,32,115,121,115,46,109,111,100,117,108,101,115,32, + 97,99,99,101,115,115,32,97,110,100,32,95,105,109,112,32, + 105,115,32,110,101,101,100,101,100,32,116,111,32,108,111,97, + 100,32,98,117,105,108,116,45,105,110,10,32,32,32,32,109, + 111,100,117,108,101,115,44,32,116,104,111,115,101,32,116,119, + 111,32,109,111,100,117,108,101,115,32,109,117,115,116,32,98, + 101,32,101,120,112,108,105,99,105,116,108,121,32,112,97,115, + 115,101,100,32,105,110,46,10,10,32,32,32,32,114,141,0, + 0,0,114,34,0,0,0,78,114,62,0,0,0,41,1,114, + 141,0,0,0,41,16,114,57,0,0,0,114,14,0,0,0, + 114,13,0,0,0,114,21,0,0,0,218,5,105,116,101,109, + 115,114,177,0,0,0,114,76,0,0,0,114,150,0,0,0, + 114,82,0,0,0,114,160,0,0,0,114,132,0,0,0,114, + 137,0,0,0,114,1,0,0,0,114,199,0,0,0,114,5, + 0,0,0,114,77,0,0,0,41,12,218,10,115,121,115,95, + 109,111,100,117,108,101,218,11,95,105,109,112,95,109,111,100, + 117,108,101,90,11,109,111,100,117,108,101,95,116,121,112,101, + 114,15,0,0,0,114,89,0,0,0,114,99,0,0,0,114, + 88,0,0,0,90,11,115,101,108,102,95,109,111,100,117,108, + 101,90,12,98,117,105,108,116,105,110,95,110,97,109,101,90, + 14,98,117,105,108,116,105,110,95,109,111,100,117,108,101,90, + 13,116,104,114,101,97,100,95,109,111,100,117,108,101,90,14, + 119,101,97,107,114,101,102,95,109,111,100,117,108,101,114,10, + 0,0,0,114,10,0,0,0,114,11,0,0,0,218,6,95, + 115,101,116,117,112,60,4,0,0,115,50,0,0,0,0,9, + 6,1,6,3,12,1,28,1,15,1,15,1,9,1,15,1, + 9,2,3,1,15,1,17,3,13,1,13,1,15,1,15,2, + 13,1,20,3,3,1,16,1,13,2,11,1,16,3,12,1, + 114,203,0,0,0,99,2,0,0,0,0,0,0,0,3,0, + 0,0,3,0,0,0,67,0,0,0,115,87,0,0,0,116, + 0,0,124,0,0,124,1,0,131,2,0,1,116,1,0,106, + 2,0,106,3,0,116,4,0,131,1,0,1,116,1,0,106, + 2,0,106,3,0,116,5,0,131,1,0,1,100,1,0,100, + 2,0,108,6,0,125,2,0,124,2,0,97,7,0,124,2, + 0,106,8,0,116,1,0,106,9,0,116,10,0,25,131,1, + 0,1,100,2,0,83,41,3,122,50,73,110,115,116,97,108, + 108,32,105,109,112,111,114,116,108,105,98,32,97,115,32,116, + 104,101,32,105,109,112,108,101,109,101,110,116,97,116,105,111, + 110,32,111,102,32,105,109,112,111,114,116,46,114,33,0,0, + 0,78,41,11,114,203,0,0,0,114,14,0,0,0,114,174, + 0,0,0,114,113,0,0,0,114,150,0,0,0,114,160,0, + 0,0,218,26,95,102,114,111,122,101,110,95,105,109,112,111, + 114,116,108,105,98,95,101,120,116,101,114,110,97,108,114,119, + 0,0,0,218,8,95,105,110,115,116,97,108,108,114,21,0, + 0,0,114,1,0,0,0,41,3,114,201,0,0,0,114,202, + 0,0,0,114,204,0,0,0,114,10,0,0,0,114,10,0, + 0,0,114,11,0,0,0,114,205,0,0,0,107,4,0,0, + 115,12,0,0,0,0,2,13,2,16,1,16,3,12,1,6, + 1,114,205,0,0,0,41,51,114,3,0,0,0,114,119,0, + 0,0,114,12,0,0,0,114,16,0,0,0,114,17,0,0, + 0,114,59,0,0,0,114,41,0,0,0,114,48,0,0,0, + 114,31,0,0,0,114,32,0,0,0,114,53,0,0,0,114, + 54,0,0,0,114,56,0,0,0,114,63,0,0,0,114,65, + 0,0,0,114,75,0,0,0,114,81,0,0,0,114,84,0, + 0,0,114,90,0,0,0,114,101,0,0,0,114,102,0,0, + 0,114,106,0,0,0,114,85,0,0,0,218,6,111,98,106, + 101,99,116,90,9,95,80,79,80,85,76,65,84,69,114,132, + 0,0,0,114,137,0,0,0,114,144,0,0,0,114,97,0, + 0,0,114,86,0,0,0,114,148,0,0,0,114,149,0,0, + 0,114,87,0,0,0,114,150,0,0,0,114,160,0,0,0, + 114,165,0,0,0,114,171,0,0,0,114,173,0,0,0,114, + 176,0,0,0,114,180,0,0,0,114,190,0,0,0,114,181, + 0,0,0,114,183,0,0,0,114,184,0,0,0,114,185,0, + 0,0,114,193,0,0,0,114,195,0,0,0,114,198,0,0, + 0,114,199,0,0,0,114,203,0,0,0,114,205,0,0,0, + 114,10,0,0,0,114,10,0,0,0,114,10,0,0,0,114, + 11,0,0,0,218,8,60,109,111,100,117,108,101,62,8,0, + 0,0,115,96,0,0,0,6,17,6,2,12,8,12,4,19, + 20,6,2,6,3,22,4,19,68,19,21,19,19,12,19,12, + 19,12,11,18,8,12,11,12,12,12,16,12,36,19,27,19, + 101,24,26,9,3,18,45,18,60,12,18,12,17,12,25,12, + 29,12,23,12,16,19,73,19,77,19,13,12,9,12,9,15, + 40,12,16,6,1,10,2,12,27,12,6,18,24,12,32,12, + 15,24,35,12,7,12,47, }; From solipsis at pitrou.net Sun Jul 23 05:06:57 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sun, 23 Jul 2017 09:06:57 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=8 Message-ID: <20170723090657.75383.F25BFA373A56B75A@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 3, 0] memory blocks, sum=3 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [1, 0, -2] memory blocks, sum=-1 test_multiprocessing_spawn leaked [2, 0, 0] memory blocks, sum=2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogWr2tMS', '--timeout', '7200'] From webhook-mailer at python.org Sun Jul 23 07:05:29 2017 From: webhook-mailer at python.org (Antoine Pitrou) Date: Sun, 23 Jul 2017 11:05:29 -0000 Subject: [Python-checkins] bpo-30919: shared memory allocation performance regression in multiprocessing (#2708) Message-ID: https://github.com/python/cpython/commit/3051f0b78e53d1b771b49375dc139ca13f9fd76e commit: 3051f0b78e53d1b771b49375dc139ca13f9fd76e branch: master author: Antoine Pitrou committer: GitHub date: 2017-07-23T13:05:26+02:00 summary: bpo-30919: shared memory allocation performance regression in multiprocessing (#2708) * Fix #30919: shared memory allocation performance regression in multiprocessing * Change strategy for Arena directory choice * Add blurb files: A Misc/NEWS.d/next/Library/2017-07-23-11-33-10.bpo-30919.5dYRru.rst M Lib/multiprocessing/heap.py diff --git a/Lib/multiprocessing/heap.py b/Lib/multiprocessing/heap.py index 443321535ec..ee3ed551d0c 100644 --- a/Lib/multiprocessing/heap.py +++ b/Lib/multiprocessing/heap.py @@ -60,26 +60,32 @@ def __setstate__(self, state): else: class Arena(object): + if sys.platform == 'linux': + _dir_candidates = ['/dev/shm'] + else: + _dir_candidates = [] def __init__(self, size, fd=-1): self.size = size self.fd = fd if fd == -1: self.fd, name = tempfile.mkstemp( - prefix='pym-%d-'%os.getpid(), dir=util.get_temp_dir()) + prefix='pym-%d-'%os.getpid(), + dir=self._choose_dir(size)) os.unlink(name) util.Finalize(self, os.close, (self.fd,)) - with open(self.fd, 'wb', closefd=False) as f: - bs = 1024 * 1024 - if size >= bs: - zeros = b'\0' * bs - for _ in range(size // bs): - f.write(zeros) - del zeros - f.write(b'\0' * (size % bs)) - assert f.tell() == size + os.ftruncate(self.fd, size) self.buffer = mmap.mmap(self.fd, self.size) + def _choose_dir(self, size): + # Choose a non-storage backed directory if possible, + # to improve performance + for d in self._dir_candidates: + st = os.statvfs(d) + if st.f_bavail * st.f_frsize >= size: # enough free space? + return d + return util.get_temp_dir() + def reduce_arena(a): if a.fd == -1: raise ValueError('Arena is unpicklable because ' diff --git a/Misc/NEWS.d/next/Library/2017-07-23-11-33-10.bpo-30919.5dYRru.rst b/Misc/NEWS.d/next/Library/2017-07-23-11-33-10.bpo-30919.5dYRru.rst new file mode 100644 index 00000000000..44c3a22bc85 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-23-11-33-10.bpo-30919.5dYRru.rst @@ -0,0 +1,4 @@ +Fix shared memory performance regression in multiprocessing in 3.x. + +Shared memory used anonymous memory mappings in 2.x, while 3.x mmaps actual +files. Try to be careful to do as little disk I/O as possible. From webhook-mailer at python.org Sun Jul 23 12:20:10 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 23 Jul 2017 16:20:10 -0000 Subject: [Python-checkins] bpo-30993: IDLE - Improve configdialog font page and tests. (#2818) Message-ID: https://github.com/python/cpython/commit/07ba305a4c169e017e076e490a173a6f9b95b38e commit: 07ba305a4c169e017e076e490a173a6f9b95b38e branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-23T12:20:08-04:00 summary: bpo-30993: IDLE - Improve configdialog font page and tests. (#2818) * Document causal event pathways in docstring. * Simplify some attribute names. * Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix test_font_set so not order dependent. * Fix renamed test_indent_scale so it tests the widget. files: A Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index c1db76817c1..d51eca6f533 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -153,70 +153,73 @@ def create_action_buttons(self): def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. - Enable users to provisionally change font face, size, or + Fonts: Enable users to provisionally change font face, size, or boldness and to see the consequence of proposed choices. Each action set 3 options in changes structuree and changes the corresponding aspect of the font sample on this page and highlight sample on highlight page. - Enable users to change spaces entered for indent tabs. + Fontlist: mouse button 1 click or up or down key invoke + on_fontlist_select(), which sets Var font_name and calls + set_samples. - Tk Variables: - font_name: Font face. - font_size: Font size. - font_bold: Select font bold or not. - Note: these 3 share var_changed_font callback. - space_num: Indentation width. + Sizelist: clicking the menubutton opens the dropdown menu. A + mouse button 1 click or return key invokes an internal command + which sets Var font_size and calls set_samples. - Data Attribute: - edit_font: Font with default font name, size, and weight. + Bold_toggle, clicking the box toggles font_bold and calls + set_samples. - Methods: - load_font_cfg: Set vars and fontlist. - on_fontlist_select: Bound to fontlist button release - or key release. - set_samples: Notify both samples of any font change. - load_tab_cfg: Get current. + Setting any of the font vars invokes var_changed_font, which + adds all 3 font options to changes. Set_samples applies a new + font constructed from the font vars to font_sample and + highlight_sample on the hightlight page. + + Tabs: Enable users to change spaces entered for indent tabs. + Changing indent_scale value with the mouse sets Var space_num, + which invokes var_changed_space_num, which adds an entry to + changes. + + Load_font_cfg and load_tab_cfg initialize vars and widgets from + idleConf entries. Widget Structure: (*) widgets bound to self - frame + frame (of tab_pages) frame_font: LabelFrame frame_font_name: Frame font_name_title: Label - (*)fontlist: ListBox + (*)fontlist: ListBox - font_name scroll_font: Scrollbar frame_font_param: Frame font_size_title: Label - (*)opt_menu_font_size: DynOptionMenu - font_size + (*)sizelist: DynOptionMenu - font_size (*)bold_toggle: Checkbutton - font_bold frame_font_sample: Frame (*)font_sample: Label frame_indent: LabelFrame - frame_indent_size: Frame - indent_size_title: Label - (*)scale_indent_size: Scale - space_num + indent_title: Label + (*)indent_scale: Scale - space_num """ parent = self.parent self.font_name = StringVar(parent) self.font_size = StringVar(parent) self.font_bold = BooleanVar(parent) self.space_num = IntVar(parent) - self.edit_font = tkFont.Font(parent, ('courier', 10, 'normal')) - # Create widgets. + # Create widgets: # body and body section frames. frame = self.tab_pages.pages['Fonts/Tabs'].frame frame_font = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') frame_indent = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') - # frame_font + # frame_font. frame_font_name = Frame(frame_font) frame_font_param = Frame(frame_font) font_name_title = Label( frame_font_name, justify=LEFT, text='Font Face :') - self.fontlist = Listbox( - frame_font_name, height=5, takefocus=FALSE, exportselection=FALSE) + self.fontlist = Listbox(frame_font_name, height=5, + takefocus=FALSE, exportselection=FALSE) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) @@ -224,43 +227,43 @@ def create_page_font_tab(self): scroll_font.config(command=self.fontlist.yview) self.fontlist.config(yscrollcommand=scroll_font.set) font_size_title = Label(frame_font_param, text='Size :') - self.opt_menu_font_size = DynOptionMenu( - frame_font_param, self.font_size, None, command=self.set_samples) + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, + None, command=self.set_samples) self.bold_toggle = Checkbutton( frame_font_param, variable=self.font_bold, onvalue=1, offvalue=0, text='Bold', command=self.set_samples) frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) + temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( - frame_font_sample, justify=LEFT, font=self.edit_font, + frame_font_sample, justify=LEFT, font=temp_font, text='AaBbCcDdEe\nFfGgHhIiJjK\n1234567890\n#:+=(){}[]') - # frame_indent - frame_indent_size = Frame(frame_indent) - indent_size_title = Label( - frame_indent_size, justify=LEFT, + # frame_indent. + indent_title = Label( + frame_indent, justify=LEFT, text='Python Standard: 4 Spaces!') - self.scale_indent_size = Scale( - frame_indent_size, variable=self.space_num, + self.indent_scale = Scale( + frame_indent, variable=self.space_num, orient='horizontal', tickinterval=2, from_=2, to=16) - # Pack widgets. - # body + # Pack widgets: + # body. frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) - # frame_font + # frame_font. frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) font_name_title.pack(side=TOP, anchor=W) self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) scroll_font.pack(side=LEFT, fill=Y) font_size_title.pack(side=LEFT, anchor=W) - self.opt_menu_font_size.pack(side=LEFT, anchor=W) + self.sizelist.pack(side=LEFT, anchor=W) self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) self.font_sample.pack(expand=TRUE, fill=BOTH) - # frame_indent - frame_indent_size.pack(side=TOP, fill=X) - indent_size_title.pack(side=TOP, anchor=W, padx=5) - self.scale_indent_size.pack(side=TOP, padx=5, fill=X) + # frame_indent. + frame_indent.pack(side=TOP, fill=X) + indent_title.pack(side=TOP, anchor=W, padx=5) + self.indent_scale.pack(side=TOP, padx=5, fill=X) return frame @@ -1410,7 +1413,7 @@ def load_font_cfg(self): Attributes updated: fontlist: Populate with fonts from tkinter.font. font_name: Set to current font. - opt_menu_font_size: Populate valid options tuple and set + sizelist: Populate valid options tuple and set to current size. font_bold: Set to current font weight. @@ -1437,9 +1440,9 @@ def load_font_cfg(self): except ValueError: pass # Set font size dropdown. - self.opt_menu_font_size.SetMenu(('7', '8', '9', '10', '11', '12', '13', - '14', '16', '18', '20', '22', - '25', '29', '34', '40'), font_size ) + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) # Set font weight. self.font_bold.set(font_bold) # Set font sample. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 171fa3d309c..b6d5df3c5b4 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -59,25 +59,28 @@ def test_font_set(self): default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' - dialog.font_name.set('Test Font') + d = dialog + d.font_name.set('Test Font') + d.font_size.set(default_size) + d.font_bold.set(default_bold) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': default_size, 'font-bold': str(default_bold)}} self.assertEqual(mainpage, expected) changes.clear() - dialog.font_size.set(20) + d.font_size.set(20) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': '20', 'font-bold': str(default_bold)}} self.assertEqual(mainpage, expected) changes.clear() - dialog.font_bold.set(not default_bold) + d.font_bold.set(not default_bold) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': '20', 'font-bold': str(not default_bold)}} self.assertEqual(mainpage, expected) - def test_set_samples_bold_toggle(self): + def test_bold_toggle_set_samples(self): # Set up. d = dialog d.font_sample, d.highlight_sample = {}, {} # Must undo this. @@ -91,7 +94,7 @@ def test_set_samples_bold_toggle(self): d.set_samples() self.assertTrue(d.font_sample == d.highlight_sample == expected1) - # Test bold_toggle. + # Test bold_toggle. If this fails, problem precedes set_samples. d.bold_toggle.invoke() self.assertFalse(d.font_bold.get()) self.assertTrue(d.font_sample == d.highlight_sample == expected0) @@ -102,9 +105,10 @@ def test_set_samples_bold_toggle(self): # Clean up. del d.font_sample, d.highlight_sample - def test_tabspace(self): - dialog.space_num.set(6) - self.assertEqual(mainpage, {'Indent': {'num-spaces': '6'}}) + def test_indent_scale(self): + dialog.indent_scale.set(26) + self.assertEqual(dialog.space_num.get(), 16) + self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) class FontSelectTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst new file mode 100644 index 00000000000..8eab703c526 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst @@ -0,0 +1,6 @@ +IDLE - Improve configdialog font page and tests. + +* Document causal pathways in docstring. * Simplify some attribute names. * +Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix +test_font_set so not order dependent. * Fix renamed test_indent_scale so it +tests the widget. From webhook-mailer at python.org Sun Jul 23 14:18:30 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 23 Jul 2017 18:18:30 -0000 Subject: [Python-checkins] [3.6] bpo-30993: IDLE - Improve configdialog font page and tests. (GH-2818) (#2826) Message-ID: https://github.com/python/cpython/commit/5aa3bf041de5ee90ccbfcff103dcf3e54c5af237 commit: 5aa3bf041de5ee90ccbfcff103dcf3e54c5af237 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-23T14:18:27-04:00 summary: [3.6] bpo-30993: IDLE - Improve configdialog font page and tests. (GH-2818) (#2826) * Document causal event pathways in docstring. * Simplify some attribute names. * Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix test_font_set so not order dependent. * Fix renamed test_indent_scale so it tests the widget. (cherry picked from commit 07ba305) files: A Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index c1db76817c1..d51eca6f533 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -153,70 +153,73 @@ def create_action_buttons(self): def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. - Enable users to provisionally change font face, size, or + Fonts: Enable users to provisionally change font face, size, or boldness and to see the consequence of proposed choices. Each action set 3 options in changes structuree and changes the corresponding aspect of the font sample on this page and highlight sample on highlight page. - Enable users to change spaces entered for indent tabs. + Fontlist: mouse button 1 click or up or down key invoke + on_fontlist_select(), which sets Var font_name and calls + set_samples. - Tk Variables: - font_name: Font face. - font_size: Font size. - font_bold: Select font bold or not. - Note: these 3 share var_changed_font callback. - space_num: Indentation width. + Sizelist: clicking the menubutton opens the dropdown menu. A + mouse button 1 click or return key invokes an internal command + which sets Var font_size and calls set_samples. - Data Attribute: - edit_font: Font with default font name, size, and weight. + Bold_toggle, clicking the box toggles font_bold and calls + set_samples. - Methods: - load_font_cfg: Set vars and fontlist. - on_fontlist_select: Bound to fontlist button release - or key release. - set_samples: Notify both samples of any font change. - load_tab_cfg: Get current. + Setting any of the font vars invokes var_changed_font, which + adds all 3 font options to changes. Set_samples applies a new + font constructed from the font vars to font_sample and + highlight_sample on the hightlight page. + + Tabs: Enable users to change spaces entered for indent tabs. + Changing indent_scale value with the mouse sets Var space_num, + which invokes var_changed_space_num, which adds an entry to + changes. + + Load_font_cfg and load_tab_cfg initialize vars and widgets from + idleConf entries. Widget Structure: (*) widgets bound to self - frame + frame (of tab_pages) frame_font: LabelFrame frame_font_name: Frame font_name_title: Label - (*)fontlist: ListBox + (*)fontlist: ListBox - font_name scroll_font: Scrollbar frame_font_param: Frame font_size_title: Label - (*)opt_menu_font_size: DynOptionMenu - font_size + (*)sizelist: DynOptionMenu - font_size (*)bold_toggle: Checkbutton - font_bold frame_font_sample: Frame (*)font_sample: Label frame_indent: LabelFrame - frame_indent_size: Frame - indent_size_title: Label - (*)scale_indent_size: Scale - space_num + indent_title: Label + (*)indent_scale: Scale - space_num """ parent = self.parent self.font_name = StringVar(parent) self.font_size = StringVar(parent) self.font_bold = BooleanVar(parent) self.space_num = IntVar(parent) - self.edit_font = tkFont.Font(parent, ('courier', 10, 'normal')) - # Create widgets. + # Create widgets: # body and body section frames. frame = self.tab_pages.pages['Fonts/Tabs'].frame frame_font = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') frame_indent = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') - # frame_font + # frame_font. frame_font_name = Frame(frame_font) frame_font_param = Frame(frame_font) font_name_title = Label( frame_font_name, justify=LEFT, text='Font Face :') - self.fontlist = Listbox( - frame_font_name, height=5, takefocus=FALSE, exportselection=FALSE) + self.fontlist = Listbox(frame_font_name, height=5, + takefocus=FALSE, exportselection=FALSE) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) @@ -224,43 +227,43 @@ def create_page_font_tab(self): scroll_font.config(command=self.fontlist.yview) self.fontlist.config(yscrollcommand=scroll_font.set) font_size_title = Label(frame_font_param, text='Size :') - self.opt_menu_font_size = DynOptionMenu( - frame_font_param, self.font_size, None, command=self.set_samples) + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, + None, command=self.set_samples) self.bold_toggle = Checkbutton( frame_font_param, variable=self.font_bold, onvalue=1, offvalue=0, text='Bold', command=self.set_samples) frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) + temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( - frame_font_sample, justify=LEFT, font=self.edit_font, + frame_font_sample, justify=LEFT, font=temp_font, text='AaBbCcDdEe\nFfGgHhIiJjK\n1234567890\n#:+=(){}[]') - # frame_indent - frame_indent_size = Frame(frame_indent) - indent_size_title = Label( - frame_indent_size, justify=LEFT, + # frame_indent. + indent_title = Label( + frame_indent, justify=LEFT, text='Python Standard: 4 Spaces!') - self.scale_indent_size = Scale( - frame_indent_size, variable=self.space_num, + self.indent_scale = Scale( + frame_indent, variable=self.space_num, orient='horizontal', tickinterval=2, from_=2, to=16) - # Pack widgets. - # body + # Pack widgets: + # body. frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) - # frame_font + # frame_font. frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) font_name_title.pack(side=TOP, anchor=W) self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) scroll_font.pack(side=LEFT, fill=Y) font_size_title.pack(side=LEFT, anchor=W) - self.opt_menu_font_size.pack(side=LEFT, anchor=W) + self.sizelist.pack(side=LEFT, anchor=W) self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) self.font_sample.pack(expand=TRUE, fill=BOTH) - # frame_indent - frame_indent_size.pack(side=TOP, fill=X) - indent_size_title.pack(side=TOP, anchor=W, padx=5) - self.scale_indent_size.pack(side=TOP, padx=5, fill=X) + # frame_indent. + frame_indent.pack(side=TOP, fill=X) + indent_title.pack(side=TOP, anchor=W, padx=5) + self.indent_scale.pack(side=TOP, padx=5, fill=X) return frame @@ -1410,7 +1413,7 @@ def load_font_cfg(self): Attributes updated: fontlist: Populate with fonts from tkinter.font. font_name: Set to current font. - opt_menu_font_size: Populate valid options tuple and set + sizelist: Populate valid options tuple and set to current size. font_bold: Set to current font weight. @@ -1437,9 +1440,9 @@ def load_font_cfg(self): except ValueError: pass # Set font size dropdown. - self.opt_menu_font_size.SetMenu(('7', '8', '9', '10', '11', '12', '13', - '14', '16', '18', '20', '22', - '25', '29', '34', '40'), font_size ) + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) # Set font weight. self.font_bold.set(font_bold) # Set font sample. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 171fa3d309c..b6d5df3c5b4 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -59,25 +59,28 @@ def test_font_set(self): default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' - dialog.font_name.set('Test Font') + d = dialog + d.font_name.set('Test Font') + d.font_size.set(default_size) + d.font_bold.set(default_bold) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': default_size, 'font-bold': str(default_bold)}} self.assertEqual(mainpage, expected) changes.clear() - dialog.font_size.set(20) + d.font_size.set(20) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': '20', 'font-bold': str(default_bold)}} self.assertEqual(mainpage, expected) changes.clear() - dialog.font_bold.set(not default_bold) + d.font_bold.set(not default_bold) expected = {'EditorWindow': {'font': 'Test Font', 'font-size': '20', 'font-bold': str(not default_bold)}} self.assertEqual(mainpage, expected) - def test_set_samples_bold_toggle(self): + def test_bold_toggle_set_samples(self): # Set up. d = dialog d.font_sample, d.highlight_sample = {}, {} # Must undo this. @@ -91,7 +94,7 @@ def test_set_samples_bold_toggle(self): d.set_samples() self.assertTrue(d.font_sample == d.highlight_sample == expected1) - # Test bold_toggle. + # Test bold_toggle. If this fails, problem precedes set_samples. d.bold_toggle.invoke() self.assertFalse(d.font_bold.get()) self.assertTrue(d.font_sample == d.highlight_sample == expected0) @@ -102,9 +105,10 @@ def test_set_samples_bold_toggle(self): # Clean up. del d.font_sample, d.highlight_sample - def test_tabspace(self): - dialog.space_num.set(6) - self.assertEqual(mainpage, {'Indent': {'num-spaces': '6'}}) + def test_indent_scale(self): + dialog.indent_scale.set(26) + self.assertEqual(dialog.space_num.get(), 16) + self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) class FontSelectTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst new file mode 100644 index 00000000000..8eab703c526 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst @@ -0,0 +1,6 @@ +IDLE - Improve configdialog font page and tests. + +* Document causal pathways in docstring. * Simplify some attribute names. * +Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix +test_font_set so not order dependent. * Fix renamed test_indent_scale so it +tests the widget. From webhook-mailer at python.org Sun Jul 23 16:39:56 2017 From: webhook-mailer at python.org (Ned Deily) Date: Sun, 23 Jul 2017 20:39:56 -0000 Subject: [Python-checkins] Mac installer build now needs venv for docs build (#2828) Message-ID: https://github.com/python/cpython/commit/4c7532e96da19f2d5543bdab2b972797699c37d5 commit: 4c7532e96da19f2d5543bdab2b972797699c37d5 branch: master author: Ned Deily committer: GitHub date: 2017-07-23T16:39:54-04:00 summary: Mac installer build now needs venv for docs build (#2828) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index 7b4376f42b8..7ffa3673664 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -1089,10 +1089,10 @@ def buildPythonDocs(): docdir = os.path.join(rootDir, 'pydocs') curDir = os.getcwd() os.chdir(buildDir) - # The Doc build changed for 3.4 (technically, for 3.4.1) and for 2.7.9 runCommand('make clean') - # Assume sphinx-build is on our PATH, checked in checkEnvironment - runCommand('make html') + # Create virtual environment for docs builds with blurb and sphinx + runCommand('make venv') + runCommand('make html PYTHON=venv/bin/python') os.chdir(curDir) if not os.path.exists(docdir): os.mkdir(docdir) From webhook-mailer at python.org Sun Jul 23 17:10:43 2017 From: webhook-mailer at python.org (Ned Deily) Date: Sun, 23 Jul 2017 21:10:43 -0000 Subject: [Python-checkins] Mac installer build now needs venv for docs build (#2828) (#2830) Message-ID: https://github.com/python/cpython/commit/f76d1a0819899c4aa6fd3fa5834c7677faa01b12 commit: f76d1a0819899c4aa6fd3fa5834c7677faa01b12 branch: 3.6 author: Ned Deily committer: GitHub date: 2017-07-23T17:10:40-04:00 summary: Mac installer build now needs venv for docs build (#2828) (#2830) (cherry picked from commit 4c7532e96da19f2d5543bdab2b972797699c37d5) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index 1fff052e248..4cb7e3214cd 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -1088,10 +1088,10 @@ def buildPythonDocs(): docdir = os.path.join(rootDir, 'pydocs') curDir = os.getcwd() os.chdir(buildDir) - # The Doc build changed for 3.4 (technically, for 3.4.1) and for 2.7.9 runCommand('make clean') - # Assume sphinx-build is on our PATH, checked in checkEnvironment - runCommand('make html') + # Create virtual environment for docs builds with blurb and sphinx + runCommand('make venv') + runCommand('make html PYTHON=venv/bin/python') os.chdir(curDir) if not os.path.exists(docdir): os.mkdir(docdir) From webhook-mailer at python.org Sun Jul 23 18:09:17 2017 From: webhook-mailer at python.org (Ned Deily) Date: Sun, 23 Jul 2017 22:09:17 -0000 Subject: [Python-checkins] Add option to pass vcs info into Mac installer build (#2832) Message-ID: https://github.com/python/cpython/commit/8b99e2da1ffa8112ee0ba7600a8823da61e132bb commit: 8b99e2da1ffa8112ee0ba7600a8823da61e132bb branch: 3.5 author: Ned Deily committer: GitHub date: 2017-07-23T18:09:14-04:00 summary: Add option to pass vcs info into Mac installer build (#2832) (cherry picked from commit 4da52247d6ae53b8384f9753430e8cd2672ff97d) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index fb112741e05..d7d40110a66 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -1168,8 +1168,25 @@ def buildPython(): shellQuote(WORKDIR)[1:-1], shellQuote(WORKDIR)[1:-1])) - print("Running make") - runCommand("make") + # Look for environment value BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS + # and, if defined, append its value to the make command. This allows + # us to pass in version control tags, like GITTAG, to a build from a + # tarball rather than from a vcs checkout, thus eliminating the need + # to have a working copy of the vcs program on the build machine. + # + # A typical use might be: + # export BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS=" \ + # GITVERSION='echo 123456789a' \ + # GITTAG='echo v3.6.0' \ + # GITBRANCH='echo 3.6'" + + make_extras = os.getenv("BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS") + if make_extras: + make_cmd = "make " + make_extras + else: + make_cmd = "make" + print("Running " + make_cmd) + runCommand(make_cmd) print("Running make install") runCommand("make install DESTDIR=%s"%( From webhook-mailer at python.org Sun Jul 23 19:39:51 2017 From: webhook-mailer at python.org (Ned Deily) Date: Sun, 23 Jul 2017 23:39:51 -0000 Subject: [Python-checkins] Mac installer build now needs venv for docs build (#2828) (#2833) Message-ID: https://github.com/python/cpython/commit/fcfbeb9ed8d89a3ba96ef85b08fe5080d08d4996 commit: fcfbeb9ed8d89a3ba96ef85b08fe5080d08d4996 branch: 3.5 author: Ned Deily committer: GitHub date: 2017-07-23T19:39:49-04:00 summary: Mac installer build now needs venv for docs build (#2828) (#2833) (cherry picked from commit 4c7532e96da19f2d5543bdab2b972797699c37d5) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index d7d40110a66..c61ad9b4c5e 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -1115,10 +1115,10 @@ def buildPythonDocs(): docdir = os.path.join(rootDir, 'pydocs') curDir = os.getcwd() os.chdir(buildDir) - # The Doc build changed for 3.4 (technically, for 3.4.1) and for 2.7.9 runCommand('make clean') - # Assume sphinx-build is on our PATH, checked in checkEnvironment - runCommand('make html') + # Create virtual environment for docs builds with blurb and sphinx + runCommand('make venv') + runCommand('make html PYTHON=venv/bin/python') os.chdir(curDir) if not os.path.exists(docdir): os.mkdir(docdir) From webhook-mailer at python.org Sun Jul 23 20:39:11 2017 From: webhook-mailer at python.org (Berker Peksag) Date: Mon, 24 Jul 2017 00:39:11 -0000 Subject: [Python-checkins] bpo-30456: Clarify example for duplicates in second argument of isinstance (GH-1699) Message-ID: https://github.com/python/cpython/commit/26248ef58dcf49619930ffa2e050ffa687a88601 commit: 26248ef58dcf49619930ffa2e050ffa687a88601 branch: master author: Eli Boyarski committer: Berker Peksag date: 2017-07-24T03:39:07+03:00 summary: bpo-30456: Clarify example for duplicates in second argument of isinstance (GH-1699) files: M Doc/library/2to3.rst diff --git a/Doc/library/2to3.rst b/Doc/library/2to3.rst index 4c9a528d42e..1ab05a62ad4 100644 --- a/Doc/library/2to3.rst +++ b/Doc/library/2to3.rst @@ -288,7 +288,8 @@ and off individually. They are described here in more detail. Fixes duplicate types in the second argument of :func:`isinstance`. For example, ``isinstance(x, (int, int))`` is converted to ``isinstance(x, - (int))``. + int)`` and ``isinstance(x, (int, float, int))`` is converted to + ``isinstance(x, (int, float))``. .. 2to3fixer:: itertools_imports From webhook-mailer at python.org Mon Jul 24 00:18:29 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Mon, 24 Jul 2017 04:18:29 -0000 Subject: [Python-checkins] bpo-30993: IDLE - Improve configdialog font page and tests. (#2831) Message-ID: https://github.com/python/cpython/commit/77e97ca9ff6f3dbbf98b89b4103c46b43eef5642 commit: 77e97ca9ff6f3dbbf98b89b4103c46b43eef5642 branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-24T00:18:25-04:00 summary: bpo-30993: IDLE - Improve configdialog font page and tests. (#2831) In configdialog: Document causal pathways in create_font_tab docstring. Simplify some attribute names. Move set_samples calls to var_changed_font (idea from Cheryl Sabella). Move related functions to positions after the create widgets function. In test_configdialog: Fix test_font_set so not order dependent. Fix renamed test_indent_scale so it tests the widget. Adjust tests for movement of set_samples call. Add tests for load functions. Put all font tests in one class and tab indent tests in another. Except for two lines, these tests completely cover the related functions. files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py M Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index d51eca6f533..1832e156dc6 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -150,6 +150,7 @@ def create_action_buttons(self): buttons.pack(side=BOTTOM) return outer + def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. @@ -159,29 +160,26 @@ def create_page_font_tab(self): corresponding aspect of the font sample on this page and highlight sample on highlight page. + Load_font_cfg initializes font vars and widgets from + idleConf entries and tk. + Fontlist: mouse button 1 click or up or down key invoke - on_fontlist_select(), which sets Var font_name and calls - set_samples. + on_fontlist_select(), which sets var font_name. Sizelist: clicking the menubutton opens the dropdown menu. A - mouse button 1 click or return key invokes an internal command - which sets Var font_size and calls set_samples. + mouse button 1 click or return key sets var font_size. - Bold_toggle, clicking the box toggles font_bold and calls - set_samples. + Bold_toggle: clicking the box toggles var font_bold. - Setting any of the font vars invokes var_changed_font, which - adds all 3 font options to changes. Set_samples applies a new - font constructed from the font vars to font_sample and - highlight_sample on the hightlight page. + Changing any of the font vars invokes var_changed_font, which + adds all 3 font options to changes and calls set_samples. + Set_samples applies a new font constructed from the font vars to + font_sample and to highlight_sample on the hightlight page. Tabs: Enable users to change spaces entered for indent tabs. Changing indent_scale value with the mouse sets Var space_num, which invokes var_changed_space_num, which adds an entry to - changes. - - Load_font_cfg and load_tab_cfg initialize vars and widgets from - idleConf entries. + changes. Load_tab_cfg initializes space_num to default. Widget Structure: (*) widgets bound to self frame (of tab_pages) @@ -227,11 +225,10 @@ def create_page_font_tab(self): scroll_font.config(command=self.fontlist.yview) self.fontlist.config(yscrollcommand=scroll_font.set) font_size_title = Label(frame_font_param, text='Size :') - self.sizelist = DynOptionMenu(frame_font_param, self.font_size, - None, command=self.set_samples) + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) self.bold_toggle = Checkbutton( - frame_font_param, variable=self.font_bold, onvalue=1, - offvalue=0, text='Bold', command=self.set_samples) + frame_font_param, variable=self.font_bold, + onvalue=1, offvalue=0, text='Bold') frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( @@ -267,6 +264,96 @@ def create_page_font_tab(self): return frame + def load_font_cfg(self): + """Load current configuration settings for the font options. + + Retrieve current font with idleConf.GetFont and font families + from tk. Setup fontlist and set font_name. Setup sizelist, + which sets font_size. Set font_bold. Setting font variables + calls set_samples (thrice). + """ + configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') + font_name = configured_font[0].lower() + font_size = configured_font[1] + font_bold = configured_font[2]=='bold' + + # Set editor font selection list and font_name. + fonts = list(tkFont.families(self)) + fonts.sort() + for font in fonts: + self.fontlist.insert(END, font) + self.font_name.set(font_name) + lc_fonts = [s.lower() for s in fonts] + try: + current_font_index = lc_fonts.index(font_name) + self.fontlist.see(current_font_index) + self.fontlist.select_set(current_font_index) + self.fontlist.select_anchor(current_font_index) + self.fontlist.activate(current_font_index) + except ValueError: + pass + # Set font size dropdown. + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) + # Set font weight. + self.font_bold.set(font_bold) + + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + + def var_changed_font(self, *params): + """Store changes to font attributes. + + When one font attribute changes, save them all, as they are + not independent from each other. In particular, when we are + overriding the default font, we need to write out everything. + """ + value = self.font_name.get() + changes.add_option('main', 'EditorWindow', 'font', value) + value = self.font_size.get() + changes.add_option('main', 'EditorWindow', 'font-size', value) + value = self.font_bold.get() + changes.add_option('main', 'EditorWindow', 'font-bold', value) + self.set_samples() + + def set_samples(self, event=None): + """Update update both screen samples with the font settings. + + Called on font initialization and change events. + Accesses font_name, font_size, and font_bold Variables. + Updates font_sample and hightlight page highlight_sample. + """ + font_name = self.font_name.get() + font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL + new_font = (font_name, self.font_size.get(), font_weight) + self.font_sample['font'] = new_font + self.highlight_sample['font'] = new_font + + def load_tab_cfg(self): + """Load current configuration settings for the tab options. + + Attributes updated: + space_num: Set to value from idleConf. + """ + # Set indent sizes. + space_num = idleConf.GetOption( + 'main', 'Indent', 'num-spaces', default=4, type='int') + self.space_num.set(space_num) + + def var_changed_space_num(self, *params): + "Store change to indentation size." + value = self.space_num.get() + changes.add_option('main', 'Indent', 'num-spaces', value) + + def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -729,25 +816,6 @@ def remove_var_callbacks(self): self.startup_edit, self.autosave,): var.trace_remove('write', var.trace_info()[0][1]) - def var_changed_font(self, *params): - """Store changes to font attributes. - - When one font attribute changes, save them all, as they are - not independent from each other. In particular, when we are - overriding the default font, we need to write out everything. - """ - value = self.font_name.get() - changes.add_option('main', 'EditorWindow', 'font', value) - value = self.font_size.get() - changes.add_option('main', 'EditorWindow', 'font-size', value) - value = self.font_bold.get() - changes.add_option('main', 'EditorWindow', 'font-bold', value) - - def var_changed_space_num(self, *params): - "Store change to indentation size." - value = self.space_num.get() - changes.add_option('main', 'Indent', 'num-spaces', value) - def var_changed_color(self, *params): "Process change to color choice." self.on_new_color_set() @@ -1216,30 +1284,6 @@ def create_new_theme(self, new_theme_name): self.is_builtin_theme.set(0) self.set_theme_type() - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - self.set_samples() - - def set_samples(self, event=None): - """Update update both screen samples with the font settings. - - Called on font initialization and change events. - Accesses font_name, font_size, and font_bold Variables. - Updates font_sample and hightlight page highlight_sample. - """ - font_name = self.font_name.get() - font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL - new_font = (font_name, self.font_size.get(), font_weight) - self.font_sample['font'] = new_font - self.highlight_sample['font'] = new_font - def set_highlight_target(self): """Set fg/bg toggle and color based on highlight tag target. @@ -1404,61 +1448,6 @@ def update_user_help_changed_items(self): 'main', 'HelpFiles', str(num), ';'.join(self.user_helplist[num-1][:2])) - def load_font_cfg(self): - """Load current configuration settings for the font options. - - Retrieve current font values from idleConf.GetFont to set - as initial values for font widgets. - - Attributes updated: - fontlist: Populate with fonts from tkinter.font. - font_name: Set to current font. - sizelist: Populate valid options tuple and set - to current size. - font_bold: Set to current font weight. - - Methods: - set_samples - """ - # Set base editor font selection list. - fonts = list(tkFont.families(self)) - fonts.sort() - for font in fonts: - self.fontlist.insert(END, font) - configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') - font_name = configured_font[0].lower() - font_size = configured_font[1] - font_bold = configured_font[2]=='bold' - self.font_name.set(font_name) - lc_fonts = [s.lower() for s in fonts] - try: - current_font_index = lc_fonts.index(font_name) - self.fontlist.see(current_font_index) - self.fontlist.select_set(current_font_index) - self.fontlist.select_anchor(current_font_index) - self.fontlist.activate(current_font_index) - except ValueError: - pass - # Set font size dropdown. - self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', - '16', '18', '20', '22', '25', '29', '34', '40'), - font_size) - # Set font weight. - self.font_bold.set(font_bold) - # Set font sample. - self.set_samples() - - def load_tab_cfg(self): - """Load current configuration settings for the tab options. - - Attributes updated: - space_num: Set to value from idleConf. - """ - # Set indent sizes. - space_num = idleConf.GetOption( - 'main', 'Indent', 'num-spaces', default=4, type='int') - self.space_num.set(space_num) - def load_theme_cfg(self): """Load current configuration settings for the theme options. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index b6d5df3c5b4..54b2d78d667 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -45,82 +45,15 @@ def tearDownModule(): del root -class FontTabTest(unittest.TestCase): - "Test that font widget enable users to make font changes." - - - def setUp(self): - changes.clear() - - def test_font_set(self): - # Test that setting a font Variable results in 3 provisional - # change entries. Use values sure to not be defaults. - # Other font tests verify that user actions set Variables. - default_font = idleConf.GetFont(root, 'main', 'EditorWindow') - default_size = str(default_font[1]) - default_bold = default_font[2] == 'bold' - d = dialog - d.font_name.set('Test Font') - d.font_size.set(default_size) - d.font_bold.set(default_bold) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': default_size, - 'font-bold': str(default_bold)}} - self.assertEqual(mainpage, expected) - changes.clear() - d.font_size.set(20) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': '20', - 'font-bold': str(default_bold)}} - self.assertEqual(mainpage, expected) - changes.clear() - d.font_bold.set(not default_bold) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': '20', - 'font-bold': str(not default_bold)}} - self.assertEqual(mainpage, expected) - - def test_bold_toggle_set_samples(self): - # Set up. - d = dialog - d.font_sample, d.highlight_sample = {}, {} # Must undo this. - d.font_name.set('test') - d.font_size.set('5') - d.font_bold.set(1) - expected0 = {'font': ('test', '5', 'normal')} - expected1 = {'font': ('test', '5', 'bold')} - - # Test set_samples. - d.set_samples() - self.assertTrue(d.font_sample == d.highlight_sample == expected1) - - # Test bold_toggle. If this fails, problem precedes set_samples. - d.bold_toggle.invoke() - self.assertFalse(d.font_bold.get()) - self.assertTrue(d.font_sample == d.highlight_sample == expected0) - d.bold_toggle.invoke() - self.assertTrue(d.font_bold.get()) - self.assertTrue(d.font_sample == d.highlight_sample == expected1) - - # Clean up. - del d.font_sample, d.highlight_sample - - def test_indent_scale(self): - dialog.indent_scale.set(26) - self.assertEqual(dialog.space_num.get(), 16) - self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) - - -class FontSelectTest(unittest.TestCase): - # These two functions test that selecting a new font in the - # list of fonts changes font_name and calls set_samples. - # The fontlist widget and on_fontlist_select event handler - # are tested here together. +class FontTest(unittest.TestCase): + """Test that font widgets enable users to make font changes. + Test that widget actions set vars, that var changes add three + options to changes and call set_samples, and that set_samples + changes the font of both sample boxes. + """ @classmethod def setUpClass(cls): - if dialog.fontlist.size() < 2: - cls.skipTest('need at least 2 fonts') dialog.set_samples = Func() # Mask instance method. @classmethod @@ -128,12 +61,27 @@ def tearDownClass(cls): del dialog.set_samples # Unmask instance method. def setUp(self): - dialog.set_samples.called = 0 changes.clear() - def test_select_font_key(self): + def test_load_font_cfg(self): + # Leave widget load test to human visual check. + # TODO Improve checks when add IdleConf.get_font_values. + d = dialog + d.font_name.set('Fake') + d.font_size.set('1') + d.font_bold.set(True) + d.set_samples.called = 0 + d.load_font_cfg() + self.assertNotEqual(d.font_name.get(), 'Fake') + self.assertNotEqual(d.font_size.get(), '1') + self.assertFalse(d.font_bold.get()) + self.assertEqual(d.set_samples.called, 3) + + def test_fontlist_key(self): # Up and Down keys should select a new font. + if dialog.fontlist.size() < 2: + cls.skipTest('need at least 2 fonts') fontlist = dialog.fontlist fontlist.activate(0) font = dialog.fontlist.get('active') @@ -147,7 +95,6 @@ def test_select_font_key(self): down_font = fontlist.get('active') self.assertNotEqual(down_font, font) self.assertIn(dialog.font_name.get(), down_font.lower()) - self.assertEqual(dialog.set_samples.called, 1) # Test Up key. fontlist.focus_force() @@ -158,11 +105,12 @@ def test_select_font_key(self): up_font = fontlist.get('active') self.assertEqual(up_font, font) self.assertIn(dialog.font_name.get(), up_font.lower()) - self.assertEqual(dialog.set_samples.called, 2) - def test_select_font_mouse(self): + def test_fontlist_mouse(self): # Click on item should select that item. + if dialog.fontlist.size() < 2: + cls.skipTest('need at least 2 fonts') fontlist = dialog.fontlist fontlist.activate(0) @@ -180,7 +128,88 @@ def test_select_font_mouse(self): select_font = fontlist.get('anchor') self.assertEqual(select_font, font1) self.assertIn(dialog.font_name.get(), font1.lower()) - self.assertEqual(dialog.set_samples.called, 1) + + def test_sizelist(self): + # Click on number shouod select that number + d = dialog + d.sizelist.variable.set(40) + self.assertEqual(d.font_size.get(), '40') + + def test_bold_toggle(self): + # Click on checkbutton should invert it. + d = dialog + d.font_bold.set(False) + d.bold_toggle.invoke() + self.assertTrue(d.font_bold.get()) + d.bold_toggle.invoke() + self.assertFalse(d.font_bold.get()) + + def test_font_set(self): + # Test that setting a font Variable results in 3 provisional + # change entries and a call to set_samples. Use values sure to + # not be defaults. + + default_font = idleConf.GetFont(root, 'main', 'EditorWindow') + default_size = str(default_font[1]) + default_bold = default_font[2] == 'bold' + d = dialog + d.font_size.set(default_size) + d.font_bold.set(default_bold) + d.set_samples.called = 0 + + d.font_name.set('Test Font') + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': default_size, + 'font-bold': str(default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 1) + changes.clear() + + d.font_size.set('20') + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': '20', + 'font-bold': str(default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 2) + changes.clear() + + d.font_bold.set(not default_bold) + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': '20', + 'font-bold': str(not default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 3) + + def test_set_samples(self): + d = dialog + del d.set_samples # Unmask method for test + d.font_sample, d.highlight_sample = {}, {} + d.font_name.set('test') + d.font_size.set('5') + d.font_bold.set(1) + expected = {'font': ('test', '5', 'bold')} + + # Test set_samples. + d.set_samples() + self.assertTrue(d.font_sample == d.highlight_sample == expected) + + del d.font_sample, d.highlight_sample + d.set_samples = Func() # Re-mask for other tests. + + +class IndentTest(unittest.TestCase): + + def test_load_tab_cfg(self): + d = dialog + d.space_num.set(16) + d.load_tab_cfg() + self.assertEqual(d.space_num.get(), 4) + + def test_indent_scale(self): + changes.clear() + dialog.indent_scale.set(26) + self.assertEqual(dialog.space_num.get(), 16) + self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) class HighlightTest(unittest.TestCase): @@ -188,8 +217,6 @@ class HighlightTest(unittest.TestCase): def setUp(self): changes.clear() - #def test_colorchoose(self): pass # TODO - class KeysTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst index 8eab703c526..04c94349165 100644 --- a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst +++ b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst @@ -1,6 +1,5 @@ IDLE - Improve configdialog font page and tests. -* Document causal pathways in docstring. * Simplify some attribute names. * -Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix -test_font_set so not order dependent. * Fix renamed test_indent_scale so it -tests the widget. +In configdialog: Document causal pathways in create_font_tab docstring. Simplify some attribute names. Move set_samples calls to var_changed_font (idea from Cheryl Sabella). Move related functions to positions after the create widgets function. + +In test_configdialog: Fix test_font_set so not order dependent. Fix renamed test_indent_scale so it tests the widget. Adjust tests for movement of set_samples call. Add tests for load functions. Put all font tests in one class and tab indent tests in another. Except for two lines, these tests completely cover the related functions. From webhook-mailer at python.org Mon Jul 24 02:50:31 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Mon, 24 Jul 2017 06:50:31 -0000 Subject: [Python-checkins] [3.6] bpo-30993: IDLE - Improve configdialog font page and tests. (GH-2831) (#2834) Message-ID: https://github.com/python/cpython/commit/1daeb259799d0664c9453a3bd8e80411e65b52c9 commit: 1daeb259799d0664c9453a3bd8e80411e65b52c9 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-24T02:50:28-04:00 summary: [3.6] bpo-30993: IDLE - Improve configdialog font page and tests. (GH-2831) (#2834) In configdialog: Document causal pathways in create_font_tab docstring. Simplify some attribute names. Move set_samples calls to var_changed_font (idea from Cheryl Sabella). Move related functions to positions after the create widgets function. In test_configdialog: Fix test_font_set so not order dependent. Fix renamed test_indent_scale so it tests the widget. Adjust tests for movement of set_samples call. Add tests for load functions. Put all font tests in one class and tab indent tests in another. Except for two lines, these tests completely cover the related functions. (cherry picked from commit 77e97ca) files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py M Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index d51eca6f533..1832e156dc6 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -150,6 +150,7 @@ def create_action_buttons(self): buttons.pack(side=BOTTOM) return outer + def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. @@ -159,29 +160,26 @@ def create_page_font_tab(self): corresponding aspect of the font sample on this page and highlight sample on highlight page. + Load_font_cfg initializes font vars and widgets from + idleConf entries and tk. + Fontlist: mouse button 1 click or up or down key invoke - on_fontlist_select(), which sets Var font_name and calls - set_samples. + on_fontlist_select(), which sets var font_name. Sizelist: clicking the menubutton opens the dropdown menu. A - mouse button 1 click or return key invokes an internal command - which sets Var font_size and calls set_samples. + mouse button 1 click or return key sets var font_size. - Bold_toggle, clicking the box toggles font_bold and calls - set_samples. + Bold_toggle: clicking the box toggles var font_bold. - Setting any of the font vars invokes var_changed_font, which - adds all 3 font options to changes. Set_samples applies a new - font constructed from the font vars to font_sample and - highlight_sample on the hightlight page. + Changing any of the font vars invokes var_changed_font, which + adds all 3 font options to changes and calls set_samples. + Set_samples applies a new font constructed from the font vars to + font_sample and to highlight_sample on the hightlight page. Tabs: Enable users to change spaces entered for indent tabs. Changing indent_scale value with the mouse sets Var space_num, which invokes var_changed_space_num, which adds an entry to - changes. - - Load_font_cfg and load_tab_cfg initialize vars and widgets from - idleConf entries. + changes. Load_tab_cfg initializes space_num to default. Widget Structure: (*) widgets bound to self frame (of tab_pages) @@ -227,11 +225,10 @@ def create_page_font_tab(self): scroll_font.config(command=self.fontlist.yview) self.fontlist.config(yscrollcommand=scroll_font.set) font_size_title = Label(frame_font_param, text='Size :') - self.sizelist = DynOptionMenu(frame_font_param, self.font_size, - None, command=self.set_samples) + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) self.bold_toggle = Checkbutton( - frame_font_param, variable=self.font_bold, onvalue=1, - offvalue=0, text='Bold', command=self.set_samples) + frame_font_param, variable=self.font_bold, + onvalue=1, offvalue=0, text='Bold') frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( @@ -267,6 +264,96 @@ def create_page_font_tab(self): return frame + def load_font_cfg(self): + """Load current configuration settings for the font options. + + Retrieve current font with idleConf.GetFont and font families + from tk. Setup fontlist and set font_name. Setup sizelist, + which sets font_size. Set font_bold. Setting font variables + calls set_samples (thrice). + """ + configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') + font_name = configured_font[0].lower() + font_size = configured_font[1] + font_bold = configured_font[2]=='bold' + + # Set editor font selection list and font_name. + fonts = list(tkFont.families(self)) + fonts.sort() + for font in fonts: + self.fontlist.insert(END, font) + self.font_name.set(font_name) + lc_fonts = [s.lower() for s in fonts] + try: + current_font_index = lc_fonts.index(font_name) + self.fontlist.see(current_font_index) + self.fontlist.select_set(current_font_index) + self.fontlist.select_anchor(current_font_index) + self.fontlist.activate(current_font_index) + except ValueError: + pass + # Set font size dropdown. + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) + # Set font weight. + self.font_bold.set(font_bold) + + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + + def var_changed_font(self, *params): + """Store changes to font attributes. + + When one font attribute changes, save them all, as they are + not independent from each other. In particular, when we are + overriding the default font, we need to write out everything. + """ + value = self.font_name.get() + changes.add_option('main', 'EditorWindow', 'font', value) + value = self.font_size.get() + changes.add_option('main', 'EditorWindow', 'font-size', value) + value = self.font_bold.get() + changes.add_option('main', 'EditorWindow', 'font-bold', value) + self.set_samples() + + def set_samples(self, event=None): + """Update update both screen samples with the font settings. + + Called on font initialization and change events. + Accesses font_name, font_size, and font_bold Variables. + Updates font_sample and hightlight page highlight_sample. + """ + font_name = self.font_name.get() + font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL + new_font = (font_name, self.font_size.get(), font_weight) + self.font_sample['font'] = new_font + self.highlight_sample['font'] = new_font + + def load_tab_cfg(self): + """Load current configuration settings for the tab options. + + Attributes updated: + space_num: Set to value from idleConf. + """ + # Set indent sizes. + space_num = idleConf.GetOption( + 'main', 'Indent', 'num-spaces', default=4, type='int') + self.space_num.set(space_num) + + def var_changed_space_num(self, *params): + "Store change to indentation size." + value = self.space_num.get() + changes.add_option('main', 'Indent', 'num-spaces', value) + + def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -729,25 +816,6 @@ def remove_var_callbacks(self): self.startup_edit, self.autosave,): var.trace_remove('write', var.trace_info()[0][1]) - def var_changed_font(self, *params): - """Store changes to font attributes. - - When one font attribute changes, save them all, as they are - not independent from each other. In particular, when we are - overriding the default font, we need to write out everything. - """ - value = self.font_name.get() - changes.add_option('main', 'EditorWindow', 'font', value) - value = self.font_size.get() - changes.add_option('main', 'EditorWindow', 'font-size', value) - value = self.font_bold.get() - changes.add_option('main', 'EditorWindow', 'font-bold', value) - - def var_changed_space_num(self, *params): - "Store change to indentation size." - value = self.space_num.get() - changes.add_option('main', 'Indent', 'num-spaces', value) - def var_changed_color(self, *params): "Process change to color choice." self.on_new_color_set() @@ -1216,30 +1284,6 @@ def create_new_theme(self, new_theme_name): self.is_builtin_theme.set(0) self.set_theme_type() - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - self.set_samples() - - def set_samples(self, event=None): - """Update update both screen samples with the font settings. - - Called on font initialization and change events. - Accesses font_name, font_size, and font_bold Variables. - Updates font_sample and hightlight page highlight_sample. - """ - font_name = self.font_name.get() - font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL - new_font = (font_name, self.font_size.get(), font_weight) - self.font_sample['font'] = new_font - self.highlight_sample['font'] = new_font - def set_highlight_target(self): """Set fg/bg toggle and color based on highlight tag target. @@ -1404,61 +1448,6 @@ def update_user_help_changed_items(self): 'main', 'HelpFiles', str(num), ';'.join(self.user_helplist[num-1][:2])) - def load_font_cfg(self): - """Load current configuration settings for the font options. - - Retrieve current font values from idleConf.GetFont to set - as initial values for font widgets. - - Attributes updated: - fontlist: Populate with fonts from tkinter.font. - font_name: Set to current font. - sizelist: Populate valid options tuple and set - to current size. - font_bold: Set to current font weight. - - Methods: - set_samples - """ - # Set base editor font selection list. - fonts = list(tkFont.families(self)) - fonts.sort() - for font in fonts: - self.fontlist.insert(END, font) - configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') - font_name = configured_font[0].lower() - font_size = configured_font[1] - font_bold = configured_font[2]=='bold' - self.font_name.set(font_name) - lc_fonts = [s.lower() for s in fonts] - try: - current_font_index = lc_fonts.index(font_name) - self.fontlist.see(current_font_index) - self.fontlist.select_set(current_font_index) - self.fontlist.select_anchor(current_font_index) - self.fontlist.activate(current_font_index) - except ValueError: - pass - # Set font size dropdown. - self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', - '16', '18', '20', '22', '25', '29', '34', '40'), - font_size) - # Set font weight. - self.font_bold.set(font_bold) - # Set font sample. - self.set_samples() - - def load_tab_cfg(self): - """Load current configuration settings for the tab options. - - Attributes updated: - space_num: Set to value from idleConf. - """ - # Set indent sizes. - space_num = idleConf.GetOption( - 'main', 'Indent', 'num-spaces', default=4, type='int') - self.space_num.set(space_num) - def load_theme_cfg(self): """Load current configuration settings for the theme options. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index b6d5df3c5b4..54b2d78d667 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -45,82 +45,15 @@ def tearDownModule(): del root -class FontTabTest(unittest.TestCase): - "Test that font widget enable users to make font changes." - - - def setUp(self): - changes.clear() - - def test_font_set(self): - # Test that setting a font Variable results in 3 provisional - # change entries. Use values sure to not be defaults. - # Other font tests verify that user actions set Variables. - default_font = idleConf.GetFont(root, 'main', 'EditorWindow') - default_size = str(default_font[1]) - default_bold = default_font[2] == 'bold' - d = dialog - d.font_name.set('Test Font') - d.font_size.set(default_size) - d.font_bold.set(default_bold) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': default_size, - 'font-bold': str(default_bold)}} - self.assertEqual(mainpage, expected) - changes.clear() - d.font_size.set(20) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': '20', - 'font-bold': str(default_bold)}} - self.assertEqual(mainpage, expected) - changes.clear() - d.font_bold.set(not default_bold) - expected = {'EditorWindow': {'font': 'Test Font', - 'font-size': '20', - 'font-bold': str(not default_bold)}} - self.assertEqual(mainpage, expected) - - def test_bold_toggle_set_samples(self): - # Set up. - d = dialog - d.font_sample, d.highlight_sample = {}, {} # Must undo this. - d.font_name.set('test') - d.font_size.set('5') - d.font_bold.set(1) - expected0 = {'font': ('test', '5', 'normal')} - expected1 = {'font': ('test', '5', 'bold')} - - # Test set_samples. - d.set_samples() - self.assertTrue(d.font_sample == d.highlight_sample == expected1) - - # Test bold_toggle. If this fails, problem precedes set_samples. - d.bold_toggle.invoke() - self.assertFalse(d.font_bold.get()) - self.assertTrue(d.font_sample == d.highlight_sample == expected0) - d.bold_toggle.invoke() - self.assertTrue(d.font_bold.get()) - self.assertTrue(d.font_sample == d.highlight_sample == expected1) - - # Clean up. - del d.font_sample, d.highlight_sample - - def test_indent_scale(self): - dialog.indent_scale.set(26) - self.assertEqual(dialog.space_num.get(), 16) - self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) - - -class FontSelectTest(unittest.TestCase): - # These two functions test that selecting a new font in the - # list of fonts changes font_name and calls set_samples. - # The fontlist widget and on_fontlist_select event handler - # are tested here together. +class FontTest(unittest.TestCase): + """Test that font widgets enable users to make font changes. + Test that widget actions set vars, that var changes add three + options to changes and call set_samples, and that set_samples + changes the font of both sample boxes. + """ @classmethod def setUpClass(cls): - if dialog.fontlist.size() < 2: - cls.skipTest('need at least 2 fonts') dialog.set_samples = Func() # Mask instance method. @classmethod @@ -128,12 +61,27 @@ def tearDownClass(cls): del dialog.set_samples # Unmask instance method. def setUp(self): - dialog.set_samples.called = 0 changes.clear() - def test_select_font_key(self): + def test_load_font_cfg(self): + # Leave widget load test to human visual check. + # TODO Improve checks when add IdleConf.get_font_values. + d = dialog + d.font_name.set('Fake') + d.font_size.set('1') + d.font_bold.set(True) + d.set_samples.called = 0 + d.load_font_cfg() + self.assertNotEqual(d.font_name.get(), 'Fake') + self.assertNotEqual(d.font_size.get(), '1') + self.assertFalse(d.font_bold.get()) + self.assertEqual(d.set_samples.called, 3) + + def test_fontlist_key(self): # Up and Down keys should select a new font. + if dialog.fontlist.size() < 2: + cls.skipTest('need at least 2 fonts') fontlist = dialog.fontlist fontlist.activate(0) font = dialog.fontlist.get('active') @@ -147,7 +95,6 @@ def test_select_font_key(self): down_font = fontlist.get('active') self.assertNotEqual(down_font, font) self.assertIn(dialog.font_name.get(), down_font.lower()) - self.assertEqual(dialog.set_samples.called, 1) # Test Up key. fontlist.focus_force() @@ -158,11 +105,12 @@ def test_select_font_key(self): up_font = fontlist.get('active') self.assertEqual(up_font, font) self.assertIn(dialog.font_name.get(), up_font.lower()) - self.assertEqual(dialog.set_samples.called, 2) - def test_select_font_mouse(self): + def test_fontlist_mouse(self): # Click on item should select that item. + if dialog.fontlist.size() < 2: + cls.skipTest('need at least 2 fonts') fontlist = dialog.fontlist fontlist.activate(0) @@ -180,7 +128,88 @@ def test_select_font_mouse(self): select_font = fontlist.get('anchor') self.assertEqual(select_font, font1) self.assertIn(dialog.font_name.get(), font1.lower()) - self.assertEqual(dialog.set_samples.called, 1) + + def test_sizelist(self): + # Click on number shouod select that number + d = dialog + d.sizelist.variable.set(40) + self.assertEqual(d.font_size.get(), '40') + + def test_bold_toggle(self): + # Click on checkbutton should invert it. + d = dialog + d.font_bold.set(False) + d.bold_toggle.invoke() + self.assertTrue(d.font_bold.get()) + d.bold_toggle.invoke() + self.assertFalse(d.font_bold.get()) + + def test_font_set(self): + # Test that setting a font Variable results in 3 provisional + # change entries and a call to set_samples. Use values sure to + # not be defaults. + + default_font = idleConf.GetFont(root, 'main', 'EditorWindow') + default_size = str(default_font[1]) + default_bold = default_font[2] == 'bold' + d = dialog + d.font_size.set(default_size) + d.font_bold.set(default_bold) + d.set_samples.called = 0 + + d.font_name.set('Test Font') + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': default_size, + 'font-bold': str(default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 1) + changes.clear() + + d.font_size.set('20') + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': '20', + 'font-bold': str(default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 2) + changes.clear() + + d.font_bold.set(not default_bold) + expected = {'EditorWindow': {'font': 'Test Font', + 'font-size': '20', + 'font-bold': str(not default_bold)}} + self.assertEqual(mainpage, expected) + self.assertEqual(d.set_samples.called, 3) + + def test_set_samples(self): + d = dialog + del d.set_samples # Unmask method for test + d.font_sample, d.highlight_sample = {}, {} + d.font_name.set('test') + d.font_size.set('5') + d.font_bold.set(1) + expected = {'font': ('test', '5', 'bold')} + + # Test set_samples. + d.set_samples() + self.assertTrue(d.font_sample == d.highlight_sample == expected) + + del d.font_sample, d.highlight_sample + d.set_samples = Func() # Re-mask for other tests. + + +class IndentTest(unittest.TestCase): + + def test_load_tab_cfg(self): + d = dialog + d.space_num.set(16) + d.load_tab_cfg() + self.assertEqual(d.space_num.get(), 4) + + def test_indent_scale(self): + changes.clear() + dialog.indent_scale.set(26) + self.assertEqual(dialog.space_num.get(), 16) + self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) class HighlightTest(unittest.TestCase): @@ -188,8 +217,6 @@ class HighlightTest(unittest.TestCase): def setUp(self): changes.clear() - #def test_colorchoose(self): pass # TODO - class KeysTest(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst index 8eab703c526..04c94349165 100644 --- a/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst +++ b/Misc/NEWS.d/next/IDLE/2017-07-22-18-08-41.bpo-30993.34vJkB.rst @@ -1,6 +1,5 @@ IDLE - Improve configdialog font page and tests. -* Document causal pathways in docstring. * Simplify some attribute names. * -Rename test_bold_toggle_set_samples to make test_font_set fail. * Fix -test_font_set so not order dependent. * Fix renamed test_indent_scale so it -tests the widget. +In configdialog: Document causal pathways in create_font_tab docstring. Simplify some attribute names. Move set_samples calls to var_changed_font (idea from Cheryl Sabella). Move related functions to positions after the create widgets function. + +In test_configdialog: Fix test_font_set so not order dependent. Fix renamed test_indent_scale so it tests the widget. Adjust tests for movement of set_samples call. Add tests for load functions. Put all font tests in one class and tab indent tests in another. Except for two lines, these tests completely cover the related functions. From webhook-mailer at python.org Mon Jul 24 03:47:35 2017 From: webhook-mailer at python.org (Ned Deily) Date: Mon, 24 Jul 2017 07:47:35 -0000 Subject: [Python-checkins] bpo-29572: Update macOS installer build to OpenSSL 1.0.2k (#457) (#2835) Message-ID: https://github.com/python/cpython/commit/002f778ecab98f4725a08f35d68f78559a13e47a commit: 002f778ecab98f4725a08f35d68f78559a13e47a branch: 3.5 author: Ned Deily committer: GitHub date: 2017-07-24T03:47:31-04:00 summary: bpo-29572: Update macOS installer build to OpenSSL 1.0.2k (#457) (#2835) (cherry picked from commit cfcd76777e35c83d548d8736f5d7dc92fe56d806) files: M Mac/BuildScript/build-installer.py M Mac/BuildScript/openssl_sdk_makedepend.patch diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index c61ad9b4c5e..09bd20eeadd 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -242,9 +242,9 @@ def library_recipes(): result.extend([ dict( - name="OpenSSL 1.0.2j", - url="https://www.openssl.org/source/openssl-1.0.2j.tar.gz", - checksum='96322138f0b69e61b7212bc53d5e912b', + name="OpenSSL 1.0.2k", + url="https://www.openssl.org/source/openssl-1.0.2k.tar.gz", + checksum='f965fc0bf01bf882b31314b61391ae65', patches=[ "openssl_sdk_makedepend.patch", ], diff --git a/Mac/BuildScript/openssl_sdk_makedepend.patch b/Mac/BuildScript/openssl_sdk_makedepend.patch index e22d67e4e45..0caac0a64c1 100644 --- a/Mac/BuildScript/openssl_sdk_makedepend.patch +++ b/Mac/BuildScript/openssl_sdk_makedepend.patch @@ -1,6 +1,6 @@ # HG changeset patch # -# using openssl 1.0.2j +# using openssl 1.0.2k # # - support building with an OS X SDK From webhook-mailer at python.org Mon Jul 24 04:02:33 2017 From: webhook-mailer at python.org (Ned Deily) Date: Mon, 24 Jul 2017 08:02:33 -0000 Subject: [Python-checkins] bpo-29572: Update macOS installer build to OpenSSL 1.0.2k (#457) (#2836) Message-ID: https://github.com/python/cpython/commit/8d41de62b9e21090c3a1ccb951ba7034a2b74180 commit: 8d41de62b9e21090c3a1ccb951ba7034a2b74180 branch: 2.7 author: Ned Deily committer: GitHub date: 2017-07-24T04:02:29-04:00 summary: bpo-29572: Update macOS installer build to OpenSSL 1.0.2k (#457) (#2836) (cherry picked from commit cfcd76777e35c83d548d8736f5d7dc92fe56d806) files: M Mac/BuildScript/build-installer.py M Mac/BuildScript/openssl_sdk_makedepend.patch diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index e8272e7e439..c7b2e8c590b 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -242,9 +242,9 @@ def library_recipes(): result.extend([ dict( - name="OpenSSL 1.0.2j", - url="https://www.openssl.org/source/openssl-1.0.2j.tar.gz", - checksum='96322138f0b69e61b7212bc53d5e912b', + name="OpenSSL 1.0.2k", + url="https://www.openssl.org/source/openssl-1.0.2k.tar.gz", + checksum='f965fc0bf01bf882b31314b61391ae65', patches=[ "openssl_sdk_makedepend.patch", ], diff --git a/Mac/BuildScript/openssl_sdk_makedepend.patch b/Mac/BuildScript/openssl_sdk_makedepend.patch index e22d67e4e45..0caac0a64c1 100644 --- a/Mac/BuildScript/openssl_sdk_makedepend.patch +++ b/Mac/BuildScript/openssl_sdk_makedepend.patch @@ -1,6 +1,6 @@ # HG changeset patch # -# using openssl 1.0.2j +# using openssl 1.0.2k # # - support building with an OS X SDK From webhook-mailer at python.org Mon Jul 24 04:29:36 2017 From: webhook-mailer at python.org (Ned Deily) Date: Mon, 24 Jul 2017 08:29:36 -0000 Subject: [Python-checkins] Backport Mac installer fixes for git-based workflow (#2837) Message-ID: https://github.com/python/cpython/commit/123a58bfc893ee30498b0d208dc1bbef34324772 commit: 123a58bfc893ee30498b0d208dc1bbef34324772 branch: 2.7 author: Ned Deily committer: GitHub date: 2017-07-24T04:29:32-04:00 summary: Backport Mac installer fixes for git-based workflow (#2837) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index c7b2e8c590b..cf395fb38f6 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -13,7 +13,7 @@ Python 2.6. In addition to what is supplied with OS X 10.5+ and Xcode 3+, the script -requires an installed version of hg and a third-party version of +requires an installed third-party version of Tcl/Tk 8.4 (for OS X 10.4 and 10.5 deployment targets) or Tcl/TK 8.5 (for 10.6 or later) installed in /Library/Frameworks. When installed, the Python built by this script will attempt to dynamically link first to @@ -23,7 +23,7 @@ 32-bit-only installer builds are still possible on OS X 10.4 with Xcode 2.5 and the installation of additional components, such as a newer Python -(2.5 is needed for Python parser updates), hg, and for the documentation +(2.5 is needed for Python parser updates) and for the documentation build either svn (pre-3.4.1) or sphinx-build (3.4.1 and later). Usage: see USAGE variable in the script. @@ -577,7 +577,7 @@ def getTclTkVersion(configfile, versionline): """ try: f = open(configfile, "r") - except: + except OSError: fatal("Framework configuration file not found: %s" % configfile) for l in f: @@ -663,9 +663,8 @@ def checkEnvironment(): base_path = base_path + ':' + OLD_DEVELOPER_TOOLS os.environ['PATH'] = base_path print("Setting default PATH: %s"%(os.environ['PATH'])) - # Ensure ws have access to hg and to sphinx-build. - # You may have to create links in /usr/bin for them. - runCommand('hg --version') + # Ensure we have access to sphinx-build. + # You may have to create a link in /usr/bin for it. runCommand('sphinx-build --version') def parseOptions(args=None): @@ -819,7 +818,7 @@ def downloadURL(url, fname): except: try: os.unlink(fname) - except: + except OSError: pass def verifyThirdPartyFile(url, checksum, fname): @@ -1115,7 +1114,6 @@ def buildPythonDocs(): docdir = os.path.join(rootDir, 'pydocs') curDir = os.getcwd() os.chdir(buildDir) - # The Doc build changed for 3.4 (technically, for 3.4.1) and for 2.7.9 runCommand('make clean') # Assume sphinx-build is on our PATH, checked in checkEnvironment runCommand('make html') @@ -1168,8 +1166,25 @@ def buildPython(): shellQuote(WORKDIR)[1:-1], shellQuote(WORKDIR)[1:-1])) - print("Running make") - runCommand("make") + # Look for environment value BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS + # and, if defined, append its value to the make command. This allows + # us to pass in version control tags, like GITTAG, to a build from a + # tarball rather than from a vcs checkout, thus eliminating the need + # to have a working copy of the vcs program on the build machine. + # + # A typical use might be: + # export BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS=" \ + # GITVERSION='echo 123456789a' \ + # GITTAG='echo v3.6.0' \ + # GITBRANCH='echo 3.6'" + + make_extras = os.getenv("BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS") + if make_extras: + make_cmd = "make " + make_extras + else: + make_cmd = "make" + print("Running " + make_cmd) + runCommand(make_cmd) print("Running make install") runCommand("make install DESTDIR=%s"%( From webhook-mailer at python.org Mon Jul 24 04:58:04 2017 From: webhook-mailer at python.org (Ned Deily) Date: Mon, 24 Jul 2017 08:58:04 -0000 Subject: [Python-checkins] Backport Mac installer fixes for git-based workflow (#2838) Message-ID: https://github.com/python/cpython/commit/dbe6aba47b8b1f91de9b1ce087d3eb322ba1297c commit: dbe6aba47b8b1f91de9b1ce087d3eb322ba1297c branch: 3.5 author: Ned Deily committer: GitHub date: 2017-07-24T04:58:00-04:00 summary: Backport Mac installer fixes for git-based workflow (#2838) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index 09bd20eeadd..518eeb97691 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -13,7 +13,7 @@ Python 2.6. In addition to what is supplied with OS X 10.5+ and Xcode 3+, the script -requires an installed version of hg and a third-party version of +requires an installed third-party version of Tcl/Tk 8.4 (for OS X 10.4 and 10.5 deployment targets) or Tcl/TK 8.5 (for 10.6 or later) installed in /Library/Frameworks. When installed, the Python built by this script will attempt to dynamically link first to @@ -23,7 +23,7 @@ 32-bit-only installer builds are still possible on OS X 10.4 with Xcode 2.5 and the installation of additional components, such as a newer Python -(2.5 is needed for Python parser updates), hg, and for the documentation +(2.5 is needed for Python parser updates) and for the documentation build either svn (pre-3.4.1) or sphinx-build (3.4.1 and later). Usage: see USAGE variable in the script. @@ -663,9 +663,8 @@ def checkEnvironment(): base_path = base_path + ':' + OLD_DEVELOPER_TOOLS os.environ['PATH'] = base_path print("Setting default PATH: %s"%(os.environ['PATH'])) - # Ensure ws have access to hg and to sphinx-build. - # You may have to create links in /usr/bin for them. - runCommand('hg --version') + # Ensure we have access to sphinx-build. + # You may have to create a link in /usr/bin for it. runCommand('sphinx-build --version') def parseOptions(args=None): From webhook-mailer at python.org Mon Jul 24 04:58:46 2017 From: webhook-mailer at python.org (Ned Deily) Date: Mon, 24 Jul 2017 08:58:46 -0000 Subject: [Python-checkins] More Mac installer fixes for git-based workflow (#2839) Message-ID: https://github.com/python/cpython/commit/b364d9f9c693742f0ddcd9e64a9bbf9339b686d9 commit: b364d9f9c693742f0ddcd9e64a9bbf9339b686d9 branch: master author: Ned Deily committer: GitHub date: 2017-07-24T04:58:43-04:00 summary: More Mac installer fixes for git-based workflow (#2839) files: M Mac/BuildScript/build-installer.py diff --git a/Mac/BuildScript/build-installer.py b/Mac/BuildScript/build-installer.py index 7ffa3673664..4cb7e3214cd 100755 --- a/Mac/BuildScript/build-installer.py +++ b/Mac/BuildScript/build-installer.py @@ -13,7 +13,7 @@ Python 2.6. In addition to what is supplied with OS X 10.5+ and Xcode 3+, the script -requires an installed version of git and a third-party version of +requires an installed third-party version of Tcl/Tk 8.4 (for OS X 10.4 and 10.5 deployment targets) or Tcl/TK 8.5 (for 10.6 or later) installed in /Library/Frameworks. When installed, the Python built by this script will attempt to dynamically link first to @@ -23,7 +23,7 @@ 32-bit-only installer builds are still possible on OS X 10.4 with Xcode 2.5 and the installation of additional components, such as a newer Python -(2.5 is needed for Python parser updates), git, and for the documentation +(2.5 is needed for Python parser updates) and for the documentation build either svn (pre-3.4.1) or sphinx-build (3.4.1 and later). Usage: see USAGE variable in the script. @@ -635,9 +635,8 @@ def checkEnvironment(): base_path = base_path + ':' + OLD_DEVELOPER_TOOLS os.environ['PATH'] = base_path print("Setting default PATH: %s"%(os.environ['PATH'])) - # Ensure ws have access to git and to sphinx-build. - # You may have to create links in /usr/bin for them. - runCommand('git --version') + # Ensure we have access to sphinx-build. + # You may have to create a link in /usr/bin for it. runCommand('sphinx-build --version') def parseOptions(args=None): @@ -1142,8 +1141,25 @@ def buildPython(): shellQuote(WORKDIR)[1:-1], shellQuote(WORKDIR)[1:-1])) - print("Running make") - runCommand("make") + # Look for environment value BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS + # and, if defined, append its value to the make command. This allows + # us to pass in version control tags, like GITTAG, to a build from a + # tarball rather than from a vcs checkout, thus eliminating the need + # to have a working copy of the vcs program on the build machine. + # + # A typical use might be: + # export BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS=" \ + # GITVERSION='echo 123456789a' \ + # GITTAG='echo v3.6.0' \ + # GITBRANCH='echo 3.6'" + + make_extras = os.getenv("BUILDINSTALLER_BUILDPYTHON_MAKE_EXTRAS") + if make_extras: + make_cmd = "make " + make_extras + else: + make_cmd = "make" + print("Running " + make_cmd) + runCommand(make_cmd) print("Running make install") runCommand("make install DESTDIR=%s"%( From solipsis at pitrou.net Mon Jul 24 05:08:38 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Mon, 24 Jul 2017 09:08:38 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=-3 Message-ID: <20170724090836.99076.9CC8984F41379C48@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 0, -7] memory blocks, sum=-7 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogV_D_9d', '--timeout', '7200'] From webhook-mailer at python.org Mon Jul 24 07:02:02 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 11:02:02 -0000 Subject: [Python-checkins] test_bsddb3 tolerates smaller timeout on Windows (#2840) Message-ID: https://github.com/python/cpython/commit/0fc940a09ae6636e78f94ecf6436b8de14bd1c45 commit: 0fc940a09ae6636e78f94ecf6436b8de14bd1c45 branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-24T13:01:59+02:00 summary: test_bsddb3 tolerates smaller timeout on Windows (#2840) bpo-30850: On Windows, test04_lock_timeout2() now tolerates 50 ms whereas 100 ms is expected. The lock sometimes times out after only 58 ms. Windows clocks have a bad resolution and bad accuracy. files: M Lib/bsddb/test/test_lock.py diff --git a/Lib/bsddb/test/test_lock.py b/Lib/bsddb/test/test_lock.py index 0b08aa105a1..22bf8cde7b7 100644 --- a/Lib/bsddb/test/test_lock.py +++ b/Lib/bsddb/test/test_lock.py @@ -2,6 +2,7 @@ TestCases for testing the locking sub-system. """ +import sys import time import unittest @@ -10,7 +11,6 @@ if have_threads : from threading import Thread - import sys if sys.version_info[0] < 3 : from threading import currentThread else : @@ -129,7 +129,14 @@ def deadlock_detection() : end_time=time.time() deadlock_detection.end=True # Floating point rounding - self.assertGreaterEqual(end_time-start_time, 0.0999) + if sys.platform == 'win32': + # bpo-30850: On Windows, tolerate 50 ms whereas 100 ms is expected. + # The lock sometimes times out after only 58 ms. Windows clocks + # have a bad resolution and bad accuracy. + min_dt = 0.050 + else: + min_dt = 0.0999 + self.assertGreaterEqual(end_time-start_time, min_dt) self.env.lock_put(lock) t.join() From webhook-mailer at python.org Mon Jul 24 07:02:23 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 11:02:23 -0000 Subject: [Python-checkins] bpo-26762: Avoid daemon process in _test_multiprocessing (#2842) Message-ID: https://github.com/python/cpython/commit/06634950c553f8df83330ed468c11483b857b7dc commit: 06634950c553f8df83330ed468c11483b857b7dc branch: master author: Victor Stinner committer: GitHub date: 2017-07-24T13:02:20+02:00 summary: bpo-26762: Avoid daemon process in _test_multiprocessing (#2842) test_level() of _test_multiprocessing._TestLogging now uses regular processes rather than daemon processes to prevent zombi processes (to not "leak" processes). files: M Lib/test/_test_multiprocessing.py diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index a14fa7422e7..88e2eb3dac1 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -3469,16 +3469,18 @@ def test_level(self): logger.setLevel(LEVEL1) p = self.Process(target=self._test_level, args=(writer,)) - p.daemon = True p.start() self.assertEqual(LEVEL1, reader.recv()) + p.join() + p.close() logger.setLevel(logging.NOTSET) root_logger.setLevel(LEVEL2) p = self.Process(target=self._test_level, args=(writer,)) - p.daemon = True p.start() self.assertEqual(LEVEL2, reader.recv()) + p.join() + p.close() root_logger.setLevel(root_level) logger.setLevel(level=LOG_LEVEL) From webhook-mailer at python.org Mon Jul 24 11:40:53 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 15:40:53 -0000 Subject: [Python-checkins] bpo-30908: Fix dangling thread in test_os.TestSendfile (#2680) (#2845) Message-ID: https://github.com/python/cpython/commit/157b6ad677b7b330d30b2bb5ffbb2edac77b78cb commit: 157b6ad677b7b330d30b2bb5ffbb2edac77b78cb branch: 3.5 author: Victor Stinner committer: GitHub date: 2017-07-24T17:40:47+02:00 summary: bpo-30908: Fix dangling thread in test_os.TestSendfile (#2680) (#2845) tearDown() now clears explicitly the self.server variable to make sure that the thread is completely cleared when tearDownClass() checks if all threads have been cleaned up. Fix the following warning: $ ./python -m test --fail-env-changed -m test.test_os.TestSendfile.test_keywords -R 3:1 test_os (...) Warning -- threading_cleanup() failed to cleanup 0 threads after 3 sec (count: 0, dangling: 2) (...) Tests result: ENV CHANGED (cherry picked from commit d1cc037d1442cc35d1b194ec8e50901514360949) files: M Lib/test/test_os.py diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py index 8ad6d8e3117..bb5d2e3429c 100644 --- a/Lib/test/test_os.py +++ b/Lib/test/test_os.py @@ -2443,6 +2443,7 @@ def tearDown(self): self.client.close() if self.server.running: self.server.stop() + self.server = None def sendfile_wrapper(self, sock, file, offset, nbytes, headers=[], trailers=[]): """A higher level wrapper representing how an application is From webhook-mailer at python.org Mon Jul 24 11:40:53 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 15:40:53 -0000 Subject: [Python-checkins] bpo-30908: Fix dangling thread in test_os.TestSendfile (#2680) (#2844) Message-ID: https://github.com/python/cpython/commit/bb33ccfc5a216eff753b10a8dc59ec0277f1e1fb commit: bb33ccfc5a216eff753b10a8dc59ec0277f1e1fb branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-24T17:40:50+02:00 summary: bpo-30908: Fix dangling thread in test_os.TestSendfile (#2680) (#2844) tearDown() now clears explicitly the self.server variable to make sure that the thread is completely cleared when tearDownClass() checks if all threads have been cleaned up. Fix the following warning: $ ./python -m test --fail-env-changed -m test.test_os.TestSendfile.test_keywords -R 3:1 test_os (...) Warning -- threading_cleanup() failed to cleanup 0 threads after 3 sec (count: 0, dangling: 2) (...) Tests result: ENV CHANGED (cherry picked from commit d1cc037d1442cc35d1b194ec8e50901514360949) files: M Lib/test/test_os.py diff --git a/Lib/test/test_os.py b/Lib/test/test_os.py index e4951b44ce4..b65ccb71591 100644 --- a/Lib/test/test_os.py +++ b/Lib/test/test_os.py @@ -2621,6 +2621,7 @@ def tearDown(self): self.client.close() if self.server.running: self.server.stop() + self.server = None def sendfile_wrapper(self, sock, file, offset, nbytes, headers=[], trailers=[]): """A higher level wrapper representing how an application is From webhook-mailer at python.org Mon Jul 24 11:41:05 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 15:41:05 -0000 Subject: [Python-checkins] bpo-30188: test_nntplib catch also ssl.SSLEOFError (#2843) Message-ID: https://github.com/python/cpython/commit/5b4feb7e86ecb813b2c56560f86cda2fd46b9579 commit: 5b4feb7e86ecb813b2c56560f86cda2fd46b9579 branch: master author: Victor Stinner committer: GitHub date: 2017-07-24T17:41:02+02:00 summary: bpo-30188: test_nntplib catch also ssl.SSLEOFError (#2843) Catch also ssl.SSLEOFError in NetworkedNNTPTests setUpClass(). EOFError was already catched. files: M Lib/test/test_nntplib.py diff --git a/Lib/test/test_nntplib.py b/Lib/test/test_nntplib.py index 3e84f3429ee..482de66e3f4 100644 --- a/Lib/test/test_nntplib.py +++ b/Lib/test/test_nntplib.py @@ -274,6 +274,11 @@ def is_connected(): NetworkedNNTPTestsMixin.wrap_methods() +EOF_ERRORS = [EOFError] +if ssl is not None: + EOF_ERRORS.append(ssl.SSLEOFError) + + class NetworkedNNTPTests(NetworkedNNTPTestsMixin, unittest.TestCase): # This server supports STARTTLS (gmane doesn't) NNTP_HOST = 'news.trigofacile.com' @@ -289,7 +294,7 @@ def setUpClass(cls): try: cls.server = cls.NNTP_CLASS(cls.NNTP_HOST, timeout=TIMEOUT, usenetrc=False) - except EOFError: + except EOF_ERRORS: raise unittest.SkipTest(f"{cls} got EOF error on connecting " f"to {cls.NNTP_HOST!r}") From webhook-mailer at python.org Mon Jul 24 17:18:11 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 21:18:11 -0000 Subject: [Python-checkins] bpo-30980: Fix double close in asyncore.file_wrapper (#2789) Message-ID: https://github.com/python/cpython/commit/c648a93ae342ac28d2abbb100161eae4f907d001 commit: c648a93ae342ac28d2abbb100161eae4f907d001 branch: master author: Nir Soffer committer: Victor Stinner date: 2017-07-24T23:18:06+02:00 summary: bpo-30980: Fix double close in asyncore.file_wrapper (#2789) * bpo-30980: Fix close test to fail test_close_twice was not considering the fact that file_wrapper is duping the file descriptor. Closing the original descriptor left the duped one open, hiding the fact that close protection is not effective. * bpo-30980: Fix double close protection Invalidated self.fd before closing, handling correctly the case when os.close raises. * bpo-30980: Fix fd leak introduced in the fixed test files: M Lib/asyncore.py M Lib/test/test_asyncore.py diff --git a/Lib/asyncore.py b/Lib/asyncore.py index 705e4068130..03d16838b73 100644 --- a/Lib/asyncore.py +++ b/Lib/asyncore.py @@ -619,8 +619,9 @@ def getsockopt(self, level, optname, buflen=None): def close(self): if self.fd < 0: return - os.close(self.fd) + fd = self.fd self.fd = -1 + os.close(fd) def fileno(self): return self.fd diff --git a/Lib/test/test_asyncore.py b/Lib/test/test_asyncore.py index dc2f716e0bb..07edf2275be 100644 --- a/Lib/test/test_asyncore.py +++ b/Lib/test/test_asyncore.py @@ -433,7 +433,10 @@ def test_close_twice(self): f = asyncore.file_wrapper(fd) os.close(fd) - f.close() + os.close(f.fd) # file_wrapper dupped fd + with self.assertRaises(OSError): + f.close() + self.assertEqual(f.fd, -1) # calling close twice should not fail f.close() From lp_benchmark_robot at intel.com Mon Jul 24 17:57:19 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Mon, 24 Jul 2017 14:57:19 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-24 Message-ID: Results for project python/master, build date: 2017-07-24 03:04:38-07:00. - commit: b364d9f - previous commit: 7c5798e - revision date: 2017-07-24 04:58:43-04:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.075% | -0.018% | +4.940% | +6.552% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.751% | -0.026% | +24.140% | +7.422% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 3.014% | -0.526% | +24.471% | +8.591% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.258% | +0.222% | +22.570% | +7.410% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.277% | +0.334% | +5.840% | +11.612% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.851% | -0.433% | +11.270% | +10.286% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.803% | -0.240% | +8.263% | +8.948% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.722% | -0.273% | +5.218% | +4.620% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.874% | -0.280% | +6.508% | +18.320% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 5.504% | -1.411% | +8.455% | +12.953% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.327% | +0.434% | +4.547% | +5.951% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.499% | +0.366% | +5.215% | +4.872% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.962% | +0.079% | +3.750% | +5.530% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.051% | +0.011% | +9.327% | +10.597% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.662% | +0.115% | +6.927% | +8.407% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.995% | +0.152% | +7.687% | +10.234% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.172% | -0.461% | +10.323% | +10.539% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.460% | -0.026% | +9.433% | +8.004% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.456% | +0.198% | +3.400% | +9.292% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 4.382% | -0.381% | +1.547% | +11.785% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.415% | +0.611% | +7.921% | +9.034% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.096% | +0.808% | +9.667% | +14.239% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.447% | +1.000% | +9.231% | +9.804% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.788% | +0.055% | +18.288% | +12.035% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 7.818% | +0.360% | +3.839% | +15.028% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.759% | -0.113% | +4.170% | +5.079% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.594% | +0.064% | -2.761% | +6.106% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.708% | +0.436% | +2.574% | +7.871% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.434% | -0.454% | +2.676% | +11.677% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 5.270% | -1.199% | +2.396% | +21.021% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.363% | +0.156% | +2.323% | +15.685% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.915% | -0.205% | +5.789% | +15.877% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 5.345% | -0.473% | +12.518% | +9.430% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.312% | -0.027% | +0.280% | +10.062% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.122% | -0.082% | +9.686% | +4.261% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.092% | -0.075% | +1.359% | +4.224% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 0.868% | +0.504% | +10.660% | +11.462% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.219% | -0.887% | -10.134% | +12.447% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.570% | +0.662% | +2.130% | +8.469% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.120% | +0.031% | -1.498% | +5.089% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.405% | -0.026% | +12.165% | +3.579% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.558% | +0.591% | +9.683% | +13.077% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.568% | -0.094% | +1.064% | +3.060% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.957% | +0.221% | +27.026% | +9.066% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.712% | -0.477% | +5.282% | +5.579% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.474% | +0.082% | +16.288% | +6.824% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 7.143% | -1.205% | +0.425% | +4.134% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.849% | -0.166% | +6.364% | +0.097% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.146% | -0.400% | +5.340% | +8.024% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.124% | +0.621% | +4.837% | +3.907% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.482% | +0.101% | +1.940% | +8.832% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.090% | -0.246% | +13.186% | +7.709% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.783% | -0.055% | +10.437% | +5.971% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.074% | -0.805% | +12.223% | +8.860% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.969% | -0.752% | +12.700% | +9.989% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.145% | -1.802% | +21.349% | +13.386% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.156% | -0.013% | +7.016% | +5.098% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.189% | -0.379% | +1.701% | +0.385% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 6.240% | +0.205% | +8.732% | +19.834% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 3.400% | -0.214% | -1.319% | +16.943% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.394% | +0.123% | +6.861% | +7.227% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.004% | -0.102% | +5.735% | +8.159% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.303% | +0.842% | +2.058% | +6.274% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.326% | -0.088% | -5.816% | +10.252% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.241% | -0.266% | +6.590% | +8.275% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-24 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Mon Jul 24 18:03:10 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Mon, 24 Jul 2017 22:03:10 -0000 Subject: [Python-checkins] Minor typo in curses.rst (#2763) Message-ID: https://github.com/python/cpython/commit/d439d3e291d30057a676825f4de6ee5bdc24f874 commit: d439d3e291d30057a676825f4de6ee5bdc24f874 branch: master author: waxmoon committer: Terry Jan Reedy date: 2017-07-24T18:03:07-04:00 summary: Minor typo in curses.rst (#2763) I found a tiny typo in the curses how-to: changed 'Thy' to 'The' on line 68. files: M Doc/howto/curses.rst diff --git a/Doc/howto/curses.rst b/Doc/howto/curses.rst index 188a5cf2231..cbff84160ff 100644 --- a/Doc/howto/curses.rst +++ b/Doc/howto/curses.rst @@ -65,7 +65,7 @@ and full support for mouse and keyboard input. The Python curses module ------------------------ -Thy Python module is a fairly simple wrapper over the C functions provided by +The Python module is a fairly simple wrapper over the C functions provided by curses; if you're already familiar with curses programming in C, it's really easy to transfer that knowledge to Python. The biggest difference is that the Python interface makes things simpler by merging different C functions such as From webhook-mailer at python.org Mon Jul 24 18:33:59 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 22:33:59 -0000 Subject: [Python-checkins] test_multiprocessing: Fix dangling process/thread (#2850) Message-ID: https://github.com/python/cpython/commit/d7e64d9934d86aa6173229de5af5fe908662a33a commit: d7e64d9934d86aa6173229de5af5fe908662a33a branch: master author: Victor Stinner committer: GitHub date: 2017-07-25T00:33:56+02:00 summary: test_multiprocessing: Fix dangling process/thread (#2850) bpo-26762: Fix more dangling processes and threads in test_multiprocessing: * Queue: call close() followed by join_thread() * Process: call join() or self.addCleanup(p.join) files: M Lib/test/_test_multiprocessing.py diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index 88e2eb3dac1..126725f44bd 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -32,11 +32,12 @@ # without thread support. import threading -import multiprocessing.dummy import multiprocessing.connection -import multiprocessing.managers +import multiprocessing.dummy import multiprocessing.heap +import multiprocessing.managers import multiprocessing.pool +import multiprocessing.queues from multiprocessing import util @@ -64,6 +65,13 @@ def latin(s): return s.encode('latin') + +def close_queue(queue): + if isinstance(queue, multiprocessing.queues.Queue): + queue.close() + queue.join_thread() + + # # Constants # @@ -825,6 +833,7 @@ def test_qsize(self): self.assertEqual(q.qsize(), 1) q.get() self.assertEqual(q.qsize(), 0) + close_queue(q) @classmethod def _test_task_done(cls, q): @@ -897,6 +906,7 @@ def __reduce__(self): q.put(True) # bpo-30595: use a timeout of 1 second for slow buildbots self.assertTrue(q.get(timeout=1.0)) + close_queue(q) # # @@ -1020,10 +1030,12 @@ def test_notify(self): p = self.Process(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) p = threading.Thread(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) # wait for both children to start sleeping sleeping.acquire() @@ -1066,11 +1078,13 @@ def test_notify_all(self): args=(cond, sleeping, woken, TIMEOUT1)) p.daemon = True p.start() + self.addCleanup(p.join) t = threading.Thread(target=self.f, args=(cond, sleeping, woken, TIMEOUT1)) t.daemon = True t.start() + self.addCleanup(t.join) # wait for them all to sleep for i in range(6): @@ -1089,10 +1103,12 @@ def test_notify_all(self): p = self.Process(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) t = threading.Thread(target=self.f, args=(cond, sleeping, woken)) t.daemon = True t.start() + self.addCleanup(t.join) # wait for them to all sleep for i in range(6): @@ -1123,10 +1139,12 @@ def test_notify_n(self): p = self.Process(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) t = threading.Thread(target=self.f, args=(cond, sleeping, woken)) t.daemon = True t.start() + self.addCleanup(t.join) # wait for them to all sleep for i in range(6): @@ -1309,6 +1327,7 @@ def test_event(self): p.daemon = True p.start() self.assertEqual(wait(), True) + p.join() # # Tests for Barrier - adapted from tests in test/lock_tests.py @@ -1654,6 +1673,7 @@ def test_thousand(self): p = self.Process(target=self._test_thousand_f, args=(self.barrier, passes, child_conn, lock)) p.start() + self.addCleanup(p.join) for i in range(passes): for j in range(self.N): From webhook-mailer at python.org Mon Jul 24 18:54:57 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Mon, 24 Jul 2017 22:54:57 -0000 Subject: [Python-checkins] [3.6] Minor typo in curses.rst (GH-2763) (#2853) Message-ID: https://github.com/python/cpython/commit/548a6889f4d5cbc3c470b118fae1316adc75826b commit: 548a6889f4d5cbc3c470b118fae1316adc75826b branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-24T18:54:53-04:00 summary: [3.6] Minor typo in curses.rst (GH-2763) (#2853) I found a tiny typo in the curses how-to: changed 'Thy' to 'The' on line 68. (cherry picked from commit d439d3e) files: M Doc/howto/curses.rst diff --git a/Doc/howto/curses.rst b/Doc/howto/curses.rst index 188a5cf2231..cbff84160ff 100644 --- a/Doc/howto/curses.rst +++ b/Doc/howto/curses.rst @@ -65,7 +65,7 @@ and full support for mouse and keyboard input. The Python curses module ------------------------ -Thy Python module is a fairly simple wrapper over the C functions provided by +The Python module is a fairly simple wrapper over the C functions provided by curses; if you're already familiar with curses programming in C, it's really easy to transfer that knowledge to Python. The biggest difference is that the Python interface makes things simpler by merging different C functions such as From webhook-mailer at python.org Mon Jul 24 19:55:57 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Mon, 24 Jul 2017 23:55:57 -0000 Subject: [Python-checkins] test_multiprocessing detects dangling per test case (#2841) Message-ID: https://github.com/python/cpython/commit/ffb49408f0780ae80a553208aa133bc5bb3ba129 commit: ffb49408f0780ae80a553208aa133bc5bb3ba129 branch: master author: Victor Stinner committer: GitHub date: 2017-07-25T01:55:54+02:00 summary: test_multiprocessing detects dangling per test case (#2841) bpo-26762: test_multiprocessing now detects dangling processes and threads per test case classes: * setUpClass()/tearDownClass() of mixin classes now check if multiprocessing.process._dangling or threading._dangling was modified to detect "dangling" processses and threads. * ManagerMixin.tearDownClass() now also emits a warning if it still has more than one active child process after 5 seconds. * tearDownModule() now checks for dangling processes and threads before sleep 500 ms. And it now only sleeps if there is a least one dangling process or thread. files: M Lib/test/_test_multiprocessing.py diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index 126725f44bd..a87b0283f52 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -4303,7 +4303,32 @@ def test_empty(self): # Mixins # -class ProcessesMixin(object): +class BaseMixin(object): + @classmethod + def setUpClass(cls): + cls.dangling = (multiprocessing.process._dangling.copy(), + threading._dangling.copy()) + + @classmethod + def tearDownClass(cls): + # bpo-26762: Some multiprocessing objects like Pool create reference + # cycles. Trigger a garbage collection to break these cycles. + test.support.gc_collect() + + processes = set(multiprocessing.process._dangling) - set(cls.dangling[0]) + if processes: + print('Warning -- Dangling processes: %s' % processes, + file=sys.stderr) + processes = None + + threads = set(threading._dangling) - set(cls.dangling[1]) + if threads: + print('Warning -- Dangling threads: %s' % threads, + file=sys.stderr) + threads = None + + +class ProcessesMixin(BaseMixin): TYPE = 'processes' Process = multiprocessing.Process connection = multiprocessing.connection @@ -4326,7 +4351,7 @@ class ProcessesMixin(object): RawArray = staticmethod(multiprocessing.RawArray) -class ManagerMixin(object): +class ManagerMixin(BaseMixin): TYPE = 'manager' Process = multiprocessing.Process Queue = property(operator.attrgetter('manager.Queue')) @@ -4350,6 +4375,7 @@ def Pool(cls, *args, **kwds): @classmethod def setUpClass(cls): + super().setUpClass() cls.manager = multiprocessing.Manager() @classmethod @@ -4357,23 +4383,35 @@ def tearDownClass(cls): # only the manager process should be returned by active_children() # but this can take a bit on slow machines, so wait a few seconds # if there are other children too (see #17395) + start_time = time.monotonic() t = 0.01 - while len(multiprocessing.active_children()) > 1 and t < 5: + while len(multiprocessing.active_children()) > 1: time.sleep(t) t *= 2 + dt = time.monotonic() - start_time + if dt >= 5.0: + print("Warning -- multiprocessing.Manager still has %s active " + "children after %s seconds" + % (multiprocessing.active_children(), dt), + file=sys.stderr) + break + gc.collect() # do garbage collection if cls.manager._number_of_objects() != 0: # This is not really an error since some tests do not # ensure that all processes which hold a reference to a # managed object have been joined. - print('Shared objects which still exist at manager shutdown:') + print('Warning -- Shared objects which still exist at manager ' + 'shutdown:') print(cls.manager._debug_info()) cls.manager.shutdown() cls.manager.join() cls.manager = None + super().tearDownClass() + -class ThreadsMixin(object): +class ThreadsMixin(BaseMixin): TYPE = 'threads' Process = multiprocessing.dummy.Process connection = multiprocessing.dummy.connection @@ -4450,18 +4488,33 @@ def setUpModule(): multiprocessing.get_logger().setLevel(LOG_LEVEL) def tearDownModule(): + need_sleep = False + + # bpo-26762: Some multiprocessing objects like Pool create reference + # cycles. Trigger a garbage collection to break these cycles. + test.support.gc_collect() + multiprocessing.set_start_method(old_start_method[0], force=True) # pause a bit so we don't get warning about dangling threads/processes - time.sleep(0.5) + processes = set(multiprocessing.process._dangling) - set(dangling[0]) + if processes: + need_sleep = True + print('Warning -- Dangling processes: %s' % processes, + file=sys.stderr) + processes = None + + threads = set(threading._dangling) - set(dangling[1]) + if threads: + need_sleep = True + print('Warning -- Dangling threads: %s' % threads, + file=sys.stderr) + threads = None + + # Sleep 500 ms to give time to child processes to complete. + if need_sleep: + time.sleep(0.5) multiprocessing.process._cleanup() - gc.collect() - tmp = set(multiprocessing.process._dangling) - set(dangling[0]) - if tmp: - print('Dangling processes:', tmp, file=sys.stderr) - del tmp - tmp = set(threading._dangling) - set(dangling[1]) - if tmp: - print('Dangling threads:', tmp, file=sys.stderr) + test.support.gc_collect() remote_globs['setUpModule'] = setUpModule remote_globs['tearDownModule'] = tearDownModule From webhook-mailer at python.org Mon Jul 24 20:40:59 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 00:40:59 -0000 Subject: [Python-checkins] bpo-26762: test_multiprocessing close more queues (#2855) Message-ID: https://github.com/python/cpython/commit/b4c52966c810b5c5e088fceff403247f610b7d13 commit: b4c52966c810b5c5e088fceff403247f610b7d13 branch: master author: Victor Stinner committer: GitHub date: 2017-07-25T02:40:55+02:00 summary: bpo-26762: test_multiprocessing close more queues (#2855) * Close explicitly queues to make sure that we don't leave dangling threads * test_queue_in_process(): remove unused queue * test_access() joins also the process to fix a random warning files: M Lib/test/_test_multiprocessing.py diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index a87b0283f52..e18f7cd3d1d 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -283,6 +283,7 @@ def test_process(self): self.assertEqual(p.exitcode, 0) self.assertEqual(p.is_alive(), False) self.assertNotIn(p, self.active_children()) + close_queue(q) @classmethod def _sleep_some(cls): @@ -461,6 +462,8 @@ def test_close(self): gc.collect() self.assertIs(wr(), None) + close_queue(q) + def test_many_processes(self): if self.TYPE == 'threads': self.skipTest('test not appropriate for {}'.format(self.TYPE)) @@ -501,6 +504,7 @@ def test_lose_target_ref(self): p.join() self.assertIs(wr(), None) self.assertEqual(q.get(), 5) + close_queue(q) @classmethod def _test_child_fd_inflation(self, evt, q): @@ -536,6 +540,7 @@ def test_child_fd_inflation(self): evt.set() for p in procs: p.join() + close_queue(q) # # @@ -721,6 +726,7 @@ def test_put(self): self.assertEqual(queue_full(queue, MAXSIZE), False) proc.join() + close_queue(queue) @classmethod def _test_get(cls, queue, child_can_start, parent_can_continue): @@ -783,6 +789,7 @@ def test_get(self): self.assertTimingAlmostEqual(get.elapsed, TIMEOUT3) proc.join() + close_queue(queue) @classmethod def _test_fork(cls, queue): @@ -818,6 +825,7 @@ def test_fork(self): self.assertRaises(pyqueue.Empty, queue.get, False) p.join() + close_queue(queue) def test_qsize(self): q = self.Queue() @@ -861,6 +869,7 @@ def test_task_done(self): for p in workers: p.join() + close_queue(queue) def test_no_import_lock_contention(self): with test.support.temp_cwd(): @@ -891,6 +900,7 @@ def test_timeout(self): # Tolerate a delta of 30 ms because of the bad clock resolution on # Windows (usually 15.6 ms) self.assertGreaterEqual(delta, 0.170) + close_queue(q) def test_queue_feeder_donot_stop_onexc(self): # bpo-30414: verify feeder handles exceptions correctly @@ -1503,6 +1513,7 @@ def test_wait_return(self): self.run_threads(self._test_wait_return_f, (self.barrier, queue)) results = [queue.get() for i in range(self.N)] self.assertEqual(results.count(0), 1) + close_queue(queue) @classmethod def _test_action_f(cls, barrier, results): @@ -3158,6 +3169,8 @@ def test_access(self): w.close() self.assertEqual(conn.recv(), 'foobar'*2) + p.join() + # # # @@ -3654,7 +3667,7 @@ def _this_sub_process(q): except pyqueue.Empty: pass -def _test_process(q): +def _test_process(): queue = multiprocessing.Queue() subProc = multiprocessing.Process(target=_this_sub_process, args=(queue,)) subProc.daemon = True @@ -3694,8 +3707,7 @@ def flush(self): class TestStdinBadfiledescriptor(unittest.TestCase): def test_queue_in_process(self): - queue = multiprocessing.Queue() - proc = multiprocessing.Process(target=_test_process, args=(queue,)) + proc = multiprocessing.Process(target=_test_process) proc.start() proc.join() From webhook-mailer at python.org Tue Jul 25 04:47:48 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 08:47:48 -0000 Subject: [Python-checkins] bpo-31018: Switch to #pragma pack from __declspec(align) (#2848) Message-ID: https://github.com/python/cpython/commit/39243779f4c97ec6f700fa73c007ca66dfa9408e commit: 39243779f4c97ec6f700fa73c007ca66dfa9408e branch: master author: Segev Finer committer: Victor Stinner date: 2017-07-25T10:47:43+02:00 summary: bpo-31018: Switch to #pragma pack from __declspec(align) (#2848) files: M Modules/_tracemalloc.c diff --git a/Modules/_tracemalloc.c b/Modules/_tracemalloc.c index d9833362dd1..6966b86a48a 100644 --- a/Modules/_tracemalloc.c +++ b/Modules/_tracemalloc.c @@ -83,7 +83,7 @@ typedef struct #ifdef __GNUC__ __attribute__((packed)) #elif defined(_MSC_VER) -_declspec(align(4)) +#pragma pack(push, 4) #endif { /* filename cannot be NULL: "" is used if the Python frame @@ -91,6 +91,9 @@ _declspec(align(4)) PyObject *filename; unsigned int lineno; } frame_t; +#ifdef _MSC_VER +#pragma pack(pop) +#endif typedef struct { From webhook-mailer at python.org Tue Jul 25 05:10:55 2017 From: webhook-mailer at python.org (Larry Hastings) Date: Tue, 25 Jul 2017 09:10:55 -0000 Subject: [Python-checkins] Update 3.5 to use blurb! Message-ID: https://github.com/python/cpython/commit/b902833f35efa1053f75d7b37769b27cb39e2682 commit: b902833f35efa1053f75d7b37769b27cb39e2682 branch: 3.5 author: Larry Hastings committer: Larry Hastings date: 2017-07-23T19:18:13-07:00 summary: Update 3.5 to use blurb! files: A Misc/NEWS.d/3.4.0.rst A Misc/NEWS.d/3.4.0a1.rst A Misc/NEWS.d/3.4.0a2.rst A Misc/NEWS.d/3.4.0a3.rst A Misc/NEWS.d/3.4.0a4.rst A Misc/NEWS.d/3.4.0b1.rst A Misc/NEWS.d/3.4.0b2.rst A Misc/NEWS.d/3.4.0b3.rst A Misc/NEWS.d/3.4.0rc1.rst A Misc/NEWS.d/3.4.0rc2.rst A Misc/NEWS.d/3.4.0rc3.rst A Misc/NEWS.d/3.5.0.rst A Misc/NEWS.d/3.5.0a1.rst A Misc/NEWS.d/3.5.0a2.rst A Misc/NEWS.d/3.5.0a3.rst A Misc/NEWS.d/3.5.0a4.rst A Misc/NEWS.d/3.5.0b1.rst A Misc/NEWS.d/3.5.0b2.rst A Misc/NEWS.d/3.5.0b3.rst A Misc/NEWS.d/3.5.0b4.rst A Misc/NEWS.d/3.5.0rc1.rst A Misc/NEWS.d/3.5.0rc2.rst A Misc/NEWS.d/3.5.0rc3.rst A Misc/NEWS.d/3.5.0rc4.rst A Misc/NEWS.d/3.5.1.rst A Misc/NEWS.d/3.5.1rc1.rst A Misc/NEWS.d/3.5.2.rst A Misc/NEWS.d/3.5.2rc1.rst A Misc/NEWS.d/3.5.3.rst A Misc/NEWS.d/3.5.3rc1.rst A Misc/NEWS.d/next/Build/005.bpo-29643.4WLIJQ.rst A Misc/NEWS.d/next/Build/006.bpo-23404.PdYVWg.rst A Misc/NEWS.d/next/Build/007.bpo-29243.WDK4hT.rst A Misc/NEWS.d/next/C API/014.bpo-29083.tGTjr_.rst A Misc/NEWS.d/next/C API/015.bpo-27867.VMCoJU.rst A Misc/NEWS.d/next/Core and Builtins/088.bpo-29478.rTQ-qy.rst A Misc/NEWS.d/next/Core and Builtins/089.bpo-29337.bjX8AE.rst A Misc/NEWS.d/next/Core and Builtins/090.bpo-29319.KLDUZf.rst A Misc/NEWS.d/next/Core and Builtins/091.bpo-29438.IKxD6I.rst A Misc/NEWS.d/next/Core and Builtins/092.bpo-29347.1RPPGN.rst A Misc/NEWS.d/next/Core and Builtins/093.bpo-29602.qyyskC.rst A Misc/NEWS.d/next/Core and Builtins/094.bpo-28598.QxbzQn.rst A Misc/NEWS.d/next/Core and Builtins/095.bpo-29537.lu1ysY.rst A Misc/NEWS.d/next/Core and Builtins/096.bpo-29600.77wQ6C.rst A Misc/NEWS.d/next/Core and Builtins/097.bpo-28876.cU-sGT.rst A Misc/NEWS.d/next/Core and Builtins/098.bpo-29935.vgjdJo.rst A Misc/NEWS.d/next/Core and Builtins/099.bpo-25794.xfPwqm.rst A Misc/NEWS.d/next/Core and Builtins/100.bpo-27945.p29r3O.rst A Misc/NEWS.d/next/Documentation/008.bpo-29349.PjSo-t.rst A Misc/NEWS.d/next/Documentation/009.bpo-26355.SDq_8Y.rst A Misc/NEWS.d/next/Documentation/010.bpo-25008.CeIzyU.rst A Misc/NEWS.d/next/Documentation/011.bpo-28929.Md7kb0.rst A Misc/NEWS.d/next/Documentation/012.bpo-26985.NB5_9S.rst A Misc/NEWS.d/next/Documentation/013.bpo-30176.VivmCg.rst A Misc/NEWS.d/next/Library/018.bpo-29142.xo6kAv.rst A Misc/NEWS.d/next/Library/019.bpo-28969.j3HJYO.rst A Misc/NEWS.d/next/Library/020.bpo-29219.kxui7t.rst A Misc/NEWS.d/next/Library/021.bpo-29011.MI5f2R.rst A Misc/NEWS.d/next/Library/022.bpo-28735.admHLO.rst A Misc/NEWS.d/next/Library/023.bpo-29290.XBqptF.rst A Misc/NEWS.d/next/Library/024.bpo-29335._KC7IK.rst A Misc/NEWS.d/next/Library/025.bpo-29444.cEwgmk.rst A Misc/NEWS.d/next/Library/026.bpo-29416.KJGyI_.rst A Misc/NEWS.d/next/Library/027.bpo-29519.oGGgZ4.rst A Misc/NEWS.d/next/Library/028.bpo-29100.LAAERS.rst A Misc/NEWS.d/next/Library/029.bpo-28556.p6967e.rst A Misc/NEWS.d/next/Library/030.bpo-29532.YCwVQn.rst A Misc/NEWS.d/next/Library/031.bpo-28961.Rt93vg.rst A Misc/NEWS.d/next/Library/032.bpo-29110.wmE-_T.rst A Misc/NEWS.d/next/Library/033.bpo-29376.rrJhJy.rst A Misc/NEWS.d/next/Library/034.bpo-29703.ZdsPCR.rst A Misc/NEWS.d/next/Library/035.bpo-29704.WHbx27.rst A Misc/NEWS.d/next/Library/036.bpo-29615.OpFKzg.rst A Misc/NEWS.d/next/Library/037.bpo-28298.xfm84U.rst A Misc/NEWS.d/next/Library/038.bpo-8256.jAwGQH.rst A Misc/NEWS.d/next/Library/039.bpo-29742.8hqfEO.rst A Misc/NEWS.d/next/Library/040.bpo-29800.d2xASa.rst A Misc/NEWS.d/next/Library/041.bpo-25455.ZsahHN.rst A Misc/NEWS.d/next/Library/042.bpo-29884.kWXR8W.rst A Misc/NEWS.d/next/Library/043.bpo-29861.t2ZoRK.rst A Misc/NEWS.d/next/Library/044.bpo-25803.CPDR0W.rst A Misc/NEWS.d/next/Library/045.bpo-28699.wZztZP.rst A Misc/NEWS.d/next/Library/046.bpo-27863.pPYHHI.rst A Misc/NEWS.d/next/Library/047.bpo-29942.CsGNuT.rst A Misc/NEWS.d/next/Library/048.bpo-29998.poeIKD.rst A Misc/NEWS.d/next/Library/049.bpo-29692.oyWrAE.rst A Misc/NEWS.d/next/Library/050.bpo-29694.LWKxb1.rst A Misc/NEWS.d/next/Library/051.bpo-30068.n4q47r.rst A Misc/NEWS.d/next/Library/052.bpo-30061.2w_dX9.rst A Misc/NEWS.d/next/Library/053.bpo-30070.XM_B41.rst A Misc/NEWS.d/next/Library/054.bpo-30205.BsxO34.rst A Misc/NEWS.d/next/Library/055.bpo-28556.51gjbP.rst A Misc/NEWS.d/next/Library/056.bpo-30185.Tiu1n8.rst A Misc/NEWS.d/next/Library/057.bpo-30243.RHQt0v.rst A Misc/NEWS.d/next/Library/058.bpo-26293.wig0YG.rst A Misc/NEWS.d/next/Library/059.bpo-29990.HWV6KE.rst A Misc/NEWS.d/next/Library/060.bpo-30048.ELRx8R.rst A Misc/NEWS.d/next/Library/061.bpo-30375.9c8qM7.rst A Misc/NEWS.d/next/Library/062.bpo-30329.EuT36N.rst A Misc/NEWS.d/next/Library/063.bpo-30301.ywOkjN.rst A Misc/NEWS.d/next/Library/064.bpo-30003.BOl9HE.rst A Misc/NEWS.d/next/Library/065.bpo-30414.jGl1Lb.rst A Misc/NEWS.d/next/Library/066.bpo-29960.g0wr3r.rst A Misc/NEWS.d/next/Library/067.bpo-30378.R_19_5.rst A Misc/NEWS.d/next/Library/068.bpo-30418.EwISQm.rst A Misc/NEWS.d/next/Library/069.bpo-27585.0Ugqqu.rst A Misc/NEWS.d/next/Library/070.bpo-29743.en2P4s.rst A Misc/NEWS.d/next/Library/071.bpo-29870.p960Ih.rst A Misc/NEWS.d/next/Library/072.bpo-28556.mESP7G.rst A Misc/NEWS.d/next/Library/073.bpo-30508.wNWRS2.rst A Misc/NEWS.d/next/Library/074.bpo-28994.9vzun1.rst A Misc/NEWS.d/next/Library/075.bpo-24484.vFem8K.rst A Misc/NEWS.d/next/Library/077.bpo-29931.tfcTwK.rst A Misc/NEWS.d/next/Library/078.bpo-30149.hE649r.rst A Misc/NEWS.d/next/Library/079.bpo-23890.GCFAAZ.rst A Misc/NEWS.d/next/Library/080.bpo-30645.oYzbbW.rst A Misc/NEWS.d/next/Library/082.bpo-29755.diQcY_.rst A Misc/NEWS.d/next/Library/085.bpo-30746.7drQI0.rst A Misc/NEWS.d/next/Library/086.bpo-30879.N3KI-o.rst A Misc/NEWS.d/next/Library/087.bpo-29169.8ypApm.rst A Misc/NEWS.d/next/Security/076.bpo-29591.ExKblw.rst A Misc/NEWS.d/next/Security/081.bpo-30500.1VG7R-.rst A Misc/NEWS.d/next/Security/083.bpo-30694.WkMWM_.rst A Misc/NEWS.d/next/Security/084.bpo-30730.rJsyTH.rst A Misc/NEWS.d/next/Tests/001.bpo-29571.r6Dixr.rst A Misc/NEWS.d/next/Tests/002.bpo-30197.c5wRfu.rst A Misc/NEWS.d/next/Tests/003.bpo-28087.m8dc4R.rst A Misc/NEWS.d/next/Tests/004.bpo-30357.n4CPEa.rst A Misc/NEWS.d/next/Windows/016.bpo-29392.OtqS5t.rst A Misc/NEWS.d/next/Windows/017.bpo-30687.8mqHnu.rst D Misc/NEWS M .travis.yml M Doc/Makefile M Doc/whatsnew/changelog.rst diff --git a/.travis.yml b/.travis.yml index cf59d965a87..eb98a657b27 100644 --- a/.travis.yml +++ b/.travis.yml @@ -40,7 +40,7 @@ matrix: - cd Doc # Sphinx is pinned so that new versions that introduce new warnings won't suddenly cause build failures. # (Updating the version is fine as long as no warnings are raised by doing so.) - - python -m pip install sphinx~=1.6.1 + - python -m pip install sphinx~=1.6.1 blurb script: - make check suspicious html SPHINXOPTS="-q -W -j4" - os: linux diff --git a/Doc/Makefile b/Doc/Makefile index b0800c15b5c..5075b0264d0 100644 --- a/Doc/Makefile +++ b/Doc/Makefile @@ -6,6 +6,7 @@ # You can set these variables from the command line. PYTHON = python3 SPHINXBUILD = sphinx-build +BLURB = $(PYTHON) -m blurb PAPER = SOURCES = DISTVERSION = $(shell $(PYTHON) tools/extensions/patchlevel.py) @@ -38,6 +39,8 @@ help: @echo " serve to serve the documentation on the localhost (8000)" build: + -mkdir -p build + $(BLURB) merge -f build/NEWS $(SPHINXBUILD) $(ALLSPHINXOPTS) @echo @@ -107,7 +110,7 @@ clean: venv: $(PYTHON) -m venv venv - ./venv/bin/python3 -m pip install -U Sphinx + ./venv/bin/python3 -m pip install -U Sphinx blurb dist: rm -rf dist diff --git a/Doc/whatsnew/changelog.rst b/Doc/whatsnew/changelog.rst index 67a12f3374f..b4356143659 100644 --- a/Doc/whatsnew/changelog.rst +++ b/Doc/whatsnew/changelog.rst @@ -4,4 +4,4 @@ Changelog +++++++++ -.. miscnews:: ../../Misc/NEWS +.. miscnews:: ../build/NEWS diff --git a/Misc/NEWS b/Misc/NEWS deleted file mode 100644 index 966a011579f..00000000000 --- a/Misc/NEWS +++ /dev/null @@ -1,9670 +0,0 @@ -+++++++++++ -Python News -+++++++++++ - -What's New in Python 3.5.4 release candidate 1? -=============================================== - -Release date: XXXX-XX-XX - -Core and Builtins ------------------ - -- bpo-27945: Fixed various segfaults with dict when input collections are - mutated during searching, inserting or comparing. Based on patches by - Duane Griffin and Tim Mitchell. - -- bpo-25794: Fixed type.__setattr__() and type.__delattr__() for - non-interned attribute names. Based on patch by Eryk Sun. - -- bpo-29935: Fixed error messages in the index() method of tuple, list and deque - when pass indices of wrong type. - -- bpo-28876: ``bool(range)`` works even if ``len(range)`` - raises :exc:`OverflowError`. - -- bpo-29600: Fix wrapping coroutine return values in StopIteration. - -- Issue #29537: Restore runtime compatibility with bytecode files generated by - CPython 3.5.0 to 3.5.2, and adjust the eval loop to avoid the problems that - could be caused by the malformed variant of the BUILD_MAP_UNPACK_WITH_CALL - opcode that they may contain. Patch by Petr Viktorin, Serhiy Storchaka, - and Nick Coghlan. - -- Issue #28598: Support __rmod__ for subclasses of str being called before - str.__mod__. Patch by Martijn Pieters. - -- bpo-29602: Fix incorrect handling of signed zeros in complex constructor for - complex subclasses and for inputs having a __complex__ method. Patch - by Serhiy Storchaka. - -- bpo-29347: Fixed possibly dereferencing undefined pointers - when creating weakref objects. - -- bpo-29438: Fixed use-after-free problem in key sharing dict. - -- Issue #29319: Prevent RunMainFromImporter overwriting sys.path[0]. - -- Issue #29337: Fixed possible BytesWarning when compare the code objects. - Warnings could be emitted at compile time. - -- bpo-29478: If max_line_length=None is specified while using the Compat32 policy, - it is no longer ignored. Patch by Mircea Cosbuc. - -Extension Modules ------------------ - -- Issue #29169: Update zlib to 1.2.11. - -Library -------- - -- bpo-30879: os.listdir() and os.scandir() now emit bytes names when called - with bytes-like argument. - -- bpo-30746: Prohibited the '=' character in environment variable names in - ``os.putenv()`` and ``os.spawn*()``. - -- [Security] bpo-30730: Prevent environment variables injection in subprocess on - Windows. Prevent passing other environment variables and command arguments. - -- [Security] bpo-30694: Upgrade expat copy from 2.2.0 to 2.2.1 to get fixes - of multiple security vulnerabilities including: CVE-2017-9233 (External - entity infinite loop DoS), CVE-2016-9063 (Integer overflow, re-fix), - CVE-2016-0718 (Fix regression bugs from 2.2.0's fix to CVE-2016-0718) - and CVE-2012-0876 (Counter hash flooding with SipHash). - Note: the CVE-2016-5300 (Use os-specific entropy sources like getrandom) - doesn't impact Python, since Python already gets entropy from the OS to set - the expat secret using ``XML_SetHashSalt()``. - -- bpo-29755: Fixed the lgettext() family of functions in the gettext module. - They now always return bytes. - -- [Security] bpo-30500: Fix urllib.parse.splithost() to correctly parse - fragments. For example, ``splithost('//127.0.0.1#@evil.com/')`` now - correctly returns the ``127.0.0.1`` host, instead of treating ``@evil.com`` - as the host in an authentification (``login at host``). - -- bpo-30645: Fix path calculation in imp.load_package(), fixing it for - cases when a package is only shipped with bytecodes. Patch by - Alexandru Ardelean. - -- bpo-23890: unittest.TestCase.assertRaises() now manually breaks a reference - cycle to not keep objects alive longer than expected. - -- bpo-30149: inspect.signature() now supports callables with - variable-argument parameters wrapped with partialmethod. - Patch by Dong-hee Na. - -- bpo-29931: Fixed comparison check for ipaddress.ip_interface objects. - Patch by Sanjay Sundaresan. - -- [Security] bpo-29591: Update expat copy from 2.1.1 to 2.2.0 to get fixes - of CVE-2016-0718 and CVE-2016-4472. See - https://sourceforge.net/p/expat/bugs/537/ for more information. - -- bpo-24484: Avoid race condition in multiprocessing cleanup. - -- bpo-28994: The traceback no longer displayed for SystemExit raised in - a callback registered by atexit. - -- bpo-30508: Don't log exceptions if Task/Future "cancel()" method was - called. - -- bpo-28556: Updates to typing module: Add generic AsyncContextManager, add - support for ContextManager on all versions. Original PRs by Jelle Zijlstra - and Ivan Levkivskyi - -- bpo-29870: Fix ssl sockets leaks when connection is aborted in asyncio/ssl - implementation. Patch by Micha?l Sgha?er. - -- bpo-29743: Closing transport during handshake process leaks open socket. - Patch by Nikolay Kim - -- bpo-27585: Fix waiter cancellation in asyncio.Lock. - Patch by Mathieu Sornay. - -- bpo-30418: On Windows, subprocess.Popen.communicate() now also ignore EINVAL - on stdin.write() if the child process is still running but closed the pipe. - -- bpo-30378: Fix the problem that logging.handlers.SysLogHandler cannot - handle IPv6 addresses. - -- bpo-29960: Preserve generator state when _random.Random.setstate() - raises an exception. Patch by Bryan Olson. - -- bpo-30414: multiprocessing.Queue._feed background running - thread do not break from main loop on exception. - -- bpo-30003: Fix handling escape characters in HZ codec. Based on patch - by Ma Lin. - -- bpo-30301: Fix AttributeError when using SimpleQueue.empty() under - *spawn* and *forkserver* start methods. - -- bpo-30329: imaplib and poplib now catch the Windows socket WSAEINVAL error - (code 10022) on shutdown(SHUT_RDWR): An invalid operation was attempted. - This error occurs sometimes on SSL connections. - -- bpo-30375: Warnings emitted when compile a regular expression now always - point to the line in the user code. Previously they could point into inners - of the re module if emitted from inside of groups or conditionals. - -- bpo-30048: Fixed ``Task.cancel()`` can be ignored when the task is - running coroutine and the coroutine returned without any more ``await``. - -- bpo-29990: Fix range checking in GB18030 decoder. Original patch by Ma Lin. - -- Revert bpo-26293 for zipfile breakage. See also bpo-29094. - -- bpo-30243: Removed the __init__ methods of _json's scanner and encoder. - Misusing them could cause memory leaks or crashes. Now scanner and encoder - objects are completely initialized in the __new__ methods. - -- bpo-30185: Avoid KeyboardInterrupt tracebacks in forkserver helper process - when Ctrl-C is received. - -- bpo-28556: Various updates to typing module: add typing.NoReturn type, use - WrapperDescriptorType, minor bug-fixes. Original PRs by - Jim Fasarakis-Hilliard and Ivan Levkivskyi. - -- bpo-30205: Fix getsockname() for unbound AF_UNIX sockets on Linux. - -- bpo-30070: Fixed leaks and crashes in errors handling in the parser module. - -- bpo-30061: Fixed crashes in IOBase methods __next__() and readlines() when - readline() or __next__() respectively return non-sizeable object. - Fixed possible other errors caused by not checking results of PyObject_Size(), - PySequence_Size(), or PyMapping_Size(). - -- bpo-30068: _io._IOBase.readlines will check if it's closed first when - hint is present. - -- bpo-29694: Fixed race condition in pathlib mkdir with flags - parents=True. Patch by Armin Rigo. - -- bpo-29692: Fixed arbitrary unchaining of RuntimeError exceptions in - contextlib.contextmanager. Patch by Siddharth Velankar. - -- bpo-29998: Pickling and copying ImportError now preserves name and path - attributes. - -- bpo-29942: Fix a crash in itertools.chain.from_iterable when encountering - long runs of empty iterables. - -- bpo-27863: Fixed multiple crashes in ElementTree caused by race conditions - and wrong types. - -- bpo-28699: Fixed a bug in pools in multiprocessing.pool that raising an - exception at the very first of an iterable may swallow the exception or - make the program hang. Patch by Davin Potts and Xiang Zhang. - -- bpo-25803: Avoid incorrect errors raised by Path.mkdir(exist_ok=True) - when the OS gives priority to errors such as EACCES over EEXIST. - -- bpo-29861: Release references to tasks, their arguments and their results - as soon as they are finished in multiprocessing.Pool. - -- bpo-29884: faulthandler: Restore the old sigaltstack during teardown. - Patch by Christophe Zeitouny. - -- bpo-25455: Fixed crashes in repr of recursive buffered file-like objects. - -- bpo-29800: Fix crashes in partial.__repr__ if the keys of partial.keywords - are not strings. Patch by Michael Seifert. - -- bpo-29742: get_extra_info() raises exception if get called on closed ssl transport. - Patch by Nikolay Kim. - -- bpo-8256: Fixed possible failing or crashing input() if attributes "encoding" - or "errors" of sys.stdin or sys.stdout are not set or are not strings. - -- bpo-28298: Fix a bug that prevented array 'Q', 'L' and 'I' from accepting big - intables (objects that have __int__) as elements. Patch by Oren Milman. - -- bpo-29615: SimpleXMLRPCDispatcher no longer chains KeyError (or any other - exception) to exception(s) raised in the dispatched methods. - Patch by Petr Motejlek. - -- bpo-29704: asyncio.subprocess.SubprocessStreamProtocol no longer closes before - all pipes are closed. - -- bpo-29703: Fix asyncio to support instantiation of new event loops - in child processes. - -- bpo-29376: Fix assertion error in threading._DummyThread.is_alive(). - -- bpo-29110: Fix file object leak in aifc.open() when file is given as a - filesystem path and is not in valid AIFF format. Patch by Anthony Zhang. - -- Issue #28961: Fix unittest.mock._Call helper: don't ignore the name parameter - anymore. Patch written by Jiajun Huang. - -- bpo-29532: Altering a kwarg dictionary passed to functools.partial() - no longer affects a partial object after creation. - -- Issue #28556: Various updates to typing module: typing.Counter, typing.ChainMap, - improved ABC caching, etc. Original PRs by Jelle Zijlstra, Ivan Levkivskyi, - Manuel Krebber, and ?ukasz Langa. - -- Issue #29100: Fix datetime.fromtimestamp() regression introduced in Python - 3.6.0: check minimum and maximum years. - -- Issue #29519: Fix weakref spewing exceptions during interpreter shutdown - when used with a rare combination of multiprocessing and custom codecs. - -- Issue #29416: Prevent infinite loop in pathlib.Path.mkdir - -- Issue #29444: Fixed out-of-bounds buffer access in the group() method of - the match object. Based on patch by WGH. - -- Issue #29335: Fix subprocess.Popen.wait() when the child process has - exited to a stopped instead of terminated state (ex: when under ptrace). - -- Issue #29290: Fix a regression in argparse that help messages would wrap at - non-breaking spaces. - -- Issue #28735: Fixed the comparison of mock.MagickMock with mock.ANY. - -- Issue #29011: Fix an important omission by adding Deque to the typing module. - -- Issue #29219: Fixed infinite recursion in the repr of uninitialized - ctypes.CDLL instances. - -- Issue #28969: Fixed race condition in C implementation of functools.lru_cache. - KeyError could be raised when cached function with full cache was - simultaneously called from differen threads with the same uncached arguments. - -- Issue #29142: In urllib.request, suffixes in no_proxy environment variable with - leading dots could match related hostnames again (e.g. .b.c matches a.b.c). - Patch by Milan Oberkirch. - -Windows -------- - -- bpo-30687: Locate msbuild.exe on Windows when building rather than - vcvarsall.bat - -- Issue #29392: Prevent crash when passing invalid arguments into msvcrt module. - -C API ------ - -- Issue #27867: Function PySlice_GetIndicesEx() is replaced with a macro if - Py_LIMITED_API is set to the value between 0x03050400 and 0x03060000 (not - including) or 0x03060100 or higher. - -- Issue #29083: Fixed the declaration of some public API functions. - PyArg_VaParse() and PyArg_VaParseTupleAndKeywords() were not available in - limited API. PyArg_ValidateKeywordArguments(), PyArg_UnpackTuple() and - Py_BuildValue() were not available in limited API of version < 3.3 when - PY_SSIZE_T_CLEAN is defined. - -Documentation -------------- - -- bpo-30176: Add missing attribute related constants in curses documentation. - -- bpo-26985: Add missing info of code object in inspect documentation. - -- bpo-28929: Link the documentation to its source file on GitHub. - -- bpo-25008: Document smtpd.py as effectively deprecated and add a pointer to - aiosmtpd, a third-party asyncio-based replacement. - -- Issue #26355: Add canonical header link on each page to corresponding major - version of the documentation. Patch by Matthias Bussonnier. - -- Issue #29349: Fix Python 2 syntax in code for building the documentation. - -Build ------ - -- bpo-29243: Prevent unnecessary rebuilding of Python during ``make test``, - ``make install`` and some other make targets when configured with - ``--enable-optimizations``. - -- bpo-23404: Don't regenerate generated files based on file modification time - anymore: the action is now explicit. Replace ``make touch`` with - ``make regen-all``. - -- bpo-29643: Fix ``--enable-optimization`` didn't work. - -Tests ------ - -- bpo-30357: test_thread: setUp() now uses support.threading_setup() and - support.threading_cleanup() to wait until threads complete to avoid - random side effects on following tests. Initial patch written by Grzegorz - Grzywacz. - -- bpo-28087: Skip test_asyncore and test_eintr poll failures on macOS. - Skip some tests of select.poll when running on macOS due to unresolved - issues with the underlying system poll function on some macOS versions. - -- bpo-30197: Enhanced functions swap_attr() and swap_item() in the - test.support module. They now work when delete replaced attribute or item - inside the with statement. The old value of the attribute or item (or None - if it doesn't exist) now will be assigned to the target of the "as" clause, - if there is one. - -- Issue #29571: to match the behaviour of the ``re.LOCALE`` flag, - test_re.test_locale_flag now uses ``locale.getpreferredencoding(False)`` to - determine the candidate encoding for the test regex (allowing it to correctly - skip the test when the default locale encoding is a multi-byte encoding) - - -What's New in Python 3.5.3? -=========================== - -Release date: 2017-01-17 - -There were no code changes between 3.5.3rc1 and 3.5.3 final. - - -What's New in Python 3.5.3 release candidate 1? -=============================================== - -Release date: 2017-01-02 - -Core and Builtins ------------------ - -- Issue #29073: bytearray formatting no longer truncates on first null byte. - -- Issue #28932: Do not include if it does not exist. - -- Issue #28147: Fix a memory leak in split-table dictionaries: setattr() - must not convert combined table into split table. - -- Issue #25677: Correct the positioning of the syntax error caret for - indented blocks. Based on patch by Michael Layzell. - -- Issue #29000: Fixed bytes formatting of octals with zero padding in alternate - form. - -- Issue #28512: Fixed setting the offset attribute of SyntaxError by - PyErr_SyntaxLocationEx() and PyErr_SyntaxLocationObject(). - -- Issue #28991: functools.lru_cache() was susceptible to an obscure reentrancy - bug caused by a monkey-patched len() function. - -- Issue #28648: Fixed crash in Py_DecodeLocale() in debug build on Mac OS X - when decode astral characters. Patch by Xiang Zhang. - -- Issue #19398: Extra slash no longer added to sys.path components in case of - empty compile-time PYTHONPATH components. - -- Issue #28426: Fixed potential crash in PyUnicode_AsDecodedObject() in debug - build. - -- Issue #23782: Fixed possible memory leak in _PyTraceback_Add() and exception - loss in PyTraceBack_Here(). - -- Issue #28379: Added sanity checks and tests for PyUnicode_CopyCharacters(). - Patch by Xiang Zhang. - -- Issue #28376: The type of long range iterator is now registered as Iterator. - Patch by Oren Milman. - -- Issue #28376: The constructor of range_iterator now checks that step is not 0. - Patch by Oren Milman. - -- Issue #26906: Resolving special methods of uninitialized type now causes - implicit initialization of the type instead of a fail. - -- Issue #18287: PyType_Ready() now checks that tp_name is not NULL. - Original patch by Niklas Koep. - -- Issue #24098: Fixed possible crash when AST is changed in process of - compiling it. - -- Issue #28350: String constants with null character no longer interned. - -- Issue #26617: Fix crash when GC runs during weakref callbacks. - -- Issue #27942: String constants now interned recursively in tuples and frozensets. - -- Issue #21578: Fixed misleading error message when ImportError called with - invalid keyword args. - -- Issue #28203: Fix incorrect type in error message from - ``complex(1.0, {2:3})``. Patch by Soumya Sharma. - -- Issue #27955: Fallback on reading /dev/urandom device when the getrandom() - syscall fails with EPERM, for example when blocked by SECCOMP. - -- Issue #28131: Fix a regression in zipimport's compile_source(). zipimport - should use the same optimization level as the interpreter. - -- Issue #25221: Fix corrupted result from PyLong_FromLong(0) when - Python is compiled with NSMALLPOSINTS = 0. - -- Issue #25758: Prevents zipimport from unnecessarily encoding a filename - (patch by Eryk Sun) - -- Issue #28189: dictitems_contains no longer swallows compare errors. - (Patch by Xiang Zhang) - -- Issue #27812: Properly clear out a generator's frame's backreference to the - generator to prevent crashes in frame.clear(). - -- Issue #27811: Fix a crash when a coroutine that has not been awaited is - finalized with warnings-as-errors enabled. - -- Issue #27587: Fix another issue found by PVS-Studio: Null pointer check - after use of 'def' in _PyState_AddModule(). - Initial patch by Christian Heimes. - -- Issue #26020: set literal evaluation order did not match documented behaviour. - -- Issue #27782: Multi-phase extension module import now correctly allows the - ``m_methods`` field to be used to add module level functions to instances - of non-module types returned from ``Py_create_mod``. Patch by Xiang Zhang. - -- Issue #27936: The round() function accepted a second None argument - for some types but not for others. Fixed the inconsistency by - accepting None for all numeric types. - -- Issue #27487: Warn if a submodule argument to "python -m" or - runpy.run_module() is found in sys.modules after parent packages are - imported, but before the submodule is executed. - -- Issue #27558: Fix a SystemError in the implementation of "raise" statement. - In a brand new thread, raise a RuntimeError since there is no active - exception to reraise. Patch written by Xiang Zhang. - -- Issue #27419: Standard __import__() no longer look up "__import__" in globals - or builtins for importing submodules or "from import". Fixed handling an - error of non-string package name. - -- Issue #27083: Respect the PYTHONCASEOK environment variable under Windows. - -- Issue #27514: Make having too many statically nested blocks a SyntaxError - instead of SystemError. - -- Issue #27473: Fixed possible integer overflow in bytes and bytearray - concatenations. Patch by Xiang Zhang. - -- Issue #27507: Add integer overflow check in bytearray.extend(). Patch by - Xiang Zhang. - -- Issue #27581: Don't rely on wrapping for overflow check in - PySequence_Tuple(). Patch by Xiang Zhang. - -- Issue #27443: __length_hint__() of bytearray iterators no longer return a - negative integer for a resized bytearray. - -- Issue #27942: Fix memory leak in codeobject.c - -Library -------- - -- Issue #15812: inspect.getframeinfo() now correctly shows the first line of - a context. Patch by Sam Breese. - -- Issue #29094: Offsets in a ZIP file created with extern file object and modes - "w" and "x" now are relative to the start of the file. - -- Issue #13051: Fixed recursion errors in large or resized - curses.textpad.Textbox. Based on patch by Tycho Andersen. - -- Issue #29119: Fix weakrefs in the pure python version of - collections.OrderedDict move_to_end() method. - Contributed by Andra Bogildea. - -- Issue #9770: curses.ascii predicates now work correctly with negative - integers. - -- Issue #28427: old keys should not remove new values from - WeakValueDictionary when collecting from another thread. - -- Issue #28923: Remove editor artifacts from Tix.py. - -- Issue #28871: Fixed a crash when deallocate deep ElementTree. - -- Issue #19542: Fix bugs in WeakValueDictionary.setdefault() and - WeakValueDictionary.pop() when a GC collection happens in another - thread. - -- Issue #20191: Fixed a crash in resource.prlimit() when pass a sequence that - doesn't own its elements as limits. - -- Issue #28779: multiprocessing.set_forkserver_preload() would crash the - forkserver process if a preloaded module instantiated some - multiprocessing objects such as locks. - -- Issue #28847: dbm.dumb now supports reading read-only files and no longer - writes the index file when it is not changed. - -- Issue #25659: In ctypes, prevent a crash calling the from_buffer() and - from_buffer_copy() methods on abstract classes like Array. - -- Issue #28732: Fix crash in os.spawnv() with no elements in args - -- Issue #28485: Always raise ValueError for negative - compileall.compile_dir(workers=...) parameter, even when multithreading is - unavailable. - -- Issue #28387: Fixed possible crash in _io.TextIOWrapper deallocator when - the garbage collector is invoked in other thread. Based on patch by - Sebastian Cufre. - -- Issue #27517: LZMA compressor and decompressor no longer raise exceptions if - given empty data twice. Patch by Benjamin Fogle. - -- Issue #28549: Fixed segfault in curses's addch() with ncurses6. - -- Issue #28449: tarfile.open() with mode "r" or "r:" now tries to open a tar - file with compression before trying to open it without compression. Otherwise - it had 50% chance failed with ignore_zeros=True. - -- Issue #23262: The webbrowser module now supports Firefox 36+ and derived - browsers. Based on patch by Oleg Broytman. - -- Issue #27939: Fixed bugs in tkinter.ttk.LabeledScale and tkinter.Scale caused - by representing the scale as float value internally in Tk. tkinter.IntVar - now works if float value is set to underlying Tk variable. - -- Issue #28255: calendar.TextCalendar().prmonth() no longer prints a space - at the start of new line after printing a month's calendar. Patch by - Xiang Zhang. - -- Issue #20491: The textwrap.TextWrapper class now honors non-breaking spaces. - Based on patch by Kaarle Ritvanen. - -- Issue #28353: os.fwalk() no longer fails on broken links. - -- Issue #25464: Fixed HList.header_exists() in tkinter.tix module by addin - a workaround to Tix library bug. - -- Issue #28488: shutil.make_archive() no longer add entry "./" to ZIP archive. - -- Issue #24452: Make webbrowser support Chrome on Mac OS X. - -- Issue #20766: Fix references leaked by pdb in the handling of SIGINT - handlers. - -- Issue #26293: Fixed writing ZIP files that starts not from the start of the - file. Offsets in ZIP file now are relative to the start of the archive in - conforming to the specification. - -- Issue #28321: Fixed writing non-BMP characters with binary format in plistlib. - -- Issue #28322: Fixed possible crashes when unpickle itertools objects from - incorrect pickle data. Based on patch by John Leitch. - -- Fix possible integer overflows and crashes in the mmap module with unusual - usage patterns. - -- Issue #1703178: Fix the ability to pass the --link-objects option to the - distutils build_ext command. - -- Issue #28253: Fixed calendar functions for extreme months: 0001-01 - and 9999-12. - - Methods itermonthdays() and itermonthdays2() are reimplemented so - that they don't call itermonthdates() which can cause datetime.date - under/overflow. - -- Issue #28275: Fixed possible use after free in the decompress() - methods of the LZMADecompressor and BZ2Decompressor classes. - Original patch by John Leitch. - -- Issue #27897: Fixed possible crash in sqlite3.Connection.create_collation() - if pass invalid string-like object as a name. Patch by Xiang Zhang. - -- Issue #18893: Fix invalid exception handling in Lib/ctypes/macholib/dyld.py. - Patch by Madison May. - -- Issue #27611: Fixed support of default root window in the tkinter.tix module. - -- Issue #27348: In the traceback module, restore the formatting of exception - messages like "Exception: None". This fixes a regression introduced in - 3.5a2. - -- Issue #25651: Allow falsy values to be used for msg parameter of subTest(). - -- Issue #27932: Prevent memory leak in win32_ver(). - -- Fix UnboundLocalError in socket._sendfile_use_sendfile. - -- Issue #28075: Check for ERROR_ACCESS_DENIED in Windows implementation of - os.stat(). Patch by Eryk Sun. - -- Issue #25270: Prevent codecs.escape_encode() from raising SystemError when - an empty bytestring is passed. - -- Issue #28181: Get antigravity over HTTPS. Patch by Kaartic Sivaraam. - -- Issue #25895: Enable WebSocket URL schemes in urllib.parse.urljoin. - Patch by Gergely Imreh and Markus Holtermann. - -- Issue #27599: Fixed buffer overrun in binascii.b2a_qp() and binascii.a2b_qp(). - -- Issue #19003:m email.generator now replaces only ``\r`` and/or ``\n`` line - endings, per the RFC, instead of all unicode line endings. - -- Issue #28019: itertools.count() no longer rounds non-integer step in range - between 1.0 and 2.0 to 1. - -- Issue #25969: Update the lib2to3 grammar to handle the unpacking - generalizations added in 3.5. - -- Issue #14977: mailcap now respects the order of the lines in the mailcap - files ("first match"), as required by RFC 1542. Patch by Michael Lazar. - -- Issue #24594: Validates persist parameter when opening MSI database - -- Issue #17582: xml.etree.ElementTree nows preserves whitespaces in attributes - (Patch by Duane Griffin. Reviewed and approved by Stefan Behnel.) - -- Issue #28047: Fixed calculation of line length used for the base64 CTE - in the new email policies. - -- Issue #27445: Don't pass str(_charset) to MIMEText.set_payload(). - Patch by Claude Paroz. - -- Issue #22450: urllib now includes an ``Accept: */*`` header among the - default headers. This makes the results of REST API requests more - consistent and predictable especially when proxy servers are involved. - -- lib2to3.pgen3.driver.load_grammar() now creates a stable cache file - between runs given the same Grammar.txt input regardless of the hash - randomization setting. - -- Issue #27570: Avoid zero-length memcpy() etc calls with null source - pointers in the "ctypes" and "array" modules. - -- Issue #22233: Break email header lines *only* on the RFC specified CR and LF - characters, not on arbitrary unicode line breaks. This also fixes a bug in - HTTP header parsing. - -- Issue #27988: Fix email iter_attachments incorrect mutation of payload list. - -- Issue #27691: Fix ssl module's parsing of GEN_RID subject alternative name - fields in X.509 certs. - -- Issue #27850: Remove 3DES from ssl module's default cipher list to counter - measure sweet32 attack (CVE-2016-2183). - -- Issue #27766: Add ChaCha20 Poly1305 to ssl module's default ciper list. - (Required OpenSSL 1.1.0 or LibreSSL). - -- Issue #26470: Port ssl and hashlib module to OpenSSL 1.1.0. - -- Remove support for passing a file descriptor to os.access. It never worked but - previously didn't raise. - -- Issue #12885: Fix error when distutils encounters symlink. - -- Issue #27881: Fixed possible bugs when setting sqlite3.Connection.isolation_level. - Based on patch by Xiang Zhang. - -- Issue #27861: Fixed a crash in sqlite3.Connection.cursor() when a factory - creates not a cursor. Patch by Xiang Zhang. - -- Issue #19884: Avoid spurious output on OS X with Gnu Readline. - -- Issue #27706: Restore deterministic behavior of random.Random().seed() - for string seeds using seeding version 1. Allows sequences of calls - to random() to exactly match those obtained in Python 2. - Patch by Nofar Schnider. - -- Issue #10513: Fix a regression in Connection.commit(). Statements should - not be reset after a commit. - -- A new version of typing.py from https://github.com/python/typing: - - Collection (only for 3.6) (Issue #27598) - - Add FrozenSet to __all__ (upstream #261) - - fix crash in _get_type_vars() (upstream #259) - - Remove the dict constraint in ForwardRef._eval_type (upstream #252) - -- Issue #27539: Fix unnormalised ``Fraction.__pow__`` result in the case - of negative exponent and negative base. - -- Issue #21718: cursor.description is now available for queries using CTEs. - -- Issue #2466: posixpath.ismount now correctly recognizes mount points which - the user does not have permission to access. - -- Issue #27773: Correct some memory management errors server_hostname in - _ssl.wrap_socket(). - -- Issue #26750: unittest.mock.create_autospec() now works properly for - subclasses of property() and other data descriptors. - -- In the curses module, raise an error if window.getstr() or window.instr() is - passed a negative value. - -- Issue #27783: Fix possible usage of uninitialized memory in - operator.methodcaller. - -- Issue #27774: Fix possible Py_DECREF on unowned object in _sre. - -- Issue #27760: Fix possible integer overflow in binascii.b2a_qp. - -- Issue #27758: Fix possible integer overflow in the _csv module for large - record lengths. - -- Issue #27568: Prevent HTTPoxy attack (CVE-2016-1000110). Ignore the - HTTP_PROXY variable when REQUEST_METHOD environment is set, which indicates - that the script is in CGI mode. - -- Issue #27656: Do not assume sched.h defines any SCHED_* constants. - -- Issue #27130: In the "zlib" module, fix handling of large buffers - (typically 4 GiB) when compressing and decompressing. Previously, inputs - were limited to 4 GiB, and compression and decompression operations did not - properly handle results of 4 GiB. - -- Issue #27533: Release GIL in nt._isdir - -- Issue #17711: Fixed unpickling by the persistent ID with protocol 0. - Original patch by Alexandre Vassalotti. - -- Issue #27522: Avoid an unintentional reference cycle in email.feedparser. - -- Issue #26844: Fix error message for imp.find_module() to refer to 'path' - instead of 'name'. Patch by Lev Maximov. - -- Issue #23804: Fix SSL zero-length recv() calls to not block and not raise - an error about unclean EOF. - -- Issue #27466: Change time format returned by http.cookie.time2netscape, - confirming the netscape cookie format and making it consistent with - documentation. - -- Issue #26664: Fix activate.fish by removing mis-use of ``$``. - -- Issue #22115: Fixed tracing Tkinter variables: trace_vdelete() with wrong - mode no longer break tracing, trace_vinfo() now always returns a list of - pairs of strings, tracing in the "u" mode now works. - -- Fix a scoping issue in importlib.util.LazyLoader which triggered an - UnboundLocalError when lazy-loading a module that was already put into - sys.modules. - -- Issue #27079: Fixed curses.ascii functions isblank(), iscntrl() and ispunct(). - -- Issue #26754: Some functions (compile() etc) accepted a filename argument - encoded as an iterable of integers. Now only strings and byte-like objects - are accepted. - -- Issue #27048: Prevents distutils failing on Windows when environment - variables contain non-ASCII characters - -- Issue #27330: Fixed possible leaks in the ctypes module. - -- Issue #27238: Got rid of bare excepts in the turtle module. Original patch - by Jelle Zijlstra. - -- Issue #27122: When an exception is raised within the context being managed - by a contextlib.ExitStack() and one of the exit stack generators - catches and raises it in a chain, do not re-raise the original exception - when exiting, let the new chained one through. This avoids the PEP 479 - bug described in issue25782. - -- [Security] Issue #27278: Fix os.urandom() implementation using getrandom() on - Linux. Truncate size to INT_MAX and loop until we collected enough random - bytes, instead of casting a directly Py_ssize_t to int. - -- Issue #26386: Fixed ttk.TreeView selection operations with item id's - containing spaces. - -- [Security] Issue #22636: Avoid shell injection problems with - ctypes.util.find_library(). - -- Issue #16182: Fix various functions in the "readline" module to use the - locale encoding, and fix get_begidx() and get_endidx() to return code point - indexes. - -- Issue #27392: Add loop.connect_accepted_socket(). - Patch by Jim Fulton. - -- Issue #27930: Improved behaviour of logging.handlers.QueueListener. - Thanks to Paulo Andrade and Petr Viktorin for the analysis and patch. - -- Issue #21201: Improves readability of multiprocessing error message. Thanks - to Wojciech Walczak for patch. - -- Issue #27456: asyncio: Set TCP_NODELAY by default. - -- Issue #27906: Fix socket accept exhaustion during high TCP traffic. - Patch by Kevin Conway. - -- Issue #28174: Handle when SO_REUSEPORT isn't properly supported. - Patch by Seth Michael Larson. - -- Issue #26654: Inspect functools.partial in asyncio.Handle.__repr__. - Patch by iceboy. - -- Issue #26909: Fix slow pipes IO in asyncio. - Patch by INADA Naoki. - -- Issue #28176: Fix callbacks race in asyncio.SelectorLoop.sock_connect. - -- Issue #27759: Fix selectors incorrectly retain invalid file descriptors. - Patch by Mark Williams. - -- Issue #28368: Refuse monitoring processes if the child watcher has - no loop attached. - Patch by Vincent Michel. - -- Issue #28369: Raise RuntimeError when transport's FD is used with - add_reader, add_writer, etc. - -- Issue #28370: Speedup asyncio.StreamReader.readexactly. - Patch by ????????? ????. - -- Issue #28371: Deprecate passing asyncio.Handles to run_in_executor. - -- Issue #28372: Fix asyncio to support formatting of non-python coroutines. - -- Issue #28399: Remove UNIX socket from FS before binding. - Patch by ????????? ????. - -- Issue #27972: Prohibit Tasks to await on themselves. - -- Issue #26923: Fix asyncio.Gather to refuse being cancelled once all - children are done. - Patch by Johannes Ebke. - -- Issue #26796: Don't configure the number of workers for default - threadpool executor. - Initial patch by Hans Lawrenz. - -- Issue #28600: Optimize loop.call_soon(). - -- Issue #28613: Fix get_event_loop() return the current loop if - called from coroutines/callbacks. - -- Issue #28639: Fix inspect.isawaitable to always return bool - Patch by Justin Mayfield. - -- Issue #28652: Make loop methods reject socket kinds they do not support. - -- Issue #28653: Fix a refleak in functools.lru_cache. - -- Issue #28703: Fix asyncio.iscoroutinefunction to handle Mock objects. - -- Issue #24142: Reading a corrupt config file left the parser in an - invalid state. Original patch by Florian H?ch. - -- Issue #28990: Fix SSL hanging if connection is closed before handshake - completed. - (Patch by HoHo-Ho) - -IDLE ----- - -- Issue #15308: Add 'interrupt execution' (^C) to Shell menu. - Patch by Roger Serwy, updated by Bayard Randel. - -- Issue #27922: Stop IDLE tests from 'flashing' gui widgets on the screen. - -- Add version to title of IDLE help window. - -- Issue #25564: In section on IDLE -- console differences, mention that - using exec means that __builtins__ is defined for each statement. - -- Issue #27714: text_textview and test_autocomplete now pass when re-run - in the same process. This occurs when test_idle fails when run with the - -w option but without -jn. Fix warning from test_config. - -- Issue #25507: IDLE no longer runs buggy code because of its tkinter imports. - Users must include the same imports required to run directly in Python. - -- Issue #27452: add line counter and crc to IDLE configHandler test dump. - -- Issue #27365: Allow non-ascii chars in IDLE NEWS.txt, for contributor names. - -- Issue #27245: IDLE: Cleanly delete custom themes and key bindings. - Previously, when IDLE was started from a console or by import, a cascade - of warnings was emitted. Patch by Serhiy Storchaka. - -C API ------ - -- Issue #28808: PyUnicode_CompareWithASCIIString() now never raises exceptions. - -- Issue #26754: PyUnicode_FSDecoder() accepted a filename argument encoded as - an iterable of integers. Now only strings and bytes-like objects are accepted. - -Documentation -------------- - -- Issue #28513: Documented command-line interface of zipfile. - -Tests ------ - -- Issue #28950: Disallow -j0 to be combined with -T/-l/-M in regrtest - command line arguments. - -- Issue #28666: Now test.support.rmtree is able to remove unwritable or - unreadable directories. - -- Issue #23839: Various caches now are cleared before running every test file. - -- Issue #28409: regrtest: fix the parser of command line arguments. - -- Issue #27787: Call gc.collect() before checking each test for "dangling - threads", since the dangling threads are weak references. - -- Issue #27369: In test_pyexpat, avoid testing an error message detail that - changed in Expat 2.2.0. - -Tools/Demos ------------ - -- Issue #27952: Get Tools/scripts/fixcid.py working with Python 3 and the - current "re" module, avoid invalid Python backslash escapes, and fix a bug - parsing escaped C quote signs. - -- Issue #27332: Fixed the type of the first argument of module-level functions - generated by Argument Clinic. Patch by Petr Viktorin. - -- Issue #27418: Fixed Tools/importbench/importbench.py. - -Windows -------- - -- Issue #28251: Improvements to help manuals on Windows. - -- Issue #28110: launcher.msi has different product codes between 32-bit and - 64-bit - -- Issue #25144: Ensures TargetDir is set before continuing with custom - install. - -- Issue #27469: Adds a shell extension to the launcher so that drag and drop - works correctly. - -- Issue #27309: Enabled proper Windows styles in python[w].exe manifest. - -Build ------ - -- Issue #29080: Removes hard dependency on hg.exe from PCBuild/build.bat - -- Issue #23903: Added missed names to PC/python3.def. - -- Issue #10656: Fix out-of-tree building on AIX. Patch by Tristan Carel and - Michael Haubenwallner. - -- Issue #26359: Rename --with-optimiations to --enable-optimizations. - -- Issue #28444: Fix missing extensions modules when cross compiling. - -- Issue #28248: Update Windows build and OS X installers to use OpenSSL 1.0.2j. - -- Issue #28258: Fixed build with Estonian locale (python-config and distclean - targets in Makefile). Patch by Arfrever Frehtes Taifersar Arahesis. - -- Issue #26661: setup.py now detects system libffi with multiarch wrapper. - -- Issue #28066: Fix the logic that searches build directories for generated - include files when building outside the source tree. - -- Issue #15819: Remove redundant include search directory option for building - outside the source tree. - -- Issue #27566: Fix clean target in freeze makefile (patch by Lisa Roach) - -- Issue #27705: Update message in validate_ucrtbase.py - -- Issue #27983: Cause lack of llvm-profdata tool when using clang as - required for PGO linking to be a configure time error rather than - make time when --with-optimizations is enabled. Also improve our - ability to find the llvm-profdata tool on MacOS and some Linuxes. - -- Issue #26307: The profile-opt build now applies PGO to the built-in modules. - -- Issue #26359: Add the --with-optimizations configure flag. - -- Issue #27713: Suppress spurious build warnings when updating importlib's - bootstrap files. Patch by Xiang Zhang - -- Issue #25825: Correct the references to Modules/python.exp and ld_so_aix, - which are required on AIX. This updates references to an installation path - that was changed in 3.2a4, and undoes changed references to the build tree - that were made in 3.5.0a1. - -- Issue #27453: CPP invocation in configure must use CPPFLAGS. Patch by - Chi Hsuan Yen. - -- Issue #27641: The configure script now inserts comments into the makefile - to prevent the pgen and _freeze_importlib executables from being cross- - compiled. - -- Issue #26662: Set PYTHON_FOR_GEN in configure as the Python program to be - used for file generation during the build. - -- Issue #10910: Avoid C++ compilation errors on FreeBSD and OS X. - Also update FreedBSD version checks for the original ctype UTF-8 workaround. - -- Issue #28676: Prevent missing 'getentropy' declaration warning on macOS. - Patch by Gareth Rees. - - -What's New in Python 3.5.2? -=========================== - -Release date: 2016-06-26 - -Core and Builtins ------------------ - -- Issue #26930: Update Windows builds to use OpenSSL 1.0.2h. - -Tests ------ - -- Issue #26867: Ubuntu's openssl OP_NO_SSLv3 is forced on by default; fix test. - -IDLE ----- - -- Issue #27365: Allow non-ascii in idlelib/NEWS.txt - minimal part for 3.5.2. - - -What's New in Python 3.5.2 release candidate 1? -=============================================== - -Release date: 2016-06-12 - -Core and Builtins ------------------ - -- Issue #27066: Fixed SystemError if a custom opener (for open()) returns a - negative number without setting an exception. - -- Issue #20041: Fixed TypeError when frame.f_trace is set to None. - Patch by Xavier de Gaye. - -- Issue #26168: Fixed possible refleaks in failing Py_BuildValue() with the "N" - format unit. - -- Issue #26991: Fix possible refleak when creating a function with annotations. - -- Issue #27039: Fixed bytearray.remove() for values greater than 127. Patch by - Joe Jevnik. - -- Issue #23640: int.from_bytes() no longer bypasses constructors for subclasses. - -- Issue #26811: gc.get_objects() no longer contains a broken tuple with NULL - pointer. - -- Issue #20120: Use RawConfigParser for .pypirc parsing, - removing support for interpolation unintentionally added - with move to Python 3. Behavior no longer does any - interpolation in .pypirc files, matching behavior in Python - 2.7 and Setuptools 19.0. - -- Issue #26659: Make the builtin slice type support cycle collection. - -- Issue #26718: super.__init__ no longer leaks memory if called multiple times. - NOTE: A direct call of super.__init__ is not endorsed! - -- Issue #25339: PYTHONIOENCODING now has priority over locale in setting the - error handler for stdin and stdout. - -- Issue #26494: Fixed crash on iterating exhausting iterators. - Affected classes are generic sequence iterators, iterators of str, bytes, - bytearray, list, tuple, set, frozenset, dict, OrderedDict, corresponding - views and os.scandir() iterator. - -- Issue #26581: If coding cookie is specified multiple times on a line in - Python source code file, only the first one is taken to account. - -- Issue #26464: Fix str.translate() when string is ASCII and first replacements - removes character, but next replacement uses a non-ASCII character or a - string longer than 1 character. Regression introduced in Python 3.5.0. - -- Issue #22836: Ensure exception reports from PyErr_Display() and - PyErr_WriteUnraisable() are sensible even when formatting them produces - secondary errors. This affects the reports produced by - sys.__excepthook__() and when __del__() raises an exception. - -- Issue #26302: Correct behavior to reject comma as a legal character for - cookie names. - -- Issue #4806: Avoid masking the original TypeError exception when using star - (``*``) unpacking in function calls. Based on patch by Hagen F?rstenau and - Daniel Urban. - -- Issue #27138: Fix the doc comment for FileFinder.find_spec(). - -- Issue #26154: Add a new private _PyThreadState_UncheckedGet() function to get - the current Python thread state, but don't issue a fatal error if it is NULL. - This new function must be used instead of accessing directly the - _PyThreadState_Current variable. The variable is no more exposed since - Python 3.5.1 to hide the exact implementation of atomic C types, to avoid - compiler issues. - -- Issue #26194: Deque.insert() gave odd results for bounded deques that had - reached their maximum size. Now an IndexError will be raised when attempting - to insert into a full deque. - -- Issue #25843: When compiling code, don't merge constants if they are equal - but have a different types. For example, ``f1, f2 = lambda: 1, lambda: 1.0`` - is now correctly compiled to two different functions: ``f1()`` returns ``1`` - (``int``) and ``f2()`` returns ``1.0`` (``int``), even if ``1`` and ``1.0`` - are equal. - -- Issue #22995: [UPDATE] Comment out the one of the pickleability tests in - _PyObject_GetState() due to regressions observed in Cython-based projects. - -- Issue #25961: Disallowed null characters in the type name. - -- Issue #25973: Fix segfault when an invalid nonlocal statement binds a name - starting with two underscores. - -- Issue #22995: Instances of extension types with a state that aren't - subclasses of list or dict and haven't implemented any pickle-related - methods (__reduce__, __reduce_ex__, __getnewargs__, __getnewargs_ex__, - or __getstate__), can no longer be pickled. Including memoryview. - -- Issue #20440: Massive replacing unsafe attribute setting code with special - macro Py_SETREF. - -- Issue #25766: Special method __bytes__() now works in str subclasses. - -- Issue #25421: __sizeof__ methods of builtin types now use dynamic basic size. - This allows sys.getsize() to work correctly with their subclasses with - __slots__ defined. - -- Issue #25709: Fixed problem with in-place string concatenation and utf-8 - cache. - -- Issue #27147: Mention PEP 420 in the importlib docs. - -- Issue #24097: Fixed crash in object.__reduce__() if slot name is freed inside - __getattr__. - -- Issue #24731: Fixed crash on converting objects with special methods - __bytes__, __trunc__, and __float__ returning instances of subclasses of - bytes, int, and float to subclasses of bytes, int, and float correspondingly. - -- Issue #26478: Fix semantic bugs when using binary operators with dictionary - views and tuples. - -- Issue #26171: Fix possible integer overflow and heap corruption in - zipimporter.get_data(). - -- Issue #25660: Fix TAB key behaviour in REPL with readline. - -- Issue #25887: Raise a RuntimeError when a coroutine object is awaited - more than once. - -- Issue #27243: Update the __aiter__ protocol: instead of returning - an awaitable that resolves to an asynchronous iterator, the asynchronous - iterator should be returned directly. Doing the former will trigger a - PendingDeprecationWarning. - - -Library -------- - -- [Security] Issue #26556: Update expat to 2.1.1, fixes CVE-2015-1283. - -- [Security] Fix TLS stripping vulnerability in smtplib, CVE-2016-0772. - Reported by Team Oststrom - -- Issue #21386: Implement missing IPv4Address.is_global property. It was - documented since 07a5610bae9d. Initial patch by Roger Luethi. - -- Issue #20900: distutils register command now decodes HTTP responses - correctly. Initial patch by ingrid. - -- A new version of typing.py provides several new classes and - features: @overload outside stubs, Reversible, DefaultDict, Text, - ContextManager, Type[], NewType(), TYPE_CHECKING, and numerous bug - fixes (note that some of the new features are not yet implemented in - mypy or other static analyzers). Also classes for PEP 492 - (Awaitable, AsyncIterable, AsyncIterator) have been added (in fact - they made it into 3.5.1 but were never mentioned). - -- Issue #25738: Stop http.server.BaseHTTPRequestHandler.send_error() from - sending a message body for 205 Reset Content. Also, don't send Content - header fields in responses that don't have a body. Patch by Susumu - Koshiba. - -- Issue #21313: Fix the "platform" module to tolerate when sys.version - contains truncated build information. - -- [Security] Issue #26839: On Linux, :func:`os.urandom` now calls - ``getrandom()`` with ``GRND_NONBLOCK`` to fall back on reading - ``/dev/urandom`` if the urandom entropy pool is not initialized yet. Patch - written by Colm Buckley. - -- Issue #27164: In the zlib module, allow decompressing raw Deflate streams - with a predefined zdict. Based on patch by Xiang Zhang. - -- Issue #24291: Fix wsgiref.simple_server.WSGIRequestHandler to completely - write data to the client. Previously it could do partial writes and - truncate data. Also, wsgiref.handler.ServerHandler can now handle stdout - doing partial writes, but this is deprecated. - -- Issue #26809: Add ``__all__`` to :mod:`string`. Patch by Emanuel Barry. - -- Issue #26373: subprocess.Popen.communicate now correctly ignores - BrokenPipeError when the child process dies before .communicate() - is called in more/all circumstances. - -- Issue #21776: distutils.upload now correctly handles HTTPError. - Initial patch by Claudiu Popa. - -- Issue #27114: Fix SSLContext._load_windows_store_certs fails with - PermissionError - -- Issue #18383: Avoid creating duplicate filters when using filterwarnings - and simplefilter. Based on patch by Alex Shkop. - -- Issue #27057: Fix os.set_inheritable() on Android, ioctl() is blocked by - SELinux and fails with EACCESS. The function now falls back to fcntl(). - Patch written by Micha? Bednarski. - -- Issue #27014: Fix infinite recursion using typing.py. Thanks to Kalle Tuure! - -- Issue #14132: Fix urllib.request redirect handling when the target only has - a query string. Original fix by J?n Janech. - -- Issue #17214: The "urllib.request" module now percent-encodes non-ASCII - bytes found in redirect target URLs. Some servers send Location header - fields with non-ASCII bytes, but "http.client" requires the request target - to be ASCII-encodable, otherwise a UnicodeEncodeError is raised. Based on - patch by Christian Heimes. - -- Issue #26892: Honor debuglevel flag in urllib.request.HTTPHandler. Patch - contributed by Chi Hsuan Yen. - -- Issue #22274: In the subprocess module, allow stderr to be redirected to - stdout even when stdout is not redirected. Patch by Akira Li. - -- Issue #26807: mock_open 'files' no longer error on readline at end of file. - Patch from Yolanda Robla. - -- Issue #25745: Fixed leaking a userptr in curses panel destructor. - -- Issue #26977: Removed unnecessary, and ignored, call to sum of squares helper - in statistics.pvariance. - -- Issue #26881: The modulefinder module now supports extended opcode arguments. - -- Issue #23815: Fixed crashes related to directly created instances of types in - _tkinter and curses.panel modules. - -- Issue #17765: weakref.ref() no longer silently ignores keyword arguments. - Patch by Georg Brandl. - -- Issue #26873: xmlrpc now raises ResponseError on unsupported type tags - instead of silently return incorrect result. - -- Issue #26711: Fixed the comparison of plistlib.Data with other types. - -- Issue #24114: Fix an uninitialized variable in `ctypes.util`. - - The bug only occurs on SunOS when the ctypes implementation searches - for the `crle` program. Patch by Xiang Zhang. Tested on SunOS by - Kees Bos. - -- Issue #26864: In urllib.request, change the proxy bypass host checking - against no_proxy to be case-insensitive, and to not match unrelated host - names that happen to have a bypassed hostname as a suffix. Patch by Xiang - Zhang. - -- Issue #26634: recursive_repr() now sets __qualname__ of wrapper. Patch by - Xiang Zhang. - -- Issue #26804: urllib.request will prefer lower_case proxy environment - variables over UPPER_CASE or Mixed_Case ones. Patch contributed by Hans-Peter - Jansen. - -- Issue #26837: assertSequenceEqual() now correctly outputs non-stringified - differing items (like bytes in the -b mode). This affects assertListEqual() - and assertTupleEqual(). - -- Issue #26041: Remove "will be removed in Python 3.7" from deprecation - messages of platform.dist() and platform.linux_distribution(). - Patch by Kumaripaba Miyurusara Athukorala. - -- Issue #26822: itemgetter, attrgetter and methodcaller objects no longer - silently ignore keyword arguments. - -- Issue #26733: Disassembling a class now disassembles class and static methods. - Patch by Xiang Zhang. - -- Issue #26801: Fix error handling in :func:`shutil.get_terminal_size`, catch - :exc:`AttributeError` instead of :exc:`NameError`. Patch written by Emanuel - Barry. - -- Issue #24838: tarfile's ustar and gnu formats now correctly calculate name - and link field limits for multibyte character encodings like utf-8. - -- [Security] Issue #26657: Fix directory traversal vulnerability with - http.server on Windows. This fixes a regression that was introduced in - 3.3.4rc1 and 3.4.0rc1. Based on patch by Philipp Hagemeister. - -- Issue #26717: Stop encoding Latin-1-ized WSGI paths with UTF-8. Patch by - Anthony Sottile. - -- Issue #26735: Fix :func:`os.urandom` on Solaris 11.3 and newer when reading - more than 1,024 bytes: call ``getrandom()`` multiple times with a limit of - 1024 bytes per call. - -- Issue #16329: Add .webm to mimetypes.types_map. Patch by Giampaolo Rodola'. - -- Issue #13952: Add .csv to mimetypes.types_map. Patch by Geoff Wilson. - -- Issue #26709: Fixed Y2038 problem in loading binary PLists. - -- Issue #23735: Handle terminal resizing with Readline 6.3+ by installing our - own SIGWINCH handler. Patch by Eric Price. - -- Issue #26586: In http.server, respond with "413 Request header fields too - large" if there are too many header fields to parse, rather than killing - the connection and raising an unhandled exception. Patch by Xiang Zhang. - -- Issue #22854: Change BufferedReader.writable() and - BufferedWriter.readable() to always return False. - -- Issue #25195: Fix a regression in mock.MagicMock. _Call is a subclass of - tuple (changeset 3603bae63c13 only works for classes) so we need to - implement __ne__ ourselves. Patch by Andrew Plummer. - -- Issue #26644: Raise ValueError rather than SystemError when a negative - length is passed to SSLSocket.recv() or read(). - -- Issue #23804: Fix SSL recv(0) and read(0) methods to return zero bytes - instead of up to 1024. - -- Issue #26616: Fixed a bug in datetime.astimezone() method. - -- Issue #21925: :func:`warnings.formatwarning` now catches exceptions on - ``linecache.getline(...)`` to be able to log :exc:`ResourceWarning` emitted - late during the Python shutdown process. - -- Issue #24266: Ctrl+C during Readline history search now cancels the search - mode when compiled with Readline 7. - -- Issue #26560: Avoid potential ValueError in BaseHandler.start_response. - Initial patch by Peter Inglesby. - -- [Security] Issue #26313: ssl.py _load_windows_store_certs fails if windows - cert store is empty. Patch by Baji. - -- Issue #26569: Fix :func:`pyclbr.readmodule` and :func:`pyclbr.readmodule_ex` - to support importing packages. - -- Issue #26499: Account for remaining Content-Length in - HTTPResponse.readline() and read1(). Based on patch by Silent Ghost. - Also document that HTTPResponse now supports these methods. - -- Issue #25320: Handle sockets in directories unittest discovery is scanning. - Patch from Victor van den Elzen. - -- Issue #16181: cookiejar.http2time() now returns None if year is higher than - datetime.MAXYEAR. - -- Issue #26513: Fixes platform module detection of Windows Server - -- Issue #23718: Fixed parsing time in week 0 before Jan 1. Original patch by - Tam?s Bence Gedai. - -- Issue #20589: Invoking Path.owner() and Path.group() on Windows now raise - NotImplementedError instead of ImportError. - -- Issue #26177: Fixed the keys() method for Canvas and Scrollbar widgets. - -- Issue #15068: Got rid of excessive buffering in the fileinput module. - The bufsize parameter is no longer used. - -- Issue #2202: Fix UnboundLocalError in - AbstractDigestAuthHandler.get_algorithm_impls. Initial patch by Mathieu - Dupuy. - -- Issue #25718: Fixed pickling and copying the accumulate() iterator with - total is None. - -- Issue #26475: Fixed debugging output for regular expressions with the (?x) - flag. - -- Issue #26457: Fixed the subnets() methods in IP network classes for the case - when resulting prefix length is equal to maximal prefix length. - Based on patch by Xiang Zhang. - -- Issue #26385: Remove the file if the internal open() call in - NamedTemporaryFile() fails. Patch by Silent Ghost. - -- Issue #26402: Fix XML-RPC client to retry when the server shuts down a - persistent connection. This was a regression related to the new - http.client.RemoteDisconnected exception in 3.5.0a4. - -- Issue #25913: Leading ``<~`` is optional now in base64.a85decode() with - adobe=True. Patch by Swati Jaiswal. - -- Issue #26186: Remove an invalid type check in importlib.util.LazyLoader. - -- Issue #26367: importlib.__import__() raises SystemError like - builtins.__import__() when ``level`` is specified but without an accompanying - package specified. - -- Issue #26309: In the "socketserver" module, shut down the request (closing - the connected socket) when verify_request() returns false. Patch by Aviv - Palivoda. - -- [Security] Issue #25939: On Windows open the cert store readonly in - ssl.enum_certificates. - -- Issue #25995: os.walk() no longer uses FDs proportional to the tree depth. - -- Issue #26117: The os.scandir() iterator now closes file descriptor not only - when the iteration is finished, but when it was failed with error. - -- Issue #25911: Restored support of bytes paths in os.walk() on Windows. - -- Issue #26045: Add UTF-8 suggestion to error message when posting a - non-Latin-1 string with http.client. - -- Issue #12923: Reset FancyURLopener's redirect counter even if there is an - exception. Based on patches by Brian Brazil and Daniel Rocco. - -- Issue #25945: Fixed a crash when unpickle the functools.partial object with - wrong state. Fixed a leak in failed functools.partial constructor. - "args" and "keywords" attributes of functools.partial have now always types - tuple and dict correspondingly. - -- Issue #26202: copy.deepcopy() now correctly copies range() objects with - non-atomic attributes. - -- Issue #23076: Path.glob() now raises a ValueError if it's called with an - invalid pattern. Patch by Thomas Nyberg. - -- Issue #19883: Fixed possible integer overflows in zipimport. - -- Issue #26227: On Windows, getnameinfo(), gethostbyaddr() and - gethostbyname_ex() functions of the socket module now decode the hostname - from the ANSI code page rather than UTF-8. - -- Issue #26147: xmlrpc now works with strings not encodable with used - non-UTF-8 encoding. - -- Issue #25935: Garbage collector now breaks reference loops with OrderedDict. - -- Issue #16620: Fixed AttributeError in msilib.Directory.glob(). - -- Issue #26013: Added compatibility with broken protocol 2 pickles created - in old Python 3 versions (3.4.3 and lower). - -- Issue #25850: Use cross-compilation by default for 64-bit Windows. - -- Issue #17633: Improve zipimport's support for namespace packages. - -- Issue #24705: Fix sysconfig._parse_makefile not expanding ${} vars - appearing before $() vars. - -- Issue #22138: Fix mock.patch behavior when patching descriptors. Restore - original values after patching. Patch contributed by Sean McCully. - -- Issue #25672: In the ssl module, enable the SSL_MODE_RELEASE_BUFFERS mode - option if it is safe to do so. - -- Issue #26012: Don't traverse into symlinks for ``**`` pattern in - pathlib.Path.[r]glob(). - -- Issue #24120: Ignore PermissionError when traversing a tree with - pathlib.Path.[r]glob(). Patch by Ulrich Petri. - -- Issue #25447: fileinput now uses sys.stdin as-is if it does not have a - buffer attribute (restores backward compatibility). - -- Issue #25447: Copying the lru_cache() wrapper object now always works, - independedly from the type of the wrapped object (by returning the original - object unchanged). - -- Issue #24103: Fixed possible use after free in ElementTree.XMLPullParser. - -- Issue #25860: os.fwalk() no longer skips remaining directories when error - occurs. Original patch by Samson Lee. - -- Issue #25914: Fixed and simplified OrderedDict.__sizeof__. - -- Issue #25902: Fixed various refcount issues in ElementTree iteration. - -- Issue #25717: Restore the previous behaviour of tolerating most fstat() - errors when opening files. This was a regression in 3.5a1, and stopped - anonymous temporary files from working in special cases. - -- Issue #24903: Fix regression in number of arguments compileall accepts when - '-d' is specified. The check on the number of arguments has been dropped - completely as it never worked correctly anyway. - -- Issue #25764: In the subprocess module, preserve any exception caused by - fork() failure when preexec_fn is used. - -- Issue #6478: _strptime's regexp cache now is reset after changing timezone - with time.tzset(). - -- Issue #14285: When executing a package with the "python -m package" option, - and package initialization fails, a proper traceback is now reported. The - "runpy" module now lets exceptions from package initialization pass back to - the caller, rather than raising ImportError. - -- Issue #19771: Also in runpy and the "-m" option, omit the irrelevant - message ". . . is a package and cannot be directly executed" if the package - could not even be initialized (e.g. due to a bad ``*.pyc`` file). - -- Issue #25177: Fixed problem with the mean of very small and very large - numbers. As a side effect, statistics.mean and statistics.variance should - be significantly faster. - -- Issue #25718: Fixed copying object with state with boolean value is false. - -- Issue #10131: Fixed deep copying of minidom documents. Based on patch - by Marian Ganisin. - -- Issue #25725: Fixed a reference leak in pickle.loads() when unpickling - invalid data including tuple instructions. - -- Issue #25663: In the Readline completer, avoid listing duplicate global - names, and search the global namespace before searching builtins. - -- Issue #25688: Fixed file leak in ElementTree.iterparse() raising an error. - -- Issue #23914: Fixed SystemError raised by unpickler on broken pickle data. - -- Issue #25691: Fixed crash on deleting ElementTree.Element attributes. - -- Issue #25624: ZipFile now always writes a ZIP_STORED header for directory - entries. Patch by Dingyuan Wang. - -- Skip getaddrinfo if host is already resolved. - Patch by A. Jesse Jiryu Davis. - -- Issue #26050: Add asyncio.StreamReader.readuntil() method. - Patch by ???? ?????????. - -- Issue #25924: Avoid unnecessary serialization of getaddrinfo(3) calls on - OS X versions 10.5 or higher. Original patch by A. Jesse Jiryu Davis. - -- Issue #26406: Avoid unnecessary serialization of getaddrinfo(3) calls on - current versions of OpenBSD and NetBSD. Patch by A. Jesse Jiryu Davis. - -- Issue #26848: Fix asyncio/subprocess.communicate() to handle empty input. - Patch by Jack O'Connor. - -- Issue #27040: Add loop.get_exception_handler method - -- Issue #27041: asyncio: Add loop.create_future method - -- Issue #27223: asyncio: Fix _read_ready and _write_ready to respect - _conn_lost. - Patch by ?ukasz Langa. - -- Issue #22970: asyncio: Fix inconsistency cancelling Condition.wait. - Patch by David Coles. - -IDLE ----- - -- Issue #5124: Paste with text selected now replaces the selection on X11. - This matches how paste works on Windows, Mac, most modern Linux apps, - and ttk widgets. Original patch by Serhiy Storchaka. - -- Issue #24759: Make clear in idlelib.idle_test.__init__ that the directory - is a private implementation of test.test_idle and tool for maintainers. - -- Issue #27196: Stop 'ThemeChanged' warnings when running IDLE tests. - These persisted after other warnings were suppressed in #20567. - Apply Serhiy Storchaka's update_idletasks solution to four test files. - Record this additional advice in idle_test/README.txt - -- Issue #20567: Revise idle_test/README.txt with advice about avoiding - tk warning messages from tests. Apply advice to several IDLE tests. - -- Issue #27117: Make colorizer htest and turtledemo work with dark themes. - Move code for configuring text widget colors to a new function. - -- Issue #26673: When tk reports font size as 0, change to size 10. - Such fonts on Linux prevented the configuration dialog from opening. - -- Issue #21939: Add test for IDLE's percolator. - Original patch by Saimadhav Heblikar. - -- Issue #21676: Add test for IDLE's replace dialog. - Original patch by Saimadhav Heblikar. - -- Issue #18410: Add test for IDLE's search dialog. - Original patch by Westley Mart?nez. - -- Issue #21703: Add test for IDLE's undo delegator. - Original patch by Saimadhav Heblikar . - -- Issue #27044: Add ConfigDialog.remove_var_callbacks to stop memory leaks. - -- Issue #23977: Add more asserts to test_delegator. - -- Issue #20640: Add tests for idlelib.configHelpSourceEdit. - Patch by Saimadhav Heblikar. - -- In the 'IDLE-console differences' section of the IDLE doc, clarify - how running with IDLE affects sys.modules and the standard streams. - -- Issue #25507: fix incorrect change in IOBinding that prevented printing. - Augment IOBinding htest to include all major IOBinding functions. - -- Issue #25905: Revert unwanted conversion of ' to ? RIGHT SINGLE QUOTATION - MARK in README.txt and open this and NEWS.txt with 'ascii'. - Re-encode CREDITS.txt to utf-8 and open it with 'utf-8'. - -Documentation -------------- - -- Issue #19489: Moved the search box from the sidebar to the header and footer - of each page. Patch by Ammar Askar. - -- Issue #24136: Document the new PEP 448 unpacking syntax of 3.5. - -- Issue #26736: Used HTTPS for external links in the documentation if possible. - -- Issue #6953: Rework the Readline module documentation to group related - functions together, and add more details such as what underlying Readline - functions and variables are accessed. - -- Issue #23606: Adds note to ctypes documentation regarding cdll.msvcrt. - -- Issue #25500: Fix documentation to not claim that __import__ is searched for - in the global scope. - -- Issue #26014: Update 3.x packaging documentation: - * "See also" links to the new docs are now provided in the legacy pages - * links to setuptools documentation have been updated - -Tests ------ - -- Issue #21916: Added tests for the turtle module. Patch by ingrid, - Gregory Loyse and Jelle Zijlstra. - -- Issue #26523: The multiprocessing thread pool (multiprocessing.dummy.Pool) - was untested. - -- Issue #26015: Added new tests for pickling iterators of mutable sequences. - -- Issue #26325: Added test.support.check_no_resource_warning() to check that - no ResourceWarning is emitted. - -- Issue #25940: Changed test_ssl to use self-signed.pythontest.net. This - avoids relying on svn.python.org, which recently changed root certificate. - -- Issue #25616: Tests for OrderedDict are extracted from test_collections - into separate file test_ordered_dict. - -- Issue #26583: Skip test_timestamp_overflow in test_import if bytecode - files cannot be written. - -Build ------ - -- Issue #26884: Fix linking extension modules for cross builds. - Patch by Xavier de Gaye. - -- Issue #22359: Disable the rules for running _freeze_importlib and pgen when - cross-compiling. The output of these programs is normally saved with the - source code anyway, and is still regenerated when doing a native build. - Patch by Xavier de Gaye. - -- Issue #27229: Fix the cross-compiling pgen rule for in-tree builds. Patch - by Xavier de Gaye. - -- Issue #21668: Link audioop, _datetime, _ctypes_test modules to libm, - except on Mac OS X. Patch written by Xavier de Gaye. - -- Issue #25702: A --with-lto configure option has been added that will - enable link time optimizations at build time during a make profile-opt. - Some compilers and toolchains are known to not produce stable code when - using LTO, be sure to test things thoroughly before relying on it. - It can provide a few % speed up over profile-opt alone. - -- Issue #26624: Adds validation of ucrtbase[d].dll version with warning - for old versions. - -- Issue #17603: Avoid error about nonexistant fileblocks.o file by using a - lower-level check for st_blocks in struct stat. - -- Issue #26079: Fixing the build output folder for tix-8.4.3.6. Patch by - Bjoern Thiel. - -- Issue #26465: Update Windows builds to use OpenSSL 1.0.2g. - -- Issue #24421: Compile Modules/_math.c once, before building extensions. - Previously it could fail to compile properly if the math and cmath builds - were concurrent. - -- Issue #25348: Added ``--pgo`` and ``--pgo-job`` arguments to - ``PCbuild\build.bat`` for building with Profile-Guided Optimization. The - old ``PCbuild\build_pgo.bat`` script is now deprecated, and simply calls - ``PCbuild\build.bat --pgo %*``. - -- Issue #25827: Add support for building with ICC to ``configure``, including - a new ``--with-icc`` flag. - -- Issue #25696: Fix installation of Python on UNIX with make -j9. - -- Issue #26930: Update OS X 10.5+ 32-bit-only installer to build - and link with OpenSSL 1.0.2h. - -- Issue #26268: Update Windows builds to use OpenSSL 1.0.2f. - -- Issue #25136: Support Apple Xcode 7's new textual SDK stub libraries. - -- Issue #24324: Do not enable unreachable code warnings when using - gcc as the option does not work correctly in older versions of gcc - and has been silently removed as of gcc-4.5. - -Windows -------- - -- Issue #27053: Updates make_zip.py to correctly generate library ZIP file. - -- Issue #26268: Update the prepare_ssl.py script to handle OpenSSL releases - that don't include the contents of the include directory (that is, 1.0.2e - and later). - -- Issue #26071: bdist_wininst created binaries fail to start and find - 32bit Python - -- Issue #26073: Update the list of magic numbers in launcher - -- Issue #26065: Excludes venv from library when generating embeddable - distro. - -Tools/Demos ------------ - -- Issue #26799: Fix python-gdb.py: don't get C types once when the Python code - is loaded, but get C types on demand. The C types can change if - python-gdb.py is loaded before the Python executable. Patch written by Thomas - Ilsche. - -- Issue #26271: Fix the Freeze tool to properly use flags passed through - configure. Patch by Daniel Shaulov. - -- Issue #26489: Add dictionary unpacking support to Tools/parser/unparse.py. - Patch by Guo Ci Teo. - -- Issue #26316: Fix variable name typo in Argument Clinic. - -Misc ----- - -- Issue #17500, and https://github.com/python/pythondotorg/issues/945: Remove - unused and outdated icons. - - -What's New in Python 3.5.1 final? -================================= - -Release date: 2015-12-06 - -Core and Builtins ------------------ - -- Issue #25709: Fixed problem with in-place string concatenation and - utf-8 cache. - -Windows -------- - -- Issue #25715: Python 3.5.1 installer shows wrong upgrade path and incorrect - logic for launcher detection. - - -What's New in Python 3.5.1 release candidate 1? -=============================================== - -Release date: 2015-11-22 - -Core and Builtins ------------------ - -- Issue #25630: Fix a possible segfault during argument parsing in functions - that accept filesystem paths. - -- Issue #23564: Fixed a partially broken sanity check in the _posixsubprocess - internals regarding how fds_to_pass were passed to the child. The bug had - no actual impact as subprocess.py already avoided it. - -- Issue #25388: Fixed tokenizer crash when processing undecodable source code - with a null byte. - -- Issue #25462: The hash of the key now is calculated only once in most - operations in C implementation of OrderedDict. - -- Issue #22995: Default implementation of __reduce__ and __reduce_ex__ now - rejects builtin types with not defined __new__. - -- Issue #25555: Fix parser and AST: fill lineno and col_offset of "arg" node - when compiling AST from Python objects. - -- Issue #24802: Avoid buffer overreads when int(), float(), compile(), exec() - and eval() are passed bytes-like objects. These objects are not - necessarily terminated by a null byte, but the functions assumed they were. - -- Issue #24726: Fixed a crash and leaking NULL in repr() of OrderedDict that - was mutated by direct calls of dict methods. - -- Issue #25449: Iterating OrderedDict with keys with unstable hash now raises - KeyError in C implementations as well as in Python implementation. - -- Issue #25395: Fixed crash when highly nested OrderedDict structures were - garbage collected. - -- Issue #25274: sys.setrecursionlimit() now raises a RecursionError if the new - recursion limit is too low depending at the current recursion depth. Modify - also the "lower-water mark" formula to make it monotonic. This mark is used - to decide when the overflowed flag of the thread state is reset. - -- Issue #24402: Fix input() to prompt to the redirected stdout when - sys.stdout.fileno() fails. - -- Issue #24806: Prevent builtin types that are not allowed to be subclassed from - being subclassed through multiple inheritance. - -- Issue #24848: Fixed a number of bugs in UTF-7 decoding of misformed data. - -- Issue #25280: Import trace messages emitted in verbose (-v) mode are no - longer formatted twice. - -- Issue #25003: On Solaris 11.3 or newer, os.urandom() now uses the - getrandom() function instead of the getentropy() function. The getentropy() - function is blocking to generate very good quality entropy, os.urandom() - doesn't need such high-quality entropy. - -- Issue #25182: The stdprinter (used as sys.stderr before the io module is - imported at startup) now uses the backslashreplace error handler. - -- Issue #25131: Make the line number and column offset of set/dict literals and - comprehensions correspond to the opening brace. - -- Issue #25150: Hide the private _Py_atomic_xxx symbols from the public - Python.h header to fix a compilation error with OpenMP. PyThreadState_GET() - becomes an alias to PyThreadState_Get() to avoid ABI incompatibilies. - -Library -------- - -- Issue #25626: Change three zlib functions to accept sizes that fit in - Py_ssize_t, but internally cap those sizes to UINT_MAX. This resolves a - regression in 3.5 where GzipFile.read() failed to read chunks larger than 2 - or 4 GiB. The change affects the zlib.Decompress.decompress() max_length - parameter, the zlib.decompress() bufsize parameter, and the - zlib.Decompress.flush() length parameter. - -- Issue #25583: Avoid incorrect errors raised by os.makedirs(exist_ok=True) - when the OS gives priority to errors such as EACCES over EEXIST. - -- Issue #25593: Change semantics of EventLoop.stop() in asyncio. - -- Issue #6973: When we know a subprocess.Popen process has died, do - not allow the send_signal(), terminate(), or kill() methods to do - anything as they could potentially signal a different process. - -- Issue #25590: In the Readline completer, only call getattr() once per - attribute. - -- Issue #25498: Fix a crash when garbage-collecting ctypes objects created - by wrapping a memoryview. This was a regression made in 3.5a1. Based - on patch by Eryksun. - -- Issue #25584: Added "escape" to the __all__ list in the glob module. - -- Issue #25584: Fixed recursive glob() with patterns starting with ``**``. - -- Issue #25446: Fix regression in smtplib's AUTH LOGIN support. - -- Issue #18010: Fix the pydoc web server's module search function to handle - exceptions from importing packages. - -- Issue #25554: Got rid of circular references in regular expression parsing. - -- Issue #25510: fileinput.FileInput.readline() now returns b'' instead of '' - at the end if the FileInput was opened with binary mode. - Patch by Ryosuke Ito. - -- Issue #25503: Fixed inspect.getdoc() for inherited docstrings of properties. - Original patch by John Mark Vandenberg. - -- Issue #25515: Always use os.urandom as a source of randomness in uuid.uuid4. - -- Issue #21827: Fixed textwrap.dedent() for the case when largest common - whitespace is a substring of smallest leading whitespace. - Based on patch by Robert Li. - -- Issue #25447: The lru_cache() wrapper objects now can be copied and pickled - (by returning the original object unchanged). - -- Issue #25390: typing: Don't crash on Union[str, Pattern]. - -- Issue #25441: asyncio: Raise error from drain() when socket is closed. - -- Issue #25410: Cleaned up and fixed minor bugs in C implementation of - OrderedDict. - -- Issue #25411: Improved Unicode support in SMTPHandler through better use of - the email package. Thanks to user simon04 for the patch. - -- Issue #25407: Remove mentions of the formatter module being removed in - Python 3.6. - -- Issue #25406: Fixed a bug in C implementation of OrderedDict.move_to_end() - that caused segmentation fault or hang in iterating after moving several - items to the start of ordered dict. - -- Issue #25364: zipfile now works in threads disabled builds. - -- Issue #25328: smtpd's SMTPChannel now correctly raises a ValueError if both - decode_data and enable_SMTPUTF8 are set to true. - -- Issue #25316: distutils raises OSError instead of DistutilsPlatformError - when MSVC is not installed. - -- Issue #25380: Fixed protocol for the STACK_GLOBAL opcode in - pickletools.opcodes. - -- Issue #23972: Updates asyncio datagram create method allowing reuseport - and reuseaddr socket options to be set prior to binding the socket. - Mirroring the existing asyncio create_server method the reuseaddr option - for datagram sockets defaults to True if the O/S is 'posix' (except if the - platform is Cygwin). Patch by Chris Laws. - -- Issue #25304: Add asyncio.run_coroutine_threadsafe(). This lets you - submit a coroutine to a loop from another thread, returning a - concurrent.futures.Future. By Vincent Michel. - -- Issue #25232: Fix CGIRequestHandler to split the query from the URL at the - first question mark (?) rather than the last. Patch from Xiang Zhang. - -- Issue #24657: Prevent CGIRequestHandler from collapsing slashes in the - query part of the URL as if it were a path. Patch from Xiang Zhang. - -- Issue #24483: C implementation of functools.lru_cache() now calculates key's - hash only once. - -- Issue #22958: Constructor and update method of weakref.WeakValueDictionary - now accept the self and the dict keyword arguments. - -- Issue #22609: Constructor of collections.UserDict now accepts the self keyword - argument. - -- Issue #25111: Fixed comparison of traceback.FrameSummary. - -- Issue #25262: Added support for BINBYTES8 opcode in Python implementation of - unpickler. Highest 32 bits of 64-bit size for BINUNICODE8 and BINBYTES8 - opcodes no longer silently ignored on 32-bit platforms in C implementation. - -- Issue #25034: Fix string.Formatter problem with auto-numbering and - nested format_specs. Patch by Anthon van der Neut. - -- Issue #25233: Rewrite the guts of asyncio.Queue and - asyncio.Semaphore to be more understandable and correct. - -- Issue #25203: Failed readline.set_completer_delims() no longer left the - module in inconsistent state. - -- Issue #23600: Default implementation of tzinfo.fromutc() was returning - wrong results in some cases. - -- Issue #23329: Allow the ssl module to be built with older versions of - LibreSSL. - -- Prevent overflow in _Unpickler_Read. - -- Issue #25047: The XML encoding declaration written by Element Tree now - respects the letter case given by the user. This restores the ability to - write encoding names in uppercase like "UTF-8", which worked in Python 2. - -- Issue #25135: Make deque_clear() safer by emptying the deque before clearing. - This helps avoid possible reentrancy issues. - -- Issue #19143: platform module now reads Windows version from kernel32.dll to - avoid compatibility shims. - -- Issue #25092: Fix datetime.strftime() failure when errno was already set to - EINVAL. - -- Issue #23517: Fix rounding in fromtimestamp() and utcfromtimestamp() methods - of datetime.datetime: microseconds are now rounded to nearest with ties - going to nearest even integer (ROUND_HALF_EVEN), instead of being rounding - towards minus infinity (ROUND_FLOOR). It's important that these methods use - the same rounding mode than datetime.timedelta to keep the property: - (datetime(1970,1,1) + timedelta(seconds=t)) == datetime.utcfromtimestamp(t). - It also the rounding mode used by round(float) for example. - -- Issue #25155: Fix datetime.datetime.now() and datetime.datetime.utcnow() on - Windows to support date after year 2038. It was a regression introduced in - Python 3.5.0. - -- Issue #25108: Omitted internal frames in traceback functions print_stack(), - format_stack(), and extract_stack() called without arguments. - -- Issue #25118: Fix a regression of Python 3.5.0 in os.waitpid() on Windows. - -- Issue #24684: socket.socket.getaddrinfo() now calls - PyUnicode_AsEncodedString() instead of calling the encode() method of the - host, to handle correctly custom string with an encode() method which doesn't - return a byte string. The encoder of the IDNA codec is now called directly - instead of calling the encode() method of the string. - -- Issue #25060: Correctly compute stack usage of the BUILD_MAP opcode. - -- Issue #24857: Comparing call_args to a long sequence now correctly returns a - boolean result instead of raising an exception. Patch by A Kaptur. - -- Issue #23144: Make sure that HTMLParser.feed() returns all the data, even - when convert_charrefs is True. - -- Issue #24982: shutil.make_archive() with the "zip" format now adds entries - for directories (including empty directories) in ZIP file. - -- Issue #25019: Fixed a crash caused by setting non-string key of expat parser. - Based on patch by John Leitch. - -- Issue #16180: Exit pdb if file has syntax error, instead of trapping user - in an infinite loop. Patch by Xavier de Gaye. - -- Issue #24891: Fix a race condition at Python startup if the file descriptor - of stdin (0), stdout (1) or stderr (2) is closed while Python is creating - sys.stdin, sys.stdout and sys.stderr objects. These attributes are now set - to None if the creation of the object failed, instead of raising an OSError - exception. Initial patch written by Marco Paolini. - -- Issue #24992: Fix error handling and a race condition (related to garbage - collection) in collections.OrderedDict constructor. - -- Issue #24881: Fixed setting binary mode in Python implementation of FileIO - on Windows and Cygwin. Patch from Akira Li. - -- Issue #25578: Fix (another) memory leak in SSLSocket.getpeercer(). - -- Issue #25530: Disable the vulnerable SSLv3 protocol by default when creating - ssl.SSLContext. - -- Issue #25569: Fix memory leak in SSLSocket.getpeercert(). - -- Issue #25471: Sockets returned from accept() shouldn't appear to be - nonblocking. - -- Issue #25319: When threading.Event is reinitialized, the underlying condition - should use a regular lock rather than a recursive lock. - -- Issue #21112: Fix regression in unittest.expectedFailure on subclasses. - Patch from Berker Peksag. - -- Issue #24764: cgi.FieldStorage.read_multi() now ignores the Content-Length - header in part headers. Patch written by Peter Landry and reviewed by Pierre - Quentel. - -- Issue #24913: Fix overrun error in deque.index(). - Found by John Leitch and Bryce Darling. - -- Issue #24774: Fix docstring in http.server.test. Patch from Chiu-Hsiang Hsu. - -- Issue #21159: Improve message in configparser.InterpolationMissingOptionError. - Patch from ?ukasz Langa. - -- Issue #20362: Honour TestCase.longMessage correctly in assertRegex. - Patch from Ilia Kurenkov. - -- Issue #23572: Fixed functools.singledispatch on classes with falsy - metaclasses. Patch by Ethan Furman. - -- asyncio: ensure_future() now accepts awaitable objects. - -IDLE ----- - -- Issue #15348: Stop the debugger engine (normally in a user process) - before closing the debugger window (running in the IDLE process). - This prevents the RuntimeErrors that were being caught and ignored. - -- Issue #24455: Prevent IDLE from hanging when a) closing the shell while the - debugger is active (15347); b) closing the debugger with the [X] button - (15348); and c) activating the debugger when already active (24455). - The patch by Mark Roseman does this by making two changes. - 1. Suspend and resume the gui.interaction method with the tcl vwait - mechanism intended for this purpose (instead of root.mainloop & .quit). - 2. In gui.run, allow any existing interaction to terminate first. - -- Change 'The program' to 'Your program' in an IDLE 'kill program?' message - to make it clearer that the program referred to is the currently running - user program, not IDLE itself. - -- Issue #24750: Improve the appearance of the IDLE editor window status bar. - Patch by Mark Roseman. - -- Issue #25313: Change the handling of new built-in text color themes to better - address the compatibility problem introduced by the addition of IDLE Dark. - Consistently use the revised idleConf.CurrentTheme everywhere in idlelib. - -- Issue #24782: Extension configuration is now a tab in the IDLE Preferences - dialog rather than a separate dialog. The former tabs are now a sorted - list. Patch by Mark Roseman. - -- Issue #22726: Re-activate the config dialog help button with some content - about the other buttons and the new IDLE Dark theme. - -- Issue #24820: IDLE now has an 'IDLE Dark' built-in text color theme. - It is more or less IDLE Classic inverted, with a cobalt blue background. - Strings, comments, keywords, ... are still green, red, orange, ... . - To use it with IDLEs released before November 2015, hit the - 'Save as New Custom Theme' button and enter a new name, - such as 'Custom Dark'. The custom theme will work with any IDLE - release, and can be modified. - -- Issue #25224: README.txt is now an idlelib index for IDLE developers and - curious users. The previous user content is now in the IDLE doc chapter. - 'IDLE' now means 'Integrated Development and Learning Environment'. - -- Issue #24820: Users can now set breakpoint colors in - Settings -> Custom Highlighting. Original patch by Mark Roseman. - -- Issue #24972: Inactive selection background now matches active selection - background, as configured by users, on all systems. Found items are now - always highlighted on Windows. Initial patch by Mark Roseman. - -- Issue #24570: Idle: make calltip and completion boxes appear on Macs - affected by a tk regression. Initial patch by Mark Roseman. - -- Issue #24988: Idle ScrolledList context menus (used in debugger) - now work on Mac Aqua. Patch by Mark Roseman. - -- Issue #24801: Make right-click for context menu work on Mac Aqua. - Patch by Mark Roseman. - -- Issue #25173: Associate tkinter messageboxes with a specific widget. - For Mac OSX, make them a 'sheet'. Patch by Mark Roseman. - -- Issue #25198: Enhance the initial html viewer now used for Idle Help. - * Properly indent fixed-pitch text (patch by Mark Roseman). - * Give code snippet a very Sphinx-like light blueish-gray background. - * Re-use initial width and height set by users for shell and editor. - * When the Table of Contents (TOC) menu is used, put the section header - at the top of the screen. - -- Issue #25225: Condense and rewrite Idle doc section on text colors. - -- Issue #21995: Explain some differences between IDLE and console Python. - -- Issue #22820: Explain need for *print* when running file from Idle editor. - -- Issue #25224: Doc: augment Idle feature list and no-subprocess section. - -- Issue #25219: Update doc for Idle command line options. - Some were missing and notes were not correct. - -- Issue #24861: Most of idlelib is private and subject to change. - Use idleib.idle.* to start Idle. See idlelib.__init__.__doc__. - -- Issue #25199: Idle: add synchronization comments for future maintainers. - -- Issue #16893: Replace help.txt with help.html for Idle doc display. - The new idlelib/help.html is rstripped Doc/build/html/library/idle.html. - It looks better than help.txt and will better document Idle as released. - The tkinter html viewer that works for this file was written by Mark Roseman. - The now unused EditorWindow.HelpDialog class and helt.txt file are deprecated. - -- Issue #24199: Deprecate unused idlelib.idlever with possible removal in 3.6. - -- Issue #24790: Remove extraneous code (which also create 2 & 3 conflicts). - -Documentation -------------- - -- Issue #22558: Add remaining doc links to source code for Python-coded modules. - Patch by Yoni Lavi. - -- Issue #12067: Rewrite Comparisons section in the Expressions chapter of the - language reference. Some of the details of comparing mixed types were - incorrect or ambiguous. NotImplemented is only relevant at a lower level - than the Expressions chapter. Added details of comparing range() objects, - and default behaviour and consistency suggestions for user-defined classes. - Patch from Andy Maier. - -- Issue #24952: Clarify the default size argument of stack_size() in - the "threading" and "_thread" modules. Patch from Mattip. - -- Issue #23725: Overhaul tempfile docs. Note deprecated status of mktemp. - Patch from Zbigniew J?drzejewski-Szmek. - -- Issue #24808: Update the types of some PyTypeObject fields. Patch by - Joseph Weston. - -- Issue #22812: Fix unittest discovery examples. - Patch from Pam McA'Nulty. - -Tests ------ - -- Issue #25449: Added tests for OrderedDict subclasses. - -- Issue #25099: Make test_compileall not fail when an entry on sys.path cannot - be written to (commonly seen in administrative installs on Windows). - -- Issue #23919: Prevents assert dialogs appearing in the test suite. - -- ``PCbuild\rt.bat`` now accepts an unlimited number of arguments to pass along - to regrtest.py. Previously there was a limit of 9. - -Build ------ - -- Issue #24915: Add LLVM support for PGO builds and use the test suite to - generate the profile data. Initial patch by Alecsandru Patrascu of Intel. - -- Issue #24910: Windows MSIs now have unique display names. - -- Issue #24986: It is now possible to build Python on Windows without errors - when external libraries are not available. - -Windows -------- - -- Issue #25450: Updates shortcuts to start Python in installation directory. - -- Issue #25164: Changes default all-users install directory to match per-user - directory. - -- Issue #25143: Improves installer error messages for unsupported platforms. - -- Issue #25163: Display correct directory in installer when using non-default - settings. - -- Issue #25361: Disables use of SSE2 instructions in Windows 32-bit build - -- Issue #25089: Adds logging to installer for case where launcher is not - selected on upgrade. - -- Issue #25165: Windows uninstallation should not remove launcher if other - versions remain - -- Issue #25112: py.exe launcher is missing icons - -- Issue #25102: Windows installer does not precompile for -O or -OO. - -- Issue #25081: Makes Back button in installer go back to upgrade page when - upgrading. - -- Issue #25091: Increases font size of the installer. - -- Issue #25126: Clarifies that the non-web installer will download some - components. - -- Issue #25213: Restores requestedExecutionLevel to manifest to disable - UAC virtualization. - -- Issue #25022: Removed very outdated PC/example_nt/ directory. - -Tools/Demos ------------ - -- Issue #25440: Fix output of python-config --extension-suffix. - - -What's New in Python 3.5.0 final? -================================= - -Release date: 2015-09-13 - -Build ------ - -- Issue #25071: Windows installer should not require TargetDir - parameter when installing quietly. - - -What's New in Python 3.5.0 release candidate 4? -=============================================== - -Release date: 2015-09-09 - -Library -------- - -- Issue #25029: Fixes MemoryError in test_strptime. - -Build ------ - -- Issue #25027: Reverts partial-static build options and adds - vcruntime140.dll to Windows installation. - - -What's New in Python 3.5.0 release candidate 3? -=============================================== - -Release date: 2015-09-07 - -Core and Builtins ------------------ - -- Issue #24305: Prevent import subsystem stack frames from being counted - by the warnings.warn(stacklevel=) parameter. - -- Issue #24912: Prevent __class__ assignment to immutable built-in objects. - -- Issue #24975: Fix AST compilation for PEP 448 syntax. - -Library -------- - -- Issue #24917: time_strftime() buffer over-read. - -- Issue #24748: To resolve a compatibility problem found with py2exe and - pywin32, imp.load_dynamic() once again ignores previously loaded modules - to support Python modules replacing themselves with extension modules. - Patch by Petr Viktorin. - -- Issue #24635: Fixed a bug in typing.py where isinstance([], typing.Iterable) - would return True once, then False on subsequent calls. - -- Issue #24989: Fixed buffer overread in BytesIO.readline() if a position is - set beyond size. Based on patch by John Leitch. - -- Issue #24913: Fix overrun error in deque.index(). - Found by John Leitch and Bryce Darling. - - -What's New in Python 3.5.0 release candidate 2? -=============================================== - -Release date: 2015-08-25 - -Core and Builtins ------------------ - -- Issue #24769: Interpreter now starts properly when dynamic loading - is disabled. Patch by Petr Viktorin. - -- Issue #21167: NAN operations are now handled correctly when python is - compiled with ICC even if -fp-model strict is not specified. - -- Issue #24492: A "package" lacking a __name__ attribute when trying to perform - a ``from .. import ...`` statement will trigger an ImportError instead of an - AttributeError. - -Library -------- - -- Issue #24847: Removes vcruntime140.dll dependency from Tcl/Tk. - -- Issue #24839: platform._syscmd_ver raises DeprecationWarning - -- Issue #24867: Fix Task.get_stack() for 'async def' coroutines - - -What's New in Python 3.5.0 release candidate 1? -=============================================== - -Release date: 2015-08-09 - -Core and Builtins ------------------ - -- Issue #24667: Resize odict in all cases that the underlying dict resizes. - -Library -------- - -- Issue #24824: Signatures of codecs.encode() and codecs.decode() now are - compatible with pydoc. - -- Issue #24634: Importing uuid should not try to load libc on Windows - -- Issue #24798: _msvccompiler.py doesn't properly support manifests - -- Issue #4395: Better testing and documentation of binary operators. - Patch by Martin Panter. - -- Issue #23973: Update typing.py from GitHub repo. - -- Issue #23004: mock_open() now reads binary data correctly when the type of - read_data is bytes. Initial patch by Aaron Hill. - -- Issue #23888: Handle fractional time in cookie expiry. Patch by ssh. - -- Issue #23652: Make it possible to compile the select module against the - libc headers from the Linux Standard Base, which do not include some - EPOLL macros. Patch by Matt Frank. - -- Issue #22932: Fix timezones in email.utils.formatdate. - Patch from Dmitry Shachnev. - -- Issue #23779: imaplib raises TypeError if authenticator tries to abort. - Patch from Craig Holmquist. - -- Issue #23319: Fix ctypes.BigEndianStructure, swap correctly bytes. Patch - written by Matthieu Gautier. - -- Issue #23254: Document how to close the TCPServer listening socket. - Patch from Martin Panter. - -- Issue #19450: Update Windows and OS X installer builds to use SQLite 3.8.11. - -- Issue #17527: Add PATCH to wsgiref.validator. Patch from Luca Sbardella. - -- Issue #24791: Fix grammar regression for call syntax: 'g(\*a or b)'. - -IDLE ----- - -- Issue #23672: Allow Idle to edit and run files with astral chars in name. - Patch by Mohd Sanad Zaki Rizvi. - -- Issue #24745: Idle editor default font. Switch from Courier to - platform-sensitive TkFixedFont. This should not affect current customized - font selections. If there is a problem, edit $HOME/.idlerc/config-main.cfg - and remove 'fontxxx' entries from [Editor Window]. Patch by Mark Roseman. - -- Issue #21192: Idle editor. When a file is run, put its name in the restart bar. - Do not print false prompts. Original patch by Adnan Umer. - -- Issue #13884: Idle menus. Remove tearoff lines. Patch by Roger Serwy. - -Documentation -------------- - -- Issue #24129: Clarify the reference documentation for name resolution. - This includes removing the assumption that readers will be familiar with the - name resolution scheme Python used prior to the introduction of lexical - scoping for function namespaces. Patch by Ivan Levkivskyi. - -- Issue #20769: Improve reload() docs. Patch by Dorian Pula. - -- Issue #23589: Remove duplicate sentence from the FAQ. Patch by Yongzhi Pan. - -- Issue #24729: Correct IO tutorial to match implementation regarding - encoding parameter to open function. - -Tests ------ - -- Issue #24751: When running regrtest with the ``-w`` command line option, - a test run is no longer marked as a failure if all tests succeed when - re-run. - - -What's New in Python 3.5.0 beta 4? -================================== - -Release date: 2015-07-26 - -Core and Builtins ------------------ - -- Issue #23573: Restored optimization of bytes.rfind() and bytearray.rfind() - for single-byte argument on Linux. - -- Issue #24569: Make PEP 448 dictionary evaluation more consistent. - -- Issue #24583: Fix crash when set is mutated while being updated. - -- Issue #24407: Fix crash when dict is mutated while being updated. - -- Issue #24619: New approach for tokenizing async/await. As a consequence, - it is now possible to have one-line 'async def foo(): await ..' functions. - -- Issue #24687: Plug refleak on SyntaxError in function parameters - annotations. - -- Issue #15944: memoryview: Allow arbitrary formats when casting to bytes. - Patch by Martin Panter. - -Library -------- - -- Issue #23441: rcompleter now prints a tab character instead of displaying - possible completions for an empty word. Initial patch by Martin Sekera. - -- Issue #24683: Fixed crashes in _json functions called with arguments of - inappropriate type. - -- Issue #21697: shutil.copytree() now correctly handles symbolic links that - point to directories. Patch by Eduardo Seabra and Thomas Kluyver. - -- Issue #14373: Fixed segmentation fault when gc.collect() is called during - constructing lru_cache (C implementation). - -- Issue #24695: Fix a regression in traceback.print_exception(). If - exc_traceback is None we shouldn't print a traceback header like described - in the documentation. - -- Issue #24620: Random.setstate() now validates the value of state last element. - -- Issue #22485: Fixed an issue that caused `inspect.getsource` to return - incorrect results on nested functions. - -- Issue #22153: Improve unittest docs. Patch from Martin Panter and evilzero. - -- Issue #24580: Symbolic group references to open group in re patterns now are - explicitly forbidden as well as numeric group references. - -- Issue #24206: Fixed __eq__ and __ne__ methods of inspect classes. - -- Issue #24631: Fixed regression in the timeit module with multiline setup. - -- Issue #18622: unittest.mock.mock_open().reset_mock would recurse infinitely. - Patch from Nicola Palumbo and Laurent De Buyst. - -- Issue #23661: unittest.mock side_effects can now be exceptions again. This - was a regression vs Python 3.4. Patch from Ignacio Rossi - -- Issue #24608: chunk.Chunk.read() now always returns bytes, not str. - -- Issue #18684: Fixed reading out of the buffer in the re module. - -- Issue #24259: tarfile now raises a ReadError if an archive is truncated - inside a data segment. - -- Issue #15014: SMTP.auth() and SMTP.login() now support RFC 4954's optional - initial-response argument to the SMTP AUTH command. - -- Issue #24669: Fix inspect.getsource() for 'async def' functions. - Patch by Kai Groner. - -- Issue #24688: ast.get_docstring() for 'async def' functions. - -Build ------ - -- Issue #24603: Update Windows builds and OS X 10.5 installer to use OpenSSL - 1.0.2d. - - -What's New in Python 3.5.0 beta 3? -================================== - -Release date: 2015-07-05 - -Core and Builtins ------------------ - -- Issue #24467: Fixed possible buffer over-read in bytearray. The bytearray - object now always allocates place for trailing null byte and it's buffer now - is always null-terminated. - -- Upgrade to Unicode 8.0.0. - -- Issue #24345: Add Py_tp_finalize slot for the stable ABI. - -- Issue #24400: Introduce a distinct type for PEP 492 coroutines; add - types.CoroutineType, inspect.getcoroutinestate, inspect.getcoroutinelocals; - coroutines no longer use CO_GENERATOR flag; sys.set_coroutine_wrapper - works only for 'async def' coroutines; inspect.iscoroutine no longer - uses collections.abc.Coroutine, it's intended to test for pure 'async def' - coroutines only; add new opcode: GET_YIELD_FROM_ITER; fix generators wrapper - used in types.coroutine to be instance of collections.abc.Generator; - collections.abc.Awaitable and collections.abc.Coroutine can no longer - be used to detect generator-based coroutines--use inspect.isawaitable - instead. - -- Issue #24450: Add gi_yieldfrom to generators and cr_await to coroutines. - Contributed by Benno Leslie and Yury Selivanov. - -- Issue #19235: Add new RecursionError exception. Patch by Georg Brandl. - -Library -------- - -- Issue #21750: mock_open.read_data can now be read from each instance, as it - could in Python 3.3. - -- Issue #24552: Fix use after free in an error case of the _pickle module. - -- Issue #24514: tarfile now tolerates number fields consisting of only - whitespace. - -- Issue #19176: Fixed doctype() related bugs in C implementation of ElementTree. - A deprecation warning no longer issued by XMLParser subclass with default - doctype() method. Direct call of doctype() now issues a warning. Parser's - doctype() now is not called if target's doctype() is called. Based on patch - by Martin Panter. - -- Issue #20387: Restore semantic round-trip correctness in tokenize/untokenize - for tab-indented blocks. - -- Issue #24456: Fixed possible buffer over-read in adpcm2lin() and lin2adpcm() - functions of the audioop module. - -- Issue #24336: The contextmanager decorator now works with functions with - keyword arguments called "func" and "self". Patch by Martin Panter. - -- Issue #24522: Fix possible integer overflow in json accelerator module. - -- Issue #24489: ensure a previously set C errno doesn't disturb cmath.polar(). - -- Issue #24408: Fixed AttributeError in measure() and metrics() methods of - tkinter.Font. - -- Issue #14373: C implementation of functools.lru_cache() now can be used with - methods. - -- Issue #24347: Set KeyError if PyDict_GetItemWithError returns NULL. - -- Issue #24348: Drop superfluous incref/decref. - -- Issue #24359: Check for changed OrderedDict size during iteration. - -- Issue #24368: Support keyword arguments in OrderedDict methods. - -- Issue #24362: Simplify the C OrderedDict fast nodes resize logic. - -- Issue #24377: Fix a ref leak in OrderedDict.__repr__. - -- Issue #24369: Defend against key-changes during iteration. - -Tests ------ - -- Issue #24373: _testmultiphase and xxlimited now use tp_traverse and - tp_finalize to avoid reference leaks encountered when combining tp_dealloc - with PyType_FromSpec (see issue #16690 for details) - -Documentation -------------- - -- Issue #24458: Update documentation to cover multi-phase initialization for - extension modules (PEP 489). Patch by Petr Viktorin. - -- Issue #24351: Clarify what is meant by "identifier" in the context of - string.Template instances. - -Build ------ - -- Issue #24432: Update Windows builds and OS X 10.5 installer to use OpenSSL - 1.0.2c. - - -What's New in Python 3.5.0 beta 2? -================================== - -Release date: 2015-05-31 - -Core and Builtins ------------------ - -- Issue #24284: The startswith and endswith methods of the str class no longer - return True when finding the empty string and the indexes are completely out - of range. - -- Issue #24115: Update uses of PyObject_IsTrue(), PyObject_Not(), - PyObject_IsInstance(), PyObject_RichCompareBool() and _PyDict_Contains() - to check for and handle errors correctly. - -- Issue #24328: Fix importing one character extension modules. - -- Issue #11205: In dictionary displays, evaluate the key before the value. - -- Issue #24285: Fixed regression that prevented importing extension modules - from inside packages. Patch by Petr Viktorin. - -Library -------- - -- Issue #23247: Fix a crash in the StreamWriter.reset() of CJK codecs. - -- Issue #24270: Add math.isclose() and cmath.isclose() functions as per PEP 485. - Contributed by Chris Barker and Tal Einat. - -- Issue #5633: Fixed timeit when the statement is a string and the setup is not. - -- Issue #24326: Fixed audioop.ratecv() with non-default weightB argument. - Original patch by David Moore. - -- Issue #16991: Add a C implementation of OrderedDict. - -- Issue #23934: Fix inspect.signature to fail correctly for builtin types - lacking signature information. Initial patch by James Powell. - - -What's New in Python 3.5.0 beta 1? -================================== - -Release date: 2015-05-24 - -Core and Builtins ------------------ - -- Issue #24276: Fixed optimization of property descriptor getter. - -- Issue #24268: PEP 489: Multi-phase extension module initialization. - Patch by Petr Viktorin. - -- Issue #23955: Add pyvenv.cfg option to suppress registry/environment - lookup for generating sys.path on Windows. - -- Issue #24257: Fixed system error in the comparison of faked - types.SimpleNamespace. - -- Issue #22939: Fixed integer overflow in iterator object. Patch by - Clement Rouault. - -- Issue #23985: Fix a possible buffer overrun when deleting a slice from - the front of a bytearray and then appending some other bytes data. - -- Issue #24102: Fixed exception type checking in standard error handlers. - -- Issue #15027: The UTF-32 encoder is now 3x to 7x faster. - -- Issue #23290: Optimize set_merge() for cases where the target is empty. - (Contributed by Serhiy Storchaka.) - -- Issue #2292: PEP 448: Additional Unpacking Generalizations. - -- Issue #24096: Make warnings.warn_explicit more robust against mutation of the - warnings.filters list. - -- Issue #23996: Avoid a crash when a delegated generator raises an - unnormalized StopIteration exception. Patch by Stefan Behnel. - -- Issue #23910: Optimize property() getter calls. Patch by Joe Jevnik. - -- Issue #23911: Move path-based importlib bootstrap code to a separate - frozen module. - -- Issue #24192: Fix namespace package imports. - -- Issue #24022: Fix tokenizer crash when processing undecodable source code. - -- Issue #9951: Added a hex() method to bytes, bytearray, and memoryview. - -- Issue #22906: PEP 479: Change StopIteration handling inside generators. - -- Issue #24017: PEP 492: Coroutines with async and await syntax. - -Library -------- - -- Issue #14373: Added C implementation of functools.lru_cache(). Based on - patches by Matt Joiner and Alexey Kachayev. - -- Issue #24230: The tempfile module now accepts bytes for prefix, suffix and dir - parameters and returns bytes in such situations (matching the os module APIs). - -- Issue #22189: collections.UserString now supports __getnewargs__(), - __rmod__(), casefold(), format_map(), isprintable(), and maketrans(). - Patch by Joe Jevnik. - -- Issue #24244: Prevents termination when an invalid format string is - encountered on Windows in strftime. - -- Issue #23973: PEP 484: Add the typing module. - -- Issue #23086: The collections.abc.Sequence() abstract base class added - *start* and *stop* parameters to the index() mixin. - Patch by Devin Jeanpierre. - -- Issue #20035: Replaced the ``tkinter._fix`` module used for setting up the - Tcl/Tk environment on Windows with a private function in the ``_tkinter`` - module that makes no permanent changes to the environment. - -- Issue #24257: Fixed segmentation fault in sqlite3.Row constructor with faked - cursor type. - -- Issue #15836: assertRaises(), assertRaisesRegex(), assertWarns() and - assertWarnsRegex() assertments now check the type of the first argument - to prevent possible user error. Based on patch by Daniel Wagner-Hall. - -- Issue #9858: Add missing method stubs to _io.RawIOBase. Patch by Laura - Rupprecht. - -- Issue #22955: attrgetter, itemgetter and methodcaller objects in the operator - module now support pickling. Added readable and evaluable repr for these - objects. Based on patch by Josh Rosenberg. - -- Issue #22107: tempfile.gettempdir() and tempfile.mkdtemp() now try again - when a directory with the chosen name already exists on Windows as well as - on Unix. tempfile.mkstemp() now fails early if parent directory is not - valid (not exists or is a file) on Windows. - -- Issue #23780: Improved error message in os.path.join() with single argument. - -- Issue #6598: Increased time precision and random number range in - email.utils.make_msgid() to strengthen the uniqueness of the message ID. - -- Issue #24091: Fixed various crashes in corner cases in C implementation of - ElementTree. - -- Issue #21931: msilib.FCICreate() now raises TypeError in the case of a bad - argument instead of a ValueError with a bogus FCI error number. - Patch by Jeffrey Armstrong. - -- Issue #13866: *quote_via* argument added to urllib.parse.urlencode. - -- Issue #20098: New mangle_from policy option for email, default True - for compat32, but False for all other policies. - -- Issue #24211: The email library now supports RFC 6532: it can generate - headers using utf-8 instead of encoded words. - -- Issue #16314: Added support for the LZMA compression in distutils. - -- Issue #21804: poplib now supports RFC 6856 (UTF8). - -- Issue #18682: Optimized pprint functions for builtin scalar types. - -- Issue #22027: smtplib now supports RFC 6531 (SMTPUTF8). - -- Issue #23488: Random generator objects now consume 2x less memory on 64-bit. - -- Issue #1322: platform.dist() and platform.linux_distribution() functions are - now deprecated. Initial patch by Vajrasky Kok. - -- Issue #22486: Added the math.gcd() function. The fractions.gcd() function - now is deprecated. Based on patch by Mark Dickinson. - -- Issue #24064: Property() docstrings are now writeable. - (Patch by Berker Peksag.) - -- Issue #22681: Added support for the koi8_t encoding. - -- Issue #22682: Added support for the kz1048 encoding. - -- Issue #23796: peek and read1 methods of BufferedReader now raise ValueError - if they called on a closed object. Patch by John Hergenroeder. - -- Issue #21795: smtpd now supports the 8BITMIME extension whenever - the new *decode_data* constructor argument is set to False. - -- Issue #24155: optimize heapq.heapify() for better cache performance - when heapifying large lists. - -- Issue #21800: imaplib now supports RFC 5161 (enable), RFC 6855 - (utf8/internationalized email) and automatically encodes non-ASCII - usernames and passwords to UTF8. - -- Issue #20274: When calling a _sqlite.Connection, it now complains if passed - any keyword arguments. Previously it silently ignored them. - -- Issue #20274: Remove ignored and erroneous "kwargs" parameters from three - METH_VARARGS methods on _sqlite.Connection. - -- Issue #24134: assertRaises(), assertRaisesRegex(), assertWarns() and - assertWarnsRegex() checks now emits a deprecation warning when callable is - None or keyword arguments except msg is passed in the context manager mode. - -- Issue #24018: Add a collections.abc.Generator abstract base class. - Contributed by Stefan Behnel. - -- Issue #23880: Tkinter's getint() and getdouble() now support Tcl_Obj. - Tkinter's getdouble() now supports any numbers (in particular int). - -- Issue #22619: Added negative limit support in the traceback module. - Based on patch by Dmitry Kazakov. - -- Issue #24094: Fix possible crash in json.encode with poorly behaved dict - subclasses. - -- Issue #9246: On POSIX, os.getcwd() now supports paths longer than 1025 bytes. - Patch written by William Orr. - -- Issue #17445: add difflib.diff_bytes() to support comparison of - byte strings (fixes a regression from Python 2). - -- Issue #23917: Fall back to sequential compilation when ProcessPoolExecutor - doesn't exist. Patch by Claudiu Popa. - -- Issue #23008: Fixed resolving attributes with boolean value is False in pydoc. - -- Fix asyncio issue 235: LifoQueue and PriorityQueue's put didn't - increment unfinished tasks (this bug was introduced when - JoinableQueue was merged with Queue). - -- Issue #23908: os functions now reject paths with embedded null character - on Windows instead of silently truncating them. - -- Issue #23728: binascii.crc_hqx() could return an integer outside of the range - 0-0xffff for empty data. - -- Issue #23887: urllib.error.HTTPError now has a proper repr() representation. - Patch by Berker Peksag. - -- asyncio: New event loop APIs: set_task_factory() and get_task_factory(). - -- asyncio: async() function is deprecated in favour of ensure_future(). - -- Issue #24178: asyncio.Lock, Condition, Semaphore, and BoundedSemaphore - support new 'async with' syntax. Contributed by Yury Selivanov. - -- Issue #24179: Support 'async for' for asyncio.StreamReader. - Contributed by Yury Selivanov. - -- Issue #24184: Add AsyncIterator and AsyncIterable ABCs to - collections.abc. Contributed by Yury Selivanov. - -- Issue #22547: Implement informative __repr__ for inspect.BoundArguments. - Contributed by Yury Selivanov. - -- Issue #24190: Implement inspect.BoundArgument.apply_defaults() method. - Contributed by Yury Selivanov. - -- Issue #20691: Add 'follow_wrapped' argument to - inspect.Signature.from_callable() and inspect.signature(). - Contributed by Yury Selivanov. - -- Issue #24248: Deprecate inspect.Signature.from_function() and - inspect.Signature.from_builtin(). - -- Issue #23898: Fix inspect.classify_class_attrs() to support attributes - with overloaded __eq__ and __bool__. Patch by Mike Bayer. - -- Issue #24298: Fix inspect.signature() to correctly unwrap wrappers - around bound methods. - -IDLE ----- - -- Issue #23184: remove unused names and imports in idlelib. - Initial patch by Al Sweigart. - -Tests ------ - -- Issue #21520: test_zipfile no longer fails if the word 'bad' appears - anywhere in the name of the current directory. - -- Issue #9517: Move script_helper into the support package. - Patch by Christie Wilson. - -Documentation -------------- - -- Issue #22155: Add File Handlers subsection with createfilehandler to tkinter - doc. Remove obsolete example from FAQ. Patch by Martin Panter. - -- Issue #24029: Document the name binding behavior for submodule imports. - -- Issue #24077: Fix typo in man page for -I command option: -s, not -S - -Tools/Demos ------------ - -- Issue #24000: Improved Argument Clinic's mapping of converters to legacy - "format units". Updated the documentation to match. - -- Issue #24001: Argument Clinic converters now use accept={type} - instead of types={'type'} to specify the types the converter accepts. - -- Issue #23330: h2py now supports arbitrary filenames in #include. - -- Issue #24031: make patchcheck now supports git checkouts, too. - - -What's New in Python 3.5.0 alpha 4? -=================================== - -Release date: 2015-04-19 - -Core and Builtins ------------------ - -- Issue #22980: Under Linux, GNU/KFreeBSD and the Hurd, C extensions now include - the architecture triplet in the extension name, to make it easy to test builds - for different ABIs in the same working tree. Under OS X, the extension name - now includes PEP 3149-style information. - -- Issue #22631: Added Linux-specific socket constant CAN_RAW_FD_FRAMES. - Patch courtesy of Joe Jevnik. - -- Issue #23731: Implement PEP 488: removal of .pyo files. - -- Issue #23726: Don't enable GC for user subclasses of non-GC types that - don't add any new fields. Patch by Eugene Toder. - -- Issue #23309: Avoid a deadlock at shutdown if a daemon thread is aborted - while it is holding a lock to a buffered I/O object, and the main thread - tries to use the same I/O object (typically stdout or stderr). A fatal - error is emitted instead. - -- Issue #22977: Fixed formatting Windows error messages on Wine. - Patch by Martin Panter. - -- Issue #23466: %c, %o, %x, and %X in bytes formatting now raise TypeError on - non-integer input. - -- Issue #24044: Fix possible null pointer dereference in list.sort in out of - memory conditions. - -- Issue #21354: PyCFunction_New function is exposed by python DLL again. - -Library -------- - -- Issue #23840: tokenize.open() now closes the temporary binary file on error - to fix a resource warning. - -- Issue #16914: new debuglevel 2 in smtplib adds timestamps to debug output. - -- Issue #7159: urllib.request now supports sending auth credentials - automatically after the first 401. This enhancement is a superset of the - enhancement from issue #19494 and supersedes that change. - -- Issue #23703: Fix a regression in urljoin() introduced in 901e4e52b20a. - Patch by Demian Brecht. - -- Issue #4254: Adds _curses.update_lines_cols(). Patch by Arnon Yaari - -- Issue #19933: Provide default argument for ndigits in round. Patch by - Vajrasky Kok. - -- Issue #23193: Add a numeric_owner parameter to - tarfile.TarFile.extract and tarfile.TarFile.extractall. Patch by - Michael Vogt and Eric Smith. - -- Issue #23342: Add a subprocess.run() function than returns a CalledProcess - instance for a more consistent API than the existing call* functions. - -- Issue #21217: inspect.getsourcelines() now tries to compute the start and end - lines from the code object, fixing an issue when a lambda function is used as - decorator argument. Patch by Thomas Ballinger and Allison Kaptur. - -- Issue #24521: Fix possible integer overflows in the pickle module. - -- Issue #22931: Allow '[' and ']' in cookie values. - -- The keywords attribute of functools.partial is now always a dictionary. - -- Issue #23811: Add missing newline to the PyCompileError error message. - Patch by Alex Shkop. - -- Issue #21116: Avoid blowing memory when allocating a multiprocessing shared - array that's larger than 50% of the available RAM. Patch by M?d?ric Boquien. - -- Issue #22982: Improve BOM handling when seeking to multiple positions of - a writable text file. - -- Issue #23464: Removed deprecated asyncio JoinableQueue. - -- Issue #23529: Limit the size of decompressed data when reading from - GzipFile, BZ2File or LZMAFile. This defeats denial of service attacks - using compressed bombs (i.e. compressed payloads which decompress to a huge - size). Patch by Martin Panter and Nikolaus Rath. - -- Issue #21859: Added Python implementation of io.FileIO. - -- Issue #23865: close() methods in multiple modules now are idempotent and more - robust at shutdown. If they need to release multiple resources, all are - released even if errors occur. - -- Issue #23400: Raise same exception on both Python 2 and 3 if sem_open is not - available. Patch by Davin Potts. - -- Issue #10838: The subprocess now module includes SubprocessError and - TimeoutError in its list of exported names for the users wild enough - to use ``from subprocess import *``. - -- Issue #23411: Added DefragResult, ParseResult, SplitResult, DefragResultBytes, - ParseResultBytes, and SplitResultBytes to urllib.parse.__all__. - Patch by Martin Panter. - -- Issue #23881: urllib.request.ftpwrapper constructor now closes the socket if - the FTP connection failed to fix a ResourceWarning. - -- Issue #23853: :meth:`socket.socket.sendall` does no more reset the socket - timeout each time data is sent successfully. The socket timeout is now the - maximum total duration to send all data. - -- Issue #22721: An order of multiline pprint output of set or dict containing - orderable and non-orderable elements no longer depends on iteration order of - set or dict. - -- Issue #15133: _tkinter.tkapp.getboolean() now supports Tcl_Obj and always - returns bool. tkinter.BooleanVar now validates input values (accepted bool, - int, str, and Tcl_Obj). tkinter.BooleanVar.get() now always returns bool. - -- Issue #10590: xml.sax.parseString() now supports string argument. - -- Issue #23338: Fixed formatting ctypes error messages on Cygwin. - Patch by Makoto Kato. - -- Issue #15582: inspect.getdoc() now follows inheritance chains. - -- Issue #2175: SAX parsers now support a character stream of InputSource object. - -- Issue #16840: Tkinter now supports 64-bit integers added in Tcl 8.4 and - arbitrary precision integers added in Tcl 8.5. - -- Issue #23834: Fix socket.sendto(), use the C Py_ssize_t type to store the - result of sendto() instead of the C int type. - -- Issue #23618: :meth:`socket.socket.connect` now waits until the connection - completes instead of raising :exc:`InterruptedError` if the connection is - interrupted by signals, signal handlers don't raise an exception and the - socket is blocking or has a timeout. :meth:`socket.socket.connect` still - raise :exc:`InterruptedError` for non-blocking sockets. - -- Issue #21526: Tkinter now supports new boolean type in Tcl 8.5. - -- Issue #23836: Fix the faulthandler module to handle reentrant calls to - its signal handlers. - -- Issue #23838: linecache now clears the cache and returns an empty result on - MemoryError. - -- Issue #10395: Added os.path.commonpath(). Implemented in posixpath and ntpath. - Based on patch by Rafik Draoui. - -- Issue #23611: Serializing more "lookupable" objects (such as unbound methods - or nested classes) now are supported with pickle protocols < 4. - -- Issue #13583: sqlite3.Row now supports slice indexing. - -- Issue #18473: Fixed 2to3 and 3to2 compatible pickle mappings. Fixed - ambigious reverse mappings. Added many new mappings. Import mapping is no - longer applied to modules already mapped with full name mapping. - -- Issue #23485: select.select() is now retried automatically with the - recomputed timeout when interrupted by a signal, except if the signal handler - raises an exception. This change is part of the PEP 475. - -- Issue #23752: When built from an existing file descriptor, io.FileIO() now - only calls fstat() once. Before fstat() was called twice, which was not - necessary. - -- Issue #23704: collections.deque() objects now support __add__, __mul__, and - __imul__(). - -- Issue #23171: csv.Writer.writerow() now supports arbitrary iterables. - -- Issue #23745: The new email header parser now handles duplicate MIME - parameter names without error, similar to how get_param behaves. - -- Issue #22117: Fix os.utime(), it now rounds the timestamp towards minus - infinity (-inf) instead of rounding towards zero. - -- Issue #23310: Fix MagicMock's initializer to work with __methods__, just - like configure_mock(). Patch by Kasia Jachim. - -Build ------ - -- Issue #23817: FreeBSD now uses "1.0" in the SOVERSION as other operating - systems, instead of just "1". - -- Issue #23501: Argument Clinic now generates code into separate files by default. - -Tests ------ - -- Issue #23799: Added test.support.start_threads() for running and - cleaning up multiple threads. - -- Issue #22390: test.regrtest now emits a warning if temporary files or - directories are left after running a test. - -Tools/Demos ------------ - -- Issue #18128: pygettext now uses standard +NNNN format in the - POT-Creation-Date header. - -- Issue #23935: Argument Clinic's understanding of format units - accepting bytes, bytearrays, and buffers is now consistent with - both the documentation and the implementation. - -- Issue #23944: Argument Clinic now wraps long impl prototypes at column 78. - -- Issue #20586: Argument Clinic now ensures that functions without docstrings - have signatures. - -- Issue #23492: Argument Clinic now generates argument parsing code with - PyArg_Parse instead of PyArg_ParseTuple if possible. - -- Issue #23500: Argument Clinic is now smarter about generating the "#ifndef" - (empty) definition of the methoddef macro: it's only generated once, even - if Argument Clinic processes the same symbol multiple times, and it's emitted - at the end of all processing rather than immediately after the first use. - -C API ------ - -- Issue #23998: PyImport_ReInitLock() now checks for lock allocation error - - -What's New in Python 3.5.0 alpha 3? -=================================== - -Release date: 2015-03-28 - -Core and Builtins ------------------ - -- Issue #23573: Increased performance of string search operations (str.find, - str.index, str.count, the in operator, str.split, str.partition) with - arguments of different kinds (UCS1, UCS2, UCS4). - -- Issue #23753: Python doesn't support anymore platforms without stat() or - fstat(), these functions are always required. - -- Issue #23681: The -b option now affects comparisons of bytes with int. - -- Issue #23632: Memoryviews now allow tuple indexing (including for - multi-dimensional memoryviews). - -- Issue #23192: Fixed generator lambdas. Patch by Bruno Cauet. - -- Issue #23629: Fix the default __sizeof__ implementation for variable-sized - objects. - -Library -------- - -- Issue #14260: The groupindex attribute of regular expression pattern object - now is non-modifiable mapping. - -- Issue #23792: Ignore KeyboardInterrupt when the pydoc pager is active. - This mimics the behavior of the standard unix pagers, and prevents - pipepager from shutting down while the pager itself is still running. - -- Issue #23775: pprint() of OrderedDict now outputs the same representation - as repr(). - -- Issue #23765: Removed IsBadStringPtr calls in ctypes - -- Issue #22364: Improved some re error messages using regex for hints. - -- Issue #23742: ntpath.expandvars() no longer loses unbalanced single quotes. - -- Issue #21717: The zipfile.ZipFile.open function now supports 'x' (exclusive - creation) mode. - -- Issue #21802: The reader in BufferedRWPair now is closed even when closing - writer failed in BufferedRWPair.close(). - -- Issue #23622: Unknown escapes in regular expressions that consist of ``'\'`` - and ASCII letter now raise a deprecation warning and will be forbidden in - Python 3.6. - -- Issue #23671: string.Template now allows specifying the "self" parameter as - a keyword argument. string.Formatter now allows specifying the "self" and - the "format_string" parameters as keyword arguments. - -- Issue #23502: The pprint module now supports mapping proxies. - -- Issue #17530: pprint now wraps long bytes objects and bytearrays. - -- Issue #22687: Fixed some corner cases in breaking words in tetxtwrap. - Got rid of quadratic complexity in breaking long words. - -- Issue #4727: The copy module now uses pickle protocol 4 (PEP 3154) and - supports copying of instances of classes whose __new__ method takes - keyword-only arguments. - -- Issue #23491: Added a zipapp module to support creating executable zip - file archives of Python code. Registered ".pyz" and ".pyzw" extensions - on Windows for these archives (PEP 441). - -- Issue #23657: Avoid explicit checks for str in zipapp, adding support - for pathlib.Path objects as arguments. - -- Issue #23688: Added support of arbitrary bytes-like objects and avoided - unnecessary copying of memoryview in gzip.GzipFile.write(). - Original patch by Wolfgang Maier. - -- Issue #23252: Added support for writing ZIP files to unseekable streams. - -- Issue #23647: Increase impalib's MAXLINE to accommodate modern mailbox sizes. - -- Issue #23539: If body is None, http.client.HTTPConnection.request now sets - Content-Length to 0 for PUT, POST, and PATCH headers to avoid 411 errors from - some web servers. - -- Issue #22351: The nntplib.NNTP constructor no longer leaves the connection - and socket open until the garbage collector cleans them up. Patch by - Martin Panter. - -- Issue #23704: collections.deque() objects now support methods for index(), - insert(), and copy(). This allows deques to be registered as a - MutableSequence and it improves their substitutability for lists. - -- Issue #23715: :func:`signal.sigwaitinfo` and :func:`signal.sigtimedwait` are - now retried when interrupted by a signal not in the *sigset* parameter, if - the signal handler does not raise an exception. signal.sigtimedwait() - recomputes the timeout with a monotonic clock when it is retried. - -- Issue #23001: Few functions in modules mmap, ossaudiodev, socket, ssl, and - codecs, that accepted only read-only bytes-like object now accept writable - bytes-like object too. - -- Issue #23646: If time.sleep() is interrupted by a signal, the sleep is now - retried with the recomputed delay, except if the signal handler raises an - exception (PEP 475). - -- Issue #23136: _strptime now uniformly handles all days in week 0, including - Dec 30 of previous year. Based on patch by Jim Carroll. - -- Issue #23700: Iterator of NamedTemporaryFile now keeps a reference to - NamedTemporaryFile instance. Patch by Bohuslav Kabrda. - -- Issue #22903: The fake test case created by unittest.loader when it fails - importing a test module is now picklable. - -- Issue #22181: On Linux, os.urandom() now uses the new getrandom() syscall if - available, syscall introduced in the Linux kernel 3.17. It is more reliable - and more secure, because it avoids the need of a file descriptor and waits - until the kernel has enough entropy. - -- Issue #2211: Updated the implementation of the http.cookies.Morsel class. - Setting attributes key, value and coded_value directly now is deprecated. - update() and setdefault() now transform and check keys. Comparing for - equality now takes into account attributes key, value and coded_value. - copy() now returns a Morsel, not a dict. repr() now contains all attributes. - Optimized checking keys and quoting values. Added new tests. - Original patch by Demian Brecht. - -- Issue #18983: Allow selection of output units in timeit. - Patch by Julian Gindi. - -- Issue #23631: Fix traceback.format_list when a traceback has been mutated. - -- Issue #23568: Add rdivmod support to MagicMock() objects. - Patch by H?kan L?vdahl. - -- Issue #2052: Add charset parameter to HtmlDiff.make_file(). - -- Issue #23668: Support os.truncate and os.ftruncate on Windows. - -- Issue #23138: Fixed parsing cookies with absent keys or values in cookiejar. - Patch by Demian Brecht. - -- Issue #23051: multiprocessing.Pool methods imap() and imap_unordered() now - handle exceptions raised by an iterator. Patch by Alon Diamant and Davin - Potts. - -- Issue #23581: Add matmul support to MagicMock. Patch by H?kan L?vdahl. - -- Issue #23566: enable(), register(), dump_traceback() and - dump_traceback_later() functions of faulthandler now accept file - descriptors. Patch by Wei Wu. - -- Issue #22928: Disabled HTTP header injections in http.client. - Original patch by Demian Brecht. - -- Issue #23615: Modules bz2, tarfile and tokenize now can be reloaded with - imp.reload(). Patch by Thomas Kluyver. - -- Issue #23605: os.walk() now calls os.scandir() instead of os.listdir(). - The usage of os.scandir() reduces the number of calls to os.stat(). - Initial patch written by Ben Hoyt. - -Build ------ - -- Issue #23585: make patchcheck will ensure the interpreter is built. - -Tests ------ - -- Issue #23583: Added tests for standard IO streams in IDLE. - -- Issue #22289: Prevent test_urllib2net failures due to ftp connection timeout. - -Tools/Demos ------------ - -- Issue #22826: The result of open() in Tools/freeze/bkfile.py is now better - compatible with regular files (in particular it now supports the context - management protocol). - - -What's New in Python 3.5 alpha 2? -================================= - -Release date: 2015-03-09 - -Core and Builtins ------------------ - -- Issue #23571: PyObject_Call() and PyCFunction_Call() now raise a SystemError - if a function returns a result and raises an exception. The SystemError is - chained to the previous exception. - -Library -------- - -- Issue #22524: New os.scandir() function, part of the PEP 471: "os.scandir() - function -- a better and faster directory iterator". Patch written by Ben - Hoyt. - -- Issue #23103: Reduced the memory consumption of IPv4Address and IPv6Address. - -- Issue #21793: BaseHTTPRequestHandler again logs response code as numeric, - not as stringified enum. Patch by Demian Brecht. - -- Issue #23476: In the ssl module, enable OpenSSL's X509_V_FLAG_TRUSTED_FIRST - flag on certificate stores when it is available. - -- Issue #23576: Avoid stalling in SSL reads when EOF has been reached in the - SSL layer but the underlying connection hasn't been closed. - -- Issue #23504: Added an __all__ to the types module. - -- Issue #23563: Optimized utility functions in urllib.parse. - -- Issue #7830: Flatten nested functools.partial. - -- Issue #20204: Added the __module__ attribute to _tkinter classes. - -- Issue #19980: Improved help() for non-recognized strings. help('') now - shows the help on str. help('help') now shows the help on help(). - Original patch by Mark Lawrence. - -- Issue #23521: Corrected pure python implementation of timedelta division. - - * Eliminated OverflowError from ``timedelta * float`` for some floats; - * Corrected rounding in timedlta true division. - -- Issue #21619: Popen objects no longer leave a zombie after exit in the with - statement if the pipe was broken. Patch by Martin Panter. - -- Issue #22936: Make it possible to show local variables in tracebacks for - both the traceback module and unittest. - -- Issue #15955: Add an option to limit the output size in bz2.decompress(). - Patch by Nikolaus Rath. - -- Issue #6639: Module-level turtle functions no longer raise TclError after - closing the window. - -- Issues #814253, #9179: Group references and conditional group references now - work in lookbehind assertions in regular expressions. - -- Issue #23215: Multibyte codecs with custom error handlers that ignores errors - consumed too much memory and raised SystemError or MemoryError. - Original patch by Aleksi Torhamo. - -- Issue #5700: io.FileIO() called flush() after closing the file. - flush() was not called in close() if closefd=False. - -- Issue #23374: Fixed pydoc failure with non-ASCII files when stdout encoding - differs from file system encoding (e.g. on Mac OS). - -- Issue #23481: Remove RC4 from the SSL module's default cipher list. - -- Issue #21548: Fix pydoc.synopsis() and pydoc.apropos() on modules with empty - docstrings. - -- Issue #22885: Fixed arbitrary code execution vulnerability in the dbm.dumb - module. Original patch by Claudiu Popa. - -- Issue #23239: ssl.match_hostname() now supports matching of IP addresses. - -- Issue #23146: Fix mishandling of absolute Windows paths with forward - slashes in pathlib. - -- Issue #23096: Pickle representation of floats with protocol 0 now is the same - for both Python and C implementations. - -- Issue #19105: pprint now more efficiently uses free space at the right. - -- Issue #14910: Add allow_abbrev parameter to argparse.ArgumentParser. Patch by - Jonathan Paugh, Steven Bethard, paul j3 and Daniel Eriksson. - -- Issue #21717: tarfile.open() now supports 'x' (exclusive creation) mode. - -- Issue #23344: marshal.dumps() is now 20-25% faster on average. - -- Issue #20416: marshal.dumps() with protocols 3 and 4 is now 40-50% faster on - average. - -- Issue #23421: Fixed compression in tarfile CLI. Patch by wdv4758h. - -- Issue #23367: Fix possible overflows in the unicodedata module. - -- Issue #23361: Fix possible overflow in Windows subprocess creation code. - -- logging.handlers.QueueListener now takes a respect_handler_level keyword - argument which, if set to True, will pass messages to handlers taking handler - levels into account. - -- Issue #19705: turtledemo now has a visual sorting algorithm demo. Original - patch from Jason Yeo. - -- Issue #23801: Fix issue where cgi.FieldStorage did not always ignore the - entire preamble to a multipart body. - -Build ------ - -- Issue #23445: pydebug builds now use "gcc -Og" where possible, to make - the resulting executable faster. - -- Issue #23686: Update OS X 10.5 installer build to use OpenSSL 1.0.2a. - -C API ------ - -- Issue #20204: Deprecation warning is now raised for builtin types without the - __module__ attribute. - -Windows -------- - -- Issue #23465: Implement PEP 486 - Make the Python Launcher aware of virtual - environments. Patch by Paul Moore. - -- Issue #23437: Make user scripts directory versioned on Windows. Patch by Paul - Moore. - - -What's New in Python 3.5 alpha 1? -================================= - -Release date: 2015-02-08 - -Core and Builtins ------------------ - -- Issue #23285: PEP 475 - EINTR handling. - -- Issue #22735: Fix many edge cases (including crashes) involving custom mro() - implementations. - -- Issue #22896: Avoid using PyObject_AsCharBuffer(), PyObject_AsReadBuffer() - and PyObject_AsWriteBuffer(). - -- Issue #21295: Revert some changes (issue #16795) to AST line numbers and - column offsets that constituted a regression. - -- Issue #22986: Allow changing an object's __class__ between a dynamic type and - static type in some cases. - -- Issue #15859: PyUnicode_EncodeFSDefault(), PyUnicode_EncodeMBCS() and - PyUnicode_EncodeCodePage() now raise an exception if the object is not a - Unicode object. For PyUnicode_EncodeFSDefault(), it was already the case on - platforms other than Windows. Patch written by Campbell Barton. - -- Issue #21408: The default __ne__() now returns NotImplemented if __eq__() - returned NotImplemented. Original patch by Martin Panter. - -- Issue #23321: Fixed a crash in str.decode() when error handler returned - replacment string longer than mailformed input data. - -- Issue #22286: The "backslashreplace" error handlers now works with - decoding and translating. - -- Issue #23253: Delay-load ShellExecute[AW] in os.startfile for reduced - startup overhead on Windows. - -- Issue #22038: pyatomic.h now uses stdatomic.h or GCC built-in functions for - atomic memory access if available. Patch written by Vitor de Lima and Gustavo - Temple. - -- Issue #20284: %-interpolation (aka printf) formatting added for bytes and - bytearray. - -- Issue #23048: Fix jumping out of an infinite while loop in the pdb. - -- Issue #20335: bytes constructor now raises TypeError when encoding or errors - is specified with non-string argument. Based on patch by Renaud Blanch. - -- Issue #22834: If the current working directory ends up being set to a - non-existent directory then import will no longer raise FileNotFoundError. - -- Issue #22869: Move the interpreter startup & shutdown code to a new - dedicated pylifecycle.c module - -- Issue #22847: Improve method cache efficiency. - -- Issue #22335: Fix crash when trying to enlarge a bytearray to 0x7fffffff - bytes on a 32-bit platform. - -- Issue #22653: Fix an assertion failure in debug mode when doing a reentrant - dict insertion in debug mode. - -- Issue #22643: Fix integer overflow in Unicode case operations (upper, lower, - title, swapcase, casefold). - -- Issue #17636: Circular imports involving relative imports are now - supported. - -- Issue #22604: Fix assertion error in debug mode when dividing a complex - number by (nan+0j). - -- Issue #21052: Do not raise ImportWarning when sys.path_hooks or sys.meta_path - are set to None. - -- Issue #16518: Use 'bytes-like object required' in error messages that - previously used the far more cryptic "'x' does not support the buffer - protocol. - -- Issue #22470: Fixed integer overflow issues in "backslashreplace", - "xmlcharrefreplace", and "surrogatepass" error handlers. - -- Issue #22540: speed up `PyObject_IsInstance` and `PyObject_IsSubclass` in the - common case that the second argument has metaclass `type`. - -- Issue #18711: Add a new `PyErr_FormatV` function, similar to `PyErr_Format` - but accepting a `va_list` argument. - -- Issue #22520: Fix overflow checking when generating the repr of a unicode - object. - -- Issue #22519: Fix overflow checking in PyBytes_Repr. - -- Issue #22518: Fix integer overflow issues in latin-1 encoding. - -- Issue #16324: _charset parameter of MIMEText now also accepts - email.charset.Charset instances. Initial patch by Claude Paroz. - -- Issue #1764286: Fix inspect.getsource() to support decorated functions. - Patch by Claudiu Popa. - -- Issue #18554: os.__all__ includes posix functions. - -- Issue #21391: Use os.path.abspath in the shutil module. - -- Issue #11471: avoid generating a JUMP_FORWARD instruction at the end of - an if-block if there is no else-clause. Original patch by Eugene Toder. - -- Issue #22215: Now ValueError is raised instead of TypeError when str or bytes - argument contains not permitted null character or byte. - -- Issue #22258: Fix the internal function set_inheritable() on Illumos. - This platform exposes the function ``ioctl(FIOCLEX)``, but calling it fails - with errno is ENOTTY: "Inappropriate ioctl for device". set_inheritable() - now falls back to the slower ``fcntl()`` (``F_GETFD`` and then ``F_SETFD``). - -- Issue #21389: Displaying the __qualname__ of the underlying function in the - repr of a bound method. - -- Issue #22206: Using pthread, PyThread_create_key() now sets errno to ENOMEM - and returns -1 (error) on integer overflow. - -- Issue #20184: Argument Clinic based signature introspection added for - 30 of the builtin functions. - -- Issue #22116: C functions and methods (of the 'builtin_function_or_method' - type) can now be weakref'ed. Patch by Wei Wu. - -- Issue #22077: Improve index error messages for bytearrays, bytes, lists, - and tuples by adding 'or slices'. Added ', not ' for bytearrays. - Original patch by Claudiu Popa. - -- Issue #20179: Apply Argument Clinic to bytes and bytearray. - Patch by Tal Einat. - -- Issue #22082: Clear interned strings in slotdefs. - -- Upgrade Unicode database to Unicode 7.0.0. - -- Issue #21897: Fix a crash with the f_locals attribute with closure - variables when frame.clear() has been called. - -- Issue #21205: Add a new ``__qualname__`` attribute to generator, the - qualified name, and use it in the representation of a generator - (``repr(gen)``). The default name of the generator (``__name__`` attribute) - is now get from the function instead of the code. Use ``gen.gi_code.co_name`` - to get the name of the code. - -- Issue #21669: With the aid of heuristics in SyntaxError.__init__, the - parser now attempts to generate more meaningful (or at least more search - engine friendly) error messages when "exec" and "print" are used as - statements. - -- Issue #21642: In the conditional if-else expression, allow an integer written - with no space between itself and the ``else`` keyword (e.g. ``True if 42else - False``) to be valid syntax. - -- Issue #21523: Fix over-pessimistic computation of the stack effect of - some opcodes in the compiler. This also fixes a quadratic compilation - time issue noticeable when compiling code with a large number of "and" - and "or" operators. - -- Issue #21418: Fix a crash in the builtin function super() when called without - argument and without current frame (ex: embedded Python). - -- Issue #21425: Fix flushing of standard streams in the interactive - interpreter. - -- Issue #21435: In rare cases, when running finalizers on objects in cyclic - trash a bad pointer dereference could occur due to a subtle flaw in - internal iteration logic. - -- Issue #21377: PyBytes_Concat() now tries to concatenate in-place when the - first argument has a reference count of 1. Patch by Nikolaus Rath. - -- Issue #20355: -W command line options now have higher priority than the - PYTHONWARNINGS environment variable. Patch by Arfrever. - -- Issue #21274: Define PATH_MAX for GNU/Hurd in Python/pythonrun.c. - -- Issue #20904: Support setting FPU precision on m68k. - -- Issue #21209: Fix sending tuples to custom generator objects with the yield - from syntax. - -- Issue #21193: pow(a, b, c) now raises ValueError rather than TypeError when b - is negative. Patch by Josh Rosenberg. - -- PEP 465 and Issue #21176: Add the '@' operator for matrix multiplication. - -- Issue #21134: Fix segfault when str is called on an uninitialized - UnicodeEncodeError, UnicodeDecodeError, or UnicodeTranslateError object. - -- Issue #19537: Fix PyUnicode_DATA() alignment under m68k. Patch by - Andreas Schwab. - -- Issue #20929: Add a type cast to avoid shifting a negative number. - -- Issue #20731: Properly position in source code files even if they - are opened in text mode. Patch by Serhiy Storchaka. - -- Issue #20637: Key-sharing now also works for instance dictionaries of - subclasses. Patch by Peter Ingebretson. - -- Issue #8297: Attributes missing from modules now include the module name - in the error text. Original patch by ysj.ray. - -- Issue #19995: %c, %o, %x, and %X now raise TypeError on non-integer input. - -- Issue #19655: The ASDL parser - used by the build process to generate code for - managing the Python AST in C - was rewritten. The new parser is self contained - and does not require to carry long the spark.py parser-generator library; - spark.py was removed from the source base. - -- Issue #12546: Allow ``\x00`` to be used as a fill character when using str, int, - float, and complex __format__ methods. - -- Issue #20480: Add ipaddress.reverse_pointer. Patch by Leon Weber. - -- Issue #13598: Modify string.Formatter to support auto-numbering of - replacement fields. It now matches the behavior of str.format() in - this regard. Patches by Phil Elson and Ramchandra Apte. - -- Issue #8931: Make alternate formatting ('#') for type 'c' raise an - exception. In versions prior to 3.5, '#' with 'c' had no effect. Now - specifying it is an error. Patch by Torsten Landschoff. - -- Issue #23165: Perform overflow checks before allocating memory in the - _Py_char2wchar function. - -Library -------- - -- Issue #23399: pyvenv creates relative symlinks where possible. - -- Issue #20289: cgi.FieldStorage() now supports the context management - protocol. - -- Issue #13128: Print response headers for CONNECT requests when debuglevel - > 0. Patch by Demian Brecht. - -- Issue #15381: Optimized io.BytesIO to make less allocations and copyings. - -- Issue #22818: Splitting on a pattern that could match an empty string now - raises a warning. Patterns that can only match empty strings are now - rejected. - -- Issue #23099: Closing io.BytesIO with exported buffer is rejected now to - prevent corrupting exported buffer. - -- Issue #23326: Removed __ne__ implementations. Since fixing default __ne__ - implementation in issue #21408 they are redundant. - -- Issue #23363: Fix possible overflow in itertools.permutations. - -- Issue #23364: Fix possible overflow in itertools.product. - -- Issue #23366: Fixed possible integer overflow in itertools.combinations. - -- Issue #23369: Fixed possible integer overflow in - _json.encode_basestring_ascii. - -- Issue #23353: Fix the exception handling of generators in - PyEval_EvalFrameEx(). At entry, save or swap the exception state even if - PyEval_EvalFrameEx() is called with throwflag=0. At exit, the exception state - is now always restored or swapped, not only if why is WHY_YIELD or - WHY_RETURN. Patch co-written with Antoine Pitrou. - -- Issue #14099: Restored support of writing ZIP files to tellable but - non-seekable streams. - -- Issue #14099: Writing to ZipFile and reading multiple ZipExtFiles is - threadsafe now. - -- Issue #19361: JSON decoder now raises JSONDecodeError instead of ValueError. - -- Issue #18518: timeit now rejects statements which can't be compiled outside - a function or a loop (e.g. "return" or "break"). - -- Issue #23094: Fixed readline with frames in Python implementation of pickle. - -- Issue #23268: Fixed bugs in the comparison of ipaddress classes. - -- Issue #21408: Removed incorrect implementations of __ne__() which didn't - returned NotImplemented if __eq__() returned NotImplemented. The default - __ne__() now works correctly. - -- Issue #19996: :class:`email.feedparser.FeedParser` now handles (malformed) - headers with no key rather than assuming the body has started. - -- Issue #20188: Support Application-Layer Protocol Negotiation (ALPN) in the ssl - module. - -- Issue #23133: Pickling of ipaddress objects now produces more compact and - portable representation. - -- Issue #23248: Update ssl error codes from latest OpenSSL git master. - -- Issue #23266: Much faster implementation of ipaddress.collapse_addresses() - when there are many non-consecutive addresses. - -- Issue #23098: 64-bit dev_t is now supported in the os module. - -- Issue #21817: When an exception is raised in a task submitted to a - ProcessPoolExecutor, the remote traceback is now displayed in the - parent process. Patch by Claudiu Popa. - -- Issue #15955: Add an option to limit output size when decompressing LZMA - data. Patch by Nikolaus Rath and Martin Panter. - -- Issue #23250: In the http.cookies module, capitalize "HttpOnly" and "Secure" - as they are written in the standard. - -- Issue #23063: In the disutils' check command, fix parsing of reST with code or - code-block directives. - -- Issue #23209, #23225: selectors.BaseSelector.get_key() now raises a - RuntimeError if the selector is closed. And selectors.BaseSelector.close() - now clears its internal reference to the selector mapping to break a - reference cycle. Initial patch written by Martin Richard. - -- Issue #17911: Provide a way to seed the linecache for a PEP-302 module - without actually loading the code. - -- Issue #17911: Provide a new object API for traceback, including the ability - to not lookup lines at all until the traceback is actually rendered, without - any trace of the original objects being kept alive. - -- Issue #19777: Provide a home() classmethod on Path objects. Contributed - by Victor Salgado and Mayank Tripathi. - -- Issue #23206: Make ``json.dumps(..., ensure_ascii=False)`` as fast as the - default case of ``ensure_ascii=True``. Patch by Naoki Inada. - -- Issue #23185: Add math.inf and math.nan constants. - -- Issue #23186: Add ssl.SSLObject.shared_ciphers() and - ssl.SSLSocket.shared_ciphers() to fetch the client's list ciphers sent at - handshake. - -- Issue #23143: Remove compatibility with OpenSSLs older than 0.9.8. - -- Issue #23132: Improve performance and introspection support of comparison - methods created by functool.total_ordering. - -- Issue #19776: Add an expanduser() method on Path objects. - -- Issue #23112: Fix SimpleHTTPServer to correctly carry the query string and - fragment when it redirects to add a trailing slash. - -- Issue #21793: Added http.HTTPStatus enums (i.e. HTTPStatus.OK, - HTTPStatus.NOT_FOUND). Patch by Demian Brecht. - -- Issue #23093: In the io, module allow more operations to work on detached - streams. - -- Issue #23111: In the ftplib, make ssl.PROTOCOL_SSLv23 the default protocol - version. - -- Issue #22585: On OpenBSD 5.6 and newer, os.urandom() now calls getentropy(), - instead of reading /dev/urandom, to get pseudo-random bytes. - -- Issue #19104: pprint now produces evaluable output for wrapped strings. - -- Issue #23071: Added missing names to codecs.__all__. Patch by Martin Panter. - -- Issue #22783: Pickling now uses the NEWOBJ opcode instead of the NEWOBJ_EX - opcode if possible. - -- Issue #15513: Added a __sizeof__ implementation for pickle classes. - -- Issue #19858: pickletools.optimize() now aware of the MEMOIZE opcode, can - produce more compact result and no longer produces invalid output if input - data contains MEMOIZE opcodes together with PUT or BINPUT opcodes. - -- Issue #22095: Fixed HTTPConnection.set_tunnel with default port. The port - value in the host header was set to "None". Patch by Demian Brecht. - -- Issue #23016: A warning no longer produces an AttributeError when the program - is run with pythonw.exe. - -- Issue #21775: shutil.copytree(): fix crash when copying to VFAT. An exception - handler assumed that OSError objects always have a 'winerror' attribute. - That is not the case, so the exception handler itself raised AttributeError - when run on Linux (and, presumably, any other non-Windows OS). - Patch by Greg Ward. - -- Issue #1218234: Fix inspect.getsource() to load updated source of - reloaded module. Initial patch by Berker Peksag. - -- Issue #21740: Support wrapped callables in doctest. Patch by Claudiu Popa. - -- Issue #23009: Make sure selectors.EpollSelecrtor.select() works when no - FD is registered. - -- Issue #22959: In the constructor of http.client.HTTPSConnection, prefer the - context's check_hostname attribute over the *check_hostname* parameter. - -- Issue #22696: Add function :func:`sys.is_finalizing` to know about - interpreter shutdown. - -- Issue #16043: Add a default limit for the amount of data xmlrpclib.gzip_decode - will return. This resolves CVE-2013-1753. - -- Issue #14099: ZipFile.open() no longer reopen the underlying file. Objects - returned by ZipFile.open() can now operate independently of the ZipFile even - if the ZipFile was created by passing in a file-like object as the first - argument to the constructor. - -- Issue #22966: Fix __pycache__ pyc file name clobber when pyc_compile is - asked to compile a source file containing multiple dots in the source file - name. - -- Issue #21971: Update turtledemo doc and add module to the index. - -- Issue #21032: Fixed socket leak if HTTPConnection.getresponse() fails. - Original patch by Martin Panter. - -- Issue #22407: Deprecated the use of re.LOCALE flag with str patterns or - re.ASCII. It was newer worked. - -- Issue #22902: The "ip" command is now used on Linux to determine MAC address - in uuid.getnode(). Pach by Bruno Cauet. - -- Issue #22960: Add a context argument to xmlrpclib.ServerProxy constructor. - -- Issue #22389: Add contextlib.redirect_stderr(). - -- Issue #21356: Make ssl.RAND_egd() optional to support LibreSSL. The - availability of the function is checked during the compilation. Patch written - by Bernard Spil. - -- Issue #22915: SAX parser now supports files opened with file descriptor or - bytes path. - -- Issue #22609: Constructors and update methods of mapping classes in the - collections module now accept the self keyword argument. - -- Issue #22940: Add readline.append_history_file. - -- Issue #19676: Added the "namereplace" error handler. - -- Issue #22788: Add *context* parameter to logging.handlers.HTTPHandler. - -- Issue #22921: Allow SSLContext to take the *hostname* parameter even if - OpenSSL doesn't support SNI. - -- Issue #22894: TestCase.subTest() would cause the test suite to be stopped - when in failfast mode, even in the absence of failures. - -- Issue #22796: HTTP cookie parsing is now stricter, in order to protect - against potential injection attacks. - -- Issue #22370: Windows detection in pathlib is now more robust. - -- Issue #22841: Reject coroutines in asyncio add_signal_handler(). - Patch by Ludovic.Gasc. - -- Issue #19494: Added urllib.request.HTTPBasicPriorAuthHandler. Patch by - Matej Cepl. - -- Issue #22578: Added attributes to the re.error class. - -- Issue #22849: Fix possible double free in the io.TextIOWrapper constructor. - -- Issue #12728: Different Unicode characters having the same uppercase but - different lowercase are now matched in case-insensitive regular expressions. - -- Issue #22821: Fixed fcntl() with integer argument on 64-bit big-endian - platforms. - -- Issue #21650: Add an `--sort-keys` option to json.tool CLI. - -- Issue #22824: Updated reprlib output format for sets to use set literals. - Patch contributed by Berker Peksag. - -- Issue #22824: Updated reprlib output format for arrays to display empty - arrays without an unnecessary empty list. Suggested by Serhiy Storchaka. - -- Issue #22406: Fixed the uu_codec codec incorrectly ported to 3.x. - Based on patch by Martin Panter. - -- Issue #17293: uuid.getnode() now determines MAC address on AIX using netstat. - Based on patch by Aivars Kalv?ns. - -- Issue #22769: Fixed ttk.Treeview.tag_has() when called without arguments. - -- Issue #22417: Verify certificates by default in httplib (PEP 476). - -- Issue #22775: Fixed unpickling of http.cookies.SimpleCookie with protocol 2 - and above. Patch by Tim Graham. - -- Issue #22776: Brought excluded code into the scope of a try block in - SysLogHandler.emit(). - -- Issue #22665: Add missing get_terminal_size and SameFileError to - shutil.__all__. - -- Issue #6623: Remove deprecated Netrc class in the ftplib module. Patch by - Matt Chaput. - -- Issue #17381: Fixed handling of case-insensitive ranges in regular - expressions. - -- Issue #22410: Module level functions in the re module now cache compiled - locale-dependent regular expressions taking into account the locale. - -- Issue #22759: Query methods on pathlib.Path() (exists(), is_dir(), etc.) - now return False when the underlying stat call raises NotADirectoryError. - -- Issue #8876: distutils now falls back to copying files when hard linking - doesn't work. This allows use with special filesystems such as VirtualBox - shared folders. - -- Issue #22217: Implemented reprs of classes in the zipfile module. - -- Issue #22457: Honour load_tests in the start_dir of discovery. - -- Issue #18216: gettext now raises an error when a .mo file has an - unsupported major version number. Patch by Aaron Hill. - -- Issue #13918: Provide a locale.delocalize() function which can remove - locale-specific number formatting from a string representing a number, - without then converting it to a specific type. Patch by C?dric Krier. - -- Issue #22676: Make the pickling of global objects which don't have a - __module__ attribute less slow. - -- Issue #18853: Fixed ResourceWarning in shlex.__nain__. - -- Issue #9351: Defaults set with set_defaults on an argparse subparser - are no longer ignored when also set on the parent parser. - -- Issue #7559: unittest test loading ImportErrors are reported as import errors - with their import exception rather than as attribute errors after the import - has already failed. - -- Issue #19746: Make it possible to examine the errors from unittest - discovery without executing the test suite. The new `errors` attribute - on TestLoader exposes these non-fatal errors encountered during discovery. - -- Issue #21991: Make email.headerregistry's header 'params' attributes - be read-only (MappingProxyType). Previously the dictionary was modifiable - but a new one was created on each access of the attribute. - -- Issue #22638: SSLv3 is now disabled throughout the standard library. - It can still be enabled by instantiating a SSLContext manually. - -- Issue #22641: In asyncio, the default SSL context for client connections - is now created using ssl.create_default_context(), for stronger security. - -- Issue #17401: Include closefd in io.FileIO repr. - -- Issue #21338: Add silent mode for compileall. quiet parameters of - compile_{dir, file, path} functions now have a multilevel value. Also, - -q option of the CLI now have a multilevel value. Patch by Thomas Kluyver. - -- Issue #20152: Convert the array and cmath modules to Argument Clinic. - -- Issue #18643: Add socket.socketpair() on Windows. - -- Issue #22435: Fix a file descriptor leak when socketserver bind fails. - -- Issue #13096: Fixed segfault in CTypes POINTER handling of large - values. - -- Issue #11694: Raise ConversionError in xdrlib as documented. Patch - by Filip Gruszczy?ski and Claudiu Popa. - -- Issue #19380: Optimized parsing of regular expressions. - -- Issue #1519638: Now unmatched groups are replaced with empty strings in re.sub() - and re.subn(). - -- Issue #18615: sndhdr.what/whathdr now return a namedtuple. - -- Issue #22462: Fix pyexpat's creation of a dummy frame to make it - appear in exception tracebacks. - -- Issue #21965: Add support for in-memory SSL to the ssl module. Patch - by Geert Jansen. - -- Issue #21173: Fix len() on a WeakKeyDictionary when .clear() was called - with an iterator alive. - -- Issue #11866: Eliminated race condition in the computation of names - for new threads. - -- Issue #21905: Avoid RuntimeError in pickle.whichmodule() when sys.modules - is mutated while iterating. Patch by Olivier Grisel. - -- Issue #11271: concurrent.futures.Executor.map() now takes a *chunksize* - argument to allow batching of tasks in child processes and improve - performance of ProcessPoolExecutor. Patch by Dan O'Reilly. - -- Issue #21883: os.path.join() and os.path.relpath() now raise a TypeError with - more helpful error message for unsupported or mismatched types of arguments. - -- Issue #22219: The zipfile module CLI now adds entries for directories - (including empty directories) in ZIP file. - -- Issue #22449: In the ssl.SSLContext.load_default_certs, consult the - environmental variables SSL_CERT_DIR and SSL_CERT_FILE on Windows. - -- Issue #22508: The email.__version__ variable has been removed; the email - code is no longer shipped separately from the stdlib, and __version__ - hasn't been updated in several releases. - -- Issue #20076: Added non derived UTF-8 aliases to locale aliases table. - -- Issue #20079: Added locales supported in glibc 2.18 to locale alias table. - -- Issue #20218: Added convenience methods read_text/write_text and read_bytes/ - write_bytes to pathlib.Path objects. - -- Issue #22396: On 32-bit AIX platform, don't expose os.posix_fadvise() nor - os.posix_fallocate() because their prototypes in system headers are wrong. - -- Issue #22517: When an io.BufferedRWPair object is deallocated, clear its - weakrefs. - -- Issue #22437: Number of capturing groups in regular expression is no longer - limited by 100. - -- Issue #17442: InteractiveInterpreter now displays the full chained traceback - in its showtraceback method, to match the built in interactive interpreter. - -- Issue #23392: Added tests for marshal C API that works with FILE*. - - -- Issue #10510: distutils register and upload methods now use HTML standards - compliant CRLF line endings. - -- Issue #9850: Fixed macpath.join() for empty first component. Patch by - Oleg Oshmyan. - -- Issue #5309: distutils' build and build_ext commands now accept a ``-j`` - option to enable parallel building of extension modules. - -- Issue #22448: Improve canceled timer handles cleanup to prevent - unbound memory usage. Patch by Joshua Moore-Oliva. - -- Issue #22427: TemporaryDirectory no longer attempts to clean up twice when - used in the with statement in generator. - -- Issue #22362: Forbidden ambiguous octal escapes out of range 0-0o377 in - regular expressions. - -- Issue #20912: Now directories added to ZIP file have correct Unix and MS-DOS - directory attributes. - -- Issue #21866: ZipFile.close() no longer writes ZIP64 central directory - records if allowZip64 is false. - -- Issue #22278: Fix urljoin problem with relative urls, a regression observed - after changes to issue22118 were submitted. - -- Issue #22415: Fixed debugging output of the GROUPREF_EXISTS opcode in the re - module. Removed trailing spaces in debugging output. - -- Issue #22423: Unhandled exception in thread no longer causes unhandled - AttributeError when sys.stderr is None. - -- Issue #21332: Ensure that ``bufsize=1`` in subprocess.Popen() selects - line buffering, rather than block buffering. Patch by Akira Li. - -- Issue #21091: Fix API bug: email.message.EmailMessage.is_attachment is now - a method. - -- Issue #21079: Fix email.message.EmailMessage.is_attachment to return the - correct result when the header has parameters as well as a value. - -- Issue #22247: Add NNTPError to nntplib.__all__. - -- Issue #22366: urllib.request.urlopen will accept a context object - (SSLContext) as an argument which will then be used for HTTPS connection. - Patch by Alex Gaynor. - -- Issue #4180: The warnings registries are now reset when the filters - are modified. - -- Issue #22419: Limit the length of incoming HTTP request in wsgiref server to - 65536 bytes and send a 414 error code for higher lengths. Patch contributed - by Devin Cook. - -- Lax cookie parsing in http.cookies could be a security issue when combined - with non-standard cookie handling in some Web browsers. Reported by - Sergey Bobrov. - -- Issue #20537: logging methods now accept an exception instance as well as a - Boolean value or exception tuple. Thanks to Yury Selivanov for the patch. - -- Issue #22384: An exception in Tkinter callback no longer crashes the program - when it is run with pythonw.exe. - -- Issue #22168: Prevent turtle AttributeError with non-default Canvas on OS X. - -- Issue #21147: sqlite3 now raises an exception if the request contains a null - character instead of truncating it. Based on patch by Victor Stinner. - -- Issue #13968: The glob module now supports recursive search in - subdirectories using the ``**`` pattern. - -- Issue #21951: Fixed a crash in Tkinter on AIX when called Tcl command with - empty string or tuple argument. - -- Issue #21951: Tkinter now most likely raises MemoryError instead of crash - if the memory allocation fails. - -- Issue #22338: Fix a crash in the json module on memory allocation failure. - -- Issue #12410: imaplib.IMAP4 now supports the context management protocol. - Original patch by Tarek Ziad?. - -- Issue #21270: We now override tuple methods in mock.call objects so that - they can be used as normal call attributes. - -- Issue #16662: load_tests() is now unconditionally run when it is present in - a package's __init__.py. TestLoader.loadTestsFromModule() still accepts - use_load_tests, but it is deprecated and ignored. A new keyword-only - attribute `pattern` is added and documented. Patch given by Robert Collins, - tweaked by Barry Warsaw. - -- Issue #22226: First letter no longer is stripped from the "status" key in - the result of Treeview.heading(). - -- Issue #19524: Fixed resource leak in the HTTP connection when an invalid - response is received. Patch by Martin Panter. - -- Issue #20421: Add a .version() method to SSL sockets exposing the actual - protocol version in use. - -- Issue #19546: configparser exceptions no longer expose implementation details. - Chained KeyErrors are removed, which leads to cleaner tracebacks. Patch by - Claudiu Popa. - -- Issue #22051: turtledemo no longer reloads examples to re-run them. - Initialization of variables and gui setup should be done in main(), - which is called each time a demo is run, but not on import. - -- Issue #21933: Turtledemo users can change the code font size with a menu - selection or control(command) '-' or '+' or control-mousewheel. - Original patch by Lita Cho. - -- Issue #21597: The separator between the turtledemo text pane and the drawing - canvas can now be grabbed and dragged with a mouse. The code text pane can - be widened to easily view or copy the full width of the text. The canvas - can be widened on small screens. Original patches by Jan Kanis and Lita Cho. - -- Issue #18132: Turtledemo buttons no longer disappear when the window is - shrunk. Original patches by Jan Kanis and Lita Cho. - -- Issue #22043: time.monotonic() is now always available. - ``threading.Lock.acquire()``, ``threading.RLock.acquire()`` and socket - operations now use a monotonic clock, instead of the system clock, when a - timeout is used. - -- Issue #21527: Add a default number of workers to ThreadPoolExecutor equal - to 5 times the number of CPUs. Patch by Claudiu Popa. - -- Issue #22216: smtplib now resets its state more completely after a quit. The - most obvious consequence of the previous behavior was a STARTTLS failure - during a connect/starttls/quit/connect/starttls sequence. - -- Issue #22098: ctypes' BigEndianStructure and LittleEndianStructure now - define an empty __slots__ so that subclasses don't always get an instance - dict. Patch by Claudiu Popa. - -- Issue #22185: Fix an occasional RuntimeError in threading.Condition.wait() - caused by mutation of the waiters queue without holding the lock. Patch - by Doug Zongker. - -- Issue #22287: On UNIX, _PyTime_gettimeofday() now uses - clock_gettime(CLOCK_REALTIME) if available. As a side effect, Python now - depends on the librt library on Solaris and on Linux (only with glibc older - than 2.17). - -- Issue #22182: Use e.args to unpack exceptions correctly in - distutils.file_util.move_file. Patch by Claudiu Popa. - -- The webbrowser module now uses subprocess's start_new_session=True rather - than a potentially risky preexec_fn=os.setsid call. - -- Issue #22042: signal.set_wakeup_fd(fd) now raises an exception if the file - descriptor is in blocking mode. - -- Issue #16808: inspect.stack() now returns a named tuple instead of a tuple. - Patch by Daniel Shahaf. - -- Issue #22236: Fixed Tkinter images copying operations in NoDefaultRoot mode. - -- Issue #2527: Add a *globals* argument to timeit functions, in order to - override the globals namespace in which the timed code is executed. - Patch by Ben Roberts. - -- Issue #22118: Switch urllib.parse to use RFC 3986 semantics for the - resolution of relative URLs, rather than RFCs 1808 and 2396. - Patch by Demian Brecht. - -- Issue #21549: Added the "members" parameter to TarFile.list(). - -- Issue #19628: Allow compileall recursion depth to be specified with a -r - option. - -- Issue #15696: Add a __sizeof__ implementation for mmap objects on Windows. - -- Issue #22068: Avoided reference loops with Variables and Fonts in Tkinter. - -- Issue #22165: SimpleHTTPRequestHandler now supports undecodable file names. - -- Issue #15381: Optimized line reading in io.BytesIO. - -- Issue #8797: Raise HTTPError on failed Basic Authentication immediately. - Initial patch by Sam Bull. - -- Issue #20729: Restored the use of lazy iterkeys()/itervalues()/iteritems() - in the mailbox module. - -- Issue #21448: Changed FeedParser feed() to avoid O(N**2) behavior when - parsing long line. Original patch by Raymond Hettinger. - -- Issue #22184: The functools LRU Cache decorator factory now gives an earlier - and clearer error message when the user forgets the required parameters. - -- Issue #17923: glob() patterns ending with a slash no longer match non-dirs on - AIX. Based on patch by Delhallt. - -- Issue #21725: Added support for RFC 6531 (SMTPUTF8) in smtpd. - -- Issue #22176: Update the ctypes module's libffi to v3.1. This release - adds support for the Linux AArch64 and POWERPC ELF ABIv2 little endian - architectures. - -- Issue #5411: Added support for the "xztar" format in the shutil module. - -- Issue #21121: Don't force 3rd party C extensions to be built with - -Werror=declaration-after-statement. - -- Issue #21975: Fixed crash when using uninitialized sqlite3.Row (in particular - when unpickling pickled sqlite3.Row). sqlite3.Row is now initialized in the - __new__() method. - -- Issue #20170: Convert posixmodule to use Argument Clinic. - -- Issue #21539: Add an *exists_ok* argument to `Pathlib.mkdir()` to mimic - `mkdir -p` and `os.makedirs()` functionality. When true, ignore - FileExistsErrors. Patch by Berker Peksag. - -- Issue #22127: Bypass IDNA for pure-ASCII host names in the socket module - (in particular for numeric IPs). - -- Issue #21047: set the default value for the *convert_charrefs* argument - of HTMLParser to True. Patch by Berker Peksag. - -- Add an __all__ to html.entities. - -- Issue #15114: the strict mode and argument of HTMLParser, HTMLParser.error, - and the HTMLParserError exception have been removed. - -- Issue #22085: Dropped support of Tk 8.3 in Tkinter. - -- Issue #21580: Now Tkinter correctly handles bytes arguments passed to Tk. - In particular this allows initializing images from binary data. - -- Issue #22003: When initialized from a bytes object, io.BytesIO() now - defers making a copy until it is mutated, improving performance and - memory use on some use cases. Patch by David Wilson. - -- Issue #22018: On Windows, signal.set_wakeup_fd() now also supports sockets. - A side effect is that Python depends to the WinSock library. - -- Issue #22054: Add os.get_blocking() and os.set_blocking() functions to get - and set the blocking mode of a file descriptor (False if the O_NONBLOCK flag - is set, True otherwise). These functions are not available on Windows. - -- Issue #17172: Make turtledemo start as active on OS X even when run with - subprocess. Patch by Lita Cho. - -- Issue #21704: Fix build error for _multiprocessing when semaphores - are not available. Patch by Arfrever Frehtes Taifersar Arahesis. - -- Issue #20173: Convert sha1, sha256, sha512 and md5 to ArgumentClinic. - Patch by Vajrasky Kok. - -- Fix repr(_socket.socket) on Windows 64-bit: don't fail with OverflowError - on closed socket. repr(socket.socket) already works fine. - -- Issue #22033: Reprs of most Python implemened classes now contain actual - class name instead of hardcoded one. - -- Issue #21947: The dis module can now disassemble generator-iterator - objects based on their gi_code attribute. Patch by Clement Rouault. - -- Issue #16133: The asynchat.async_chat.handle_read() method now ignores - BlockingIOError exceptions. - -- Issue #22044: Fixed premature DECREF in call_tzinfo_method. - Patch by Tom Flanagan. - -- Issue #19884: readline: Disable the meta modifier key if stdout is not - a terminal to not write the ANSI sequence ``"\033[1034h"`` into stdout. This - sequence is used on some terminal (ex: TERM=xterm-256color") to enable - support of 8 bit characters. - -- Issue #4350: Removed a number of out-of-dated and non-working for a long time - Tkinter methods. - -- Issue #6167: Scrollbar.activate() now returns the name of active element if - the argument is not specified. Scrollbar.set() now always accepts only 2 - arguments. - -- Issue #15275: Clean up and speed up the ntpath module. - -- Issue #21888: plistlib's load() and loads() now work if the fmt parameter is - specified. - -- Issue #22032: __qualname__ instead of __name__ is now always used to format - fully qualified class names of Python implemented classes. - -- Issue #22031: Reprs now always use hexadecimal format with the "0x" prefix - when contain an id in form " at 0x...". - -- Issue #22018: signal.set_wakeup_fd() now raises an OSError instead of a - ValueError on ``fstat()`` failure. - -- Issue #21044: tarfile.open() now handles fileobj with an integer 'name' - attribute. Based on patch by Antoine Pietri. - -- Issue #21966: Respect -q command-line option when code module is ran. - -- Issue #19076: Don't pass the redundant 'file' argument to self.error(). - -- Issue #16382: Improve exception message of warnings.warn() for bad - category. Initial patch by Phil Elson. - -- Issue #21932: os.read() now uses a :c:func:`Py_ssize_t` type instead of - :c:type:`int` for the size to support reading more than 2 GB at once. On - Windows, the size is truncted to INT_MAX. As any call to os.read(), the OS - may read less bytes than the number of requested bytes. - -- Issue #21942: Fixed source file viewing in pydoc's server mode on Windows. - -- Issue #11259: asynchat.async_chat().set_terminator() now raises a ValueError - if the number of received bytes is negative. - -- Issue #12523: asynchat.async_chat.push() now raises a TypeError if it doesn't - get a bytes string - -- Issue #21707: Add missing kwonlyargcount argument to - ModuleFinder.replace_paths_in_code(). - -- Issue #20639: calling Path.with_suffix('') allows removing the suffix - again. Patch by July Tikhonov. - -- Issue #21714: Disallow the construction of invalid paths using - Path.with_name(). Original patch by Antony Lee. - -- Issue #15014: Added 'auth' method to smtplib to make implementing auth - mechanisms simpler, and used it internally in the login method. - -- Issue #21151: Fixed a segfault in the winreg module when ``None`` is passed - as a ``REG_BINARY`` value to SetValueEx. Patch by John Ehresman. - -- Issue #21090: io.FileIO.readall() does not ignore I/O errors anymore. Before, - it ignored I/O errors if at least the first C call read() succeed. - -- Issue #5800: headers parameter of wsgiref.headers.Headers is now optional. - Initial patch by Pablo Torres Navarrete and SilentGhost. - -- Issue #21781: ssl.RAND_add() now supports strings longer than 2 GB. - -- Issue #21679: Prevent extraneous fstat() calls during open(). Patch by - Bohuslav Kabrda. - -- Issue #21863: cProfile now displays the module name of C extension functions, - in addition to their own name. - -- Issue #11453: asyncore: emit a ResourceWarning when an unclosed file_wrapper - object is destroyed. The destructor now closes the file if needed. The - close() method can now be called twice: the second call does nothing. - -- Issue #21858: Better handling of Python exceptions in the sqlite3 module. - -- Issue #21476: Make sure the email.parser.BytesParser TextIOWrapper is - discarded after parsing, so the input file isn't unexpectedly closed. - -- Issue #20295: imghdr now recognizes OpenEXR format images. - -- Issue #21729: Used the "with" statement in the dbm.dumb module to ensure - files closing. Patch by Claudiu Popa. - -- Issue #21491: socketserver: Fix a race condition in child processes reaping. - -- Issue #21719: Added the ``st_file_attributes`` field to os.stat_result on - Windows. - -- Issue #21832: Require named tuple inputs to be exact strings. - -- Issue #21722: The distutils "upload" command now exits with a non-zero - return code when uploading fails. Patch by Martin Dengler. - -- Issue #21723: asyncio.Queue: support any type of number (ex: float) for the - maximum size. Patch written by Vajrasky Kok. - -- Issue #21711: support for "site-python" directories has now been removed - from the site module (it was deprecated in 3.4). - -- Issue #17552: new socket.sendfile() method allowing a file to be sent over a - socket by using high-performance os.sendfile() on UNIX. - Patch by Giampaolo Rodola'. - -- Issue #18039: dbm.dump.open() now always creates a new database when the - flag has the value 'n'. Patch by Claudiu Popa. - -- Issue #21326: Add a new is_closed() method to asyncio.BaseEventLoop. - run_forever() and run_until_complete() methods of asyncio.BaseEventLoop now - raise an exception if the event loop was closed. - -- Issue #21766: Prevent a security hole in CGIHTTPServer by URL unquoting paths - before checking for a CGI script at that path. - -- Issue #21310: Fixed possible resource leak in failed open(). - -- Issue #21256: Printout of keyword args should be in deterministic order in - a mock function call. This will help to write better doctests. - -- Issue #21677: Fixed chaining nonnormalized exceptions in io close() methods. - -- Issue #11709: Fix the pydoc.help function to not fail when sys.stdin is not a - valid file. - -- Issue #21515: tempfile.TemporaryFile now uses os.O_TMPFILE flag is available. - -- Issue #13223: Fix pydoc.writedoc so that the HTML documentation for methods - that use 'self' in the example code is generated correctly. - -- Issue #21463: In urllib.request, fix pruning of the FTP cache. - -- Issue #21618: The subprocess module could fail to close open fds that were - inherited by the calling process and already higher than POSIX resource - limits would otherwise allow. On systems with a functioning /proc/self/fd - or /dev/fd interface the max is now ignored and all fds are closed. - -- Issue #20383: Introduce importlib.util.module_from_spec() as the preferred way - to create a new module. - -- Issue #21552: Fixed possible integer overflow of too long string lengths in - the tkinter module on 64-bit platforms. - -- Issue #14315: The zipfile module now ignores extra fields in the central - directory that are too short to be parsed instead of letting a struct.unpack - error bubble up as this "bad data" appears in many real world zip files in - the wild and is ignored by other zip tools. - -- Issue #13742: Added "key" and "reverse" parameters to heapq.merge(). - (First draft of patch contributed by Simon Sapin.) - -- Issue #21402: tkinter.ttk now works when default root window is not set. - -- Issue #3015: _tkinter.create() now creates tkapp object with wantobject=1 by - default. - -- Issue #10203: sqlite3.Row now truly supports sequence protocol. In particular - it supports reverse() and negative indices. Original patch by Claudiu Popa. - -- Issue #18807: If copying (no symlinks) specified for a venv, then the python - interpreter aliases (python, python3) are now created by copying rather than - symlinking. - -- Issue #20197: Added support for the WebP image type in the imghdr module. - Patch by Fabrice Aneche and Claudiu Popa. - -- Issue #21513: Speedup some properties of IP addresses (IPv4Address, - IPv6Address) such as .is_private or .is_multicast. - -- Issue #21137: Improve the repr for threading.Lock() and its variants - by showing the "locked" or "unlocked" status. Patch by Berker Peksag. - -- Issue #21538: The plistlib module now supports loading of binary plist files - when reference or offset size is not a power of two. - -- Issue #21455: Add a default backlog to socket.listen(). - -- Issue #21525: Most Tkinter methods which accepted tuples now accept lists too. - -- Issue #22166: With the assistance of a new internal _codecs._forget_codec - helping function, test_codecs now clears the encoding caches to avoid the - appearance of a reference leak - -- Issue #22236: Tkinter tests now don't reuse default root window. New root - window is created for every test class. - -- Issue #10744: Fix PEP 3118 format strings on ctypes objects with a nontrivial - shape. - -- Issue #20826: Optimize ipaddress.collapse_addresses(). - -- Issue #21487: Optimize ipaddress.summarize_address_range() and - ipaddress.{IPv4Network,IPv6Network}.subnets(). - -- Issue #21486: Optimize parsing of netmasks in ipaddress.IPv4Network and - ipaddress.IPv6Network. - -- Issue #13916: Disallowed the surrogatepass error handler for non UTF-\* - encodings. - -- Issue #20998: Fixed re.fullmatch() of repeated single character pattern - with ignore case. Original patch by Matthew Barnett. - -- Issue #21075: fileinput.FileInput now reads bytes from standard stream if - binary mode is specified. Patch by Sam Kimbrel. - -- Issue #19775: Add a samefile() method to pathlib Path objects. Initial - patch by Vajrasky Kok. - -- Issue #21226: Set up modules properly in PyImport_ExecCodeModuleObject - (and friends). - -- Issue #21398: Fix a unicode error in the pydoc pager when the documentation - contains characters not encodable to the stdout encoding. - -- Issue #16531: ipaddress.IPv4Network and ipaddress.IPv6Network now accept - an (address, netmask) tuple argument, so as to easily construct network - objects from existing addresses. - -- Issue #21156: importlib.abc.InspectLoader.source_to_code() is now a - staticmethod. - -- Issue #21424: Simplified and optimized heaqp.nlargest() and nmsmallest() - to make fewer tuple comparisons. - -- Issue #21396: Fix TextIOWrapper(..., write_through=True) to not force a - flush() on the underlying binary stream. Patch by akira. - -- Issue #18314: Unlink now removes junctions on Windows. Patch by Kim Gr?sman - -- Issue #21088: Bugfix for curses.window.addch() regression in 3.4.0. - In porting to Argument Clinic, the first two arguments were reversed. - -- Issue #21407: _decimal: The module now supports function signatures. - -- Issue #10650: Remove the non-standard 'watchexp' parameter from the - Decimal.quantize() method in the Python version. It had never been - present in the C version. - -- Issue #21469: Reduced the risk of false positives in robotparser by - checking to make sure that robots.txt has been read or does not exist - prior to returning True in can_fetch(). - -- Issue #19414: Have the OrderedDict mark deleted links as unusable. - This gives an early failure if the link is deleted during iteration. - -- Issue #21421: Add __slots__ to the MappingViews ABC. - Patch by Josh Rosenberg. - -- Issue #21101: Eliminate double hashing in the C speed-up code for - collections.Counter(). - -- Issue #21321: itertools.islice() now releases the reference to the source - iterator when the slice is exhausted. Patch by Anton Afanasyev. - -- Issue #21057: TextIOWrapper now allows the underlying binary stream's - read() or read1() method to return an arbitrary bytes-like object - (such as a memoryview). Patch by Nikolaus Rath. - -- Issue #20951: SSLSocket.send() now raises either SSLWantReadError or - SSLWantWriteError on a non-blocking socket if the operation would block. - Previously, it would return 0. Patch by Nikolaus Rath. - -- Issue #13248: removed previously deprecated asyncore.dispatcher __getattr__ - cheap inheritance hack. - -- Issue #9815: assertRaises now tries to clear references to local variables - in the exception's traceback. - -- Issue #19940: ssl.cert_time_to_seconds() now interprets the given time - string in the UTC timezone (as specified in RFC 5280), not the local - timezone. - -- Issue #13204: Calling sys.flags.__new__ would crash the interpreter, - now it raises a TypeError. - -- Issue #19385: Make operations on a closed dbm.dumb database always raise the - same exception. - -- Issue #21207: Detect when the os.urandom cached fd has been closed or - replaced, and open it anew. - -- Issue #21291: subprocess's Popen.wait() is now thread safe so that - multiple threads may be calling wait() or poll() on a Popen instance - at the same time without losing the Popen.returncode value. - -- Issue #21127: Path objects can now be instantiated from str subclass - instances (such as ``numpy.str_``). - -- Issue #15002: urllib.response object to use _TemporaryFileWrapper (and - _TemporaryFileCloser) facility. Provides a better way to handle file - descriptor close. Patch contributed by Christian Theune. - -- Issue #12220: mindom now raises a custom ValueError indicating it doesn't - support spaces in URIs instead of letting a 'split' ValueError bubble up. - -- Issue #21068: The ssl.PROTOCOL* constants are now enum members. - -- Issue #21276: posixmodule: Don't define USE_XATTRS on KFreeBSD and the Hurd. - -- Issue #21262: New method assert_not_called for Mock. - It raises AssertionError if the mock has been called. - -- Issue #21238: New keyword argument `unsafe` to Mock. It raises - `AttributeError` incase of an attribute startswith assert or assret. - -- Issue #20896: ssl.get_server_certificate() now uses PROTOCOL_SSLv23, not - PROTOCOL_SSLv3, for maximum compatibility. - -- Issue #21239: patch.stopall() didn't work deterministically when the same - name was patched more than once. - -- Issue #21203: Updated fileConfig and dictConfig to remove inconsistencies. - Thanks to Jure Koren for the patch. - -- Issue #21222: Passing name keyword argument to mock.create_autospec now - works. - -- Issue #21197: Add lib64 -> lib symlink in venvs on 64-bit non-OS X POSIX. - -- Issue #17498: Some SMTP servers disconnect after certain errors, violating - strict RFC conformance. Instead of losing the error code when we issue the - subsequent RSET, smtplib now returns the error code and defers raising the - SMTPServerDisconnected error until the next command is issued. - -- Issue #17826: setting an iterable side_effect on a mock function created by - create_autospec now works. Patch by Kushal Das. - -- Issue #7776: Fix ``Host:`` header and reconnection when using - http.client.HTTPConnection.set_tunnel(). Patch by Nikolaus Rath. - -- Issue #20968: unittest.mock.MagicMock now supports division. - Patch by Johannes Baiter. - -- Issue #21529 (CVE-2014-4616): Fix arbitrary memory access in - JSONDecoder.raw_decode with a negative second parameter. Bug reported by Guido - Vranken. - -- Issue #21169: getpass now handles non-ascii characters that the - input stream encoding cannot encode by re-encoding using the - replace error handler. - -- Issue #21171: Fixed undocumented filter API of the rot13 codec. - Patch by Berker Peksag. - -- Issue #20539: Improved math.factorial error message for large positive inputs - and changed exception type (OverflowError -> ValueError) for large negative - inputs. - -- Issue #21172: isinstance check relaxed from dict to collections.Mapping. - -- Issue #21155: asyncio.EventLoop.create_unix_server() now raises a ValueError - if path and sock are specified at the same time. - -- Issue #21136: Avoid unnecessary normalization of Fractions resulting from - power and other operations. Patch by Raymond Hettinger. - -- Issue #17621: Introduce importlib.util.LazyLoader. - -- Issue #21076: signal module constants were turned into enums. - Patch by Giampaolo Rodola'. - -- Issue #20636: Improved the repr of Tkinter widgets. - -- Issue #19505: The items, keys, and values views of OrderedDict now support - reverse iteration using reversed(). - -- Issue #21149: Improved thread-safety in logging cleanup during interpreter - shutdown. Thanks to Devin Jeanpierre for the patch. - -- Issue #21058: Fix a leak of file descriptor in - :func:`tempfile.NamedTemporaryFile`, close the file descriptor if - :func:`io.open` fails - -- Issue #21200: Return None from pkgutil.get_loader() when __spec__ is missing. - -- Issue #21013: Enhance ssl.create_default_context() when used for server side - sockets to provide better security by default. - -- Issue #20145: `assertRaisesRegex` and `assertWarnsRegex` now raise a - TypeError if the second argument is not a string or compiled regex. - -- Issue #20633: Replace relative import by absolute import. - -- Issue #20980: Stop wrapping exception when using ThreadPool. - -- Issue #21082: In os.makedirs, do not set the process-wide umask. Note this - changes behavior of makedirs when exist_ok=True. - -- Issue #20990: Fix issues found by pyflakes for multiprocessing. - -- Issue #21015: SSL contexts will now automatically select an elliptic - curve for ECDH key exchange on OpenSSL 1.0.2 and later, and otherwise - default to "prime256v1". - -- Issue #21000: Improve the command-line interface of json.tool. - -- Issue #20995: Enhance default ciphers used by the ssl module to enable - better security and prioritize perfect forward secrecy. - -- Issue #20884: Don't assume that __file__ is defined on importlib.__init__. - -- Issue #21499: Ignore __builtins__ in several test_importlib.test_api tests. - -- Issue #20627: xmlrpc.client.ServerProxy is now a context manager. - -- Issue #19165: The formatter module now raises DeprecationWarning instead of - PendingDeprecationWarning. - -- Issue #13936: Remove the ability of datetime.time instances to be considered - false in boolean contexts. - -- Issue #18931: selectors module now supports /dev/poll on Solaris. - Patch by Giampaolo Rodola'. - -- Issue #19977: When the ``LC_TYPE`` locale is the POSIX locale (``C`` locale), - :py:data:`sys.stdin` and :py:data:`sys.stdout` are now using the - ``surrogateescape`` error handler, instead of the ``strict`` error handler. - -- Issue #20574: Implement incremental decoder for cp65001 code (Windows code - page 65001, Microsoft UTF-8). - -- Issue #20879: Delay the initialization of encoding and decoding tables for - base32, ascii85 and base85 codecs in the base64 module, and delay the - initialization of the unquote_to_bytes() table of the urllib.parse module, to - not waste memory if these modules are not used. - -- Issue #19157: Include the broadcast address in the usuable hosts for IPv6 - in ipaddress. - -- Issue #11599: When an external command (e.g. compiler) fails, distutils now - prints out the whole command line (instead of just the command name) if the - environment variable DISTUTILS_DEBUG is set. - -- Issue #4931: distutils should not produce unhelpful "error: None" messages - anymore. distutils.util.grok_environment_error is kept but doc-deprecated. - -- Issue #20875: Prevent possible gzip "'read' is not defined" NameError. - Patch by Claudiu Popa. - -- Issue #11558: ``email.message.Message.attach`` now returns a more - useful error message if ``attach`` is called on a message for which - ``is_multipart`` is False. - -- Issue #20283: RE pattern methods now accept the string keyword parameters - as documented. The pattern and source keyword parameters are left as - deprecated aliases. - -- Issue #20778: Fix modulefinder to work with bytecode-only modules. - -- Issue #20791: copy.copy() now doesn't make a copy when the input is - a bytes object. Initial patch by Peter Otten. - -- Issue #19748: On AIX, time.mktime() now raises an OverflowError for year - outsize range [1902; 2037]. - -- Issue #19573: inspect.signature: Use enum for parameter kind constants. - -- Issue #20726: inspect.signature: Make Signature and Parameter picklable. - -- Issue #17373: Add inspect.Signature.from_callable method. - -- Issue #20378: Improve repr of inspect.Signature and inspect.Parameter. - -- Issue #20816: Fix inspect.getcallargs() to raise correct TypeError for - missing keyword-only arguments. Patch by Jeremiah Lowin. - -- Issue #20817: Fix inspect.getcallargs() to fail correctly if more - than 3 arguments are missing. Patch by Jeremiah Lowin. - -- Issue #6676: Ensure a meaningful exception is raised when attempting - to parse more than one XML document per pyexpat xmlparser instance. - (Original patches by Hirokazu Yamamoto and Amaury Forgeot d'Arc, with - suggested wording by David Gutteridge) - -- Issue #21117: Fix inspect.signature to better support functools.partial. - Due to the specifics of functools.partial implementation, - positional-or-keyword arguments passed as keyword arguments become - keyword-only. - -- Issue #20334: inspect.Signature and inspect.Parameter are now hashable. - Thanks to Antony Lee for bug reports and suggestions. - -- Issue #15916: doctest.DocTestSuite returns an empty unittest.TestSuite instead - of raising ValueError if it finds no tests - -- Issue #21209: Fix asyncio.tasks.CoroWrapper to workaround a bug - in yield-from implementation in CPythons prior to 3.4.1. - -- asyncio: Add gi_{frame,running,code} properties to CoroWrapper - (upstream issue #163). - -- Issue #21311: Avoid exception in _osx_support with non-standard compiler - configurations. Patch by John Szakmeister. - -- Issue #11571: Ensure that the turtle window becomes the topmost window - when launched on OS X. - -- Issue #21801: Validate that __signature__ is None or an instance of Signature. - -- Issue #21923: Prevent AttributeError in distutils.sysconfig.customize_compiler - due to possible uninitialized _config_vars. - -- Issue #21323: Fix http.server to again handle scripts in CGI subdirectories, - broken by the fix for security issue #19435. Patch by Zach Byrne. - -- Issue #22733: Fix ffi_prep_args not zero-extending argument values correctly - on 64-bit Windows. - -- Issue #23302: Default to TCP_NODELAY=1 upon establishing an HTTPConnection. - Removed use of hard-coded MSS as it's an optimization that's no longer needed - with Nagle disabled. - -IDLE ----- - -- Issue #20577: Configuration of the max line length for the FormatParagraph - extension has been moved from the General tab of the Idle preferences dialog - to the FormatParagraph tab of the Config Extensions dialog. - Patch by Tal Einat. - -- Issue #16893: Update Idle doc chapter to match current Idle and add new - information. - -- Issue #3068: Add Idle extension configuration dialog to Options menu. - Changes are written to HOME/.idlerc/config-extensions.cfg. - Original patch by Tal Einat. - -- Issue #16233: A module browser (File : Class Browser, Alt+C) requires an - editor window with a filename. When Class Browser is requested otherwise, - from a shell, output window, or 'Untitled' editor, Idle no longer displays - an error box. It now pops up an Open Module box (Alt+M). If a valid name - is entered and a module is opened, a corresponding browser is also opened. - -- Issue #4832: Save As to type Python files automatically adds .py to the - name you enter (even if your system does not display it). Some systems - automatically add .txt when type is Text files. - -- Issue #21986: Code objects are not normally pickled by the pickle module. - To match this, they are no longer pickled when running under Idle. - -- Issue #17390: Adjust Editor window title; remove 'Python', - move version to end. - -- Issue #14105: Idle debugger breakpoints no longer disappear - when inserting or deleting lines. - -- Issue #17172: Turtledemo can now be run from Idle. - Currently, the entry is on the Help menu, but it may move to Run. - Patch by Ramchandra Apt and Lita Cho. - -- Issue #21765: Add support for non-ascii identifiers to HyperParser. - -- Issue #21940: Add unittest for WidgetRedirector. Initial patch by Saimadhav - Heblikar. - -- Issue #18592: Add unittest for SearchDialogBase. Patch by Phil Webster. - -- Issue #21694: Add unittest for ParenMatch. Patch by Saimadhav Heblikar. - -- Issue #21686: add unittest for HyperParser. Original patch by Saimadhav - Heblikar. - -- Issue #12387: Add missing upper(lower)case versions of default Windows key - bindings for Idle so Caps Lock does not disable them. Patch by Roger Serwy. - -- Issue #21695: Closing a Find-in-files output window while the search is - still in progress no longer closes Idle. - -- Issue #18910: Add unittest for textView. Patch by Phil Webster. - -- Issue #18292: Add unittest for AutoExpand. Patch by Saihadhav Heblikar. - -- Issue #18409: Add unittest for AutoComplete. Patch by Phil Webster. - -- Issue #21477: htest.py - Improve framework, complete set of tests. - Patches by Saimadhav Heblikar - -- Issue #18104: Add idlelib/idle_test/htest.py with a few sample tests to begin - consolidating and improving human-validated tests of Idle. Change other files - as needed to work with htest. Running the module as __main__ runs all tests. - -- Issue #21139: Change default paragraph width to 72, the PEP 8 recommendation. - -- Issue #21284: Paragraph reformat test passes after user changes reformat width. - -- Issue #17654: Ensure IDLE menus are customized properly on OS X for - non-framework builds and for all variants of Tk. - -- Issue #23180: Rename IDLE "Windows" menu item to "Window". - Patch by Al Sweigart. - -Build ------ - -- Issue #15506: Use standard PKG_PROG_PKG_CONFIG autoconf macro in the configure - script. - -- Issue #22935: Allow the ssl module to be compiled if openssl doesn't support - SSL 3. - -- Issue #22592: Drop support of the Borland C compiler to build Python. The - distutils module still supports it to build extensions. - -- Issue #22591: Drop support of MS-DOS, especially of the DJGPP compiler - (MS-DOS port of GCC). - -- Issue #16537: Check whether self.extensions is empty in setup.py. Patch by - Jonathan Hosmer. - -- Issue #22359: Remove incorrect uses of recursive make. Patch by Jonas - Wagner. - -- Issue #21958: Define HAVE_ROUND when building with Visual Studio 2013 and - above. Patch by Zachary Turner. - -- Issue #18093: the programs that embed the CPython runtime are now in a - separate "Programs" directory, rather than being kept in the Modules - directory. - -- Issue #15759: "make suspicious", "make linkcheck" and "make doctest" in Doc/ - now display special message when and only when there are failures. - -- Issue #21141: The Windows build process no longer attempts to find Perl, - instead relying on OpenSSL source being configured and ready to build. The - ``PCbuild\build_ssl.py`` script has been re-written and re-named to - ``PCbuild\prepare_ssl.py``, and takes care of configuring OpenSSL source - for both 32 and 64 bit platforms. OpenSSL sources obtained from - svn.python.org will always be pre-configured and ready to build. - -- Issue #21037: Add a build option to enable AddressSanitizer support. - -- Issue #19962: The Windows build process now creates "python.bat" in the - root of the source tree, which passes all arguments through to the most - recently built interpreter. - -- Issue #21285: Refactor and fix curses configure check to always search - in a ncursesw directory. - -- Issue #15234: For BerkelyDB and Sqlite, only add the found library and - include directories if they aren't already being searched. This avoids - an explicit runtime library dependency. - -- Issue #17861: Tools/scripts/generate_opcode_h.py automatically regenerates - Include/opcode.h from Lib/opcode.py if the latter gets any change. - -- Issue #20644: OS X installer build support for documentation build changes - in 3.4.1: assume externally supplied sphinx-build is available in /usr/bin. - -- Issue #20022: Eliminate use of deprecated bundlebuilder in OS X builds. - -- Issue #15968: Incorporated Tcl, Tk, and Tix builds into the Windows build - solution. - -- Issue #17095: Fix Modules/Setup *shared* support. - -- Issue #21811: Anticipated fixes to support OS X versions > 10.9. - -- Issue #21166: Prevent possible segfaults and other random failures of - python --generate-posix-vars in pybuilddir.txt build target. - -- Issue #18096: Fix library order returned by python-config. - -- Issue #17219: Add library build dir for Python extension cross-builds. - -- Issue #22919: Windows build updated to support VC 14.0 (Visual Studio 2015), - which will be used for the official release. - -- Issue #21236: Build _msi.pyd with cabinet.lib instead of fci.lib - -- Issue #17128: Use private version of OpenSSL for OS X 10.5+ installer. - -C API ------ - -- Issue #14203: Remove obsolete support for view==NULL in PyBuffer_FillInfo(), - bytearray_getbuffer(), bytesiobuf_getbuffer() and array_buffer_getbuf(). - All functions now raise BufferError in that case. - -- Issue #22445: PyBuffer_IsContiguous() now implements precise contiguity - tests, compatible with NumPy's NPY_RELAXED_STRIDES_CHECKING compilation - flag. Previously the function reported false negatives for corner cases. - -- Issue #22079: PyType_Ready() now checks that statically allocated type has - no dynamically allocated bases. - -- Issue #22453: Removed non-documented macro PyObject_REPR(). - -- Issue #18395: Rename ``_Py_char2wchar()`` to :c:func:`Py_DecodeLocale`, - rename ``_Py_wchar2char()`` to :c:func:`Py_EncodeLocale`, and document - these functions. - -- Issue #21233: Add new C functions: PyMem_RawCalloc(), PyMem_Calloc(), - PyObject_Calloc(), _PyObject_GC_Calloc(). bytes(int) is now using - ``calloc()`` instead of ``malloc()`` for large objects which is faster and - use less memory. - -- Issue #20942: PyImport_ImportFrozenModuleObject() no longer sets __file__ to - match what importlib does; this affects _frozen_importlib as well as any - module loaded using imp.init_frozen(). - -Documentation -------------- - -- Issue #19548: Update the codecs module documentation to better cover the - distinction between text encodings and other codecs, together with other - clarifications. Patch by Martin Panter. - -- Issue #22394: Doc/Makefile now supports ``make venv PYTHON=../python`` to - create a venv for generating the documentation, e.g., - ``make html PYTHON=venv/bin/python3``. - -- Issue #21514: The documentation of the json module now refers to new JSON RFC - 7159 instead of obsoleted RFC 4627. - -- Issue #21777: The binary sequence methods on bytes and bytearray are now - documented explicitly, rather than assuming users will be able to derive - the expected behaviour from the behaviour of the corresponding str methods. - -- Issue #6916: undocument deprecated asynchat.fifo class. - -- Issue #17386: Expanded functionality of the ``Doc/make.bat`` script to make - it much more comparable to ``Doc/Makefile``. - -- Issue #21312: Update the thread_foobar.h template file to include newer - threading APIs. Patch by Jack McCracken. - -- Issue #21043: Remove the recommendation for specific CA organizations and to - mention the ability to load the OS certificates. - -- Issue #20765: Add missing documentation for PurePath.with_name() and - PurePath.with_suffix(). - -- Issue #19407: New package installation and distribution guides based on - the Python Packaging Authority tools. Existing guides have been retained - as legacy links from the distutils docs, as they still contain some - required reference material for tool developers that isn't recorded - anywhere else. - -- Issue #19697: Document cases where __main__.__spec__ is None. - -Tests ------ - -- Issue #18982: Add tests for CLI of the calendar module. - -- Issue #19548: Added some additional checks to test_codecs to ensure that - statements in the updated documentation remain accurate. Patch by Martin - Panter. - -- Issue #22838: All test_re tests now work with unittest test discovery. - -- Issue #22173: Update lib2to3 tests to use unittest test discovery. - -- Issue #16000: Convert test_curses to use unittest. - -- Issue #21456: Skip two tests in test_urllib2net.py if _ssl module not - present. Patch by Remi Pointel. - -- Issue #20746: Fix test_pdb to run in refleak mode (-R). Patch by Xavier - de Gaye. - -- Issue #22060: test_ctypes has been somewhat cleaned up and simplified; it - now uses unittest test discovery to find its tests. - -- Issue #22104: regrtest.py no longer holds a reference to the suite of tests - loaded from test modules that don't define test_main(). - -- Issue #22111: Assorted cleanups in test_imaplib. Patch by Milan Oberkirch. - -- Issue #22002: Added ``load_package_tests`` function to test.support and used - it to implement/augment test discovery in test_asyncio, test_email, - test_importlib, test_json, and test_tools. - -- Issue #21976: Fix test_ssl to accept LibreSSL version strings. Thanks - to William Orr. - -- Issue #21918: Converted test_tools from a module to a package containing - separate test files for each tested script. - -- Issue #9554: Use modern unittest features in test_argparse. Initial patch by - Denver Coneybeare and Radu Voicilas. - -- Issue #20155: Changed HTTP method names in failing tests in test_httpservers - so that packet filtering software (specifically Windows Base Filtering Engine) - does not interfere with the transaction semantics expected by the tests. - -- Issue #19493: Refactored the ctypes test package to skip tests explicitly - rather than silently. - -- Issue #18492: All resources are now allowed when tests are not run by - regrtest.py. - -- Issue #21634: Fix pystone micro-benchmark: use floor division instead of true - division to benchmark integers instead of floating point numbers. Set pystone - version to 1.2. Patch written by Lennart Regebro. - -- Issue #21605: Added tests for Tkinter images. - -- Issue #21493: Added test for ntpath.expanduser(). Original patch by - Claudiu Popa. - -- Issue #19925: Added tests for the spwd module. Original patch by Vajrasky Kok. - -- Issue #21522: Added Tkinter tests for Listbox.itemconfigure(), - PanedWindow.paneconfigure(), and Menu.entryconfigure(). - -- Issue #17756: Fix test_code test when run from the installed location. - -- Issue #17752: Fix distutils tests when run from the installed location. - -- Issue #18604: Consolidated checks for GUI availability. All platforms now - at least check whether Tk can be instantiated when the GUI resource is - requested. - -- Issue #21275: Fix a socket test on KFreeBSD. - -- Issue #21223: Pass test_site/test_startup_imports when some of the extensions - are built as builtins. - -- Issue #20635: Added tests for Tk geometry managers. - -- Add test case for freeze. - -- Issue #20743: Fix a reference leak in test_tcl. - -- Issue #21097: Move test_namespace_pkgs into test_importlib. - -- Issue #21503: Use test_both() consistently in test_importlib. - -- Issue #20939: Avoid various network test failures due to new - redirect of http://www.python.org/ to https://www.python.org: - use http://www.example.com instead. - -- Issue #20668: asyncio tests no longer rely on tests.txt file. - (Patch by Vajrasky Kok) - -- Issue #21093: Prevent failures of ctypes test_macholib on OS X if a - copy of libz exists in $HOME/lib or /usr/local/lib. - -- Issue #22770: Prevent some Tk segfaults on OS X when running gui tests. - -- Issue #23211: Workaround test_logging failure on some OS X 10.6 systems. - -- Issue #23345: Prevent test_ssl failures with large OpenSSL patch level - values (like 0.9.8zc). - -Tools/Demos ------------ - -- Issue #22314: pydoc now works when the LINES environment variable is set. - -- Issue #22615: Argument Clinic now supports the "type" argument for the - int converter. This permits using the int converter with enums and - typedefs. - -- Issue #20076: The makelocalealias.py script no longer ignores UTF-8 mapping. - -- Issue #20079: The makelocalealias.py script now can parse the SUPPORTED file - from glibc sources and supports command line options for source paths. - -- Issue #22201: Command-line interface of the zipfile module now correctly - extracts ZIP files with directory entries. Patch by Ryan Wilson. - -- Issue #22120: For functions using an unsigned integer return converter, - Argument Clinic now generates a cast to that type for the comparison - to -1 in the generated code. (This suppresses a compilation warning.) - -- Issue #18974: Tools/scripts/diff.py now uses argparse instead of optparse. - -- Issue #21906: Make Tools/scripts/md5sum.py work in Python 3. - Patch by Zachary Ware. - -- Issue #21629: Fix Argument Clinic's "--converters" feature. - -- Add support for ``yield from`` to 2to3. - -- Add support for the PEP 465 matrix multiplication operator to 2to3. - -- Issue #16047: Fix module exception list and __file__ handling in freeze. - Patch by Meador Inge. - -- Issue #11824: Consider ABI tags in freeze. Patch by Meador Inge. - -- Issue #20535: PYTHONWARNING no longer affects the run_tests.py script. - Patch by Arfrever Frehtes Taifersar Arahesis. - -Windows -------- - -- Issue #23260: Update Windows installer - -- The bundled version of Tcl/Tk has been updated to 8.6.3. The most visible - result of this change is the addition of new native file dialogs when - running on Windows Vista or newer. See Tcl/Tk's TIP 432 for more - information. Also, this version of Tcl/Tk includes support for Windows 10. - -- Issue #17896: The Windows build scripts now expect external library sources - to be in ``PCbuild\..\externals`` rather than ``PCbuild\..\..``. - -- Issue #17717: The Windows build scripts now use a copy of NASM pulled from - svn.python.org to build OpenSSL. - -- Issue #21907: Improved the batch scripts provided for building Python. - -- Issue #22644: The bundled version of OpenSSL has been updated to 1.0.1j. - -- Issue #10747: Use versioned labels in the Windows start menu. - Patch by Olive Kilburn. - -- Issue #22980: .pyd files with a version and platform tag (for example, - ".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 #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 incompatibilities with Tcl/Tk 8.6. - -- Issue #16809: Tkinter's splitlist() and split() methods now accept Tcl_Obj - argument. - -- 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 #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 #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

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 #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/Misc/NEWS.d/3.4.0.rst b/Misc/NEWS.d/3.4.0.rst new file mode 100644 index 00000000000..544c12a4031 --- /dev/null +++ b/Misc/NEWS.d/3.4.0.rst @@ -0,0 +1,17 @@ +.. bpo: 20939 +.. date: 8350 +.. nonce: MX5O4e +.. release date: 2014-03-16 +.. section: Library + +Fix test_geturl failure in test_urllibnet due to new redirect of +http://www.python.org/ to https://www.python.org. + +.. + +.. bpo: 0 +.. date: 8349 +.. nonce: 1hrH2G +.. section: Documentation + +Merge in all documentation changes since branching 3.4.0rc1. diff --git a/Misc/NEWS.d/3.4.0a1.rst b/Misc/NEWS.d/3.4.0a1.rst new file mode 100644 index 00000000000..34b3c718535 --- /dev/null +++ b/Misc/NEWS.d/3.4.0a1.rst @@ -0,0 +1,7218 @@ +.. bpo: 16741 +.. date: 7743 +.. nonce: bBBAqs +.. release date: 2013-08-03 +.. section: Core and Builtins + +Fix an error reporting in int(). + +.. + +.. bpo: 17899 +.. date: 7742 +.. nonce: Asq8mo +.. section: Core and Builtins + +Fix rare file descriptor leak in os.listdir(). + +.. + +.. bpo: 10241 +.. date: 7741 +.. nonce: V_nZk4 +.. section: Core and Builtins + +Clear extension module dict copies at interpreter shutdown. Patch by Neil +Schemenauer, minimally modified. + +.. + +.. bpo: 9035 +.. date: 7740 +.. nonce: Cx3O-7 +.. section: Core and Builtins + +ismount now recognises volumes mounted below a drive root on Windows. +Original patch by Atsuo Ishimoto. + +.. + +.. bpo: 18214 +.. date: 7739 +.. nonce: K8wQAM +.. section: Core and Builtins + +Improve finalization of Python modules to avoid setting their globals to +None, in most cases. + +.. + +.. bpo: 18112 +.. date: 7738 +.. nonce: 2Oph_E +.. section: Core and Builtins + +PEP 442 implementation (safe object finalization). + +.. + +.. bpo: 18552 +.. date: 7737 +.. nonce: hbrQHu +.. section: Core and Builtins + +Check return value of PyArena_AddPyObject() in obj2ast_object(). + +.. + +.. bpo: 18560 +.. date: 7736 +.. nonce: 5q_c1C +.. section: Core and Builtins + +Fix potential NULL pointer dereference in sum(). + +.. + +.. bpo: 18520 +.. date: 7735 +.. nonce: JY197j +.. section: Core and Builtins + +Add a new PyStructSequence_InitType2() function, same than +PyStructSequence_InitType() except that it has a return value (0 on success, +-1 on error). + +.. + +.. bpo: 15905 +.. date: 7734 +.. nonce: RG-KXt +.. section: Core and Builtins + +Fix theoretical buffer overflow in handling of sys.argv[0], prefix and +exec_prefix if the operation system does not obey MAXPATHLEN. + +.. + +.. bpo: 18408 +.. date: 7733 +.. nonce: w526wJ +.. section: Core and Builtins + +Fix many various bugs in code handling errors, especially on memory +allocation failure (MemoryError). + +.. + +.. bpo: 18344 +.. date: 7732 +.. nonce: QFOn66 +.. section: Core and Builtins + +Fix potential ref-leaks in _bufferedreader_read_all(). + +.. + +.. bpo: 18342 +.. date: 7731 +.. nonce: PkhUGS +.. section: Core and Builtins + +Use the repr of a module name when an import fails when using ``from ... +import ...``. + +.. + +.. bpo: 17872 +.. date: 7730 +.. nonce: P_Eal- +.. section: Core and Builtins + +Fix a segfault in marshal.load() when input stream returns more bytes than +requested. + +.. + +.. bpo: 18338 +.. date: 7729 +.. nonce: dhKNX2 +.. section: Core and Builtins + +`python --version` now prints version string to stdout, and not to stderr. +Patch by Berker Peksag and Michael Dickens. + +.. + +.. bpo: 18426 +.. date: 7728 +.. nonce: NdnL3v +.. section: Core and Builtins + +Fix NULL pointer dereference in C extension import when PyModule_GetDef() +returns an error. + +.. + +.. bpo: 17206 +.. date: 7727 +.. nonce: eT7Ywa +.. section: Core and Builtins + +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. + +.. + +.. bpo: 3329 +.. date: 7726 +.. nonce: 9PzUjS +.. section: Core and Builtins + +Implement the PEP 445: Add new APIs to customize Python memory allocators. + +.. + +.. bpo: 18328 +.. date: 7725 +.. nonce: JHuF3K +.. section: Core and Builtins + +Reorder ops in PyThreadState_Delete*() functions. Now the tstate is first +removed from TLS and then deallocated. + +.. + +.. bpo: 13483 +.. date: 7724 +.. nonce: hc6skP +.. section: Core and Builtins + +Use VirtualAlloc in obmalloc on Windows. + +.. + +.. bpo: 18184 +.. date: 7723 +.. nonce: xLNVG3 +.. section: Core and Builtins + +PyUnicode_FromFormat() and PyUnicode_FromFormatV() now raise OverflowError +when an argument of %c format is out of range. + +.. + +.. bpo: 18111 +.. date: 7722 +.. nonce: 73CZdq +.. section: Core and Builtins + +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.) + +.. + +.. bpo: 18137 +.. date: 7721 +.. nonce: a_Vsor +.. section: Core and Builtins + +Detect integer overflow on precision in float.__format__() and +complex.__format__(). + +.. + +.. bpo: 18183 +.. date: 7720 +.. nonce: v68GC2 +.. section: Core and Builtins + +Fix various unicode operations on strings with large unicode codepoints. + +.. + +.. bpo: 18180 +.. date: 7719 +.. nonce: GqAflm +.. section: Core and Builtins + +Fix ref leak in _PyImport_GetDynLoadWindows(). + +.. + +.. bpo: 18038 +.. date: 7718 +.. nonce: Q8prhd +.. section: Core and Builtins + +SyntaxError raised during compilation sources with illegal encoding now +always contains an encoding name. + +.. + +.. bpo: 17931 +.. date: 7717 +.. nonce: FCMg_f +.. section: Core and Builtins + +Resolve confusion on Windows between pids and process handles. + +.. + +.. bpo: 0 +.. date: 7716 +.. nonce: Kzwq2I +.. section: Core and Builtins + +Tweak the exception message when the magic number or size value in a +bytecode file is truncated. + +.. + +.. bpo: 17932 +.. date: 7715 +.. nonce: Y5Sfd4 +.. section: Core and Builtins + +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. + +.. + +.. bpo: 18065 +.. date: 7714 +.. nonce: tMRL_r +.. section: Core and Builtins + +Don't set __path__ to the package name for frozen packages. + +.. + +.. bpo: 18088 +.. date: 7713 +.. nonce: 0wObC2 +.. section: Core and Builtins + +When reloading a module, unconditionally reset all relevant attributes on +the module (e.g. __name__, __loader__, __package__, __file__, __cached__). + +.. + +.. bpo: 17937 +.. date: 7712 +.. nonce: xCh9n7 +.. section: Core and Builtins + +Try harder to collect cyclic garbage at shutdown. + +.. + +.. bpo: 12370 +.. date: 7711 +.. nonce: 6tvbpM +.. section: Core and Builtins + +Prevent class bodies from interfering with the __class__ closure. + +.. + +.. bpo: 17644 +.. date: 7710 +.. nonce: OuMIFJ +.. section: Core and Builtins + +Fix a crash in str.format when curly braces are used in square brackets. + +.. + +.. bpo: 17237 +.. date: 7709 +.. nonce: cF-0Zw +.. section: Core and Builtins + +Fix crash in the ASCII decoder on m68k. + +.. + +.. bpo: 17927 +.. date: 7708 +.. nonce: w21Pnm +.. section: Core and Builtins + +Frame objects kept arguments alive if they had been copied into a cell, even +if the cell was cleared. + +.. + +.. bpo: 1545463 +.. date: 7707 +.. nonce: ChdQTJ +.. section: Core and Builtins + +At shutdown, defer finalization of codec modules so that stderr remains +usable. + +.. + +.. bpo: 7330 +.. date: 7706 +.. nonce: _GTI9L +.. section: Core and Builtins + +Implement width and precision (ex: "%5.3s") for the format string of +PyUnicode_FromFormat() function, original patch written by Ysj Ray. + +.. + +.. bpo: 1545463 +.. date: 7705 +.. nonce: 5O00l2 +.. section: Core and Builtins + +Global variables caught in reference cycles are now garbage-collected at +shutdown. + +.. + +.. bpo: 17094 +.. date: 7704 +.. nonce: Uc8zDO +.. section: Core and Builtins + +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). + +.. + +.. bpo: 17408 +.. date: 7703 +.. nonce: mfHmrB +.. section: Core and Builtins + +Avoid using an obsolete instance of the copyreg module when the interpreter +is shutdown and then started again. + +.. + +.. bpo: 5845 +.. date: 7702 +.. nonce: Ws1eJX +.. section: Core and Builtins + +Enable tab-completion in the interactive interpreter by default, thanks to a +new sys.__interactivehook__. + +.. + +.. bpo: 17115 +.. date: 7701 +.. nonce: UWAXqy +.. section: Core and Builtins + +Module initialization now includes setting __package__ and __loader__ +attributes to None. (See also: bpo-17116) + +.. + +.. bpo: 17853 +.. date: 7700 +.. nonce: 7_fwd1 +.. section: Core and Builtins + +Ensure locals of a class that shadow free variables always win over the +closures. + +.. + +.. bpo: 17863 +.. date: 7699 +.. nonce: 3PTJAD +.. section: Core and Builtins + +In the interactive console, don't loop forever if the encoding can't be +fetched from stdin. + +.. + +.. bpo: 17867 +.. date: 7698 +.. nonce: DrmXe2 +.. section: Core and Builtins + +Raise an ImportError if __import__ is not found in __builtins__. + +.. + +.. bpo: 18698 +.. date: 7697 +.. nonce: q9QV4u +.. section: Core and Builtins + +Ensure importlib.reload() returns the module out of sys.modules. + +.. + +.. bpo: 17857 +.. date: 7696 +.. nonce: 7cCKDk +.. section: Core and Builtins + +Prevent build failures with pre-3.5.0 versions of sqlite3, such as was +shipped with Centos 5 and Mac OS X 10.4. + +.. + +.. bpo: 17413 +.. date: 7695 +.. nonce: Nt_U0G +.. section: Core and Builtins + +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. + +.. + +.. bpo: 17782 +.. date: 7694 +.. nonce: HwEf1N +.. section: Core and Builtins + +Fix undefined behaviour on platforms where ``struct timespec``'s "tv_nsec" +member is not a C long. + +.. + +.. bpo: 17722 +.. date: 7693 +.. nonce: SJ2O7r +.. section: Core and Builtins + +When looking up __round__, resolve descriptors. + +.. + +.. bpo: 16061 +.. date: 7692 +.. nonce: 4LQQlk +.. section: Core and Builtins + +Speed up str.replace() for replacing 1-character strings. + +.. + +.. bpo: 17715 +.. date: 7691 +.. nonce: gZ33Sm +.. section: Core and Builtins + +Fix segmentation fault from raising an exception in a __trunc__ method. + +.. + +.. bpo: 17643 +.. date: 7690 +.. nonce: O1HaFZ +.. section: Core and Builtins + +Add __callback__ attribute to weakref.ref. + +.. + +.. bpo: 16447 +.. date: 7689 +.. nonce: Nqypja +.. section: Core and Builtins + +Fixed potential segmentation fault when setting __name__ on a class. + +.. + +.. bpo: 17669 +.. date: 7688 +.. nonce: TkSpEF +.. section: Core and Builtins + +Fix crash involving finalization of generators using yield from. + +.. + +.. bpo: 14439 +.. date: 7687 +.. nonce: AK0wtz +.. section: Core and Builtins + +Python now prints the traceback on runpy failure at startup. + +.. + +.. bpo: 17469 +.. date: 7686 +.. nonce: Y2sqTK +.. section: Core and Builtins + +Fix _Py_GetAllocatedBlocks() and sys.getallocatedblocks() when running on +valgrind. + +.. + +.. bpo: 17619 +.. date: 7685 +.. nonce: nQqD2x +.. section: Core and Builtins + +Make input() check for Ctrl-C correctly on Windows. + +.. + +.. bpo: 17357 +.. date: 7684 +.. nonce: _xDD4K +.. section: Core and Builtins + +Add missing verbosity messages for -v/-vv that were lost during the +importlib transition. + +.. + +.. bpo: 17610 +.. date: 7683 +.. nonce: QpIzEB +.. section: Core and Builtins + +Don't rely on non-standard behavior of the C qsort() function. + +.. + +.. bpo: 17323 +.. date: 7682 +.. nonce: TozBFg +.. section: Core and Builtins + +The "[X refs, Y blocks]" printed by debug builds has been disabled by +default. It can be re-enabled with the `-X showrefcount` option. + +.. + +.. bpo: 17328 +.. date: 7681 +.. nonce: 5JxFnr +.. section: Core and Builtins + +Fix possible refleak in dict.setdefault. + +.. + +.. bpo: 17275 +.. date: 7680 +.. nonce: Aqerft +.. section: Core and Builtins + +Corrected class name in init error messages of the C version of +BufferedWriter and BufferedRandom. + +.. + +.. bpo: 7963 +.. date: 7679 +.. nonce: FWJtUT +.. section: Core and Builtins + +Fixed misleading error message that issued when object is called without +arguments. + +.. + +.. bpo: 8745 +.. date: 7678 +.. nonce: 7K11Uf +.. section: Core and Builtins + +Small speed up zipimport on Windows. Patch by Catalin Iacob. + +.. + +.. bpo: 5308 +.. date: 7677 +.. nonce: s5uAbP +.. section: Core and Builtins + +Raise ValueError when marshalling too large object (a sequence with size >= +2**31), instead of producing illegal marshal data. + +.. + +.. bpo: 12983 +.. date: 7676 +.. nonce: 9igtJf +.. section: Core and Builtins + +Bytes literals with invalid ``\x`` escape now raise a SyntaxError and a full +traceback including line number. + +.. + +.. bpo: 16967 +.. date: 7675 +.. nonce: UYSqkX +.. section: Core and Builtins + +In function definition, evaluate positional defaults before keyword-only +defaults. + +.. + +.. bpo: 17173 +.. date: 7674 +.. nonce: -KwwJ2 +.. section: Core and Builtins + +Remove uses of locale-dependent C functions (isalpha() etc.) in the +interpreter. + +.. + +.. bpo: 17137 +.. date: 7673 +.. nonce: CXHitK +.. section: Core and Builtins + +When a Unicode string is resized, the internal wide character string (wstr) +format is now cleared. + +.. + +.. bpo: 17043 +.. date: 7672 +.. nonce: 4OVhGk +.. section: Core and Builtins + +The unicode-internal decoder no longer read past the end of input buffer. + +.. + +.. bpo: 17098 +.. date: 7671 +.. nonce: hppfYX +.. section: Core and Builtins + +All modules now have __loader__ set even if they pre-exist the bootstrapping +of importlib. + +.. + +.. bpo: 16979 +.. date: 7670 +.. nonce: jTR3Oe +.. section: Core and Builtins + +Fix error handling bugs in the unicode-escape-decode decoder. + +.. + +.. bpo: 16772 +.. date: 7669 +.. nonce: 8qUxMn +.. section: Core and Builtins + +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. + +.. + +.. bpo: 10156 +.. date: 7668 +.. nonce: iEZGhY +.. section: Core and Builtins + +In the interpreter's initialization phase, unicode globals are now +initialized dynamically as needed. + +.. + +.. bpo: 16980 +.. date: 7667 +.. nonce: e2jDb2 +.. section: Core and Builtins + +Fix processing of escaped non-ascii bytes in the unicode-escape-decode +decoder. + +.. + +.. bpo: 16975 +.. date: 7666 +.. nonce: MfvORJ +.. section: Core and Builtins + +Fix error handling bug in the escape-decode bytes decoder. + +.. + +.. bpo: 14850 +.. date: 7665 +.. nonce: yScInY +.. section: Core and Builtins + +Now a charmap decoder treats U+FFFE as "undefined mapping" in any mapping, +not only in a string. + +.. + +.. bpo: 16613 +.. date: 7664 +.. nonce: 8V5m-H +.. section: Core and Builtins + +Add *m* argument to ``collections.Chainmap.new_child`` to allow the new +child map to be specified explicitly. + +.. + +.. bpo: 16730 +.. date: 7663 +.. nonce: X_pIAe +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16906 +.. date: 7662 +.. nonce: 3kn92w +.. section: Core and Builtins + +Fix a logic error that prevented most static strings from being cleared. + +.. + +.. bpo: 11461 +.. date: 7661 +.. nonce: xwn_Zw +.. section: Core and Builtins + +Fix the incremental UTF-16 decoder. Original patch by Amaury Forgeot d'Arc. + +.. + +.. bpo: 16856 +.. date: 7660 +.. nonce: _alafL +.. section: Core and Builtins + +Fix a segmentation fault from calling repr() on a dict with a key whose repr +raise an exception. + +.. + +.. bpo: 16367 +.. date: 7659 +.. nonce: lewlCg +.. section: Core and Builtins + +Fix FileIO.readall() on Windows for files larger than 2 GB. + +.. + +.. bpo: 16761 +.. date: 7658 +.. nonce: bZqaqq +.. section: Core and Builtins + +Calling int() with base argument only now raises TypeError. + +.. + +.. bpo: 16759 +.. date: 7657 +.. nonce: U0-CFS +.. section: Core and Builtins + +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. + +.. + +.. bpo: 14420 +.. date: 7656 +.. nonce: P8fmk8 +.. section: Core and Builtins + +Support the full DWORD (unsigned long) range in Py2Reg when passed a +REG_DWORD value. Fixes OverflowError in winreg.SetValueEx. + +.. + +.. bpo: 11939 +.. date: 7655 +.. nonce: rjfRMW +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16772 +.. date: 7654 +.. nonce: XI5NvS +.. section: Core and Builtins + +The int() constructor's second argument (base) no longer accepts non integer +values. Consistent with the behavior in Python 2. + +.. + +.. bpo: 14470 +.. date: 7653 +.. nonce: Qn1nFM +.. section: Core and Builtins + +Remove w9xpopen support per PEP 11. + +.. + +.. bpo: 9856 +.. date: 7652 +.. nonce: 5huiiZ +.. section: Core and Builtins + +Replace deprecation warning with raising TypeError in object.__format__. +Patch by Florent Xicluna. + +.. + +.. bpo: 16597 +.. date: 7651 +.. nonce: z8uMEN +.. section: Core and Builtins + +In buffered and text IO, call close() on the underlying stream if invoking +flush() fails. + +.. + +.. bpo: 16722 +.. date: 7650 +.. nonce: HXliz2 +.. section: Core and Builtins + +In the bytes() constructor, try to call __bytes__ on the argument before +__index__. + +.. + +.. bpo: 16421 +.. date: 7649 +.. nonce: Y9A84i +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16602 +.. date: 7648 +.. nonce: FjnLTD +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16495 +.. date: 7647 +.. nonce: HCGy9Q +.. section: Core and Builtins + +Remove extraneous NULL encoding check from bytes_decode(). + +.. + +.. bpo: 16619 +.. date: 7646 +.. nonce: STDaB4 +.. section: Core and Builtins + +Create NameConstant AST class to represent None, True, and False literals. +As a result, these constants are never loaded at runtime from builtins. + +.. + +.. bpo: 16455 +.. date: 7645 +.. nonce: chBHs2 +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16562 +.. date: 7644 +.. nonce: IR_Kj7 +.. section: Core and Builtins + +Optimize dict equality testing. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16588 +.. date: 7643 +.. nonce: YKgxOa +.. section: Core and Builtins + +Silence unused-but-set warnings in Python/thread_pthread + +.. + +.. bpo: 16592 +.. date: 7642 +.. nonce: QVZPAM +.. section: Core and Builtins + +stringlib_bytes_join doesn't raise MemoryError on allocation failure. + +.. + +.. bpo: 16546 +.. date: 7641 +.. nonce: LXZuCC +.. section: Core and Builtins + +Fix: ast.YieldFrom argument is now mandatory. + +.. + +.. bpo: 16514 +.. date: 7640 +.. nonce: NoxJ7R +.. section: Core and Builtins + +Fix regression causing a traceback when sys.path[0] is None (actually, any +non-string or non-bytes type). + +.. + +.. bpo: 16306 +.. date: 7639 +.. nonce: H29SXn +.. section: Core and Builtins + +Fix multiple error messages when unknown command line parameters where +passed to the interpreter. Patch by Hieu Nguyen. + +.. + +.. bpo: 16215 +.. date: 7638 +.. nonce: hoWMgb +.. section: Core and Builtins + +Fix potential double memory free in str.replace(). Patch by Serhiy +Storchaka. + +.. + +.. bpo: 16290 +.. date: 7637 +.. nonce: aCFQF9 +.. section: Core and Builtins + +A float return value from the __complex__ special method is no longer +accepted in the complex() constructor. + +.. + +.. bpo: 16416 +.. date: 7636 +.. nonce: v9EtVT +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16453 +.. date: 7635 +.. nonce: 0Zm9en +.. section: Core and Builtins + +Fix equality testing of dead weakref objects. + +.. + +.. bpo: 9535 +.. date: 7634 +.. nonce: hkixPD +.. section: Core and Builtins + +Fix pending signals that have been received but not yet handled by Python to +not persist after os.fork() in the child process. + +.. + +.. bpo: 14794 +.. date: 7633 +.. nonce: lc6bpg +.. section: Core and Builtins + +Fix slice.indices to return correct results for huge values, rather than +raising OverflowError. + +.. + +.. bpo: 15001 +.. date: 7632 +.. nonce: oD3gtX +.. section: Core and Builtins + +fix segfault on "del sys.modules['__main__']". Patch by Victor Stinner. + +.. + +.. bpo: 8271 +.. date: 7631 +.. nonce: 1qiQia +.. section: Core and Builtins + +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. + +.. + +.. bpo: 5765 +.. date: 7630 +.. nonce: YFFijP +.. section: Core and Builtins + +Apply a hard recursion limit in the compiler instead of blowing the stack +and segfaulting. Initial patch by Andrea Griffini. + +.. + +.. bpo: 16402 +.. date: 7629 +.. nonce: j73Ooz +.. section: Core and Builtins + +When slicing a range, fix shadowing of exceptions from __index__. + +.. + +.. bpo: 16336 +.. date: 7628 +.. nonce: JaupVb +.. section: Core and Builtins + +fix input checking in the surrogatepass error handler. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 8401 +.. date: 7627 +.. nonce: TslRZr +.. section: Core and Builtins + +assigning an int to a bytearray slice (e.g. b[3:4] = 5) now raises an error. + +.. + +.. bpo: 7317 +.. date: 7626 +.. nonce: 0ogGME +.. section: Core and Builtins + +Display full tracebacks when an error occurs asynchronously. Patch by Alon +Horev with update by Alexey Kachayev. + +.. + +.. bpo: 16309 +.. date: 7625 +.. nonce: i2KrDU +.. section: Core and Builtins + +Make PYTHONPATH="" behavior the same as if PYTHONPATH not set at all. + +.. + +.. bpo: 10189 +.. date: 7624 +.. nonce: 3tsml3 +.. section: Core and Builtins + +Improve the error reporting of SyntaxErrors related to global and nonlocal +statements. + +.. + +.. bpo: 0 +.. date: 7623 +.. nonce: iqyUxO +.. section: Core and Builtins + +Fix segfaults on setting __qualname__ on builtin types and attempting to +delete it on any type. + +.. + +.. bpo: 14625 +.. date: 7622 +.. nonce: FHSRMM +.. section: Core and Builtins + +Rewrite the UTF-32 decoder. It is now 3x to 4x faster. Patch written by +Serhiy Storchaka. + +.. + +.. bpo: 16345 +.. date: 7621 +.. nonce: azvPpP +.. section: Core and Builtins + +Fix an infinite loop when ``fromkeys`` on a dict subclass received a +nonempty dict from the constructor. + +.. + +.. bpo: 16271 +.. date: 7620 +.. nonce: ALsJdN +.. section: Core and Builtins + +Fix strange bugs that resulted from __qualname__ appearing in a class's +__dict__ and on type. + +.. + +.. bpo: 12805 +.. date: 7619 +.. nonce: 0u9UGE +.. section: Core and Builtins + +Make bytes.join and bytearray.join faster when the separator is empty. +Patch by Serhiy Storchaka. + +.. + +.. bpo: 6074 +.. date: 7618 +.. nonce: CXlveH +.. section: Core and Builtins + +Ensure cached bytecode files can always be updated by the user that created +them, even when the source file is read-only. + +.. + +.. bpo: 15958 +.. date: 7617 +.. nonce: 0MDv_n +.. section: Core and Builtins + +bytes.join and bytearray.join now accept arbitrary buffer objects. + +.. + +.. bpo: 14783 +.. date: 7616 +.. nonce: bv7z1_ +.. section: Core and Builtins + +Improve int() docstring and switch docstrings for str(), range(), and +slice() to use multi-line signatures. + +.. + +.. bpo: 16160 +.. date: 7615 +.. nonce: NKBYGr +.. section: Core and Builtins + +Subclass support now works for types.SimpleNamespace. + +.. + +.. bpo: 16148 +.. date: 7614 +.. nonce: tRekKP +.. section: Core and Builtins + +Implement PEP 424, adding operator.length_hint and PyObject_LengthHint. + +.. + +.. bpo: 0 +.. date: 7613 +.. nonce: J74Dx4 +.. section: Core and Builtins + +Upgrade Unicode data (UCD) to version 6.2. + +.. + +.. bpo: 15379 +.. date: 7612 +.. nonce: Ix2NTb +.. section: Core and Builtins + +Fix passing of non-BMP characters as integers for the charmap decoder +(already working as unicode strings). Patch by Serhiy Storchaka. + +.. + +.. bpo: 15144 +.. date: 7611 +.. nonce: ENBWTp +.. section: Core and Builtins + +Fix possible integer overflow when handling pointers as integer values, by +using `Py_uintptr_t` instead of `size_t`. Patch by Serhiy Storchaka. + +.. + +.. bpo: 15965 +.. date: 7610 +.. nonce: kbbwZh +.. section: Core and Builtins + +Explicitly cast `AT_FDCWD` as (int). Required on Solaris 10 (which defines +`AT_FDCWD` as ``0xffd19553``), harmless on other platforms. + +.. + +.. bpo: 15839 +.. date: 7609 +.. nonce: upi9Zr +.. section: Core and Builtins + +Convert SystemErrors in `super()` to RuntimeErrors. + +.. + +.. bpo: 15448 +.. date: 7608 +.. nonce: dj1nDm +.. section: Core and Builtins + +Buffered IO now frees the buffer when closed, instead of when deallocating. + +.. + +.. bpo: 15846 +.. date: 7607 +.. nonce: fkKoxl +.. section: Core and Builtins + +Fix SystemError which happened when using `ast.parse()` in an exception +handler on code with syntax errors. + +.. + +.. bpo: 15897 +.. date: 7606 +.. nonce: GQpoBE +.. section: Core and Builtins + +zipimport.c doesn't check return value of fseek(). Patch by Felipe Cruz. + +.. + +.. bpo: 15801 +.. date: 7605 +.. nonce: gpcQV3 +.. section: Core and Builtins + +Make sure mappings passed to '%' formatting are actually subscriptable. + +.. + +.. bpo: 15111 +.. date: 7604 +.. nonce: hM48LB +.. section: Core and Builtins + +__import__ should propagate ImportError when raised as a side-effect of a +module triggered from using fromlist. + +.. + +.. bpo: 15022 +.. date: 7603 +.. nonce: VevUbS +.. section: Core and Builtins + +Add pickle and comparison support to types.SimpleNamespace. + +.. + +.. bpo: 4331 +.. date: 7602 +.. nonce: Ua1fF0 +.. section: Library + +Added functools.partialmethod (Initial patch by Alon Horev) + +.. + +.. bpo: 13461 +.. date: 7601 +.. nonce: nLeS2R +.. section: Library + +Fix a crash in the TextIOWrapper.tell method on 64-bit platforms. Patch by +Yogesh Chaudhari. + +.. + +.. bpo: 18681 +.. date: 7600 +.. nonce: 8Oug5y +.. section: Library + +Fix a NameError in importlib.reload() (noticed by Weizhao Li). + +.. + +.. bpo: 14323 +.. date: 7599 +.. nonce: Sp7tzh +.. section: Library + +Expanded the number of digits in the coefficients for the RGB -- YIQ +conversions so that they match the FCC NTSC versions. + +.. + +.. bpo: 17998 +.. date: 7598 +.. nonce: hIbru5 +.. section: Library + +Fix an internal error in regular expression engine. + +.. + +.. bpo: 17557 +.. date: 7597 +.. nonce: s6BEMI +.. section: Library + +Fix os.getgroups() to work with the modified behavior of getgroups(2) on OS +X 10.8. Original patch by Mateusz Lenik. + +.. + +.. bpo: 18608 +.. date: 7596 +.. nonce: iLz2V4 +.. section: Library + +Avoid keeping a strong reference to the locale module inside the _io module. + +.. + +.. bpo: 18619 +.. date: 7595 +.. nonce: sj_OcY +.. section: Library + +Fix atexit leaking callbacks registered from sub-interpreters, and make it +GC-aware. + +.. + +.. bpo: 15699 +.. date: 7594 +.. nonce: tRg3Ny +.. section: Library + +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. + +.. + +.. bpo: 17616 +.. date: 7593 +.. nonce: BZCSg_ +.. section: Library + +wave.open now supports the context management protocol. + +.. + +.. bpo: 18599 +.. date: 7592 +.. nonce: OLGDK_ +.. section: Library + +Fix name attribute of _sha1.sha1() object. It now returns 'SHA1' instead of +'SHA'. + +.. + +.. bpo: 13266 +.. date: 7591 +.. nonce: vWxl34 +.. section: Library + +Added inspect.unwrap to easily unravel __wrapped__ chains (initial patch by +Daniel Urban and Aaron Iles) + +.. + +.. bpo: 18561 +.. date: 7590 +.. nonce: vgaf-k +.. section: Library + +Skip name in ctypes' _build_callargs() if name is NULL. + +.. + +.. bpo: 18559 +.. date: 7589 +.. nonce: svR01x +.. section: Library + +Fix NULL pointer dereference error in _pickle module + +.. + +.. bpo: 18556 +.. date: 7588 +.. nonce: -3Wtbg +.. section: Library + +Check the return type of PyUnicode_AsWideChar() in ctype's U_set(). + +.. + +.. bpo: 17818 +.. date: 7587 +.. nonce: zyqY5Z +.. section: Library + +aifc.getparams now returns a namedtuple. + +.. + +.. bpo: 18549 +.. date: 7586 +.. nonce: DfZaOD +.. section: Library + +Eliminate dead code in socket_ntohl() + +.. + +.. bpo: 18530 +.. date: 7585 +.. nonce: roUGYs +.. section: Library + +Remove additional stat call from posixpath.ismount. Patch by Alex Gaynor. + +.. + +.. bpo: 18514 +.. date: 7584 +.. nonce: byuxVK +.. section: Library + +Fix unreachable Py_DECREF() call in PyCData_FromBaseObj() + +.. + +.. bpo: 9177 +.. date: 7583 +.. nonce: 0NCpHI +.. section: Library + +Calling read() or write() now raises ValueError, not AttributeError, on a +closed SSL socket. Patch by Senko Rasic. + +.. + +.. bpo: 18513 +.. date: 7582 +.. nonce: 12JUZi +.. section: Library + +Fix behaviour of cmath.rect w.r.t. signed zeros on OS X 10.8 + gcc. + +.. + +.. bpo: 18479 +.. date: 7581 +.. nonce: CLFAeo +.. section: Library + +Changed venv Activate.ps1 to make deactivate a function, and removed +Deactivate.ps1. + +.. + +.. bpo: 18480 +.. date: 7580 +.. nonce: JoDjBC +.. section: Library + +Add missing call to PyType_Ready to the _elementtree extension. + +.. + +.. bpo: 17778 +.. date: 7579 +.. nonce: odXAnT +.. section: Library + +Fix test discovery for test_multiprocessing. (Patch by Zachary Ware.) + +.. + +.. bpo: 18393 +.. date: 7578 +.. nonce: J5Ss7D +.. section: Library + +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. + +.. + +.. bpo: 17482 +.. date: 7577 +.. nonce: HSxNCy +.. section: Library + +functools.update_wrapper (and functools.wraps) now set the __wrapped__ +attribute correctly even if the underlying function has a __wrapped__ +attribute set. + +.. + +.. bpo: 18431 +.. date: 7576 +.. nonce: 4TWlLe +.. section: Library + +The new email header parser now decodes RFC2047 encoded words in structured +headers. + +.. + +.. bpo: 18432 +.. date: 7575 +.. nonce: 3KWObr +.. section: Library + +The sched module's queue method was incorrectly returning an iterator +instead of a list. + +.. + +.. bpo: 18044 +.. date: 7574 +.. nonce: -TYxNg +.. section: Library + +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. + +.. + +.. bpo: 18101 +.. date: 7573 +.. nonce: Y9oAK1 +.. section: Library + +Tcl.split() now process strings nested in a tuple as it do with byte +strings. + +.. + +.. bpo: 18116 +.. date: 7572 +.. nonce: ZOamPj +.. section: Library + +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. + +.. + +.. bpo: 17198 +.. date: 7571 +.. nonce: MZjVaU +.. section: Library + +Fix a NameError in the dbm module. Patch by Valentina Mukhamedzhanova. + +.. + +.. bpo: 18013 +.. date: 7570 +.. nonce: wzBMJh +.. section: Library + +Fix cgi.FieldStorage to parse the W3C sample form. + +.. + +.. bpo: 18020 +.. date: 7569 +.. nonce: eN5fLA +.. section: Library + +improve html.escape speed by an order of magnitude. Patch by Matt Bryant. + +.. + +.. bpo: 18347 +.. date: 7568 +.. nonce: r98Yh- +.. section: Library + +ElementTree's html serializer now preserves the case of closing tags. + +.. + +.. bpo: 17261 +.. date: 7567 +.. nonce: FBzLVh +.. section: Library + +Ensure multiprocessing's proxies use proper address. + +.. + +.. bpo: 18343 +.. date: 7566 +.. nonce: hHmlM5 +.. section: Library + +faulthandler.register() now keeps the previous signal handler when the +function is called twice, so faulthandler.unregister() restores correctly +the original signal handler. + +.. + +.. bpo: 17097 +.. date: 7565 +.. nonce: npje1S +.. section: Library + +Make multiprocessing ignore EINTR. + +.. + +.. bpo: 18339 +.. date: 7564 +.. nonce: tawrrh +.. section: Library + +Negative ints keys in unpickler.memo dict no longer cause a segfault inside +the _pickle C extension. + +.. + +.. bpo: 18240 +.. date: 7563 +.. nonce: Um--C2 +.. section: Library + +The HMAC module is no longer restricted to bytes and accepts any bytes-like +object, e.g. memoryview. Original patch by Jonas Borgstr?m. + +.. + +.. bpo: 18224 +.. date: 7562 +.. nonce: QcraR9 +.. section: Library + +Removed pydoc script from created venv, as it causes problems on Windows and +adds no value over and above python -m pydoc ... + +.. + +.. bpo: 18155 +.. date: 7561 +.. nonce: P-O3wv +.. section: Library + +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. + +.. + +.. bpo: 14360 +.. date: 7560 +.. nonce: bn3mJY +.. section: Library + +encode_quopri can now be successfully used as an encoder when constructing a +MIMEApplication object. + +.. + +.. bpo: 11390 +.. date: 7559 +.. nonce: KD6eql +.. section: Library + +Add -o and -f command line options to the doctest CLI to specify doctest +options (and convert it to using argparse). + +.. + +.. bpo: 18135 +.. date: 7558 +.. nonce: NUPrSU +.. section: Library + +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. + +.. + +.. bpo: 11016 +.. date: 7557 +.. nonce: w7C0Pf +.. section: Library + +Add C implementation of the stat module as _stat. + +.. + +.. bpo: 18248 +.. date: 7556 +.. nonce: SFH5BJ +.. section: Library + +Fix libffi build on AIX. + +.. + +.. bpo: 18259 +.. date: 7555 +.. nonce: _GlBhr +.. section: Library + +Declare sethostname in socketmodule.c for AIX + +.. + +.. bpo: 18147 +.. date: 7554 +.. nonce: SwrMZ0 +.. section: Library + +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. + +.. + +.. bpo: 18167 +.. date: 7553 +.. nonce: ZeSV0k +.. section: Library + +cgi.FieldStorage no longer fails to handle multipart/form-data when ``\r\n`` +appears at end of 65535 bytes without other newlines. + +.. + +.. bpo: 18076 +.. date: 7552 +.. nonce: 4lL63W +.. section: Library + +Introduce importlib.util.decode_source(). + +.. + +.. bpo: 18357 +.. date: 7551 +.. nonce: jRiyQA +.. section: Library + +add tests for dictview set difference. Patch by Fraser Tweedale. + +.. + +.. bpo: 0 +.. date: 7550 +.. nonce: 8RBFdG +.. section: Library + +importlib.abc.SourceLoader.get_source() no longer changes SyntaxError or +UnicodeDecodeError into ImportError. + +.. + +.. bpo: 18058 +.. date: 7549 +.. nonce: rfXwQL +.. section: Library + +Make the namespace package loader meet the importlib.abc.InspectLoader ABC, +allowing for namespace packages to work with runpy. (See also: bpo-18057) + +.. + +.. bpo: 17177 +.. date: 7548 +.. nonce: S7sdI_ +.. section: Library + +The imp module is pending deprecation. + +.. + +.. bpo: 0 +.. date: 7547 +.. nonce: Y71ClT +.. section: Library + +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. + +.. + +.. bpo: 18194 +.. date: 7546 +.. nonce: -jAlVj +.. section: Library + +Introduce importlib.util.cache_from_source() and source_from_cache() while +documenting the equivalent functions in imp as deprecated. + +.. + +.. bpo: 17907 +.. date: 7545 +.. nonce: yz9wrd +.. section: Library + +Document imp.new_module() as deprecated in favour of types.ModuleType. + +.. + +.. bpo: 18192 +.. date: 7544 +.. nonce: R4NYan +.. section: Library + +Introduce importlib.util.MAGIC_NUMBER and document as deprecated +imp.get_magic(). + +.. + +.. bpo: 18149 +.. date: 7543 +.. nonce: pYRXFc +.. section: Library + +Add filecmp.clear_cache() to manually clear the filecmp cache. Patch by Mark +Levitt + +.. + +.. bpo: 18193 +.. date: 7542 +.. nonce: Hi1c_l +.. section: Library + +Add importlib.reload(). + +.. + +.. bpo: 18157 +.. date: 7541 +.. nonce: 3qhsTW +.. section: Library + +Stop using imp.load_module() in pydoc. + +.. + +.. bpo: 16102 +.. date: 7540 +.. nonce: Ue82lF +.. section: Library + +Make uuid._netbios_getnode() work again on Python 3. + +.. + +.. bpo: 17134 +.. date: 7539 +.. nonce: 2FXUYZ +.. section: Library + +Add ssl.enum_cert_store() as interface to Windows' cert store. + +.. + +.. bpo: 18143 +.. date: 7538 +.. nonce: qot9pC +.. section: Library + +Implement ssl.get_default_verify_paths() in order to debug the default +locations for cafile and capath. + +.. + +.. bpo: 17314 +.. date: 7537 +.. nonce: EgLvA7 +.. section: Library + +Move multiprocessing.forking over to importlib. + +.. + +.. bpo: 11959 +.. date: 7536 +.. nonce: KvHon- +.. section: Library + +SMTPServer and SMTPChannel now take an optional map, use of which avoids +affecting global state. + +.. + +.. bpo: 18109 +.. date: 7535 +.. nonce: ix7u1y +.. section: Library + +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. + +.. + +.. bpo: 18089 +.. date: 7534 +.. nonce: f8TdL7 +.. section: Library + +Implement importlib.abc.InspectLoader.load_module. + +.. + +.. bpo: 18088 +.. date: 7533 +.. nonce: G6H6Z2 +.. section: Library + +Introduce importlib.abc.Loader.init_module_attrs for setting module +attributes. Leads to the pending deprecation of +importlib.util.module_for_loader. + +.. + +.. bpo: 17403 +.. date: 7532 +.. nonce: gtIhUd +.. section: Library + +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. + +.. + +.. bpo: 18070 +.. date: 7531 +.. nonce: ocj8nr +.. section: Library + +Have importlib.util.module_for_loader() set attributes unconditionally in +order to properly support reloading. + +.. + +.. bpo: 0 +.. date: 7530 +.. nonce: J5E4J_ +.. section: Library + +Added importlib.util.module_to_load to return a context manager to provide +the proper module object to load. + +.. + +.. bpo: 18025 +.. date: 7529 +.. nonce: i8mW0x +.. section: Library + +Fixed a segfault in io.BufferedIOBase.readinto() when raw stream's read() +returns more bytes than requested. + +.. + +.. bpo: 18011 +.. date: 7528 +.. nonce: lvv4RQ +.. section: Library + +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. + +.. + +.. bpo: 18072 +.. date: 7527 +.. nonce: id8KzR +.. section: Library + +Implement importlib.abc.InspectLoader.get_code() and +importlib.abc.ExecutionLoader.get_code(). + +.. + +.. bpo: 8240 +.. date: 7526 +.. nonce: XMOgJe +.. section: Library + +Set the SSL_MODE_ACCEPT_MOVING_WRITE_BUFFER flag on SSL sockets. + +.. + +.. bpo: 17269 +.. date: 7525 +.. nonce: 7LxyKz +.. section: Library + +Workaround for socket.getaddrinfo crash on MacOS X with port None or "0" and +flags AI_NUMERICSERV. + +.. + +.. bpo: 16986 +.. date: 7524 +.. nonce: htN8mZ +.. section: Library + +ElementTree now correctly works with string input when the internal XML +encoding is not UTF-8 or US-ASCII. + +.. + +.. bpo: 17996 +.. date: 7523 +.. nonce: JRofiI +.. section: Library + +socket module now exposes AF_LINK constant on BSD and OSX. + +.. + +.. bpo: 17900 +.. date: 7522 +.. nonce: KONBQp +.. section: Library + +Allowed pickling of recursive OrderedDicts. Decreased pickled size and +pickling time. + +.. + +.. bpo: 17914 +.. date: 7521 +.. nonce: a7CBRm +.. section: Library + +Add os.cpu_count(). Patch by Yogesh Chaudhari, based on an initial patch by +Trent Nelson. + +.. + +.. bpo: 17812 +.. date: 7520 +.. nonce: WW32FE +.. section: Library + +Fixed quadratic complexity of base64.b32encode(). Optimize +base64.b32encode() and base64.b32decode() (speed up to 3x). + +.. + +.. bpo: 17980 +.. date: 7519 +.. nonce: oLLRCS +.. section: Library + +Fix possible abuse of ssl.match_hostname() for denial of service using +certificates with many wildcards (CVE-2013-2099). + +.. + +.. bpo: 15758 +.. date: 7518 +.. nonce: jcf1UW +.. section: Library + +Fix FileIO.readall() so it no longer has O(n**2) complexity. + +.. + +.. bpo: 14596 +.. date: 7517 +.. nonce: _L9ARc +.. section: Library + +The struct.Struct() objects now use a more compact implementation. + +.. + +.. bpo: 17981 +.. date: 7516 +.. nonce: 6UZcQZ +.. section: Library + +logging's SysLogHandler now closes the socket when it catches socket +OSErrors. + +.. + +.. bpo: 17964 +.. date: 7515 +.. nonce: fypN2L +.. section: Library + +Fix os.sysconf(): the return type of the C sysconf() function is long, not +int. + +.. + +.. bpo: 0 +.. date: 7514 +.. nonce: 9OGCJH +.. section: Library + +Fix typos in the multiprocessing module. + +.. + +.. bpo: 17754 +.. date: 7513 +.. nonce: xa6Bc3 +.. section: Library + +Make ctypes.util.find_library() independent of the locale. + +.. + +.. bpo: 17968 +.. date: 7512 +.. nonce: nY_hjb +.. section: Library + +Fix memory leak in os.listxattr(). + +.. + +.. bpo: 17606 +.. date: 7511 +.. nonce: KiLlUm +.. section: Library + +Fixed support of encoded byte strings in the XMLGenerator characters() and +ignorableWhitespace() methods. Original patch by Sebastian Ortiz Vasquez. + +.. + +.. bpo: 17732 +.. date: 7510 +.. nonce: nVRMov +.. section: Library + +Ignore distutils.cfg options pertaining to install paths if a virtual +environment is active. + +.. + +.. bpo: 17915 +.. date: 7509 +.. nonce: ugMGeG +.. section: Library + +Fix interoperability of xml.sax with file objects returned by codecs.open(). + +.. + +.. bpo: 16601 +.. date: 7508 +.. nonce: nolAu_ +.. section: Library + +Restarting iteration over tarfile really restarts rather than continuing +from where it left off. Patch by Michael Birtwell. + +.. + +.. bpo: 17289 +.. date: 7507 +.. nonce: NPHOks +.. section: Library + +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. + +.. + +.. bpo: 12181 +.. date: 7506 +.. nonce: Dq2moC +.. section: Library + +select module: Fix struct kevent definition on OpenBSD 64-bit platforms. +Patch by Federico Schwindt. + +.. + +.. bpo: 11816 +.. date: 7505 +.. nonce: sv6zV1 +.. section: Library + +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. + +.. + +.. bpo: 13831 +.. date: 7504 +.. nonce: 2ERopR +.. section: Library + +Embed stringification of remote traceback in local traceback raised when +pool task raises an exception. + +.. + +.. bpo: 15528 +.. date: 7503 +.. nonce: EwXcQD +.. section: Library + +Add weakref.finalize to support finalization using weakref callbacks. + +.. + +.. bpo: 14173 +.. date: 7502 +.. nonce: mZM9Pr +.. section: Library + +Avoid crashing when reading a signal handler during interpreter shutdown. + +.. + +.. bpo: 15902 +.. date: 7501 +.. nonce: 3XIl24 +.. section: Library + +Fix imp.load_module() accepting None as a file when loading an extension +module. + +.. + +.. bpo: 13721 +.. date: 7500 +.. nonce: _1u_jf +.. section: Library + +SSLSocket.getpeercert() and SSLSocket.do_handshake() now raise an OSError +with ENOTCONN, instead of an AttributeError, when the SSLSocket is not +connected. + +.. + +.. bpo: 14679 +.. date: 7499 +.. nonce: XSBn-L +.. section: Library + +add an __all__ (that contains only HTMLParser) to html.parser. + +.. + +.. bpo: 17802 +.. date: 7498 +.. nonce: ztoqWb +.. section: Library + +Fix an UnboundLocalError in html.parser. Initial tests by Thomas Barlow. + +.. + +.. bpo: 17358 +.. date: 7497 +.. nonce: qFWG6Z +.. section: Library + +Modules loaded by imp.load_source() and load_compiled() (and by extension +load_module()) now have a better chance of working when reloaded. + +.. + +.. bpo: 17804 +.. date: 7496 +.. nonce: 3ehiC3 +.. section: Library + +New function ``struct.iter_unpack`` allows for streaming struct unpacking. + +.. + +.. bpo: 17830 +.. date: 7495 +.. nonce: guxczO +.. section: Library + +When keyword.py is used to update a keyword file, it now preserves the line +endings of the original file. + +.. + +.. bpo: 17272 +.. date: 7494 +.. nonce: UdNBlq +.. section: Library + +Making the urllib.request's Request.full_url a descriptor. Fixes bugs with +assignment to full_url. Patch by Demian Brecht. + +.. + +.. bpo: 17353 +.. date: 7493 +.. nonce: 6Wiqfl +.. section: Library + +Plistlib emitted empty data tags with deeply nested datastructures + +.. + +.. bpo: 11714 +.. date: 7492 +.. nonce: EZxzYl +.. section: Library + +Use 'with' statements to assure a Semaphore releases a condition variable. +Original patch by Thomas Rachel. + +.. + +.. bpo: 16624 +.. date: 7491 +.. nonce: fEhnPS +.. section: Library + +`subprocess.check_output` now accepts an `input` argument, allowing the +subprocess's stdin to be provided as a (byte) string. Patch by Zack +Weinberg. + +.. + +.. bpo: 17795 +.. date: 7490 +.. nonce: IgVwMv +.. section: Library + +Reverted backwards-incompatible change in SysLogHandler with Unix domain +sockets. + +.. + +.. bpo: 16694 +.. date: 7489 +.. nonce: rHrtHr +.. section: Library + +Add a pure Python implementation of the operator module. Patch by Zachary +Ware. + +.. + +.. bpo: 11182 +.. date: 7488 +.. nonce: FEuMiq +.. section: Library + +remove the unused and undocumented pydoc.Scanner class. Patch by Martin +Morrison. + +.. + +.. bpo: 17741 +.. date: 7487 +.. nonce: nAezWJ +.. section: Library + +Add ElementTree.XMLPullParser, an event-driven parser for non-blocking +applications. + +.. + +.. bpo: 17555 +.. date: 7486 +.. nonce: 9klJCB +.. section: Library + +Fix ForkAwareThreadLock so that size of after fork registry does not grow +exponentially with generation of process. + +.. + +.. bpo: 17707 +.. date: 7485 +.. nonce: jX-JqL +.. section: Library + +fix regression in multiprocessing.Queue's get() method where it did not +block for short timeouts. + +.. + +.. bpo: 17720 +.. date: 7484 +.. nonce: mMh9Hz +.. section: Library + +Fix the Python implementation of pickle.Unpickler to correctly process the +APPENDS opcode when it is used on non-list objects. + +.. + +.. bpo: 17012 +.. date: 7483 +.. nonce: EW-5OU +.. section: Library + +shutil.which() no longer falls back to the PATH environment variable if an +empty path argument is specified. Patch by Serhiy Storchaka. + +.. + +.. bpo: 17710 +.. date: 7482 +.. nonce: OCzZ2n +.. section: Library + +Fix pickle raising a SystemError on bogus input. + +.. + +.. bpo: 17341 +.. date: 7481 +.. nonce: DI-1AO +.. section: Library + +Include the invalid name in the error messages from re about invalid group +names. + +.. + +.. bpo: 17702 +.. date: 7480 +.. nonce: ySqg1b +.. section: Library + +os.environ now raises KeyError with the original environment variable name +(str on UNIX), instead of using the encoded name (bytes on UNIX). + +.. + +.. bpo: 16163 +.. date: 7479 +.. nonce: 3aay4D +.. section: Library + +Make the importlib based version of pkgutil.iter_importers work for +submodules. Initial patch by Berker Peksag. + +.. + +.. bpo: 16804 +.. date: 7478 +.. nonce: vK8Q1B +.. section: Library + +Fix a bug in the 'site' module that caused running 'python -S -m site' to +incorrectly throw an exception. + +.. + +.. bpo: 15480 +.. date: 7477 +.. nonce: RMEmOd +.. section: Library + +Remove the deprecated and unused TYPE_INT64 code from marshal. Initial patch +by Daniel Riti. + +.. + +.. bpo: 2118 +.. date: 7476 +.. nonce: jsDIem +.. section: Library + +SMTPException is now a subclass of OSError. + +.. + +.. bpo: 17016 +.. date: 7475 +.. nonce: lQnMI8 +.. section: Library + +Get rid of possible pointer wraparounds and integer overflows in the re +module. Patch by Nickolai Zeldovich. + +.. + +.. bpo: 16658 +.. date: 7474 +.. nonce: WgAKmI +.. section: Library + +add missing return to HTTPConnection.send(). Patch by Jeff Knupp. + +.. + +.. bpo: 9556 +.. date: 7473 +.. nonce: Dk30j0 +.. section: Library + +the logging package now allows specifying a time-of-day for a +TimedRotatingFileHandler to rotate. + +.. + +.. bpo: 14971 +.. date: 7472 +.. nonce: cc8xNA +.. section: Library + +unittest test discovery no longer gets confused when a function has a +different __name__ than its name in the TestCase class dictionary. + +.. + +.. bpo: 17487 +.. date: 7471 +.. nonce: pP4v4C +.. section: Library + +The wave getparams method now returns a namedtuple rather than a plain +tuple. + +.. + +.. bpo: 17675 +.. date: 7470 +.. nonce: -A8oHC +.. section: Library + +socket repr() provides local and remote addresses (if any). Patch by +Giampaolo Rodola' + +.. + +.. bpo: 17093 +.. date: 7469 +.. nonce: M-IcJ- +.. section: Library + +Make the ABCs in importlib.abc provide default values or raise reasonable +exceptions for their methods to make them more amenable to super() calls. + +.. + +.. bpo: 17566 +.. date: 7468 +.. nonce: dqA1rg +.. section: Library + +Make importlib.abc.Loader.module_repr() optional instead of an +abstractmethod; now it raises NotImplementedError so as to be ignored by +default. + +.. + +.. bpo: 17678 +.. date: 7467 +.. nonce: PZfAGl +.. section: Library + +Remove the use of deprecated method in http/cookiejar.py by changing the +call to get_origin_req_host() to origin_req_host. + +.. + +.. bpo: 17666 +.. date: 7466 +.. nonce: L8Gq8u +.. section: Library + +Fix reading gzip files with an extra field. + +.. + +.. bpo: 16475 +.. date: 7465 +.. nonce: aNp-kL +.. section: Library + +Support object instancing, recursion and interned strings in marshal + +.. + +.. bpo: 17502 +.. date: 7464 +.. nonce: yOccrz +.. section: Library + +Process DEFAULT values in mock side_effect that returns iterator. + +.. + +.. bpo: 16795 +.. date: 7463 +.. nonce: zi6RPl +.. section: Library + +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. + +.. + +.. bpo: 17434 +.. date: 7462 +.. nonce: bctYsc +.. section: Library + +Properly raise a SyntaxError when a string occurs between future imports. + +.. + +.. bpo: 17117 +.. date: 7461 +.. nonce: 2wgWhb +.. section: Library + +Import and @importlib.util.set_loader now set __loader__ when it has a value +of None or the attribute doesn't exist. + +.. + +.. bpo: 17032 +.. date: 7460 +.. nonce: FKHNgX +.. section: Library + +The "global" in the "NameError: global name 'x' is not defined" error +message has been removed. Patch by Ram Rachum. + +.. + +.. bpo: 18080 +.. date: 7459 +.. nonce: rNHtkk +.. section: Library + +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. + +.. + +.. bpo: 18113 +.. date: 7458 +.. nonce: 7w81KJ +.. section: Library + +Fixed a refcount leak in the curses.panel module's set_userptr() method. +Reported by Atsuo Ishimoto. + +.. + +.. bpo: 0 +.. date: 7457 +.. nonce: t5hfCI +.. section: Library + +Implement PEP 443 "Single-dispatch generic functions". + +.. + +.. bpo: 0 +.. date: 7456 +.. nonce: U2ylaI +.. section: Library + +Implement PEP 435 "Adding an Enum type to the Python standard library". + +.. + +.. bpo: 15596 +.. date: 7455 +.. nonce: 0NKCQv +.. section: Library + +Faster pickling of unicode strings. + +.. + +.. bpo: 17572 +.. date: 7454 +.. nonce: 98CntI +.. section: Library + +Avoid chained exceptions when passing bad directives to time.strptime(). +Initial patch by Claudiu Popa. + +.. + +.. bpo: 17435 +.. date: 7453 +.. nonce: 167Uzu +.. section: Library + +threading.Timer's __init__ method no longer uses mutable default values for +the args and kwargs parameters. + +.. + +.. bpo: 17526 +.. date: 7452 +.. nonce: wiYvlk +.. section: Library + +fix an IndexError raised while passing code without filename to +inspect.findsource(). Initial patch by Tyler Doyle. + +.. + +.. bpo: 17540 +.. date: 7451 +.. nonce: 0FlRFl +.. section: Library + +Added style parameter to logging formatter configuration by dict. + +.. + +.. bpo: 16692 +.. date: 7450 +.. nonce: 1HPMSd +.. section: Library + +The ssl module now supports TLS 1.1 and TLS 1.2. Initial patch by Michele +Orr?. + +.. + +.. bpo: 17025 +.. date: 7449 +.. nonce: 2cO-DW +.. section: Library + +multiprocessing: Reduce Queue and SimpleQueue contention. + +.. + +.. bpo: 17536 +.. date: 7448 +.. nonce: PLE2RC +.. section: Library + +Add to webbrowser's browser list: www-browser, x-www-browser, iceweasel, +iceape. + +.. + +.. bpo: 17150 +.. date: 7447 +.. nonce: cs1ti6 +.. section: Library + +pprint now uses line continuations to wrap long string literals. + +.. + +.. bpo: 17488 +.. date: 7446 +.. nonce: ODub-T +.. section: Library + +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. + +.. + +.. bpo: 17521 +.. date: 7445 +.. nonce: rDGKe7 +.. section: Library + +Corrected non-enabling of logger following two calls to fileConfig(). + +.. + +.. bpo: 17508 +.. date: 7444 +.. nonce: B0KwKx +.. section: Library + +Corrected logging MemoryHandler configuration in dictConfig() where the +target handler wasn't configured first. + +.. + +.. bpo: 17209 +.. date: 7443 +.. nonce: w9J1io +.. section: Library + +curses.window.get_wch() now correctly handles KeyboardInterrupt (CTRL+c). + +.. + +.. bpo: 5713 +.. date: 7442 +.. nonce: SuN3vQ +.. section: Library + +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. + +.. + +.. bpo: 16997 +.. date: 7441 +.. nonce: vtxNkx +.. section: Library + +unittest.TestCase now provides a subTest() context manager to procedurally +generate, in an easy way, small test instances. + +.. + +.. bpo: 17485 +.. date: 7440 +.. nonce: coQ2Mv +.. section: Library + +Also delete the Request Content-Length header if the data attribute is +deleted. (Follow on to issue Issue #16464). + +.. + +.. bpo: 15927 +.. date: 7439 +.. nonce: YpppEm +.. section: Library + +CVS now correctly parses escaped newlines and carriage when parsing with +quoting turned off. + +.. + +.. bpo: 17467 +.. date: 7438 +.. nonce: XLE6Ww +.. section: Library + +add readline and readlines support to mock_open in unittest.mock. + +.. + +.. bpo: 13248 +.. date: 7437 +.. nonce: YnMTCa +.. section: Library + +removed deprecated and undocumented difflib.isbjunk, isbpopular. + +.. + +.. bpo: 17192 +.. date: 7436 +.. nonce: U0oKFo +.. section: Library + +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. + +.. + +.. bpo: 8862 +.. date: 7435 +.. nonce: WpBti_ +.. section: Library + +Fixed curses cleanup when getkey is interrupted by a signal. + +.. + +.. bpo: 17443 +.. date: 7434 +.. nonce: _ARDbV +.. section: Library + +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. + +.. + +.. bpo: 17476 +.. date: 7433 +.. nonce: Vs3Ky0 +.. section: Library + +Fixed regression relative to Python2 in undocumented pydoc 'allmethods'; it +was missing unbound methods on the class. + +.. + +.. bpo: 17474 +.. date: 7432 +.. nonce: y7hWoH +.. section: Library + +Remove the deprecated methods of Request class. + +.. + +.. bpo: 16709 +.. date: 7431 +.. nonce: 03AeYP +.. section: Library + +unittest discover order is no-longer filesystem specific. Patch by Jeff +Ramnani. + +.. + +.. bpo: 0 +.. date: 7430 +.. nonce: 4ymwbY +.. section: Library + +Use the HTTPS PyPI url for upload, overriding any plain HTTP URL in pypirc. + +.. + +.. bpo: 5024 +.. date: 7429 +.. nonce: 4cj0qD +.. section: Library + +sndhdr.whichhdr now returns the frame count for WAV files rather than -1. + +.. + +.. bpo: 17460 +.. date: 7428 +.. nonce: EQquZ6 +.. section: Library + +Remove the strict argument of HTTPConnection and removing the +DeprecationWarning being issued from 3.2 onwards. + +.. + +.. bpo: 16880 +.. date: 7427 +.. nonce: VYBbI- +.. section: Library + +Do not assume _imp.load_dynamic() is defined in the imp module. + +.. + +.. bpo: 16389 +.. date: 7426 +.. nonce: uQ4z93 +.. section: Library + +Fixed a performance regression relative to Python 3.1 in the caching of +compiled regular expressions. + +.. + +.. bpo: 0 +.. date: 7425 +.. nonce: VWrGFv +.. section: Library + +Added missing FeedParser and BytesFeedParser to email.parser.__all__. + +.. + +.. bpo: 17431 +.. date: 7424 +.. nonce: nID-Rk +.. section: Library + +Fix missing import of BytesFeedParser in email.parser. + +.. + +.. bpo: 12921 +.. date: 7423 +.. nonce: TksQ6K +.. section: Library + +http.server's send_error takes an explain argument to send more information +in response. Patch contributed by Karl. + +.. + +.. bpo: 17414 +.. date: 7422 +.. nonce: lOLLCV +.. section: Library + +Add timeit, repeat, and default_timer to timeit.__all__. + +.. + +.. bpo: 1285086 +.. date: 7421 +.. nonce: RN9orX +.. section: Library + +Get rid of the refcounting hack and speed up urllib.parse.unquote() and +urllib.parse.unquote_to_bytes(). + +.. + +.. bpo: 17099 +.. date: 7420 +.. nonce: CfR4FA +.. section: Library + +Have importlib.find_loader() raise ValueError when __loader__ is not set, +harmonizing with what happens when the attribute is set to None. + +.. + +.. bpo: 0 +.. date: 7419 +.. nonce: a1ikiC +.. section: Library + +Expose the O_PATH constant in the os module if it is available. + +.. + +.. bpo: 17368 +.. date: 7418 +.. nonce: y8QiJd +.. section: Library + +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. + +.. + +.. bpo: 17385 +.. date: 7417 +.. nonce: vuRrxn +.. section: Library + +Fix quadratic behavior in threading.Condition. The FIFO queue now uses a +deque instead of a list. + +.. + +.. bpo: 15806 +.. date: 7416 +.. nonce: vWRkOo +.. section: Library + +Add contextlib.ignore(). This creates a context manager to ignore specified +exceptions, replacing the "except SomeException: pass" idiom. + +.. + +.. bpo: 14645 +.. date: 7415 +.. nonce: FevIjz +.. section: Library + +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. + +.. + +.. bpo: 17278 +.. date: 7414 +.. nonce: pOF4An +.. section: Library + +Fix a crash in heapq.heappush() and heapq.heappop() when the list is being +resized concurrently. + +.. + +.. bpo: 16962 +.. date: 7413 +.. nonce: 4mCLOO +.. section: Library + +Use getdents64 instead of the obsolete getdents syscall in the subprocess +module on Linux. + +.. + +.. bpo: 16935 +.. date: 7412 +.. nonce: ykjyut +.. section: Library + +unittest now counts the module as skipped if it raises SkipTest, instead of +counting it as an error. Patch by Zachary Ware. + +.. + +.. bpo: 17018 +.. date: 7411 +.. nonce: l8_sa8 +.. section: Library + +Make Process.join() retry if os.waitpid() fails with EINTR. + +.. + +.. bpo: 17223 +.. date: 7410 +.. nonce: gzcSyh +.. section: Library + +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. + +.. + +.. bpo: 17197 +.. date: 7409 +.. nonce: 8BMC_8 +.. section: Library + +profile/cProfile modules refactored so that code of run() and runctx() +utility functions is not duplicated in both modules. + +.. + +.. bpo: 14720 +.. date: 7408 +.. nonce: rjT0OJ +.. section: Library + +sqlite3: Convert datetime microseconds correctly. Patch by Lowe Thiderman. + +.. + +.. bpo: 15132 +.. date: 7407 +.. nonce: kC6tTe +.. section: Library + +Allow a list for the defaultTest argument of unittest.TestProgram. Patch by +Jyrki Pulliainen. + +.. + +.. bpo: 17225 +.. date: 7406 +.. nonce: Z396fN +.. section: Library + +JSON decoder now counts columns in the first line starting with 1, as in +other lines. + +.. + +.. bpo: 6623 +.. date: 7405 +.. nonce: eWizvk +.. section: Library + +Added explicit DeprecationWarning for ftplib.netrc, which has been +deprecated and undocumented for a long time. + +.. + +.. bpo: 13700 +.. date: 7404 +.. nonce: sfJ2nZ +.. section: Library + +Fix byte/string handling in imaplib authentication when an authobject is +specified. + +.. + +.. bpo: 13153 +.. date: 7403 +.. nonce: DW27xH +.. section: Library + +Tkinter functions now raise TclError instead of ValueError when a string +argument contains non-BMP character. + +.. + +.. bpo: 9669 +.. date: 7402 +.. nonce: Td9alB +.. section: Library + +Protect re against infinite loops on zero-width matching in non-greedy +repeat. Patch by Matthew Barnett. + +.. + +.. bpo: 13169 +.. date: 7401 +.. nonce: txDMgH +.. section: Library + +The maximal repetition number in a regular expression has been increased +from 65534 to 2147483647 (on 32-bit platform) or 4294967294 (on 64-bit). + +.. + +.. bpo: 17143 +.. date: 7400 +.. nonce: HLnFxv +.. section: Library + +Fix a missing import in the trace module. Initial patch by Berker Peksag. + +.. + +.. bpo: 15220 +.. date: 7399 +.. nonce: 7GI-FE +.. section: Library + +email.feedparser's line splitting algorithm is now simpler and faster. + +.. + +.. bpo: 16743 +.. date: 7398 +.. nonce: 7vwfDN +.. section: Library + +Fix mmap overflow check on 32 bit Windows. + +.. + +.. bpo: 16996 +.. date: 7397 +.. nonce: HEPEjp +.. section: Library + +webbrowser module now uses shutil.which() to find a web-browser on the +executable search path. + +.. + +.. bpo: 16800 +.. date: 7396 +.. nonce: HxSo58 +.. section: Library + +tempfile.gettempdir() no longer left temporary files when the disk is full. +Original patch by Amir Szekely. + +.. + +.. bpo: 17192 +.. date: 7395 +.. nonce: f8i9hd +.. section: Library + +Import libffi-3.0.12. + +.. + +.. bpo: 16564 +.. date: 7394 +.. nonce: KBvsbB +.. section: Library + +Fixed regression relative to Python2 in the operation of +email.encoders.encode_7or8bit when used with binary data. + +.. + +.. bpo: 17052 +.. date: 7393 +.. nonce: TEWdzQ +.. section: Library + +unittest discovery should use self.testLoader. + +.. + +.. bpo: 4591 +.. date: 7392 +.. nonce: 9wJlD8 +.. section: Library + +Uid and gid values larger than 2**31 are supported now. + +.. + +.. bpo: 17141 +.. date: 7391 +.. nonce: wvMZ5Q +.. section: Library + +random.vonmisesvariate() no longer hangs for large kappas. + +.. + +.. bpo: 17149 +.. date: 7390 +.. nonce: _hUd7T +.. section: Library + +Fix random.vonmisesvariate to always return results in [0, 2*math.pi]. + +.. + +.. bpo: 1470548 +.. date: 7389 +.. nonce: vqnyer +.. section: Library + +XMLGenerator now works with binary output streams. + +.. + +.. bpo: 6975 +.. date: 7388 +.. nonce: 4GoPXW +.. section: Library + +os.path.realpath() now correctly resolves multiple nested symlinks on POSIX +platforms. + +.. + +.. bpo: 13773 +.. date: 7387 +.. nonce: SKb5ok +.. section: Library + +sqlite3.connect() gets a new `uri` parameter to pass the filename as a URI, +allowing custom options to be passed. + +.. + +.. bpo: 16564 +.. date: 7386 +.. nonce: 5RdAXG +.. section: Library + +Fixed regression relative to Python2 in the operation of +email.encoders.encode_noop when used with binary data. + +.. + +.. bpo: 10355 +.. date: 7385 +.. nonce: s_RAWf +.. section: Library + +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. + +.. + +.. bpo: 16686 +.. date: 7384 +.. nonce: zT_bpe +.. section: Library + +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. + +.. + +.. bpo: 17073 +.. date: 7383 +.. nonce: wlCar1 +.. section: Library + +Fix some integer overflows in sqlite3 module. + +.. + +.. bpo: 16723 +.. date: 7382 +.. nonce: q1Cw-s +.. section: Library + +httplib.HTTPResponse no longer marked closed when the connection is +automatically closed. + +.. + +.. bpo: 15359 +.. date: 7381 +.. nonce: UDphxr +.. section: Library + +Add CAN_BCM protocol support to the socket module. Patch by Brian Thorne. + +.. + +.. bpo: 16948 +.. date: 7380 +.. nonce: 8mm-53 +.. section: Library + +Fix quoted printable body encoding for non-latin1 character sets in the +email package. + +.. + +.. bpo: 16811 +.. date: 7379 +.. nonce: rlH6y6 +.. section: Library + +Fix folding of headers with no value in the provisional email policies. + +.. + +.. bpo: 17132 +.. date: 7378 +.. nonce: ebpN0J +.. section: Library + +Update symbol for "yield from" grammar changes. + +.. + +.. bpo: 17076 +.. date: 7377 +.. nonce: IOhR77 +.. section: Library + +Make copying of xattrs more tolerant of missing FS support. Patch by Thomas +Wouters. + +.. + +.. bpo: 17089 +.. date: 7376 +.. nonce: Z3-kED +.. section: Library + +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. + +.. + +.. bpo: 6083 +.. date: 7375 +.. nonce: MVAIwI +.. section: Library + +Fix multiple segmentation faults occurred when PyArg_ParseTuple parses +nested mutating sequence. + +.. + +.. bpo: 5289 +.. date: 7374 +.. nonce: 4azz2m +.. section: Library + +Fix ctypes.util.find_library on Solaris. + +.. + +.. bpo: 17106 +.. date: 7373 +.. nonce: -2_cbV +.. section: Library + +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). + +.. + +.. bpo: 17015 +.. date: 7372 +.. nonce: SzigPI +.. section: Library + +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. + +.. + +.. bpo: 15633 +.. date: 7371 +.. nonce: t407yZ +.. section: Library + +httplib.HTTPResponse is now mark closed when the server sends less than the +advertised Content-Length. + +.. + +.. bpo: 12268 +.. date: 7370 +.. nonce: sIHfGM +.. section: Library + +The io module file object write methods no longer abort early when one of +its write system calls is interrupted (EINTR). + +.. + +.. bpo: 6972 +.. date: 7369 +.. nonce: e2Lq4T +.. section: Library + +The zipfile module no longer overwrites files outside of its destination +path when extracting malicious zip files. + +.. + +.. bpo: 4844 +.. date: 7368 +.. nonce: ascNW4 +.. section: Library + +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. + +.. + +.. bpo: 17071 +.. date: 7367 +.. nonce: kRQAey +.. section: Library + +Signature.bind() now works when one of the keyword arguments is named +``self``. + +.. + +.. bpo: 12004 +.. date: 7366 +.. nonce: SAEl1I +.. section: Library + +Fix an internal error in PyZipFile when writing an invalid Python file. +Patch by Ben Morgan. + +.. + +.. bpo: 0 +.. date: 7365 +.. nonce: 4OOKnh +.. section: Library + +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. + +.. + +.. bpo: 16972 +.. date: 7364 +.. nonce: nEo5JN +.. section: Library + +Have site.addpackage() consider already known paths even when none are +explicitly passed in. Bug report and fix by Kirill. + +.. + +.. bpo: 1602133 +.. date: 7363 +.. nonce: lYqpUo +.. section: Library + +on Mac OS X a shared library build (``--enable-shared``) now fills the +``os.environ`` variable correctly. + +.. + +.. bpo: 15505 +.. date: 7362 +.. nonce: -pH9Mh +.. section: Library + +`unittest.installHandler` no longer assumes SIGINT handler is set to a +callable object. + +.. + +.. bpo: 13454 +.. date: 7361 +.. nonce: 81rUI- +.. section: Library + +Fix a crash when deleting an iterator created by itertools.tee() if all +other iterators were very advanced before. + +.. + +.. bpo: 12411 +.. date: 7360 +.. nonce: cw1MdL +.. section: Library + +Fix to cgi.parse_multipart to correctly use bytes boundaries and bytes data. +Patch by Jonas Wagner. + +.. + +.. bpo: 16957 +.. date: 7359 +.. nonce: ne-gBj +.. section: Library + +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. + +.. + +.. bpo: 1159051 +.. date: 7358 +.. nonce: 1KBJ6M +.. section: Library + +GzipFile now raises EOFError when reading a corrupted file with truncated +header or footer. + +.. + +.. bpo: 16993 +.. date: 7357 +.. nonce: L3OmWx +.. section: Library + +shutil.which() now preserves the case of the path and extension on Windows. + +.. + +.. bpo: 16992 +.. date: 7356 +.. nonce: s_RXIM +.. section: Library + +On Windows in signal.set_wakeup_fd, validate the file descriptor argument. + +.. + +.. bpo: 16422 +.. date: 7355 +.. nonce: SNwB1o +.. section: Library + +For compatibility with the Python version, the C version of decimal now uses +strings instead of integers for rounding mode constants. + +.. + +.. bpo: 15861 +.. date: 7354 +.. nonce: gGkxCM +.. section: Library + +tkinter now correctly works with lists and tuples containing strings with +whitespaces, backslashes or unbalanced braces. + +.. + +.. bpo: 9720 +.. date: 7353 +.. nonce: XPXDks +.. section: Library + +zipfile now writes correct local headers for files larger than 4 GiB. + +.. + +.. bpo: 16955 +.. date: 7352 +.. nonce: VD_jpc +.. section: Library + +Fix the poll() method for multiprocessing's socket connections on Windows. + +.. + +.. bpo: 0 +.. date: 7351 +.. nonce: PoQ__t +.. section: Library + +SSLContext.load_dh_params() now properly closes the input file. + +.. + +.. bpo: 15031 +.. date: 7350 +.. nonce: an2pG1 +.. section: Library + +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. + +.. + +.. bpo: 16398 +.. date: 7349 +.. nonce: JU7cL4 +.. section: Library + +Optimize deque.rotate() so that it only moves pointers and doesn't touch the +underlying data with increfs and decrefs. + +.. + +.. bpo: 16900 +.. date: 7348 +.. nonce: oyyCUi +.. section: Library + +Issue a ResourceWarning when an ssl socket is left unclosed. + +.. + +.. bpo: 13899 +.. date: 7347 +.. nonce: PJ5tHf +.. section: Library + +``\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. + +.. + +.. bpo: 15545 +.. date: 7346 +.. nonce: FCBNNV +.. section: Library + +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). + +.. + +.. bpo: 0 +.. date: 7345 +.. nonce: dEUst7 +.. section: Library + +fcntl: add F_DUPFD_CLOEXEC constant, available on Linux 2.6.24+. + +.. + +.. bpo: 15972 +.. date: 7344 +.. nonce: G3_6id +.. section: Library + +Fix error messages when os functions expecting a file name or file +descriptor receive the incorrect type. + +.. + +.. bpo: 8109 +.. date: 7343 +.. nonce: CbDLHH +.. section: Library + +The ssl module now has support for server-side SNI, thanks to a +:meth:`SSLContext.set_servername_callback` method. Patch by Daniel Black. + +.. + +.. bpo: 16860 +.. date: 7342 +.. nonce: W9CpNg +.. section: Library + +In tempfile, use O_CLOEXEC when available to set the close-on-exec flag +atomically. + +.. + +.. bpo: 16674 +.. date: 7341 +.. nonce: Q8wDpT +.. section: Library + +random.getrandbits() is now 20-40% faster for small integers. + +.. + +.. bpo: 16009 +.. date: 7340 +.. nonce: tTmrs1 +.. section: Library + +JSON error messages now provide more information. + +.. + +.. bpo: 16828 +.. date: 7339 +.. nonce: uSGRTZ +.. section: Library + +Fix error incorrectly raised by bz2.compress(b'') and +bz2.BZ2Compressor.compress(b''). Initial patch by Martin Packman. + +.. + +.. bpo: 16833 +.. date: 7338 +.. nonce: g0QSh5 +.. section: Library + +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. + +.. + +.. bpo: 16541 +.. date: 7337 +.. nonce: rfIhAb +.. section: Library + +tk_setPalette() now works with keyword arguments. + +.. + +.. bpo: 16820 +.. date: 7336 +.. nonce: e27ceV +.. section: Library + +In configparser, `parser.popitem()` no longer raises ValueError. This makes +`parser.clean()` work correctly. + +.. + +.. bpo: 16820 +.. date: 7335 +.. nonce: eSaGa4 +.. section: Library + +In configparser, ``parser['section'] = {}`` now preserves section order +within the parser. This makes `parser.update()` preserve section order as +well. + +.. + +.. bpo: 16820 +.. date: 7334 +.. nonce: yk3gzb +.. section: Library + +In configparser, ``parser['DEFAULT'] = {}`` now correctly clears previous +values stored in the default section. Same goes for +``parser.update({'DEFAULT': {}})``. + +.. + +.. bpo: 9586 +.. date: 7333 +.. nonce: 9tuKgR +.. section: Library + +Redefine SEM_FAILED on MacOSX to keep compiler happy. + +.. + +.. bpo: 16787 +.. date: 7332 +.. nonce: H5R03d +.. section: Library + +Increase asyncore and asynchat default output buffers size, to decrease CPU +usage and increase throughput. + +.. + +.. bpo: 10527 +.. date: 7331 +.. nonce: 7btVvN +.. section: Library + +make multiprocessing use poll() instead of select() if available. + +.. + +.. bpo: 16688 +.. date: 7330 +.. nonce: V4uNMo +.. section: Library + +Now regexes contained backreferences correctly work with non-ASCII strings. +Patch by Matthew Barnett. + +.. + +.. bpo: 16486 +.. date: 7329 +.. nonce: bfM62e +.. section: Library + +Make aifc files act as context managers. + +.. + +.. bpo: 16485 +.. date: 7328 +.. nonce: aUJyTZ +.. section: Library + +Now file descriptors are closed if file header patching failed on closing an +aifc file. + +.. + +.. bpo: 16640 +.. date: 7327 +.. nonce: uijEnP +.. section: Library + +Run less code under a lock in sched module. + +.. + +.. bpo: 16165 +.. date: 7326 +.. nonce: QuZOIy +.. section: Library + +sched.scheduler.run() no longer blocks a scheduler for other threads. + +.. + +.. bpo: 16641 +.. date: 7325 +.. nonce: JYpAhs +.. section: Library + +Default values of sched.scheduler.enter() are no longer modifiable. + +.. + +.. bpo: 16618 +.. date: 7324 +.. nonce: lo3BQu +.. section: Library + +Make glob.glob match consistently across strings and bytes regarding leading +dots. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16788 +.. date: 7323 +.. nonce: Os6OJu +.. section: Library + +Add samestat to Lib/ntpath.py + +.. + +.. bpo: 16713 +.. date: 7322 +.. nonce: Mq84Hq +.. section: Library + +Parsing of 'tel' urls using urlparse separates params from path. + +.. + +.. bpo: 16443 +.. date: 7321 +.. nonce: SnGosi +.. section: Library + +Add docstrings to regular expression match objects. Patch by Anton Kasyanov. + +.. + +.. bpo: 15701 +.. date: 7320 +.. nonce: rAh1Sy +.. section: Library + +Fix HTTPError info method call to return the headers information. + +.. + +.. bpo: 16752 +.. date: 7319 +.. nonce: gIWkHK +.. section: Library + +Add a missing import to modulefinder. Patch by Berker Peksag. + +.. + +.. bpo: 16646 +.. date: 7318 +.. nonce: Tc3vsq +.. section: Library + +ftplib.FTP.makeport() might lose socket error details. (patch by Serhiy +Storchaka) + +.. + +.. bpo: 16626 +.. date: 7317 +.. nonce: P9xKcu +.. section: Library + +Fix infinite recursion in glob.glob() on Windows when the pattern contains a +wildcard in the drive or UNC path. Patch by Serhiy Storchaka. + +.. + +.. bpo: 15783 +.. date: 7316 +.. nonce: y8LbED +.. section: Library + +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. + +.. + +.. bpo: 11175 +.. date: 7315 +.. nonce: T80G4_ +.. section: Library + +argparse.FileType now accepts encoding and errors arguments. Patch by Lucas +Maystre. + +.. + +.. bpo: 16488 +.. date: 7314 +.. nonce: SeOkz0 +.. section: Library + +epoll() objects now support the `with` statement. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 16298 +.. date: 7313 +.. nonce: kN3o52 +.. section: Library + +In HTTPResponse.read(), close the socket when there is no Content-Length and +the incoming stream is finished. Patch by Eran Rundstein. + +.. + +.. bpo: 16049 +.. date: 7312 +.. nonce: HeaoM8 +.. section: Library + +Add abc.ABC class to enable the use of inheritance to create ABCs, rather +than the more cumbersome metaclass=ABCMeta. Patch by Bruno Dupuis. + +.. + +.. bpo: 0 +.. date: 7311 +.. nonce: 0T54b0 +.. section: Library + +Expose the TCP_FASTOPEN and MSG_FASTOPEN flags in socket when they're +available. + +.. + +.. bpo: 15701 +.. date: 7310 +.. nonce: 7KaZjl +.. section: Library + +Add a .headers attribute to urllib.error.HTTPError. Patch contributed by +Berker Peksag. + +.. + +.. bpo: 15872 +.. date: 7309 +.. nonce: hPj0NT +.. section: Library + +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. + +.. + +.. bpo: 16248 +.. date: 7308 +.. nonce: yOopnt +.. section: Library + +Disable code execution from the user's home directory by tkinter when the -E +flag is passed to Python. Patch by Zachary Ware. + +.. + +.. bpo: 13390 +.. date: 7307 +.. nonce: Oj2WC_ +.. section: Library + +New function :func:`sys.getallocatedblocks()` returns the number of memory +blocks currently allocated. + +.. + +.. bpo: 16628 +.. date: 7306 +.. nonce: qnWML3 +.. section: Library + +Fix a memory leak in ctypes.resize(). + +.. + +.. bpo: 13614 +.. date: 7305 +.. nonce: buqA2j +.. section: Library + +Fix setup.py register failure with invalid rst in description. Patch by +Julien Courteau and Pierre Paul Lefebvre. + +.. + +.. bpo: 13512 +.. date: 7304 +.. nonce: KW8Du9 +.. section: Library + +Create ~/.pypirc securely (CVE-2011-4944). Initial patch by Philip Jenvey, +tested by Mageia and Debian. + +.. + +.. bpo: 7719 +.. date: 7303 +.. nonce: O-kdp6 +.. section: Library + +Make distutils ignore ``.nfs*`` files instead of choking later on. Initial +patch by SilentGhost and Jeff Ramnani. + +.. + +.. bpo: 13120 +.. date: 7302 +.. nonce: 3PKTDf +.. section: Library + +Allow calling pdb.set_trace() from thread. Patch by Ilya Sandler. + +.. + +.. bpo: 16585 +.. date: 7301 +.. nonce: f_MHWg +.. section: Library + +Make CJK encoders support error handlers that return bytes per PEP 383. + +.. + +.. bpo: 10182 +.. date: 7300 +.. nonce: 0nH79H +.. section: Library + +The re module doesn't truncate indices to 32 bits anymore. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 16333 +.. date: 7299 +.. nonce: 8YUVkp +.. section: Library + +use (",", ": ") as default separator in json when indent is specified, to +avoid trailing whitespace. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16573 +.. date: 7298 +.. nonce: kKjx72 +.. section: Library + +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(). + +.. + +.. bpo: 16464 +.. date: 7297 +.. nonce: fcgAzt +.. section: Library + +Reset the Content-Length header when a urllib Request is reused with new +data. + +.. + +.. bpo: 12848 +.. date: 7296 +.. nonce: gGAbLz +.. section: Library + +The pure Python pickle implementation now treats object lengths as unsigned +32-bit integers, like the C implementation does. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16423 +.. date: 7295 +.. nonce: ZVmUs3 +.. section: Library + +urllib.request now has support for ``data:`` URLs. Patch by Mathias +Panzenb?ck. + +.. + +.. bpo: 4473 +.. date: 7294 +.. nonce: 3tTGZx +.. section: Library + +Add a POP3.stls() to switch a clear-text POP3 session into an encrypted POP3 +session, on supported servers. Patch by Lorenzo Catucci. + +.. + +.. bpo: 4473 +.. date: 7293 +.. nonce: BcE9oH +.. section: Library + +Add a POP3.capa() method to query the capabilities advertised by the POP3 +server. Patch by Lorenzo Catucci. + +.. + +.. bpo: 4473 +.. date: 7292 +.. nonce: dU-l8q +.. section: Library + +Ensure the socket is shutdown cleanly in POP3.close(). Patch by Lorenzo +Catucci. + +.. + +.. bpo: 16522 +.. date: 7291 +.. nonce: NIzWem +.. section: Library + +added FAIL_FAST flag to doctest. + +.. + +.. bpo: 15627 +.. date: 7290 +.. nonce: 4PHtp9 +.. section: Library + +Add the importlib.abc.InspectLoader.source_to_code() method. + +.. + +.. bpo: 16408 +.. date: 7289 +.. nonce: iqzks4 +.. section: Library + +Fix file descriptors not being closed in error conditions in the zipfile +module. Patch by Serhiy Storchaka. + +.. + +.. bpo: 14631 +.. date: 7288 +.. nonce: -GSQmy +.. section: Library + +Add a new :class:`weakref.WeakMethod` to simulate weak references to bound +methods. + +.. + +.. bpo: 16469 +.. date: 7287 +.. nonce: Od7MLh +.. section: Library + +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. + +.. + +.. bpo: 16481 +.. date: 7286 +.. nonce: TsOri8 +.. section: Library + +multiprocessing no longer leaks process handles on Windows. + +.. + +.. bpo: 12428 +.. date: 7285 +.. nonce: wo0Z3V +.. section: Library + +Add a pure Python implementation of functools.partial(). Patch by Brian +Thorne. + +.. + +.. bpo: 16140 +.. date: 7284 +.. nonce: lszQfR +.. section: Library + +The subprocess module no longer double closes its child subprocess.PIPE +parent file descriptors on child error prior to exec(). + +.. + +.. bpo: 0 +.. date: 7283 +.. nonce: G2vxaZ +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 7282 +.. nonce: Kf0oN- +.. section: Library + +The subprocess module now raises its own SubprocessError instead of a +RuntimeError in various error situations which should not normally happen. + +.. + +.. bpo: 16327 +.. date: 7281 +.. nonce: uVAHv3 +.. section: Library + +The subprocess module no longer leaks file descriptors used for +stdin/stdout/stderr pipes to the child when fork() fails. + +.. + +.. bpo: 14396 +.. date: 7280 +.. nonce: aUgPuV +.. section: Library + +Handle the odd rare case of waitpid returning 0 when not expected in +subprocess.Popen.wait(). + +.. + +.. bpo: 16411 +.. date: 7279 +.. nonce: 9Mn07O +.. section: Library + +Fix a bug where zlib.decompressobj().flush() might try to access previously- +freed memory. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16357 +.. date: 7278 +.. nonce: JSAbxU +.. section: Library + +fix calling accept() on a SSLSocket created through +SSLContext.wrap_socket(). Original patch by Jeff McNeil. + +.. + +.. bpo: 16409 +.. date: 7277 +.. nonce: Q4-W9i +.. section: Library + +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. + +.. + +.. bpo: 16431 +.. date: 7276 +.. nonce: e4cPCA +.. section: Library + +Use the type information when constructing a Decimal subtype from a Decimal +argument. + +.. + +.. bpo: 15641 +.. date: 7275 +.. nonce: vCK1I7 +.. section: Library + +Clean up deprecated classes from importlib. Patch by Taras Lyapun. + +.. + +.. bpo: 16350 +.. date: 7274 +.. nonce: b77tF6 +.. section: Library + +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. + +.. + +.. bpo: 12759 +.. date: 7273 +.. nonce: c7p8aw +.. section: Library + +sre_parse now raises a proper error when the name of the group is missing. +Initial patch by Serhiy Storchaka. + +.. + +.. bpo: 16152 +.. date: 7272 +.. nonce: Lypvsp +.. section: Library + +fix tokenize to ignore whitespace at the end of the code when no newline is +found. Patch by Ned Batchelder. + +.. + +.. bpo: 16284 +.. date: 7271 +.. nonce: fNPApL +.. section: Library + +Prevent keeping unnecessary references to worker functions in +concurrent.futures ThreadPoolExecutor. + +.. + +.. bpo: 16230 +.. date: 7270 +.. nonce: Y7XU0- +.. section: Library + +Fix a crash in select.select() when one of the lists changes size while +iterated on. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16228 +.. date: 7269 +.. nonce: zsna-8 +.. section: Library + +Fix a crash in the json module where a list changes size while it is being +encoded. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16351 +.. date: 7268 +.. nonce: pm5Uwv +.. section: Library + +New function gc.get_stats() returns per-generation collection statistics. + +.. + +.. bpo: 14897 +.. date: 7267 +.. nonce: OGbALj +.. section: Library + +Enhance error messages of struct.pack and struct.pack_into. Patch by Matti +M?ki. + +.. + +.. bpo: 16316 +.. date: 7266 +.. nonce: JuyfbK +.. section: Library + +mimetypes now recognizes the .xz and .txz (.tar.xz) extensions. Patch by +Serhiy Storchaka. + +.. + +.. bpo: 12890 +.. date: 7265 +.. nonce: kDaDxa +.. section: Library + +cgitb no longer prints spurious

tags in text mode when the logdir option +is specified. + +.. + +.. bpo: 16307 +.. date: 7264 +.. nonce: a50VwB +.. section: Library + +Fix multiprocessing.Pool.map_async not calling its callbacks. Patch by Janne +Karila. + +.. + +.. bpo: 16305 +.. date: 7263 +.. nonce: 16wmhi +.. section: Library + +Fix a segmentation fault occurring when interrupting math.factorial. + +.. + +.. bpo: 16116 +.. date: 7262 +.. nonce: vgGtQF +.. section: Library + +Fix include and library paths to be correct when building C extensions in +venvs. + +.. + +.. bpo: 16245 +.. date: 7261 +.. nonce: kJSC-a +.. section: Library + +Fix the value of a few entities in html.entities.html5. + +.. + +.. bpo: 16301 +.. date: 7260 +.. nonce: hBD_Yq +.. section: Library + +Fix the localhost verification in urllib/request.py for ``file://`` urls. + +.. + +.. bpo: 16250 +.. date: 7259 +.. nonce: ieVkF0 +.. section: Library + +Fix the invocations of URLError which had misplaced filename attribute for +exception. + +.. + +.. bpo: 10836 +.. date: 7258 +.. nonce: Jh2ffY +.. section: Library + +Fix exception raised when file not found in urlretrieve Initial patch by +Ezio Melotti. + +.. + +.. bpo: 14398 +.. date: 7257 +.. nonce: jPT4ME +.. section: Library + +Fix size truncation and overflow bugs in the bz2 module. + +.. + +.. bpo: 12692 +.. date: 7256 +.. nonce: 2Mzlsy +.. section: Library + +Fix resource leak in urllib.request when talking to an HTTP server that does +not include a ``Connection: close`` header in its responses. + +.. + +.. bpo: 12034 +.. date: 7255 +.. nonce: btn3x3 +.. section: Library + +Fix bogus caching of result in check_GetFinalPathNameByHandle. Patch by +Atsuo Ishimoto. + +.. + +.. bpo: 0 +.. date: 7254 +.. nonce: D_nbXg +.. section: Library + +Improve performance of `lzma.LZMAFile` (see also issue #16034). + +.. + +.. bpo: 16220 +.. date: 7253 +.. nonce: KAtvbg +.. section: Library + +wsgiref now always calls close() on an iterable response. Patch by Brent +Tubbs. + +.. + +.. bpo: 16270 +.. date: 7252 +.. nonce: O-WZPm +.. section: Library + +urllib may hang when used for retrieving files via FTP by using a context +manager. Patch by Giampaolo Rodola'. + +.. + +.. bpo: 16461 +.. date: 7251 +.. nonce: 4XLB7L +.. section: Library + +Wave library should be able to deal with 4GB wav files, and sample rate of +44100 Hz. + +.. + +.. bpo: 16176 +.. date: 7250 +.. nonce: iZz-x5 +.. section: Library + +Properly identify Windows 8 via platform.platform() + +.. + +.. bpo: 16088 +.. date: 7249 +.. nonce: 9zmUAz +.. section: Library + +BaseHTTPRequestHandler's send_error method includes a Content-Length header +in its response now. Patch by Antoine Pitrou. + +.. + +.. bpo: 16114 +.. date: 7248 +.. nonce: 99pl4N +.. section: Library + +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. + +.. + +.. bpo: 16169 +.. date: 7247 +.. nonce: zjnL7m +.. section: Library + +Fix ctypes.WinError()'s confusion between errno and winerror. + +.. + +.. bpo: 16110 +.. date: 7246 +.. nonce: fJpUiF +.. section: Library + +logging.fileConfig now accepts a pre-initialised ConfigParser instance. + +.. + +.. bpo: 1492704 +.. date: 7245 +.. nonce: 9rDdhr +.. section: Library + +shutil.copyfile() raises a distinct SameFileError now if source and +destination are the same file. Patch by Atsuo Ishimoto. + +.. + +.. bpo: 13896 +.. date: 7244 +.. nonce: iM0TJp +.. section: Library + +Make shelf instances work with 'with' as context managers. Original patch by +Filip Gruszczy?ski. + +.. + +.. bpo: 15417 +.. date: 7243 +.. nonce: Rd0mDH +.. section: Library + +Add support for csh and fish in venv activation scripts. + +.. + +.. bpo: 14377 +.. date: 7242 +.. nonce: P85CJN +.. section: Library + +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. + +.. + +.. bpo: 16089 +.. date: 7241 +.. nonce: L9jCK7 +.. section: Library + +Allow ElementTree.TreeBuilder to work again with a non-Element +element_factory (fixes a regression in SimpleTAL). + +.. + +.. bpo: 9650 +.. date: 7240 +.. nonce: cENePt +.. section: Library + +List commonly used format codes in time.strftime and time.strptime +docsttings. Original patch by Mike Hoy. + +.. + +.. bpo: 15452 +.. date: 7239 +.. nonce: qqK1EO +.. section: Library + +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. + +.. + +.. bpo: 16034 +.. date: 7238 +.. nonce: E_ZhP2 +.. section: Library + +Fix performance regressions in the new `bz2.BZ2File` implementation. +Initial patch by Serhiy Storchaka. + +.. + +.. bpo: 0 +.. date: 7237 +.. nonce: f4R5V2 +.. section: Library + +`pty.spawn()` now returns the child process status returned by +`os.waitpid()`. + +.. + +.. bpo: 15756 +.. date: 7236 +.. nonce: WAeC4R +.. section: Library + +`subprocess.poll()` now properly handles `errno.ECHILD` to return a +returncode of 0 when the child has already exited or cannot be waited on. + +.. + +.. bpo: 15323 +.. date: 7235 +.. nonce: L4bD_6 +.. section: Library + +Improve failure message of `Mock.assert_called_once_with()`. + +.. + +.. bpo: 16064 +.. date: 7234 +.. nonce: oSOZ0F +.. section: Library + +``unittest -m`` claims executable is "python", not "python3". + +.. + +.. bpo: 12376 +.. date: 7233 +.. nonce: XQz0f2 +.. section: Library + +Pass on parameters in `TextTestResult.__init__()` super call. + +.. + +.. bpo: 15222 +.. date: 7232 +.. nonce: 1KFZ58 +.. section: Library + +Insert blank line after each message in mbox mailboxes. + +.. + +.. bpo: 16013 +.. date: 7231 +.. nonce: QtdOeT +.. section: Library + +Fix `csv.Reader` parsing issue with ending quote characters. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 15421 +.. date: 7230 +.. nonce: bS-Hq5 +.. section: Library + +Fix an OverflowError in `Calendar.itermonthdates()` after +`datetime.MAXYEAR`. Patch by C?dric Krier. + +.. + +.. bpo: 16112 +.. date: 7229 +.. nonce: 7UQthq +.. section: Library + +platform.architecture does not correctly escape argument to /usr/bin/file. +Patch by David Benjamin. + +.. + +.. bpo: 15970 +.. date: 7228 +.. nonce: -hD9Ha +.. section: Library + +`xml.etree.ElementTree` now serializes correctly the empty HTML elements +'meta' and 'param'. + +.. + +.. bpo: 15842 +.. date: 7227 +.. nonce: _Kzj4o +.. section: Library + +The `SocketIO.{readable,writable,seekable}` methods now raise ValueError +when the file-like object is closed. Patch by Alessandro Moura. + +.. + +.. bpo: 15876 +.. date: 7226 +.. nonce: hMWNMn +.. section: Library + +Fix a refleak in the `curses` module: window.encoding. + +.. + +.. bpo: 15881 +.. date: 7225 +.. nonce: 0CCbVo +.. section: Library + +Fix `atexit` hook in `multiprocessing`. Original patch by Chris McDonough. + +.. + +.. bpo: 15841 +.. date: 7224 +.. nonce: UVh8eH +.. section: Library + +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. + +.. + +.. bpo: 15447 +.. date: 7223 +.. nonce: bdNIb1 +.. section: Library + +Use `subprocess.DEVNULL` in webbrowser, instead of opening `os.devnull` +explicitly and leaving it open. + +.. + +.. bpo: 15509 +.. date: 7222 +.. nonce: q1hQFS +.. section: Library + +`webbrowser.UnixBrowser` no longer passes empty arguments to Popen when +``%action`` substitutions produce empty strings. + +.. + +.. bpo: 12776 +.. date: 7221 +.. nonce: XiJzFk +.. section: Library + +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. (See also: +bpo-11839) + +.. + +.. bpo: 15906 +.. date: 7220 +.. nonce: qeshwx +.. section: Library + +Fix a regression in argparse caused by the preceding change, when +``action='append'``, ``type='str'`` and ``default=[]``. + +.. + +.. bpo: 16113 +.. date: 7219 +.. nonce: tpf8Os +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 7218 +.. nonce: t35X7X +.. section: Library + +ctypes.call_commethod was removed, since its only usage was in the defunct +samples directory. + +.. + +.. bpo: 16692 +.. date: 7217 +.. nonce: Hh7vnr +.. section: Library + +Added TLSv1.1 and TLSv1.2 support for the ssl modules. + +.. + +.. bpo: 16832 +.. date: 7216 +.. nonce: D7LpUw +.. section: Library + +add abc.get_cache_token() to expose cache validity checking support in +ABCMeta. + +.. + +.. bpo: 18429 +.. date: 7215 +.. nonce: F1lTq1 +.. section: IDLE + +Format / Format Paragraph, now works when comment blocks are selected. As +with text blocks, this works best when the selection only includes complete +lines. + +.. + +.. bpo: 18226 +.. date: 7214 +.. nonce: 5HtrW1 +.. section: IDLE + +Add docstrings and unittests for FormatParagraph.py. Original patches by +Todd Rovito and Phil Webster. + +.. + +.. bpo: 18279 +.. date: 7213 +.. nonce: UoF-oR +.. section: IDLE + +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). + +.. + +.. bpo: 7136 +.. date: 7212 +.. nonce: 7horQf +.. section: IDLE + +In the Idle File menu, "New Window" is renamed "New File". Patch by Tal +Einat, Roget Serwy, and Todd Rovito. + +.. + +.. bpo: 0 +.. date: 7211 +.. nonce: OsJiav +.. section: IDLE + +Remove dead imports of imp. + +.. + +.. bpo: 18196 +.. date: 7210 +.. nonce: hyO7x0 +.. section: IDLE + +Avoid displaying spurious SystemExit tracebacks. + +.. + +.. bpo: 5492 +.. date: 7209 +.. nonce: LCx7lq +.. section: IDLE + +Avoid traceback when exiting IDLE caused by a race condition. + +.. + +.. bpo: 17511 +.. date: 7208 +.. nonce: 6XqdTH +.. section: IDLE + +Keep IDLE find dialog open after clicking "Find Next". Original patch by +Sarah K. + +.. + +.. bpo: 18055 +.. date: 7207 +.. nonce: e6MZXb +.. section: IDLE + +Move IDLE off of imp and on to importlib. + +.. + +.. bpo: 15392 +.. date: 7206 +.. nonce: ukT_lg +.. section: IDLE + +Create a unittest framework for IDLE. Initial patch by Rajagopalasarma +Jayakrishnan. See Lib/idlelib/idle_test/README.txt for how to run Idle +tests. + +.. + +.. bpo: 14146 +.. date: 7205 +.. nonce: -n5gzd +.. section: IDLE + +Highlight source line while debugging on Windows. + +.. + +.. bpo: 17838 +.. date: 7204 +.. nonce: -DDdhT +.. section: IDLE + +Allow sys.stdin to be reassigned. + +.. + +.. bpo: 13495 +.. date: 7203 +.. nonce: CqEc2d +.. section: IDLE + +Avoid loading the color delegator twice in IDLE. + +.. + +.. bpo: 17798 +.. date: 7202 +.. nonce: PVfMob +.. section: IDLE + +Allow IDLE to edit new files when specified on command line. + +.. + +.. bpo: 14735 +.. date: 7201 +.. nonce: lbbw49 +.. section: IDLE + +Update IDLE docs to omit "Control-z on Windows". + +.. + +.. bpo: 17532 +.. date: 7200 +.. nonce: wgA70Z +.. section: IDLE + +Always include Options menu for IDLE on OS X. Patch by Guilherme Sim?es. + +.. + +.. bpo: 17585 +.. date: 7199 +.. nonce: oXlcVX +.. section: IDLE + +Fixed IDLE regression. Now closes when using exit() or quit(). + +.. + +.. bpo: 17657 +.. date: 7198 +.. nonce: rGfxNo +.. section: IDLE + +Show full Tk version in IDLE's about dialog. Patch by Todd Rovito. + +.. + +.. bpo: 17613 +.. date: 7197 +.. nonce: MfAJ31 +.. section: IDLE + +Prevent traceback when removing syntax colorizer in IDLE. + +.. + +.. bpo: 1207589 +.. date: 7196 +.. nonce: wqzkjh +.. section: IDLE + +Backwards-compatibility patch for right-click menu in IDLE. + +.. + +.. bpo: 16887 +.. date: 7195 +.. nonce: -tb-0g +.. section: IDLE + +IDLE now accepts Cancel in tabify/untabify dialog box. + +.. + +.. bpo: 17625 +.. date: 7194 +.. nonce: SoDm9J +.. section: IDLE + +In IDLE, close the replace dialog after it is used. + +.. + +.. bpo: 14254 +.. date: 7193 +.. nonce: heeMG- +.. section: IDLE + +IDLE now handles readline correctly across shell restarts. + +.. + +.. bpo: 17614 +.. date: 7192 +.. nonce: 9pmpYW +.. section: IDLE + +IDLE no longer raises exception when quickly closing a file. + +.. + +.. bpo: 6698 +.. date: 7191 +.. nonce: fXoiv2 +.. section: IDLE + +IDLE now opens just an editor window when configured to do so. + +.. + +.. bpo: 8900 +.. date: 7190 +.. nonce: jkW99r +.. section: IDLE + +Using keyboard shortcuts in IDLE to open a file no longer raises an +exception. + +.. + +.. bpo: 6649 +.. date: 7189 +.. nonce: uwGice +.. section: IDLE + +Fixed missing exit status in IDLE. Patch by Guilherme Polo. + +.. + +.. bpo: 17114 +.. date: 7188 +.. nonce: vKMHae +.. section: IDLE + +IDLE now uses non-strict config parser. + +.. + +.. bpo: 9290 +.. date: 7187 +.. nonce: Msbacw +.. section: IDLE + +In IDLE the sys.std* streams now implement io.TextIOBase interface and +support all mandatory methods and properties. + +.. + +.. bpo: 5066 +.. date: 7186 +.. nonce: 005zjD +.. section: IDLE + +Update IDLE docs. Patch by Todd Rovito. + +.. + +.. bpo: 16829 +.. date: 7185 +.. nonce: u44Uel +.. section: IDLE + +IDLE printing no longer fails if there are spaces or other special +characters in the file path. + +.. + +.. bpo: 16491 +.. date: 7184 +.. nonce: xeXwAA +.. section: IDLE + +IDLE now prints chained exception tracebacks. + +.. + +.. bpo: 16819 +.. date: 7183 +.. nonce: xEntNh +.. section: IDLE + +IDLE method completion now correctly works for bytes literals. + +.. + +.. bpo: 16504 +.. date: 7182 +.. nonce: othtN_ +.. section: IDLE + +IDLE now catches SyntaxErrors raised by tokenizer. Patch by Roger Serwy. + +.. + +.. bpo: 16511 +.. date: 7181 +.. nonce: yFDlh7 +.. section: IDLE + +Use default IDLE width and height if config param is not valid. Patch Serhiy +Storchaka. + +.. + +.. bpo: 1207589 +.. date: 7180 +.. nonce: 0bmiue +.. section: IDLE + +Add Cut/Copy/Paste items to IDLE right click Context Menu. Patch by Todd +Rovito. + +.. + +.. bpo: 16123 +.. date: 7179 +.. nonce: btKEXc +.. section: IDLE + +IDLE - deprecate running without a subprocess. Patch by Roger Serwy. + +.. + +.. bpo: 1666318 +.. date: 7178 +.. nonce: OPrK2i +.. section: Tests + +Add a test that shutil.copytree() retains directory permissions. Patch by +Catherine Devlin. + +.. + +.. bpo: 18273 +.. date: 7177 +.. nonce: t4fyCm +.. section: Tests + +move the tests in Lib/test/json_tests to Lib/test/test_json and make them +discoverable by unittest. Patch by Zachary Ware. + +.. + +.. bpo: 0 +.. date: 7176 +.. nonce: wExQ77 +.. section: Tests + +Fix a fcntl test case on KFreeBSD, Debian #708653 (Petr Salinger). + +.. + +.. bpo: 18396 +.. date: 7175 +.. nonce: 3gPC49 +.. section: Tests + +Fix spurious test failure in test_signal on Windows when faulthandler is +enabled (Patch by Jeremy Kloth) + +.. + +.. bpo: 17046 +.. date: 7174 +.. nonce: mQoh7R +.. section: Tests + +Fix broken test_executable_without_cwd in test_subprocess. + +.. + +.. bpo: 15415 +.. date: 7173 +.. nonce: u-UTrH +.. section: Tests + +Add new temp_dir() and change_cwd() context managers to test.support, and +refactor temp_cwd() to use them. Patch by Chris Jerdonek. + +.. + +.. bpo: 15494 +.. date: 7172 +.. nonce: 52m-vd +.. section: Tests + +test.support is now a package rather than a module (Initial patch by Indra +Talip) + +.. + +.. bpo: 17944 +.. date: 7171 +.. nonce: 6e9wcJ +.. section: Tests + +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. + +.. + +.. bpo: 18266 +.. date: 7170 +.. nonce: Fs0fT4 +.. section: Tests + +test_largefile now works with unittest test discovery and supports running +only selected tests. Patch by Zachary Ware. + +.. + +.. bpo: 17767 +.. date: 7169 +.. nonce: rObwV7 +.. section: Tests + +test_locale now works with unittest test discovery. Original patch by +Zachary Ware. + +.. + +.. bpo: 18375 +.. date: 7168 +.. nonce: yMrtSQ +.. section: Tests + +Assume --randomize when --randseed is used for running the testsuite. + +.. + +.. bpo: 11185 +.. date: 7167 +.. nonce: McIHeT +.. section: Tests + +Fix test_wait4 under AIX. Patch by S?bastien Sabl?. + +.. + +.. bpo: 18207 +.. date: 7166 +.. nonce: QN93aB +.. section: Tests + +Fix test_ssl for some versions of OpenSSL that ignore seconds in ASN1_TIME +fields. + +.. + +.. bpo: 18094 +.. date: 7165 +.. nonce: EDwnjd +.. section: Tests + +test_uuid no longer reports skipped tests as passed. + +.. + +.. bpo: 17992 +.. date: 7164 +.. nonce: UQQWYc +.. section: Tests + +Add timeouts to asyncore and asynchat tests so that they won't accidentally +hang. + +.. + +.. bpo: 17833 +.. date: 7163 +.. nonce: AqQAlk +.. section: Tests + +Fix test_gdb failures seen on machines where debug symbols for glibc are +available (seen on PPC64 Linux). + +.. + +.. bpo: 7855 +.. date: 7162 +.. nonce: ZbX91d +.. section: Tests + +Add tests for ctypes/winreg for issues found in IronPython. Initial patch by +Dino Viehland. + +.. + +.. bpo: 11078 +.. date: 7161 +.. nonce: TuZjxB +.. section: Tests + +test___all__ now checks for duplicates in __all__. Initial patch by R. David +Murray. + +.. + +.. bpo: 17712 +.. date: 7160 +.. nonce: RqkHUB +.. section: Tests + +Fix test_gdb failures on Ubuntu 13.04. + +.. + +.. bpo: 17835 +.. date: 7159 +.. nonce: mJdR71 +.. section: Tests + +Fix test_io when the default OS pipe buffer size is larger than one million +bytes. + +.. + +.. bpo: 17065 +.. date: 7158 +.. nonce: rql8lF +.. section: Tests + +Use process-unique key for winreg tests to avoid failures if test is run +multiple times in parallel (eg: on a buildbot host). + +.. + +.. bpo: 12820 +.. date: 7157 +.. nonce: HATljf +.. section: Tests + +add tests for the xml.dom.minicompat module. Patch by John Chandler and Phil +Connell. + +.. + +.. bpo: 17691 +.. date: 7156 +.. nonce: KHFcyE +.. section: Tests + +test_univnewlines now works with unittest test discovery. Patch by Zachary +Ware. + +.. + +.. bpo: 17790 +.. date: 7155 +.. nonce: JJXcrD +.. section: Tests + +test_set now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17789 +.. date: 7154 +.. nonce: ILUl9_ +.. section: Tests + +test_random now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17779 +.. date: 7153 +.. nonce: f61EJr +.. section: Tests + +test_osx_env now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17766 +.. date: 7152 +.. nonce: fGhYwN +.. section: Tests + +test_iterlen now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17690 +.. date: 7151 +.. nonce: Tm3Owh +.. section: Tests + +test_time now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17692 +.. date: 7150 +.. nonce: 6eSLWJ +.. section: Tests + +test_sqlite now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 11995 +.. date: 7149 +.. nonce: varfN1 +.. section: Tests + +test_pydoc doesn't import all sys.path modules anymore. + +.. + +.. bpo: 17448 +.. date: 7148 +.. nonce: E2kxQS +.. section: Tests + +test_sax now skips if there are no xml parsers available instead of raising +an ImportError. + +.. + +.. bpo: 11420 +.. date: 7147 +.. nonce: J5oaxT +.. section: Tests + +make test suite pass with -B/DONTWRITEBYTECODE set. Initial patch by Thomas +Wouters. + +.. + +.. bpo: 10652 +.. date: 7146 +.. nonce: hWhWD_ +.. section: Tests + +make tcl/tk tests run after __all__ test, patch by Zachary Ware. + +.. + +.. bpo: 11963 +.. date: 7145 +.. nonce: _g8d_g +.. section: Tests + +remove human verification from test_parser and test_subprocess. + +.. + +.. bpo: 11732 +.. date: 7144 +.. nonce: c8z-Dq +.. section: Tests + +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. + +.. + +.. bpo: 13898 +.. date: 7143 +.. nonce: HeB5Ep +.. section: Tests + +test_ssl no longer prints a spurious stack trace on Ubuntu. + +.. + +.. bpo: 17283 +.. date: 7142 +.. nonce: rDD37m +.. section: Tests + +Share code between `__main__.py` and `regrtest.py` in `Lib/test`. + +.. + +.. bpo: 17249 +.. date: 7141 +.. nonce: wGvw7G +.. section: Tests + +convert a test in test_capi to use unittest and reap threads. + +.. + +.. bpo: 17107 +.. date: 7140 +.. nonce: rQeSWM +.. section: Tests + +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. + +.. + +.. bpo: 17041 +.. date: 7139 +.. nonce: QNrBhm +.. section: Tests + +Fix testing when Python is configured with the --without-doc-strings. + +.. + +.. bpo: 16923 +.. date: 7138 +.. nonce: gK2bSh +.. section: Tests + +Fix ResourceWarnings in test_ssl. + +.. + +.. bpo: 15539 +.. date: 7137 +.. nonce: a1_G0Q +.. section: Tests + +Added regression tests for Tools/scripts/pindent.py. + +.. + +.. bpo: 17479 +.. date: 7136 +.. nonce: e2vj2q +.. section: Tests + +test_io now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17066 +.. date: 7135 +.. nonce: 6axkCO +.. section: Tests + +test_robotparser now works with unittest test discovery. Patch by Zachary +Ware. + +.. + +.. bpo: 17334 +.. date: 7134 +.. nonce: hOeO8N +.. section: Tests + +test_index now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17333 +.. date: 7133 +.. nonce: wKzaNc +.. section: Tests + +test_imaplib now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17082 +.. date: 7132 +.. nonce: B-o8aq +.. section: Tests + +test_dbm* now work with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17079 +.. date: 7131 +.. nonce: Uz1Ysh +.. section: Tests + +test_ctypes now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17304 +.. date: 7130 +.. nonce: HUHsX_ +.. section: Tests + +test_hash now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17303 +.. date: 7129 +.. nonce: TGUnon +.. section: Tests + +test_future* now work with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 17163 +.. date: 7128 +.. nonce: RtwHDs +.. section: Tests + +test_file now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16925 +.. date: 7127 +.. nonce: SMQSIJ +.. section: Tests + +test_configparser now works with unittest test discovery. Patch by Zachary +Ware. + +.. + +.. bpo: 16918 +.. date: 7126 +.. nonce: Dw6bfJ +.. section: Tests + +test_codecs now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16919 +.. date: 7125 +.. nonce: RD7mec +.. section: Tests + +test_crypt now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16910 +.. date: 7124 +.. nonce: awigr8 +.. section: Tests + +test_bytes, test_unicode, and test_userstring now work with unittest test +discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16905 +.. date: 7123 +.. nonce: 8SuIFn +.. section: Tests + +test_warnings now works with unittest test discovery. Initial patch by +Berker Peksag. + +.. + +.. bpo: 16898 +.. date: 7122 +.. nonce: 1pNH58 +.. section: Tests + +test_bufio now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16888 +.. date: 7121 +.. nonce: yWvMUM +.. section: Tests + +test_array now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16896 +.. date: 7120 +.. nonce: 8uLSFW +.. section: Tests + +test_asyncore now works with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16897 +.. date: 7119 +.. nonce: aEwG-R +.. section: Tests + +test_bisect now works with unittest test discovery. Initial patch by Zachary +Ware. + +.. + +.. bpo: 16852 +.. date: 7118 +.. nonce: z4zef9 +.. section: Tests + +test_genericpath, test_posixpath, test_ntpath, and test_macpath now work +with unittest test discovery. Patch by Zachary Ware. + +.. + +.. bpo: 16748 +.. date: 7117 +.. nonce: 74HpRw +.. section: Tests + +test_heapq now works with unittest test discovery. + +.. + +.. bpo: 10646 +.. date: 7116 +.. nonce: -n9wSX +.. section: Tests + +Tests rearranged for os.samefile/samestat to check for not just symlinks but +also hard links. + +.. + +.. bpo: 15302 +.. date: 7115 +.. nonce: nohKYA +.. section: Tests + +Switch regrtest from using getopt to using argparse. + +.. + +.. bpo: 15324 +.. date: 7114 +.. nonce: mcS3I3 +.. section: Tests + +Fix regrtest parsing of --fromfile, --match, and --randomize options. + +.. + +.. bpo: 16702 +.. date: 7113 +.. nonce: 3Xf_t- +.. section: Tests + +test_urllib2_localnet tests now correctly ignores proxies for localhost +tests. + +.. + +.. bpo: 16664 +.. date: 7112 +.. nonce: CxbZwX +.. section: Tests + +Add regression tests for glob's behaviour concerning entries starting with a +".". Patch by Sebastian Kreft. + +.. + +.. bpo: 13390 +.. date: 7111 +.. nonce: CRkOlc +.. section: Tests + +The ``-R`` option to regrtest now also checks for memory allocation leaks, +using :func:`sys.getallocatedblocks()`. + +.. + +.. bpo: 16559 +.. date: 7110 +.. nonce: JvxWbq +.. section: Tests + +Add more tests for the json module, including some from the official test +suite at json.org. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16661 +.. date: 7109 +.. nonce: Qn2hnC +.. section: Tests + +Fix the `os.getgrouplist()` test by not assuming that it gives the same +output as :command:`id -G`. + +.. + +.. bpo: 16115 +.. date: 7108 +.. nonce: vhK6oh +.. section: Tests + +Add some tests for the executable argument to subprocess.Popen(). Initial +patch by Kushal Das. + +.. + +.. bpo: 16126 +.. date: 7107 +.. nonce: blh5K0 +.. section: Tests + +PyErr_Format format mismatch in _testcapimodule.c. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 15304 +.. date: 7106 +.. nonce: DhyMtI +.. section: Tests + +Fix warning message when `os.chdir()` fails inside +`test.support.temp_cwd()`. Patch by Chris Jerdonek. + +.. + +.. bpo: 15802 +.. date: 7105 +.. nonce: 1duwD4 +.. section: Tests + +Fix test logic in `TestMaildir.test_create_tmp()`. Patch by Serhiy +Storchaka. + +.. + +.. bpo: 15557 +.. date: 7104 +.. nonce: H9Mhea +.. section: Tests + +Added a test suite for the webbrowser module, thanks to Anton Barkovsky. + +.. + +.. bpo: 16698 +.. date: 7103 +.. nonce: RgmYjY +.. section: Tests + +Skip posix test_getgroups when built with OS X deployment target prior to +10.6. + +.. + +.. bpo: 16067 +.. date: 7102 +.. nonce: A9L5PU +.. section: Build + +Add description into MSI file to replace installer's temporary name. + +.. + +.. bpo: 18257 +.. date: 7101 +.. nonce: E-TNPc +.. section: Build + +Fix readlink usage in python-config. Install the python version again on +Darwin. + +.. + +.. bpo: 18481 +.. date: 7100 +.. nonce: Is1C3p +.. section: Build + +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". + +.. + +.. bpo: 17845 +.. date: 7099 +.. nonce: kMmKYt +.. section: Build + +Clarified the message printed when some module are not built. + +.. + +.. bpo: 18256 +.. date: 7098 +.. nonce: PiEkYT +.. section: Build + +Compilation fix for recent AIX releases. Patch by David Edelsohn. + +.. + +.. bpo: 17547 +.. date: 7097 +.. nonce: yVllRd +.. section: Build + +In configure, explicitly pass -Wformat for the benefit for GCC 4.8. + +.. + +.. bpo: 15172 +.. date: 7096 +.. nonce: CpJRf2 +.. section: Build + +Document NASM 2.10+ as requirement for building OpenSSL 1.0.1 on Windows. + +.. + +.. bpo: 17591 +.. date: 7095 +.. nonce: e9az4p +.. section: Build + +Use lowercase filenames when including Windows header files. Patch by Roumen +Petrov. + +.. + +.. bpo: 17550 +.. date: 7094 +.. nonce: zn8gOk +.. section: Build + +Fix the --enable-profiling configure switch. + +.. + +.. bpo: 17425 +.. date: 7093 +.. nonce: Ix2fQh +.. section: Build + +Build with openssl 1.0.1d on Windows. + +.. + +.. bpo: 16754 +.. date: 7092 +.. nonce: fLN-7H +.. section: Build + +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. + +.. + +.. bpo: 5033 +.. date: 7091 +.. nonce: HKAgDA +.. section: Build + +Fix building of the sqlite3 extension module when the SQLite library version +has "beta" in it. Patch by Andreas Pelme. + +.. + +.. bpo: 17228 +.. date: 7090 +.. nonce: CCkAM0 +.. section: Build + +Fix building without pymalloc. + +.. + +.. bpo: 3718 +.. date: 7089 +.. nonce: n6-Cv2 +.. section: Build + +Use AC_ARG_VAR to set MACHDEP in configure.ac. + +.. + +.. bpo: 16235 +.. date: 7088 +.. nonce: u8Yi12 +.. section: Build + +Implement python-config as a shell script. + +.. + +.. bpo: 16769 +.. date: 7087 +.. nonce: bK11Wq +.. section: Build + +Remove outdated Visual Studio projects. + +.. + +.. bpo: 17031 +.. date: 7086 +.. nonce: 947KBS +.. section: Build + +Fix running regen in cross builds. + +.. + +.. bpo: 3754 +.. date: 7085 +.. nonce: sUdOUp +.. section: Build + +fix typo in pthread AC_CACHE_VAL. + +.. + +.. bpo: 15484 +.. date: 7084 +.. nonce: CgA5fS +.. section: Build + +Fix _PYTHON_PROJECT_BASE for srcdir != builddir builds; use +_PYTHON_PROJECT_BASE in distutils/sysconfig.py. + +.. + +.. bpo: 0 +.. date: 7083 +.. nonce: eLqyZu +.. section: Build + +Drop support for Windows 2000 (changeset e52df05b496a). + +.. + +.. bpo: 17029 +.. date: 7082 +.. nonce: dUd1NT +.. section: Build + +Let h2py search the multiarch system include directory. + +.. + +.. bpo: 16953 +.. date: 7081 +.. nonce: tW1KVY +.. section: Build + +Fix socket module compilation on platforms with HAVE_BROKEN_POLL. Patch by +Jeffrey Armstrong. + +.. + +.. bpo: 16320 +.. date: 7080 +.. nonce: wSizMv +.. section: Build + +Remove redundant Makefile dependencies for strings and bytes. + +.. + +.. bpo: 0 +.. date: 7079 +.. nonce: WRrrlF +.. section: Build + +Cross compiling needs host and build settings. configure no longer creates a +broken PYTHON_FOR_BUILD variable when --build is missing. + +.. + +.. bpo: 0 +.. date: 7078 +.. nonce: R2awqG +.. section: Build + +Fix cross compiling issue in setup.py, ensure that lib_dirs and inc_dirs are +defined in cross compiling mode, too. + +.. + +.. bpo: 16836 +.. date: 7077 +.. nonce: JZ-zO7 +.. section: Build + +Enable IPv6 support even if IPv6 is disabled on the build host. + +.. + +.. bpo: 16593 +.. date: 7076 +.. nonce: mS-VZr +.. section: Build + +Have BSD 'make -s' do the right thing, thanks to Daniel Shahaf + +.. + +.. bpo: 16262 +.. date: 7075 +.. nonce: puaCXo +.. section: Build + +fix out-of-src-tree builds, if mercurial is not installed. + +.. + +.. bpo: 15298 +.. date: 7074 +.. nonce: xiQHlO +.. section: Build + +ensure _sysconfigdata is generated in build directory, not source directory. + +.. + +.. bpo: 15833 +.. date: 7073 +.. nonce: tqz7oy +.. section: Build + +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. + +.. + +.. bpo: 15923 +.. date: 7072 +.. nonce: a2-GWK +.. section: Build + +Fix a mistake in ``asdl_c.py`` that resulted in a TypeError after +2801bf875a24 (see #15801). + +.. + +.. bpo: 16135 +.. date: 7071 +.. nonce: G5PgZc +.. section: Build + +Remove OS/2 support. + +.. + +.. bpo: 15819 +.. date: 7070 +.. nonce: VE2bTI +.. section: Build + +Make sure we can build Python out-of-tree from a read-only source directory. +(Somewhat related to issue #9860.) + +.. + +.. bpo: 15587 +.. date: 7069 +.. nonce: gR7vei +.. section: Build + +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. + +.. + +.. bpo: 17161 +.. date: 7068 +.. nonce: AT7PDZ +.. section: Build + +make install now also installs a python3 man page. + +.. + +.. bpo: 18351 +.. date: 7067 +.. nonce: pODT4P +.. section: C API + +Fix various issues in a function in importlib provided to help +PyImport_ExecCodeModuleWithPathnames() (and thus by extension +PyImport_ExecCodeModule() and PyImport_ExecCodeModuleEx()). + +.. + +.. bpo: 9369 +.. date: 7066 +.. nonce: z_ZQqc +.. section: C API + +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. + +.. + +.. bpo: 17206 +.. date: 7065 +.. nonce: yljYPd +.. section: C API + +Py_CLEAR(), Py_DECREF(), Py_XINCREF() and Py_XDECREF() now expand their +arguments once instead of multiple times. Patch written by Illia +Polosukhin. + +.. + +.. bpo: 17522 +.. date: 7064 +.. nonce: 7R55LY +.. section: C API + +Add the PyGILState_Check() API. + +.. + +.. bpo: 17327 +.. date: 7063 +.. nonce: PVFW3J +.. section: C API + +Add PyDict_SetDefault. + +.. + +.. bpo: 16881 +.. date: 7062 +.. nonce: 8SMude +.. section: C API + +Fix Py_ARRAY_LENGTH macro for GCC < 3.1. + +.. + +.. bpo: 16505 +.. date: 7061 +.. nonce: NiEndF +.. section: C API + +Remove unused Py_TPFLAGS_INT_SUBCLASS. + +.. + +.. bpo: 16086 +.. date: 7060 +.. nonce: z-DFqk +.. section: C API + +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). + +.. + +.. bpo: 16166 +.. date: 7059 +.. nonce: PDTSqL +.. section: C API + +Add PY_LITTLE_ENDIAN and PY_BIG_ENDIAN macros and unified endianness +detection and handling. + +.. + +.. bpo: 23006 +.. date: 7058 +.. nonce: B64FC0 +.. section: Documentation + +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. + +.. + +.. bpo: 17701 +.. date: 7057 +.. nonce: FtTZ66 +.. section: Documentation + +Improving strftime documentation. + +.. + +.. bpo: 18440 +.. date: 7056 +.. nonce: LyvSOC +.. section: Documentation + +Clarify that `hash()` can truncate the value returned from an object's +custom `__hash__()` method. + +.. + +.. bpo: 17844 +.. date: 7055 +.. nonce: V3aWU6 +.. section: Documentation + +Add links to encoders and decoders for bytes-to-bytes codecs. + +.. + +.. bpo: 14097 +.. date: 7054 +.. nonce: xeOs59 +.. section: Documentation + +improve the "introduction" page of the tutorial. + +.. + +.. bpo: 17977 +.. date: 7053 +.. nonce: 5f6eWJ +.. section: Documentation + +The documentation for the cadefault argument's default value in +urllib.request.urlopen() is fixed to match the code. + +.. + +.. bpo: 6696 +.. date: 7052 +.. nonce: -aRVrf +.. section: Documentation + +add documentation for the Profile objects, and improve profile/cProfile +docs. Patch by Tom Pinckney. + +.. + +.. bpo: 15940 +.. date: 7051 +.. nonce: XL62xu +.. section: Documentation + +Specify effect of locale on time functions. + +.. + +.. bpo: 17538 +.. date: 7050 +.. nonce: M8FVLz +.. section: Documentation + +Document XML vulnerabilties + +.. + +.. bpo: 16642 +.. date: 7049 +.. nonce: Cee7KE +.. section: Documentation + +sched.scheduler timefunc initial default is time.monotonic. Patch by +Ramchandra Apte + +.. + +.. bpo: 17047 +.. date: 7048 +.. nonce: sVzpby +.. section: Documentation + +remove doubled words in docs and docstrings reported by Serhiy Storchaka and +Matthew Barnett. + +.. + +.. bpo: 15465 +.. date: 7047 +.. nonce: yN2tkV +.. section: Documentation + +Document the versioning macros in the C API docs rather than the standard +library docs. Patch by Kushal Das. + +.. + +.. bpo: 16406 +.. date: 7046 +.. nonce: Q6DEK3 +.. section: Documentation + +Combine the pages for uploading and registering to PyPI. + +.. + +.. bpo: 16403 +.. date: 7045 +.. nonce: wPuYgA +.. section: Documentation + +Document how distutils uses the maintainer field in PKG-INFO. Patch by Jyrki +Pulliainen. + +.. + +.. bpo: 16695 +.. date: 7044 +.. nonce: O3-q4k +.. section: Documentation + +Document how glob handles filenames starting with a dot. Initial patch by +Jyrki Pulliainen. + +.. + +.. bpo: 8890 +.. date: 7043 +.. nonce: ldKgWT +.. section: Documentation + +Stop advertising an insecure practice by replacing uses of the /tmp +directory with better alternatives in the documentation. Patch by Geoff +Wilson. + +.. + +.. bpo: 17203 +.. date: 7042 +.. nonce: b42JWx +.. section: Documentation + +add long option names to unittest discovery docs. + +.. + +.. bpo: 13094 +.. date: 7041 +.. nonce: ujdNxz +.. section: Documentation + +add "Why do lambdas defined in a loop with different values all return the +same result?" programming FAQ. + +.. + +.. bpo: 14901 +.. date: 7040 +.. nonce: o_thZo +.. section: Documentation + +Update portions of the Windows FAQ. Patch by Ashish Nitin Patil. + +.. + +.. bpo: 16267 +.. date: 7039 +.. nonce: SSKvue +.. section: Documentation + +Better document the 3.3+ approach to combining @abstractmethod with + at staticmethod, @classmethod and @property + +.. + +.. bpo: 15209 +.. date: 7038 +.. nonce: w1UuQK +.. section: Documentation + +Clarify exception chaining description in exceptions module documentation + +.. + +.. bpo: 15990 +.. date: 7037 +.. nonce: 41C5_M +.. section: Documentation + +Improve argument/parameter documentation. + +.. + +.. bpo: 16209 +.. date: 7036 +.. nonce: 8-hM8N +.. section: Documentation + +Move the documentation for the str built-in function to a new str class +entry in the "Text Sequence Type" section. + +.. + +.. bpo: 13538 +.. date: 7035 +.. nonce: 6bfAto +.. section: Documentation + +Improve str() and object.__str__() documentation. + +.. + +.. bpo: 16489 +.. date: 7034 +.. nonce: N4Xo3- +.. section: Documentation + +Make it clearer that importlib.find_loader() needs parent packages to be +explicitly imported. + +.. + +.. bpo: 16400 +.. date: 7033 +.. nonce: kDLZRV +.. section: Documentation + +Update the description of which versions of a given package PyPI displays. + +.. + +.. bpo: 15677 +.. date: 7032 +.. nonce: _0vY-h +.. section: Documentation + +Document that zlib and gzip accept a compression level of 0 to mean 'no +compression'. Patch by Brian Brazil. + +.. + +.. bpo: 16197 +.. date: 7031 +.. nonce: LT1sjI +.. section: Documentation + +Update winreg docstrings and documentation to match code. Patch by Zachary +Ware. + +.. + +.. bpo: 8040 +.. date: 7030 +.. nonce: R8VAys +.. section: Documentation + +added a version switcher to the documentation. Patch by Yury Selivanov. + +.. + +.. bpo: 16241 +.. date: 7029 +.. nonce: LfdE7f +.. section: Documentation + +Document -X faulthandler command line option. Patch by Marek ?uppa. + +.. + +.. bpo: 0 +.. date: 7028 +.. nonce: tWKgrg +.. section: Documentation + +Additional comments and some style changes in the concurrent.futures URL +retrieval example + +.. + +.. bpo: 16115 +.. date: 7027 +.. nonce: Ba1MH_ +.. section: Documentation + +Improve subprocess.Popen() documentation around args, shell, and executable +arguments. + +.. + +.. bpo: 13498 +.. date: 7026 +.. nonce: LI0aQ4 +.. section: Documentation + +Clarify docs of os.makedirs()'s exist_ok argument. Done with great native- +speaker help from R. David Murray. + +.. + +.. bpo: 15533 +.. date: 7025 +.. nonce: oRcsqW +.. section: Documentation + +Clarify docs and add tests for `subprocess.Popen()`'s cwd argument. + +.. + +.. bpo: 15979 +.. date: 7024 +.. nonce: UATtRZ +.. section: Documentation + +Improve timeit documentation. + +.. + +.. bpo: 16036 +.. date: 7023 +.. nonce: ITDZx_ +.. section: Documentation + +Improve documentation of built-in `int()`'s signature and arguments. + +.. + +.. bpo: 15935 +.. date: 7022 +.. nonce: 49QYHM +.. section: Documentation + +Clarification of `argparse` docs, re: add_argument() type and default +arguments. Patch contributed by Chris Jerdonek. + +.. + +.. bpo: 11964 +.. date: 7021 +.. nonce: TswBww +.. section: Documentation + +Document a change in v3.2 to the behavior of the indent parameter of json +encoding operations. + +.. + +.. bpo: 15116 +.. date: 7020 +.. nonce: uDQI_8 +.. section: Documentation + +Remove references to appscript as it is no longer being supported. + +.. + +.. bpo: 18817 +.. date: 7019 +.. nonce: b4b2nk +.. section: Tools/Demos + +Fix a resource warning in Lib/aifc.py demo. Patch by Vajrasky Kok. + +.. + +.. bpo: 18439 +.. date: 7018 +.. nonce: W9DxeL +.. section: Tools/Demos + +Make patchcheck work on Windows for ACKS, NEWS. + +.. + +.. bpo: 18448 +.. date: 7017 +.. nonce: eLT81k +.. section: Tools/Demos + +Fix a typo in Tools/demo/eiffel.py. + +.. + +.. bpo: 18457 +.. date: 7016 +.. nonce: fTGIAR +.. section: Tools/Demos + +Fixed saving of formulas and complex numbers in Tools/demo/ss1.py. + +.. + +.. bpo: 18449 +.. date: 7015 +.. nonce: ufcaWC +.. section: Tools/Demos + +Make Tools/demo/ss1.py work again on Python 3. Patch by F?vry Thibault. + +.. + +.. bpo: 12990 +.. date: 7014 +.. nonce: E1geL- +.. section: Tools/Demos + +The "Python Launcher" on OSX could not launch python scripts that have paths +that include wide characters. + +.. + +.. bpo: 15239 +.. date: 7013 +.. nonce: uzPBlK +.. section: Tools/Demos + +Make mkstringprep.py work again on Python 3. + +.. + +.. bpo: 17028 +.. date: 7012 +.. nonce: d0Ryfg +.. section: Tools/Demos + +Allowed Python arguments to be supplied to the Windows launcher. + +.. + +.. bpo: 17156 +.. date: 7011 +.. nonce: zmokst +.. section: Tools/Demos + +pygettext.py now detects the encoding of source files and correctly writes +and escapes non-ascii characters. + +.. + +.. bpo: 15539 +.. date: 7010 +.. nonce: 6bqqV- +.. section: Tools/Demos + +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. + +.. + +.. bpo: 11797 +.. date: 7009 +.. nonce: 2UOmWr +.. section: Tools/Demos + +Add a 2to3 fixer that maps reload() to imp.reload(). + +.. + +.. bpo: 10966 +.. date: 7008 +.. nonce: WsfpDc +.. section: Tools/Demos + +Remove the concept of unexpected skipped tests. + +.. + +.. bpo: 9893 +.. date: 7007 +.. nonce: pJeYiB +.. section: Tools/Demos + +Removed the Misc/Vim directory. + +.. + +.. bpo: 0 +.. date: 7006 +.. nonce: mdt8FR +.. section: Tools/Demos + +Removed the Misc/TextMate directory. + +.. + +.. bpo: 16245 +.. date: 7005 +.. nonce: eZNpI- +.. section: Tools/Demos + +Add the Tools/scripts/parse_html5_entities.py script to parse the list of +HTML5 entities and update the html.entities.html5 dictionary. + +.. + +.. bpo: 15378 +.. date: 7004 +.. nonce: IO1T92 +.. section: Tools/Demos + +Fix Tools/unicode/comparecodecs.py. Patch by Serhiy Storchaka. + +.. + +.. bpo: 16549 +.. date: 7003 +.. nonce: 2Pj5iC +.. section: Tools/Demos + +Make json.tool work again on Python 3 and add tests. Initial patch by Berker +Peksag and Serhiy Storchaka. + +.. + +.. bpo: 13301 +.. date: 7002 +.. nonce: A4WOk5 +.. section: Tools/Demos + +use ast.literal_eval() instead of eval() in Tools/i18n/msgfmt.py. Patch by +Serhiy Storchaka. + +.. + +.. bpo: 18569 +.. date: 7001 +.. nonce: 0L-xR0 +.. section: Windows + +The installer now adds .py to the PATHEXT variable when extensions are +registered. Patch by Paul Moore. diff --git a/Misc/NEWS.d/3.4.0a2.rst b/Misc/NEWS.d/3.4.0a2.rst new file mode 100644 index 00000000000..81ca1a33414 --- /dev/null +++ b/Misc/NEWS.d/3.4.0a2.rst @@ -0,0 +1,788 @@ +.. bpo: 18942 +.. date: 7823 +.. nonce: xpMQx7 +.. release date: 2013-09-09 +.. section: Core and Builtins + +sys._debugmallocstats() output was damaged on Windows. + +.. + +.. bpo: 18571 +.. date: 7822 +.. nonce: hvNoE2 +.. section: Core and Builtins + +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(). + +.. + +.. bpo: 11619 +.. date: 7821 +.. nonce: r2uijI +.. section: Core and Builtins + +The parser and the import machinery do not encode Unicode filenames anymore +on Windows. + +.. + +.. bpo: 18808 +.. date: 7820 +.. nonce: DicDIV +.. section: Core and Builtins + +Non-daemon threads are now automatically joined when a sub-interpreter is +shutdown (it would previously dump a fatal error). + +.. + +.. bpo: 0 +.. date: 7819 +.. nonce: FDR7CW +.. section: Core and Builtins + +Remove support for compiling on systems without getcwd(). + +.. + +.. bpo: 18774 +.. date: 7818 +.. nonce: 4hnKQ1 +.. section: Core and Builtins + +Remove last bits of GNU PTH thread code and thread_pth.h. + +.. + +.. bpo: 18771 +.. date: 7817 +.. nonce: gPhE3D +.. section: Core and Builtins + +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. + +.. + +.. bpo: 16105 +.. date: 7816 +.. nonce: L1PWWk +.. section: Core and Builtins + +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. + +.. + +.. bpo: 18722 +.. date: 7815 +.. nonce: 6O_dyg +.. section: Core and Builtins + +Remove uses of the "register" keyword in C code. + +.. + +.. bpo: 18667 +.. date: 7814 +.. nonce: xycqzn +.. section: Core and Builtins + +Add missing "HAVE_FCHOWNAT" symbol to posix._have_functions. + +.. + +.. bpo: 16499 +.. date: 7813 +.. nonce: BoV9L7 +.. section: Core and Builtins + +Add command line option for isolated mode. + +.. + +.. bpo: 15301 +.. date: 7812 +.. nonce: rov_YS +.. section: Core and Builtins + +Parsing fd, uid, and gid parameters for builtins in Modules/posixmodule.c is +now far more robust. + +.. + +.. bpo: 18368 +.. date: 7811 +.. nonce: eZ-IVt +.. section: Core and Builtins + +PyOS_StdioReadline() no longer leaks memory when realloc() fail. + +.. + +.. bpo: 17934 +.. date: 7810 +.. nonce: R2hCWw +.. section: Core and Builtins + +Add a clear() method to frame objects, to help clean up expensive details +(local variables) and break reference cycles. + +.. + +.. bpo: 18780 +.. date: 7809 +.. nonce: cRO6Nc +.. section: Core and Builtins + +%-formatting codes %d, %i, and %u now treat int-subclasses as int (displays +value of int-subclass instead of str(int-subclass) ). + +.. + +.. bpo: 18808 +.. date: 7808 +.. nonce: rKe4pf +.. section: Library + +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. + +.. + +.. bpo: 18458 +.. date: 7807 +.. nonce: XphzAu +.. section: Library + +Prevent crashes with newer versions of libedit. Its readline emulation has +changed from 0-based indexing to 1-based like gnu readline. + +.. + +.. bpo: 18852 +.. date: 7806 +.. nonce: x1dLH9 +.. section: Library + +Handle case of ``readline.__doc__`` being ``None`` in the new readline +activation code in ``site.py``. + +.. + +.. bpo: 18672 +.. date: 7805 +.. nonce: CIblDh +.. section: Library + +Fixed format specifiers for Py_ssize_t in debugging output in the _sre +module. + +.. + +.. bpo: 18830 +.. date: 7804 +.. nonce: 1kmGPa +.. section: Library + +inspect.getclasstree() no longer produces duplicate entries even when input +list contains duplicates. + +.. + +.. bpo: 18878 +.. date: 7803 +.. nonce: VuQM8h +.. section: Library + +sunau.open now supports the context management protocol. Based on patches +by Claudiu Popa and R. David Murray. + +.. + +.. bpo: 18909 +.. date: 7802 +.. nonce: XSu98N +.. section: Library + +Fix _tkinter.tkapp.interpaddr() on Windows 64-bit, don't cast 64-bit pointer +to long (32 bits). + +.. + +.. bpo: 18876 +.. date: 7801 +.. nonce: 30Ist9 +.. section: Library + +The FileIO.mode attribute now better reflects the actual mode under which +the file was opened. Patch by Erik Bray. + +.. + +.. bpo: 16853 +.. date: 7800 +.. nonce: HyyMyr +.. section: Library + +Add new selectors module. + +.. + +.. bpo: 18882 +.. date: 7799 +.. nonce: Z9cjmU +.. section: Library + +Add threading.main_thread() function. + +.. + +.. bpo: 18901 +.. date: 7798 +.. nonce: CRT02s +.. section: Library + +The sunau getparams method now returns a namedtuple rather than a plain +tuple. Patch by Claudiu Popa. + +.. + +.. bpo: 17487 +.. date: 7797 +.. nonce: EziBDf +.. section: Library + +The result of the wave getparams method now is pickleable again. Patch by +Claudiu Popa. + +.. + +.. bpo: 18756 +.. date: 7796 +.. nonce: DS8ILK +.. section: Library + +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. + +.. + +.. bpo: 18418 +.. date: 7795 +.. nonce: _SFG8w +.. section: Library + +After fork(), reinit all threads states, not only active ones. Patch by A. +Jesse Jiryu Davis. + +.. + +.. bpo: 17974 +.. date: 7794 +.. nonce: mo7MP0 +.. section: Library + +Switch unittest from using getopt to using argparse. + +.. + +.. bpo: 11798 +.. date: 7793 +.. nonce: 0AnJcy +.. section: Library + +TestSuite now drops references to own tests after execution. + +.. + +.. bpo: 16611 +.. date: 7792 +.. nonce: aHrYR1 +.. section: Library + +http.cookie now correctly parses the 'secure' and 'httponly' cookie flags. + +.. + +.. bpo: 11973 +.. date: 7791 +.. nonce: uPtBvG +.. section: Library + +Fix a problem in kevent. The flags and fflags fields are now properly +handled as unsigned. + +.. + +.. bpo: 18807 +.. date: 7790 +.. nonce: TnD-vF +.. section: Library + +``pyvenv`` now takes a --copies argument allowing copies instead of symlinks +even where symlinks are available and the default. + +.. + +.. bpo: 18538 +.. date: 7789 +.. nonce: wuWw4M +.. section: Library + +``python -m dis`` now uses argparse for argument processing. Patch by +Michele Orr?. + +.. + +.. bpo: 18394 +.. date: 7788 +.. nonce: 6pOClT +.. section: Library + +Close cgi.FieldStorage's optional file. + +.. + +.. bpo: 17702 +.. date: 7787 +.. nonce: TDPIyM +.. section: Library + +On error, os.environb now suppresses the exception context when raising a +new KeyError with the original key. + +.. + +.. bpo: 16809 +.. date: 7786 +.. nonce: TF5mD7 +.. section: Library + +Fixed some tkinter incompatibilities with Tcl/Tk 8.6. + +.. + +.. bpo: 16809 +.. date: 7785 +.. nonce: WqSHdP +.. section: Library + +Tkinter's splitlist() and split() methods now accept Tcl_Obj argument. + +.. + +.. bpo: 18324 +.. date: 7784 +.. nonce: 0vkj_r +.. section: Library + +set_payload now correctly handles binary input. This also supersedes the +previous fixes for #14360, #1717, and #16564. + +.. + +.. bpo: 18794 +.. date: 7783 +.. nonce: A0pB9X +.. section: Library + +Add a fileno() method and a closed attribute to select.devpoll objects. + +.. + +.. bpo: 17119 +.. date: 7782 +.. nonce: KfZ3-l +.. section: Library + +Fixed integer overflows when processing large strings and tuples in the +tkinter module. + +.. + +.. bpo: 18747 +.. date: 7781 +.. nonce: tPZkbG +.. section: Library + +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. + +.. + +.. bpo: 8865 +.. date: 7780 +.. nonce: cKBSJh +.. section: Library + +Concurrent invocation of select.poll.poll() now raises a RuntimeError +exception. Patch by Christian Schubert. + +.. + +.. bpo: 18777 +.. date: 7779 +.. nonce: VLsjOw +.. section: Library + +The ssl module now uses the new CRYPTO_THREADID API of OpenSSL 1.0.0+ +instead of the deprecated CRYPTO id callback function. + +.. + +.. bpo: 18768 +.. date: 7778 +.. nonce: r3TSCo +.. section: Library + +Correct doc string of RAND_edg(). Patch by Vajrasky Kok. + +.. + +.. bpo: 18178 +.. date: 7777 +.. nonce: i4hnf- +.. section: Library + +Fix ctypes on BSD. dlmalloc.c was compiled twice which broke malloc weak +symbols. + +.. + +.. bpo: 18709 +.. date: 7776 +.. nonce: DWzpRe +.. section: Library + +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). + +.. + +.. bpo: 18701 +.. date: 7775 +.. nonce: nlDK3r +.. section: Library + +Remove support of old CPython versions (<3.0) from C code. + +.. + +.. bpo: 18756 +.. date: 7774 +.. nonce: moRUfX +.. section: Library + +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). + +.. + +.. bpo: 18673 +.. date: 7773 +.. nonce: fZ5WYI +.. section: Library + +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. + +.. + +.. bpo: 18532 +.. date: 7772 +.. nonce: 2hh1ms +.. section: Library + +Change the builtin hash algorithms' names to lower case names as promised by +hashlib's documentation. + +.. + +.. bpo: 8713 +.. date: 7771 +.. nonce: BFXgYS +.. section: Library + +add new spwan and forkserver start methods, and new functions +get_all_start_methods, get_start_method, and set_start_method, to +multiprocessing. + +.. + +.. bpo: 18405 +.. date: 7770 +.. nonce: z6flbp +.. section: Library + +Improve the entropy of crypt.mksalt(). + +.. + +.. bpo: 12015 +.. date: 7769 +.. nonce: wImE9r +.. section: Library + +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. + +.. + +.. bpo: 18585 +.. date: 7768 +.. nonce: fooJpB +.. section: Library + +Add :func:`textwrap.shorten` to collapse and truncate a piece of text to a +given length. + +.. + +.. bpo: 18598 +.. date: 7767 +.. nonce: KRZlim +.. section: Library + +Tweak exception message for importlib.import_module() to include the module +name when a key argument is missing. + +.. + +.. bpo: 19151 +.. date: 7766 +.. nonce: 2MrIlH +.. section: Library + +Fix docstring and use of _get_supported_file_loaders() to reflect 2-tuples. + +.. + +.. bpo: 19152 +.. date: 7765 +.. nonce: 2VYxzU +.. section: Library + +Add ExtensionFileLoader.get_filename(). + +.. + +.. bpo: 18676 +.. date: 7764 +.. nonce: WAq1iB +.. section: Library + +Change 'positive' to 'non-negative' in queue.py put and get docstrings and +ValueError messages. Patch by Zhongyue Luo + +.. + +.. bpo: 0 +.. date: 7763 +.. nonce: Q7tLxE +.. section: Library + +Fix refcounting issue with extension types in tkinter. + +.. + +.. bpo: 8112 +.. date: 7762 +.. nonce: J4M-dG +.. section: Library + +xlmrpc.server's DocXMLRPCServer server no longer raises an error if methods +have annotations; it now correctly displays the annotations. + +.. + +.. bpo: 18600 +.. date: 7761 +.. nonce: lnNy-j +.. section: Library + +Added policy argument to email.message.Message.as_string, and as_bytes and +__bytes__ methods to Message. + +.. + +.. bpo: 18671 +.. date: 7760 +.. nonce: ip02-u +.. section: Library + +Output more information when logging exceptions occur. + +.. + +.. bpo: 18621 +.. date: 7759 +.. nonce: uGY0Dw +.. section: Library + +Prevent the site module's patched builtins from keeping too many references +alive for too long. + +.. + +.. bpo: 4885 +.. date: 7758 +.. nonce: tdRzg0 +.. section: Library + +Add weakref support to mmap objects. Patch by Valerie Lambert. + +.. + +.. bpo: 8860 +.. date: 7757 +.. nonce: g3CWcZ +.. section: Library + +Fixed rounding in timedelta constructor. + +.. + +.. bpo: 18849 +.. date: 7756 +.. nonce: Q0kF0R +.. section: Library + +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. + +.. + +.. bpo: 18920 +.. date: 7755 +.. nonce: ymifXY +.. section: Library + +argparse's default destination for the version action (-v, --version) has +also been changed to stdout, to match the Python executable. + +.. + +.. bpo: 18623 +.. date: 7754 +.. nonce: ac3L1h +.. section: Tests + +Factor out the _SuppressCoreFiles context manager into test.support. Patch +by Valerie Lambert. + +.. + +.. bpo: 12037 +.. date: 7753 +.. nonce: pcCgBV +.. section: Tests + +Fix test_email for desktop Windows. + +.. + +.. bpo: 15507 +.. date: 7752 +.. nonce: 3_em_8 +.. section: Tests + +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. + +.. + +.. bpo: 16799 +.. date: 7751 +.. nonce: Z_fDrt +.. section: Tests + +Switched from getopt to argparse style in regrtest's argument parsing. +Added more tests for regrtest's argument parsing. + +.. + +.. bpo: 18792 +.. date: 7750 +.. nonce: 5RkYdK +.. section: Tests + +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. + +.. + +.. bpo: 18489 +.. date: 7749 +.. nonce: nOvxOH +.. section: IDLE + +Add tests for SearchEngine. Original patch by Phil Webster. + +.. + +.. bpo: 18743 +.. date: 7748 +.. nonce: 5WKkvu +.. section: Documentation + +Fix references to non-existent "StringIO" module. + +.. + +.. bpo: 18783 +.. date: 7747 +.. nonce: n5K5vI +.. section: Documentation + +Removed existing mentions of Python long type in docstrings, error messages +and comments. + +.. + +.. bpo: 1584 +.. date: 7746 +.. nonce: Lh1ZOs +.. section: Build + +Provide configure options to override default search paths for Tcl and Tk +when building _tkinter. + +.. + +.. bpo: 15663 +.. date: 7745 +.. nonce: VJKYGf +.. section: Build + +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. + +.. + +.. bpo: 18922 +.. date: 7744 +.. nonce: xCUCW0 +.. section: Tools/Demos + +Now The Lib/smtpd.py and Tools/i18n/msgfmt.py scripts write their version +strings to stdout, and not to sderr. diff --git a/Misc/NEWS.d/3.4.0a3.rst b/Misc/NEWS.d/3.4.0a3.rst new file mode 100644 index 00000000000..6e1938e97e9 --- /dev/null +++ b/Misc/NEWS.d/3.4.0a3.rst @@ -0,0 +1,283 @@ +.. bpo: 18818 +.. date: 7851 +.. nonce: fsZ51D +.. release date: 2013-09-29 +.. section: Core and Builtins + +The "encodingname" part of PYTHONIOENCODING is now optional. + +.. + +.. bpo: 19098 +.. date: 7850 +.. nonce: 5XU9uv +.. section: Core and Builtins + +Prevent overflow in the compiler when the recursion limit is set absurdly +high. + +.. + +.. bpo: 18929 +.. date: 7849 +.. nonce: xt9_At +.. section: Library + +`inspect.classify_class_attrs()` now correctly finds class attributes +returned by `dir()` that are located in the metaclass. + +.. + +.. bpo: 18950 +.. date: 7848 +.. nonce: DHn3qf +.. section: Library + +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. + +.. + +.. bpo: 18594 +.. date: 7847 +.. nonce: Dm34qD +.. section: Library + +The fast path for collections.Counter() was never taken due to an over- +restrictive type check. + +.. + +.. bpo: 19053 +.. date: 7846 +.. nonce: DkcFZ8 +.. section: Library + +ZipExtFile.read1() with non-zero argument no more returns empty bytes until +end of data. + +.. + +.. bpo: 0 +.. date: 7845 +.. nonce: x-7joT +.. section: Library + +logging: added support for Unix domain sockets to SocketHandler and +DatagramHandler. + +.. + +.. bpo: 18996 +.. date: 7844 +.. nonce: 1Waotx +.. section: Library + +TestCase.assertEqual() now more cleverly shorten differing strings in error +report. + +.. + +.. bpo: 19034 +.. date: 7843 +.. nonce: S5MyMF +.. section: Library + +repr() for tkinter.Tcl_Obj now exposes string reperesentation. + +.. + +.. bpo: 18978 +.. date: 7842 +.. nonce: qyLkAY +.. section: Library + +``urllib.request.Request`` now allows the method to be indicated on the +class and no longer sets it to None in ``__init__``. + +.. + +.. bpo: 18626 +.. date: 7841 +.. nonce: X3HiU3 +.. section: Library + +the inspect module now offers a basic command line introspection interface +(Initial patch by Claudiu Popa) + +.. + +.. bpo: 3015 +.. date: 7840 +.. nonce: Db5Zwa +.. section: Library + +Fixed tkinter with wantobject=False. Any Tcl command call returned empty +string. + +.. + +.. bpo: 19037 +.. date: 7839 +.. nonce: OfBhoU +.. section: Library + +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. + +.. + +.. bpo: 14984 +.. date: 7838 +.. nonce: iRbFp4 +.. section: Library + +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. + +.. + +.. bpo: 18873 +.. date: 7837 +.. nonce: 3ezwXm +.. section: Library + +The tokenize module now detects Python source code encoding only in comment +lines. + +.. + +.. bpo: 17764 +.. date: 7836 +.. nonce: czuuKO +.. section: Library + +Enable http.server to bind to a user specified network interface. Patch +contributed by Malte Swart. + +.. + +.. bpo: 18937 +.. date: 7835 +.. nonce: bcvKgi +.. section: Library + +Add an assertLogs() context manager to unittest.TestCase to ensure that a +block of code emits a message using the logging module. + +.. + +.. bpo: 17324 +.. date: 7834 +.. nonce: 0PkOTi +.. section: Library + +Fix http.server's request handling case on trailing '/'. Patch contributed +by Vajrasky Kok. + +.. + +.. bpo: 19018 +.. date: 7833 +.. nonce: mntKOW +.. section: Library + +The heapq.merge() function no longer suppresses IndexError in the underlying +iterables. + +.. + +.. bpo: 18784 +.. date: 7832 +.. nonce: dtzGbX +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 7831 +.. nonce: 22MCfN +.. section: Library + +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`. + +.. + +.. bpo: 1565525 +.. date: 7830 +.. nonce: 0rVMB7 +.. section: Library + +New function ``traceback.clear_frames`` will clear the local variables of +all the stack frames referenced by a traceback object. + +.. + +.. bpo: 18952 +.. date: 7829 +.. nonce: ysovuf +.. section: Tests + +Fix regression in support data downloads introduced when test.support was +converted to a package. Regression noticed by Zachary Ware. + +.. + +.. bpo: 18873 +.. date: 7828 +.. nonce: dyLPY9 +.. section: IDLE + +IDLE now detects Python source code encoding only in comment lines. + +.. + +.. bpo: 18988 +.. date: 7827 +.. nonce: 6CpesW +.. section: IDLE + +The "Tab" key now works when a word is already autocompleted. + +.. + +.. bpo: 17003 +.. date: 7826 +.. nonce: eQGdny +.. section: Documentation + +Unified the size argument names in the io module with common practice. + +.. + +.. bpo: 18596 +.. date: 7825 +.. nonce: TMPNJZ +.. section: Build + +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. + +.. + +.. bpo: 18873 +.. date: 7824 +.. nonce: i_1Tf_ +.. section: Tools/Demos + +2to3 and the findnocoding.py script now detect Python source code encoding +only in comment lines. diff --git a/Misc/NEWS.d/3.4.0a4.rst b/Misc/NEWS.d/3.4.0a4.rst new file mode 100644 index 00000000000..201ac16d589 --- /dev/null +++ b/Misc/NEWS.d/3.4.0a4.rst @@ -0,0 +1,659 @@ +.. bpo: 19301 +.. date: 7918 +.. nonce: xZv71d +.. release date: 2013-10-20 +.. section: Core and Builtins + +Give classes and functions that are explicitly marked global a global +qualname. + +.. + +.. bpo: 19279 +.. date: 7917 +.. nonce: VVzqJy +.. section: Core and Builtins + +UTF-7 decoder no longer produces illegal strings. + +.. + +.. bpo: 16612 +.. date: 7916 +.. nonce: 8bgX-E +.. section: Core and Builtins + +Add "Argument Clinic", a compile-time preprocessor for C files to generate +argument parsing code. (See PEP 436.) + +.. + +.. bpo: 18810 +.. date: 7915 +.. nonce: tQAzk_ +.. section: Core and Builtins + +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. + +.. + +.. bpo: 18416 +.. date: 7914 +.. nonce: 5mWnIr +.. section: Core and Builtins + +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. + +.. + +.. bpo: 4555 +.. date: 7913 +.. nonce: mOxiRO +.. section: Core and Builtins + +All exported C symbols are now prefixed with either "Py" or "_Py". + +.. + +.. bpo: 19219 +.. date: 7912 +.. nonce: _H8xTK +.. section: Core and Builtins + +Speed up marshal.loads(), and make pyc files slightly (5% to 10%) smaller. + +.. + +.. bpo: 19221 +.. date: 7911 +.. nonce: Y7d-d9 +.. section: Core and Builtins + +Upgrade Unicode database to version 6.3.0. + +.. + +.. bpo: 16742 +.. date: 7910 +.. nonce: vmmba7 +.. section: Core and Builtins + +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(). + +.. + +.. bpo: 19199 +.. date: 7909 +.. nonce: HZHjaz +.. section: Core and Builtins + +Remove ``PyThreadState.tick_counter`` field + +.. + +.. bpo: 0 +.. date: 7908 +.. nonce: 5kIB0G +.. section: Core and Builtins + +Fix macro expansion of _PyErr_OCCURRED(), and make sure to use it in at +least one place so as to avoid regressions. + +.. + +.. bpo: 19087 +.. date: 7907 +.. nonce: gdUdnV +.. section: Core and Builtins + +Improve bytearray allocation in order to allow cheap popping of data at the +front (slice deletion). + +.. + +.. bpo: 19014 +.. date: 7906 +.. nonce: y4w-XY +.. section: Core and Builtins + +memoryview.cast() is now allowed on zero-length views. + +.. + +.. bpo: 18690 +.. date: 7905 +.. nonce: CS9avj +.. section: Core and Builtins + +memoryview is now automatically registered with collections.abc.Sequence + +.. + +.. bpo: 19078 +.. date: 7904 +.. nonce: PQhOCk +.. section: Core and Builtins + +memoryview now correctly supports the reversed builtin (Patch by Claudiu +Popa) + +.. + +.. bpo: 17457 +.. date: 7903 +.. nonce: TeaU1w +.. section: Library + +unittest test discovery now works with namespace packages. Patch by Claudiu +Popa. + +.. + +.. bpo: 18235 +.. date: 7902 +.. nonce: LdBO1h +.. section: Library + +Fix the sysconfig variables LDSHARED and BLDSHARED under AIX. Patch by David +Edelsohn. + +.. + +.. bpo: 18606 +.. date: 7901 +.. nonce: CIapUf +.. section: Library + +Add the new "statistics" module (PEP 450). Contributed by Steven D'Aprano. + +.. + +.. bpo: 12866 +.. date: 7900 +.. nonce: 7c7GGc +.. section: Library + +The audioop module now supports 24-bit samples. + +.. + +.. bpo: 19254 +.. date: 7899 +.. nonce: hq_ejm +.. section: Library + +Provide an optimized Python implementation of pbkdf2_hmac. + +.. + +.. bpo: 19201 +.. date: 7898 +.. nonce: OY6_PP +.. section: Library + +Add "x" mode (exclusive creation) in opening file to bz2, gzip and lzma +modules. Patches by Tim Heaney and Vajrasky Kok. (See also: bpo-19222, +bpo-19223) + +.. + +.. bpo: 0 +.. date: 7897 +.. nonce: dSKPsn +.. section: Library + +Fix a reference count leak in _sre. + +.. + +.. bpo: 19262 +.. date: 7896 +.. nonce: fNsTCq +.. section: Library + +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. + +.. + +.. bpo: 19276 +.. date: 7895 +.. nonce: Y69Qmv +.. section: Library + +Fixed the wave module on 64-bit big-endian platforms. + +.. + +.. bpo: 19266 +.. date: 7894 +.. nonce: an8EiY +.. section: Library + +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). + +.. + +.. bpo: 18891 +.. date: 7893 +.. nonce: 4TroDn +.. section: Library + +Completed the new email package (provisional) API additions by adding new +classes EmailMessage, MIMEPart, and ContentManager. + +.. + +.. bpo: 18281 +.. date: 7892 +.. nonce: 1FnfEW +.. section: Library + +Unused stat constants removed from `tarfile`. + +.. + +.. bpo: 18999 +.. date: 7891 +.. nonce: -2OZju +.. section: Library + +Multiprocessing now supports 'contexts' with the same API as the module, but +bound to specified start methods. + +.. + +.. bpo: 18468 +.. date: 7890 +.. nonce: 8a1TVz +.. section: Library + +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. + +.. + +.. bpo: 18725 +.. date: 7889 +.. nonce: zkMEqo +.. section: Library + +The textwrap module now supports truncating multiline text. + +.. + +.. bpo: 18776 +.. date: 7888 +.. nonce: Y-0SKr +.. section: Library + +atexit callbacks now display their full traceback when they raise an +exception. + +.. + +.. bpo: 17827 +.. date: 7887 +.. nonce: HJGFDL +.. section: Library + +Add the missing documentation for ``codecs.encode`` and ``codecs.decode``. + +.. + +.. bpo: 19218 +.. date: 7886 +.. nonce: Cd2omk +.. section: Library + +Rename collections.abc to _collections_abc in order to speed up interpreter +start. + +.. + +.. bpo: 18582 +.. date: 7885 +.. nonce: hn0YhD +.. section: Library + +Add 'pbkdf2_hmac' to the hashlib module. It implements PKCS#5 password-based +key derivation functions with HMAC as pseudorandom function. + +.. + +.. bpo: 19131 +.. date: 7884 +.. nonce: eZXzpr +.. section: Library + +The aifc module now correctly reads and writes sampwidth of compressed +streams. + +.. + +.. bpo: 19209 +.. date: 7883 +.. nonce: 3Hyd-- +.. section: Library + +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. + +.. + +.. bpo: 19205 +.. date: 7882 +.. nonce: yrFzJn +.. section: Library + +Don't import the 're' module in site and sysconfig module to speed up +interpreter start. + +.. + +.. bpo: 9548 +.. date: 7881 +.. nonce: nhTqHw +.. section: Library + +Add a minimal "_bootlocale" module that is imported by the _io module +instead of the full locale module. + +.. + +.. bpo: 18764 +.. date: 7880 +.. nonce: rbnhLA +.. section: Library + +Remove the 'print' alias for the PDB 'p' command so that it no longer +shadows the print function. + +.. + +.. bpo: 19158 +.. date: 7879 +.. nonce: GvkZuU +.. section: Library + +A rare race in BoundedSemaphore could allow .release() too often. + +.. + +.. bpo: 15805 +.. date: 7878 +.. nonce: F_Ubx0 +.. section: Library + +Add contextlib.redirect_stdout(). + +.. + +.. bpo: 18716 +.. date: 7877 +.. nonce: L9QcWX +.. section: Library + +Deprecate the formatter module. + +.. + +.. bpo: 10712 +.. date: 7876 +.. nonce: rnd0oc +.. section: Library + +2to3 has a new "asserts" fixer that replaces deprecated names of unittest +methods (e.g. failUnlessEqual -> assertEqual). + +.. + +.. bpo: 18037 +.. date: 7875 +.. nonce: 7XGs8m +.. section: Library + +2to3 now escapes ``'\u'`` and ``'\U'`` in native strings. + +.. + +.. bpo: 17839 +.. date: 7874 +.. nonce: EyWhFu +.. section: Library + +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) + +.. + +.. bpo: 19132 +.. date: 7873 +.. nonce: ADBW6c +.. section: Library + +The pprint module now supports compact mode. + +.. + +.. bpo: 19137 +.. date: 7872 +.. nonce: Iuit_M +.. section: Library + +The pprint module now correctly formats instances of set and frozenset +subclasses. + +.. + +.. bpo: 10042 +.. date: 7871 +.. nonce: AH33zP +.. section: Library + +functools.total_ordering now correctly handles NotImplemented being returned +by the underlying comparison function (Patch by Katie Miller) + +.. + +.. bpo: 19092 +.. date: 7870 +.. nonce: Z7dea9 +.. section: Library + +contextlib.ExitStack now correctly reraises exceptions from the __exit__ +callbacks of inner context managers (Patch by Hrvoje Nik?i?) + +.. + +.. bpo: 12641 +.. date: 7869 +.. nonce: r9sIyX +.. section: Library + +Avoid passing "-mno-cygwin" to the mingw32 compiler, except when necessary. +Patch by Oscar Benjamin. + +.. + +.. bpo: 5845 +.. date: 7868 +.. nonce: obzVIH +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 7867 +.. nonce: 08TsG5 +.. section: Library + +Properly initialize all fields of a SSL object after allocation. + +.. + +.. bpo: 19095 +.. date: 7866 +.. nonce: qZGvAs +.. section: Library + +SSLSocket.getpeercert() now raises ValueError when the SSL handshake hasn't +been done. + +.. + +.. bpo: 4366 +.. date: 7865 +.. nonce: lDEdfK +.. section: Library + +Fix building extensions on all platforms when --enable-shared is used. + +.. + +.. bpo: 19030 +.. date: 7864 +.. nonce: uKvvJF +.. section: Library + +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. + +.. + +.. bpo: 1772673 +.. date: 7863 +.. nonce: 5cdzx1 +.. section: C API + +The type of `char*` arguments now changed to `const char*`. + +.. + +.. bpo: 16129 +.. date: 7862 +.. nonce: 8zyucl +.. section: C API + +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) + +.. + +.. bpo: 19275 +.. date: 7861 +.. nonce: uboiiw +.. section: Tests + +Fix test_site on AMD64 Snow Leopard + +.. + +.. bpo: 14407 +.. date: 7860 +.. nonce: -tmRl9 +.. section: Tests + +Fix unittest test discovery in test_concurrent_futures. + +.. + +.. bpo: 18919 +.. date: 7859 +.. nonce: cEkIuG +.. section: Tests + +Unified and extended tests for audio modules: aifc, sunau and wave. + +.. + +.. bpo: 18714 +.. date: 7858 +.. nonce: tcsRe- +.. section: Tests + +Added tests for ``pdb.find_function()``. + +.. + +.. bpo: 18758 +.. date: 7857 +.. nonce: hMCi7Z +.. section: Documentation + +Fixed and improved cross-references. + +.. + +.. bpo: 18972 +.. date: 7856 +.. nonce: iFwRVt +.. section: Documentation + +Modernize email examples and use the argparse module in them. + +.. + +.. bpo: 19130 +.. date: 7855 +.. nonce: 7l54jz +.. section: Build + +Correct PCbuild/readme.txt, Python 3.3 and 3.4 require VS 2010. + +.. + +.. bpo: 15663 +.. date: 7854 +.. nonce: 72Jlq0 +.. section: Build + +Update OS X 10.6+ installer to use Tcl/Tk 8.5.15. + +.. + +.. bpo: 14499 +.. date: 7853 +.. nonce: 5ipy19 +.. section: Build + +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. + +.. + +.. bpo: 19019 +.. date: 7852 +.. nonce: 5W7lw_ +.. section: Build + +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. diff --git a/Misc/NEWS.d/3.4.0b1.rst b/Misc/NEWS.d/3.4.0b1.rst new file mode 100644 index 00000000000..5d93b0a4dbb --- /dev/null +++ b/Misc/NEWS.d/3.4.0b1.rst @@ -0,0 +1,1451 @@ +.. bpo: 0 +.. date: 8065 +.. nonce: HZ3bne +.. release date: 2013-11-24 +.. section: Core and Builtins + +Use the repr of a module name in more places in import, especially +exceptions. + +.. + +.. bpo: 19619 +.. date: 8064 +.. nonce: p4mly- +.. section: Core and Builtins + +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) + +.. + +.. bpo: 19183 +.. date: 8063 +.. nonce: uRQl7Q +.. section: Core and Builtins + +Implement PEP 456 'secure and interchangeable hash algorithm'. Python now +uses SipHash24 on all major platforms. + +.. + +.. bpo: 12892 +.. date: 8062 +.. nonce: TBN6AI +.. section: Core and Builtins + +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. + +.. + +.. bpo: 17806 +.. date: 8061 +.. nonce: Mkg_9s +.. section: Core and Builtins + +Added keyword-argument support for "tabsize" to str/bytes.expandtabs(). + +.. + +.. bpo: 17828 +.. date: 8060 +.. nonce: -sD57u +.. section: Core and Builtins + +Output type errors in str.encode(), bytes.decode() and bytearray.decode() +now direct users to codecs.encode() or codecs.decode() as appropriate. + +.. + +.. bpo: 17828 +.. date: 8059 +.. nonce: k-Stau +.. section: Core and Builtins + +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. + +.. + +.. bpo: 19466 +.. date: 8058 +.. nonce: QjlDnq +.. section: Core and Builtins + +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. + +.. + +.. bpo: 19514 +.. date: 8057 +.. nonce: FfR4kF +.. section: Core and Builtins + +Deduplicate some _Py_IDENTIFIER declarations. Patch by Andrei Dorian Duma. + +.. + +.. bpo: 17936 +.. date: 8056 +.. nonce: Vva8kQ +.. section: Core and Builtins + +Fix O(n**2) behaviour when adding or removing many subclasses of a given +type. + +.. + +.. bpo: 19428 +.. date: 8055 +.. nonce: wN6Oyz +.. section: Core and Builtins + +zipimport now handles errors when reading truncated or invalid ZIP archive. + +.. + +.. bpo: 18408 +.. date: 8054 +.. nonce: IDTlVz +.. section: Core and Builtins + +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. + +.. + +.. bpo: 19369 +.. date: 8053 +.. nonce: 19W2nG +.. section: Core and Builtins + +Optimized the usage of __length_hint__(). + +.. + +.. bpo: 18603 +.. date: 8052 +.. nonce: 7SMyAQ +.. section: Core and Builtins + +Ensure that PyOS_mystricmp and PyOS_mystrnicmp are in the Python executable +and not removed by the linker's optimizer. + +.. + +.. bpo: 19306 +.. date: 8051 +.. nonce: PYfqS6 +.. section: Core and Builtins + +Add extra hints to the faulthandler module's stack dumps that these are +"upside down". + +.. + +.. bpo: 3158 +.. date: 8050 +.. nonce: Uuris9 +.. section: Library + +doctest can now find doctests in functions and methods written in C. + +.. + +.. bpo: 13477 +.. date: 8049 +.. nonce: KYiO6P +.. section: Library + +Added command line interface to the tarfile module. Original patch by Berker +Peksag. + +.. + +.. bpo: 19674 +.. date: 8048 +.. nonce: wDLXgw +.. section: Library + +inspect.signature() now produces a correct signature for some builtins. + +.. + +.. bpo: 19722 +.. date: 8047 +.. nonce: pZvdfi +.. section: Library + +Added opcode.stack_effect(), which computes the stack effect of bytecode +instructions. + +.. + +.. bpo: 19735 +.. date: 8046 +.. nonce: 4JGp9S +.. section: Library + +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(). + +.. + +.. bpo: 16203 +.. date: 8045 +.. nonce: Obg29F +.. section: Library + +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. + +.. + +.. bpo: 13592 +.. date: 8044 +.. nonce: LI-pVN +.. section: Library + +Improved the repr for regular expression pattern objects. Based on patch by +Hugo Lopes Tavares. + +.. + +.. bpo: 19641 +.. date: 8043 +.. nonce: S_oEqp +.. section: Library + +Added the audioop.byteswap() function to convert big-endian samples to +little-endian and vice versa. + +.. + +.. bpo: 15204 +.. date: 8042 +.. nonce: bICOJc +.. section: Library + +Deprecated the 'U' mode in file-like objects. + +.. + +.. bpo: 17810 +.. date: 8041 +.. nonce: eJrPc5 +.. section: Library + +Implement PEP 3154, pickle protocol 4. + +.. + +.. bpo: 19668 +.. date: 8040 +.. nonce: e177xD +.. section: Library + +Added support for the cp1125 encoding. + +.. + +.. bpo: 19689 +.. date: 8039 +.. nonce: ucsUkZ +.. section: Library + +Add ssl.create_default_context() factory function. It creates a new +SSLContext object with secure default settings. + +.. + +.. bpo: 19727 +.. date: 8038 +.. nonce: 7z890j +.. section: Library + +os.utime(..., None) is now potentially more precise under Windows. + +.. + +.. bpo: 17201 +.. date: 8037 +.. nonce: x3oEjg +.. section: Library + +ZIP64 extensions now are enabled by default. Patch by William Mallard. + +.. + +.. bpo: 19292 +.. date: 8036 +.. nonce: SRsZqK +.. section: Library + +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. + +.. + +.. bpo: 19673 +.. date: 8035 +.. nonce: cbMrgH +.. section: Library + +Add pathlib to the stdlib as a provisional module (PEP 428). + +.. + +.. bpo: 16596 +.. date: 8034 +.. nonce: Fk4mD0 +.. section: Library + +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.) + +.. + +.. bpo: 17916 +.. date: 8033 +.. nonce: NhM62k +.. section: Library + +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). + +.. + +.. bpo: 19552 +.. date: 8032 +.. nonce: YLwRGR +.. section: Library + +venv now supports bootstrapping pip into virtual environments + +.. + +.. bpo: 17134 +.. date: 8031 +.. nonce: 59bg3U +.. section: Library + +Finalize interface to Windows' certificate store. Cert and CRL enumeration +are now two functions. enum_certificates() also returns purpose flags as set +of OIDs. + +.. + +.. bpo: 19555 +.. date: 8030 +.. nonce: Cl1wp9 +.. section: Library + +Restore sysconfig.get_config_var('SO'), (and the distutils equivalent) with +a DeprecationWarning pointing people at $EXT_SUFFIX. + +.. + +.. bpo: 8813 +.. date: 8029 +.. nonce: eOLgxE +.. section: Library + +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. + +.. + +.. bpo: 18294 +.. date: 8028 +.. nonce: hCjVbY +.. section: Library + +Fix the zlib module to make it 64-bit safe. + +.. + +.. bpo: 19682 +.. date: 8027 +.. nonce: Ruo2jD +.. section: Library + +Fix compatibility issue with old version of OpenSSL that was introduced by +Issue #18379. + +.. + +.. bpo: 14455 +.. date: 8026 +.. nonce: p3C8TR +.. section: Library + +plistlib now supports binary plists and has an updated API. + +.. + +.. bpo: 19633 +.. date: 8025 +.. nonce: XJNQit +.. section: Library + +Fixed writing not compressed 16- and 32-bit wave files on big-endian +platforms. + +.. + +.. bpo: 18379 +.. date: 8024 +.. nonce: 6MEkk8 +.. section: Library + +SSLSocket.getpeercert() returns CA issuer AIA fields, OCSP and CRL +distribution points. + +.. + +.. bpo: 18138 +.. date: 8023 +.. nonce: Xt0I1D +.. section: Library + +Implement cadata argument of SSLContext.load_verify_location() to load CA +certificates and CRL from memory. It supports PEM and DER encoded strings. + +.. + +.. bpo: 18775 +.. date: 8022 +.. nonce: Q0s2iT +.. section: Library + +Add name and block_size attribute to HMAC object. They now provide the same +API elements as non-keyed cryptographic hash functions. + +.. + +.. bpo: 17276 +.. date: 8021 +.. nonce: Rusj_j +.. section: Library + +MD5 as default digestmod for HMAC is deprecated. The HMAC module supports +digestmod names, e.g. hmac.HMAC('sha1'). + +.. + +.. bpo: 19449 +.. date: 8020 +.. nonce: F2TbC_ +.. section: Library + +in csv's writerow, handle non-string keys when generating the error message +that certain keys are not in the 'fieldnames' list. + +.. + +.. bpo: 13633 +.. date: 8019 +.. nonce: 1AJC3w +.. section: Library + +Added a new convert_charrefs keyword arg to HTMLParser that, when True, +automatically converts all character references. + +.. + +.. bpo: 2927 +.. date: 8018 +.. nonce: 5t4wCh +.. section: Library + +Added the unescape() function to the html module. + +.. + +.. bpo: 8402 +.. date: 8017 +.. nonce: -VPGJN +.. section: Library + +Added the escape() function to the glob module. + +.. + +.. bpo: 17618 +.. date: 8016 +.. nonce: OI2l3J +.. section: Library + +Add Base85 and Ascii85 encoding/decoding to the base64 module. + +.. + +.. bpo: 19634 +.. date: 8015 +.. nonce: -pzaWO +.. section: Library + +time.strftime("%y") now raises a ValueError on AIX when given a year before +1900. + +.. + +.. bpo: 0 +.. date: 8014 +.. nonce: -1Tvel +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 8013 +.. nonce: pmUthH +.. section: Library + +Fix compilation error under gcc of the ctypes module bundled libffi for arm. + +.. + +.. bpo: 19448 +.. date: 8012 +.. nonce: oHsofd +.. section: Library + +Add private API to SSL module to lookup ASN.1 objects by OID, NID, short +name and long name. + +.. + +.. bpo: 19282 +.. date: 8011 +.. nonce: dDB6fB +.. section: Library + +dbm.open now supports the context management protocol. (Initial patch by +Claudiu Popa) + +.. + +.. bpo: 8311 +.. date: 8010 +.. nonce: 1h-XNN +.. section: Library + +Added support for writing any bytes-like objects in the aifc, sunau, and +wave modules. + +.. + +.. bpo: 5202 +.. date: 8009 +.. nonce: Qmv91E +.. section: Library + +Added support for unseekable files in the wave module. + +.. + +.. bpo: 19544 +.. date: 8008 +.. nonce: KA-RHQ +.. section: Library + +Restore global option to ignore ~/.pydistutils.cfg in Distutils, +accidentally removed in backout of distutils2 changes. (See also: bpo-1180) + +.. + +.. bpo: 19523 +.. date: 8007 +.. nonce: tNiY9i +.. section: Library + +Closed FileHandler leak which occurred when delay was set. + +.. + +.. bpo: 19544 +.. date: 8006 +.. nonce: vFbcTR +.. section: Library + +Restore support for --user and --group parameters to sdist command +accidentally rolled back as part of the distutils2 rollback. (See also: +bpo-6516) + +.. + +.. bpo: 13674 +.. date: 8005 +.. nonce: EIYe4u +.. section: Library + +Prevented time.strftime from crashing on Windows when given a year before +1900 and a format of %y. + +.. + +.. bpo: 19406 +.. date: 8004 +.. nonce: _vGZ47 +.. section: Library + +implementation of the ensurepip module (part of PEP 453). Patch by Donald +Stufft and Nick Coghlan. + +.. + +.. bpo: 19544 +.. date: 8003 +.. nonce: NJk1xH +.. section: Library + +Restore use of urllib over http allowing use of http_proxy for Distutils +upload command, a feature accidentally lost in the rollback of distutils2. +(See also: bpo-6286) + +.. + +.. bpo: 19544 +.. date: 8002 +.. nonce: ZtCJGn +.. section: Library + +Restore the read_pkg_file method to distutils.dist.DistributionMetadata +accidentally removed in the undo of distutils2. (See also: bpo-7457) + +.. + +.. bpo: 16685 +.. date: 8001 +.. nonce: qc5QWm +.. section: Library + +Added support for any bytes-like objects in the audioop module. Removed +support for strings. + +.. + +.. bpo: 7171 +.. date: 8000 +.. nonce: irjmxW +.. section: Library + +Add Windows implementation of ``inet_ntop`` and ``inet_pton`` to socket +module. Patch by Atsuo Ishimoto. + +.. + +.. bpo: 19261 +.. date: 7999 +.. nonce: MDxLbN +.. section: Library + +Added support for writing 24-bit samples in the sunau module. + +.. + +.. bpo: 1097797 +.. date: 7998 +.. nonce: s8FvuZ +.. section: Library + +Added CP273 encoding, used on IBM mainframes in Germany and Austria. +Mapping provided by Michael Bierenfeld. + +.. + +.. bpo: 1575020 +.. date: 7997 +.. nonce: skWyvl +.. section: Library + +Fixed support of 24-bit wave files on big-endian platforms. + +.. + +.. bpo: 19378 +.. date: 7996 +.. nonce: 1XDVqS +.. section: Library + +Fixed a number of cases in the dis module where the new "file" parameter was +not being honoured correctly + +.. + +.. bpo: 19378 +.. date: 7995 +.. nonce: s_AkzU +.. section: Library + +Removed the "dis.Bytecode.show_info" method + +.. + +.. bpo: 19378 +.. date: 7994 +.. nonce: mEYzGf +.. section: Library + +Renamed the "dis.Bytecode.display_code" method to "dis.Bytecode.dis" and +converted it to returning a string rather than printing output. + +.. + +.. bpo: 19378 +.. date: 7993 +.. nonce: zuYjXC +.. section: Library + +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. + +.. + +.. bpo: 18678 +.. date: 7992 +.. nonce: 7wTha_ +.. section: Library + +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. + +.. + +.. bpo: 6157 +.. date: 7991 +.. nonce: SpFEy2 +.. section: Library + +Fixed tkinter.Text.debug(). tkinter.Text.bbox() now raises TypeError +instead of TclError on wrong number of arguments. Original patch by +Guilherme Polo. + +.. + +.. bpo: 10197 +.. date: 7990 +.. nonce: 6uq2Xn +.. section: Library + +Rework subprocess.get[status]output to use subprocess functionality and thus +to work on Windows. Patch by Nick Coghlan + +.. + +.. bpo: 6160 +.. date: 7989 +.. nonce: Mr5UuA +.. section: Library + +The bbox() method of tkinter.Spinbox now returns a tuple of integers instead +of a string. Based on patch by Guilherme Polo. + +.. + +.. bpo: 19403 +.. date: 7988 +.. nonce: rJUF8f +.. section: Library + +contextlib.redirect_stdout is now reentrant + +.. + +.. bpo: 19286 +.. date: 7987 +.. nonce: TUZetF +.. section: Library + +Directories in ``package_data`` are no longer added to the filelist, +preventing failure outlined in the ticket. + +.. + +.. bpo: 19480 +.. date: 7986 +.. nonce: MY3dmW +.. section: Library + +HTMLParser now accepts all valid start-tag names as defined by the HTML5 +standard. + +.. + +.. bpo: 15114 +.. date: 7985 +.. nonce: MuB2Yy +.. section: Library + +The html.parser module now raises a DeprecationWarning when the strict +argument of HTMLParser or the HTMLParser.error method are used. + +.. + +.. bpo: 19410 +.. date: 7984 +.. nonce: OU3U4K +.. section: Library + +Undo the special-casing removal of '' for importlib.machinery.FileFinder. + +.. + +.. bpo: 19424 +.. date: 7983 +.. nonce: vYBdnZ +.. section: Library + +Fix the warnings module to accept filename containing surrogate characters. + +.. + +.. bpo: 19435 +.. date: 7982 +.. nonce: kXqMz3 +.. section: Library + +Fix directory traversal attack on CGIHttpRequestHandler. + +.. + +.. bpo: 19227 +.. date: 7981 +.. nonce: yGdfN6 +.. section: Library + +Remove pthread_atfork() handler. The handler was added to solve #18747 but +has caused issues. + +.. + +.. bpo: 19420 +.. date: 7980 +.. nonce: eJad_G +.. section: Library + +Fix reference leak in module initialization code of _hashopenssl.c + +.. + +.. bpo: 19329 +.. date: 7979 +.. nonce: f3o3tr +.. section: Library + +Optimized compiling charsets in regular expressions. + +.. + +.. bpo: 19227 +.. date: 7978 +.. nonce: -dpnbn +.. section: Library + +Try to fix deadlocks caused by re-seeding then OpenSSL pseudo-random number +generator on fork(). + +.. + +.. bpo: 16037 +.. date: 7977 +.. nonce: cxufSm +.. section: Library + +HTTPMessage.readheaders() raises an HTTPException when more than 100 headers +are read. Adapted from patch by Jyrki Pulliainen. + +.. + +.. bpo: 16040 +.. date: 7976 +.. nonce: xg3xlX +.. section: Library + +CVE-2013-1752: nntplib: Limit maximum line lengths to 2048 to prevent +readline() calls from consuming too much memory. Patch by Jyrki Pulliainen. + +.. + +.. bpo: 16041 +.. date: 7975 +.. nonce: XFY0lr +.. section: Library + +CVE-2013-1752: poplib: Limit maximum line lengths to 2048 to prevent +readline() calls from consuming too much memory. Patch by Jyrki Pulliainen. + +.. + +.. bpo: 17997 +.. date: 7974 +.. nonce: sJUozx +.. section: Library + +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. + +.. + +.. bpo: 16039 +.. date: 7973 +.. nonce: ipafYi +.. section: Library + +CVE-2013-1752: Change use of readline in imaplib module to limit line +length. Patch by Emil Lind. + +.. + +.. bpo: 19330 +.. date: 7972 +.. nonce: -pfViq +.. section: Library + +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 + +.. + +.. bpo: 19393 +.. date: 7971 +.. nonce: ytbAwl +.. section: Library + +Fix symtable.symtable function to not be confused when there are functions +or classes named "top". + +.. + +.. bpo: 18685 +.. date: 7970 +.. nonce: R0OJ2- +.. section: Library + +Restore re performance to pre-PEP 393 levels. + +.. + +.. bpo: 19339 +.. date: 7969 +.. nonce: kxMuh2 +.. section: Library + +telnetlib module is now using time.monotonic() when available to compute +timeout. + +.. + +.. bpo: 19399 +.. date: 7968 +.. nonce: ofrcCx +.. section: Library + +fix sporadic test_subprocess failure. + +.. + +.. bpo: 13234 +.. date: 7967 +.. nonce: uuePvu +.. section: Library + +Fix os.listdir to work with extended paths on Windows. Patch by Santoso +Wijaya. + +.. + +.. bpo: 19375 +.. date: 7966 +.. nonce: Kbkj5C +.. section: Library + +The site module adding a "site-python" directory to sys.path, if it exists, +is now deprecated. + +.. + +.. bpo: 19379 +.. date: 7965 +.. nonce: jOblDO +.. section: Library + +Lazily import linecache in the warnings module, to make startup with +warnings faster until a warning gets printed. + +.. + +.. bpo: 19288 +.. date: 7964 +.. nonce: nKDzgw +.. section: Library + +Fixed the "in" operator of dbm.gnu databases for string argument. Original +patch by Arfrever Frehtes Taifersar Arahesis. + +.. + +.. bpo: 19287 +.. date: 7963 +.. nonce: IVl3jY +.. section: Library + +Fixed the "in" operator of dbm.ndbm databases for string argument. Original +patch by Arfrever Frehtes Taifersar Arahesis. + +.. + +.. bpo: 19327 +.. date: 7962 +.. nonce: S7Xvxs +.. section: Library + +Fixed the working of regular expressions with too big charset. + +.. + +.. bpo: 17400 +.. date: 7961 +.. nonce: 8BUFmy +.. section: Library + +New 'is_global' attribute for ipaddress to tell if an address is allocated +by IANA for global or private networks. + +.. + +.. bpo: 19350 +.. date: 7960 +.. nonce: MCCKjK +.. section: Library + +Increasing the test coverage of macurl2path. Patch by Colin Williams. + +.. + +.. bpo: 19365 +.. date: 7959 +.. nonce: ZBG2Mi +.. section: Library + +Optimized the parsing of long replacement string in re.sub*() functions. + +.. + +.. bpo: 19352 +.. date: 7958 +.. nonce: 3TfAkY +.. section: Library + +Fix unittest discovery when a module can be reached through several paths +(e.g. under Debian/Ubuntu with virtualenv). + +.. + +.. bpo: 15207 +.. date: 7957 +.. nonce: piOBBi +.. section: Library + +Fix mimetypes to read from correct part of Windows registry Original patch +by Dave Chambers + +.. + +.. bpo: 16595 +.. date: 7956 +.. nonce: Be5Hga +.. section: Library + +Add prlimit() to resource module. + +.. + +.. bpo: 19324 +.. date: 7955 +.. nonce: e0cvlt +.. section: Library + +Expose Linux-specific constants in resource module. + +.. + +.. bpo: 0 +.. date: 7954 +.. nonce: sxxiug +.. section: Library + +Load SSL's error strings in hashlib. + +.. + +.. bpo: 18527 +.. date: 7953 +.. nonce: fA-A37 +.. section: Library + +Upgrade internal copy of zlib to 1.2.8. + +.. + +.. bpo: 19274 +.. date: 7952 +.. nonce: i8khqy +.. section: Library + +Add a filterfunc parameter to PyZipFile.writepy. + +.. + +.. bpo: 8964 +.. date: 7951 +.. nonce: dzU2FB +.. section: Library + +fix platform._sys_version to handle IronPython 2.6+. Patch by Martin +Matusiak. + +.. + +.. bpo: 19413 +.. date: 7950 +.. nonce: 2Niic6 +.. section: Library + +Restore pre-3.3 reload() semantics of re-finding modules. + +.. + +.. bpo: 18958 +.. date: 7949 +.. nonce: AoIQm9 +.. section: Library + +Improve error message for json.load(s) while passing a string that starts +with a UTF-8 BOM. + +.. + +.. bpo: 19307 +.. date: 7948 +.. nonce: iFye0G +.. section: Library + +Improve error message for json.load(s) while passing objects of the wrong +type. + +.. + +.. bpo: 16038 +.. date: 7947 +.. nonce: TZGbSo +.. section: Library + +CVE-2013-1752: ftplib: Limit amount of data read by limiting the call to +readline(). Original patch by Micha? Jastrz?bski and Giampaolo Rodola. + +.. + +.. bpo: 17087 +.. date: 7946 +.. nonce: A3XA7C +.. section: Library + +Improved the repr for regular expression match objects. + +.. + +.. bpo: 19664 +.. date: 7945 +.. nonce: Nw449E +.. section: Tests + +test_userdict's repr test no longer depends on the order of dict elements. + +.. + +.. bpo: 19440 +.. date: 7944 +.. nonce: BW6mI9 +.. section: Tests + +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. + +.. + +.. bpo: 19378 +.. date: 7943 +.. nonce: zeWIz0 +.. section: Tests + +the main dis module tests are now run with both stdout redirection *and* +passing an explicit file parameter + +.. + +.. bpo: 19378 +.. date: 7942 +.. nonce: MOkpfA +.. section: Tests + +removed the not-actually-helpful assertInstructionMatches and +assertBytecodeExactlyMatches helpers from bytecode_helper + +.. + +.. bpo: 18702 +.. date: 7941 +.. nonce: 91BEkZ +.. section: Tests + +All skipped tests now reported as skipped. + +.. + +.. bpo: 19439 +.. date: 7940 +.. nonce: J96-Vv +.. section: Tests + +interpreter embedding tests are now executed on Windows (Patch by Zachary +Ware) + +.. + +.. bpo: 19085 +.. date: 7939 +.. nonce: Gcl9XX +.. section: Tests + +Added basic tests for all tkinter widget options. + +.. + +.. bpo: 19384 +.. date: 7938 +.. nonce: v6r_8A +.. section: Tests + +Fix test_py_compile for root user, patch by Claudiu Popa. + +.. + +.. bpo: 18326 +.. date: 7937 +.. nonce: juaetA +.. section: Documentation + +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. + +.. + +.. bpo: 19358 +.. date: 7936 +.. nonce: 80ySM- +.. section: Build + +"make clinic" now runs the Argument Clinic preprocessor over all CPython +source files. + +.. + +.. bpo: 0 +.. date: 7935 +.. nonce: -GnKfJ +.. section: Build + +Update SQLite to 3.8.1, xz to 5.0.5, and Tcl/Tk to 8.6.1 on Windows. + +.. + +.. bpo: 16632 +.. date: 7934 +.. nonce: BiQhFA +.. section: Build + +Enable DEP and ASLR on Windows. + +.. + +.. bpo: 17791 +.. date: 7933 +.. nonce: fExj5r +.. section: Build + +Drop PREFIX and EXEC_PREFIX definitions from PC/pyconfig.h + +.. + +.. bpo: 0 +.. date: 7932 +.. nonce: uI77cH +.. section: Build + +Add workaround for VS 2010 nmake clean issue. VS 2010 doesn't set up PATH +for nmake.exe correctly. + +.. + +.. bpo: 19550 +.. date: 7931 +.. nonce: MLDPnk +.. section: Build + +Implement Windows installer changes of PEP 453 (ensurepip). + +.. + +.. bpo: 19520 +.. date: 7930 +.. nonce: KBn7ff +.. section: Build + +Fix compiler warning in the _sha3 module on 32bit Windows. + +.. + +.. bpo: 19356 +.. date: 7929 +.. nonce: lHamQS +.. section: Build + +Avoid using a C variabled named "_self", it's a reserved word in some C +compilers. + +.. + +.. bpo: 15792 +.. date: 7928 +.. nonce: Rx4fV2 +.. section: Build + +Correct build options on Win64. Patch by Jeremy Kloth. + +.. + +.. bpo: 19373 +.. date: 7927 +.. nonce: Gxnb8v +.. section: Build + +Apply upstream change to Tk 8.5.15 fixing OS X 10.9 screen refresh problem +for OS X installer build. + +.. + +.. bpo: 19649 +.. date: 7926 +.. nonce: yuZ3xq +.. section: Build + +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. + +.. + +.. bpo: 19553 +.. date: 7925 +.. nonce: JY6pHm +.. section: Build + +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]". + +.. + +.. bpo: 19551 +.. date: 7924 +.. nonce: Co7ZOp +.. section: Build + +PEP 453 - the OS X installer now installs pip by default. + +.. + +.. bpo: 0 +.. date: 7923 +.. nonce: kxcK-F +.. section: Build + +Update third-party libraries for OS X installers: xz 5.0.3 -> 5.0.5, SQLite +3.7.13 -> 3.8.1 + +.. + +.. bpo: 15663 +.. date: 7922 +.. nonce: f91_wP +.. section: Build + +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. + +.. + +.. bpo: 19730 +.. date: 7921 +.. nonce: B7hBq7 +.. section: Tools/Demos + +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. + +.. + +.. bpo: 19552 +.. date: 7920 +.. nonce: zuitRR +.. section: Tools/Demos + +pyvenv now bootstraps pip into virtual environments by default (pass +--without-pip to request the old behaviour) + +.. + +.. bpo: 19390 +.. date: 7919 +.. nonce: CROPNO +.. section: Tools/Demos + +Argument Clinic no longer accepts malformed Python and C ids. diff --git a/Misc/NEWS.d/3.4.0b2.rst b/Misc/NEWS.d/3.4.0b2.rst new file mode 100644 index 00000000000..50a1f144cdb --- /dev/null +++ b/Misc/NEWS.d/3.4.0b2.rst @@ -0,0 +1,1197 @@ +.. bpo: 17432 +.. date: 8188 +.. nonce: mmNI4f +.. release date: 2014-01-05 +.. section: Core and Builtins + +Drop UCS2 from names of Unicode functions in python3.def. + +.. + +.. bpo: 19526 +.. date: 8187 +.. nonce: 9WWttQ +.. section: Core and Builtins + +Exclude all new API from the stable ABI. Exceptions can be made if a need is +demonstrated. + +.. + +.. bpo: 19969 +.. date: 8186 +.. nonce: mmRsrB +.. section: Core and Builtins + +PyBytes_FromFormatV() now raises an OverflowError if "%c" argument is not in +range [0; 255]. + +.. + +.. bpo: 19995 +.. date: 8185 +.. nonce: gQHtAc +.. section: Core and Builtins + +%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__. + +.. + +.. bpo: 19787 +.. date: 8184 +.. nonce: tAMy-H +.. section: Core and Builtins + +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). + +.. + +.. bpo: 14432 +.. date: 8183 +.. nonce: yov4oy +.. section: Core and Builtins + +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. + +.. + +.. bpo: 19576 +.. date: 8182 +.. nonce: b_UtIp +.. section: Core and Builtins + +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. + +.. + +.. bpo: 17576 +.. date: 8181 +.. nonce: ukzqsg +.. section: Core and Builtins + +Deprecation warning emitted now when __int__() or __index__() return not int +instance. + +.. + +.. bpo: 19932 +.. date: 8180 +.. nonce: ZU_tXW +.. section: Core and Builtins + +Fix typo in import.h, missing whitespaces in function prototypes. + +.. + +.. bpo: 19736 +.. date: 8179 +.. nonce: j35rNX +.. section: Core and Builtins + +Add module-level statvfs constants defined for GNU/glibc based systems. + +.. + +.. bpo: 20097 +.. date: 8178 +.. nonce: _L-Wql +.. section: Core and Builtins + +Fix bad use of "self" in importlib's WindowsRegistryFinder. + +.. + +.. bpo: 19729 +.. date: 8177 +.. nonce: HmZThe +.. section: Core and Builtins + +In str.format(), fix recursive expansion in format spec. + +.. + +.. bpo: 19638 +.. date: 8176 +.. nonce: lh5Awt +.. section: Core and Builtins + +Fix possible crash / undefined behaviour from huge (more than 2 billion +characters) input strings in _Py_dg_strtod. + +.. + +.. bpo: 20154 +.. date: 8175 +.. nonce: 5JyK0Q +.. section: Library + +Deadlock in asyncio.StreamReader.readexactly(). + +.. + +.. bpo: 16113 +.. date: 8174 +.. nonce: 2gaEPO +.. section: Library + +Remove sha3 module again. + +.. + +.. bpo: 20111 +.. date: 8173 +.. nonce: NsoIDi +.. section: Library + +pathlib.Path.with_suffix() now sanity checks the given suffix. + +.. + +.. bpo: 0 +.. date: 8172 +.. nonce: 6LOl16 +.. section: Library + +Fix breakage in TestSuite.countTestCases() introduced by issue #11798. + +.. + +.. bpo: 20108 +.. date: 8171 +.. nonce: HxuC0s +.. section: Library + +Avoid parameter name clash in inspect.getcallargs(). + +.. + +.. bpo: 19918 +.. date: 8170 +.. nonce: SciMAd +.. section: Library + +Fix PurePath.relative_to() under Windows. + +.. + +.. bpo: 19422 +.. date: 8169 +.. nonce: 1dRaPS +.. section: Library + +Explicitly disallow non-SOCK_STREAM sockets in the ssl module, rather than +silently let them emit clear text data. + +.. + +.. bpo: 20046 +.. date: 8168 +.. nonce: NkWtze +.. section: Library + +Locale alias table no longer contains entities which can be calculated. +Generalized support of the euro modifier. + +.. + +.. bpo: 20027 +.. date: 8167 +.. nonce: dtB7OG +.. section: Library + +Fixed locale aliases for devanagari locales. + +.. + +.. bpo: 20067 +.. date: 8166 +.. nonce: MlnlYd +.. section: Library + +Tkinter variables now work when wantobjects is false. + +.. + +.. bpo: 19020 +.. date: 8165 +.. nonce: _16K__ +.. section: Library + +Tkinter now uses splitlist() instead of split() in configure methods. + +.. + +.. bpo: 19744 +.. date: 8164 +.. nonce: frub3A +.. section: Library + +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) + +.. + +.. bpo: 19734 +.. date: 8163 +.. nonce: jHpBF- +.. section: Library + +ensurepip now ignores all pip environment variables to avoid odd behaviour +based on user configuration settings + +.. + +.. bpo: 0 +.. date: 8162 +.. nonce: d5LOJv +.. section: Library + +Fix TypeError on "setup.py upload --show-response". + +.. + +.. bpo: 20045 +.. date: 8161 +.. nonce: fdKDSA +.. section: Library + +Fix "setup.py register --list-classifiers". + +.. + +.. bpo: 18879 +.. date: 8160 +.. nonce: CEiozo +.. section: Library + +When a method is looked up on a temporary file, avoid closing the file +before the method is possibly called. + +.. + +.. bpo: 20037 +.. date: 8159 +.. nonce: Mnn2jV +.. section: Library + +Avoid crashes when opening a text file late at interpreter shutdown. + +.. + +.. bpo: 19967 +.. date: 8158 +.. nonce: 0zAW9L +.. section: Library + +Thanks to the PEP 442, asyncio.Future now uses a destructor to log uncaught +exceptions, instead of the dedicated _TracebackLogger class. + +.. + +.. bpo: 0 +.. date: 8157 +.. nonce: Gqaj5f +.. section: Library + +Added a Task.current_task() class method to asyncio. + +.. + +.. bpo: 19850 +.. date: 8156 +.. nonce: WPTJDe +.. section: Library + +Set SA_RESTART in asyncio when registering a signal handler to limit EINTR +occurrences. + +.. + +.. bpo: 0 +.. date: 8155 +.. nonce: JivAZe +.. section: Library + +Implemented write flow control in asyncio for proactor event loop (Windows). + +.. + +.. bpo: 0 +.. date: 8154 +.. nonce: WBY2wl +.. section: Library + +Change write buffer in asyncio use to avoid O(N**2) behavior. Make +write()/sendto() accept bytearray/memoryview. + +.. + +.. bpo: 20034 +.. date: 8153 +.. nonce: GlYpNX +.. section: Library + +Updated alias mapping to most recent locale.alias file from X.org +distribution using makelocalealias.py. + +.. + +.. bpo: 5815 +.. date: 8152 +.. nonce: FxSb0P +.. section: Library + +Fixed support for locales with modifiers. Fixed support for locale +encodings with hyphens. + +.. + +.. bpo: 20026 +.. date: 8151 +.. nonce: KO1jB6 +.. section: Library + +Fix the sqlite module to handle correctly invalid isolation level (wrong +type). + +.. + +.. bpo: 18829 +.. date: 8150 +.. nonce: QPwJFn +.. section: Library + +csv.Dialect() now checks type for delimiter, escapechar and quotechar +fields. Original patch by Vajrasky Kok. + +.. + +.. bpo: 19855 +.. date: 8149 +.. nonce: TtBUO6 +.. section: Library + +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. + +.. + +.. bpo: 20007 +.. date: 8148 +.. nonce: IaSnPo +.. section: Library + +HTTPResponse.read(0) no more prematurely closes connection. Original patch +by Simon Sapin. + +.. + +.. bpo: 19946 +.. date: 8147 +.. nonce: hcbn92 +.. section: Library + +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. + +.. + +.. bpo: 19921 +.. date: 8146 +.. nonce: LGeNky +.. section: Library + +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). + +.. + +.. bpo: 19887 +.. date: 8145 +.. nonce: 2jM2qA +.. section: Library + +Improve the Path.resolve() algorithm to support certain symlink chains. + +.. + +.. bpo: 19912 +.. date: 8144 +.. nonce: TviIPi +.. section: Library + +Fixed numerous bugs in ntpath.splitunc(). + +.. + +.. bpo: 19911 +.. date: 8143 +.. nonce: w1QmnT +.. section: Library + +ntpath.splitdrive() now correctly processes the '?' character (U+0130, LATIN +CAPITAL LETTER I WITH DOT ABOVE). + +.. + +.. bpo: 19532 +.. date: 8142 +.. nonce: vCt7bh +.. section: Library + +python -m compileall with no filename/directory arguments now respects the +-f and -q flags instead of ignoring them. + +.. + +.. bpo: 19623 +.. date: 8141 +.. nonce: zv4rIL +.. section: Library + +Fixed writing to unseekable files in the aifc module. + +.. + +.. bpo: 19946 +.. date: 8140 +.. nonce: b4Js6X +.. section: Library + +multiprocessing.spawn now raises ImportError when the module to be used as +the main module cannot be imported. + +.. + +.. bpo: 17919 +.. date: 8139 +.. nonce: H5iGXv +.. section: Library + +select.poll.register() again works with poll.POLLNVAL on AIX. Fixed integer +overflow in the eventmask parameter. + +.. + +.. bpo: 19063 +.. date: 8138 +.. nonce: pQzK1K +.. section: Library + +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). + +.. + +.. bpo: 15475 +.. date: 8137 +.. nonce: -vqlm1 +.. section: Library + +Add __sizeof__ implementations for itertools objects. + +.. + +.. bpo: 19944 +.. date: 8136 +.. nonce: XxQU2O +.. section: Library + +Fix importlib.find_spec() so it imports parents as needed and move the +function to importlib.util. + +.. + +.. bpo: 19880 +.. date: 8135 +.. nonce: wJls1u +.. section: Library + +Fix a reference leak in unittest.TestCase. Explicitly break reference cycles +between frames and the _Outcome instance. + +.. + +.. bpo: 17429 +.. date: 8134 +.. nonce: dlZP0_ +.. section: Library + +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. + +.. + +.. bpo: 19343 +.. date: 8133 +.. nonce: La15PA +.. section: Library + +Expose FreeBSD-specific APIs in resource module. Original patch by Koobs. + +.. + +.. bpo: 19929 +.. date: 8132 +.. nonce: BZDeEj +.. section: Library + +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. + +.. + +.. bpo: 19506 +.. date: 8131 +.. nonce: GteUMC +.. section: Library + +Use a memoryview to avoid a data copy when piping data to stdin within +subprocess.Popen.communicate. 5-10% less cpu usage. + +.. + +.. bpo: 19876 +.. date: 8130 +.. nonce: 2YXHY- +.. section: Library + +selectors unregister() no longer raises ValueError or OSError if the FD is +closed (as long as it was registered). + +.. + +.. bpo: 19908 +.. date: 8129 +.. nonce: rOsMVQ +.. section: Library + +pathlib now joins relative Windows paths correctly when a drive is present. +Original patch by Antoine Pitrou. + +.. + +.. bpo: 19296 +.. date: 8128 +.. nonce: WVPZAK +.. section: Library + +Silence compiler warning in dbm_open + +.. + +.. bpo: 6784 +.. date: 8127 +.. nonce: uxEt6F +.. section: Library + +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. + +.. + +.. bpo: 19839 +.. date: 8126 +.. nonce: qfP0k5 +.. section: Library + +Fix regression in bz2 module's handling of non-bzip2 data at EOF, and +analogous bug in lzma module. + +.. + +.. bpo: 19881 +.. date: 8125 +.. nonce: NKrKAh +.. section: Library + +Fix pickling bug where cpickle would emit bad pickle data for large bytes +string (i.e., with size greater than 2**32-1). + +.. + +.. bpo: 19138 +.. date: 8124 +.. nonce: xwKrX_ +.. section: Library + +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). + +.. + +.. bpo: 19927 +.. date: 8123 +.. nonce: ZijD-E +.. section: Library + +Add __eq__ to path-based loaders in importlib. + +.. + +.. bpo: 19827 +.. date: 8122 +.. nonce: KBYfyd +.. section: Library + +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. + +.. + +.. bpo: 19785 +.. date: 8121 +.. nonce: dTWAof +.. section: Library + +smtplib now supports SSLContext.check_hostname and server name indication +for TLS/SSL connections. + +.. + +.. bpo: 19784 +.. date: 8120 +.. nonce: t85DbS +.. section: Library + +poplib now supports SSLContext.check_hostname and server name indication for +TLS/SSL connections. + +.. + +.. bpo: 19783 +.. date: 8119 +.. nonce: VRsf8d +.. section: Library + +nntplib now supports SSLContext.check_hostname and server name indication +for TLS/SSL connections. + +.. + +.. bpo: 19782 +.. date: 8118 +.. nonce: 7jF-re +.. section: Library + +imaplib now supports SSLContext.check_hostname and server name indication +for TLS/SSL connections. + +.. + +.. bpo: 20123 +.. date: 8117 +.. nonce: o-MHVk +.. section: Library + +Fix pydoc.synopsis() for "binary" modules. + +.. + +.. bpo: 19834 +.. date: 8116 +.. nonce: rlFmTq +.. section: Library + +Support unpickling of exceptions pickled by Python 2. + +.. + +.. bpo: 19781 +.. date: 8115 +.. nonce: 4ZiyRb +.. section: Library + +ftplib now supports SSLContext.check_hostname and server name indication for +TLS/SSL connections. + +.. + +.. bpo: 19509 +.. date: 8114 +.. nonce: I2qj0u +.. section: Library + +Add SSLContext.check_hostname to match the peer's certificate with +server_hostname on handshake. + +.. + +.. bpo: 15798 +.. date: 8113 +.. nonce: 1bxNCP +.. section: Library + +Fixed subprocess.Popen() to no longer fail if file descriptor 0, 1 or 2 is +closed. + +.. + +.. bpo: 17897 +.. date: 8112 +.. nonce: 0iKzvE +.. section: Library + +Optimized unpickle prefetching. + +.. + +.. bpo: 3693 +.. date: 8111 +.. nonce: _c0s5z +.. section: Library + +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. + +.. + +.. bpo: 19088 +.. date: 8110 +.. nonce: JBKVzp +.. section: Library + +Fixed incorrect caching of the copyreg module in object.__reduce__() and +object.__reduce_ex__(). + +.. + +.. bpo: 19698 +.. date: 8109 +.. nonce: Xcq8uC +.. section: Library + +Removed exec_module() methods from importlib.machinery.BuiltinImporter and +ExtensionFileLoader. + +.. + +.. bpo: 18864 +.. date: 8108 +.. nonce: 2CR2Xi +.. section: Library + +Added a setter for ModuleSpec.has_location. + +.. + +.. bpo: 0 +.. date: 8107 +.. nonce: UKWITk +.. section: Library + +Fixed _pickle.Unpickler to not fail when loading empty strings as persistent +IDs. + +.. + +.. bpo: 11480 +.. date: 8106 +.. nonce: qkIZLG +.. section: Library + +Fixed copy.copy to work with classes with custom metaclasses. Patch by +Daniel Urban. + +.. + +.. bpo: 6477 +.. date: 8105 +.. nonce: nK1lHr +.. section: Library + +Added support for pickling the types of built-in singletons (i.e., Ellipsis, +NotImplemented, None). + +.. + +.. bpo: 19713 +.. date: 8104 +.. nonce: UhiUKc +.. section: Library + +Add remaining PEP 451-related deprecations and move away from using +find_module/find_loaer/load_module. + +.. + +.. bpo: 19708 +.. date: 8103 +.. nonce: HJuToY +.. section: Library + +Update pkgutil to use the new importer APIs. + +.. + +.. bpo: 19703 +.. date: 8102 +.. nonce: pLtVYQ +.. section: Library + +Update pydoc to use the new importer APIs. + +.. + +.. bpo: 19851 +.. date: 8101 +.. nonce: 4HQZWz +.. section: Library + +Fixed a regression in reloading sub-modules. + +.. + +.. bpo: 0 +.. date: 8100 +.. nonce: 3H16yn +.. section: Library + +ssl.create_default_context() sets OP_NO_COMPRESSION to prevent CRIME. + +.. + +.. bpo: 19802 +.. date: 8099 +.. nonce: PswaEk +.. section: Library + +Add socket.SO_PRIORITY. + +.. + +.. bpo: 11508 +.. date: 8098 +.. nonce: fx7Abs +.. section: Library + +Fixed uuid.getnode() and uuid.uuid1() on environment with virtual interface. +Original patch by Kent Frazier. + +.. + +.. bpo: 11489 +.. date: 8097 +.. nonce: 3ZQHi8 +.. section: Library + +JSON decoder now accepts lone surrogates. + +.. + +.. bpo: 19545 +.. date: 8096 +.. nonce: 1FBY5Z +.. section: Library + +Avoid chained exceptions while passing stray % to time.strptime(). Initial +patch by Claudiu Popa. + +.. + +.. bpo: 20058 +.. date: 8095 +.. nonce: KnDlhH +.. section: IDLE + +sys.stdin.readline() in IDLE now always returns only one line. + +.. + +.. bpo: 19481 +.. date: 8094 +.. nonce: BNkHOm +.. section: IDLE + +print() of string subclass instance in IDLE no longer hangs. + +.. + +.. bpo: 18270 +.. date: 8093 +.. nonce: lu6dRW +.. section: IDLE + +Prevent possible IDLE AttributeError on OS X when no initial shell window is +present. + +.. + +.. bpo: 20055 +.. date: 8092 +.. nonce: iE7yU6 +.. section: Tests + +Fix test_shutil under Windows with symlink privileges held. Patch by +Vajrasky Kok. + +.. + +.. bpo: 20070 +.. date: 8091 +.. nonce: HpyZrQ +.. section: Tests + +Don't run test_urllib2net when network resources are not enabled. + +.. + +.. bpo: 19938 +.. date: 8090 +.. nonce: 2iLiKJ +.. section: Tests + +Re-enabled test_bug_1333982 in test_dis, which had been disabled since 3.0 +due to the changes in listcomp handling. + +.. + +.. bpo: 19320 +.. date: 8089 +.. nonce: 9x_cw5 +.. section: Tests + +test_tcl no longer fails when wantobjects is false. + +.. + +.. bpo: 19919 +.. date: 8088 +.. nonce: N9bnWv +.. section: Tests + +Fix flaky SSL test. connect_ex() sometimes returns EWOULDBLOCK on Windows or +VMs hosted on Windows. + +.. + +.. bpo: 19912 +.. date: 8087 +.. nonce: NmE9ZX +.. section: Tests + +Added tests for ntpath.splitunc(). + +.. + +.. bpo: 19828 +.. date: 8086 +.. nonce: f5HrFG +.. section: Tests + +Fixed test_site when the whole suite is run with -S. + +.. + +.. bpo: 19928 +.. date: 8085 +.. nonce: dwOQ95 +.. section: Tests + +Implemented a test for repr() of cell objects. + +.. + +.. bpo: 19535 +.. date: 8084 +.. nonce: 9ZtpA7 +.. section: Tests + +Fixed test_docxmlrpc, test_functools, test_inspect, and test_statistics when +python is run with -OO. + +.. + +.. bpo: 19926 +.. date: 8083 +.. nonce: fkWjtw +.. section: Tests + +Removed unneeded test_main from test_abstract_numbers. Patch by Vajrasky +Kok. + +.. + +.. bpo: 19572 +.. date: 8082 +.. nonce: _65KAy +.. section: Tests + +More skipped tests explicitly marked as skipped. + +.. + +.. bpo: 19595 +.. date: 8081 +.. nonce: q5oNE_ +.. section: Tests + +Re-enabled a long-disabled test in test_winsound. (See also: bpo-19987) + +.. + +.. bpo: 19588 +.. date: 8080 +.. nonce: EXKxpC +.. section: Tests + +Fixed tests in test_random that were silently skipped most of the time. +Patch by Julian Gindi. + +.. + +.. bpo: 19728 +.. date: 8079 +.. nonce: q1zXeT +.. section: Build + +Enable pip installation by default on Windows. + +.. + +.. bpo: 16136 +.. date: 8078 +.. nonce: FQGvGl +.. section: Build + +Remove VMS support + +.. + +.. bpo: 18215 +.. date: 8077 +.. nonce: yw2j0l +.. section: Build + +Add script Tools/ssl/test_multiple_versions.py to compile and run Python's +unit tests with multiple versions of OpenSSL. + +.. + +.. bpo: 19922 +.. date: 8076 +.. nonce: cG30aH +.. section: Build + +define _INCLUDE__STDC_A1_SOURCE in HP-UX to include mbstate_t for mbrtowc(). + +.. + +.. bpo: 19788 +.. date: 8075 +.. nonce: P7qrFB +.. section: Build + +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. + +.. + +.. bpo: 20265 +.. date: 8074 +.. nonce: J7Xxm7 +.. section: Documentation + +Updated some parts of the Using Windows document. + +.. + +.. bpo: 20266 +.. date: 8073 +.. nonce: CieiXa +.. section: Documentation + +Updated some parts of the Windows FAQ. + +.. + +.. bpo: 20255 +.. date: 8072 +.. nonce: SnYjEP +.. section: Documentation + +Updated the about and bugs pages. + +.. + +.. bpo: 20253 +.. date: 8071 +.. nonce: nbp6uJ +.. section: Documentation + +Fixed a typo in the ipaddress docs that advertised an illegal attribute +name. Found by INADA Naoki. + +.. + +.. bpo: 18840 +.. date: 8070 +.. nonce: _2UItV +.. section: Documentation + +Introduce the json module in the tutorial, and de-emphasize the pickle +module. + +.. + +.. bpo: 19845 +.. date: 8069 +.. nonce: luj-oI +.. section: Documentation + +Updated the Compiling Python on Windows section. + +.. + +.. bpo: 19795 +.. date: 8068 +.. nonce: z5sbe1 +.. section: Documentation + +Improved markup of True/False constants. + +.. + +.. bpo: 19659 +.. date: 8067 +.. nonce: kghZl0 +.. section: Tools/Demos + +Added documentation for Argument Clinic. + +.. + +.. bpo: 19976 +.. date: 8066 +.. nonce: My60GG +.. section: Tools/Demos + +Argument Clinic METH_NOARGS functions now always take two parameters. diff --git a/Misc/NEWS.d/3.4.0b3.rst b/Misc/NEWS.d/3.4.0b3.rst new file mode 100644 index 00000000000..e1e4fc6487f --- /dev/null +++ b/Misc/NEWS.d/3.4.0b3.rst @@ -0,0 +1,665 @@ +.. bpo: 20189 +.. date: 8254 +.. nonce: OIbmmo +.. release date: 2014-01-26 +.. section: Core and Builtins + +Four additional builtin types (PyTypeObject, PyMethodDescr_Type, +_PyMethodWrapper_Type, and PyWrapperDescr_Type) have been modified to +provide introspection information for builtins. + +.. + +.. bpo: 17825 +.. date: 8253 +.. nonce: toRoZf +.. section: Core and Builtins + +Cursor "^" is correctly positioned for SyntaxError and IndentationError. + +.. + +.. bpo: 2382 +.. date: 8252 +.. nonce: kL_Sgg +.. section: Core and Builtins + +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. + +.. + +.. bpo: 18960 +.. date: 8251 +.. nonce: lhfZNw +.. section: Core and Builtins + +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. + +.. + +.. bpo: 0 +.. date: 8250 +.. nonce: GB7eBz +.. section: 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. + +.. + +.. bpo: 20311 +.. date: 8249 +.. nonce: -6LF_t +.. section: Library + +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. + +.. + +.. bpo: 20311 +.. date: 8248 +.. nonce: JgE5j7 +.. section: Library + +selectors: Add a resolution attribute to BaseSelector. + +.. + +.. bpo: 20189 +.. date: 8247 +.. nonce: L9IuSm +.. section: Library + +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. + +.. + +.. bpo: 20317 +.. date: 8246 +.. nonce: 9JI93M +.. section: Library + +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. + +.. + +.. bpo: 20374 +.. date: 8245 +.. nonce: EWofHb +.. section: Library + +Fix build with GNU readline >= 6.3. + +.. + +.. bpo: 20262 +.. date: 8244 +.. nonce: co0t1R +.. section: Library + +Warnings are raised now when duplicate names are added in the ZIP file or +too long ZIP file comment is truncated. + +.. + +.. bpo: 20165 +.. date: 8243 +.. nonce: PyLZUR +.. section: Library + +The unittest module no longer considers tests marked with @expectedFailure +successful if they pass. + +.. + +.. bpo: 18574 +.. date: 8242 +.. nonce: 28Z8aX +.. section: Library + +Added missing newline in 100-Continue reply from +http.server.BaseHTTPRequestHandler. Patch by Nikolaus Rath. + +.. + +.. bpo: 20270 +.. date: 8241 +.. nonce: Z2Cks9 +.. section: Library + +urllib.urlparse now supports empty ports. + +.. + +.. bpo: 20243 +.. date: 8240 +.. nonce: nApKCK +.. section: Library + +TarFile no longer raise ReadError when opened in write mode. + +.. + +.. bpo: 20238 +.. date: 8239 +.. nonce: qojq-l +.. section: Library + +TarFile opened with external fileobj and "w:gz" mode didn't write complete +output on close. + +.. + +.. bpo: 20245 +.. date: 8238 +.. nonce: 93kf_h +.. section: Library + +The open functions in the tarfile module now correctly handle empty mode. + +.. + +.. bpo: 20242 +.. date: 8237 +.. nonce: yvmL9l +.. section: Library + +Fixed basicConfig() format strings for the alternative formatting styles. +Thanks to kespindler for the bug report and patch. + +.. + +.. bpo: 20246 +.. date: 8236 +.. nonce: CC8uTq +.. section: Library + +Fix buffer overflow in socket.recvfrom_into. + +.. + +.. bpo: 20206 +.. date: 8235 +.. nonce: CtFEMz +.. section: Library + +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. (See also: bpo-5803) + +.. + +.. bpo: 19082 +.. date: 8234 +.. nonce: idZnK7 +.. section: Library + +Working xmlrpc.server and xmlrpc.client examples. Both in modules and in +documentation. Initial patch contributed by Vajrasky Kok. + +.. + +.. bpo: 20138 +.. date: 8233 +.. nonce: A4c9qc +.. section: Library + +The wsgiref.application_uri() and wsgiref.request_uri() functions now +conform to PEP 3333 when handle non-ASCII URLs. + +.. + +.. bpo: 19097 +.. date: 8232 +.. nonce: 5aGg0o +.. section: Library + +Raise the correct Exception when cgi.FieldStorage is given an invalid +fileobj. + +.. + +.. bpo: 20152 +.. date: 8231 +.. nonce: eqfltY +.. section: Library + +Ported Python/import.c over to Argument Clinic. + +.. + +.. bpo: 13107 +.. date: 8230 +.. nonce: YgEEME +.. section: Library + +argparse and optparse no longer raises an exception when output a help on +environment with too small COLUMNS. Based on patch by Elazar Gershuni. + +.. + +.. bpo: 20207 +.. date: 8229 +.. nonce: ziIyF1 +.. section: Library + +Always disable SSLv2 except when PROTOCOL_SSLv2 is explicitly asked for. + +.. + +.. bpo: 18960 +.. date: 8228 +.. nonce: _8qsXn +.. section: Library + +The tokenize module now ignore the source encoding declaration on the second +line if the first line contains anything except a comment. + +.. + +.. bpo: 20078 +.. date: 8227 +.. nonce: 4FYvd_ +.. section: Library + +Reading malformed zipfiles no longer hangs with 100% CPU consumption. + +.. + +.. bpo: 20113 +.. date: 8226 +.. nonce: T6DWMh +.. section: Library + +os.readv() and os.writev() now raise an OSError exception on error instead +of returning -1. + +.. + +.. bpo: 19719 +.. date: 8225 +.. nonce: 1yF3Hm +.. section: Library + +Make importlib.abc.MetaPathFinder.find_module(), +PathEntryFinder.find_loader(), and Loader.load_module() use PEP 451 APIs to +help with backwards-compatibility. + +.. + +.. bpo: 20144 +.. date: 8224 +.. nonce: UDSyaK +.. section: Library + +inspect.Signature now supports parsing simple symbolic constants as +parameter default values in __text_signature__. + +.. + +.. bpo: 20072 +.. date: 8223 +.. nonce: FzVG15 +.. section: Library + +Fixed multiple errors in tkinter with wantobjects is False. + +.. + +.. bpo: 20229 +.. date: 8222 +.. nonce: WCDCjt +.. section: Library + +Avoid plistlib deprecation warning in platform.mac_ver(). + +.. + +.. bpo: 14455 +.. date: 8221 +.. nonce: CDaul1 +.. section: Library + +Fix some problems with the new binary plist support in plistlib. + +.. + +.. bpo: 17390 +.. date: 8220 +.. nonce: 9m6ZhV +.. section: IDLE + +Add Python version to Idle editor window title bar. Original patches by +Edmond Burnett and Kent Johnson. + +.. + +.. bpo: 18960 +.. date: 8219 +.. nonce: d87SuA +.. section: IDLE + +IDLE now ignores the source encoding declaration on the second line if the +first line contains anything except a comment. + +.. + +.. bpo: 20358 +.. date: 8218 +.. nonce: e2PP3S +.. section: Tests + +Tests for curses.window.overlay and curses.window.overwrite no longer +specify min{row,col} > max{row,col}. + +.. + +.. bpo: 19804 +.. date: 8217 +.. nonce: xIHIl7 +.. section: Tests + +The test_find_mac test in test_uuid is now skipped if the ifconfig +executable is not available. + +.. + +.. bpo: 19886 +.. date: 8216 +.. nonce: nqDFRC +.. section: Tests + +Use better estimated memory requirements for bigmem tests. + +.. + +.. bpo: 20390 +.. date: 8215 +.. nonce: QXEDu6 +.. section: Tools/Demos + +Argument Clinic's "file" output preset now defaults to +"{dirname}/clinic/{basename}.h". + +.. + +.. bpo: 20390 +.. date: 8214 +.. nonce: 7f_5Hn +.. section: Tools/Demos + +Argument Clinic's "class" directive syntax has been extended with two new +required arguments: "typedef" and "type_object". + +.. + +.. bpo: 20390 +.. date: 8213 +.. nonce: mDzhDq +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20390 +.. date: 8212 +.. nonce: Feo6X8 +.. section: Tools/Demos + +Argument Clinic now fails if you have required parameters after optional +parameters. + +.. + +.. bpo: 20390 +.. date: 8211 +.. nonce: DrPQn0 +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20376 +.. date: 8210 +.. nonce: Xq3E4A +.. section: Tools/Demos + +Argument Clinic now escapes backslashes in docstrings. + +.. + +.. bpo: 20381 +.. date: 8209 +.. nonce: _wqg4- +.. section: Tools/Demos + +Argument Clinic now sanity checks the default argument when c_default is +also specified, providing a nice failure message for disallowed values. + +.. + +.. bpo: 20189 +.. date: 8208 +.. nonce: zdiKDh +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20189 +.. date: 8207 +.. nonce: a1Tfvj +.. section: Tools/Demos + +Argument Clinic now suppresses the docstring for __new__ and __init__ +functions if no docstring is provided in the input. + +.. + +.. bpo: 20189 +.. date: 8206 +.. nonce: uWF8XZ +.. section: Tools/Demos + +Argument Clinic now suppresses the "self" parameter in the impl for + at staticmethod functions. + +.. + +.. bpo: 20294 +.. date: 8205 +.. nonce: XeuO9b +.. section: Tools/Demos + +Argument Clinic now supports argument parsing for __new__ and __init__ +functions. + +.. + +.. bpo: 20299 +.. date: 8204 +.. nonce: yLslQI +.. section: Tools/Demos + +Argument Clinic custom converters may now change the default value of +c_default and py_default with a class member. + +.. + +.. bpo: 20287 +.. date: 8203 +.. nonce: ACjrv7 +.. section: Tools/Demos + +Argument Clinic's output is now configurable, allowing delaying its output +or even redirecting it to a separate file. + +.. + +.. bpo: 20226 +.. date: 8202 +.. nonce: GKAbRe +.. section: Tools/Demos + +Argument Clinic now permits simple expressions (e.g. "sys.maxsize - 1") as +default values for parameters. + +.. + +.. bpo: 19936 +.. date: 8201 +.. nonce: BLtXkq +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20268 +.. date: 8200 +.. nonce: _-GWRe +.. section: Tools/Demos + +Argument Clinic now supports cloning the parameters and return converter of +existing functions. + +.. + +.. bpo: 20228 +.. date: 8199 +.. nonce: pQeW8t +.. section: Tools/Demos + +Argument Clinic now has special support for class special methods. + +.. + +.. bpo: 20214 +.. date: 8198 +.. nonce: OoBv_8 +.. section: Tools/Demos + +Fixed a number of small issues and documentation errors in Argument Clinic +(see issue for details). + +.. + +.. bpo: 20196 +.. date: 8197 +.. nonce: BhK2gF +.. section: Tools/Demos + +Fixed a bug where Argument Clinic did not generate correct parsing code for +functions with positional-only parameters where all arguments are optional. + +.. + +.. bpo: 18960 +.. date: 8196 +.. nonce: vONLqA +.. section: Tools/Demos + +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. + +.. + +.. bpo: 19723 +.. date: 8195 +.. nonce: LApk5w +.. section: Tools/Demos + +The marker comments Argument Clinic uses have been changed to improve +readability. + +.. + +.. bpo: 20157 +.. date: 8194 +.. nonce: SvrlOc +.. section: Tools/Demos + +When Argument Clinic renames a parameter because its name collides with a C +keyword, it no longer exposes that rename to PyArg_Parse. + +.. + +.. bpo: 20141 +.. date: 8193 +.. nonce: uYixKR +.. section: Tools/Demos + +Improved Argument Clinic's support for the PyArg_Parse "O!" format unit. + +.. + +.. bpo: 20144 +.. date: 8192 +.. nonce: jUfrSz +.. section: Tools/Demos + +Argument Clinic now supports simple symbolic constants as parameter default +values. + +.. + +.. bpo: 20143 +.. date: 8191 +.. nonce: XvGuQk +.. section: Tools/Demos + +The line numbers reported in Argument Clinic errors are now more accurate. + +.. + +.. bpo: 20142 +.. date: 8190 +.. nonce: FdECT9 +.. section: Tools/Demos + +Py_buffer variables generated by Argument Clinic are now initialized with a +default value. + +.. + +.. bpo: 12837 +.. date: 8189 +.. nonce: nsgduf +.. section: Build + +Silence a tautological comparison warning on OS X under Clang in +socketmodule.c. diff --git a/Misc/NEWS.d/3.4.0rc1.rst b/Misc/NEWS.d/3.4.0rc1.rst new file mode 100644 index 00000000000..6a9fccef03a --- /dev/null +++ b/Misc/NEWS.d/3.4.0rc1.rst @@ -0,0 +1,715 @@ +.. bpo: 19255 +.. date: 8324 +.. nonce: eED7PV +.. release date: 2014-02-10 +.. section: Core and Builtins + +The builtins module is restored to initial value before cleaning other +modules. The sys and builtins modules are cleaned last. + +.. + +.. bpo: 20588 +.. date: 8323 +.. nonce: Yibtu_ +.. section: Core and Builtins + +Make Python-ast.c C89 compliant. + +.. + +.. bpo: 20437 +.. date: 8322 +.. nonce: E8n1Y- +.. section: Core and Builtins + +Fixed 22 potential bugs when deleting object references. + +.. + +.. bpo: 20500 +.. date: 8321 +.. nonce: BJiIvW +.. section: Core and Builtins + +Displaying an exception at interpreter shutdown no longer risks triggering +an assertion failure in PyObject_Str. + +.. + +.. bpo: 20538 +.. date: 8320 +.. nonce: 7FRDsi +.. section: Core and Builtins + +UTF-7 incremental decoder produced inconsistent string when input was +truncated in BASE64 section. + +.. + +.. bpo: 20404 +.. date: 8319 +.. nonce: 9dU6on +.. section: Core and Builtins + +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. + +.. + +.. bpo: 17162 +.. date: 8318 +.. nonce: p4Q-Hw +.. section: Core and Builtins + +Add PyType_GetSlot. + +.. + +.. bpo: 20162 +.. date: 8317 +.. nonce: u8qICT +.. section: Core and Builtins + +Fix an alignment issue in the siphash24() hash function which caused a crash +on PowerPC 64-bit (ppc64). + +.. + +.. bpo: 20530 +.. date: 8316 +.. nonce: LXsfhK +.. section: Library + +The signatures for slot builtins have been updated to reflect the fact that +they only accept positional-only arguments. + +.. + +.. bpo: 20517 +.. date: 8315 +.. nonce: 81zuY3 +.. section: Library + +Functions in the os module that accept two filenames now register both +filenames in the exception on failure. + +.. + +.. bpo: 20563 +.. date: 8314 +.. nonce: VTqHq5 +.. section: Library + +The ipaddress module API is now considered stable. + +.. + +.. bpo: 14983 +.. date: 8313 +.. nonce: H_gs8w +.. section: Library + +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. + +.. + +.. bpo: 20540 +.. date: 8312 +.. nonce: rhK6IW +.. section: Library + +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. + +.. + +.. bpo: 16983 +.. date: 8311 +.. nonce: MoPgVQ +.. section: Library + +the new email header parsing code will now decode encoded words that are +(incorrectly) surrounded by quotes, and register a defect. + +.. + +.. bpo: 19772 +.. date: 8310 +.. nonce: pRi-Hm +.. section: Library + +email.generator no longer mutates the message object when doing a down- +transform from 8bit to 7bit CTEs. + +.. + +.. bpo: 20536 +.. date: 8309 +.. nonce: YWe5TG +.. section: Library + +the statistics module now correctly handle Decimal instances with positive +exponents + +.. + +.. bpo: 18805 +.. date: 8308 +.. nonce: fBdyY2 +.. section: Library + +the netmask/hostmask parsing in ipaddress now more reliably filters out +illegal values and correctly allows any valid prefix length. + +.. + +.. bpo: 20481 +.. date: 8307 +.. nonce: ycaV9P +.. section: Library + +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. + +.. + +.. bpo: 20478 +.. date: 8306 +.. nonce: LVoG5Q +.. section: Library + +the statistics module now treats collections.Counter inputs like any other +iterable. + +.. + +.. bpo: 17369 +.. date: 8305 +.. nonce: ZBFAd4 +.. section: Library + +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. + +.. + +.. bpo: 20013 +.. date: 8304 +.. nonce: erNy8V +.. section: Library + +Some imap servers disconnect if the current mailbox is deleted, and imaplib +did not handle that case gracefully. Now it handles the 'bye' correctly. + +.. + +.. bpo: 20531 +.. date: 8303 +.. nonce: yz_zOY +.. section: Library + +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. + +.. + +.. bpo: 20476 +.. date: 8302 +.. nonce: VhH-Lc +.. section: Library + +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. + +.. + +.. bpo: 19920 +.. date: 8301 +.. nonce: _fEm-X +.. section: Library + +TarFile.list() no longer fails when outputs a listing containing non- +encodable characters. Based on patch by Vajrasky Kok. + +.. + +.. bpo: 20515 +.. date: 8300 +.. nonce: JrEnar +.. section: Library + +Fix NULL pointer dereference introduced by issue #20368. + +.. + +.. bpo: 19186 +.. date: 8299 +.. nonce: cuiicK +.. section: Library + +Restore namespacing of expat symbols inside the pyexpat module. + +.. + +.. bpo: 20053 +.. date: 8298 +.. nonce: vy5u-i +.. section: Library + +ensurepip (and hence venv) are no longer affected by the settings in the +default pip configuration file. + +.. + +.. bpo: 20426 +.. date: 8297 +.. nonce: f0ozAP +.. section: Library + +When passing the re.DEBUG flag, re.compile() displays the debug output every +time it is called, regardless of the compilation cache. + +.. + +.. bpo: 20368 +.. date: 8296 +.. nonce: I8sm7u +.. section: Library + +The null character now correctly passed from Tcl to Python. Improved error +handling in variables-related commands. + +.. + +.. bpo: 20435 +.. date: 8295 +.. nonce: _UNhlH +.. section: Library + +Fix _pyio.StringIO.getvalue() to take into account newline translation +settings. + +.. + +.. bpo: 0 +.. date: 8294 +.. nonce: 2Jcf1f +.. section: Library + +tracemalloc: Fix slicing traces and fix slicing a traceback. + +.. + +.. bpo: 20354 +.. date: 8293 +.. nonce: kn2Ns9 +.. section: Library + +Fix an alignment issue in the tracemalloc module on 64-bit platforms. Bug +seen on 64-bit Linux when using "make profile-opt". + +.. + +.. bpo: 17159 +.. date: 8292 +.. nonce: c2P911 +.. section: Library + +inspect.signature now accepts duck types of functions, which adds support +for Cython functions. Initial patch by Stefan Behnel. + +.. + +.. bpo: 18801 +.. date: 8291 +.. nonce: Tm4jxb +.. section: Library + +Fix inspect.classify_class_attrs to correctly classify object.__new__ and +object.__init__. + +.. + +.. bpo: 0 +.. date: 8290 +.. nonce: 3eFjFu +.. section: Library + +Fixed cmath.isinf's name in its argument parsing code. + +.. + +.. bpo: 20311 +.. date: 8289 +.. nonce: f1lBLr +.. section: Library + +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. +(See also: bpo-20452) + +.. + +.. bpo: 0 +.. date: 8288 +.. nonce: qcxztP +.. section: Library + +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. + +.. + +.. bpo: 20288 +.. date: 8287 +.. nonce: 6zUZe3 +.. section: Library + +fix handling of invalid numeric charrefs in HTMLParser. + +.. + +.. bpo: 20424 +.. date: 8286 +.. nonce: deh6LJ +.. section: Library + +Python implementation of io.StringIO now supports lone surrogates. + +.. + +.. bpo: 20308 +.. date: 8285 +.. nonce: lquugc +.. section: Library + +inspect.signature now works on classes without user-defined __init__ or +__new__ methods. + +.. + +.. bpo: 20372 +.. date: 8284 +.. nonce: Mn_S78 +.. section: Library + +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__. + +.. + +.. bpo: 20356 +.. date: 8283 +.. nonce: rD04St +.. section: Library + +inspect.signature formatting uses '/' to separate positional-only parameters +from others. + +.. + +.. bpo: 20223 +.. date: 8282 +.. nonce: y3icbD +.. section: Library + +inspect.signature now supports methods defined with +functools.partialmethods. + +.. + +.. bpo: 19456 +.. date: 8281 +.. nonce: 6HhsFx +.. section: Library + +ntpath.join() now joins relative paths correctly when a drive is present. + +.. + +.. bpo: 19077 +.. date: 8280 +.. nonce: xrOYHl +.. section: Library + +tempfile.TemporaryDirectory cleanup no longer fails when called during +shutdown. Emitting resource warning in __del__ no longer fails. Original +patch by Antoine Pitrou. + +.. + +.. bpo: 20394 +.. date: 8279 +.. nonce: HzRZRc +.. section: Library + +Silence Coverity warning in audioop module. + +.. + +.. bpo: 20367 +.. date: 8278 +.. nonce: K0bFqf +.. section: Library + +Fix behavior of concurrent.futures.as_completed() for duplicate arguments. +Patch by Glenn Langford. + +.. + +.. bpo: 8260 +.. date: 8277 +.. nonce: nf7gg9 +.. section: Library + +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. + +.. + +.. bpo: 20105 +.. date: 8276 +.. nonce: foel6V +.. section: Library + +the codec exception chaining now correctly sets the traceback of the +original exception as its __traceback__ attribute. + +.. + +.. bpo: 17481 +.. date: 8275 +.. nonce: RrGlJS +.. section: Library + +inspect.getfullargspec() now uses inspect.signature() API. + +.. + +.. bpo: 15304 +.. date: 8274 +.. nonce: GfZ2Sa +.. section: Library + +concurrent.futures.wait() can block forever even if Futures have completed. +Patch by Glenn Langford. + +.. + +.. bpo: 14455 +.. date: 8273 +.. nonce: bk3GTQ +.. section: Library + +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. + +.. + +.. bpo: 20406 +.. date: 8272 +.. nonce: AgBe_5 +.. section: IDLE + +Use Python application icons for Idle window title bars. Patch mostly by +Serhiy Storchaka. + +.. + +.. bpo: 0 +.. date: 8271 +.. nonce: FTwP_j +.. section: IDLE + +Update the python.gif icon for the Idle classbrowser and pathbowser from the +old green snake to the new blue and yellow snakes. + +.. + +.. bpo: 17721 +.. date: 8270 +.. nonce: 8Jh8C1 +.. section: IDLE + +Remove non-functional configuration dialog help button until we make it +actually gives some help when clicked. Patch by Guilherme Sim?es. + +.. + +.. bpo: 20532 +.. date: 8269 +.. nonce: qsOt4d +.. section: Tests + +Tests which use _testcapi now are marked as CPython only. + +.. + +.. bpo: 19920 +.. date: 8268 +.. nonce: suOIC7 +.. section: Tests + +Added tests for TarFile.list(). Based on patch by Vajrasky Kok. + +.. + +.. bpo: 19990 +.. date: 8267 +.. nonce: Lp1MVj +.. section: Tests + +Added tests for the imghdr module. Based on patch by Claudiu Popa. + +.. + +.. bpo: 20474 +.. date: 8266 +.. nonce: Jm7xrk +.. section: Tests + +Fix test_socket "unexpected success" failures on OS X 10.7+. + +.. + +.. bpo: 20530 +.. date: 8265 +.. nonce: dqn540 +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20456 +.. date: 8264 +.. nonce: RA_zxP +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20456 +.. date: 8263 +.. nonce: tYeVw1 +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20456 +.. date: 8262 +.. nonce: vG6PXO +.. section: Tools/Demos + +Fixed Argument Clinic's test suite and "--converters" feature. + +.. + +.. bpo: 20456 +.. date: 8261 +.. nonce: E-qgFP +.. section: Tools/Demos + +Argument Clinic now allows specifying different names for a parameter in +Python and C, using "as" on the parameter line. + +.. + +.. bpo: 20326 +.. date: 8260 +.. nonce: 1nRUAK +.. section: Tools/Demos + +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. + +.. + +.. bpo: 20326 +.. date: 8259 +.. nonce: eVlPqt +.. section: Tools/Demos + +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). + +.. + +.. bpo: 20465 +.. date: 8258 +.. nonce: 6xLtE3 +.. section: Build + +Update SQLite shipped with OS X installer to 3.8.3. + +.. + +.. bpo: 20517 +.. date: 8257 +.. nonce: PHWtoF +.. section: C API + +Added new functions allowing OSError exceptions to reference two filenames +instead of one: PyErr_SetFromErrnoWithFilenameObjects() and +PyErr_SetExcFromWindowsErrWithFilenameObjects(). + +.. + +.. bpo: 20488 +.. date: 8256 +.. nonce: csO04J +.. section: Documentation + +Change wording to say importlib is *the* implementation of import instead of +just *an* implementation. + +.. + +.. bpo: 6386 +.. date: 8255 +.. nonce: TO2sFS +.. section: Documentation + +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. diff --git a/Misc/NEWS.d/3.4.0rc2.rst b/Misc/NEWS.d/3.4.0rc2.rst new file mode 100644 index 00000000000..418fa4f26fd --- /dev/null +++ b/Misc/NEWS.d/3.4.0rc2.rst @@ -0,0 +1,177 @@ +.. bpo: 20625 +.. date: 8341 +.. nonce: IA5Cu9 +.. release date: 2014-02-23 +.. section: Core and Builtins + +Parameter names in __annotations__ were not mangled properly. Discovered by +Jonas Wielicki, patch by Yury Selivanov. + +.. + +.. bpo: 20261 +.. date: 8340 +.. nonce: xyA9tG +.. section: Core and Builtins + +In pickle, lookup __getnewargs__ and __getnewargs_ex__ on the type of the +object. + +.. + +.. bpo: 20619 +.. date: 8339 +.. nonce: GtdhSO +.. section: Core and Builtins + +Give the AST nodes of keyword-only arguments a column and line number. + +.. + +.. bpo: 20526 +.. date: 8338 +.. nonce: wZEy32 +.. section: Core and Builtins + +Revert changes of issue #19466 which introduces a regression: don't clear +anymore the state of Python threads early during the Python shutdown. + +.. + +.. bpo: 20710 +.. date: 8337 +.. nonce: byega8 +.. section: Library + +The pydoc summary line no longer displays the "self" parameter for bound +methods. + +.. + +.. bpo: 20566 +.. date: 8336 +.. nonce: R8yrPZ +.. section: Library + +Change asyncio.as_completed() to use a Queue, to avoid O(N**2) behavior. + +.. + +.. bpo: 20704 +.. date: 8335 +.. nonce: QQ4uy4 +.. section: Library + +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. + +.. + +.. bpo: 0 +.. date: 8334 +.. nonce: Ocnov- +.. section: Library + +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. + +.. + +.. bpo: 20684 +.. date: 8333 +.. nonce: EArKf9 +.. section: Library + +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. + +.. + +.. bpo: 20681 +.. date: 8332 +.. nonce: O8EUu8 +.. section: Library + +Add new error handling API in asyncio. New APIs: +loop.set_exception_handler(), loop.default_exception_handler(), and +loop.call_exception_handler(). + +.. + +.. bpo: 20673 +.. date: 8331 +.. nonce: bLJpSo +.. section: Library + +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(). + +.. + +.. bpo: 20616 +.. date: 8330 +.. nonce: 9fIygg +.. section: Library + +Add a format() method to tracemalloc.Traceback. + +.. + +.. bpo: 19744 +.. date: 8329 +.. nonce: fL4Brl +.. section: Library + +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. + +.. + +.. bpo: 20594 +.. date: 8328 +.. nonce: BVHxPd +.. section: Library + +Avoid name clash with the libc function posix_close. + +.. + +.. bpo: 20641 +.. date: 8327 +.. nonce: kAo-M- +.. section: Build + +Run MSI custom actions (pip installation, pyc compilation) with the +NoImpersonate flag, to support elevated execution (UAC). + +.. + +.. bpo: 20221 +.. date: 8326 +.. nonce: _yAetK +.. section: Build + +Removed conflicting (or circular) hypot definition when compiled with VS +2010 or above. Initial patch by Tabrez Mohammed. + +.. + +.. bpo: 20609 +.. date: 8325 +.. nonce: IMbrDQ +.. section: Build + +Restored the ability to build 64-bit Windows binaries on 32-bit Windows, +which was broken by the change in issue #19788. diff --git a/Misc/NEWS.d/3.4.0rc3.rst b/Misc/NEWS.d/3.4.0rc3.rst new file mode 100644 index 00000000000..d12350eedc2 --- /dev/null +++ b/Misc/NEWS.d/3.4.0rc3.rst @@ -0,0 +1,66 @@ +.. bpo: 20786 +.. date: 8348 +.. nonce: M_2OYE +.. release date: 2014-03-09 +.. section: Core and Builtins + +Fix signatures for dict.__delitem__ and property.__delete__ builtins. + +.. + +.. bpo: 20839 +.. date: 8347 +.. nonce: SNn1MY +.. section: Library + +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). + +.. + +.. bpo: 14512 +.. date: 8346 +.. nonce: y7vmx3 +.. section: Build + +Launch pydoc -b instead of pydocgui.pyw on Windows. + +.. + +.. bpo: 20748 +.. date: 8345 +.. nonce: HbDp_u +.. section: Build + +Uninstalling pip does not leave behind the pyc of the uninstaller anymore. + +.. + +.. bpo: 20568 +.. date: 8344 +.. nonce: ZvMU8d +.. section: Build + +The Windows installer now installs the unversioned ``pip`` command in +addition to the versioned ``pip3`` and ``pip3.4`` commands. + +.. + +.. bpo: 20757 +.. date: 8343 +.. nonce: BGFT6U +.. section: Build + +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. + +.. + +.. bpo: 20465 +.. date: 8342 +.. nonce: iemVBC +.. section: Build + +Update OS X and Windows installer builds to use SQLite 3.8.3.1. diff --git a/Misc/NEWS.d/3.5.0.rst b/Misc/NEWS.d/3.5.0.rst new file mode 100644 index 00000000000..949997422f2 --- /dev/null +++ b/Misc/NEWS.d/3.5.0.rst @@ -0,0 +1,8 @@ +.. bpo: 25071 +.. date: 9305 +.. nonce: EwjXl1 +.. release date: 2015-09-13 +.. section: Build + +Windows installer should not require TargetDir parameter when installing +quietly. diff --git a/Misc/NEWS.d/3.5.0a1.rst b/Misc/NEWS.d/3.5.0a1.rst new file mode 100644 index 00000000000..f5e1e5ae05d --- /dev/null +++ b/Misc/NEWS.d/3.5.0a1.rst @@ -0,0 +1,5869 @@ +.. bpo: 23285 +.. date: 8948 +.. nonce: bJJA8B +.. release date: 2015-02-08 +.. section: Core and Builtins + +PEP 475 - EINTR handling. + +.. + +.. bpo: 22735 +.. date: 8947 +.. nonce: mFEX9n +.. section: Core and Builtins + +Fix many edge cases (including crashes) involving custom mro() +implementations. + +.. + +.. bpo: 22896 +.. date: 8946 +.. nonce: xSDAHK +.. section: Core and Builtins + +Avoid using PyObject_AsCharBuffer(), PyObject_AsReadBuffer() and +PyObject_AsWriteBuffer(). + +.. + +.. bpo: 21295 +.. date: 8945 +.. nonce: LYq9nF +.. section: Core and Builtins + +Revert some changes (issue #16795) to AST line numbers and column offsets +that constituted a regression. + +.. + +.. bpo: 22986 +.. date: 8944 +.. nonce: yay2Lv +.. section: Core and Builtins + +Allow changing an object's __class__ between a dynamic type and static type +in some cases. + +.. + +.. bpo: 15859 +.. date: 8943 +.. nonce: Fs5mE2 +.. section: Core and Builtins + +PyUnicode_EncodeFSDefault(), PyUnicode_EncodeMBCS() and +PyUnicode_EncodeCodePage() now raise an exception if the object is not a +Unicode object. For PyUnicode_EncodeFSDefault(), it was already the case on +platforms other than Windows. Patch written by Campbell Barton. + +.. + +.. bpo: 21408 +.. date: 8942 +.. nonce: Lz6P3P +.. section: Core and Builtins + +The default __ne__() now returns NotImplemented if __eq__() returned +NotImplemented. Original patch by Martin Panter. + +.. + +.. bpo: 23321 +.. date: 8941 +.. nonce: HQelge +.. section: Core and Builtins + +Fixed a crash in str.decode() when error handler returned replacment string +longer than mailformed input data. + +.. + +.. bpo: 22286 +.. date: 8940 +.. nonce: l6Qyy1 +.. section: Core and Builtins + +The "backslashreplace" error handlers now works with decoding and +translating. + +.. + +.. bpo: 23253 +.. date: 8939 +.. nonce: p4B1H- +.. section: Core and Builtins + +Delay-load ShellExecute[AW] in os.startfile for reduced startup overhead on +Windows. + +.. + +.. bpo: 22038 +.. date: 8938 +.. nonce: BMZUHx +.. section: Core and Builtins + +pyatomic.h now uses stdatomic.h or GCC built-in functions for atomic memory +access if available. Patch written by Vitor de Lima and Gustavo Temple. + +.. + +.. bpo: 20284 +.. date: 8937 +.. nonce: CH8wpD +.. section: Core and Builtins + +%-interpolation (aka printf) formatting added for bytes and bytearray. + +.. + +.. bpo: 23048 +.. date: 8936 +.. nonce: X5BUd3 +.. section: Core and Builtins + +Fix jumping out of an infinite while loop in the pdb. + +.. + +.. bpo: 20335 +.. date: 8935 +.. nonce: YcAPOs +.. section: Core and Builtins + +bytes constructor now raises TypeError when encoding or errors is specified +with non-string argument. Based on patch by Renaud Blanch. + +.. + +.. bpo: 22834 +.. date: 8934 +.. nonce: N1kAXN +.. section: Core and Builtins + +If the current working directory ends up being set to a non-existent +directory then import will no longer raise FileNotFoundError. + +.. + +.. bpo: 22869 +.. date: 8933 +.. nonce: rAWg-V +.. section: Core and Builtins + +Move the interpreter startup & shutdown code to a new dedicated +pylifecycle.c module + +.. + +.. bpo: 22847 +.. date: 8932 +.. nonce: 6baj9f +.. section: Core and Builtins + +Improve method cache efficiency. + +.. + +.. bpo: 22335 +.. date: 8931 +.. nonce: DWsXiy +.. section: Core and Builtins + +Fix crash when trying to enlarge a bytearray to 0x7fffffff bytes on a 32-bit +platform. + +.. + +.. bpo: 22653 +.. date: 8930 +.. nonce: pCNlpv +.. section: Core and Builtins + +Fix an assertion failure in debug mode when doing a reentrant dict insertion +in debug mode. + +.. + +.. bpo: 22643 +.. date: 8929 +.. nonce: xv8xev +.. section: Core and Builtins + +Fix integer overflow in Unicode case operations (upper, lower, title, +swapcase, casefold). + +.. + +.. bpo: 17636 +.. date: 8928 +.. nonce: wiqnhw +.. section: Core and Builtins + +Circular imports involving relative imports are now supported. + +.. + +.. bpo: 22604 +.. date: 8927 +.. nonce: yii-It +.. section: Core and Builtins + +Fix assertion error in debug mode when dividing a complex number by +(nan+0j). + +.. + +.. bpo: 21052 +.. date: 8926 +.. nonce: -sf3tp +.. section: Core and Builtins + +Do not raise ImportWarning when sys.path_hooks or sys.meta_path are set to +None. + +.. + +.. bpo: 16518 +.. date: 8925 +.. nonce: UADwcN +.. section: Core and Builtins + +Use 'bytes-like object required' in error messages that previously used the +far more cryptic "'x' does not support the buffer protocol. + +.. + +.. bpo: 22470 +.. date: 8924 +.. nonce: igrgN2 +.. section: Core and Builtins + +Fixed integer overflow issues in "backslashreplace", "xmlcharrefreplace", +and "surrogatepass" error handlers. + +.. + +.. bpo: 22540 +.. date: 8923 +.. nonce: FM72m- +.. section: Core and Builtins + +speed up `PyObject_IsInstance` and `PyObject_IsSubclass` in the common case +that the second argument has metaclass `type`. + +.. + +.. bpo: 18711 +.. date: 8922 +.. nonce: ds5wQa +.. section: Core and Builtins + +Add a new `PyErr_FormatV` function, similar to `PyErr_Format` but accepting +a `va_list` argument. + +.. + +.. bpo: 22520 +.. date: 8921 +.. nonce: ZPJXSq +.. section: Core and Builtins + +Fix overflow checking when generating the repr of a unicode object. + +.. + +.. bpo: 22519 +.. date: 8920 +.. nonce: xvJVg0 +.. section: Core and Builtins + +Fix overflow checking in PyBytes_Repr. + +.. + +.. bpo: 22518 +.. date: 8919 +.. nonce: C9T6ed +.. section: Core and Builtins + +Fix integer overflow issues in latin-1 encoding. + +.. + +.. bpo: 16324 +.. date: 8918 +.. nonce: YfrBNz +.. section: Core and Builtins + +_charset parameter of MIMEText now also accepts email.charset.Charset +instances. Initial patch by Claude Paroz. + +.. + +.. bpo: 1764286 +.. date: 8917 +.. nonce: L4seL2 +.. section: Core and Builtins + +Fix inspect.getsource() to support decorated functions. Patch by Claudiu +Popa. + +.. + +.. bpo: 18554 +.. date: 8916 +.. nonce: hxnaui +.. section: Core and Builtins + +os.__all__ includes posix functions. + +.. + +.. bpo: 21391 +.. date: 8915 +.. nonce: 3jntPd +.. section: Core and Builtins + +Use os.path.abspath in the shutil module. + +.. + +.. bpo: 11471 +.. date: 8914 +.. nonce: Uu752F +.. section: Core and Builtins + +avoid generating a JUMP_FORWARD instruction at the end of an if-block if +there is no else-clause. Original patch by Eugene Toder. + +.. + +.. bpo: 22215 +.. date: 8913 +.. nonce: IBFi6H +.. section: Core and Builtins + +Now ValueError is raised instead of TypeError when str or bytes argument +contains not permitted null character or byte. + +.. + +.. bpo: 22258 +.. date: 8912 +.. nonce: 4FszMt +.. section: Core and Builtins + +Fix the internal function set_inheritable() on Illumos. This platform +exposes the function ``ioctl(FIOCLEX)``, but calling it fails with errno is +ENOTTY: "Inappropriate ioctl for device". set_inheritable() now falls back +to the slower ``fcntl()`` (``F_GETFD`` and then ``F_SETFD``). + +.. + +.. bpo: 21389 +.. date: 8911 +.. nonce: dnWZBn +.. section: Core and Builtins + +Displaying the __qualname__ of the underlying function in the repr of a +bound method. + +.. + +.. bpo: 22206 +.. date: 8910 +.. nonce: 0i_ihB +.. section: Core and Builtins + +Using pthread, PyThread_create_key() now sets errno to ENOMEM and returns -1 +(error) on integer overflow. + +.. + +.. bpo: 20184 +.. date: 8909 +.. nonce: bb3uHY +.. section: Core and Builtins + +Argument Clinic based signature introspection added for 30 of the builtin +functions. + +.. + +.. bpo: 22116 +.. date: 8908 +.. nonce: auVmIt +.. section: Core and Builtins + +C functions and methods (of the 'builtin_function_or_method' type) can now +be weakref'ed. Patch by Wei Wu. + +.. + +.. bpo: 22077 +.. date: 8907 +.. nonce: KZUDR- +.. section: Core and Builtins + +Improve index error messages for bytearrays, bytes, lists, and tuples by +adding 'or slices'. Added ', not ' for bytearrays. Original patch +by Claudiu Popa. + +.. + +.. bpo: 20179 +.. date: 8906 +.. nonce: Nvhffc +.. section: Core and Builtins + +Apply Argument Clinic to bytes and bytearray. Patch by Tal Einat. + +.. + +.. bpo: 22082 +.. date: 8905 +.. nonce: 6X8Qmg +.. section: Core and Builtins + +Clear interned strings in slotdefs. + +.. + +.. bpo: 0 +.. date: 8904 +.. nonce: tuMnCc +.. section: Core and Builtins + +Upgrade Unicode database to Unicode 7.0.0. + +.. + +.. bpo: 21897 +.. date: 8903 +.. nonce: kiOGHe +.. section: Core and Builtins + +Fix a crash with the f_locals attribute with closure variables when +frame.clear() has been called. + +.. + +.. bpo: 21205 +.. date: 8902 +.. nonce: wZsx1K +.. section: Core and Builtins + +Add a new ``__qualname__`` attribute to generator, the qualified name, and +use it in the representation of a generator (``repr(gen)``). The default +name of the generator (``__name__`` attribute) is now get from the function +instead of the code. Use ``gen.gi_code.co_name`` to get the name of the +code. + +.. + +.. bpo: 21669 +.. date: 8901 +.. nonce: DFDrBA +.. section: Core and Builtins + +With the aid of heuristics in SyntaxError.__init__, the parser now attempts +to generate more meaningful (or at least more search engine friendly) error +messages when "exec" and "print" are used as statements. + +.. + +.. bpo: 21642 +.. date: 8900 +.. nonce: -lWoKz +.. section: Core and Builtins + +In the conditional if-else expression, allow an integer written with no +space between itself and the ``else`` keyword (e.g. ``True if 42else +False``) to be valid syntax. + +.. + +.. bpo: 21523 +.. date: 8899 +.. nonce: f_PPYO +.. section: Core and Builtins + +Fix over-pessimistic computation of the stack effect of some opcodes in the +compiler. This also fixes a quadratic compilation time issue noticeable +when compiling code with a large number of "and" and "or" operators. + +.. + +.. bpo: 21418 +.. date: 8898 +.. nonce: z9jp1_ +.. section: Core and Builtins + +Fix a crash in the builtin function super() when called without argument and +without current frame (ex: embedded Python). + +.. + +.. bpo: 21425 +.. date: 8897 +.. nonce: i3Teb8 +.. section: Core and Builtins + +Fix flushing of standard streams in the interactive interpreter. + +.. + +.. bpo: 21435 +.. date: 8896 +.. nonce: ZojVOT +.. section: Core and Builtins + +In rare cases, when running finalizers on objects in cyclic trash a bad +pointer dereference could occur due to a subtle flaw in internal iteration +logic. + +.. + +.. bpo: 21377 +.. date: 8895 +.. nonce: OawYfl +.. section: Core and Builtins + +PyBytes_Concat() now tries to concatenate in-place when the first argument +has a reference count of 1. Patch by Nikolaus Rath. + +.. + +.. bpo: 20355 +.. date: 8894 +.. nonce: OrCNkZ +.. section: Core and Builtins + +-W command line options now have higher priority than the PYTHONWARNINGS +environment variable. Patch by Arfrever. + +.. + +.. bpo: 21274 +.. date: 8893 +.. nonce: fVGfwq +.. section: Core and Builtins + +Define PATH_MAX for GNU/Hurd in Python/pythonrun.c. + +.. + +.. bpo: 20904 +.. date: 8892 +.. nonce: fAGdj2 +.. section: Core and Builtins + +Support setting FPU precision on m68k. + +.. + +.. bpo: 21209 +.. date: 8891 +.. nonce: nMljFr +.. section: Core and Builtins + +Fix sending tuples to custom generator objects with the yield from syntax. + +.. + +.. bpo: 21193 +.. date: 8890 +.. nonce: Dg98Oo +.. section: Core and Builtins + +pow(a, b, c) now raises ValueError rather than TypeError when b is negative. +Patch by Josh Rosenberg. + +.. + +.. bpo: 21176 +.. date: 8889 +.. nonce: mitDhW +.. section: Core and Builtins + +PEP 465: Add the '@' operator for matrix multiplication. + +.. + +.. bpo: 21134 +.. date: 8888 +.. nonce: ZL4SKo +.. section: Core and Builtins + +Fix segfault when str is called on an uninitialized UnicodeEncodeError, +UnicodeDecodeError, or UnicodeTranslateError object. + +.. + +.. bpo: 19537 +.. date: 8887 +.. nonce: AkuC_J +.. section: Core and Builtins + +Fix PyUnicode_DATA() alignment under m68k. Patch by Andreas Schwab. + +.. + +.. bpo: 20929 +.. date: 8886 +.. nonce: 9NlUR7 +.. section: Core and Builtins + +Add a type cast to avoid shifting a negative number. + +.. + +.. bpo: 20731 +.. date: 8885 +.. nonce: _03SZg +.. section: Core and Builtins + +Properly position in source code files even if they are opened in text mode. +Patch by Serhiy Storchaka. + +.. + +.. bpo: 20637 +.. date: 8884 +.. nonce: ppYU0o +.. section: Core and Builtins + +Key-sharing now also works for instance dictionaries of subclasses. Patch +by Peter Ingebretson. + +.. + +.. bpo: 8297 +.. date: 8883 +.. nonce: _XdGON +.. section: Core and Builtins + +Attributes missing from modules now include the module name in the error +text. Original patch by ysj.ray. + +.. + +.. bpo: 19995 +.. date: 8882 +.. nonce: mnHEzX +.. section: Core and Builtins + +%c, %o, %x, and %X now raise TypeError on non-integer input. + +.. + +.. bpo: 19655 +.. date: 8881 +.. nonce: JgVdes +.. section: Core and Builtins + +The ASDL parser - used by the build process to generate code for managing +the Python AST in C - was rewritten. The new parser is self contained and +does not require to carry long the spark.py parser-generator library; +spark.py was removed from the source base. + +.. + +.. bpo: 12546 +.. date: 8880 +.. nonce: 09naZ9 +.. section: Core and Builtins + +Allow ``\x00`` to be used as a fill character when using str, int, float, +and complex __format__ methods. + +.. + +.. bpo: 20480 +.. date: 8879 +.. nonce: TIYPLo +.. section: Core and Builtins + +Add ipaddress.reverse_pointer. Patch by Leon Weber. + +.. + +.. bpo: 13598 +.. date: 8878 +.. nonce: GJelrw +.. section: Core and Builtins + +Modify string.Formatter to support auto-numbering of replacement fields. It +now matches the behavior of str.format() in this regard. Patches by Phil +Elson and Ramchandra Apte. + +.. + +.. bpo: 8931 +.. date: 8877 +.. nonce: M05x4f +.. section: Core and Builtins + +Make alternate formatting ('#') for type 'c' raise an exception. In versions +prior to 3.5, '#' with 'c' had no effect. Now specifying it is an error. +Patch by Torsten Landschoff. + +.. + +.. bpo: 23165 +.. date: 8876 +.. nonce: lk8uCE +.. section: Core and Builtins + +Perform overflow checks before allocating memory in the _Py_char2wchar +function. + +.. + +.. bpo: 23399 +.. date: 8875 +.. nonce: hXMYgA +.. section: Library + +pyvenv creates relative symlinks where possible. + +.. + +.. bpo: 20289 +.. date: 8874 +.. nonce: nio1N- +.. section: Library + +cgi.FieldStorage() now supports the context management protocol. + +.. + +.. bpo: 13128 +.. date: 8873 +.. nonce: vqEcsy +.. section: Library + +Print response headers for CONNECT requests when debuglevel > 0. Patch by +Demian Brecht. + +.. + +.. bpo: 15381 +.. date: 8872 +.. nonce: Xv-wu8 +.. section: Library + +Optimized io.BytesIO to make less allocations and copyings. + +.. + +.. bpo: 22818 +.. date: 8871 +.. nonce: NYdAc9 +.. section: Library + +Splitting on a pattern that could match an empty string now raises a +warning. Patterns that can only match empty strings are now rejected. + +.. + +.. bpo: 23099 +.. date: 8870 +.. nonce: ZASrUo +.. section: Library + +Closing io.BytesIO with exported buffer is rejected now to prevent +corrupting exported buffer. + +.. + +.. bpo: 23326 +.. date: 8869 +.. nonce: 8VzlZD +.. section: Library + +Removed __ne__ implementations. Since fixing default __ne__ implementation +in issue #21408 they are redundant. + +.. + +.. bpo: 23363 +.. date: 8868 +.. nonce: -koaol +.. section: Library + +Fix possible overflow in itertools.permutations. + +.. + +.. bpo: 23364 +.. date: 8867 +.. nonce: 3yBV-6 +.. section: Library + +Fix possible overflow in itertools.product. + +.. + +.. bpo: 23366 +.. date: 8866 +.. nonce: tyAfm8 +.. section: Library + +Fixed possible integer overflow in itertools.combinations. + +.. + +.. bpo: 23369 +.. date: 8865 +.. nonce: nqChyE +.. section: Library + +Fixed possible integer overflow in _json.encode_basestring_ascii. + +.. + +.. bpo: 23353 +.. date: 8864 +.. nonce: Iytkpc +.. section: Library + +Fix the exception handling of generators in PyEval_EvalFrameEx(). At entry, +save or swap the exception state even if PyEval_EvalFrameEx() is called with +throwflag=0. At exit, the exception state is now always restored or swapped, +not only if why is WHY_YIELD or WHY_RETURN. Patch co-written with Antoine +Pitrou. + +.. + +.. bpo: 14099 +.. date: 8863 +.. nonce: t9-HVE +.. section: Library + +Restored support of writing ZIP files to tellable but non-seekable streams. + +.. + +.. bpo: 14099 +.. date: 8862 +.. nonce: Myxxww +.. section: Library + +Writing to ZipFile and reading multiple ZipExtFiles is threadsafe now. + +.. + +.. bpo: 19361 +.. date: 8861 +.. nonce: 2mvrV3 +.. section: Library + +JSON decoder now raises JSONDecodeError instead of ValueError. + +.. + +.. bpo: 18518 +.. date: 8860 +.. nonce: JXgicC +.. section: Library + +timeit now rejects statements which can't be compiled outside a function or +a loop (e.g. "return" or "break"). + +.. + +.. bpo: 23094 +.. date: 8859 +.. nonce: -8AXSi +.. section: Library + +Fixed readline with frames in Python implementation of pickle. + +.. + +.. bpo: 23268 +.. date: 8858 +.. nonce: ATtRa5 +.. section: Library + +Fixed bugs in the comparison of ipaddress classes. + +.. + +.. bpo: 21408 +.. date: 8857 +.. nonce: 0rI6tx +.. section: Library + +Removed incorrect implementations of __ne__() which didn't returned +NotImplemented if __eq__() returned NotImplemented. The default __ne__() +now works correctly. + +.. + +.. bpo: 19996 +.. date: 8856 +.. nonce: 2-SiMf +.. section: Library + +:class:`email.feedparser.FeedParser` now handles (malformed) headers with no +key rather than assuming the body has started. + +.. + +.. bpo: 20188 +.. date: 8855 +.. nonce: xocY-2 +.. section: Library + +Support Application-Layer Protocol Negotiation (ALPN) in the ssl module. + +.. + +.. bpo: 23133 +.. date: 8854 +.. nonce: 8p2Wnl +.. section: Library + +Pickling of ipaddress objects now produces more compact and portable +representation. + +.. + +.. bpo: 23248 +.. date: 8853 +.. nonce: FjcyCP +.. section: Library + +Update ssl error codes from latest OpenSSL git master. + +.. + +.. bpo: 23266 +.. date: 8852 +.. nonce: Mo7alR +.. section: Library + +Much faster implementation of ipaddress.collapse_addresses() when there are +many non-consecutive addresses. + +.. + +.. bpo: 23098 +.. date: 8851 +.. nonce: 7VwF3K +.. section: Library + +64-bit dev_t is now supported in the os module. + +.. + +.. bpo: 21817 +.. date: 8850 +.. nonce: xYUW-9 +.. section: Library + +When an exception is raised in a task submitted to a ProcessPoolExecutor, +the remote traceback is now displayed in the parent process. Patch by +Claudiu Popa. + +.. + +.. bpo: 15955 +.. date: 8849 +.. nonce: uvpBL4 +.. section: Library + +Add an option to limit output size when decompressing LZMA data. Patch by +Nikolaus Rath and Martin Panter. + +.. + +.. bpo: 23250 +.. date: 8848 +.. nonce: qNGAUf +.. section: Library + +In the http.cookies module, capitalize "HttpOnly" and "Secure" as they are +written in the standard. + +.. + +.. bpo: 23063 +.. date: 8847 +.. nonce: 9-UJRs +.. section: Library + +In the disutils' check command, fix parsing of reST with code or code-block +directives. + +.. + +.. bpo: 23209 +.. date: 8846 +.. nonce: I0bCCH +.. section: Library + +selectors.BaseSelector.get_key() now raises a RuntimeError if the selector +is closed. And selectors.BaseSelector.close() now clears its internal +reference to the selector mapping to break a reference cycle. Initial patch +written by Martin Richard. (See also: bpo-23225) + +.. + +.. bpo: 17911 +.. date: 8845 +.. nonce: yg65Iu +.. section: Library + +Provide a way to seed the linecache for a PEP-302 module without actually +loading the code. + +.. + +.. bpo: 17911 +.. date: 8844 +.. nonce: qeTePa +.. section: Library + +Provide a new object API for traceback, including the ability to not lookup +lines at all until the traceback is actually rendered, without any trace of +the original objects being kept alive. + +.. + +.. bpo: 19777 +.. date: 8843 +.. nonce: H_NDIA +.. section: Library + +Provide a home() classmethod on Path objects. Contributed by Victor Salgado +and Mayank Tripathi. + +.. + +.. bpo: 23206 +.. date: 8842 +.. nonce: xSiYwq +.. section: Library + +Make ``json.dumps(..., ensure_ascii=False)`` as fast as the default case of +``ensure_ascii=True``. Patch by Naoki Inada. + +.. + +.. bpo: 23185 +.. date: 8841 +.. nonce: KHyoSO +.. section: Library + +Add math.inf and math.nan constants. + +.. + +.. bpo: 23186 +.. date: 8840 +.. nonce: KzWLP2 +.. section: Library + +Add ssl.SSLObject.shared_ciphers() and ssl.SSLSocket.shared_ciphers() to +fetch the client's list ciphers sent at handshake. + +.. + +.. bpo: 23143 +.. date: 8839 +.. nonce: AWxJXV +.. section: Library + +Remove compatibility with OpenSSLs older than 0.9.8. + +.. + +.. bpo: 23132 +.. date: 8838 +.. nonce: pbQcut +.. section: Library + +Improve performance and introspection support of comparison methods created +by functool.total_ordering. + +.. + +.. bpo: 19776 +.. date: 8837 +.. nonce: BxNgxd +.. section: Library + +Add an expanduser() method on Path objects. + +.. + +.. bpo: 23112 +.. date: 8836 +.. nonce: dZGf82 +.. section: Library + +Fix SimpleHTTPServer to correctly carry the query string and fragment when +it redirects to add a trailing slash. + +.. + +.. bpo: 21793 +.. date: 8835 +.. nonce: T1kQBL +.. section: Library + +Added http.HTTPStatus enums (i.e. HTTPStatus.OK, HTTPStatus.NOT_FOUND). +Patch by Demian Brecht. + +.. + +.. bpo: 23093 +.. date: 8834 +.. nonce: cP7OqD +.. section: Library + +In the io, module allow more operations to work on detached streams. + +.. + +.. bpo: 23111 +.. date: 8833 +.. nonce: A34IA4 +.. section: Library + +In the ftplib, make ssl.PROTOCOL_SSLv23 the default protocol version. + +.. + +.. bpo: 22585 +.. date: 8832 +.. nonce: F4BkNo +.. section: Library + +On OpenBSD 5.6 and newer, os.urandom() now calls getentropy(), instead of +reading /dev/urandom, to get pseudo-random bytes. + +.. + +.. bpo: 19104 +.. date: 8831 +.. nonce: _eIThy +.. section: Library + +pprint now produces evaluable output for wrapped strings. + +.. + +.. bpo: 23071 +.. date: 8830 +.. nonce: 3BSqF7 +.. section: Library + +Added missing names to codecs.__all__. Patch by Martin Panter. + +.. + +.. bpo: 22783 +.. date: 8829 +.. nonce: OfYxBd +.. section: Library + +Pickling now uses the NEWOBJ opcode instead of the NEWOBJ_EX opcode if +possible. + +.. + +.. bpo: 15513 +.. date: 8828 +.. nonce: 7yVnRE +.. section: Library + +Added a __sizeof__ implementation for pickle classes. + +.. + +.. bpo: 19858 +.. date: 8827 +.. nonce: cqOlIt +.. section: Library + +pickletools.optimize() now aware of the MEMOIZE opcode, can produce more +compact result and no longer produces invalid output if input data contains +MEMOIZE opcodes together with PUT or BINPUT opcodes. + +.. + +.. bpo: 22095 +.. date: 8826 +.. nonce: iISzxM +.. section: Library + +Fixed HTTPConnection.set_tunnel with default port. The port value in the +host header was set to "None". Patch by Demian Brecht. + +.. + +.. bpo: 23016 +.. date: 8825 +.. nonce: LyrPd_ +.. section: Library + +A warning no longer produces an AttributeError when the program is run with +pythonw.exe. + +.. + +.. bpo: 21775 +.. date: 8824 +.. nonce: ELR_Al +.. section: Library + +shutil.copytree(): fix crash when copying to VFAT. An exception handler +assumed that OSError objects always have a 'winerror' attribute. That is not +the case, so the exception handler itself raised AttributeError when run on +Linux (and, presumably, any other non-Windows OS). Patch by Greg Ward. + +.. + +.. bpo: 1218234 +.. date: 8823 +.. nonce: 4GcoQK +.. section: Library + +Fix inspect.getsource() to load updated source of reloaded module. Initial +patch by Berker Peksag. + +.. + +.. bpo: 21740 +.. date: 8822 +.. nonce: TtAApO +.. section: Library + +Support wrapped callables in doctest. Patch by Claudiu Popa. + +.. + +.. bpo: 23009 +.. date: 8821 +.. nonce: -sW7gk +.. section: Library + +Make sure selectors.EpollSelecrtor.select() works when no FD is registered. + +.. + +.. bpo: 22959 +.. date: 8820 +.. nonce: Vxt3EP +.. section: Library + +In the constructor of http.client.HTTPSConnection, prefer the context's +check_hostname attribute over the *check_hostname* parameter. + +.. + +.. bpo: 22696 +.. date: 8819 +.. nonce: pvdcxs +.. section: Library + +Add function :func:`sys.is_finalizing` to know about interpreter shutdown. + +.. + +.. bpo: 16043 +.. date: 8818 +.. nonce: TGIC7t +.. section: Library + +Add a default limit for the amount of data xmlrpclib.gzip_decode will +return. This resolves CVE-2013-1753. + +.. + +.. bpo: 14099 +.. date: 8817 +.. nonce: GJ5meQ +.. section: Library + +ZipFile.open() no longer reopen the underlying file. Objects returned by +ZipFile.open() can now operate independently of the ZipFile even if the +ZipFile was created by passing in a file-like object as the first argument +to the constructor. + +.. + +.. bpo: 22966 +.. date: 8816 +.. nonce: zIxDrT +.. section: Library + +Fix __pycache__ pyc file name clobber when pyc_compile is asked to compile a +source file containing multiple dots in the source file name. + +.. + +.. bpo: 21971 +.. date: 8815 +.. nonce: XlTc22 +.. section: Library + +Update turtledemo doc and add module to the index. + +.. + +.. bpo: 21032 +.. date: 8814 +.. nonce: wxT_41 +.. section: Library + +Fixed socket leak if HTTPConnection.getresponse() fails. Original patch by +Martin Panter. + +.. + +.. bpo: 22407 +.. date: 8813 +.. nonce: CWi1wX +.. section: Library + +Deprecated the use of re.LOCALE flag with str patterns or re.ASCII. It was +newer worked. + +.. + +.. bpo: 22902 +.. date: 8812 +.. nonce: ZqXriA +.. section: Library + +The "ip" command is now used on Linux to determine MAC address in +uuid.getnode(). Pach by Bruno Cauet. + +.. + +.. bpo: 22960 +.. date: 8811 +.. nonce: 2VDILT +.. section: Library + +Add a context argument to xmlrpclib.ServerProxy constructor. + +.. + +.. bpo: 22389 +.. date: 8810 +.. nonce: 82DuwD +.. section: Library + +Add contextlib.redirect_stderr(). + +.. + +.. bpo: 21356 +.. date: 8809 +.. nonce: 8NY75J +.. section: Library + +Make ssl.RAND_egd() optional to support LibreSSL. The availability of the +function is checked during the compilation. Patch written by Bernard Spil. + +.. + +.. bpo: 22915 +.. date: 8808 +.. nonce: 709UAo +.. section: Library + +SAX parser now supports files opened with file descriptor or bytes path. + +.. + +.. bpo: 22609 +.. date: 8807 +.. nonce: mmLoeb +.. section: Library + +Constructors and update methods of mapping classes in the collections module +now accept the self keyword argument. + +.. + +.. bpo: 22940 +.. date: 8806 +.. nonce: SP99Nf +.. section: Library + +Add readline.append_history_file. + +.. + +.. bpo: 19676 +.. date: 8805 +.. nonce: Wijwr8 +.. section: Library + +Added the "namereplace" error handler. + +.. + +.. bpo: 22788 +.. date: 8804 +.. nonce: vofL9e +.. section: Library + +Add *context* parameter to logging.handlers.HTTPHandler. + +.. + +.. bpo: 22921 +.. date: 8803 +.. nonce: a4wx1C +.. section: Library + +Allow SSLContext to take the *hostname* parameter even if OpenSSL doesn't +support SNI. + +.. + +.. bpo: 22894 +.. date: 8802 +.. nonce: 4AkwPA +.. section: Library + +TestCase.subTest() would cause the test suite to be stopped when in failfast +mode, even in the absence of failures. + +.. + +.. bpo: 22796 +.. date: 8801 +.. nonce: _pFPFA +.. section: Library + +HTTP cookie parsing is now stricter, in order to protect against potential +injection attacks. + +.. + +.. bpo: 22370 +.. date: 8800 +.. nonce: j4y21u +.. section: Library + +Windows detection in pathlib is now more robust. + +.. + +.. bpo: 22841 +.. date: 8799 +.. nonce: 8wpk7T +.. section: Library + +Reject coroutines in asyncio add_signal_handler(). Patch by Ludovic.Gasc. + +.. + +.. bpo: 19494 +.. date: 8798 +.. nonce: 7O5O8k +.. section: Library + +Added urllib.request.HTTPBasicPriorAuthHandler. Patch by Matej Cepl. + +.. + +.. bpo: 22578 +.. date: 8797 +.. nonce: 6XZ0Jf +.. section: Library + +Added attributes to the re.error class. + +.. + +.. bpo: 22849 +.. date: 8796 +.. nonce: AqBPyj +.. section: Library + +Fix possible double free in the io.TextIOWrapper constructor. + +.. + +.. bpo: 12728 +.. date: 8795 +.. nonce: rHZmXO +.. section: Library + +Different Unicode characters having the same uppercase but different +lowercase are now matched in case-insensitive regular expressions. + +.. + +.. bpo: 22821 +.. date: 8794 +.. nonce: 30cQ-U +.. section: Library + +Fixed fcntl() with integer argument on 64-bit big-endian platforms. + +.. + +.. bpo: 21650 +.. date: 8793 +.. nonce: 62MLqr +.. section: Library + +Add an `--sort-keys` option to json.tool CLI. + +.. + +.. bpo: 22824 +.. date: 8792 +.. nonce: d5Txvr +.. section: Library + +Updated reprlib output format for sets to use set literals. Patch +contributed by Berker Peksag. + +.. + +.. bpo: 22824 +.. date: 8791 +.. nonce: H_r9uH +.. section: Library + +Updated reprlib output format for arrays to display empty arrays without an +unnecessary empty list. Suggested by Serhiy Storchaka. + +.. + +.. bpo: 22406 +.. date: 8790 +.. nonce: sPlVbI +.. section: Library + +Fixed the uu_codec codec incorrectly ported to 3.x. Based on patch by Martin +Panter. + +.. + +.. bpo: 17293 +.. date: 8789 +.. nonce: Hk06bO +.. section: Library + +uuid.getnode() now determines MAC address on AIX using netstat. Based on +patch by Aivars Kalv?ns. + +.. + +.. bpo: 22769 +.. date: 8788 +.. nonce: PunnvQ +.. section: Library + +Fixed ttk.Treeview.tag_has() when called without arguments. + +.. + +.. bpo: 22417 +.. date: 8787 +.. nonce: To4b7U +.. section: Library + +Verify certificates by default in httplib (PEP 476). + +.. + +.. bpo: 22775 +.. date: 8786 +.. nonce: V5aCUz +.. section: Library + +Fixed unpickling of http.cookies.SimpleCookie with protocol 2 and above. +Patch by Tim Graham. + +.. + +.. bpo: 22776 +.. date: 8785 +.. nonce: xNcRse +.. section: Library + +Brought excluded code into the scope of a try block in SysLogHandler.emit(). + +.. + +.. bpo: 22665 +.. date: 8784 +.. nonce: j6Jlp8 +.. section: Library + +Add missing get_terminal_size and SameFileError to shutil.__all__. + +.. + +.. bpo: 6623 +.. date: 8783 +.. nonce: 6LOidS +.. section: Library + +Remove deprecated Netrc class in the ftplib module. Patch by Matt Chaput. + +.. + +.. bpo: 17381 +.. date: 8782 +.. nonce: 4J5yv7 +.. section: Library + +Fixed handling of case-insensitive ranges in regular expressions. + +.. + +.. bpo: 22410 +.. date: 8781 +.. nonce: 99YFdd +.. section: Library + +Module level functions in the re module now cache compiled locale-dependent +regular expressions taking into account the locale. + +.. + +.. bpo: 22759 +.. date: 8780 +.. nonce: BJPdiL +.. section: Library + +Query methods on pathlib.Path() (exists(), is_dir(), etc.) now return False +when the underlying stat call raises NotADirectoryError. + +.. + +.. bpo: 8876 +.. date: 8779 +.. nonce: A83Av4 +.. section: Library + +distutils now falls back to copying files when hard linking doesn't work. +This allows use with special filesystems such as VirtualBox shared folders. + +.. + +.. bpo: 22217 +.. date: 8778 +.. nonce: nXzGur +.. section: Library + +Implemented reprs of classes in the zipfile module. + +.. + +.. bpo: 22457 +.. date: 8777 +.. nonce: Xd2Mk- +.. section: Library + +Honour load_tests in the start_dir of discovery. + +.. + +.. bpo: 18216 +.. date: 8776 +.. nonce: trTZw4 +.. section: Library + +gettext now raises an error when a .mo file has an unsupported major version +number. Patch by Aaron Hill. + +.. + +.. bpo: 13918 +.. date: 8775 +.. nonce: -OnUhD +.. section: Library + +Provide a locale.delocalize() function which can remove locale-specific +number formatting from a string representing a number, without then +converting it to a specific type. Patch by C?dric Krier. + +.. + +.. bpo: 22676 +.. date: 8774 +.. nonce: d2v8QM +.. section: Library + +Make the pickling of global objects which don't have a __module__ attribute +less slow. + +.. + +.. bpo: 18853 +.. date: 8773 +.. nonce: 76DrPD +.. section: Library + +Fixed ResourceWarning in shlex.__nain__. + +.. + +.. bpo: 9351 +.. date: 8772 +.. nonce: u5UI-6 +.. section: Library + +Defaults set with set_defaults on an argparse subparser are no longer +ignored when also set on the parent parser. + +.. + +.. bpo: 7559 +.. date: 8771 +.. nonce: QG35ZP +.. section: Library + +unittest test loading ImportErrors are reported as import errors with their +import exception rather than as attribute errors after the import has +already failed. + +.. + +.. bpo: 19746 +.. date: 8770 +.. nonce: S1dg1K +.. section: Library + +Make it possible to examine the errors from unittest discovery without +executing the test suite. The new `errors` attribute on TestLoader exposes +these non-fatal errors encountered during discovery. + +.. + +.. bpo: 21991 +.. date: 8769 +.. nonce: Mkm0IN +.. section: Library + +Make email.headerregistry's header 'params' attributes be read-only +(MappingProxyType). Previously the dictionary was modifiable but a new one +was created on each access of the attribute. + +.. + +.. bpo: 22638 +.. date: 8768 +.. nonce: Ur73gJ +.. section: Library + +SSLv3 is now disabled throughout the standard library. It can still be +enabled by instantiating a SSLContext manually. + +.. + +.. bpo: 22641 +.. date: 8767 +.. nonce: m0ldtl +.. section: Library + +In asyncio, the default SSL context for client connections is now created +using ssl.create_default_context(), for stronger security. + +.. + +.. bpo: 17401 +.. date: 8766 +.. nonce: SZd19P +.. section: Library + +Include closefd in io.FileIO repr. + +.. + +.. bpo: 21338 +.. date: 8765 +.. nonce: evDyHD +.. section: Library + +Add silent mode for compileall. quiet parameters of compile_{dir, file, +path} functions now have a multilevel value. Also, -q option of the CLI now +have a multilevel value. Patch by Thomas Kluyver. + +.. + +.. bpo: 20152 +.. date: 8764 +.. nonce: 9_o92A +.. section: Library + +Convert the array and cmath modules to Argument Clinic. + +.. + +.. bpo: 18643 +.. date: 8763 +.. nonce: 6Qdc0J +.. section: Library + +Add socket.socketpair() on Windows. + +.. + +.. bpo: 22435 +.. date: 8762 +.. nonce: s2U7Zm +.. section: Library + +Fix a file descriptor leak when socketserver bind fails. + +.. + +.. bpo: 13096 +.. date: 8761 +.. nonce: rsailB +.. section: Library + +Fixed segfault in CTypes POINTER handling of large values. + +.. + +.. bpo: 11694 +.. date: 8760 +.. nonce: JuDrch +.. section: Library + +Raise ConversionError in xdrlib as documented. Patch by Filip Gruszczy?ski +and Claudiu Popa. + +.. + +.. bpo: 19380 +.. date: 8759 +.. nonce: nqgoRQ +.. section: Library + +Optimized parsing of regular expressions. + +.. + +.. bpo: 1519638 +.. date: 8758 +.. nonce: 2pbuog +.. section: Library + +Now unmatched groups are replaced with empty strings in re.sub() and +re.subn(). + +.. + +.. bpo: 18615 +.. date: 8757 +.. nonce: 65TxnY +.. section: Library + +sndhdr.what/whathdr now return a namedtuple. + +.. + +.. bpo: 22462 +.. date: 8756 +.. nonce: 1h4Kpr +.. section: Library + +Fix pyexpat's creation of a dummy frame to make it appear in exception +tracebacks. + +.. + +.. bpo: 21965 +.. date: 8755 +.. nonce: n_jnXs +.. section: Library + +Add support for in-memory SSL to the ssl module. Patch by Geert Jansen. + +.. + +.. bpo: 21173 +.. date: 8754 +.. nonce: egkbEx +.. section: Library + +Fix len() on a WeakKeyDictionary when .clear() was called with an iterator +alive. + +.. + +.. bpo: 11866 +.. date: 8753 +.. nonce: xrvbIC +.. section: Library + +Eliminated race condition in the computation of names for new threads. + +.. + +.. bpo: 21905 +.. date: 8752 +.. nonce: coKyRo +.. section: Library + +Avoid RuntimeError in pickle.whichmodule() when sys.modules is mutated while +iterating. Patch by Olivier Grisel. + +.. + +.. bpo: 11271 +.. date: 8751 +.. nonce: ZYiJru +.. section: Library + +concurrent.futures.Executor.map() now takes a *chunksize* argument to allow +batching of tasks in child processes and improve performance of +ProcessPoolExecutor. Patch by Dan O'Reilly. + +.. + +.. bpo: 21883 +.. date: 8750 +.. nonce: qpuQu6 +.. section: Library + +os.path.join() and os.path.relpath() now raise a TypeError with more helpful +error message for unsupported or mismatched types of arguments. + +.. + +.. bpo: 22219 +.. date: 8749 +.. nonce: l9Enh9 +.. section: Library + +The zipfile module CLI now adds entries for directories (including empty +directories) in ZIP file. + +.. + +.. bpo: 22449 +.. date: 8748 +.. nonce: nFW_Fl +.. section: Library + +In the ssl.SSLContext.load_default_certs, consult the environmental +variables SSL_CERT_DIR and SSL_CERT_FILE on Windows. + +.. + +.. bpo: 22508 +.. date: 8747 +.. nonce: 2LbnGQ +.. section: Library + +The email.__version__ variable has been removed; the email code is no longer +shipped separately from the stdlib, and __version__ hasn't been updated in +several releases. + +.. + +.. bpo: 20076 +.. date: 8746 +.. nonce: -7OIVB +.. section: Library + +Added non derived UTF-8 aliases to locale aliases table. + +.. + +.. bpo: 20079 +.. date: 8745 +.. nonce: qM949O +.. section: Library + +Added locales supported in glibc 2.18 to locale alias table. + +.. + +.. bpo: 20218 +.. date: 8744 +.. nonce: CMgOyE +.. section: Library + +Added convenience methods read_text/write_text and read_bytes/ write_bytes +to pathlib.Path objects. + +.. + +.. bpo: 22396 +.. date: 8743 +.. nonce: cQSizA +.. section: Library + +On 32-bit AIX platform, don't expose os.posix_fadvise() nor +os.posix_fallocate() because their prototypes in system headers are wrong. + +.. + +.. bpo: 22517 +.. date: 8742 +.. nonce: qT6-aB +.. section: Library + +When an io.BufferedRWPair object is deallocated, clear its weakrefs. + +.. + +.. bpo: 22437 +.. date: 8741 +.. nonce: MRVnmQ +.. section: Library + +Number of capturing groups in regular expression is no longer limited by +100. + +.. + +.. bpo: 17442 +.. date: 8740 +.. nonce: rnc87D +.. section: Library + +InteractiveInterpreter now displays the full chained traceback in its +showtraceback method, to match the built in interactive interpreter. + +.. + +.. bpo: 23392 +.. date: 8739 +.. nonce: Pe7_WK +.. section: Library + +Added tests for marshal C API that works with FILE*. + +.. + +.. bpo: 10510 +.. date: 8738 +.. nonce: N-ntcD +.. section: Library + +distutils register and upload methods now use HTML standards compliant CRLF +line endings. + +.. + +.. bpo: 9850 +.. date: 8737 +.. nonce: D-UnVi +.. section: Library + +Fixed macpath.join() for empty first component. Patch by Oleg Oshmyan. + +.. + +.. bpo: 5309 +.. date: 8736 +.. nonce: pVMmQ8 +.. section: Library + +distutils' build and build_ext commands now accept a ``-j`` option to enable +parallel building of extension modules. + +.. + +.. bpo: 22448 +.. date: 8735 +.. nonce: fAapvE +.. section: Library + +Improve canceled timer handles cleanup to prevent unbound memory usage. +Patch by Joshua Moore-Oliva. + +.. + +.. bpo: 22427 +.. date: 8734 +.. nonce: TZ5S_u +.. section: Library + +TemporaryDirectory no longer attempts to clean up twice when used in the +with statement in generator. + +.. + +.. bpo: 22362 +.. date: 8733 +.. nonce: xIBThN +.. section: Library + +Forbidden ambiguous octal escapes out of range 0-0o377 in regular +expressions. + +.. + +.. bpo: 20912 +.. date: 8732 +.. nonce: cAq3mZ +.. section: Library + +Now directories added to ZIP file have correct Unix and MS-DOS directory +attributes. + +.. + +.. bpo: 21866 +.. date: 8731 +.. nonce: hSc4wM +.. section: Library + +ZipFile.close() no longer writes ZIP64 central directory records if +allowZip64 is false. + +.. + +.. bpo: 22278 +.. date: 8730 +.. nonce: abqBXZ +.. section: Library + +Fix urljoin problem with relative urls, a regression observed after changes +to issue22118 were submitted. + +.. + +.. bpo: 22415 +.. date: 8729 +.. nonce: xJLAvI +.. section: Library + +Fixed debugging output of the GROUPREF_EXISTS opcode in the re module. +Removed trailing spaces in debugging output. + +.. + +.. bpo: 22423 +.. date: 8728 +.. nonce: Rtb4oT +.. section: Library + +Unhandled exception in thread no longer causes unhandled AttributeError when +sys.stderr is None. + +.. + +.. bpo: 21332 +.. date: 8727 +.. nonce: Gwxwlr +.. section: Library + +Ensure that ``bufsize=1`` in subprocess.Popen() selects line buffering, +rather than block buffering. Patch by Akira Li. + +.. + +.. bpo: 21091 +.. date: 8726 +.. nonce: M5hAtT +.. section: Library + +Fix API bug: email.message.EmailMessage.is_attachment is now a method. + +.. + +.. bpo: 21079 +.. date: 8725 +.. nonce: czVcL8 +.. section: Library + +Fix email.message.EmailMessage.is_attachment to return the correct result +when the header has parameters as well as a value. + +.. + +.. bpo: 22247 +.. date: 8724 +.. nonce: sGIpR3 +.. section: Library + +Add NNTPError to nntplib.__all__. + +.. + +.. bpo: 22366 +.. date: 8723 +.. nonce: Dd1eFj +.. section: Library + +urllib.request.urlopen will accept a context object (SSLContext) as an +argument which will then be used for HTTPS connection. Patch by Alex Gaynor. + +.. + +.. bpo: 4180 +.. date: 8722 +.. nonce: QBx0JK +.. section: Library + +The warnings registries are now reset when the filters are modified. + +.. + +.. bpo: 22419 +.. date: 8721 +.. nonce: FqH4aC +.. section: Library + +Limit the length of incoming HTTP request in wsgiref server to 65536 bytes +and send a 414 error code for higher lengths. Patch contributed by Devin +Cook. + +.. + +.. bpo: 0 +.. date: 8720 +.. nonce: y7r3O2 +.. section: Library + +Lax cookie parsing in http.cookies could be a security issue when combined +with non-standard cookie handling in some Web browsers. Reported by Sergey +Bobrov. + +.. + +.. bpo: 20537 +.. date: 8719 +.. nonce: E0CE54 +.. section: Library + +logging methods now accept an exception instance as well as a Boolean value +or exception tuple. Thanks to Yury Selivanov for the patch. + +.. + +.. bpo: 22384 +.. date: 8718 +.. nonce: -Nl4He +.. section: Library + +An exception in Tkinter callback no longer crashes the program when it is +run with pythonw.exe. + +.. + +.. bpo: 22168 +.. date: 8717 +.. nonce: vLeKWC +.. section: Library + +Prevent turtle AttributeError with non-default Canvas on OS X. + +.. + +.. bpo: 21147 +.. date: 8716 +.. nonce: w9DE17 +.. section: Library + +sqlite3 now raises an exception if the request contains a null character +instead of truncating it. Based on patch by Victor Stinner. + +.. + +.. bpo: 13968 +.. date: 8715 +.. nonce: 1okGqm +.. section: Library + +The glob module now supports recursive search in subdirectories using the +``**`` pattern. + +.. + +.. bpo: 21951 +.. date: 8714 +.. nonce: 3vS4LK +.. section: Library + +Fixed a crash in Tkinter on AIX when called Tcl command with empty string or +tuple argument. + +.. + +.. bpo: 21951 +.. date: 8713 +.. nonce: _CCC4v +.. section: Library + +Tkinter now most likely raises MemoryError instead of crash if the memory +allocation fails. + +.. + +.. bpo: 22338 +.. date: 8712 +.. nonce: rKlCMz +.. section: Library + +Fix a crash in the json module on memory allocation failure. + +.. + +.. bpo: 12410 +.. date: 8711 +.. nonce: oFf-cB +.. section: Library + +imaplib.IMAP4 now supports the context management protocol. Original patch +by Tarek Ziad?. + +.. + +.. bpo: 21270 +.. date: 8710 +.. nonce: qMBaY- +.. section: Library + +We now override tuple methods in mock.call objects so that they can be used +as normal call attributes. + +.. + +.. bpo: 16662 +.. date: 8709 +.. nonce: Nghn-Y +.. section: Library + +load_tests() is now unconditionally run when it is present in a package's +__init__.py. TestLoader.loadTestsFromModule() still accepts use_load_tests, +but it is deprecated and ignored. A new keyword-only attribute `pattern` is +added and documented. Patch given by Robert Collins, tweaked by Barry +Warsaw. + +.. + +.. bpo: 22226 +.. date: 8708 +.. nonce: T1ZMPY +.. section: Library + +First letter no longer is stripped from the "status" key in the result of +Treeview.heading(). + +.. + +.. bpo: 19524 +.. date: 8707 +.. nonce: EQJjlF +.. section: Library + +Fixed resource leak in the HTTP connection when an invalid response is +received. Patch by Martin Panter. + +.. + +.. bpo: 20421 +.. date: 8706 +.. nonce: iR0S1s +.. section: Library + +Add a .version() method to SSL sockets exposing the actual protocol version +in use. + +.. + +.. bpo: 19546 +.. date: 8705 +.. nonce: 8VdYBK +.. section: Library + +configparser exceptions no longer expose implementation details. Chained +KeyErrors are removed, which leads to cleaner tracebacks. Patch by Claudiu +Popa. + +.. + +.. bpo: 22051 +.. date: 8704 +.. nonce: cUjFqL +.. section: Library + +turtledemo no longer reloads examples to re-run them. Initialization of +variables and gui setup should be done in main(), which is called each time +a demo is run, but not on import. + +.. + +.. bpo: 21933 +.. date: 8703 +.. nonce: IhMjN1 +.. section: Library + +Turtledemo users can change the code font size with a menu selection or +control(command) '-' or '+' or control-mousewheel. Original patch by Lita +Cho. + +.. + +.. bpo: 21597 +.. date: 8702 +.. nonce: aPTCWJ +.. section: Library + +The separator between the turtledemo text pane and the drawing canvas can +now be grabbed and dragged with a mouse. The code text pane can be widened +to easily view or copy the full width of the text. The canvas can be +widened on small screens. Original patches by Jan Kanis and Lita Cho. + +.. + +.. bpo: 18132 +.. date: 8701 +.. nonce: 2R2nwM +.. section: Library + +Turtledemo buttons no longer disappear when the window is shrunk. Original +patches by Jan Kanis and Lita Cho. + +.. + +.. bpo: 22043 +.. date: 8700 +.. nonce: Q6RvGL +.. section: Library + +time.monotonic() is now always available. ``threading.Lock.acquire()``, +``threading.RLock.acquire()`` and socket operations now use a monotonic +clock, instead of the system clock, when a timeout is used. + +.. + +.. bpo: 21527 +.. date: 8699 +.. nonce: N5WPxr +.. section: Library + +Add a default number of workers to ThreadPoolExecutor equal to 5 times the +number of CPUs. Patch by Claudiu Popa. + +.. + +.. bpo: 22216 +.. date: 8698 +.. nonce: Cmalu6 +.. section: Library + +smtplib now resets its state more completely after a quit. The most obvious +consequence of the previous behavior was a STARTTLS failure during a +connect/starttls/quit/connect/starttls sequence. + +.. + +.. bpo: 22098 +.. date: 8697 +.. nonce: 5JYiQN +.. section: Library + +ctypes' BigEndianStructure and LittleEndianStructure now define an empty +__slots__ so that subclasses don't always get an instance dict. Patch by +Claudiu Popa. + +.. + +.. bpo: 22185 +.. date: 8696 +.. nonce: 1SCCIK +.. section: Library + +Fix an occasional RuntimeError in threading.Condition.wait() caused by +mutation of the waiters queue without holding the lock. Patch by Doug +Zongker. + +.. + +.. bpo: 22287 +.. date: 8695 +.. nonce: awH2AI +.. section: Library + +On UNIX, _PyTime_gettimeofday() now uses clock_gettime(CLOCK_REALTIME) if +available. As a side effect, Python now depends on the librt library on +Solaris and on Linux (only with glibc older than 2.17). + +.. + +.. bpo: 22182 +.. date: 8694 +.. nonce: 5EG1Bc +.. section: Library + +Use e.args to unpack exceptions correctly in distutils.file_util.move_file. +Patch by Claudiu Popa. + +.. + +.. bpo: 0 +.. date: 8693 +.. nonce: zBfe8J +.. section: Library + +The webbrowser module now uses subprocess's start_new_session=True rather +than a potentially risky preexec_fn=os.setsid call. + +.. + +.. bpo: 22042 +.. date: 8692 +.. nonce: WZvb8s +.. section: Library + +signal.set_wakeup_fd(fd) now raises an exception if the file descriptor is +in blocking mode. + +.. + +.. bpo: 16808 +.. date: 8691 +.. nonce: kPy_5U +.. section: Library + +inspect.stack() now returns a named tuple instead of a tuple. Patch by +Daniel Shahaf. + +.. + +.. bpo: 22236 +.. date: 8690 +.. nonce: 1utXkg +.. section: Library + +Fixed Tkinter images copying operations in NoDefaultRoot mode. + +.. + +.. bpo: 2527 +.. date: 8689 +.. nonce: fR2GS6 +.. section: Library + +Add a *globals* argument to timeit functions, in order to override the +globals namespace in which the timed code is executed. Patch by Ben Roberts. + +.. + +.. bpo: 22118 +.. date: 8688 +.. nonce: 3gdkOF +.. section: Library + +Switch urllib.parse to use RFC 3986 semantics for the resolution of relative +URLs, rather than RFCs 1808 and 2396. Patch by Demian Brecht. + +.. + +.. bpo: 21549 +.. date: 8687 +.. nonce: i1LVvg +.. section: Library + +Added the "members" parameter to TarFile.list(). + +.. + +.. bpo: 19628 +.. date: 8686 +.. nonce: ssQVP8 +.. section: Library + +Allow compileall recursion depth to be specified with a -r option. + +.. + +.. bpo: 15696 +.. date: 8685 +.. nonce: PTwXYJ +.. section: Library + +Add a __sizeof__ implementation for mmap objects on Windows. + +.. + +.. bpo: 22068 +.. date: 8684 +.. nonce: wCdaW0 +.. section: Library + +Avoided reference loops with Variables and Fonts in Tkinter. + +.. + +.. bpo: 22165 +.. date: 8683 +.. nonce: J1np4o +.. section: Library + +SimpleHTTPRequestHandler now supports undecodable file names. + +.. + +.. bpo: 15381 +.. date: 8682 +.. nonce: Ia8pf6 +.. section: Library + +Optimized line reading in io.BytesIO. + +.. + +.. bpo: 8797 +.. date: 8681 +.. nonce: aJcIPu +.. section: Library + +Raise HTTPError on failed Basic Authentication immediately. Initial patch by +Sam Bull. + +.. + +.. bpo: 20729 +.. date: 8680 +.. nonce: I-1Lap +.. section: Library + +Restored the use of lazy iterkeys()/itervalues()/iteritems() in the mailbox +module. + +.. + +.. bpo: 21448 +.. date: 8679 +.. nonce: THJSYB +.. section: Library + +Changed FeedParser feed() to avoid O(N**2) behavior when parsing long line. +Original patch by Raymond Hettinger. + +.. + +.. bpo: 22184 +.. date: 8678 +.. nonce: UCbSOt +.. section: Library + +The functools LRU Cache decorator factory now gives an earlier and clearer +error message when the user forgets the required parameters. + +.. + +.. bpo: 17923 +.. date: 8677 +.. nonce: YI_QjG +.. section: Library + +glob() patterns ending with a slash no longer match non-dirs on AIX. Based +on patch by Delhallt. + +.. + +.. bpo: 21725 +.. date: 8676 +.. nonce: eIu-2N +.. section: Library + +Added support for RFC 6531 (SMTPUTF8) in smtpd. + +.. + +.. bpo: 22176 +.. date: 8675 +.. nonce: rgbRyg +.. section: Library + +Update the ctypes module's libffi to v3.1. This release adds support for +the Linux AArch64 and POWERPC ELF ABIv2 little endian architectures. + +.. + +.. bpo: 5411 +.. date: 8674 +.. nonce: 5Utapn +.. section: Library + +Added support for the "xztar" format in the shutil module. + +.. + +.. bpo: 21121 +.. date: 8673 +.. nonce: ZLsRil +.. section: Library + +Don't force 3rd party C extensions to be built with -Werror=declaration- +after-statement. + +.. + +.. bpo: 21975 +.. date: 8672 +.. nonce: MI8ntO +.. section: Library + +Fixed crash when using uninitialized sqlite3.Row (in particular when +unpickling pickled sqlite3.Row). sqlite3.Row is now initialized in the +__new__() method. + +.. + +.. bpo: 20170 +.. date: 8671 +.. nonce: 8QfhN7 +.. section: Library + +Convert posixmodule to use Argument Clinic. + +.. + +.. bpo: 21539 +.. date: 8670 +.. nonce: YccmZF +.. section: Library + +Add an *exists_ok* argument to `Pathlib.mkdir()` to mimic `mkdir -p` and +`os.makedirs()` functionality. When true, ignore FileExistsErrors. Patch +by Berker Peksag. + +.. + +.. bpo: 22127 +.. date: 8669 +.. nonce: 0l2OO5 +.. section: Library + +Bypass IDNA for pure-ASCII host names in the socket module (in particular +for numeric IPs). + +.. + +.. bpo: 21047 +.. date: 8668 +.. nonce: XfUQG3 +.. section: Library + +set the default value for the *convert_charrefs* argument of HTMLParser to +True. Patch by Berker Peksag. + +.. + +.. bpo: 0 +.. date: 8667 +.. nonce: 56bAnQ +.. section: Library + +Add an __all__ to html.entities. + +.. + +.. bpo: 15114 +.. date: 8666 +.. nonce: jXwseC +.. section: Library + +the strict mode and argument of HTMLParser, HTMLParser.error, and the +HTMLParserError exception have been removed. + +.. + +.. bpo: 22085 +.. date: 8665 +.. nonce: 3JM_Aw +.. section: Library + +Dropped support of Tk 8.3 in Tkinter. + +.. + +.. bpo: 21580 +.. date: 8664 +.. nonce: 3ssycS +.. section: Library + +Now Tkinter correctly handles bytes arguments passed to Tk. In particular +this allows initializing images from binary data. + +.. + +.. bpo: 22003 +.. date: 8663 +.. nonce: 4ZIDS1 +.. section: Library + +When initialized from a bytes object, io.BytesIO() now defers making a copy +until it is mutated, improving performance and memory use on some use cases. +Patch by David Wilson. + +.. + +.. bpo: 22018 +.. date: 8662 +.. nonce: 6ApxSH +.. section: Library + +On Windows, signal.set_wakeup_fd() now also supports sockets. A side effect +is that Python depends to the WinSock library. + +.. + +.. bpo: 22054 +.. date: 8661 +.. nonce: zp6Svw +.. section: Library + +Add os.get_blocking() and os.set_blocking() functions to get and set the +blocking mode of a file descriptor (False if the O_NONBLOCK flag is set, +True otherwise). These functions are not available on Windows. + +.. + +.. bpo: 17172 +.. date: 8660 +.. nonce: R_LI_2 +.. section: Library + +Make turtledemo start as active on OS X even when run with subprocess. +Patch by Lita Cho. + +.. + +.. bpo: 21704 +.. date: 8659 +.. nonce: gL3ikj +.. section: Library + +Fix build error for _multiprocessing when semaphores are not available. +Patch by Arfrever Frehtes Taifersar Arahesis. + +.. + +.. bpo: 20173 +.. date: 8658 +.. nonce: FAL-4L +.. section: Library + +Convert sha1, sha256, sha512 and md5 to ArgumentClinic. Patch by Vajrasky +Kok. + +.. + +.. bpo: 0 +.. date: 8657 +.. nonce: G25tq3 +.. section: Library + +Fix repr(_socket.socket) on Windows 64-bit: don't fail with OverflowError on +closed socket. repr(socket.socket) already works fine. + +.. + +.. bpo: 22033 +.. date: 8656 +.. nonce: nkBNci +.. section: Library + +Reprs of most Python implemened classes now contain actual class name +instead of hardcoded one. + +.. + +.. bpo: 21947 +.. date: 8655 +.. nonce: mlisu- +.. section: Library + +The dis module can now disassemble generator-iterator objects based on their +gi_code attribute. Patch by Clement Rouault. + +.. + +.. bpo: 16133 +.. date: 8654 +.. nonce: tYuYQF +.. section: Library + +The asynchat.async_chat.handle_read() method now ignores BlockingIOError +exceptions. + +.. + +.. bpo: 22044 +.. date: 8653 +.. nonce: t09GRU +.. section: Library + +Fixed premature DECREF in call_tzinfo_method. Patch by Tom Flanagan. + +.. + +.. bpo: 19884 +.. date: 8652 +.. nonce: v73gSn +.. section: Library + +readline: Disable the meta modifier key if stdout is not a terminal to not +write the ANSI sequence ``"\033[1034h"`` into stdout. This sequence is used +on some terminal (ex: TERM=xterm-256color") to enable support of 8 bit +characters. + +.. + +.. bpo: 4350 +.. date: 8651 +.. nonce: nrTzJn +.. section: Library + +Removed a number of out-of-dated and non-working for a long time Tkinter +methods. + +.. + +.. bpo: 6167 +.. date: 8650 +.. nonce: n9dV_D +.. section: Library + +Scrollbar.activate() now returns the name of active element if the argument +is not specified. Scrollbar.set() now always accepts only 2 arguments. + +.. + +.. bpo: 15275 +.. date: 8649 +.. nonce: jk0tTI +.. section: Library + +Clean up and speed up the ntpath module. + +.. + +.. bpo: 21888 +.. date: 8648 +.. nonce: danlpz +.. section: Library + +plistlib's load() and loads() now work if the fmt parameter is specified. + +.. + +.. bpo: 22032 +.. date: 8647 +.. nonce: UklzQW +.. section: Library + +__qualname__ instead of __name__ is now always used to format fully +qualified class names of Python implemented classes. + +.. + +.. bpo: 22031 +.. date: 8646 +.. nonce: 9aazp1 +.. section: Library + +Reprs now always use hexadecimal format with the "0x" prefix when contain an +id in form " at 0x...". + +.. + +.. bpo: 22018 +.. date: 8645 +.. nonce: b_JTHH +.. section: Library + +signal.set_wakeup_fd() now raises an OSError instead of a ValueError on +``fstat()`` failure. + +.. + +.. bpo: 21044 +.. date: 8644 +.. nonce: 16xo9u +.. section: Library + +tarfile.open() now handles fileobj with an integer 'name' attribute. Based +on patch by Antoine Pietri. + +.. + +.. bpo: 21966 +.. date: 8643 +.. nonce: hHD9MK +.. section: Library + +Respect -q command-line option when code module is ran. + +.. + +.. bpo: 19076 +.. date: 8642 +.. nonce: xCoIai +.. section: Library + +Don't pass the redundant 'file' argument to self.error(). + +.. + +.. bpo: 16382 +.. date: 8641 +.. nonce: -XBK7z +.. section: Library + +Improve exception message of warnings.warn() for bad category. Initial patch +by Phil Elson. + +.. + +.. bpo: 21932 +.. date: 8640 +.. nonce: LK_5S1 +.. section: Library + +os.read() now uses a :c:func:`Py_ssize_t` type instead of :c:type:`int` for +the size to support reading more than 2 GB at once. On Windows, the size is +truncted to INT_MAX. As any call to os.read(), the OS may read less bytes +than the number of requested bytes. + +.. + +.. bpo: 21942 +.. date: 8639 +.. nonce: TLOS41 +.. section: Library + +Fixed source file viewing in pydoc's server mode on Windows. + +.. + +.. bpo: 11259 +.. date: 8638 +.. nonce: GxfYnE +.. section: Library + +asynchat.async_chat().set_terminator() now raises a ValueError if the number +of received bytes is negative. + +.. + +.. bpo: 12523 +.. date: 8637 +.. nonce: XBdAky +.. section: Library + +asynchat.async_chat.push() now raises a TypeError if it doesn't get a bytes +string + +.. + +.. bpo: 21707 +.. date: 8636 +.. nonce: rrY_wd +.. section: Library + +Add missing kwonlyargcount argument to ModuleFinder.replace_paths_in_code(). + +.. + +.. bpo: 20639 +.. date: 8635 +.. nonce: YdvOpp +.. section: Library + +calling Path.with_suffix('') allows removing the suffix again. Patch by +July Tikhonov. + +.. + +.. bpo: 21714 +.. date: 8634 +.. nonce: HhkGXW +.. section: Library + +Disallow the construction of invalid paths using Path.with_name(). Original +patch by Antony Lee. + +.. + +.. bpo: 15014 +.. date: 8633 +.. nonce: dB50zb +.. section: Library + +Added 'auth' method to smtplib to make implementing auth mechanisms simpler, +and used it internally in the login method. + +.. + +.. bpo: 21151 +.. date: 8632 +.. nonce: o7IuiD +.. section: Library + +Fixed a segfault in the winreg module when ``None`` is passed as a +``REG_BINARY`` value to SetValueEx. Patch by John Ehresman. + +.. + +.. bpo: 21090 +.. date: 8631 +.. nonce: 20Ooif +.. section: Library + +io.FileIO.readall() does not ignore I/O errors anymore. Before, it ignored +I/O errors if at least the first C call read() succeed. + +.. + +.. bpo: 5800 +.. date: 8630 +.. nonce: ZJiLZP +.. section: Library + +headers parameter of wsgiref.headers.Headers is now optional. Initial patch +by Pablo Torres Navarrete and SilentGhost. + +.. + +.. bpo: 21781 +.. date: 8629 +.. nonce: u_oiv9 +.. section: Library + +ssl.RAND_add() now supports strings longer than 2 GB. + +.. + +.. bpo: 21679 +.. date: 8628 +.. nonce: CTVT9A +.. section: Library + +Prevent extraneous fstat() calls during open(). Patch by Bohuslav Kabrda. + +.. + +.. bpo: 21863 +.. date: 8627 +.. nonce: BzbwSL +.. section: Library + +cProfile now displays the module name of C extension functions, in addition +to their own name. + +.. + +.. bpo: 11453 +.. date: 8626 +.. nonce: 53Gr_R +.. section: Library + +asyncore: emit a ResourceWarning when an unclosed file_wrapper object is +destroyed. The destructor now closes the file if needed. The close() method +can now be called twice: the second call does nothing. + +.. + +.. bpo: 21858 +.. date: 8625 +.. nonce: 0hbFBG +.. section: Library + +Better handling of Python exceptions in the sqlite3 module. + +.. + +.. bpo: 21476 +.. date: 8624 +.. nonce: VN-5pW +.. section: Library + +Make sure the email.parser.BytesParser TextIOWrapper is discarded after +parsing, so the input file isn't unexpectedly closed. + +.. + +.. bpo: 20295 +.. date: 8623 +.. nonce: U1MPhw +.. section: Library + +imghdr now recognizes OpenEXR format images. + +.. + +.. bpo: 21729 +.. date: 8622 +.. nonce: dk7o_U +.. section: Library + +Used the "with" statement in the dbm.dumb module to ensure files closing. +Patch by Claudiu Popa. + +.. + +.. bpo: 21491 +.. date: 8621 +.. nonce: Zxmut- +.. section: Library + +socketserver: Fix a race condition in child processes reaping. + +.. + +.. bpo: 21719 +.. date: 8620 +.. nonce: DhQz3I +.. section: Library + +Added the ``st_file_attributes`` field to os.stat_result on Windows. + +.. + +.. bpo: 21832 +.. date: 8619 +.. nonce: PBA0Uu +.. section: Library + +Require named tuple inputs to be exact strings. + +.. + +.. bpo: 21722 +.. date: 8618 +.. nonce: WTHuRy +.. section: Library + +The distutils "upload" command now exits with a non-zero return code when +uploading fails. Patch by Martin Dengler. + +.. + +.. bpo: 21723 +.. date: 8617 +.. nonce: r86fwb +.. section: Library + +asyncio.Queue: support any type of number (ex: float) for the maximum size. +Patch written by Vajrasky Kok. + +.. + +.. bpo: 21711 +.. date: 8616 +.. nonce: JWPFQZ +.. section: Library + +support for "site-python" directories has now been removed from the site +module (it was deprecated in 3.4). + +.. + +.. bpo: 17552 +.. date: 8615 +.. nonce: NunErD +.. section: Library + +new socket.sendfile() method allowing a file to be sent over a socket by +using high-performance os.sendfile() on UNIX. Patch by Giampaolo Rodola'. + +.. + +.. bpo: 18039 +.. date: 8614 +.. nonce: vC9hNy +.. section: Library + +dbm.dump.open() now always creates a new database when the flag has the +value 'n'. Patch by Claudiu Popa. + +.. + +.. bpo: 21326 +.. date: 8613 +.. nonce: Y6iW3s +.. section: Library + +Add a new is_closed() method to asyncio.BaseEventLoop. run_forever() and +run_until_complete() methods of asyncio.BaseEventLoop now raise an exception +if the event loop was closed. + +.. + +.. bpo: 21766 +.. date: 8612 +.. nonce: 0xk_xC +.. section: Library + +Prevent a security hole in CGIHTTPServer by URL unquoting paths before +checking for a CGI script at that path. + +.. + +.. bpo: 21310 +.. date: 8611 +.. nonce: 2mjByJ +.. section: Library + +Fixed possible resource leak in failed open(). + +.. + +.. bpo: 21256 +.. date: 8610 +.. nonce: dGq6cw +.. section: Library + +Printout of keyword args should be in deterministic order in a mock function +call. This will help to write better doctests. + +.. + +.. bpo: 21677 +.. date: 8609 +.. nonce: 58CDDD +.. section: Library + +Fixed chaining nonnormalized exceptions in io close() methods. + +.. + +.. bpo: 11709 +.. date: 8608 +.. nonce: JdObvL +.. section: Library + +Fix the pydoc.help function to not fail when sys.stdin is not a valid file. + +.. + +.. bpo: 21515 +.. date: 8607 +.. nonce: D9TLJF +.. section: Library + +tempfile.TemporaryFile now uses os.O_TMPFILE flag is available. + +.. + +.. bpo: 13223 +.. date: 8606 +.. nonce: 9AzEbN +.. section: Library + +Fix pydoc.writedoc so that the HTML documentation for methods that use +'self' in the example code is generated correctly. + +.. + +.. bpo: 21463 +.. date: 8605 +.. nonce: 09PsgH +.. section: Library + +In urllib.request, fix pruning of the FTP cache. + +.. + +.. bpo: 21618 +.. date: 8604 +.. nonce: 3Z7WS3 +.. section: Library + +The subprocess module could fail to close open fds that were inherited by +the calling process and already higher than POSIX resource limits would +otherwise allow. On systems with a functioning /proc/self/fd or /dev/fd +interface the max is now ignored and all fds are closed. + +.. + +.. bpo: 20383 +.. date: 8603 +.. nonce: pSPFpW +.. section: Library + +Introduce importlib.util.module_from_spec() as the preferred way to create a +new module. + +.. + +.. bpo: 21552 +.. date: 8602 +.. nonce: uVy4tM +.. section: Library + +Fixed possible integer overflow of too long string lengths in the tkinter +module on 64-bit platforms. + +.. + +.. bpo: 14315 +.. date: 8601 +.. nonce: YzZzS8 +.. section: Library + +The zipfile module now ignores extra fields in the central directory that +are too short to be parsed instead of letting a struct.unpack error bubble +up as this "bad data" appears in many real world zip files in the wild and +is ignored by other zip tools. + +.. + +.. bpo: 13742 +.. date: 8600 +.. nonce: QJiVSC +.. section: Library + +Added "key" and "reverse" parameters to heapq.merge(). (First draft of patch +contributed by Simon Sapin.) + +.. + +.. bpo: 21402 +.. date: 8599 +.. nonce: 51vDXt +.. section: Library + +tkinter.ttk now works when default root window is not set. + +.. + +.. bpo: 3015 +.. date: 8598 +.. nonce: FE_PII +.. section: Library + +_tkinter.create() now creates tkapp object with wantobject=1 by default. + +.. + +.. bpo: 10203 +.. date: 8597 +.. nonce: zgr0hh +.. section: Library + +sqlite3.Row now truly supports sequence protocol. In particular it supports +reverse() and negative indices. Original patch by Claudiu Popa. + +.. + +.. bpo: 18807 +.. date: 8596 +.. nonce: XP7p8B +.. section: Library + +If copying (no symlinks) specified for a venv, then the python interpreter +aliases (python, python3) are now created by copying rather than symlinking. + +.. + +.. bpo: 20197 +.. date: 8595 +.. nonce: nYR9fq +.. section: Library + +Added support for the WebP image type in the imghdr module. Patch by Fabrice +Aneche and Claudiu Popa. + +.. + +.. bpo: 21513 +.. date: 8594 +.. nonce: ro4AOe +.. section: Library + +Speedup some properties of IP addresses (IPv4Address, IPv6Address) such as +.is_private or .is_multicast. + +.. + +.. bpo: 21137 +.. date: 8593 +.. nonce: wgHb_F +.. section: Library + +Improve the repr for threading.Lock() and its variants by showing the +"locked" or "unlocked" status. Patch by Berker Peksag. + +.. + +.. bpo: 21538 +.. date: 8592 +.. nonce: Q60FWA +.. section: Library + +The plistlib module now supports loading of binary plist files when +reference or offset size is not a power of two. + +.. + +.. bpo: 21455 +.. date: 8591 +.. nonce: 6-Uvv4 +.. section: Library + +Add a default backlog to socket.listen(). + +.. + +.. bpo: 21525 +.. date: 8590 +.. nonce: hAKOve +.. section: Library + +Most Tkinter methods which accepted tuples now accept lists too. + +.. + +.. bpo: 22166 +.. date: 8589 +.. nonce: sZYhmv +.. section: Library + +With the assistance of a new internal _codecs._forget_codec helping +function, test_codecs now clears the encoding caches to avoid the appearance +of a reference leak + +.. + +.. bpo: 22236 +.. date: 8588 +.. nonce: ginJSI +.. section: Library + +Tkinter tests now don't reuse default root window. New root window is +created for every test class. + +.. + +.. bpo: 10744 +.. date: 8587 +.. nonce: kfV0wm +.. section: Library + +Fix PEP 3118 format strings on ctypes objects with a nontrivial shape. + +.. + +.. bpo: 20826 +.. date: 8586 +.. nonce: 3rXqMC +.. section: Library + +Optimize ipaddress.collapse_addresses(). + +.. + +.. bpo: 21487 +.. date: 8585 +.. nonce: sX8YmK +.. section: Library + +Optimize ipaddress.summarize_address_range() and +ipaddress.{IPv4Network,IPv6Network}.subnets(). + +.. + +.. bpo: 21486 +.. date: 8584 +.. nonce: CeFKRP +.. section: Library + +Optimize parsing of netmasks in ipaddress.IPv4Network and +ipaddress.IPv6Network. + +.. + +.. bpo: 13916 +.. date: 8583 +.. nonce: D77YVH +.. section: Library + +Disallowed the surrogatepass error handler for non UTF-\* encodings. + +.. + +.. bpo: 20998 +.. date: 8582 +.. nonce: fkxpXI +.. section: Library + +Fixed re.fullmatch() of repeated single character pattern with ignore case. +Original patch by Matthew Barnett. + +.. + +.. bpo: 21075 +.. date: 8581 +.. nonce: f_hmEh +.. section: Library + +fileinput.FileInput now reads bytes from standard stream if binary mode is +specified. Patch by Sam Kimbrel. + +.. + +.. bpo: 19775 +.. date: 8580 +.. nonce: yxxD_R +.. section: Library + +Add a samefile() method to pathlib Path objects. Initial patch by Vajrasky +Kok. + +.. + +.. bpo: 21226 +.. date: 8579 +.. nonce: pzGmG1 +.. section: Library + +Set up modules properly in PyImport_ExecCodeModuleObject (and friends). + +.. + +.. bpo: 21398 +.. date: 8578 +.. nonce: guSBXt +.. section: Library + +Fix a unicode error in the pydoc pager when the documentation contains +characters not encodable to the stdout encoding. + +.. + +.. bpo: 16531 +.. date: 8577 +.. nonce: AhrY_v +.. section: Library + +ipaddress.IPv4Network and ipaddress.IPv6Network now accept an (address, +netmask) tuple argument, so as to easily construct network objects from +existing addresses. + +.. + +.. bpo: 21156 +.. date: 8576 +.. nonce: 3dmBEp +.. section: Library + +importlib.abc.InspectLoader.source_to_code() is now a staticmethod. + +.. + +.. bpo: 21424 +.. date: 8575 +.. nonce: 8CJBqW +.. section: Library + +Simplified and optimized heaqp.nlargest() and nmsmallest() to make fewer +tuple comparisons. + +.. + +.. bpo: 21396 +.. date: 8574 +.. nonce: cqO6DN +.. section: Library + +Fix TextIOWrapper(..., write_through=True) to not force a flush() on the +underlying binary stream. Patch by akira. + +.. + +.. bpo: 18314 +.. date: 8573 +.. nonce: NCd_KF +.. section: Library + +Unlink now removes junctions on Windows. Patch by Kim Gr?sman + +.. + +.. bpo: 21088 +.. date: 8572 +.. nonce: WOg7Xy +.. section: Library + +Bugfix for curses.window.addch() regression in 3.4.0. In porting to Argument +Clinic, the first two arguments were reversed. + +.. + +.. bpo: 21407 +.. date: 8571 +.. nonce: cZjFde +.. section: Library + +_decimal: The module now supports function signatures. + +.. + +.. bpo: 10650 +.. date: 8570 +.. nonce: HYT4Oe +.. section: Library + +Remove the non-standard 'watchexp' parameter from the Decimal.quantize() +method in the Python version. It had never been present in the C version. + +.. + +.. bpo: 21469 +.. date: 8569 +.. nonce: _fFGuq +.. section: Library + +Reduced the risk of false positives in robotparser by checking to make sure +that robots.txt has been read or does not exist prior to returning True in +can_fetch(). + +.. + +.. bpo: 19414 +.. date: 8568 +.. nonce: bAAw4D +.. section: Library + +Have the OrderedDict mark deleted links as unusable. This gives an early +failure if the link is deleted during iteration. + +.. + +.. bpo: 21421 +.. date: 8567 +.. nonce: 5AKAat +.. section: Library + +Add __slots__ to the MappingViews ABC. Patch by Josh Rosenberg. + +.. + +.. bpo: 21101 +.. date: 8566 +.. nonce: Lj-_P4 +.. section: Library + +Eliminate double hashing in the C speed-up code for collections.Counter(). + +.. + +.. bpo: 21321 +.. date: 8565 +.. nonce: wUkTON +.. section: Library + +itertools.islice() now releases the reference to the source iterator when +the slice is exhausted. Patch by Anton Afanasyev. + +.. + +.. bpo: 21057 +.. date: 8564 +.. nonce: 0TC4Xl +.. section: Library + +TextIOWrapper now allows the underlying binary stream's read() or read1() +method to return an arbitrary bytes-like object (such as a memoryview). +Patch by Nikolaus Rath. + +.. + +.. bpo: 20951 +.. date: 8563 +.. nonce: tF0dJi +.. section: Library + +SSLSocket.send() now raises either SSLWantReadError or SSLWantWriteError on +a non-blocking socket if the operation would block. Previously, it would +return 0. Patch by Nikolaus Rath. + +.. + +.. bpo: 13248 +.. date: 8562 +.. nonce: 7vtGj0 +.. section: Library + +removed previously deprecated asyncore.dispatcher __getattr__ cheap +inheritance hack. + +.. + +.. bpo: 9815 +.. date: 8561 +.. nonce: 52FPlI +.. section: Library + +assertRaises now tries to clear references to local variables in the +exception's traceback. + +.. + +.. bpo: 19940 +.. date: 8560 +.. nonce: 2qtBQ8 +.. section: Library + +ssl.cert_time_to_seconds() now interprets the given time string in the UTC +timezone (as specified in RFC 5280), not the local timezone. + +.. + +.. bpo: 13204 +.. date: 8559 +.. nonce: ZPKA5g +.. section: Library + +Calling sys.flags.__new__ would crash the interpreter, now it raises a +TypeError. + +.. + +.. bpo: 19385 +.. date: 8558 +.. nonce: PexO_g +.. section: Library + +Make operations on a closed dbm.dumb database always raise the same +exception. + +.. + +.. bpo: 21207 +.. date: 8557 +.. nonce: Hr72AB +.. section: Library + +Detect when the os.urandom cached fd has been closed or replaced, and open +it anew. + +.. + +.. bpo: 21291 +.. date: 8556 +.. nonce: 5sSLWN +.. section: Library + +subprocess's Popen.wait() is now thread safe so that multiple threads may be +calling wait() or poll() on a Popen instance at the same time without losing +the Popen.returncode value. + +.. + +.. bpo: 21127 +.. date: 8555 +.. nonce: A1aBjG +.. section: Library + +Path objects can now be instantiated from str subclass instances (such as +``numpy.str_``). + +.. + +.. bpo: 15002 +.. date: 8554 +.. nonce: qorYDe +.. section: Library + +urllib.response object to use _TemporaryFileWrapper (and +_TemporaryFileCloser) facility. Provides a better way to handle file +descriptor close. Patch contributed by Christian Theune. + +.. + +.. bpo: 12220 +.. date: 8553 +.. nonce: U25uE9 +.. section: Library + +mindom now raises a custom ValueError indicating it doesn't support spaces +in URIs instead of letting a 'split' ValueError bubble up. + +.. + +.. bpo: 21068 +.. date: 8552 +.. nonce: 9k6N9m +.. section: Library + +The ssl.PROTOCOL* constants are now enum members. + +.. + +.. bpo: 21276 +.. date: 8551 +.. nonce: JkfhvQ +.. section: Library + +posixmodule: Don't define USE_XATTRS on KFreeBSD and the Hurd. + +.. + +.. bpo: 21262 +.. date: 8550 +.. nonce: 1J5ylk +.. section: Library + +New method assert_not_called for Mock. It raises AssertionError if the mock +has been called. + +.. + +.. bpo: 21238 +.. date: 8549 +.. nonce: 5CDoox +.. section: Library + +New keyword argument `unsafe` to Mock. It raises `AttributeError` incase of +an attribute startswith assert or assret. + +.. + +.. bpo: 20896 +.. date: 8548 +.. nonce: oWwAb1 +.. section: Library + +ssl.get_server_certificate() now uses PROTOCOL_SSLv23, not PROTOCOL_SSLv3, +for maximum compatibility. + +.. + +.. bpo: 21239 +.. date: 8547 +.. nonce: EalCNt +.. section: Library + +patch.stopall() didn't work deterministically when the same name was patched +more than once. + +.. + +.. bpo: 21203 +.. date: 8546 +.. nonce: 1IMs-Z +.. section: Library + +Updated fileConfig and dictConfig to remove inconsistencies. Thanks to Jure +Koren for the patch. + +.. + +.. bpo: 21222 +.. date: 8545 +.. nonce: G6MQBP +.. section: Library + +Passing name keyword argument to mock.create_autospec now works. + +.. + +.. bpo: 21197 +.. date: 8544 +.. nonce: Gzfqdl +.. section: Library + +Add lib64 -> lib symlink in venvs on 64-bit non-OS X POSIX. + +.. + +.. bpo: 17498 +.. date: 8543 +.. nonce: LR9xyb +.. section: Library + +Some SMTP servers disconnect after certain errors, violating strict RFC +conformance. Instead of losing the error code when we issue the subsequent +RSET, smtplib now returns the error code and defers raising the +SMTPServerDisconnected error until the next command is issued. + +.. + +.. bpo: 17826 +.. date: 8542 +.. nonce: z0zMRV +.. section: Library + +setting an iterable side_effect on a mock function created by +create_autospec now works. Patch by Kushal Das. + +.. + +.. bpo: 7776 +.. date: 8541 +.. nonce: K5S2Pe +.. section: Library + +Fix ``Host:`` header and reconnection when using +http.client.HTTPConnection.set_tunnel(). Patch by Nikolaus Rath. + +.. + +.. bpo: 20968 +.. date: 8540 +.. nonce: 53Aagz +.. section: Library + +unittest.mock.MagicMock now supports division. Patch by Johannes Baiter. + +.. + +.. bpo: 21529 +.. date: 8539 +.. nonce: 57R_Fc +.. section: Library + +Fix arbitrary memory access in JSONDecoder.raw_decode with a negative second +parameter. Bug reported by Guido Vranken. (See also: CVE-2014-4616) + +.. + +.. bpo: 21169 +.. date: 8538 +.. nonce: KE7B0M +.. section: Library + +getpass now handles non-ascii characters that the input stream encoding +cannot encode by re-encoding using the replace error handler. + +.. + +.. bpo: 21171 +.. date: 8537 +.. nonce: iUbV9S +.. section: Library + +Fixed undocumented filter API of the rot13 codec. Patch by Berker Peksag. + +.. + +.. bpo: 20539 +.. date: 8536 +.. nonce: 62nbEb +.. section: Library + +Improved math.factorial error message for large positive inputs and changed +exception type (OverflowError -> ValueError) for large negative inputs. + +.. + +.. bpo: 21172 +.. date: 8535 +.. nonce: dQ7yY7 +.. section: Library + +isinstance check relaxed from dict to collections.Mapping. + +.. + +.. bpo: 21155 +.. date: 8534 +.. nonce: JSKEE7 +.. section: Library + +asyncio.EventLoop.create_unix_server() now raises a ValueError if path and +sock are specified at the same time. + +.. + +.. bpo: 21136 +.. date: 8533 +.. nonce: JZAKv3 +.. section: Library + +Avoid unnecessary normalization of Fractions resulting from power and other +operations. Patch by Raymond Hettinger. + +.. + +.. bpo: 17621 +.. date: 8532 +.. nonce: 1x0mvJ +.. section: Library + +Introduce importlib.util.LazyLoader. + +.. + +.. bpo: 21076 +.. date: 8531 +.. nonce: upxQc6 +.. section: Library + +signal module constants were turned into enums. Patch by Giampaolo Rodola'. + +.. + +.. bpo: 20636 +.. date: 8530 +.. nonce: KGh-BD +.. section: Library + +Improved the repr of Tkinter widgets. + +.. + +.. bpo: 19505 +.. date: 8529 +.. nonce: VEtIE6 +.. section: Library + +The items, keys, and values views of OrderedDict now support reverse +iteration using reversed(). + +.. + +.. bpo: 21149 +.. date: 8528 +.. nonce: cnjwMR +.. section: Library + +Improved thread-safety in logging cleanup during interpreter shutdown. +Thanks to Devin Jeanpierre for the patch. + +.. + +.. bpo: 21058 +.. date: 8527 +.. nonce: IhluPP +.. section: Library + +Fix a leak of file descriptor in :func:`tempfile.NamedTemporaryFile`, close +the file descriptor if :func:`io.open` fails + +.. + +.. bpo: 21200 +.. date: 8526 +.. nonce: Kht8yD +.. section: Library + +Return None from pkgutil.get_loader() when __spec__ is missing. + +.. + +.. bpo: 21013 +.. date: 8525 +.. nonce: 3s8Ic0 +.. section: Library + +Enhance ssl.create_default_context() when used for server side sockets to +provide better security by default. + +.. + +.. bpo: 20145 +.. date: 8524 +.. nonce: FP5FY0 +.. section: Library + +`assertRaisesRegex` and `assertWarnsRegex` now raise a TypeError if the +second argument is not a string or compiled regex. + +.. + +.. bpo: 20633 +.. date: 8523 +.. nonce: 6kaPjT +.. section: Library + +Replace relative import by absolute import. + +.. + +.. bpo: 20980 +.. date: 8522 +.. nonce: cYszHY +.. section: Library + +Stop wrapping exception when using ThreadPool. + +.. + +.. bpo: 21082 +.. date: 8521 +.. nonce: GLzGlV +.. section: Library + +In os.makedirs, do not set the process-wide umask. Note this changes +behavior of makedirs when exist_ok=True. + +.. + +.. bpo: 20990 +.. date: 8520 +.. nonce: PBfjW3 +.. section: Library + +Fix issues found by pyflakes for multiprocessing. + +.. + +.. bpo: 21015 +.. date: 8519 +.. nonce: xnwWAH +.. section: Library + +SSL contexts will now automatically select an elliptic curve for ECDH key +exchange on OpenSSL 1.0.2 and later, and otherwise default to "prime256v1". + +.. + +.. bpo: 21000 +.. date: 8518 +.. nonce: JUyyVV +.. section: Library + +Improve the command-line interface of json.tool. + +.. + +.. bpo: 20995 +.. date: 8517 +.. nonce: KSORJT +.. section: Library + +Enhance default ciphers used by the ssl module to enable better security and +prioritize perfect forward secrecy. + +.. + +.. bpo: 20884 +.. date: 8516 +.. nonce: qNmub_ +.. section: Library + +Don't assume that __file__ is defined on importlib.__init__. + +.. + +.. bpo: 21499 +.. date: 8515 +.. nonce: wU4OBi +.. section: Library + +Ignore __builtins__ in several test_importlib.test_api tests. + +.. + +.. bpo: 20627 +.. date: 8514 +.. nonce: fgfQ1x +.. section: Library + +xmlrpc.client.ServerProxy is now a context manager. + +.. + +.. bpo: 19165 +.. date: 8513 +.. nonce: sAkUjU +.. section: Library + +The formatter module now raises DeprecationWarning instead of +PendingDeprecationWarning. + +.. + +.. bpo: 13936 +.. date: 8512 +.. nonce: _Q0Yog +.. section: Library + +Remove the ability of datetime.time instances to be considered false in +boolean contexts. + +.. + +.. bpo: 18931 +.. date: 8511 +.. nonce: mq4Mud +.. section: Library + +selectors module now supports /dev/poll on Solaris. Patch by Giampaolo +Rodola'. + +.. + +.. bpo: 19977 +.. date: 8510 +.. nonce: A-sQ_V +.. section: Library + +When the ``LC_TYPE`` locale is the POSIX locale (``C`` locale), +:py:data:`sys.stdin` and :py:data:`sys.stdout` are now using the +``surrogateescape`` error handler, instead of the ``strict`` error handler. + +.. + +.. bpo: 20574 +.. date: 8509 +.. nonce: KaKqSs +.. section: Library + +Implement incremental decoder for cp65001 code (Windows code page 65001, +Microsoft UTF-8). + +.. + +.. bpo: 20879 +.. date: 8508 +.. nonce: myeYdq +.. section: Library + +Delay the initialization of encoding and decoding tables for base32, ascii85 +and base85 codecs in the base64 module, and delay the initialization of the +unquote_to_bytes() table of the urllib.parse module, to not waste memory if +these modules are not used. + +.. + +.. bpo: 19157 +.. date: 8507 +.. nonce: V1-XhC +.. section: Library + +Include the broadcast address in the usuable hosts for IPv6 in ipaddress. + +.. + +.. bpo: 11599 +.. date: 8506 +.. nonce: 9QOXf4 +.. section: Library + +When an external command (e.g. compiler) fails, distutils now prints out the +whole command line (instead of just the command name) if the environment +variable DISTUTILS_DEBUG is set. + +.. + +.. bpo: 4931 +.. date: 8505 +.. nonce: uF10hr +.. section: Library + +distutils should not produce unhelpful "error: None" messages anymore. +distutils.util.grok_environment_error is kept but doc-deprecated. + +.. + +.. bpo: 20875 +.. date: 8504 +.. nonce: IjfI5V +.. section: Library + +Prevent possible gzip "'read' is not defined" NameError. Patch by Claudiu +Popa. + +.. + +.. bpo: 11558 +.. date: 8503 +.. nonce: pxrsmq +.. section: Library + +``email.message.Message.attach`` now returns a more useful error message if +``attach`` is called on a message for which ``is_multipart`` is False. + +.. + +.. bpo: 20283 +.. date: 8502 +.. nonce: v0Vs9V +.. section: Library + +RE pattern methods now accept the string keyword parameters as documented. +The pattern and source keyword parameters are left as deprecated aliases. + +.. + +.. bpo: 20778 +.. date: 8501 +.. nonce: g_fAGI +.. section: Library + +Fix modulefinder to work with bytecode-only modules. + +.. + +.. bpo: 20791 +.. date: 8500 +.. nonce: n_zrkc +.. section: Library + +copy.copy() now doesn't make a copy when the input is a bytes object. +Initial patch by Peter Otten. + +.. + +.. bpo: 19748 +.. date: 8499 +.. nonce: kiA171 +.. section: Library + +On AIX, time.mktime() now raises an OverflowError for year outsize range +[1902; 2037]. + +.. + +.. bpo: 19573 +.. date: 8498 +.. nonce: QJvX_V +.. section: Library + +inspect.signature: Use enum for parameter kind constants. + +.. + +.. bpo: 20726 +.. date: 8497 +.. nonce: 0yfRDI +.. section: Library + +inspect.signature: Make Signature and Parameter picklable. + +.. + +.. bpo: 17373 +.. date: 8496 +.. nonce: ECwuJO +.. section: Library + +Add inspect.Signature.from_callable method. + +.. + +.. bpo: 20378 +.. date: 8495 +.. nonce: l9M3H- +.. section: Library + +Improve repr of inspect.Signature and inspect.Parameter. + +.. + +.. bpo: 20816 +.. date: 8494 +.. nonce: DFMEgN +.. section: Library + +Fix inspect.getcallargs() to raise correct TypeError for missing keyword- +only arguments. Patch by Jeremiah Lowin. + +.. + +.. bpo: 20817 +.. date: 8493 +.. nonce: O5XyZB +.. section: Library + +Fix inspect.getcallargs() to fail correctly if more than 3 arguments are +missing. Patch by Jeremiah Lowin. + +.. + +.. bpo: 6676 +.. date: 8492 +.. nonce: CJu5On +.. section: Library + +Ensure a meaningful exception is raised when attempting to parse more than +one XML document per pyexpat xmlparser instance. (Original patches by +Hirokazu Yamamoto and Amaury Forgeot d'Arc, with suggested wording by David +Gutteridge) + +.. + +.. bpo: 21117 +.. date: 8491 +.. nonce: hyH7EK +.. section: Library + +Fix inspect.signature to better support functools.partial. Due to the +specifics of functools.partial implementation, positional-or-keyword +arguments passed as keyword arguments become keyword-only. + +.. + +.. bpo: 20334 +.. date: 8490 +.. nonce: 0yFmfQ +.. section: Library + +inspect.Signature and inspect.Parameter are now hashable. Thanks to Antony +Lee for bug reports and suggestions. + +.. + +.. bpo: 15916 +.. date: 8489 +.. nonce: _vhKPn +.. section: Library + +doctest.DocTestSuite returns an empty unittest.TestSuite instead of raising +ValueError if it finds no tests + +.. + +.. bpo: 21209 +.. date: 8488 +.. nonce: wRE7Dn +.. section: Library + +Fix asyncio.tasks.CoroWrapper to workaround a bug in yield-from +implementation in CPythons prior to 3.4.1. + +.. + +.. bpo: 0 +.. date: 8487 +.. nonce: Q1I78Z +.. section: Library + +asyncio: Add gi_{frame,running,code} properties to CoroWrapper (upstream +issue #163). + +.. + +.. bpo: 21311 +.. date: 8486 +.. nonce: JsDF8H +.. section: Library + +Avoid exception in _osx_support with non-standard compiler configurations. +Patch by John Szakmeister. + +.. + +.. bpo: 11571 +.. date: 8485 +.. nonce: RPeGNo +.. section: Library + +Ensure that the turtle window becomes the topmost window when launched on OS +X. + +.. + +.. bpo: 21801 +.. date: 8484 +.. nonce: rzfhYl +.. section: Library + +Validate that __signature__ is None or an instance of Signature. + +.. + +.. bpo: 21923 +.. date: 8483 +.. nonce: hXnoZa +.. section: Library + +Prevent AttributeError in distutils.sysconfig.customize_compiler due to +possible uninitialized _config_vars. + +.. + +.. bpo: 21323 +.. date: 8482 +.. nonce: quiWfl +.. section: Library + +Fix http.server to again handle scripts in CGI subdirectories, broken by the +fix for security issue #19435. Patch by Zach Byrne. + +.. + +.. bpo: 22733 +.. date: 8481 +.. nonce: 21gJBp +.. section: Library + +Fix ffi_prep_args not zero-extending argument values correctly on 64-bit +Windows. + +.. + +.. bpo: 23302 +.. date: 8480 +.. nonce: X2dabK +.. section: Library + +Default to TCP_NODELAY=1 upon establishing an HTTPConnection. Removed use of +hard-coded MSS as it's an optimization that's no longer needed with Nagle +disabled. + +.. + +.. bpo: 20577 +.. date: 8479 +.. nonce: Y71IMj +.. section: IDLE + +Configuration of the max line length for the FormatParagraph extension has +been moved from the General tab of the Idle preferences dialog to the +FormatParagraph tab of the Config Extensions dialog. Patch by Tal Einat. + +.. + +.. bpo: 16893 +.. date: 8478 +.. nonce: JfHAA4 +.. section: IDLE + +Update Idle doc chapter to match current Idle and add new information. + +.. + +.. bpo: 3068 +.. date: 8477 +.. nonce: TYjXTA +.. section: IDLE + +Add Idle extension configuration dialog to Options menu. Changes are written +to HOME/.idlerc/config-extensions.cfg. Original patch by Tal Einat. + +.. + +.. bpo: 16233 +.. date: 8476 +.. nonce: sOadNo +.. section: IDLE + +A module browser (File : Class Browser, Alt+C) requires an editor window +with a filename. When Class Browser is requested otherwise, from a shell, +output window, or 'Untitled' editor, Idle no longer displays an error box. +It now pops up an Open Module box (Alt+M). If a valid name is entered and a +module is opened, a corresponding browser is also opened. + +.. + +.. bpo: 4832 +.. date: 8475 +.. nonce: GRKi9M +.. section: IDLE + +Save As to type Python files automatically adds .py to the name you enter +(even if your system does not display it). Some systems automatically add +.txt when type is Text files. + +.. + +.. bpo: 21986 +.. date: 8474 +.. nonce: 04GUv2 +.. section: IDLE + +Code objects are not normally pickled by the pickle module. To match this, +they are no longer pickled when running under Idle. + +.. + +.. bpo: 17390 +.. date: 8473 +.. nonce: I4vHFh +.. section: IDLE + +Adjust Editor window title; remove 'Python', move version to end. + +.. + +.. bpo: 14105 +.. date: 8472 +.. nonce: -FZwYH +.. section: IDLE + +Idle debugger breakpoints no longer disappear when inserting or deleting +lines. + +.. + +.. bpo: 17172 +.. date: 8471 +.. nonce: R8jkU1 +.. section: IDLE + +Turtledemo can now be run from Idle. Currently, the entry is on the Help +menu, but it may move to Run. Patch by Ramchandra Apt and Lita Cho. + +.. + +.. bpo: 21765 +.. date: 8470 +.. nonce: JyiDbd +.. section: IDLE + +Add support for non-ascii identifiers to HyperParser. + +.. + +.. bpo: 21940 +.. date: 8469 +.. nonce: VlIRz7 +.. section: IDLE + +Add unittest for WidgetRedirector. Initial patch by Saimadhav Heblikar. + +.. + +.. bpo: 18592 +.. date: 8468 +.. nonce: sMG-SZ +.. section: IDLE + +Add unittest for SearchDialogBase. Patch by Phil Webster. + +.. + +.. bpo: 21694 +.. date: 8467 +.. nonce: 1oLmRo +.. section: IDLE + +Add unittest for ParenMatch. Patch by Saimadhav Heblikar. + +.. + +.. bpo: 21686 +.. date: 8466 +.. nonce: TAkFB0 +.. section: IDLE + +add unittest for HyperParser. Original patch by Saimadhav Heblikar. + +.. + +.. bpo: 12387 +.. date: 8465 +.. nonce: XO7Ozk +.. section: IDLE + +Add missing upper(lower)case versions of default Windows key bindings for +Idle so Caps Lock does not disable them. Patch by Roger Serwy. + +.. + +.. bpo: 21695 +.. date: 8464 +.. nonce: g-t0Tm +.. section: IDLE + +Closing a Find-in-files output window while the search is still in progress +no longer closes Idle. + +.. + +.. bpo: 18910 +.. date: 8463 +.. nonce: ke8lMK +.. section: IDLE + +Add unittest for textView. Patch by Phil Webster. + +.. + +.. bpo: 18292 +.. date: 8462 +.. nonce: ks_3wm +.. section: IDLE + +Add unittest for AutoExpand. Patch by Saihadhav Heblikar. + +.. + +.. bpo: 18409 +.. date: 8461 +.. nonce: 7fe-aK +.. section: IDLE + +Add unittest for AutoComplete. Patch by Phil Webster. + +.. + +.. bpo: 21477 +.. date: 8460 +.. nonce: 33NOe0 +.. section: IDLE + +htest.py - Improve framework, complete set of tests. Patches by Saimadhav +Heblikar + +.. + +.. bpo: 18104 +.. date: 8459 +.. nonce: 8Fj9Pf +.. section: IDLE + +Add idlelib/idle_test/htest.py with a few sample tests to begin +consolidating and improving human-validated tests of Idle. Change other +files as needed to work with htest. Running the module as __main__ runs all +tests. + +.. + +.. bpo: 21139 +.. date: 8458 +.. nonce: kqetng +.. section: IDLE + +Change default paragraph width to 72, the PEP 8 recommendation. + +.. + +.. bpo: 21284 +.. date: 8457 +.. nonce: KKJfmv +.. section: IDLE + +Paragraph reformat test passes after user changes reformat width. + +.. + +.. bpo: 17654 +.. date: 8456 +.. nonce: NbzhNS +.. section: IDLE + +Ensure IDLE menus are customized properly on OS X for non-framework builds +and for all variants of Tk. + +.. + +.. bpo: 23180 +.. date: 8455 +.. nonce: cE_89F +.. section: IDLE + +Rename IDLE "Windows" menu item to "Window". Patch by Al Sweigart. + +.. + +.. bpo: 15506 +.. date: 8454 +.. nonce: nh8KlR +.. section: Build + +Use standard PKG_PROG_PKG_CONFIG autoconf macro in the configure script. + +.. + +.. bpo: 22935 +.. date: 8453 +.. nonce: -vY3lc +.. section: Build + +Allow the ssl module to be compiled if openssl doesn't support SSL 3. + +.. + +.. bpo: 22592 +.. date: 8452 +.. nonce: O_IE9W +.. section: Build + +Drop support of the Borland C compiler to build Python. The distutils module +still supports it to build extensions. + +.. + +.. bpo: 22591 +.. date: 8451 +.. nonce: wwBlG8 +.. section: Build + +Drop support of MS-DOS, especially of the DJGPP compiler (MS-DOS port of +GCC). + +.. + +.. bpo: 16537 +.. date: 8450 +.. nonce: llFo71 +.. section: Build + +Check whether self.extensions is empty in setup.py. Patch by Jonathan +Hosmer. + +.. + +.. bpo: 22359 +.. date: 8449 +.. nonce: YYFOFG +.. section: Build + +Remove incorrect uses of recursive make. Patch by Jonas Wagner. + +.. + +.. bpo: 21958 +.. date: 8448 +.. nonce: 3rq4qR +.. section: Build + +Define HAVE_ROUND when building with Visual Studio 2013 and above. Patch by +Zachary Turner. + +.. + +.. bpo: 18093 +.. date: 8447 +.. nonce: gnZieo +.. section: Build + +the programs that embed the CPython runtime are now in a separate "Programs" +directory, rather than being kept in the Modules directory. + +.. + +.. bpo: 15759 +.. date: 8446 +.. nonce: iGLR6O +.. section: Build + +"make suspicious", "make linkcheck" and "make doctest" in Doc/ now display +special message when and only when there are failures. + +.. + +.. bpo: 21141 +.. date: 8445 +.. nonce: 669LzK +.. section: Build + +The Windows build process no longer attempts to find Perl, instead relying +on OpenSSL source being configured and ready to build. The +``PCbuild\build_ssl.py`` script has been re-written and re-named to +``PCbuild\prepare_ssl.py``, and takes care of configuring OpenSSL source for +both 32 and 64 bit platforms. OpenSSL sources obtained from svn.python.org +will always be pre-configured and ready to build. + +.. + +.. bpo: 21037 +.. date: 8444 +.. nonce: v1rZzo +.. section: Build + +Add a build option to enable AddressSanitizer support. + +.. + +.. bpo: 19962 +.. date: 8443 +.. nonce: HDlwsE +.. section: Build + +The Windows build process now creates "python.bat" in the root of the source +tree, which passes all arguments through to the most recently built +interpreter. + +.. + +.. bpo: 21285 +.. date: 8442 +.. nonce: cU9p2E +.. section: Build + +Refactor and fix curses configure check to always search in a ncursesw +directory. + +.. + +.. bpo: 15234 +.. date: 8441 +.. nonce: vlM720 +.. section: Build + +For BerkelyDB and Sqlite, only add the found library and include directories +if they aren't already being searched. This avoids an explicit runtime +library dependency. + +.. + +.. bpo: 17861 +.. date: 8440 +.. nonce: jCi44U +.. section: Build + +Tools/scripts/generate_opcode_h.py automatically regenerates +Include/opcode.h from Lib/opcode.py if the latter gets any change. + +.. + +.. bpo: 20644 +.. date: 8439 +.. nonce: aV0zq7 +.. section: Build + +OS X installer build support for documentation build changes in 3.4.1: +assume externally supplied sphinx-build is available in /usr/bin. + +.. + +.. bpo: 20022 +.. date: 8438 +.. nonce: EqSCTW +.. section: Build + +Eliminate use of deprecated bundlebuilder in OS X builds. + +.. + +.. bpo: 15968 +.. date: 8437 +.. nonce: vxUxHK +.. section: Build + +Incorporated Tcl, Tk, and Tix builds into the Windows build solution. + +.. + +.. bpo: 17095 +.. date: 8436 +.. nonce: -XEBIU +.. section: Build + +Fix Modules/Setup *shared* support. + +.. + +.. bpo: 21811 +.. date: 8435 +.. nonce: 3_Xyr- +.. section: Build + +Anticipated fixes to support OS X versions > 10.9. + +.. + +.. bpo: 21166 +.. date: 8434 +.. nonce: KAl7aO +.. section: Build + +Prevent possible segfaults and other random failures of python --generate- +posix-vars in pybuilddir.txt build target. + +.. + +.. bpo: 18096 +.. date: 8433 +.. nonce: ELyAUJ +.. section: Build + +Fix library order returned by python-config. + +.. + +.. bpo: 17219 +.. date: 8432 +.. nonce: q8ueQ0 +.. section: Build + +Add library build dir for Python extension cross-builds. + +.. + +.. bpo: 22919 +.. date: 8431 +.. nonce: 1XThL9 +.. section: Build + +Windows build updated to support VC 14.0 (Visual Studio 2015), which will be +used for the official release. + +.. + +.. bpo: 21236 +.. date: 8430 +.. nonce: 84LXxj +.. section: Build + +Build _msi.pyd with cabinet.lib instead of fci.lib + +.. + +.. bpo: 17128 +.. date: 8429 +.. nonce: U2biLA +.. section: Build + +Use private version of OpenSSL for OS X 10.5+ installer. + +.. + +.. bpo: 14203 +.. date: 8428 +.. nonce: 3hv0TX +.. section: C API + +Remove obsolete support for view==NULL in PyBuffer_FillInfo(), +bytearray_getbuffer(), bytesiobuf_getbuffer() and array_buffer_getbuf(). All +functions now raise BufferError in that case. + +.. + +.. bpo: 22445 +.. date: 8427 +.. nonce: s0AOAS +.. section: C API + +PyBuffer_IsContiguous() now implements precise contiguity tests, compatible +with NumPy's NPY_RELAXED_STRIDES_CHECKING compilation flag. Previously the +function reported false negatives for corner cases. + +.. + +.. bpo: 22079 +.. date: 8426 +.. nonce: zhs2qM +.. section: C API + +PyType_Ready() now checks that statically allocated type has no dynamically +allocated bases. + +.. + +.. bpo: 22453 +.. date: 8425 +.. nonce: XoO4ns +.. section: C API + +Removed non-documented macro PyObject_REPR(). + +.. + +.. bpo: 18395 +.. date: 8424 +.. nonce: YC9B06 +.. section: C API + +Rename ``_Py_char2wchar()`` to :c:func:`Py_DecodeLocale`, rename +``_Py_wchar2char()`` to :c:func:`Py_EncodeLocale`, and document these +functions. + +.. + +.. bpo: 21233 +.. date: 8423 +.. nonce: 98hZAt +.. section: C API + +Add new C functions: PyMem_RawCalloc(), PyMem_Calloc(), PyObject_Calloc(), +_PyObject_GC_Calloc(). bytes(int) is now using ``calloc()`` instead of +``malloc()`` for large objects which is faster and use less memory. + +.. + +.. bpo: 20942 +.. date: 8422 +.. nonce: qHLJ5- +.. section: C API + +PyImport_ImportFrozenModuleObject() no longer sets __file__ to match what +importlib does; this affects _frozen_importlib as well as any module loaded +using imp.init_frozen(). + +.. + +.. bpo: 19548 +.. date: 8421 +.. nonce: yOX8sS +.. section: Documentation + +Update the codecs module documentation to better cover the distinction +between text encodings and other codecs, together with other clarifications. +Patch by Martin Panter. + +.. + +.. bpo: 22394 +.. date: 8420 +.. nonce: 6bJywY +.. section: Documentation + +Doc/Makefile now supports ``make venv PYTHON=../python`` to create a venv +for generating the documentation, e.g., ``make html +PYTHON=venv/bin/python3``. + +.. + +.. bpo: 21514 +.. date: 8419 +.. nonce: 1H16T6 +.. section: Documentation + +The documentation of the json module now refers to new JSON RFC 7159 instead +of obsoleted RFC 4627. + +.. + +.. bpo: 21777 +.. date: 8418 +.. nonce: dtQCWV +.. section: Documentation + +The binary sequence methods on bytes and bytearray are now documented +explicitly, rather than assuming users will be able to derive the expected +behaviour from the behaviour of the corresponding str methods. + +.. + +.. bpo: 6916 +.. date: 8417 +.. nonce: 4sm3nE +.. section: Documentation + +undocument deprecated asynchat.fifo class. + +.. + +.. bpo: 17386 +.. date: 8416 +.. nonce: ivaGLb +.. section: Documentation + +Expanded functionality of the ``Doc/make.bat`` script to make it much more +comparable to ``Doc/Makefile``. + +.. + +.. bpo: 21312 +.. date: 8415 +.. nonce: 6IqcV4 +.. section: Documentation + +Update the thread_foobar.h template file to include newer threading APIs. +Patch by Jack McCracken. + +.. + +.. bpo: 21043 +.. date: 8414 +.. nonce: oEOC8O +.. section: Documentation + +Remove the recommendation for specific CA organizations and to mention the +ability to load the OS certificates. + +.. + +.. bpo: 20765 +.. date: 8413 +.. nonce: Rv3GgV +.. section: Documentation + +Add missing documentation for PurePath.with_name() and +PurePath.with_suffix(). + +.. + +.. bpo: 19407 +.. date: 8412 +.. nonce: mRyNnG +.. section: Documentation + +New package installation and distribution guides based on the Python +Packaging Authority tools. Existing guides have been retained as legacy +links from the distutils docs, as they still contain some required reference +material for tool developers that isn't recorded anywhere else. + +.. + +.. bpo: 19697 +.. date: 8411 +.. nonce: 2jMQBP +.. section: Documentation + +Document cases where __main__.__spec__ is None. + +.. + +.. bpo: 18982 +.. date: 8410 +.. nonce: TynSM6 +.. section: Tests + +Add tests for CLI of the calendar module. + +.. + +.. bpo: 19548 +.. date: 8409 +.. nonce: 25Kxq_ +.. section: Tests + +Added some additional checks to test_codecs to ensure that statements in the +updated documentation remain accurate. Patch by Martin Panter. + +.. + +.. bpo: 22838 +.. date: 8408 +.. nonce: VZBtZg +.. section: Tests + +All test_re tests now work with unittest test discovery. + +.. + +.. bpo: 22173 +.. date: 8407 +.. nonce: dxIIVx +.. section: Tests + +Update lib2to3 tests to use unittest test discovery. + +.. + +.. bpo: 16000 +.. date: 8406 +.. nonce: Y7O6TP +.. section: Tests + +Convert test_curses to use unittest. + +.. + +.. bpo: 21456 +.. date: 8405 +.. nonce: Axsw43 +.. section: Tests + +Skip two tests in test_urllib2net.py if _ssl module not present. Patch by +Remi Pointel. + +.. + +.. bpo: 20746 +.. date: 8404 +.. nonce: N2pzAY +.. section: Tests + +Fix test_pdb to run in refleak mode (-R). Patch by Xavier de Gaye. + +.. + +.. bpo: 22060 +.. date: 8403 +.. nonce: TduJNO +.. section: Tests + +test_ctypes has been somewhat cleaned up and simplified; it now uses +unittest test discovery to find its tests. + +.. + +.. bpo: 22104 +.. date: 8402 +.. nonce: -YYDup +.. section: Tests + +regrtest.py no longer holds a reference to the suite of tests loaded from +test modules that don't define test_main(). + +.. + +.. bpo: 22111 +.. date: 8401 +.. nonce: 0XlFAU +.. section: Tests + +Assorted cleanups in test_imaplib. Patch by Milan Oberkirch. + +.. + +.. bpo: 22002 +.. date: 8400 +.. nonce: jpiaA2 +.. section: Tests + +Added ``load_package_tests`` function to test.support and used it to +implement/augment test discovery in test_asyncio, test_email, +test_importlib, test_json, and test_tools. + +.. + +.. bpo: 21976 +.. date: 8399 +.. nonce: Slq6se +.. section: Tests + +Fix test_ssl to accept LibreSSL version strings. Thanks to William Orr. + +.. + +.. bpo: 21918 +.. date: 8398 +.. nonce: QTFFSj +.. section: Tests + +Converted test_tools from a module to a package containing separate test +files for each tested script. + +.. + +.. bpo: 9554 +.. date: 8397 +.. nonce: VsP0Ve +.. section: Tests + +Use modern unittest features in test_argparse. Initial patch by Denver +Coneybeare and Radu Voicilas. + +.. + +.. bpo: 20155 +.. date: 8396 +.. nonce: nphzS3 +.. section: Tests + +Changed HTTP method names in failing tests in test_httpservers so that +packet filtering software (specifically Windows Base Filtering Engine) does +not interfere with the transaction semantics expected by the tests. + +.. + +.. bpo: 19493 +.. date: 8395 +.. nonce: SwbzLQ +.. section: Tests + +Refactored the ctypes test package to skip tests explicitly rather than +silently. + +.. + +.. bpo: 18492 +.. date: 8394 +.. nonce: ylPRU7 +.. section: Tests + +All resources are now allowed when tests are not run by regrtest.py. + +.. + +.. bpo: 21634 +.. date: 8393 +.. nonce: Eng06F +.. section: Tests + +Fix pystone micro-benchmark: use floor division instead of true division to +benchmark integers instead of floating point numbers. Set pystone version to +1.2. Patch written by Lennart Regebro. + +.. + +.. bpo: 21605 +.. date: 8392 +.. nonce: qsLV8d +.. section: Tests + +Added tests for Tkinter images. + +.. + +.. bpo: 21493 +.. date: 8391 +.. nonce: NqhRsy +.. section: Tests + +Added test for ntpath.expanduser(). Original patch by Claudiu Popa. + +.. + +.. bpo: 19925 +.. date: 8390 +.. nonce: dhMx08 +.. section: Tests + +Added tests for the spwd module. Original patch by Vajrasky Kok. + +.. + +.. bpo: 21522 +.. date: 8389 +.. nonce: b-VwFW +.. section: Tests + +Added Tkinter tests for Listbox.itemconfigure(), +PanedWindow.paneconfigure(), and Menu.entryconfigure(). + +.. + +.. bpo: 17756 +.. date: 8388 +.. nonce: LLfbfU +.. section: Tests + +Fix test_code test when run from the installed location. + +.. + +.. bpo: 17752 +.. date: 8387 +.. nonce: P8iG44 +.. section: Tests + +Fix distutils tests when run from the installed location. + +.. + +.. bpo: 18604 +.. date: 8386 +.. nonce: Q00Xrj +.. section: Tests + +Consolidated checks for GUI availability. All platforms now at least check +whether Tk can be instantiated when the GUI resource is requested. + +.. + +.. bpo: 21275 +.. date: 8385 +.. nonce: lI5FkX +.. section: Tests + +Fix a socket test on KFreeBSD. + +.. + +.. bpo: 21223 +.. date: 8384 +.. nonce: lMY6ka +.. section: Tests + +Pass test_site/test_startup_imports when some of the extensions are built as +builtins. + +.. + +.. bpo: 20635 +.. date: 8383 +.. nonce: mzWmoS +.. section: Tests + +Added tests for Tk geometry managers. + +.. + +.. bpo: 0 +.. date: 8382 +.. nonce: E5XNqr +.. section: Tests + +Add test case for freeze. + +.. + +.. bpo: 20743 +.. date: 8381 +.. nonce: hxZQUf +.. section: Tests + +Fix a reference leak in test_tcl. + +.. + +.. bpo: 21097 +.. date: 8380 +.. nonce: gsUesm +.. section: Tests + +Move test_namespace_pkgs into test_importlib. + +.. + +.. bpo: 21503 +.. date: 8379 +.. nonce: H9TPCg +.. section: Tests + +Use test_both() consistently in test_importlib. + +.. + +.. bpo: 20939 +.. date: 8378 +.. nonce: x3KQ35 +.. section: Tests + +Avoid various network test failures due to new redirect of +http://www.python.org/ to https://www.python.org: use http://www.example.com +instead. + +.. + +.. bpo: 20668 +.. date: 8377 +.. nonce: IWjOSC +.. section: Tests + +asyncio tests no longer rely on tests.txt file. (Patch by Vajrasky Kok) + +.. + +.. bpo: 21093 +.. date: 8376 +.. nonce: CcpRim +.. section: Tests + +Prevent failures of ctypes test_macholib on OS X if a copy of libz exists in +$HOME/lib or /usr/local/lib. + +.. + +.. bpo: 22770 +.. date: 8375 +.. nonce: FxAh91 +.. section: Tests + +Prevent some Tk segfaults on OS X when running gui tests. + +.. + +.. bpo: 23211 +.. date: 8374 +.. nonce: Bc-QfJ +.. section: Tests + +Workaround test_logging failure on some OS X 10.6 systems. + +.. + +.. bpo: 23345 +.. date: 8373 +.. nonce: HIGBKx +.. section: Tests + +Prevent test_ssl failures with large OpenSSL patch level values (like +0.9.8zc). + +.. + +.. bpo: 22314 +.. date: 8372 +.. nonce: ws6xsH +.. section: Tools/Demos + +pydoc now works when the LINES environment variable is set. + +.. + +.. bpo: 22615 +.. date: 8371 +.. nonce: My3DWN +.. section: Tools/Demos + +Argument Clinic now supports the "type" argument for the int converter. +This permits using the int converter with enums and typedefs. + +.. + +.. bpo: 20076 +.. date: 8370 +.. nonce: ZNuBrC +.. section: Tools/Demos + +The makelocalealias.py script no longer ignores UTF-8 mapping. + +.. + +.. bpo: 20079 +.. date: 8369 +.. nonce: ogPXcK +.. section: Tools/Demos + +The makelocalealias.py script now can parse the SUPPORTED file from glibc +sources and supports command line options for source paths. + +.. + +.. bpo: 22201 +.. date: 8368 +.. nonce: k1Awbh +.. section: Tools/Demos + +Command-line interface of the zipfile module now correctly extracts ZIP +files with directory entries. Patch by Ryan Wilson. + +.. + +.. bpo: 22120 +.. date: 8367 +.. nonce: KmBUj- +.. section: Tools/Demos + +For functions using an unsigned integer return converter, Argument Clinic +now generates a cast to that type for the comparison to -1 in the generated +code. (This suppresses a compilation warning.) + +.. + +.. bpo: 18974 +.. date: 8366 +.. nonce: I3DdAo +.. section: Tools/Demos + +Tools/scripts/diff.py now uses argparse instead of optparse. + +.. + +.. bpo: 21906 +.. date: 8365 +.. nonce: ZsKy9v +.. section: Tools/Demos + +Make Tools/scripts/md5sum.py work in Python 3. Patch by Zachary Ware. + +.. + +.. bpo: 21629 +.. date: 8364 +.. nonce: 9kZmQl +.. section: Tools/Demos + +Fix Argument Clinic's "--converters" feature. + +.. + +.. bpo: 0 +.. date: 8363 +.. nonce: _-ge-g +.. section: Tools/Demos + +Add support for ``yield from`` to 2to3. + +.. + +.. bpo: 0 +.. date: 8362 +.. nonce: dpFbyZ +.. section: Tools/Demos + +Add support for the PEP 465 matrix multiplication operator to 2to3. + +.. + +.. bpo: 16047 +.. date: 8361 +.. nonce: IsgTzm +.. section: Tools/Demos + +Fix module exception list and __file__ handling in freeze. Patch by Meador +Inge. + +.. + +.. bpo: 11824 +.. date: 8360 +.. nonce: OBWc3T +.. section: Tools/Demos + +Consider ABI tags in freeze. Patch by Meador Inge. + +.. + +.. bpo: 20535 +.. date: 8359 +.. nonce: 0qkvZZ +.. section: Tools/Demos + +PYTHONWARNING no longer affects the run_tests.py script. Patch by Arfrever +Frehtes Taifersar Arahesis. + +.. + +.. bpo: 23260 +.. date: 8358 +.. nonce: aZ5VLH +.. section: Windows + +Update Windows installer + +.. + +.. bpo: 0 +.. date: 8357 +.. nonce: _aEUNt +.. section: Windows + +The bundled version of Tcl/Tk has been updated to 8.6.3. The most visible +result of this change is the addition of new native file dialogs when +running on Windows Vista or newer. See Tcl/Tk's TIP 432 for more +information. Also, this version of Tcl/Tk includes support for Windows 10. + +.. + +.. bpo: 17896 +.. date: 8356 +.. nonce: o79rHM +.. section: Windows + +The Windows build scripts now expect external library sources to be in +``PCbuild\..\externals`` rather than ``PCbuild\..\..``. + +.. + +.. bpo: 17717 +.. date: 8355 +.. nonce: y1zoye +.. section: Windows + +The Windows build scripts now use a copy of NASM pulled from svn.python.org +to build OpenSSL. + +.. + +.. bpo: 21907 +.. date: 8354 +.. nonce: jm1smN +.. section: Windows + +Improved the batch scripts provided for building Python. + +.. + +.. bpo: 22644 +.. date: 8353 +.. nonce: gosBki +.. section: Windows + +The bundled version of OpenSSL has been updated to 1.0.1j. + +.. + +.. bpo: 10747 +.. date: 8352 +.. nonce: LTWhLn +.. section: Windows + +Use versioned labels in the Windows start menu. Patch by Olive Kilburn. + +.. + +.. bpo: 22980 +.. date: 8351 +.. nonce: -UypE5 +.. section: Windows + +.pyd files with a version and platform tag (for example, ".cp35-win32.pyd") +will now be loaded in preference to those without tags. diff --git a/Misc/NEWS.d/3.5.0a2.rst b/Misc/NEWS.d/3.5.0a2.rst new file mode 100644 index 00000000000..80bf9e8e556 --- /dev/null +++ b/Misc/NEWS.d/3.5.0a2.rst @@ -0,0 +1,406 @@ +.. bpo: 23571 +.. date: 8990 +.. nonce: GTkAkq +.. release date: 2015-03-09 +.. section: Core and Builtins + +PyObject_Call() and PyCFunction_Call() now raise a SystemError if a function +returns a result and raises an exception. The SystemError is chained to the +previous exception. + +.. + +.. bpo: 22524 +.. date: 8989 +.. nonce: Ks6_2x +.. section: Library + +New os.scandir() function, part of the PEP 471: "os.scandir() function -- a +better and faster directory iterator". Patch written by Ben Hoyt. + +.. + +.. bpo: 23103 +.. date: 8988 +.. nonce: I3RLIV +.. section: Library + +Reduced the memory consumption of IPv4Address and IPv6Address. + +.. + +.. bpo: 21793 +.. date: 8987 +.. nonce: GQtYMM +.. section: Library + +BaseHTTPRequestHandler again logs response code as numeric, not as +stringified enum. Patch by Demian Brecht. + +.. + +.. bpo: 23476 +.. date: 8986 +.. nonce: 82QV9I +.. section: Library + +In the ssl module, enable OpenSSL's X509_V_FLAG_TRUSTED_FIRST flag on +certificate stores when it is available. + +.. + +.. bpo: 23576 +.. date: 8985 +.. nonce: 98F-PP +.. section: Library + +Avoid stalling in SSL reads when EOF has been reached in the SSL layer but +the underlying connection hasn't been closed. + +.. + +.. bpo: 23504 +.. date: 8984 +.. nonce: o31h5I +.. section: Library + +Added an __all__ to the types module. + +.. + +.. bpo: 23563 +.. date: 8983 +.. nonce: iQB-ba +.. section: Library + +Optimized utility functions in urllib.parse. + +.. + +.. bpo: 7830 +.. date: 8982 +.. nonce: irvPdC +.. section: Library + +Flatten nested functools.partial. + +.. + +.. bpo: 20204 +.. date: 8981 +.. nonce: DorA4b +.. section: Library + +Added the __module__ attribute to _tkinter classes. + +.. + +.. bpo: 19980 +.. date: 8980 +.. nonce: whwzL_ +.. section: Library + +Improved help() for non-recognized strings. help('') now shows the help on +str. help('help') now shows the help on help(). Original patch by Mark +Lawrence. + +.. + +.. bpo: 23521 +.. date: 8979 +.. nonce: HvwFfd +.. section: Library + +Corrected pure python implementation of timedelta division. + +Eliminated OverflowError from ``timedelta * float`` for some floats; +Corrected rounding in timedlta true division. + +.. + +.. bpo: 21619 +.. date: 8978 +.. nonce: uL0SZh +.. section: Library + +Popen objects no longer leave a zombie after exit in the with statement if +the pipe was broken. Patch by Martin Panter. + +.. + +.. bpo: 22936 +.. date: 8977 +.. nonce: JrhGYd +.. section: Library + +Make it possible to show local variables in tracebacks for both the +traceback module and unittest. + +.. + +.. bpo: 15955 +.. date: 8976 +.. nonce: _8nYPy +.. section: Library + +Add an option to limit the output size in bz2.decompress(). Patch by +Nikolaus Rath. + +.. + +.. bpo: 6639 +.. date: 8975 +.. nonce: rmjUmG +.. section: Library + +Module-level turtle functions no longer raise TclError after closing the +window. + +.. + +.. bpo: 814253 +.. date: 8974 +.. nonce: icZb-I +.. section: Library + +Group references and conditional group references now work in lookbehind +assertions in regular expressions. (See also: bpo-9179) + +.. + +.. bpo: 23215 +.. date: 8973 +.. nonce: VHVSVX +.. section: Library + +Multibyte codecs with custom error handlers that ignores errors consumed too +much memory and raised SystemError or MemoryError. Original patch by Aleksi +Torhamo. + +.. + +.. bpo: 5700 +.. date: 8972 +.. nonce: iA5yzL +.. section: Library + +io.FileIO() called flush() after closing the file. flush() was not called in +close() if closefd=False. + +.. + +.. bpo: 23374 +.. date: 8971 +.. nonce: 8A9LuZ +.. section: Library + +Fixed pydoc failure with non-ASCII files when stdout encoding differs from +file system encoding (e.g. on Mac OS). + +.. + +.. bpo: 23481 +.. date: 8970 +.. nonce: ZWwliG +.. section: Library + +Remove RC4 from the SSL module's default cipher list. + +.. + +.. bpo: 21548 +.. date: 8969 +.. nonce: CmO_Yh +.. section: Library + +Fix pydoc.synopsis() and pydoc.apropos() on modules with empty docstrings. + +.. + +.. bpo: 22885 +.. date: 8968 +.. nonce: p8FnYk +.. section: Library + +Fixed arbitrary code execution vulnerability in the dbm.dumb module. +Original patch by Claudiu Popa. + +.. + +.. bpo: 23239 +.. date: 8967 +.. nonce: PGUq7T +.. section: Library + +ssl.match_hostname() now supports matching of IP addresses. + +.. + +.. bpo: 23146 +.. date: 8966 +.. nonce: PW-O3u +.. section: Library + +Fix mishandling of absolute Windows paths with forward slashes in pathlib. + +.. + +.. bpo: 23096 +.. date: 8965 +.. nonce: Ftrmf3 +.. section: Library + +Pickle representation of floats with protocol 0 now is the same for both +Python and C implementations. + +.. + +.. bpo: 19105 +.. date: 8964 +.. nonce: ZK07Ff +.. section: Library + +pprint now more efficiently uses free space at the right. + +.. + +.. bpo: 14910 +.. date: 8963 +.. nonce: zueIhP +.. section: Library + +Add allow_abbrev parameter to argparse.ArgumentParser. Patch by Jonathan +Paugh, Steven Bethard, paul j3 and Daniel Eriksson. + +.. + +.. bpo: 21717 +.. date: 8962 +.. nonce: Knut81 +.. section: Library + +tarfile.open() now supports 'x' (exclusive creation) mode. + +.. + +.. bpo: 23344 +.. date: 8961 +.. nonce: ieu8C1 +.. section: Library + +marshal.dumps() is now 20-25% faster on average. + +.. + +.. bpo: 20416 +.. date: 8960 +.. nonce: cwEgkL +.. section: Library + +marshal.dumps() with protocols 3 and 4 is now 40-50% faster on average. + +.. + +.. bpo: 23421 +.. date: 8959 +.. nonce: eckzoV +.. section: Library + +Fixed compression in tarfile CLI. Patch by wdv4758h. + +.. + +.. bpo: 23367 +.. date: 8958 +.. nonce: kHnFiz +.. section: Library + +Fix possible overflows in the unicodedata module. + +.. + +.. bpo: 23361 +.. date: 8957 +.. nonce: I_w0-z +.. section: Library + +Fix possible overflow in Windows subprocess creation code. + +.. + +.. bpo: 0 +.. date: 8956 +.. nonce: sfmjTs +.. section: Library + +logging.handlers.QueueListener now takes a respect_handler_level keyword +argument which, if set to True, will pass messages to handlers taking +handler levels into account. + +.. + +.. bpo: 19705 +.. date: 8955 +.. nonce: WLzTRV +.. section: Library + +turtledemo now has a visual sorting algorithm demo. Original patch from +Jason Yeo. + +.. + +.. bpo: 23801 +.. date: 8954 +.. nonce: jyJK3z +.. section: Library + +Fix issue where cgi.FieldStorage did not always ignore the entire preamble +to a multipart body. + +.. + +.. bpo: 23445 +.. date: 8953 +.. nonce: 7fmkYO +.. section: Build + +pydebug builds now use "gcc -Og" where possible, to make the resulting +executable faster. + +.. + +.. bpo: 23686 +.. date: 8952 +.. nonce: B7jDXY +.. section: Build + +Update OS X 10.5 installer build to use OpenSSL 1.0.2a. + +.. + +.. bpo: 20204 +.. date: 8951 +.. nonce: M_jcNK +.. section: C API + +Deprecation warning is now raised for builtin types without the __module__ +attribute. + +.. + +.. bpo: 23465 +.. date: 8950 +.. nonce: qBauCy +.. section: Windows + +Implement PEP 486 - Make the Python Launcher aware of virtual environments. +Patch by Paul Moore. + +.. + +.. bpo: 23437 +.. date: 8949 +.. nonce: ro9X8r +.. section: Windows + +Make user scripts directory versioned on Windows. Patch by Paul Moore. diff --git a/Misc/NEWS.d/3.5.0a3.rst b/Misc/NEWS.d/3.5.0a3.rst new file mode 100644 index 00000000000..2c62799dab6 --- /dev/null +++ b/Misc/NEWS.d/3.5.0a3.rst @@ -0,0 +1,518 @@ +.. bpo: 23573 +.. date: 9042 +.. nonce: ZpM4D- +.. release date: 2015-03-28 +.. section: Core and Builtins + +Increased performance of string search operations (str.find, str.index, +str.count, the in operator, str.split, str.partition) with arguments of +different kinds (UCS1, UCS2, UCS4). + +.. + +.. bpo: 23753 +.. date: 9041 +.. nonce: CREjLC +.. section: Core and Builtins + +Python doesn't support anymore platforms without stat() or fstat(), these +functions are always required. + +.. + +.. bpo: 23681 +.. date: 9040 +.. nonce: kh02TF +.. section: Core and Builtins + +The -b option now affects comparisons of bytes with int. + +.. + +.. bpo: 23632 +.. date: 9039 +.. nonce: UVdIZY +.. section: Core and Builtins + +Memoryviews now allow tuple indexing (including for multi-dimensional +memoryviews). + +.. + +.. bpo: 23192 +.. date: 9038 +.. nonce: QKqdow +.. section: Core and Builtins + +Fixed generator lambdas. Patch by Bruno Cauet. + +.. + +.. bpo: 23629 +.. date: 9037 +.. nonce: r9Mt2C +.. section: Core and Builtins + +Fix the default __sizeof__ implementation for variable-sized objects. + +.. + +.. bpo: 14260 +.. date: 9036 +.. nonce: b5M04V +.. section: Library + +The groupindex attribute of regular expression pattern object now is non- +modifiable mapping. + +.. + +.. bpo: 23792 +.. date: 9035 +.. nonce: Kfm9-f +.. section: Library + +Ignore KeyboardInterrupt when the pydoc pager is active. This mimics the +behavior of the standard unix pagers, and prevents pipepager from shutting +down while the pager itself is still running. + +.. + +.. bpo: 23775 +.. date: 9034 +.. nonce: xKGrSQ +.. section: Library + +pprint() of OrderedDict now outputs the same representation as repr(). + +.. + +.. bpo: 23765 +.. date: 9033 +.. nonce: 2ta_C4 +.. section: Library + +Removed IsBadStringPtr calls in ctypes + +.. + +.. bpo: 22364 +.. date: 9032 +.. nonce: ejtoKl +.. section: Library + +Improved some re error messages using regex for hints. + +.. + +.. bpo: 23742 +.. date: 9031 +.. nonce: _EkAIa +.. section: Library + +ntpath.expandvars() no longer loses unbalanced single quotes. + +.. + +.. bpo: 21717 +.. date: 9030 +.. nonce: pKndpx +.. section: Library + +The zipfile.ZipFile.open function now supports 'x' (exclusive creation) +mode. + +.. + +.. bpo: 21802 +.. date: 9029 +.. nonce: ygSM2A +.. section: Library + +The reader in BufferedRWPair now is closed even when closing writer failed +in BufferedRWPair.close(). + +.. + +.. bpo: 23622 +.. date: 9028 +.. nonce: 9-ZRqj +.. section: Library + +Unknown escapes in regular expressions that consist of ``'\'`` and ASCII +letter now raise a deprecation warning and will be forbidden in Python 3.6. + +.. + +.. bpo: 23671 +.. date: 9027 +.. nonce: zWPm-a +.. section: Library + +string.Template now allows specifying the "self" parameter as a keyword +argument. string.Formatter now allows specifying the "self" and the +"format_string" parameters as keyword arguments. + +.. + +.. bpo: 23502 +.. date: 9026 +.. nonce: AH20IQ +.. section: Library + +The pprint module now supports mapping proxies. + +.. + +.. bpo: 17530 +.. date: 9025 +.. nonce: PUp8rL +.. section: Library + +pprint now wraps long bytes objects and bytearrays. + +.. + +.. bpo: 22687 +.. date: 9024 +.. nonce: zEJPd9 +.. section: Library + +Fixed some corner cases in breaking words in tetxtwrap. Got rid of quadratic +complexity in breaking long words. + +.. + +.. bpo: 4727 +.. date: 9023 +.. nonce: iDQSpi +.. section: Library + +The copy module now uses pickle protocol 4 (PEP 3154) and supports copying +of instances of classes whose __new__ method takes keyword-only arguments. + +.. + +.. bpo: 23491 +.. date: 9022 +.. nonce: P_WKrt +.. section: Library + +Added a zipapp module to support creating executable zip file archives of +Python code. Registered ".pyz" and ".pyzw" extensions on Windows for these +archives (PEP 441). + +.. + +.. bpo: 23657 +.. date: 9021 +.. nonce: y1OaV- +.. section: Library + +Avoid explicit checks for str in zipapp, adding support for pathlib.Path +objects as arguments. + +.. + +.. bpo: 23688 +.. date: 9020 +.. nonce: d6LVy3 +.. section: Library + +Added support of arbitrary bytes-like objects and avoided unnecessary +copying of memoryview in gzip.GzipFile.write(). Original patch by Wolfgang +Maier. + +.. + +.. bpo: 23252 +.. date: 9019 +.. nonce: Goi18g +.. section: Library + +Added support for writing ZIP files to unseekable streams. + +.. + +.. bpo: 23647 +.. date: 9018 +.. nonce: pX2qrx +.. section: Library + +Increase impalib's MAXLINE to accommodate modern mailbox sizes. + +.. + +.. bpo: 23539 +.. date: 9017 +.. nonce: 5BVUim +.. section: Library + +If body is None, http.client.HTTPConnection.request now sets Content-Length +to 0 for PUT, POST, and PATCH headers to avoid 411 errors from some web +servers. + +.. + +.. bpo: 22351 +.. date: 9016 +.. nonce: agB8Y3 +.. section: Library + +The nntplib.NNTP constructor no longer leaves the connection and socket open +until the garbage collector cleans them up. Patch by Martin Panter. + +.. + +.. bpo: 23704 +.. date: 9015 +.. nonce: LTyyxL +.. section: Library + +collections.deque() objects now support methods for index(), insert(), and +copy(). This allows deques to be registered as a MutableSequence and it +improves their substitutability for lists. + +.. + +.. bpo: 23715 +.. date: 9014 +.. nonce: Yap3tU +.. section: Library + +:func:`signal.sigwaitinfo` and :func:`signal.sigtimedwait` are now retried +when interrupted by a signal not in the *sigset* parameter, if the signal +handler does not raise an exception. signal.sigtimedwait() recomputes the +timeout with a monotonic clock when it is retried. + +.. + +.. bpo: 23001 +.. date: 9013 +.. nonce: YSFnam +.. section: Library + +Few functions in modules mmap, ossaudiodev, socket, ssl, and codecs, that +accepted only read-only bytes-like object now accept writable bytes-like +object too. + +.. + +.. bpo: 23646 +.. date: 9012 +.. nonce: Tljc1S +.. section: Library + +If time.sleep() is interrupted by a signal, the sleep is now retried with +the recomputed delay, except if the signal handler raises an exception (PEP +475). + +.. + +.. bpo: 23136 +.. date: 9011 +.. nonce: 1bnpnb +.. section: Library + +_strptime now uniformly handles all days in week 0, including Dec 30 of +previous year. Based on patch by Jim Carroll. + +.. + +.. bpo: 23700 +.. date: 9010 +.. nonce: VfnWwi +.. section: Library + +Iterator of NamedTemporaryFile now keeps a reference to NamedTemporaryFile +instance. Patch by Bohuslav Kabrda. + +.. + +.. bpo: 22903 +.. date: 9009 +.. nonce: 2GjTHY +.. section: Library + +The fake test case created by unittest.loader when it fails importing a test +module is now picklable. + +.. + +.. bpo: 22181 +.. date: 9008 +.. nonce: 7mnxea +.. section: Library + +On Linux, os.urandom() now uses the new getrandom() syscall if available, +syscall introduced in the Linux kernel 3.17. It is more reliable and more +secure, because it avoids the need of a file descriptor and waits until the +kernel has enough entropy. + +.. + +.. bpo: 2211 +.. date: 9007 +.. nonce: 17Iz5U +.. section: Library + +Updated the implementation of the http.cookies.Morsel class. Setting +attributes key, value and coded_value directly now is deprecated. update() +and setdefault() now transform and check keys. Comparing for equality now +takes into account attributes key, value and coded_value. copy() now returns +a Morsel, not a dict. repr() now contains all attributes. Optimized +checking keys and quoting values. Added new tests. Original patch by Demian +Brecht. + +.. + +.. bpo: 18983 +.. date: 9006 +.. nonce: vF4i2S +.. section: Library + +Allow selection of output units in timeit. Patch by Julian Gindi. + +.. + +.. bpo: 23631 +.. date: 9005 +.. nonce: GfSqNI +.. section: Library + +Fix traceback.format_list when a traceback has been mutated. + +.. + +.. bpo: 23568 +.. date: 9004 +.. nonce: ffzJc7 +.. section: Library + +Add rdivmod support to MagicMock() objects. Patch by H?kan L?vdahl. + +.. + +.. bpo: 2052 +.. date: 9003 +.. nonce: ujNgna +.. section: Library + +Add charset parameter to HtmlDiff.make_file(). + +.. + +.. bpo: 23668 +.. date: 9002 +.. nonce: nF_jnN +.. section: Library + +Support os.truncate and os.ftruncate on Windows. + +.. + +.. bpo: 23138 +.. date: 9001 +.. nonce: 4vMoMZ +.. section: Library + +Fixed parsing cookies with absent keys or values in cookiejar. Patch by +Demian Brecht. + +.. + +.. bpo: 23051 +.. date: 9000 +.. nonce: Vi5tCZ +.. section: Library + +multiprocessing.Pool methods imap() and imap_unordered() now handle +exceptions raised by an iterator. Patch by Alon Diamant and Davin Potts. + +.. + +.. bpo: 23581 +.. date: 8999 +.. nonce: D4Lknl +.. section: Library + +Add matmul support to MagicMock. Patch by H?kan L?vdahl. + +.. + +.. bpo: 23566 +.. date: 8998 +.. nonce: F6LSyk +.. section: Library + +enable(), register(), dump_traceback() and dump_traceback_later() functions +of faulthandler now accept file descriptors. Patch by Wei Wu. + +.. + +.. bpo: 22928 +.. date: 8997 +.. nonce: q2TmY0 +.. section: Library + +Disabled HTTP header injections in http.client. Original patch by Demian +Brecht. + +.. + +.. bpo: 23615 +.. date: 8996 +.. nonce: 5Kx9k5 +.. section: Library + +Modules bz2, tarfile and tokenize now can be reloaded with imp.reload(). +Patch by Thomas Kluyver. + +.. + +.. bpo: 23605 +.. date: 8995 +.. nonce: JUOA_X +.. section: Library + +os.walk() now calls os.scandir() instead of os.listdir(). The usage of +os.scandir() reduces the number of calls to os.stat(). Initial patch written +by Ben Hoyt. + +.. + +.. bpo: 23585 +.. date: 8994 +.. nonce: DTIIoI +.. section: Build + +make patchcheck will ensure the interpreter is built. + +.. + +.. bpo: 23583 +.. date: 8993 +.. nonce: bY8AbM +.. section: Tests + +Added tests for standard IO streams in IDLE. + +.. + +.. bpo: 22289 +.. date: 8992 +.. nonce: ybGcC- +.. section: Tests + +Prevent test_urllib2net failures due to ftp connection timeout. + +.. + +.. bpo: 22826 +.. date: 8991 +.. nonce: 3bcoDL +.. section: Tools/Demos + +The result of open() in Tools/freeze/bkfile.py is now better compatible with +regular files (in particular it now supports the context management +protocol). diff --git a/Misc/NEWS.d/3.5.0a4.rst b/Misc/NEWS.d/3.5.0a4.rst new file mode 100644 index 00000000000..9b162bb5f86 --- /dev/null +++ b/Misc/NEWS.d/3.5.0a4.rst @@ -0,0 +1,665 @@ +.. bpo: 22980 +.. date: 9109 +.. nonce: Lu_y6y +.. release date: 2015-04-19 +.. section: Core and Builtins + +Under Linux, GNU/KFreeBSD and the Hurd, C extensions now include the +architecture triplet in the extension name, to make it easy to test builds +for different ABIs in the same working tree. Under OS X, the extension name +now includes PEP 3149-style information. + +.. + +.. bpo: 22631 +.. date: 9108 +.. nonce: nTx_ZF +.. section: Core and Builtins + +Added Linux-specific socket constant CAN_RAW_FD_FRAMES. Patch courtesy of +Joe Jevnik. + +.. + +.. bpo: 23731 +.. date: 9107 +.. nonce: FOXb37 +.. section: Core and Builtins + +Implement PEP 488: removal of .pyo files. + +.. + +.. bpo: 23726 +.. date: 9106 +.. nonce: ZopTQ0 +.. section: Core and Builtins + +Don't enable GC for user subclasses of non-GC types that don't add any new +fields. Patch by Eugene Toder. + +.. + +.. bpo: 23309 +.. date: 9105 +.. nonce: Wfnsnz +.. section: Core and Builtins + +Avoid a deadlock at shutdown if a daemon thread is aborted while it is +holding a lock to a buffered I/O object, and the main thread tries to use +the same I/O object (typically stdout or stderr). A fatal error is emitted +instead. + +.. + +.. bpo: 22977 +.. date: 9104 +.. nonce: hutEse +.. section: Core and Builtins + +Fixed formatting Windows error messages on Wine. Patch by Martin Panter. + +.. + +.. bpo: 23466 +.. date: 9103 +.. nonce: KhMltK +.. section: Core and Builtins + +%c, %o, %x, and %X in bytes formatting now raise TypeError on non-integer +input. + +.. + +.. bpo: 24044 +.. date: 9102 +.. nonce: H7vb6- +.. section: Core and Builtins + +Fix possible null pointer dereference in list.sort in out of memory +conditions. + +.. + +.. bpo: 21354 +.. date: 9101 +.. nonce: ZZTe1E +.. section: Core and Builtins + +PyCFunction_New function is exposed by python DLL again. + +.. + +.. bpo: 23840 +.. date: 9100 +.. nonce: mtSbqO +.. section: Library + +tokenize.open() now closes the temporary binary file on error to fix a +resource warning. + +.. + +.. bpo: 16914 +.. date: 9099 +.. nonce: GrP2Jr +.. section: Library + +new debuglevel 2 in smtplib adds timestamps to debug output. + +.. + +.. bpo: 7159 +.. date: 9098 +.. nonce: KCgOUm +.. section: Library + +urllib.request now supports sending auth credentials automatically after the +first 401. This enhancement is a superset of the enhancement from issue +#19494 and supersedes that change. + +.. + +.. bpo: 23703 +.. date: 9097 +.. nonce: kYybxm +.. section: Library + +Fix a regression in urljoin() introduced in 901e4e52b20a. Patch by Demian +Brecht. + +.. + +.. bpo: 4254 +.. date: 9096 +.. nonce: eUC_2H +.. section: Library + +Adds _curses.update_lines_cols(). Patch by Arnon Yaari + +.. + +.. bpo: 19933 +.. date: 9095 +.. nonce: Qq8utk +.. section: Library + +Provide default argument for ndigits in round. Patch by Vajrasky Kok. + +.. + +.. bpo: 23193 +.. date: 9094 +.. nonce: n5ahcG +.. section: Library + +Add a numeric_owner parameter to tarfile.TarFile.extract and +tarfile.TarFile.extractall. Patch by Michael Vogt and Eric Smith. + +.. + +.. bpo: 23342 +.. date: 9093 +.. nonce: CbSzYI +.. section: Library + +Add a subprocess.run() function than returns a CalledProcess instance for a +more consistent API than the existing call* functions. + +.. + +.. bpo: 21217 +.. date: 9092 +.. nonce: TkFTlk +.. section: Library + +inspect.getsourcelines() now tries to compute the start and end lines from +the code object, fixing an issue when a lambda function is used as decorator +argument. Patch by Thomas Ballinger and Allison Kaptur. + +.. + +.. bpo: 24521 +.. date: 9091 +.. nonce: bn4U-y +.. section: Library + +Fix possible integer overflows in the pickle module. + +.. + +.. bpo: 22931 +.. date: 9090 +.. nonce: 4CuWYD +.. section: Library + +Allow '[' and ']' in cookie values. + +.. + +.. bpo: 0 +.. date: 9089 +.. nonce: fgX8Qe +.. section: Library + +The keywords attribute of functools.partial is now always a dictionary. + +.. + +.. bpo: 23811 +.. date: 9088 +.. nonce: B6tzf9 +.. section: Library + +Add missing newline to the PyCompileError error message. Patch by Alex +Shkop. + +.. + +.. bpo: 21116 +.. date: 9087 +.. nonce: Orft3K +.. section: Library + +Avoid blowing memory when allocating a multiprocessing shared array that's +larger than 50% of the available RAM. Patch by M?d?ric Boquien. + +.. + +.. bpo: 22982 +.. date: 9086 +.. nonce: xYmG62 +.. section: Library + +Improve BOM handling when seeking to multiple positions of a writable text +file. + +.. + +.. bpo: 23464 +.. date: 9085 +.. nonce: _XGkBk +.. section: Library + +Removed deprecated asyncio JoinableQueue. + +.. + +.. bpo: 23529 +.. date: 9084 +.. nonce: Hr7AHH +.. section: Library + +Limit the size of decompressed data when reading from GzipFile, BZ2File or +LZMAFile. This defeats denial of service attacks using compressed bombs +(i.e. compressed payloads which decompress to a huge size). Patch by Martin +Panter and Nikolaus Rath. + +.. + +.. bpo: 21859 +.. date: 9083 +.. nonce: GYrUNP +.. section: Library + +Added Python implementation of io.FileIO. + +.. + +.. bpo: 23865 +.. date: 9082 +.. nonce: PtSLgU +.. section: Library + +close() methods in multiple modules now are idempotent and more robust at +shutdown. If they need to release multiple resources, all are released even +if errors occur. + +.. + +.. bpo: 23400 +.. date: 9081 +.. nonce: JSh9Z3 +.. section: Library + +Raise same exception on both Python 2 and 3 if sem_open is not available. +Patch by Davin Potts. + +.. + +.. bpo: 10838 +.. date: 9080 +.. nonce: p9tSPC +.. section: Library + +The subprocess now module includes SubprocessError and TimeoutError in its +list of exported names for the users wild enough to use ``from subprocess +import *``. + +.. + +.. bpo: 23411 +.. date: 9079 +.. nonce: 0im3Qw +.. section: Library + +Added DefragResult, ParseResult, SplitResult, DefragResultBytes, +ParseResultBytes, and SplitResultBytes to urllib.parse.__all__. Patch by +Martin Panter. + +.. + +.. bpo: 23881 +.. date: 9078 +.. nonce: yZjl4b +.. section: Library + +urllib.request.ftpwrapper constructor now closes the socket if the FTP +connection failed to fix a ResourceWarning. + +.. + +.. bpo: 23853 +.. date: 9077 +.. nonce: mNY1eI +.. section: Library + +:meth:`socket.socket.sendall` does no more reset the socket timeout each +time data is sent successfully. The socket timeout is now the maximum total +duration to send all data. + +.. + +.. bpo: 22721 +.. date: 9076 +.. nonce: MVfBL9 +.. section: Library + +An order of multiline pprint output of set or dict containing orderable and +non-orderable elements no longer depends on iteration order of set or dict. + +.. + +.. bpo: 15133 +.. date: 9075 +.. nonce: C0QfV8 +.. section: Library + +_tkinter.tkapp.getboolean() now supports Tcl_Obj and always returns bool. +tkinter.BooleanVar now validates input values (accepted bool, int, str, and +Tcl_Obj). tkinter.BooleanVar.get() now always returns bool. + +.. + +.. bpo: 10590 +.. date: 9074 +.. nonce: nkxXfU +.. section: Library + +xml.sax.parseString() now supports string argument. + +.. + +.. bpo: 23338 +.. date: 9073 +.. nonce: ZYMGN1 +.. section: Library + +Fixed formatting ctypes error messages on Cygwin. Patch by Makoto Kato. + +.. + +.. bpo: 15582 +.. date: 9072 +.. nonce: 26wJNk +.. section: Library + +inspect.getdoc() now follows inheritance chains. + +.. + +.. bpo: 2175 +.. date: 9071 +.. nonce: cHiVOp +.. section: Library + +SAX parsers now support a character stream of InputSource object. + +.. + +.. bpo: 16840 +.. date: 9070 +.. nonce: kKIhPm +.. section: Library + +Tkinter now supports 64-bit integers added in Tcl 8.4 and arbitrary +precision integers added in Tcl 8.5. + +.. + +.. bpo: 23834 +.. date: 9069 +.. nonce: fX3TF4 +.. section: Library + +Fix socket.sendto(), use the C Py_ssize_t type to store the result of +sendto() instead of the C int type. + +.. + +.. bpo: 23618 +.. date: 9068 +.. nonce: Of_q5t +.. section: Library + +:meth:`socket.socket.connect` now waits until the connection completes +instead of raising :exc:`InterruptedError` if the connection is interrupted +by signals, signal handlers don't raise an exception and the socket is +blocking or has a timeout. :meth:`socket.socket.connect` still raise +:exc:`InterruptedError` for non-blocking sockets. + +.. + +.. bpo: 21526 +.. date: 9067 +.. nonce: QQEXrR +.. section: Library + +Tkinter now supports new boolean type in Tcl 8.5. + +.. + +.. bpo: 23836 +.. date: 9066 +.. nonce: zrEmlR +.. section: Library + +Fix the faulthandler module to handle reentrant calls to its signal +handlers. + +.. + +.. bpo: 23838 +.. date: 9065 +.. nonce: IX6FPX +.. section: Library + +linecache now clears the cache and returns an empty result on MemoryError. + +.. + +.. bpo: 10395 +.. date: 9064 +.. nonce: fi_lZp +.. section: Library + +Added os.path.commonpath(). Implemented in posixpath and ntpath. Based on +patch by Rafik Draoui. + +.. + +.. bpo: 23611 +.. date: 9063 +.. nonce: QkBJVB +.. section: Library + +Serializing more "lookupable" objects (such as unbound methods or nested +classes) now are supported with pickle protocols < 4. + +.. + +.. bpo: 13583 +.. date: 9062 +.. nonce: -MPBjZ +.. section: Library + +sqlite3.Row now supports slice indexing. + +.. + +.. bpo: 18473 +.. date: 9061 +.. nonce: 89RHm- +.. section: Library + +Fixed 2to3 and 3to2 compatible pickle mappings. Fixed ambigious reverse +mappings. Added many new mappings. Import mapping is no longer applied to +modules already mapped with full name mapping. + +.. + +.. bpo: 23485 +.. date: 9060 +.. nonce: kQWN6L +.. section: Library + +select.select() is now retried automatically with the recomputed timeout +when interrupted by a signal, except if the signal handler raises an +exception. This change is part of the PEP 475. + +.. + +.. bpo: 23752 +.. date: 9059 +.. nonce: 5fbVNb +.. section: Library + +When built from an existing file descriptor, io.FileIO() now only calls +fstat() once. Before fstat() was called twice, which was not necessary. + +.. + +.. bpo: 23704 +.. date: 9058 +.. nonce: Ggjvm8 +.. section: Library + +collections.deque() objects now support __add__, __mul__, and __imul__(). + +.. + +.. bpo: 23171 +.. date: 9057 +.. nonce: b6PBzM +.. section: Library + +csv.Writer.writerow() now supports arbitrary iterables. + +.. + +.. bpo: 23745 +.. date: 9056 +.. nonce: E00Bml +.. section: Library + +The new email header parser now handles duplicate MIME parameter names +without error, similar to how get_param behaves. + +.. + +.. bpo: 22117 +.. date: 9055 +.. nonce: bTO0xx +.. section: Library + +Fix os.utime(), it now rounds the timestamp towards minus infinity (-inf) +instead of rounding towards zero. + +.. + +.. bpo: 23310 +.. date: 9054 +.. nonce: GXmFMR +.. section: Library + +Fix MagicMock's initializer to work with __methods__, just like +configure_mock(). Patch by Kasia Jachim. + +.. + +.. bpo: 23817 +.. date: 9053 +.. nonce: DTmVan +.. section: Build + +FreeBSD now uses "1.0" in the SOVERSION as other operating systems, instead +of just "1". + +.. + +.. bpo: 23501 +.. date: 9052 +.. nonce: iz10e6 +.. section: Build + +Argument Clinic now generates code into separate files by default. + +.. + +.. bpo: 23799 +.. date: 9051 +.. nonce: XU2xDw +.. section: Tests + +Added test.support.start_threads() for running and cleaning up multiple +threads. + +.. + +.. bpo: 22390 +.. date: 9050 +.. nonce: UPVFnq +.. section: Tests + +test.regrtest now emits a warning if temporary files or directories are left +after running a test. + +.. + +.. bpo: 18128 +.. date: 9049 +.. nonce: lx2V5a +.. section: Tools/Demos + +pygettext now uses standard +NNNN format in the POT-Creation-Date header. + +.. + +.. bpo: 23935 +.. date: 9048 +.. nonce: JSYowT +.. section: Tools/Demos + +Argument Clinic's understanding of format units accepting bytes, bytearrays, +and buffers is now consistent with both the documentation and the +implementation. + +.. + +.. bpo: 23944 +.. date: 9047 +.. nonce: Q8ZL2s +.. section: Tools/Demos + +Argument Clinic now wraps long impl prototypes at column 78. + +.. + +.. bpo: 20586 +.. date: 9046 +.. nonce: 7BiEkx +.. section: Tools/Demos + +Argument Clinic now ensures that functions without docstrings have +signatures. + +.. + +.. bpo: 23492 +.. date: 9045 +.. nonce: kjIcQW +.. section: Tools/Demos + +Argument Clinic now generates argument parsing code with PyArg_Parse instead +of PyArg_ParseTuple if possible. + +.. + +.. bpo: 23500 +.. date: 9044 +.. nonce: H6_dX_ +.. section: Tools/Demos + +Argument Clinic is now smarter about generating the "#ifndef" (empty) +definition of the methoddef macro: it's only generated once, even if +Argument Clinic processes the same symbol multiple times, and it's emitted +at the end of all processing rather than immediately after the first use. + +.. + +.. bpo: 23998 +.. date: 9043 +.. nonce: z7mlLW +.. section: C API + +PyImport_ReInitLock() now checks for lock allocation error diff --git a/Misc/NEWS.d/3.5.0b1.rst b/Misc/NEWS.d/3.5.0b1.rst new file mode 100644 index 00000000000..edecd79f15d --- /dev/null +++ b/Misc/NEWS.d/3.5.0b1.rst @@ -0,0 +1,848 @@ +.. bpo: 24276 +.. date: 9197 +.. nonce: awsxJJ +.. release date: 2015-05-24 +.. section: Core and Builtins + +Fixed optimization of property descriptor getter. + +.. + +.. bpo: 24268 +.. date: 9196 +.. nonce: nS7uea +.. section: Core and Builtins + +PEP 489: Multi-phase extension module initialization. Patch by Petr +Viktorin. + +.. + +.. bpo: 23955 +.. date: 9195 +.. nonce: hBHSaU +.. section: Core and Builtins + +Add pyvenv.cfg option to suppress registry/environment lookup for generating +sys.path on Windows. + +.. + +.. bpo: 24257 +.. date: 9194 +.. nonce: UBxshR +.. section: Core and Builtins + +Fixed system error in the comparison of faked types.SimpleNamespace. + +.. + +.. bpo: 22939 +.. date: 9193 +.. nonce: DWA9ls +.. section: Core and Builtins + +Fixed integer overflow in iterator object. Patch by Clement Rouault. + +.. + +.. bpo: 23985 +.. date: 9192 +.. nonce: eezPxO +.. section: Core and Builtins + +Fix a possible buffer overrun when deleting a slice from the front of a +bytearray and then appending some other bytes data. + +.. + +.. bpo: 24102 +.. date: 9191 +.. nonce: 9T6h3m +.. section: Core and Builtins + +Fixed exception type checking in standard error handlers. + +.. + +.. bpo: 15027 +.. date: 9190 +.. nonce: wi9sCd +.. section: Core and Builtins + +The UTF-32 encoder is now 3x to 7x faster. + +.. + +.. bpo: 23290 +.. date: 9189 +.. nonce: 57aqLU +.. section: Core and Builtins + +Optimize set_merge() for cases where the target is empty. (Contributed by +Serhiy Storchaka.) + +.. + +.. bpo: 2292 +.. date: 9188 +.. nonce: h4sibO +.. section: Core and Builtins + +PEP 448: Additional Unpacking Generalizations. + +.. + +.. bpo: 24096 +.. date: 9187 +.. nonce: a_Rap7 +.. section: Core and Builtins + +Make warnings.warn_explicit more robust against mutation of the +warnings.filters list. + +.. + +.. bpo: 23996 +.. date: 9186 +.. nonce: znqcT8 +.. section: Core and Builtins + +Avoid a crash when a delegated generator raises an unnormalized +StopIteration exception. Patch by Stefan Behnel. + +.. + +.. bpo: 23910 +.. date: 9185 +.. nonce: _gDzaj +.. section: Core and Builtins + +Optimize property() getter calls. Patch by Joe Jevnik. + +.. + +.. bpo: 23911 +.. date: 9184 +.. nonce: 0FnTHk +.. section: Core and Builtins + +Move path-based importlib bootstrap code to a separate frozen module. + +.. + +.. bpo: 24192 +.. date: 9183 +.. nonce: 6ZxJ_R +.. section: Core and Builtins + +Fix namespace package imports. + +.. + +.. bpo: 24022 +.. date: 9182 +.. nonce: 1l8YBm +.. section: Core and Builtins + +Fix tokenizer crash when processing undecodable source code. + +.. + +.. bpo: 9951 +.. date: 9181 +.. nonce: wGztNC +.. section: Core and Builtins + +Added a hex() method to bytes, bytearray, and memoryview. + +.. + +.. bpo: 22906 +.. date: 9180 +.. nonce: WN_kQ6 +.. section: Core and Builtins + +PEP 479: Change StopIteration handling inside generators. + +.. + +.. bpo: 24017 +.. date: 9179 +.. nonce: QJa1SC +.. section: Core and Builtins + +PEP 492: Coroutines with async and await syntax. + +.. + +.. bpo: 14373 +.. date: 9178 +.. nonce: 0sk6kE +.. section: Library + +Added C implementation of functools.lru_cache(). Based on patches by Matt +Joiner and Alexey Kachayev. + +.. + +.. bpo: 24230 +.. date: 9177 +.. nonce: b-kgme +.. section: Library + +The tempfile module now accepts bytes for prefix, suffix and dir parameters +and returns bytes in such situations (matching the os module APIs). + +.. + +.. bpo: 22189 +.. date: 9176 +.. nonce: 8epgat +.. section: Library + +collections.UserString now supports __getnewargs__(), __rmod__(), +casefold(), format_map(), isprintable(), and maketrans(). Patch by Joe +Jevnik. + +.. + +.. bpo: 24244 +.. date: 9175 +.. nonce: OKE_3R +.. section: Library + +Prevents termination when an invalid format string is encountered on Windows +in strftime. + +.. + +.. bpo: 23973 +.. date: 9174 +.. nonce: EK6awi +.. section: Library + +PEP 484: Add the typing module. + +.. + +.. bpo: 23086 +.. date: 9173 +.. nonce: Aix6Nv +.. section: Library + +The collections.abc.Sequence() abstract base class added *start* and *stop* +parameters to the index() mixin. Patch by Devin Jeanpierre. + +.. + +.. bpo: 20035 +.. date: 9172 +.. nonce: UNZzw6 +.. section: Library + +Replaced the ``tkinter._fix`` module used for setting up the Tcl/Tk +environment on Windows with a private function in the ``_tkinter`` module +that makes no permanent changes to the environment. + +.. + +.. bpo: 24257 +.. date: 9171 +.. nonce: L_efq0 +.. section: Library + +Fixed segmentation fault in sqlite3.Row constructor with faked cursor type. + +.. + +.. bpo: 15836 +.. date: 9170 +.. nonce: gU3Rmx +.. section: Library + +assertRaises(), assertRaisesRegex(), assertWarns() and assertWarnsRegex() +assertments now check the type of the first argument to prevent possible +user error. Based on patch by Daniel Wagner-Hall. + +.. + +.. bpo: 9858 +.. date: 9169 +.. nonce: uke9pa +.. section: Library + +Add missing method stubs to _io.RawIOBase. Patch by Laura Rupprecht. + +.. + +.. bpo: 22955 +.. date: 9168 +.. nonce: Jw_B9_ +.. section: Library + +attrgetter, itemgetter and methodcaller objects in the operator module now +support pickling. Added readable and evaluable repr for these objects. +Based on patch by Josh Rosenberg. + +.. + +.. bpo: 22107 +.. date: 9167 +.. nonce: 2F8k4W +.. section: Library + +tempfile.gettempdir() and tempfile.mkdtemp() now try again when a directory +with the chosen name already exists on Windows as well as on Unix. +tempfile.mkstemp() now fails early if parent directory is not valid (not +exists or is a file) on Windows. + +.. + +.. bpo: 23780 +.. date: 9166 +.. nonce: jFPVcN +.. section: Library + +Improved error message in os.path.join() with single argument. + +.. + +.. bpo: 6598 +.. date: 9165 +.. nonce: JdZNDt +.. section: Library + +Increased time precision and random number range in email.utils.make_msgid() +to strengthen the uniqueness of the message ID. + +.. + +.. bpo: 24091 +.. date: 9164 +.. nonce: Jw0-wj +.. section: Library + +Fixed various crashes in corner cases in C implementation of ElementTree. + +.. + +.. bpo: 21931 +.. date: 9163 +.. nonce: t6lGxY +.. section: Library + +msilib.FCICreate() now raises TypeError in the case of a bad argument +instead of a ValueError with a bogus FCI error number. Patch by Jeffrey +Armstrong. + +.. + +.. bpo: 13866 +.. date: 9162 +.. nonce: n5NAj0 +.. section: Library + +*quote_via* argument added to urllib.parse.urlencode. + +.. + +.. bpo: 20098 +.. date: 9161 +.. nonce: Y4otaf +.. section: Library + +New mangle_from policy option for email, default True for compat32, but +False for all other policies. + +.. + +.. bpo: 24211 +.. date: 9160 +.. nonce: j3Afpc +.. section: Library + +The email library now supports RFC 6532: it can generate headers using utf-8 +instead of encoded words. + +.. + +.. bpo: 16314 +.. date: 9159 +.. nonce: Xc4d1O +.. section: Library + +Added support for the LZMA compression in distutils. + +.. + +.. bpo: 21804 +.. date: 9158 +.. nonce: lEhTlc +.. section: Library + +poplib now supports RFC 6856 (UTF8). + +.. + +.. bpo: 18682 +.. date: 9157 +.. nonce: 6Pnfte +.. section: Library + +Optimized pprint functions for builtin scalar types. + +.. + +.. bpo: 22027 +.. date: 9156 +.. nonce: _aeUQS +.. section: Library + +smtplib now supports RFC 6531 (SMTPUTF8). + +.. + +.. bpo: 23488 +.. date: 9155 +.. nonce: 7gs3Cm +.. section: Library + +Random generator objects now consume 2x less memory on 64-bit. + +.. + +.. bpo: 1322 +.. date: 9154 +.. nonce: 495nFL +.. section: Library + +platform.dist() and platform.linux_distribution() functions are now +deprecated. Initial patch by Vajrasky Kok. + +.. + +.. bpo: 22486 +.. date: 9153 +.. nonce: Yxov5m +.. section: Library + +Added the math.gcd() function. The fractions.gcd() function now is +deprecated. Based on patch by Mark Dickinson. + +.. + +.. bpo: 24064 +.. date: 9152 +.. nonce: zXC7OL +.. section: Library + +Property() docstrings are now writeable. (Patch by Berker Peksag.) + +.. + +.. bpo: 22681 +.. date: 9151 +.. nonce: 2rIoA2 +.. section: Library + +Added support for the koi8_t encoding. + +.. + +.. bpo: 22682 +.. date: 9150 +.. nonce: cP4i3L +.. section: Library + +Added support for the kz1048 encoding. + +.. + +.. bpo: 23796 +.. date: 9149 +.. nonce: JJmUnc +.. section: Library + +peek and read1 methods of BufferedReader now raise ValueError if they called +on a closed object. Patch by John Hergenroeder. + +.. + +.. bpo: 21795 +.. date: 9148 +.. nonce: BDLMS4 +.. section: Library + +smtpd now supports the 8BITMIME extension whenever the new *decode_data* +constructor argument is set to False. + +.. + +.. bpo: 24155 +.. date: 9147 +.. nonce: FZx5c2 +.. section: Library + +optimize heapq.heapify() for better cache performance when heapifying large +lists. + +.. + +.. bpo: 21800 +.. date: 9146 +.. nonce: evGSKc +.. section: Library + +imaplib now supports RFC 5161 (enable), RFC 6855 (utf8/internationalized +email) and automatically encodes non-ASCII usernames and passwords to UTF8. + +.. + +.. bpo: 20274 +.. date: 9145 +.. nonce: uVHogg +.. section: Library + +When calling a _sqlite.Connection, it now complains if passed any keyword +arguments. Previously it silently ignored them. + +.. + +.. bpo: 20274 +.. date: 9144 +.. nonce: hBst4M +.. section: Library + +Remove ignored and erroneous "kwargs" parameters from three METH_VARARGS +methods on _sqlite.Connection. + +.. + +.. bpo: 24134 +.. date: 9143 +.. nonce: Ajw0S- +.. section: Library + +assertRaises(), assertRaisesRegex(), assertWarns() and assertWarnsRegex() +checks now emits a deprecation warning when callable is None or keyword +arguments except msg is passed in the context manager mode. + +.. + +.. bpo: 24018 +.. date: 9142 +.. nonce: hk7Rcn +.. section: Library + +Add a collections.abc.Generator abstract base class. Contributed by Stefan +Behnel. + +.. + +.. bpo: 23880 +.. date: 9141 +.. nonce: QtKupC +.. section: Library + +Tkinter's getint() and getdouble() now support Tcl_Obj. Tkinter's +getdouble() now supports any numbers (in particular int). + +.. + +.. bpo: 22619 +.. date: 9140 +.. nonce: 1gJEqV +.. section: Library + +Added negative limit support in the traceback module. Based on patch by +Dmitry Kazakov. + +.. + +.. bpo: 24094 +.. date: 9139 +.. nonce: 7T-u7k +.. section: Library + +Fix possible crash in json.encode with poorly behaved dict subclasses. + +.. + +.. bpo: 9246 +.. date: 9138 +.. nonce: oM-Ikk +.. section: Library + +On POSIX, os.getcwd() now supports paths longer than 1025 bytes. Patch +written by William Orr. + +.. + +.. bpo: 17445 +.. date: 9137 +.. nonce: Z-QYh5 +.. section: Library + +add difflib.diff_bytes() to support comparison of byte strings (fixes a +regression from Python 2). + +.. + +.. bpo: 23917 +.. date: 9136 +.. nonce: uMVPV7 +.. section: Library + +Fall back to sequential compilation when ProcessPoolExecutor doesn't exist. +Patch by Claudiu Popa. + +.. + +.. bpo: 23008 +.. date: 9135 +.. nonce: OZFCd- +.. section: Library + +Fixed resolving attributes with boolean value is False in pydoc. + +.. + +.. bpo: 0 +.. date: 9134 +.. nonce: 6tJNf2 +.. section: Library + +Fix asyncio issue 235: LifoQueue and PriorityQueue's put didn't increment +unfinished tasks (this bug was introduced when JoinableQueue was merged with +Queue). + +.. + +.. bpo: 23908 +.. date: 9133 +.. nonce: ATdNG- +.. section: Library + +os functions now reject paths with embedded null character on Windows +instead of silently truncating them. + +.. + +.. bpo: 23728 +.. date: 9132 +.. nonce: YBmQmV +.. section: Library + +binascii.crc_hqx() could return an integer outside of the range 0-0xffff for +empty data. + +.. + +.. bpo: 23887 +.. date: 9131 +.. nonce: _XpjPN +.. section: Library + +urllib.error.HTTPError now has a proper repr() representation. Patch by +Berker Peksag. + +.. + +.. bpo: 0 +.. date: 9130 +.. nonce: MjNdSC +.. section: Library + +asyncio: New event loop APIs: set_task_factory() and get_task_factory(). + +.. + +.. bpo: 0 +.. date: 9129 +.. nonce: rVcHXp +.. section: Library + +asyncio: async() function is deprecated in favour of ensure_future(). + +.. + +.. bpo: 24178 +.. date: 9128 +.. nonce: -enO4y +.. section: Library + +asyncio.Lock, Condition, Semaphore, and BoundedSemaphore support new 'async +with' syntax. Contributed by Yury Selivanov. + +.. + +.. bpo: 24179 +.. date: 9127 +.. nonce: wDy_WZ +.. section: Library + +Support 'async for' for asyncio.StreamReader. Contributed by Yury Selivanov. + +.. + +.. bpo: 24184 +.. date: 9126 +.. nonce: El74TU +.. section: Library + +Add AsyncIterator and AsyncIterable ABCs to collections.abc. Contributed by +Yury Selivanov. + +.. + +.. bpo: 22547 +.. date: 9125 +.. nonce: _ikCaj +.. section: Library + +Implement informative __repr__ for inspect.BoundArguments. Contributed by +Yury Selivanov. + +.. + +.. bpo: 24190 +.. date: 9124 +.. nonce: 1a3vWW +.. section: Library + +Implement inspect.BoundArgument.apply_defaults() method. Contributed by Yury +Selivanov. + +.. + +.. bpo: 20691 +.. date: 9123 +.. nonce: -raLyf +.. section: Library + +Add 'follow_wrapped' argument to inspect.Signature.from_callable() and +inspect.signature(). Contributed by Yury Selivanov. + +.. + +.. bpo: 24248 +.. date: 9122 +.. nonce: IxWooo +.. section: Library + +Deprecate inspect.Signature.from_function() and +inspect.Signature.from_builtin(). + +.. + +.. bpo: 23898 +.. date: 9121 +.. nonce: OSiZie +.. section: Library + +Fix inspect.classify_class_attrs() to support attributes with overloaded +__eq__ and __bool__. Patch by Mike Bayer. + +.. + +.. bpo: 24298 +.. date: 9120 +.. nonce: u_TaxI +.. section: Library + +Fix inspect.signature() to correctly unwrap wrappers around bound methods. + +.. + +.. bpo: 23184 +.. date: 9119 +.. nonce: G_Cp9v +.. section: IDLE + +remove unused names and imports in idlelib. Initial patch by Al Sweigart. + +.. + +.. bpo: 21520 +.. date: 9118 +.. nonce: FKtvmQ +.. section: Tests + +test_zipfile no longer fails if the word 'bad' appears anywhere in the name +of the current directory. + +.. + +.. bpo: 9517 +.. date: 9117 +.. nonce: W0Ag2V +.. section: Tests + +Move script_helper into the support package. Patch by Christie Wilson. + +.. + +.. bpo: 22155 +.. date: 9116 +.. nonce: 9EbOit +.. section: Documentation + +Add File Handlers subsection with createfilehandler to tkinter doc. Remove +obsolete example from FAQ. Patch by Martin Panter. + +.. + +.. bpo: 24029 +.. date: 9115 +.. nonce: M2Bnks +.. section: Documentation + +Document the name binding behavior for submodule imports. + +.. + +.. bpo: 24077 +.. date: 9114 +.. nonce: 2Og2j- +.. section: Documentation + +Fix typo in man page for -I command option: -s, not -S + +.. + +.. bpo: 24000 +.. date: 9113 +.. nonce: MJyXRr +.. section: Tools/Demos + +Improved Argument Clinic's mapping of converters to legacy "format units". +Updated the documentation to match. + +.. + +.. bpo: 24001 +.. date: 9112 +.. nonce: m74vst +.. section: Tools/Demos + +Argument Clinic converters now use accept={type} instead of types={'type'} +to specify the types the converter accepts. + +.. + +.. bpo: 23330 +.. date: 9111 +.. nonce: LTlKDp +.. section: Tools/Demos + +h2py now supports arbitrary filenames in #include. + +.. + +.. bpo: 24031 +.. date: 9110 +.. nonce: duGo88 +.. section: Tools/Demos + +make patchcheck now supports git checkouts, too. diff --git a/Misc/NEWS.d/3.5.0b2.rst b/Misc/NEWS.d/3.5.0b2.rst new file mode 100644 index 00000000000..21c75dd2352 --- /dev/null +++ b/Misc/NEWS.d/3.5.0b2.rst @@ -0,0 +1,104 @@ +.. bpo: 24284 +.. date: 9208 +.. nonce: NvtEnc +.. release date: 2015-05-31 +.. section: Core and Builtins + +The startswith and endswith methods of the str class no longer return True +when finding the empty string and the indexes are completely out of range. + +.. + +.. bpo: 24115 +.. date: 9207 +.. nonce: y9e_MO +.. section: Core and Builtins + +Update uses of PyObject_IsTrue(), PyObject_Not(), PyObject_IsInstance(), +PyObject_RichCompareBool() and _PyDict_Contains() to check for and handle +errors correctly. + +.. + +.. bpo: 24328 +.. date: 9206 +.. nonce: 5gL8or +.. section: Core and Builtins + +Fix importing one character extension modules. + +.. + +.. bpo: 11205 +.. date: 9205 +.. nonce: bikrRP +.. section: Core and Builtins + +In dictionary displays, evaluate the key before the value. + +.. + +.. bpo: 24285 +.. date: 9204 +.. nonce: wvJumr +.. section: Core and Builtins + +Fixed regression that prevented importing extension modules from inside +packages. Patch by Petr Viktorin. + +.. + +.. bpo: 23247 +.. date: 9203 +.. nonce: nN-K74 +.. section: Library + +Fix a crash in the StreamWriter.reset() of CJK codecs. + +.. + +.. bpo: 24270 +.. date: 9202 +.. nonce: M2rJNs +.. section: Library + +Add math.isclose() and cmath.isclose() functions as per PEP 485. Contributed +by Chris Barker and Tal Einat. + +.. + +.. bpo: 5633 +.. date: 9201 +.. nonce: JNzKZq +.. section: Library + +Fixed timeit when the statement is a string and the setup is not. + +.. + +.. bpo: 24326 +.. date: 9200 +.. nonce: 4t_6Gy +.. section: Library + +Fixed audioop.ratecv() with non-default weightB argument. Original patch by +David Moore. + +.. + +.. bpo: 16991 +.. date: 9199 +.. nonce: 19_Zmj +.. section: Library + +Add a C implementation of OrderedDict. + +.. + +.. bpo: 23934 +.. date: 9198 +.. nonce: esb-45 +.. section: Library + +Fix inspect.signature to fail correctly for builtin types lacking signature +information. Initial patch by James Powell. diff --git a/Misc/NEWS.d/3.5.0b3.rst b/Misc/NEWS.d/3.5.0b3.rst new file mode 100644 index 00000000000..bb4cc33cc99 --- /dev/null +++ b/Misc/NEWS.d/3.5.0b3.rst @@ -0,0 +1,273 @@ +.. bpo: 24467 +.. date: 9236 +.. nonce: BAJ80- +.. release date: 2015-07-05 +.. section: Core and Builtins + +Fixed possible buffer over-read in bytearray. The bytearray object now +always allocates place for trailing null byte and it's buffer now is always +null-terminated. + +.. + +.. bpo: 0 +.. date: 9235 +.. nonce: 944IUY +.. section: Core and Builtins + +Upgrade to Unicode 8.0.0. + +.. + +.. bpo: 24345 +.. date: 9234 +.. nonce: fVcTaB +.. section: Core and Builtins + +Add Py_tp_finalize slot for the stable ABI. + +.. + +.. bpo: 24400 +.. date: 9233 +.. nonce: 2mNeD8 +.. section: Core and Builtins + +Introduce a distinct type for PEP 492 coroutines; add types.CoroutineType, +inspect.getcoroutinestate, inspect.getcoroutinelocals; coroutines no longer +use CO_GENERATOR flag; sys.set_coroutine_wrapper works only for 'async def' +coroutines; inspect.iscoroutine no longer uses collections.abc.Coroutine, +it's intended to test for pure 'async def' coroutines only; add new opcode: +GET_YIELD_FROM_ITER; fix generators wrapper used in types.coroutine to be +instance of collections.abc.Generator; collections.abc.Awaitable and +collections.abc.Coroutine can no longer be used to detect generator-based +coroutines--use inspect.isawaitable instead. + +.. + +.. bpo: 24450 +.. date: 9232 +.. nonce: lF0S5c +.. section: Core and Builtins + +Add gi_yieldfrom to generators and cr_await to coroutines. Contributed by +Benno Leslie and Yury Selivanov. + +.. + +.. bpo: 19235 +.. date: 9231 +.. nonce: 0kW4n5 +.. section: Core and Builtins + +Add new RecursionError exception. Patch by Georg Brandl. + +.. + +.. bpo: 21750 +.. date: 9230 +.. nonce: _Ycvgi +.. section: Library + +mock_open.read_data can now be read from each instance, as it could in +Python 3.3. + +.. + +.. bpo: 24552 +.. date: 9229 +.. nonce: VTO6sf +.. section: Library + +Fix use after free in an error case of the _pickle module. + +.. + +.. bpo: 24514 +.. date: 9228 +.. nonce: _xRb2r +.. section: Library + +tarfile now tolerates number fields consisting of only whitespace. + +.. + +.. bpo: 19176 +.. date: 9227 +.. nonce: 8V6nOK +.. section: Library + +Fixed doctype() related bugs in C implementation of ElementTree. A +deprecation warning no longer issued by XMLParser subclass with default +doctype() method. Direct call of doctype() now issues a warning. Parser's +doctype() now is not called if target's doctype() is called. Based on patch +by Martin Panter. + +.. + +.. bpo: 20387 +.. date: 9226 +.. nonce: aAbWbQ +.. section: Library + +Restore semantic round-trip correctness in tokenize/untokenize for tab- +indented blocks. + +.. + +.. bpo: 24456 +.. date: 9225 +.. nonce: yYSd2u +.. section: Library + +Fixed possible buffer over-read in adpcm2lin() and lin2adpcm() functions of +the audioop module. + +.. + +.. bpo: 24336 +.. date: 9224 +.. nonce: 4a5y1m +.. section: Library + +The contextmanager decorator now works with functions with keyword arguments +called "func" and "self". Patch by Martin Panter. + +.. + +.. bpo: 24522 +.. date: 9223 +.. nonce: PkcqCA +.. section: Library + +Fix possible integer overflow in json accelerator module. + +.. + +.. bpo: 24489 +.. date: 9222 +.. nonce: GJnMcW +.. section: Library + +ensure a previously set C errno doesn't disturb cmath.polar(). + +.. + +.. bpo: 24408 +.. date: 9221 +.. nonce: vPb5UK +.. section: Library + +Fixed AttributeError in measure() and metrics() methods of tkinter.Font. + +.. + +.. bpo: 14373 +.. date: 9220 +.. nonce: CTYZ4J +.. section: Library + +C implementation of functools.lru_cache() now can be used with methods. + +.. + +.. bpo: 24347 +.. date: 9219 +.. nonce: CPPDb8 +.. section: Library + +Set KeyError if PyDict_GetItemWithError returns NULL. + +.. + +.. bpo: 24348 +.. date: 9218 +.. nonce: U11rhr +.. section: Library + +Drop superfluous incref/decref. + +.. + +.. bpo: 24359 +.. date: 9217 +.. nonce: -IRNG9 +.. section: Library + +Check for changed OrderedDict size during iteration. + +.. + +.. bpo: 24368 +.. date: 9216 +.. nonce: 550kDT +.. section: Library + +Support keyword arguments in OrderedDict methods. + +.. + +.. bpo: 24362 +.. date: 9215 +.. nonce: cHYce5 +.. section: Library + +Simplify the C OrderedDict fast nodes resize logic. + +.. + +.. bpo: 24377 +.. date: 9214 +.. nonce: Gp1Bqr +.. section: Library + +Fix a ref leak in OrderedDict.__repr__. + +.. + +.. bpo: 24369 +.. date: 9213 +.. nonce: qFl7lZ +.. section: Library + +Defend against key-changes during iteration. + +.. + +.. bpo: 24373 +.. date: 9212 +.. nonce: 6TL2XG +.. section: Tests + +_testmultiphase and xxlimited now use tp_traverse and tp_finalize to avoid +reference leaks encountered when combining tp_dealloc with PyType_FromSpec +(see issue #16690 for details) + +.. + +.. bpo: 24458 +.. date: 9211 +.. nonce: 1egApX +.. section: Documentation + +Update documentation to cover multi-phase initialization for extension +modules (PEP 489). Patch by Petr Viktorin. + +.. + +.. bpo: 24351 +.. date: 9210 +.. nonce: XeSVl5 +.. section: Documentation + +Clarify what is meant by "identifier" in the context of string.Template +instances. + +.. + +.. bpo: 24432 +.. date: 9209 +.. nonce: IvUSiN +.. section: Build + +Update Windows builds and OS X 10.5 installer to use OpenSSL 1.0.2c. diff --git a/Misc/NEWS.d/3.5.0b4.rst b/Misc/NEWS.d/3.5.0b4.rst new file mode 100644 index 00000000000..bcc7345d8a7 --- /dev/null +++ b/Misc/NEWS.d/3.5.0b4.rst @@ -0,0 +1,255 @@ +.. bpo: 23573 +.. date: 9263 +.. nonce: HdJPs7 +.. release date: 2015-07-26 +.. section: Core and Builtins + +Restored optimization of bytes.rfind() and bytearray.rfind() for single-byte +argument on Linux. + +.. + +.. bpo: 24569 +.. date: 9262 +.. nonce: bqh6PQ +.. section: Core and Builtins + +Make PEP 448 dictionary evaluation more consistent. + +.. + +.. bpo: 24583 +.. date: 9261 +.. nonce: Ooq0Tn +.. section: Core and Builtins + +Fix crash when set is mutated while being updated. + +.. + +.. bpo: 24407 +.. date: 9260 +.. nonce: GmCBB3 +.. section: Core and Builtins + +Fix crash when dict is mutated while being updated. + +.. + +.. bpo: 24619 +.. date: 9259 +.. nonce: cnfZGo +.. section: Core and Builtins + +New approach for tokenizing async/await. As a consequence, it is now +possible to have one-line 'async def foo(): await ..' functions. + +.. + +.. bpo: 24687 +.. date: 9258 +.. nonce: 0UaXFe +.. section: Core and Builtins + +Plug refleak on SyntaxError in function parameters annotations. + +.. + +.. bpo: 15944 +.. date: 9257 +.. nonce: 4GuwqX +.. section: Core and Builtins + +memoryview: Allow arbitrary formats when casting to bytes. Patch by Martin +Panter. + +.. + +.. bpo: 23441 +.. date: 9256 +.. nonce: JXt2Yt +.. section: Library + +rcompleter now prints a tab character instead of displaying possible +completions for an empty word. Initial patch by Martin Sekera. + +.. + +.. bpo: 24683 +.. date: 9255 +.. nonce: aJdWEv +.. section: Library + +Fixed crashes in _json functions called with arguments of inappropriate +type. + +.. + +.. bpo: 21697 +.. date: 9254 +.. nonce: jpATha +.. section: Library + +shutil.copytree() now correctly handles symbolic links that point to +directories. Patch by Eduardo Seabra and Thomas Kluyver. + +.. + +.. bpo: 14373 +.. date: 9253 +.. nonce: Je0yDg +.. section: Library + +Fixed segmentation fault when gc.collect() is called during constructing +lru_cache (C implementation). + +.. + +.. bpo: 24695 +.. date: 9252 +.. nonce: QjZzFb +.. section: Library + +Fix a regression in traceback.print_exception(). If exc_traceback is None +we shouldn't print a traceback header like described in the documentation. + +.. + +.. bpo: 24620 +.. date: 9251 +.. nonce: rrnxB- +.. section: Library + +Random.setstate() now validates the value of state last element. + +.. + +.. bpo: 22485 +.. date: 9250 +.. nonce: HvJf6T +.. section: Library + +Fixed an issue that caused `inspect.getsource` to return incorrect results +on nested functions. + +.. + +.. bpo: 22153 +.. date: 9249 +.. nonce: 6n6yld +.. section: Library + +Improve unittest docs. Patch from Martin Panter and evilzero. + +.. + +.. bpo: 24580 +.. date: 9248 +.. nonce: AGi4Gm +.. section: Library + +Symbolic group references to open group in re patterns now are explicitly +forbidden as well as numeric group references. + +.. + +.. bpo: 24206 +.. date: 9247 +.. nonce: ffkVHH +.. section: Library + +Fixed __eq__ and __ne__ methods of inspect classes. + +.. + +.. bpo: 24631 +.. date: 9246 +.. nonce: uljPxM +.. section: Library + +Fixed regression in the timeit module with multiline setup. + +.. + +.. bpo: 18622 +.. date: 9245 +.. nonce: i6nCCW +.. section: Library + +unittest.mock.mock_open().reset_mock would recurse infinitely. Patch from +Nicola Palumbo and Laurent De Buyst. + +.. + +.. bpo: 23661 +.. date: 9244 +.. nonce: 5VHJmh +.. section: Library + +unittest.mock side_effects can now be exceptions again. This was a +regression vs Python 3.4. Patch from Ignacio Rossi + +.. + +.. bpo: 24608 +.. date: 9243 +.. nonce: 0TndL0 +.. section: Library + +chunk.Chunk.read() now always returns bytes, not str. + +.. + +.. bpo: 18684 +.. date: 9242 +.. nonce: S2es0F +.. section: Library + +Fixed reading out of the buffer in the re module. + +.. + +.. bpo: 24259 +.. date: 9241 +.. nonce: vMAi1A +.. section: Library + +tarfile now raises a ReadError if an archive is truncated inside a data +segment. + +.. + +.. bpo: 15014 +.. date: 9240 +.. nonce: hwXwCH +.. section: Library + +SMTP.auth() and SMTP.login() now support RFC 4954's optional initial- +response argument to the SMTP AUTH command. + +.. + +.. bpo: 24669 +.. date: 9239 +.. nonce: kFThK0 +.. section: Library + +Fix inspect.getsource() for 'async def' functions. Patch by Kai Groner. + +.. + +.. bpo: 24688 +.. date: 9238 +.. nonce: -yWfcO +.. section: Library + +ast.get_docstring() for 'async def' functions. + +.. + +.. bpo: 24603 +.. date: 9237 +.. nonce: PyHyF5 +.. section: Build + +Update Windows builds and OS X 10.5 installer to use OpenSSL 1.0.2d. diff --git a/Misc/NEWS.d/3.5.0rc1.rst b/Misc/NEWS.d/3.5.0rc1.rst new file mode 100644 index 00000000000..1fb9bc6c04d --- /dev/null +++ b/Misc/NEWS.d/3.5.0rc1.rst @@ -0,0 +1,241 @@ +.. bpo: 24667 +.. date: 9288 +.. nonce: tdwszf +.. release date: 2015-08-09 +.. section: Core and Builtins + +Resize odict in all cases that the underlying dict resizes. + +.. + +.. bpo: 24824 +.. date: 9287 +.. nonce: Eoc4lq +.. section: Library + +Signatures of codecs.encode() and codecs.decode() now are compatible with +pydoc. + +.. + +.. bpo: 24634 +.. date: 9286 +.. nonce: 7bnVgr +.. section: Library + +Importing uuid should not try to load libc on Windows + +.. + +.. bpo: 24798 +.. date: 9285 +.. nonce: zDXL5R +.. section: Library + +_msvccompiler.py doesn't properly support manifests + +.. + +.. bpo: 4395 +.. date: 9284 +.. nonce: JpT0k7 +.. section: Library + +Better testing and documentation of binary operators. Patch by Martin +Panter. + +.. + +.. bpo: 23973 +.. date: 9283 +.. nonce: wT59Vh +.. section: Library + +Update typing.py from GitHub repo. + +.. + +.. bpo: 23004 +.. date: 9282 +.. nonce: xswcPm +.. section: Library + +mock_open() now reads binary data correctly when the type of read_data is +bytes. Initial patch by Aaron Hill. + +.. + +.. bpo: 23888 +.. date: 9281 +.. nonce: 7gw4oO +.. section: Library + +Handle fractional time in cookie expiry. Patch by ssh. + +.. + +.. bpo: 23652 +.. date: 9280 +.. nonce: DKQ_7t +.. section: Library + +Make it possible to compile the select module against the libc headers from +the Linux Standard Base, which do not include some EPOLL macros. Patch by +Matt Frank. + +.. + +.. bpo: 22932 +.. date: 9279 +.. nonce: mPclSJ +.. section: Library + +Fix timezones in email.utils.formatdate. Patch from Dmitry Shachnev. + +.. + +.. bpo: 23779 +.. date: 9278 +.. nonce: ET4JJP +.. section: Library + +imaplib raises TypeError if authenticator tries to abort. Patch from Craig +Holmquist. + +.. + +.. bpo: 23319 +.. date: 9277 +.. nonce: FXyUH- +.. section: Library + +Fix ctypes.BigEndianStructure, swap correctly bytes. Patch written by +Matthieu Gautier. + +.. + +.. bpo: 23254 +.. date: 9276 +.. nonce: zNiy1X +.. section: Library + +Document how to close the TCPServer listening socket. Patch from Martin +Panter. + +.. + +.. bpo: 19450 +.. date: 9275 +.. nonce: VG7T-L +.. section: Library + +Update Windows and OS X installer builds to use SQLite 3.8.11. + +.. + +.. bpo: 17527 +.. date: 9274 +.. nonce: ve9fyw +.. section: Library + +Add PATCH to wsgiref.validator. Patch from Luca Sbardella. + +.. + +.. bpo: 24791 +.. date: 9273 +.. nonce: Ok-3nA +.. section: Library + +Fix grammar regression for call syntax: 'g(\*a or b)'. + +.. + +.. bpo: 23672 +.. date: 9272 +.. nonce: 8td2se +.. section: IDLE + +Allow Idle to edit and run files with astral chars in name. Patch by Mohd +Sanad Zaki Rizvi. + +.. + +.. bpo: 24745 +.. date: 9271 +.. nonce: edbziT +.. section: IDLE + +Idle editor default font. Switch from Courier to platform-sensitive +TkFixedFont. This should not affect current customized font selections. If +there is a problem, edit $HOME/.idlerc/config-main.cfg and remove 'fontxxx' +entries from [Editor Window]. Patch by Mark Roseman. + +.. + +.. bpo: 21192 +.. date: 9270 +.. nonce: CdbipH +.. section: IDLE + +Idle editor. When a file is run, put its name in the restart bar. Do not +print false prompts. Original patch by Adnan Umer. + +.. + +.. bpo: 13884 +.. date: 9269 +.. nonce: vVcO1E +.. section: IDLE + +Idle menus. Remove tearoff lines. Patch by Roger Serwy. + +.. + +.. bpo: 24129 +.. date: 9268 +.. nonce: Imr54z +.. section: Documentation + +Clarify the reference documentation for name resolution. This includes +removing the assumption that readers will be familiar with the name +resolution scheme Python used prior to the introduction of lexical scoping +for function namespaces. Patch by Ivan Levkivskyi. + +.. + +.. bpo: 20769 +.. date: 9267 +.. nonce: ZUc9z9 +.. section: Documentation + +Improve reload() docs. Patch by Dorian Pula. + +.. + +.. bpo: 23589 +.. date: 9266 +.. nonce: rjU421 +.. section: Documentation + +Remove duplicate sentence from the FAQ. Patch by Yongzhi Pan. + +.. + +.. bpo: 24729 +.. date: 9265 +.. nonce: PH3A9p +.. section: Documentation + +Correct IO tutorial to match implementation regarding encoding parameter to +open function. + +.. + +.. bpo: 24751 +.. date: 9264 +.. nonce: pL2pbj +.. section: Tests + +When running regrtest with the ``-w`` command line option, a test run is no +longer marked as a failure if all tests succeed when re-run. diff --git a/Misc/NEWS.d/3.5.0rc2.rst b/Misc/NEWS.d/3.5.0rc2.rst new file mode 100644 index 00000000000..2a8a52a13ce --- /dev/null +++ b/Misc/NEWS.d/3.5.0rc2.rst @@ -0,0 +1,56 @@ +.. bpo: 24769 +.. date: 9294 +.. nonce: XgRA0n +.. release date: 2015-08-25 +.. section: Core and Builtins + +Interpreter now starts properly when dynamic loading is disabled. Patch by +Petr Viktorin. + +.. + +.. bpo: 21167 +.. date: 9293 +.. nonce: uom-Dq +.. section: Core and Builtins + +NAN operations are now handled correctly when python is compiled with ICC +even if -fp-model strict is not specified. + +.. + +.. bpo: 24492 +.. date: 9292 +.. nonce: LKDAIu +.. section: Core and Builtins + +A "package" lacking a __name__ attribute when trying to perform a ``from .. +import ...`` statement will trigger an ImportError instead of an +AttributeError. + +.. + +.. bpo: 24847 +.. date: 9291 +.. nonce: SHiiO_ +.. section: Library + +Removes vcruntime140.dll dependency from Tcl/Tk. + +.. + +.. bpo: 24839 +.. date: 9290 +.. nonce: 7_iQZl +.. section: Library + +platform._syscmd_ver raises DeprecationWarning + +.. + +.. bpo: 24867 +.. date: 9289 +.. nonce: rxJIl7 +.. section: Library + +Fix Task.get_stack() for 'async def' coroutines diff --git a/Misc/NEWS.d/3.5.0rc3.rst b/Misc/NEWS.d/3.5.0rc3.rst new file mode 100644 index 00000000000..c6976c0f0c2 --- /dev/null +++ b/Misc/NEWS.d/3.5.0rc3.rst @@ -0,0 +1,76 @@ +.. bpo: 24305 +.. date: 9302 +.. nonce: QeF4A8 +.. release date: 2015-09-07 +.. section: Core and Builtins + +Prevent import subsystem stack frames from being counted by the +warnings.warn(stacklevel=) parameter. + +.. + +.. bpo: 24912 +.. date: 9301 +.. nonce: ubSi5J +.. section: Core and Builtins + +Prevent __class__ assignment to immutable built-in objects. + +.. + +.. bpo: 24975 +.. date: 9300 +.. nonce: 2gLdfN +.. section: Core and Builtins + +Fix AST compilation for PEP 448 syntax. + +.. + +.. bpo: 24917 +.. date: 9299 +.. nonce: xaQocz +.. section: Library + +time_strftime() buffer over-read. + +.. + +.. bpo: 24748 +.. date: 9298 +.. nonce: 83NuO8 +.. section: Library + +To resolve a compatibility problem found with py2exe and pywin32, +imp.load_dynamic() once again ignores previously loaded modules to support +Python modules replacing themselves with extension modules. Patch by Petr +Viktorin. + +.. + +.. bpo: 24635 +.. date: 9297 +.. nonce: EiJPPf +.. section: Library + +Fixed a bug in typing.py where isinstance([], typing.Iterable) would return +True once, then False on subsequent calls. + +.. + +.. bpo: 24989 +.. date: 9296 +.. nonce: 9BJLiy +.. section: Library + +Fixed buffer overread in BytesIO.readline() if a position is set beyond +size. Based on patch by John Leitch. + +.. + +.. bpo: 24913 +.. date: 9295 +.. nonce: p2ZAJ4 +.. section: Library + +Fix overrun error in deque.index(). Found by John Leitch and Bryce Darling. diff --git a/Misc/NEWS.d/3.5.0rc4.rst b/Misc/NEWS.d/3.5.0rc4.rst new file mode 100644 index 00000000000..a6d9454f198 --- /dev/null +++ b/Misc/NEWS.d/3.5.0rc4.rst @@ -0,0 +1,17 @@ +.. bpo: 25029 +.. date: 9304 +.. nonce: Zf97rk +.. release date: 2015-09-09 +.. section: Library + +Fixes MemoryError in test_strptime. + +.. + +.. bpo: 25027 +.. date: 9303 +.. nonce: Zaib78 +.. section: Build + +Reverts partial-static build options and adds vcruntime140.dll to Windows +installation. diff --git a/Misc/NEWS.d/3.5.1.rst b/Misc/NEWS.d/3.5.1.rst new file mode 100644 index 00000000000..45df6f9bafd --- /dev/null +++ b/Misc/NEWS.d/3.5.1.rst @@ -0,0 +1,17 @@ +.. bpo: 25709 +.. date: 9452 +.. nonce: OPX2TS +.. release date: 2015-12-06 +.. section: Core and Builtins + +Fixed problem with in-place string concatenation and utf-8 cache. + +.. + +.. bpo: 25715 +.. date: 9451 +.. nonce: 3LLYLj +.. section: Windows + +Python 3.5.1 installer shows wrong upgrade path and incorrect logic for +launcher detection. diff --git a/Misc/NEWS.d/3.5.1rc1.rst b/Misc/NEWS.d/3.5.1rc1.rst new file mode 100644 index 00000000000..bb2d84a0109 --- /dev/null +++ b/Misc/NEWS.d/3.5.1rc1.rst @@ -0,0 +1,1451 @@ +.. bpo: 25630 +.. date: 9450 +.. nonce: ZxzcoY +.. release date: 2015-11-22 +.. section: Core and Builtins + +Fix a possible segfault during argument parsing in functions that accept +filesystem paths. + +.. + +.. bpo: 23564 +.. date: 9449 +.. nonce: XHarGG +.. section: Core and Builtins + +Fixed a partially broken sanity check in the _posixsubprocess internals +regarding how fds_to_pass were passed to the child. The bug had no actual +impact as subprocess.py already avoided it. + +.. + +.. bpo: 25388 +.. date: 9448 +.. nonce: zm3uuQ +.. section: Core and Builtins + +Fixed tokenizer crash when processing undecodable source code with a null +byte. + +.. + +.. bpo: 25462 +.. date: 9447 +.. nonce: eXDzgO +.. section: Core and Builtins + +The hash of the key now is calculated only once in most operations in C +implementation of OrderedDict. + +.. + +.. bpo: 22995 +.. date: 9446 +.. nonce: 90kpuP +.. section: Core and Builtins + +Default implementation of __reduce__ and __reduce_ex__ now rejects builtin +types with not defined __new__. + +.. + +.. bpo: 25555 +.. date: 9445 +.. nonce: MUpG-j +.. section: Core and Builtins + +Fix parser and AST: fill lineno and col_offset of "arg" node when compiling +AST from Python objects. + +.. + +.. bpo: 24802 +.. date: 9444 +.. nonce: Qie066 +.. section: Core and Builtins + +Avoid buffer overreads when int(), float(), compile(), exec() and eval() are +passed bytes-like objects. These objects are not necessarily terminated by +a null byte, but the functions assumed they were. + +.. + +.. bpo: 24726 +.. date: 9443 +.. nonce: AHk4v2 +.. section: Core and Builtins + +Fixed a crash and leaking NULL in repr() of OrderedDict that was mutated by +direct calls of dict methods. + +.. + +.. bpo: 25449 +.. date: 9442 +.. nonce: VqTOFi +.. section: Core and Builtins + +Iterating OrderedDict with keys with unstable hash now raises KeyError in C +implementations as well as in Python implementation. + +.. + +.. bpo: 25395 +.. date: 9441 +.. nonce: htkE3W +.. section: Core and Builtins + +Fixed crash when highly nested OrderedDict structures were garbage +collected. + +.. + +.. bpo: 25274 +.. date: 9440 +.. nonce: QCGvAF +.. section: Core and Builtins + +sys.setrecursionlimit() now raises a RecursionError if the new recursion +limit is too low depending at the current recursion depth. Modify also the +"lower-water mark" formula to make it monotonic. This mark is used to decide +when the overflowed flag of the thread state is reset. + +.. + +.. bpo: 24402 +.. date: 9439 +.. nonce: MAgi3X +.. section: Core and Builtins + +Fix input() to prompt to the redirected stdout when sys.stdout.fileno() +fails. + +.. + +.. bpo: 24806 +.. date: 9438 +.. nonce: Nb0znT +.. section: Core and Builtins + +Prevent builtin types that are not allowed to be subclassed from being +subclassed through multiple inheritance. + +.. + +.. bpo: 24848 +.. date: 9437 +.. nonce: HlUSuy +.. section: Core and Builtins + +Fixed a number of bugs in UTF-7 decoding of misformed data. + +.. + +.. bpo: 25280 +.. date: 9436 +.. nonce: ivTMwd +.. section: Core and Builtins + +Import trace messages emitted in verbose (-v) mode are no longer formatted +twice. + +.. + +.. bpo: 25003 +.. date: 9435 +.. nonce: _ban92 +.. section: Core and Builtins + +On Solaris 11.3 or newer, os.urandom() now uses the getrandom() function +instead of the getentropy() function. The getentropy() function is blocking +to generate very good quality entropy, os.urandom() doesn't need such high- +quality entropy. + +.. + +.. bpo: 25182 +.. date: 9434 +.. nonce: gBDq-T +.. section: Core and Builtins + +The stdprinter (used as sys.stderr before the io module is imported at +startup) now uses the backslashreplace error handler. + +.. + +.. bpo: 25131 +.. date: 9433 +.. nonce: j5hH6a +.. section: Core and Builtins + +Make the line number and column offset of set/dict literals and +comprehensions correspond to the opening brace. + +.. + +.. bpo: 25150 +.. date: 9432 +.. nonce: 0Gh-Ty +.. section: Core and Builtins + +Hide the private _Py_atomic_xxx symbols from the public Python.h header to +fix a compilation error with OpenMP. PyThreadState_GET() becomes an alias to +PyThreadState_Get() to avoid ABI incompatibilies. + +.. + +.. bpo: 25626 +.. date: 9431 +.. nonce: TQ3fvb +.. section: Library + +Change three zlib functions to accept sizes that fit in Py_ssize_t, but +internally cap those sizes to UINT_MAX. This resolves a regression in 3.5 +where GzipFile.read() failed to read chunks larger than 2 or 4 GiB. The +change affects the zlib.Decompress.decompress() max_length parameter, the +zlib.decompress() bufsize parameter, and the zlib.Decompress.flush() length +parameter. + +.. + +.. bpo: 25583 +.. date: 9430 +.. nonce: Gk-cim +.. section: Library + +Avoid incorrect errors raised by os.makedirs(exist_ok=True) when the OS +gives priority to errors such as EACCES over EEXIST. + +.. + +.. bpo: 25593 +.. date: 9429 +.. nonce: 56uegI +.. section: Library + +Change semantics of EventLoop.stop() in asyncio. + +.. + +.. bpo: 6973 +.. date: 9428 +.. nonce: nl5cHt +.. section: Library + +When we know a subprocess.Popen process has died, do not allow the +send_signal(), terminate(), or kill() methods to do anything as they could +potentially signal a different process. + +.. + +.. bpo: 25590 +.. date: 9427 +.. nonce: aCt-yW +.. section: Library + +In the Readline completer, only call getattr() once per attribute. + +.. + +.. bpo: 25498 +.. date: 9426 +.. nonce: AvqEBl +.. section: Library + +Fix a crash when garbage-collecting ctypes objects created by wrapping a +memoryview. This was a regression made in 3.5a1. Based on patch by +Eryksun. + +.. + +.. bpo: 25584 +.. date: 9425 +.. nonce: 124mYw +.. section: Library + +Added "escape" to the __all__ list in the glob module. + +.. + +.. bpo: 25584 +.. date: 9424 +.. nonce: ZeWX0J +.. section: Library + +Fixed recursive glob() with patterns starting with ``**``. + +.. + +.. bpo: 25446 +.. date: 9423 +.. nonce: k1DByx +.. section: Library + +Fix regression in smtplib's AUTH LOGIN support. + +.. + +.. bpo: 18010 +.. date: 9422 +.. nonce: Azyf1C +.. section: Library + +Fix the pydoc web server's module search function to handle exceptions from +importing packages. + +.. + +.. bpo: 25554 +.. date: 9421 +.. nonce: UM9MlR +.. section: Library + +Got rid of circular references in regular expression parsing. + +.. + +.. bpo: 25510 +.. date: 9420 +.. nonce: 79g7LA +.. section: Library + +fileinput.FileInput.readline() now returns b'' instead of '' at the end if +the FileInput was opened with binary mode. Patch by Ryosuke Ito. + +.. + +.. bpo: 25503 +.. date: 9419 +.. nonce: Zea0Y7 +.. section: Library + +Fixed inspect.getdoc() for inherited docstrings of properties. Original +patch by John Mark Vandenberg. + +.. + +.. bpo: 25515 +.. date: 9418 +.. nonce: fQsyYG +.. section: Library + +Always use os.urandom as a source of randomness in uuid.uuid4. + +.. + +.. bpo: 21827 +.. date: 9417 +.. nonce: k2oreR +.. section: Library + +Fixed textwrap.dedent() for the case when largest common whitespace is a +substring of smallest leading whitespace. Based on patch by Robert Li. + +.. + +.. bpo: 25447 +.. date: 9416 +.. nonce: eDYc4t +.. section: Library + +The lru_cache() wrapper objects now can be copied and pickled (by returning +the original object unchanged). + +.. + +.. bpo: 25390 +.. date: 9415 +.. nonce: 6mSgRq +.. section: Library + +typing: Don't crash on Union[str, Pattern]. + +.. + +.. bpo: 25441 +.. date: 9414 +.. nonce: d7zph6 +.. section: Library + +asyncio: Raise error from drain() when socket is closed. + +.. + +.. bpo: 25410 +.. date: 9413 +.. nonce: QAs_3B +.. section: Library + +Cleaned up and fixed minor bugs in C implementation of OrderedDict. + +.. + +.. bpo: 25411 +.. date: 9412 +.. nonce: qsJTCb +.. section: Library + +Improved Unicode support in SMTPHandler through better use of the email +package. Thanks to user simon04 for the patch. + +.. + +.. bpo: 25407 +.. date: 9411 +.. nonce: ukNt1D +.. section: Library + +Remove mentions of the formatter module being removed in Python 3.6. + +.. + +.. bpo: 25406 +.. date: 9410 +.. nonce: 5MZKU_ +.. section: Library + +Fixed a bug in C implementation of OrderedDict.move_to_end() that caused +segmentation fault or hang in iterating after moving several items to the +start of ordered dict. + +.. + +.. bpo: 25364 +.. date: 9409 +.. nonce: u_1Wi6 +.. section: Library + +zipfile now works in threads disabled builds. + +.. + +.. bpo: 25328 +.. date: 9408 +.. nonce: Rja1Xg +.. section: Library + +smtpd's SMTPChannel now correctly raises a ValueError if both decode_data +and enable_SMTPUTF8 are set to true. + +.. + +.. bpo: 25316 +.. date: 9407 +.. nonce: dHQHWI +.. section: Library + +distutils raises OSError instead of DistutilsPlatformError when MSVC is not +installed. + +.. + +.. bpo: 25380 +.. date: 9406 +.. nonce: sKZ6-I +.. section: Library + +Fixed protocol for the STACK_GLOBAL opcode in pickletools.opcodes. + +.. + +.. bpo: 23972 +.. date: 9405 +.. nonce: s2g30g +.. section: Library + +Updates asyncio datagram create method allowing reuseport and reuseaddr +socket options to be set prior to binding the socket. Mirroring the existing +asyncio create_server method the reuseaddr option for datagram sockets +defaults to True if the O/S is 'posix' (except if the platform is Cygwin). +Patch by Chris Laws. + +.. + +.. bpo: 25304 +.. date: 9404 +.. nonce: CsmLyI +.. section: Library + +Add asyncio.run_coroutine_threadsafe(). This lets you submit a coroutine to +a loop from another thread, returning a concurrent.futures.Future. By +Vincent Michel. + +.. + +.. bpo: 25232 +.. date: 9403 +.. nonce: KhKjCE +.. section: Library + +Fix CGIRequestHandler to split the query from the URL at the first question +mark (?) rather than the last. Patch from Xiang Zhang. + +.. + +.. bpo: 24657 +.. date: 9402 +.. nonce: h2Ag7y +.. section: Library + +Prevent CGIRequestHandler from collapsing slashes in the query part of the +URL as if it were a path. Patch from Xiang Zhang. + +.. + +.. bpo: 24483 +.. date: 9401 +.. nonce: WPLGSJ +.. section: Library + +C implementation of functools.lru_cache() now calculates key's hash only +once. + +.. + +.. bpo: 22958 +.. date: 9400 +.. nonce: Ebu7Gl +.. section: Library + +Constructor and update method of weakref.WeakValueDictionary now accept the +self and the dict keyword arguments. + +.. + +.. bpo: 22609 +.. date: 9399 +.. nonce: fV7hdV +.. section: Library + +Constructor of collections.UserDict now accepts the self keyword argument. + +.. + +.. bpo: 25111 +.. date: 9398 +.. nonce: azL4qE +.. section: Library + +Fixed comparison of traceback.FrameSummary. + +.. + +.. bpo: 25262 +.. date: 9397 +.. nonce: pQS5cB +.. section: Library + +Added support for BINBYTES8 opcode in Python implementation of unpickler. +Highest 32 bits of 64-bit size for BINUNICODE8 and BINBYTES8 opcodes no +longer silently ignored on 32-bit platforms in C implementation. + +.. + +.. bpo: 25034 +.. date: 9396 +.. nonce: eGvOIb +.. section: Library + +Fix string.Formatter problem with auto-numbering and nested format_specs. +Patch by Anthon van der Neut. + +.. + +.. bpo: 25233 +.. date: 9395 +.. nonce: EdZV9x +.. section: Library + +Rewrite the guts of asyncio.Queue and asyncio.Semaphore to be more +understandable and correct. + +.. + +.. bpo: 25203 +.. date: 9394 +.. nonce: IgDEbt +.. section: Library + +Failed readline.set_completer_delims() no longer left the module in +inconsistent state. + +.. + +.. bpo: 23600 +.. date: 9393 +.. nonce: 7J_RD5 +.. section: Library + +Default implementation of tzinfo.fromutc() was returning wrong results in +some cases. + +.. + +.. bpo: 23329 +.. date: 9392 +.. nonce: yccJBE +.. section: Library + +Allow the ssl module to be built with older versions of LibreSSL. + +.. + +.. bpo: 0 +.. date: 9391 +.. nonce: ww9QSm +.. section: Library + +Prevent overflow in _Unpickler_Read. + +.. + +.. bpo: 25047 +.. date: 9390 +.. nonce: kc8tqx +.. section: Library + +The XML encoding declaration written by Element Tree now respects the letter +case given by the user. This restores the ability to write encoding names in +uppercase like "UTF-8", which worked in Python 2. + +.. + +.. bpo: 25135 +.. date: 9389 +.. nonce: gVHNy- +.. section: Library + +Make deque_clear() safer by emptying the deque before clearing. This helps +avoid possible reentrancy issues. + +.. + +.. bpo: 19143 +.. date: 9388 +.. nonce: 76SBSO +.. section: Library + +platform module now reads Windows version from kernel32.dll to avoid +compatibility shims. + +.. + +.. bpo: 25092 +.. date: 9387 +.. nonce: fQ37Ac +.. section: Library + +Fix datetime.strftime() failure when errno was already set to EINVAL. + +.. + +.. bpo: 23517 +.. date: 9386 +.. nonce: 3ABmf1 +.. section: Library + +Fix rounding in fromtimestamp() and utcfromtimestamp() methods of +datetime.datetime: microseconds are now rounded to nearest with ties going +to nearest even integer (ROUND_HALF_EVEN), instead of being rounding towards +minus infinity (ROUND_FLOOR). It's important that these methods use the same +rounding mode than datetime.timedelta to keep the property: +(datetime(1970,1,1) + timedelta(seconds=t)) == datetime.utcfromtimestamp(t). +It also the rounding mode used by round(float) for example. + +.. + +.. bpo: 25155 +.. date: 9385 +.. nonce: JiETzD +.. section: Library + +Fix datetime.datetime.now() and datetime.datetime.utcnow() on Windows to +support date after year 2038. It was a regression introduced in Python +3.5.0. + +.. + +.. bpo: 25108 +.. date: 9384 +.. nonce: zGPbgA +.. section: Library + +Omitted internal frames in traceback functions print_stack(), +format_stack(), and extract_stack() called without arguments. + +.. + +.. bpo: 25118 +.. date: 9383 +.. nonce: wGm1u6 +.. section: Library + +Fix a regression of Python 3.5.0 in os.waitpid() on Windows. + +.. + +.. bpo: 24684 +.. date: 9382 +.. nonce: t4T77O +.. section: Library + +socket.socket.getaddrinfo() now calls PyUnicode_AsEncodedString() instead of +calling the encode() method of the host, to handle correctly custom string +with an encode() method which doesn't return a byte string. The encoder of +the IDNA codec is now called directly instead of calling the encode() method +of the string. + +.. + +.. bpo: 25060 +.. date: 9381 +.. nonce: zLdvIk +.. section: Library + +Correctly compute stack usage of the BUILD_MAP opcode. + +.. + +.. bpo: 24857 +.. date: 9380 +.. nonce: PpJWZ9 +.. section: Library + +Comparing call_args to a long sequence now correctly returns a boolean +result instead of raising an exception. Patch by A Kaptur. + +.. + +.. bpo: 23144 +.. date: 9379 +.. nonce: cLf67X +.. section: Library + +Make sure that HTMLParser.feed() returns all the data, even when +convert_charrefs is True. + +.. + +.. bpo: 24982 +.. date: 9378 +.. nonce: sGMMAR +.. section: Library + +shutil.make_archive() with the "zip" format now adds entries for directories +(including empty directories) in ZIP file. + +.. + +.. bpo: 25019 +.. date: 9377 +.. nonce: JQJlOZ +.. section: Library + +Fixed a crash caused by setting non-string key of expat parser. Based on +patch by John Leitch. + +.. + +.. bpo: 16180 +.. date: 9376 +.. nonce: 6IUcNS +.. section: Library + +Exit pdb if file has syntax error, instead of trapping user in an infinite +loop. Patch by Xavier de Gaye. + +.. + +.. bpo: 24891 +.. date: 9375 +.. nonce: ddVmHS +.. section: Library + +Fix a race condition at Python startup if the file descriptor of stdin (0), +stdout (1) or stderr (2) is closed while Python is creating sys.stdin, +sys.stdout and sys.stderr objects. These attributes are now set to None if +the creation of the object failed, instead of raising an OSError exception. +Initial patch written by Marco Paolini. + +.. + +.. bpo: 24992 +.. date: 9374 +.. nonce: 5sqF74 +.. section: Library + +Fix error handling and a race condition (related to garbage collection) in +collections.OrderedDict constructor. + +.. + +.. bpo: 24881 +.. date: 9373 +.. nonce: ZoVZXu +.. section: Library + +Fixed setting binary mode in Python implementation of FileIO on Windows and +Cygwin. Patch from Akira Li. + +.. + +.. bpo: 25578 +.. date: 9372 +.. nonce: G6S-ft +.. section: Library + +Fix (another) memory leak in SSLSocket.getpeercer(). + +.. + +.. bpo: 25530 +.. date: 9371 +.. nonce: hDFkwu +.. section: Library + +Disable the vulnerable SSLv3 protocol by default when creating +ssl.SSLContext. + +.. + +.. bpo: 25569 +.. date: 9370 +.. nonce: CfvQjK +.. section: Library + +Fix memory leak in SSLSocket.getpeercert(). + +.. + +.. bpo: 25471 +.. date: 9369 +.. nonce: T0A02M +.. section: Library + +Sockets returned from accept() shouldn't appear to be nonblocking. + +.. + +.. bpo: 25319 +.. date: 9368 +.. nonce: iyuglv +.. section: Library + +When threading.Event is reinitialized, the underlying condition should use a +regular lock rather than a recursive lock. + +.. + +.. bpo: 21112 +.. date: 9367 +.. nonce: vSFU1r +.. section: Library + +Fix regression in unittest.expectedFailure on subclasses. Patch from Berker +Peksag. + +.. + +.. bpo: 24764 +.. date: 9366 +.. nonce: QwFZ2S +.. section: Library + +cgi.FieldStorage.read_multi() now ignores the Content-Length header in part +headers. Patch written by Peter Landry and reviewed by Pierre Quentel. + +.. + +.. bpo: 24913 +.. date: 9365 +.. nonce: p2ZAJ4 +.. section: Library + +Fix overrun error in deque.index(). Found by John Leitch and Bryce Darling. + +.. + +.. bpo: 24774 +.. date: 9364 +.. nonce: xLbskG +.. section: Library + +Fix docstring in http.server.test. Patch from Chiu-Hsiang Hsu. + +.. + +.. bpo: 21159 +.. date: 9363 +.. nonce: ochL5W +.. section: Library + +Improve message in configparser.InterpolationMissingOptionError. Patch from +?ukasz Langa. + +.. + +.. bpo: 20362 +.. date: 9362 +.. nonce: 5aP_Ri +.. section: Library + +Honour TestCase.longMessage correctly in assertRegex. Patch from Ilia +Kurenkov. + +.. + +.. bpo: 23572 +.. date: 9361 +.. nonce: QhQ9RD +.. section: Library + +Fixed functools.singledispatch on classes with falsy metaclasses. Patch by +Ethan Furman. + +.. + +.. bpo: 0 +.. date: 9360 +.. nonce: DO1sFa +.. section: Library + +asyncio: ensure_future() now accepts awaitable objects. + +.. + +.. bpo: 15348 +.. date: 9359 +.. nonce: d1Fg01 +.. section: IDLE + +Stop the debugger engine (normally in a user process) before closing the +debugger window (running in the IDLE process). This prevents the +RuntimeErrors that were being caught and ignored. + +.. + +.. bpo: 24455 +.. date: 9358 +.. nonce: x6YqtE +.. section: IDLE + +Prevent IDLE from hanging when a) closing the shell while the debugger is +active (15347); b) closing the debugger with the [X] button (15348); and c) +activating the debugger when already active (24455). The patch by Mark +Roseman does this by making two changes. 1. Suspend and resume the +gui.interaction method with the tcl vwait mechanism intended for this +purpose (instead of root.mainloop & .quit). 2. In gui.run, allow any +existing interaction to terminate first. + +.. + +.. bpo: 0 +.. date: 9357 +.. nonce: Yp9LRY +.. section: IDLE + +Change 'The program' to 'Your program' in an IDLE 'kill program?' message to +make it clearer that the program referred to is the currently running user +program, not IDLE itself. + +.. + +.. bpo: 24750 +.. date: 9356 +.. nonce: xgsi-K +.. section: IDLE + +Improve the appearance of the IDLE editor window status bar. Patch by Mark +Roseman. + +.. + +.. bpo: 25313 +.. date: 9355 +.. nonce: xMXHpO +.. section: IDLE + +Change the handling of new built-in text color themes to better address the +compatibility problem introduced by the addition of IDLE Dark. Consistently +use the revised idleConf.CurrentTheme everywhere in idlelib. + +.. + +.. bpo: 24782 +.. date: 9354 +.. nonce: RgIPYE +.. section: IDLE + +Extension configuration is now a tab in the IDLE Preferences dialog rather +than a separate dialog. The former tabs are now a sorted list. Patch by +Mark Roseman. + +.. + +.. bpo: 22726 +.. date: 9353 +.. nonce: x8T0dA +.. section: IDLE + +Re-activate the config dialog help button with some content about the other +buttons and the new IDLE Dark theme. + +.. + +.. bpo: 24820 +.. date: 9352 +.. nonce: TFPJhr +.. section: IDLE + +IDLE now has an 'IDLE Dark' built-in text color theme. It is more or less +IDLE Classic inverted, with a cobalt blue background. Strings, comments, +keywords, ... are still green, red, orange, ... . To use it with IDLEs +released before November 2015, hit the 'Save as New Custom Theme' button and +enter a new name, such as 'Custom Dark'. The custom theme will work with +any IDLE release, and can be modified. + +.. + +.. bpo: 25224 +.. date: 9351 +.. nonce: 5Llwo4 +.. section: IDLE + +README.txt is now an idlelib index for IDLE developers and curious users. +The previous user content is now in the IDLE doc chapter. 'IDLE' now means +'Integrated Development and Learning Environment'. + +.. + +.. bpo: 24820 +.. date: 9350 +.. nonce: ZUz9Fn +.. section: IDLE + +Users can now set breakpoint colors in Settings -> Custom Highlighting. +Original patch by Mark Roseman. + +.. + +.. bpo: 24972 +.. date: 9349 +.. nonce: uc0uNo +.. section: IDLE + +Inactive selection background now matches active selection background, as +configured by users, on all systems. Found items are now always highlighted +on Windows. Initial patch by Mark Roseman. + +.. + +.. bpo: 24570 +.. date: 9348 +.. nonce: s3EkNn +.. section: IDLE + +Idle: make calltip and completion boxes appear on Macs affected by a tk +regression. Initial patch by Mark Roseman. + +.. + +.. bpo: 24988 +.. date: 9347 +.. nonce: tXqq4T +.. section: IDLE + +Idle ScrolledList context menus (used in debugger) now work on Mac Aqua. +Patch by Mark Roseman. + +.. + +.. bpo: 24801 +.. date: 9346 +.. nonce: -bj_Ou +.. section: IDLE + +Make right-click for context menu work on Mac Aqua. Patch by Mark Roseman. + +.. + +.. bpo: 25173 +.. date: 9345 +.. nonce: EZzrPg +.. section: IDLE + +Associate tkinter messageboxes with a specific widget. For Mac OSX, make +them a 'sheet'. Patch by Mark Roseman. + +.. + +.. bpo: 25198 +.. date: 9344 +.. nonce: -j_BV7 +.. section: IDLE + +Enhance the initial html viewer now used for Idle Help. * Properly indent +fixed-pitch text (patch by Mark Roseman). * Give code snippet a very Sphinx- +like light blueish-gray background. * Re-use initial width and height set by +users for shell and editor. * When the Table of Contents (TOC) menu is used, +put the section header at the top of the screen. + +.. + +.. bpo: 25225 +.. date: 9343 +.. nonce: 9pvdq6 +.. section: IDLE + +Condense and rewrite Idle doc section on text colors. + +.. + +.. bpo: 21995 +.. date: 9342 +.. nonce: C5Rmzx +.. section: IDLE + +Explain some differences between IDLE and console Python. + +.. + +.. bpo: 22820 +.. date: 9341 +.. nonce: hix_8X +.. section: IDLE + +Explain need for *print* when running file from Idle editor. + +.. + +.. bpo: 25224 +.. date: 9340 +.. nonce: UVMYQq +.. section: IDLE + +Doc: augment Idle feature list and no-subprocess section. + +.. + +.. bpo: 25219 +.. date: 9339 +.. nonce: 8_9DYg +.. section: IDLE + +Update doc for Idle command line options. Some were missing and notes were +not correct. + +.. + +.. bpo: 24861 +.. date: 9338 +.. nonce: Ecg2yT +.. section: IDLE + +Most of idlelib is private and subject to change. Use idleib.idle.* to start +Idle. See idlelib.__init__.__doc__. + +.. + +.. bpo: 25199 +.. date: 9337 +.. nonce: ih7yY3 +.. section: IDLE + +Idle: add synchronization comments for future maintainers. + +.. + +.. bpo: 16893 +.. date: 9336 +.. nonce: bZtPgJ +.. section: IDLE + +Replace help.txt with help.html for Idle doc display. The new +idlelib/help.html is rstripped Doc/build/html/library/idle.html. It looks +better than help.txt and will better document Idle as released. The tkinter +html viewer that works for this file was written by Mark Roseman. The now +unused EditorWindow.HelpDialog class and helt.txt file are deprecated. + +.. + +.. bpo: 24199 +.. date: 9335 +.. nonce: VKnZEv +.. section: IDLE + +Deprecate unused idlelib.idlever with possible removal in 3.6. + +.. + +.. bpo: 24790 +.. date: 9334 +.. nonce: hD1hlj +.. section: IDLE + +Remove extraneous code (which also create 2 & 3 conflicts). + +.. + +.. bpo: 22558 +.. date: 9333 +.. nonce: Pk02YC +.. section: Documentation + +Add remaining doc links to source code for Python-coded modules. Patch by +Yoni Lavi. + +.. + +.. bpo: 12067 +.. date: 9332 +.. nonce: nLD2M- +.. section: Documentation + +Rewrite Comparisons section in the Expressions chapter of the language +reference. Some of the details of comparing mixed types were incorrect or +ambiguous. NotImplemented is only relevant at a lower level than the +Expressions chapter. Added details of comparing range() objects, and default +behaviour and consistency suggestions for user-defined classes. Patch from +Andy Maier. + +.. + +.. bpo: 24952 +.. date: 9331 +.. nonce: RHhFPE +.. section: Documentation + +Clarify the default size argument of stack_size() in the "threading" and +"_thread" modules. Patch from Mattip. + +.. + +.. bpo: 23725 +.. date: 9330 +.. nonce: 49TZ5f +.. section: Documentation + +Overhaul tempfile docs. Note deprecated status of mktemp. Patch from +Zbigniew J?drzejewski-Szmek. + +.. + +.. bpo: 24808 +.. date: 9329 +.. nonce: MGjc3F +.. section: Documentation + +Update the types of some PyTypeObject fields. Patch by Joseph Weston. + +.. + +.. bpo: 22812 +.. date: 9328 +.. nonce: kLCF0G +.. section: Documentation + +Fix unittest discovery examples. Patch from Pam McA'Nulty. + +.. + +.. bpo: 25449 +.. date: 9327 +.. nonce: MP6KNs +.. section: Tests + +Added tests for OrderedDict subclasses. + +.. + +.. bpo: 25099 +.. date: 9326 +.. nonce: tJQOWx +.. section: Tests + +Make test_compileall not fail when an entry on sys.path cannot be written to +(commonly seen in administrative installs on Windows). + +.. + +.. bpo: 23919 +.. date: 9325 +.. nonce: vJnjaq +.. section: Tests + +Prevents assert dialogs appearing in the test suite. + +.. + +.. bpo: 0 +.. date: 9324 +.. nonce: X-Bk5l +.. section: Tests + +``PCbuild\rt.bat`` now accepts an unlimited number of arguments to pass +along to regrtest.py. Previously there was a limit of 9. + +.. + +.. bpo: 24915 +.. date: 9323 +.. nonce: PgD3Cx +.. section: Build + +Add LLVM support for PGO builds and use the test suite to generate the +profile data. Initial patch by Alecsandru Patrascu of Intel. + +.. + +.. bpo: 24910 +.. date: 9322 +.. nonce: ZZdfl0 +.. section: Build + +Windows MSIs now have unique display names. + +.. + +.. bpo: 24986 +.. date: 9321 +.. nonce: 1WyXeU +.. section: Build + +It is now possible to build Python on Windows without errors when external +libraries are not available. + +.. + +.. bpo: 25450 +.. date: 9320 +.. nonce: X4xlWf +.. section: Windows + +Updates shortcuts to start Python in installation directory. + +.. + +.. bpo: 25164 +.. date: 9319 +.. nonce: FHVOOA +.. section: Windows + +Changes default all-users install directory to match per-user directory. + +.. + +.. bpo: 25143 +.. date: 9318 +.. nonce: hmxsia +.. section: Windows + +Improves installer error messages for unsupported platforms. + +.. + +.. bpo: 25163 +.. date: 9317 +.. nonce: uCRe8H +.. section: Windows + +Display correct directory in installer when using non-default settings. + +.. + +.. bpo: 25361 +.. date: 9316 +.. nonce: GETaSY +.. section: Windows + +Disables use of SSE2 instructions in Windows 32-bit build + +.. + +.. bpo: 25089 +.. date: 9315 +.. nonce: n_YJgw +.. section: Windows + +Adds logging to installer for case where launcher is not selected on +upgrade. + +.. + +.. bpo: 25165 +.. date: 9314 +.. nonce: aUTN1e +.. section: Windows + +Windows uninstallation should not remove launcher if other versions remain + +.. + +.. bpo: 25112 +.. date: 9313 +.. nonce: frdKij +.. section: Windows + +py.exe launcher is missing icons + +.. + +.. bpo: 25102 +.. date: 9312 +.. nonce: 6y6Akl +.. section: Windows + +Windows installer does not precompile for -O or -OO. + +.. + +.. bpo: 25081 +.. date: 9311 +.. nonce: dcRCTO +.. section: Windows + +Makes Back button in installer go back to upgrade page when upgrading. + +.. + +.. bpo: 25091 +.. date: 9310 +.. nonce: 1u-VKy +.. section: Windows + +Increases font size of the installer. + +.. + +.. bpo: 25126 +.. date: 9309 +.. nonce: ANx3DW +.. section: Windows + +Clarifies that the non-web installer will download some components. + +.. + +.. bpo: 25213 +.. date: 9308 +.. nonce: KGmXoe +.. section: Windows + +Restores requestedExecutionLevel to manifest to disable UAC virtualization. + +.. + +.. bpo: 25022 +.. date: 9307 +.. nonce: vAt_zr +.. section: Windows + +Removed very outdated PC/example_nt/ directory. + +.. + +.. bpo: 25440 +.. date: 9306 +.. nonce: 5xhyGr +.. section: Tools/Demos + +Fix output of python-config --extension-suffix. diff --git a/Misc/NEWS.d/3.5.2.rst b/Misc/NEWS.d/3.5.2.rst new file mode 100644 index 00000000000..982b227962d --- /dev/null +++ b/Misc/NEWS.d/3.5.2.rst @@ -0,0 +1,25 @@ +.. bpo: 26930 +.. date: 9676 +.. nonce: 9JUeSD +.. release date: 2016-06-26 +.. section: Core and Builtins + +Update Windows builds to use OpenSSL 1.0.2h. + +.. + +.. bpo: 26867 +.. date: 9675 +.. nonce: QPSyP5 +.. section: Tests + +Ubuntu's openssl OP_NO_SSLv3 is forced on by default; fix test. + +.. + +.. bpo: 27365 +.. date: 9674 +.. nonce: ipkJ_M +.. section: IDLE + +Allow non-ascii in idlelib/NEWS.txt - minimal part for 3.5.2. diff --git a/Misc/NEWS.d/3.5.2rc1.rst b/Misc/NEWS.d/3.5.2rc1.rst new file mode 100644 index 00000000000..6a07020c0ac --- /dev/null +++ b/Misc/NEWS.d/3.5.2rc1.rst @@ -0,0 +1,2204 @@ +.. bpo: 27066 +.. date: 9673 +.. nonce: SNExZi +.. release date: 2016-06-12 +.. section: Core and Builtins + +Fixed SystemError if a custom opener (for open()) returns a negative number +without setting an exception. + +.. + +.. bpo: 20041 +.. date: 9672 +.. nonce: TypyGp +.. section: Core and Builtins + +Fixed TypeError when frame.f_trace is set to None. Patch by Xavier de Gaye. + +.. + +.. bpo: 26168 +.. date: 9671 +.. nonce: -nPBL6 +.. section: Core and Builtins + +Fixed possible refleaks in failing Py_BuildValue() with the "N" format unit. + +.. + +.. bpo: 26991 +.. date: 9670 +.. nonce: yWGNhz +.. section: Core and Builtins + +Fix possible refleak when creating a function with annotations. + +.. + +.. bpo: 27039 +.. date: 9669 +.. nonce: Zj7tV7 +.. section: Core and Builtins + +Fixed bytearray.remove() for values greater than 127. Patch by Joe Jevnik. + +.. + +.. bpo: 23640 +.. date: 9668 +.. nonce: kvNC4c +.. section: Core and Builtins + +int.from_bytes() no longer bypasses constructors for subclasses. + +.. + +.. bpo: 26811 +.. date: 9667 +.. nonce: oNzUWt +.. section: Core and Builtins + +gc.get_objects() no longer contains a broken tuple with NULL pointer. + +.. + +.. bpo: 20120 +.. date: 9666 +.. nonce: c-FZZc +.. section: Core and Builtins + +Use RawConfigParser for .pypirc parsing, removing support for interpolation +unintentionally added with move to Python 3. Behavior no longer does any +interpolation in .pypirc files, matching behavior in Python 2.7 and +Setuptools 19.0. + +.. + +.. bpo: 26659 +.. date: 9665 +.. nonce: 5PRa83 +.. section: Core and Builtins + +Make the builtin slice type support cycle collection. + +.. + +.. bpo: 26718 +.. date: 9664 +.. nonce: K5PQ8j +.. section: Core and Builtins + +super.__init__ no longer leaks memory if called multiple times. NOTE: A +direct call of super.__init__ is not endorsed! + +.. + +.. bpo: 25339 +.. date: 9663 +.. nonce: ZcaC2E +.. section: Core and Builtins + +PYTHONIOENCODING now has priority over locale in setting the error handler +for stdin and stdout. + +.. + +.. bpo: 26494 +.. date: 9662 +.. nonce: G6eXIi +.. section: Core and Builtins + +Fixed crash on iterating exhausting iterators. Affected classes are generic +sequence iterators, iterators of str, bytes, bytearray, list, tuple, set, +frozenset, dict, OrderedDict, corresponding views and os.scandir() iterator. + +.. + +.. bpo: 26581 +.. date: 9661 +.. nonce: yNA7nm +.. section: Core and Builtins + +If coding cookie is specified multiple times on a line in Python source code +file, only the first one is taken to account. + +.. + +.. bpo: 26464 +.. date: 9660 +.. nonce: 7BreGz +.. section: Core and Builtins + +Fix str.translate() when string is ASCII and first replacements removes +character, but next replacement uses a non-ASCII character or a string +longer than 1 character. Regression introduced in Python 3.5.0. + +.. + +.. bpo: 22836 +.. date: 9659 +.. nonce: cimt1y +.. section: Core and Builtins + +Ensure exception reports from PyErr_Display() and PyErr_WriteUnraisable() +are sensible even when formatting them produces secondary errors. This +affects the reports produced by sys.__excepthook__() and when __del__() +raises an exception. + +.. + +.. bpo: 26302 +.. date: 9658 +.. nonce: UD9XQt +.. section: Core and Builtins + +Correct behavior to reject comma as a legal character for cookie names. + +.. + +.. bpo: 4806 +.. date: 9657 +.. nonce: i9m3hj +.. section: Core and Builtins + +Avoid masking the original TypeError exception when using star (``*``) +unpacking in function calls. Based on patch by Hagen F?rstenau and Daniel +Urban. + +.. + +.. bpo: 27138 +.. date: 9656 +.. nonce: ifYEro +.. section: Core and Builtins + +Fix the doc comment for FileFinder.find_spec(). + +.. + +.. bpo: 26154 +.. date: 9655 +.. nonce: MtnRAH +.. section: Core and Builtins + +Add a new private _PyThreadState_UncheckedGet() function to get the current +Python thread state, but don't issue a fatal error if it is NULL. This new +function must be used instead of accessing directly the +_PyThreadState_Current variable. The variable is no more exposed since +Python 3.5.1 to hide the exact implementation of atomic C types, to avoid +compiler issues. + +.. + +.. bpo: 26194 +.. date: 9654 +.. nonce: j9zand +.. section: Core and Builtins + +Deque.insert() gave odd results for bounded deques that had reached their +maximum size. Now an IndexError will be raised when attempting to insert +into a full deque. + +.. + +.. bpo: 25843 +.. date: 9653 +.. nonce: t2kGug +.. section: Core and Builtins + +When compiling code, don't merge constants if they are equal but have a +different types. For example, ``f1, f2 = lambda: 1, lambda: 1.0`` is now +correctly compiled to two different functions: ``f1()`` returns ``1`` +(``int``) and ``f2()`` returns ``1.0`` (``int``), even if ``1`` and ``1.0`` +are equal. + +.. + +.. bpo: 22995 +.. date: 9652 +.. nonce: KYNKvs +.. section: Core and Builtins + +[UPDATE] Comment out the one of the pickleability tests in +_PyObject_GetState() due to regressions observed in Cython-based projects. + +.. + +.. bpo: 25961 +.. date: 9651 +.. nonce: Hdjjw0 +.. section: Core and Builtins + +Disallowed null characters in the type name. + +.. + +.. bpo: 25973 +.. date: 9650 +.. nonce: Ud__ZP +.. section: Core and Builtins + +Fix segfault when an invalid nonlocal statement binds a name starting with +two underscores. + +.. + +.. bpo: 22995 +.. date: 9649 +.. nonce: Wq0E86 +.. section: Core and Builtins + +Instances of extension types with a state that aren't subclasses of list or +dict and haven't implemented any pickle-related methods (__reduce__, +__reduce_ex__, __getnewargs__, __getnewargs_ex__, or __getstate__), can no +longer be pickled. Including memoryview. + +.. + +.. bpo: 20440 +.. date: 9648 +.. nonce: GCwOfH +.. section: Core and Builtins + +Massive replacing unsafe attribute setting code with special macro +Py_SETREF. + +.. + +.. bpo: 25766 +.. date: 9647 +.. nonce: jn93Yu +.. section: Core and Builtins + +Special method __bytes__() now works in str subclasses. + +.. + +.. bpo: 25421 +.. date: 9646 +.. nonce: c47YEL +.. section: Core and Builtins + +__sizeof__ methods of builtin types now use dynamic basic size. This allows +sys.getsize() to work correctly with their subclasses with __slots__ +defined. + +.. + +.. bpo: 25709 +.. date: 9645 +.. nonce: WwGm2k +.. section: Core and Builtins + +Fixed problem with in-place string concatenation and utf-8 cache. + +.. + +.. bpo: 27147 +.. date: 9644 +.. nonce: tCCgmH +.. section: Core and Builtins + +Mention PEP 420 in the importlib docs. + +.. + +.. bpo: 24097 +.. date: 9643 +.. nonce: Vt4E-i +.. section: Core and Builtins + +Fixed crash in object.__reduce__() if slot name is freed inside __getattr__. + +.. + +.. bpo: 24731 +.. date: 9642 +.. nonce: h9-hnz +.. section: Core and Builtins + +Fixed crash on converting objects with special methods __bytes__, __trunc__, +and __float__ returning instances of subclasses of bytes, int, and float to +subclasses of bytes, int, and float correspondingly. + +.. + +.. bpo: 26478 +.. date: 9641 +.. nonce: n0dB8e +.. section: Core and Builtins + +Fix semantic bugs when using binary operators with dictionary views and +tuples. + +.. + +.. bpo: 26171 +.. date: 9640 +.. nonce: 8SaQEa +.. section: Core and Builtins + +Fix possible integer overflow and heap corruption in zipimporter.get_data(). + +.. + +.. bpo: 25660 +.. date: 9639 +.. nonce: 93DzBo +.. section: Core and Builtins + +Fix TAB key behaviour in REPL with readline. + +.. + +.. bpo: 25887 +.. date: 9638 +.. nonce: PtVIX7 +.. section: Core and Builtins + +Raise a RuntimeError when a coroutine object is awaited more than once. + +.. + +.. bpo: 27243 +.. date: 9637 +.. nonce: U36M4E +.. section: Core and Builtins + +Update the __aiter__ protocol: instead of returning an awaitable that +resolves to an asynchronous iterator, the asynchronous iterator should be +returned directly. Doing the former will trigger a +PendingDeprecationWarning. + +.. + +.. bpo: 26556 +.. date: 9636 +.. nonce: v5j2uL +.. original section: Library +.. section: Security + +Update expat to 2.1.1, fixes CVE-2015-1283. + +.. + +.. bpo: 0 +.. date: 9635 +.. nonce: E4ochz +.. original section: Library +.. section: Security + +Fix TLS stripping vulnerability in smtplib, CVE-2016-0772. Reported by Team +Oststrom + +.. + +.. bpo: 21386 +.. date: 9634 +.. nonce: DjV72U +.. section: Library + +Implement missing IPv4Address.is_global property. It was documented since +07a5610bae9d. Initial patch by Roger Luethi. + +.. + +.. bpo: 20900 +.. date: 9633 +.. nonce: H5YQPR +.. section: Library + +distutils register command now decodes HTTP responses correctly. Initial +patch by ingrid. + +.. + +.. bpo: 0 +.. date: 9632 +.. nonce: iYIeng +.. section: Library + +A new version of typing.py provides several new classes and features: + at overload outside stubs, Reversible, DefaultDict, Text, ContextManager, +Type[], NewType(), TYPE_CHECKING, and numerous bug fixes (note that some of +the new features are not yet implemented in mypy or other static analyzers). +Also classes for PEP 492 (Awaitable, AsyncIterable, AsyncIterator) have been +added (in fact they made it into 3.5.1 but were never mentioned). + +.. + +.. bpo: 25738 +.. date: 9631 +.. nonce: mED9w4 +.. section: Library + +Stop http.server.BaseHTTPRequestHandler.send_error() from sending a message +body for 205 Reset Content. Also, don't send Content header fields in +responses that don't have a body. Patch by Susumu Koshiba. + +.. + +.. bpo: 21313 +.. date: 9630 +.. nonce: W30MBr +.. section: Library + +Fix the "platform" module to tolerate when sys.version contains truncated +build information. + +.. + +.. bpo: 26839 +.. date: 9629 +.. nonce: yVvy7R +.. original section: Library +.. section: Security + +On Linux, :func:`os.urandom` now calls ``getrandom()`` with +``GRND_NONBLOCK`` to fall back on reading ``/dev/urandom`` if the urandom +entropy pool is not initialized yet. Patch written by Colm Buckley. + +.. + +.. bpo: 27164 +.. date: 9628 +.. nonce: 6wmjx2 +.. section: Library + +In the zlib module, allow decompressing raw Deflate streams with a +predefined zdict. Based on patch by Xiang Zhang. + +.. + +.. bpo: 24291 +.. date: 9627 +.. nonce: Ac6HvL +.. section: Library + +Fix wsgiref.simple_server.WSGIRequestHandler to completely write data to the +client. Previously it could do partial writes and truncate data. Also, +wsgiref.handler.ServerHandler can now handle stdout doing partial writes, +but this is deprecated. + +.. + +.. bpo: 26809 +.. date: 9626 +.. nonce: ya7JMb +.. section: Library + +Add ``__all__`` to :mod:`string`. Patch by Emanuel Barry. + +.. + +.. bpo: 26373 +.. date: 9625 +.. nonce: P6qz6o +.. section: Library + +subprocess.Popen.communicate now correctly ignores BrokenPipeError when the +child process dies before .communicate() is called in more/all +circumstances. + +.. + +.. bpo: 21776 +.. date: 9624 +.. nonce: 04eQfa +.. section: Library + +distutils.upload now correctly handles HTTPError. Initial patch by Claudiu +Popa. + +.. + +.. bpo: 27114 +.. date: 9623 +.. nonce: bGCuAM +.. section: Library + +Fix SSLContext._load_windows_store_certs fails with PermissionError + +.. + +.. bpo: 18383 +.. date: 9622 +.. nonce: jr-b0l +.. section: Library + +Avoid creating duplicate filters when using filterwarnings and simplefilter. +Based on patch by Alex Shkop. + +.. + +.. bpo: 27057 +.. date: 9621 +.. nonce: YzTA_Q +.. section: Library + +Fix os.set_inheritable() on Android, ioctl() is blocked by SELinux and fails +with EACCESS. The function now falls back to fcntl(). Patch written by +Micha? Bednarski. + +.. + +.. bpo: 27014 +.. date: 9620 +.. nonce: ui7Khn +.. section: Library + +Fix infinite recursion using typing.py. Thanks to Kalle Tuure! + +.. + +.. bpo: 14132 +.. date: 9619 +.. nonce: 5wR9MN +.. section: Library + +Fix urllib.request redirect handling when the target only has a query +string. Original fix by J?n Janech. + +.. + +.. bpo: 17214 +.. date: 9618 +.. nonce: lUbZOV +.. section: Library + +The "urllib.request" module now percent-encodes non-ASCII bytes found in +redirect target URLs. Some servers send Location header fields with non- +ASCII bytes, but "http.client" requires the request target to be ASCII- +encodable, otherwise a UnicodeEncodeError is raised. Based on patch by +Christian Heimes. + +.. + +.. bpo: 26892 +.. date: 9617 +.. nonce: XIXb0h +.. section: Library + +Honor debuglevel flag in urllib.request.HTTPHandler. Patch contributed by +Chi Hsuan Yen. + +.. + +.. bpo: 22274 +.. date: 9616 +.. nonce: 0RHDMN +.. section: Library + +In the subprocess module, allow stderr to be redirected to stdout even when +stdout is not redirected. Patch by Akira Li. + +.. + +.. bpo: 26807 +.. date: 9615 +.. nonce: LXSPP6 +.. section: Library + +mock_open 'files' no longer error on readline at end of file. Patch from +Yolanda Robla. + +.. + +.. bpo: 25745 +.. date: 9614 +.. nonce: -n8acU +.. section: Library + +Fixed leaking a userptr in curses panel destructor. + +.. + +.. bpo: 26977 +.. date: 9613 +.. nonce: 5G4HtL +.. section: Library + +Removed unnecessary, and ignored, call to sum of squares helper in +statistics.pvariance. + +.. + +.. bpo: 26881 +.. date: 9612 +.. nonce: mdiq_L +.. section: Library + +The modulefinder module now supports extended opcode arguments. + +.. + +.. bpo: 23815 +.. date: 9611 +.. nonce: _krNe8 +.. section: Library + +Fixed crashes related to directly created instances of types in _tkinter and +curses.panel modules. + +.. + +.. bpo: 17765 +.. date: 9610 +.. nonce: hiSVS1 +.. section: Library + +weakref.ref() no longer silently ignores keyword arguments. Patch by Georg +Brandl. + +.. + +.. bpo: 26873 +.. date: 9609 +.. nonce: cYXRcH +.. section: Library + +xmlrpc now raises ResponseError on unsupported type tags instead of silently +return incorrect result. + +.. + +.. bpo: 26711 +.. date: 9608 +.. nonce: Eu85Qw +.. section: Library + +Fixed the comparison of plistlib.Data with other types. + +.. + +.. bpo: 24114 +.. date: 9607 +.. nonce: RMRMtM +.. section: Library + +Fix an uninitialized variable in `ctypes.util`. + +The bug only occurs on SunOS when the ctypes implementation searches for the +`crle` program. Patch by Xiang Zhang. Tested on SunOS by Kees Bos. + +.. + +.. bpo: 26864 +.. date: 9606 +.. nonce: 1KgGds +.. section: Library + +In urllib.request, change the proxy bypass host checking against no_proxy to +be case-insensitive, and to not match unrelated host names that happen to +have a bypassed hostname as a suffix. Patch by Xiang Zhang. + +.. + +.. bpo: 26634 +.. date: 9605 +.. nonce: FZvsSb +.. section: Library + +recursive_repr() now sets __qualname__ of wrapper. Patch by Xiang Zhang. + +.. + +.. bpo: 26804 +.. date: 9604 +.. nonce: 9Orp-G +.. section: Library + +urllib.request will prefer lower_case proxy environment variables over +UPPER_CASE or Mixed_Case ones. Patch contributed by Hans-Peter Jansen. + +.. + +.. bpo: 26837 +.. date: 9603 +.. nonce: 2FXGsD +.. section: Library + +assertSequenceEqual() now correctly outputs non-stringified differing items +(like bytes in the -b mode). This affects assertListEqual() and +assertTupleEqual(). + +.. + +.. bpo: 26041 +.. date: 9602 +.. nonce: bVem-p +.. section: Library + +Remove "will be removed in Python 3.7" from deprecation messages of +platform.dist() and platform.linux_distribution(). Patch by Kumaripaba +Miyurusara Athukorala. + +.. + +.. bpo: 26822 +.. date: 9601 +.. nonce: rYSL4W +.. section: Library + +itemgetter, attrgetter and methodcaller objects no longer silently ignore +keyword arguments. + +.. + +.. bpo: 26733 +.. date: 9600 +.. nonce: YxaJmL +.. section: Library + +Disassembling a class now disassembles class and static methods. Patch by +Xiang Zhang. + +.. + +.. bpo: 26801 +.. date: 9599 +.. nonce: TQGY-7 +.. section: Library + +Fix error handling in :func:`shutil.get_terminal_size`, catch +:exc:`AttributeError` instead of :exc:`NameError`. Patch written by Emanuel +Barry. + +.. + +.. bpo: 24838 +.. date: 9598 +.. nonce: 3Pfx8T +.. section: Library + +tarfile's ustar and gnu formats now correctly calculate name and link field +limits for multibyte character encodings like utf-8. + +.. + +.. bpo: 26657 +.. date: 9597 +.. nonce: C_-XFg +.. original section: Library +.. section: Security + +Fix directory traversal vulnerability with http.server on Windows. This +fixes a regression that was introduced in 3.3.4rc1 and 3.4.0rc1. Based on +patch by Philipp Hagemeister. + +.. + +.. bpo: 26717 +.. date: 9596 +.. nonce: jngTdu +.. section: Library + +Stop encoding Latin-1-ized WSGI paths with UTF-8. Patch by Anthony Sottile. + +.. + +.. bpo: 26735 +.. date: 9595 +.. nonce: riSl3b +.. section: Library + +Fix :func:`os.urandom` on Solaris 11.3 and newer when reading more than +1,024 bytes: call ``getrandom()`` multiple times with a limit of 1024 bytes +per call. + +.. + +.. bpo: 16329 +.. date: 9594 +.. nonce: nuXD8W +.. section: Library + +Add .webm to mimetypes.types_map. Patch by Giampaolo Rodola'. + +.. + +.. bpo: 13952 +.. date: 9593 +.. nonce: SOoTVE +.. section: Library + +Add .csv to mimetypes.types_map. Patch by Geoff Wilson. + +.. + +.. bpo: 26709 +.. date: 9592 +.. nonce: luOPbP +.. section: Library + +Fixed Y2038 problem in loading binary PLists. + +.. + +.. bpo: 23735 +.. date: 9591 +.. nonce: Y5oQ9r +.. section: Library + +Handle terminal resizing with Readline 6.3+ by installing our own SIGWINCH +handler. Patch by Eric Price. + +.. + +.. bpo: 26586 +.. date: 9590 +.. nonce: V5pZNa +.. section: Library + +In http.server, respond with "413 Request header fields too large" if there +are too many header fields to parse, rather than killing the connection and +raising an unhandled exception. Patch by Xiang Zhang. + +.. + +.. bpo: 22854 +.. date: 9589 +.. nonce: K3rMEH +.. section: Library + +Change BufferedReader.writable() and BufferedWriter.readable() to always +return False. + +.. + +.. bpo: 25195 +.. date: 9588 +.. nonce: EOc4Po +.. section: Library + +Fix a regression in mock.MagicMock. _Call is a subclass of tuple (changeset +3603bae63c13 only works for classes) so we need to implement __ne__ +ourselves. Patch by Andrew Plummer. + +.. + +.. bpo: 26644 +.. date: 9587 +.. nonce: 7tt1tk +.. section: Library + +Raise ValueError rather than SystemError when a negative length is passed to +SSLSocket.recv() or read(). + +.. + +.. bpo: 23804 +.. date: 9586 +.. nonce: PP63Ff +.. section: Library + +Fix SSL recv(0) and read(0) methods to return zero bytes instead of up to +1024. + +.. + +.. bpo: 26616 +.. date: 9585 +.. nonce: v3QwdD +.. section: Library + +Fixed a bug in datetime.astimezone() method. + +.. + +.. bpo: 21925 +.. date: 9584 +.. nonce: _fr69L +.. section: Library + +:func:`warnings.formatwarning` now catches exceptions on +``linecache.getline(...)`` to be able to log :exc:`ResourceWarning` emitted +late during the Python shutdown process. + +.. + +.. bpo: 24266 +.. date: 9583 +.. nonce: YZgVyM +.. section: Library + +Ctrl+C during Readline history search now cancels the search mode when +compiled with Readline 7. + +.. + +.. bpo: 26560 +.. date: 9582 +.. nonce: A4WXNz +.. section: Library + +Avoid potential ValueError in BaseHandler.start_response. Initial patch by +Peter Inglesby. + +.. + +.. bpo: 26313 +.. date: 9581 +.. nonce: LjZAjy +.. original section: Library +.. section: Security + +ssl.py _load_windows_store_certs fails if windows cert store is empty. Patch +by Baji. + +.. + +.. bpo: 26569 +.. date: 9580 +.. nonce: EX8vF1 +.. section: Library + +Fix :func:`pyclbr.readmodule` and :func:`pyclbr.readmodule_ex` to support +importing packages. + +.. + +.. bpo: 26499 +.. date: 9579 +.. nonce: NP08PI +.. section: Library + +Account for remaining Content-Length in HTTPResponse.readline() and read1(). +Based on patch by Silent Ghost. Also document that HTTPResponse now supports +these methods. + +.. + +.. bpo: 25320 +.. date: 9578 +.. nonce: V96LIy +.. section: Library + +Handle sockets in directories unittest discovery is scanning. Patch from +Victor van den Elzen. + +.. + +.. bpo: 16181 +.. date: 9577 +.. nonce: P7lLvo +.. section: Library + +cookiejar.http2time() now returns None if year is higher than +datetime.MAXYEAR. + +.. + +.. bpo: 26513 +.. date: 9576 +.. nonce: HoPepy +.. section: Library + +Fixes platform module detection of Windows Server + +.. + +.. bpo: 23718 +.. date: 9575 +.. nonce: AMPC0o +.. section: Library + +Fixed parsing time in week 0 before Jan 1. Original patch by Tam?s Bence +Gedai. + +.. + +.. bpo: 20589 +.. date: 9574 +.. nonce: NsQ_I1 +.. section: Library + +Invoking Path.owner() and Path.group() on Windows now raise +NotImplementedError instead of ImportError. + +.. + +.. bpo: 26177 +.. date: 9573 +.. nonce: HlSWer +.. section: Library + +Fixed the keys() method for Canvas and Scrollbar widgets. + +.. + +.. bpo: 15068 +.. date: 9572 +.. nonce: bcHtiw +.. section: Library + +Got rid of excessive buffering in the fileinput module. The bufsize +parameter is no longer used. + +.. + +.. bpo: 2202 +.. date: 9571 +.. nonce: dk9sd0 +.. section: Library + +Fix UnboundLocalError in AbstractDigestAuthHandler.get_algorithm_impls. +Initial patch by Mathieu Dupuy. + +.. + +.. bpo: 25718 +.. date: 9570 +.. nonce: 4EjZyv +.. section: Library + +Fixed pickling and copying the accumulate() iterator with total is None. + +.. + +.. bpo: 26475 +.. date: 9569 +.. nonce: JXVccY +.. section: Library + +Fixed debugging output for regular expressions with the (?x) flag. + +.. + +.. bpo: 26457 +.. date: 9568 +.. nonce: Xe6Clh +.. section: Library + +Fixed the subnets() methods in IP network classes for the case when +resulting prefix length is equal to maximal prefix length. Based on patch by +Xiang Zhang. + +.. + +.. bpo: 26385 +.. date: 9567 +.. nonce: 50bDXm +.. section: Library + +Remove the file if the internal open() call in NamedTemporaryFile() fails. +Patch by Silent Ghost. + +.. + +.. bpo: 26402 +.. date: 9566 +.. nonce: k7DVuU +.. section: Library + +Fix XML-RPC client to retry when the server shuts down a persistent +connection. This was a regression related to the new +http.client.RemoteDisconnected exception in 3.5.0a4. + +.. + +.. bpo: 25913 +.. date: 9565 +.. nonce: 5flb95 +.. section: Library + +Leading ``<~`` is optional now in base64.a85decode() with adobe=True. Patch +by Swati Jaiswal. + +.. + +.. bpo: 26186 +.. date: 9564 +.. nonce: R9rfiL +.. section: Library + +Remove an invalid type check in importlib.util.LazyLoader. + +.. + +.. bpo: 26367 +.. date: 9563 +.. nonce: ckpNeU +.. section: Library + +importlib.__import__() raises SystemError like builtins.__import__() when +``level`` is specified but without an accompanying package specified. + +.. + +.. bpo: 26309 +.. date: 9562 +.. nonce: ubEeiz +.. section: Library + +In the "socketserver" module, shut down the request (closing the connected +socket) when verify_request() returns false. Patch by Aviv Palivoda. + +.. + +.. bpo: 25939 +.. date: 9561 +.. nonce: X49Fqd +.. original section: Library +.. section: Security + +On Windows open the cert store readonly in ssl.enum_certificates. + +.. + +.. bpo: 25995 +.. date: 9560 +.. nonce: NfcimP +.. section: Library + +os.walk() no longer uses FDs proportional to the tree depth. + +.. + +.. bpo: 26117 +.. date: 9559 +.. nonce: ne6p11 +.. section: Library + +The os.scandir() iterator now closes file descriptor not only when the +iteration is finished, but when it was failed with error. + +.. + +.. bpo: 25911 +.. date: 9558 +.. nonce: d4Zadh +.. section: Library + +Restored support of bytes paths in os.walk() on Windows. + +.. + +.. bpo: 26045 +.. date: 9557 +.. nonce: WmzUrX +.. section: Library + +Add UTF-8 suggestion to error message when posting a non-Latin-1 string with +http.client. + +.. + +.. bpo: 12923 +.. date: 9556 +.. nonce: HPAu-B +.. section: Library + +Reset FancyURLopener's redirect counter even if there is an exception. +Based on patches by Brian Brazil and Daniel Rocco. + +.. + +.. bpo: 25945 +.. date: 9555 +.. nonce: guNgNM +.. section: Library + +Fixed a crash when unpickle the functools.partial object with wrong state. +Fixed a leak in failed functools.partial constructor. "args" and "keywords" +attributes of functools.partial have now always types tuple and dict +correspondingly. + +.. + +.. bpo: 26202 +.. date: 9554 +.. nonce: LPIXLg +.. section: Library + +copy.deepcopy() now correctly copies range() objects with non-atomic +attributes. + +.. + +.. bpo: 23076 +.. date: 9553 +.. nonce: 8rphoP +.. section: Library + +Path.glob() now raises a ValueError if it's called with an invalid pattern. +Patch by Thomas Nyberg. + +.. + +.. bpo: 19883 +.. date: 9552 +.. nonce: z9TsO6 +.. section: Library + +Fixed possible integer overflows in zipimport. + +.. + +.. bpo: 26227 +.. date: 9551 +.. nonce: Fe6oiB +.. section: Library + +On Windows, getnameinfo(), gethostbyaddr() and gethostbyname_ex() functions +of the socket module now decode the hostname from the ANSI code page rather +than UTF-8. + +.. + +.. bpo: 26147 +.. date: 9550 +.. nonce: i-Jc01 +.. section: Library + +xmlrpc now works with strings not encodable with used non-UTF-8 encoding. + +.. + +.. bpo: 25935 +.. date: 9549 +.. nonce: cyni91 +.. section: Library + +Garbage collector now breaks reference loops with OrderedDict. + +.. + +.. bpo: 16620 +.. date: 9548 +.. nonce: rxpn_Y +.. section: Library + +Fixed AttributeError in msilib.Directory.glob(). + +.. + +.. bpo: 26013 +.. date: 9547 +.. nonce: 93RKNz +.. section: Library + +Added compatibility with broken protocol 2 pickles created in old Python 3 +versions (3.4.3 and lower). + +.. + +.. bpo: 25850 +.. date: 9546 +.. nonce: jwFPxj +.. section: Library + +Use cross-compilation by default for 64-bit Windows. + +.. + +.. bpo: 17633 +.. date: 9545 +.. nonce: 9mpbUO +.. section: Library + +Improve zipimport's support for namespace packages. + +.. + +.. bpo: 24705 +.. date: 9544 +.. nonce: IZYwjR +.. section: Library + +Fix sysconfig._parse_makefile not expanding ${} vars appearing before $() +vars. + +.. + +.. bpo: 22138 +.. date: 9543 +.. nonce: nRNYkc +.. section: Library + +Fix mock.patch behavior when patching descriptors. Restore original values +after patching. Patch contributed by Sean McCully. + +.. + +.. bpo: 25672 +.. date: 9542 +.. nonce: fw9RJP +.. section: Library + +In the ssl module, enable the SSL_MODE_RELEASE_BUFFERS mode option if it is +safe to do so. + +.. + +.. bpo: 26012 +.. date: 9541 +.. nonce: IFSXNm +.. section: Library + +Don't traverse into symlinks for ``**`` pattern in pathlib.Path.[r]glob(). + +.. + +.. bpo: 24120 +.. date: 9540 +.. nonce: Yiwa0h +.. section: Library + +Ignore PermissionError when traversing a tree with pathlib.Path.[r]glob(). +Patch by Ulrich Petri. + +.. + +.. bpo: 25447 +.. date: 9539 +.. nonce: -4m4xO +.. section: Library + +fileinput now uses sys.stdin as-is if it does not have a buffer attribute +(restores backward compatibility). + +.. + +.. bpo: 25447 +.. date: 9538 +.. nonce: AtHkWA +.. section: Library + +Copying the lru_cache() wrapper object now always works, independedly from +the type of the wrapped object (by returning the original object unchanged). + +.. + +.. bpo: 24103 +.. date: 9537 +.. nonce: WufqrQ +.. section: Library + +Fixed possible use after free in ElementTree.XMLPullParser. + +.. + +.. bpo: 25860 +.. date: 9536 +.. nonce: 0hActb +.. section: Library + +os.fwalk() no longer skips remaining directories when error occurs. +Original patch by Samson Lee. + +.. + +.. bpo: 25914 +.. date: 9535 +.. nonce: h0V61F +.. section: Library + +Fixed and simplified OrderedDict.__sizeof__. + +.. + +.. bpo: 25902 +.. date: 9534 +.. nonce: 6t2FmH +.. section: Library + +Fixed various refcount issues in ElementTree iteration. + +.. + +.. bpo: 25717 +.. date: 9533 +.. nonce: 0_xjaK +.. section: Library + +Restore the previous behaviour of tolerating most fstat() errors when +opening files. This was a regression in 3.5a1, and stopped anonymous +temporary files from working in special cases. + +.. + +.. bpo: 24903 +.. date: 9532 +.. nonce: 3LBdzb +.. section: Library + +Fix regression in number of arguments compileall accepts when '-d' is +specified. The check on the number of arguments has been dropped completely +as it never worked correctly anyway. + +.. + +.. bpo: 25764 +.. date: 9531 +.. nonce: 7WWG07 +.. section: Library + +In the subprocess module, preserve any exception caused by fork() failure +when preexec_fn is used. + +.. + +.. bpo: 6478 +.. date: 9530 +.. nonce: -Bi9Hb +.. section: Library + +_strptime's regexp cache now is reset after changing timezone with +time.tzset(). + +.. + +.. bpo: 14285 +.. date: 9529 +.. nonce: UyG8Hj +.. section: Library + +When executing a package with the "python -m package" option, and package +initialization fails, a proper traceback is now reported. The "runpy" +module now lets exceptions from package initialization pass back to the +caller, rather than raising ImportError. + +.. + +.. bpo: 19771 +.. date: 9528 +.. nonce: 5NG-bg +.. section: Library + +Also in runpy and the "-m" option, omit the irrelevant message ". . . is a +package and cannot be directly executed" if the package could not even be +initialized (e.g. due to a bad ``*.pyc`` file). + +.. + +.. bpo: 25177 +.. date: 9527 +.. nonce: aNR4Ha +.. section: Library + +Fixed problem with the mean of very small and very large numbers. As a side +effect, statistics.mean and statistics.variance should be significantly +faster. + +.. + +.. bpo: 25718 +.. date: 9526 +.. nonce: D9mHZF +.. section: Library + +Fixed copying object with state with boolean value is false. + +.. + +.. bpo: 10131 +.. date: 9525 +.. nonce: a7tptz +.. section: Library + +Fixed deep copying of minidom documents. Based on patch by Marian Ganisin. + +.. + +.. bpo: 25725 +.. date: 9524 +.. nonce: XIKv3R +.. section: Library + +Fixed a reference leak in pickle.loads() when unpickling invalid data +including tuple instructions. + +.. + +.. bpo: 25663 +.. date: 9523 +.. nonce: Ofwfqa +.. section: Library + +In the Readline completer, avoid listing duplicate global names, and search +the global namespace before searching builtins. + +.. + +.. bpo: 25688 +.. date: 9522 +.. nonce: 8P1HOv +.. section: Library + +Fixed file leak in ElementTree.iterparse() raising an error. + +.. + +.. bpo: 23914 +.. date: 9521 +.. nonce: 1sEz4J +.. section: Library + +Fixed SystemError raised by unpickler on broken pickle data. + +.. + +.. bpo: 25691 +.. date: 9520 +.. nonce: ZEaapY +.. section: Library + +Fixed crash on deleting ElementTree.Element attributes. + +.. + +.. bpo: 25624 +.. date: 9519 +.. nonce: ed-fM0 +.. section: Library + +ZipFile now always writes a ZIP_STORED header for directory entries. Patch +by Dingyuan Wang. + +.. + +.. bpo: 0 +.. date: 9518 +.. nonce: rtZyid +.. section: Library + +Skip getaddrinfo if host is already resolved. Patch by A. Jesse Jiryu Davis. + +.. + +.. bpo: 26050 +.. date: 9517 +.. nonce: sclyvk +.. section: Library + +Add asyncio.StreamReader.readuntil() method. Patch by ???? ?????????. + +.. + +.. bpo: 25924 +.. date: 9516 +.. nonce: Uxr2vt +.. section: Library + +Avoid unnecessary serialization of getaddrinfo(3) calls on OS X versions +10.5 or higher. Original patch by A. Jesse Jiryu Davis. + +.. + +.. bpo: 26406 +.. date: 9515 +.. nonce: ihvhF4 +.. section: Library + +Avoid unnecessary serialization of getaddrinfo(3) calls on current versions +of OpenBSD and NetBSD. Patch by A. Jesse Jiryu Davis. + +.. + +.. bpo: 26848 +.. date: 9514 +.. nonce: ChBOpQ +.. section: Library + +Fix asyncio/subprocess.communicate() to handle empty input. Patch by Jack +O'Connor. + +.. + +.. bpo: 27040 +.. date: 9513 +.. nonce: UASyCC +.. section: Library + +Add loop.get_exception_handler method + +.. + +.. bpo: 27041 +.. date: 9512 +.. nonce: p3893U +.. section: Library + +asyncio: Add loop.create_future method + +.. + +.. bpo: 27223 +.. date: 9511 +.. nonce: PRf4I6 +.. section: Library + +asyncio: Fix _read_ready and _write_ready to respect _conn_lost. Patch by +?ukasz Langa. + +.. + +.. bpo: 22970 +.. date: 9510 +.. nonce: WhdhyM +.. section: Library + +asyncio: Fix inconsistency cancelling Condition.wait. Patch by David Coles. + +.. + +.. bpo: 5124 +.. date: 9509 +.. nonce: 4kwBvM +.. section: IDLE + +Paste with text selected now replaces the selection on X11. This matches how +paste works on Windows, Mac, most modern Linux apps, and ttk widgets. +Original patch by Serhiy Storchaka. + +.. + +.. bpo: 24759 +.. date: 9508 +.. nonce: ccmySu +.. section: IDLE + +Make clear in idlelib.idle_test.__init__ that the directory is a private +implementation of test.test_idle and tool for maintainers. + +.. + +.. bpo: 27196 +.. date: 9507 +.. nonce: 3yp8TF +.. section: IDLE + +Stop 'ThemeChanged' warnings when running IDLE tests. These persisted after +other warnings were suppressed in #20567. Apply Serhiy Storchaka's +update_idletasks solution to four test files. Record this additional advice +in idle_test/README.txt + +.. + +.. bpo: 20567 +.. date: 9506 +.. nonce: hhT32b +.. section: IDLE + +Revise idle_test/README.txt with advice about avoiding tk warning messages +from tests. Apply advice to several IDLE tests. + +.. + +.. bpo: 27117 +.. date: 9505 +.. nonce: YrLPf4 +.. section: IDLE + +Make colorizer htest and turtledemo work with dark themes. Move code for +configuring text widget colors to a new function. + +.. + +.. bpo: 26673 +.. date: 9504 +.. nonce: dh0_Ij +.. section: IDLE + +When tk reports font size as 0, change to size 10. Such fonts on Linux +prevented the configuration dialog from opening. + +.. + +.. bpo: 21939 +.. date: 9503 +.. nonce: pWz-OK +.. section: IDLE + +Add test for IDLE's percolator. Original patch by Saimadhav Heblikar. + +.. + +.. bpo: 21676 +.. date: 9502 +.. nonce: hqy6Qh +.. section: IDLE + +Add test for IDLE's replace dialog. Original patch by Saimadhav Heblikar. + +.. + +.. bpo: 18410 +.. date: 9501 +.. nonce: DLSPZo +.. section: IDLE + +Add test for IDLE's search dialog. Original patch by Westley Mart?nez. + +.. + +.. bpo: 21703 +.. date: 9500 +.. nonce: BAZfDM +.. section: IDLE + +Add test for IDLE's undo delegator. Original patch by Saimadhav Heblikar . + +.. + +.. bpo: 27044 +.. date: 9499 +.. nonce: 4y7tyM +.. section: IDLE + +Add ConfigDialog.remove_var_callbacks to stop memory leaks. + +.. + +.. bpo: 23977 +.. date: 9498 +.. nonce: miDjj8 +.. section: IDLE + +Add more asserts to test_delegator. + +.. + +.. bpo: 20640 +.. date: 9497 +.. nonce: PmI-G8 +.. section: IDLE + +Add tests for idlelib.configHelpSourceEdit. Patch by Saimadhav Heblikar. + +.. + +.. bpo: 0 +.. date: 9496 +.. nonce: _YJfG7 +.. section: IDLE + +In the 'IDLE-console differences' section of the IDLE doc, clarify how +running with IDLE affects sys.modules and the standard streams. + +.. + +.. bpo: 25507 +.. date: 9495 +.. nonce: i8bNpk +.. section: IDLE + +fix incorrect change in IOBinding that prevented printing. Augment IOBinding +htest to include all major IOBinding functions. + +.. + +.. bpo: 25905 +.. date: 9494 +.. nonce: FzNb3B +.. section: IDLE + +Revert unwanted conversion of ' to ? RIGHT SINGLE QUOTATION MARK in +README.txt and open this and NEWS.txt with 'ascii'. Re-encode CREDITS.txt to +utf-8 and open it with 'utf-8'. + +.. + +.. bpo: 19489 +.. date: 9493 +.. nonce: jvzuO7 +.. section: Documentation + +Moved the search box from the sidebar to the header and footer of each page. +Patch by Ammar Askar. + +.. + +.. bpo: 24136 +.. date: 9492 +.. nonce: MUK0zK +.. section: Documentation + +Document the new PEP 448 unpacking syntax of 3.5. + +.. + +.. bpo: 26736 +.. date: 9491 +.. nonce: U_Hyqo +.. section: Documentation + +Used HTTPS for external links in the documentation if possible. + +.. + +.. bpo: 6953 +.. date: 9490 +.. nonce: Zk6rno +.. section: Documentation + +Rework the Readline module documentation to group related functions +together, and add more details such as what underlying Readline functions +and variables are accessed. + +.. + +.. bpo: 23606 +.. date: 9489 +.. nonce: 9MhIso +.. section: Documentation + +Adds note to ctypes documentation regarding cdll.msvcrt. + +.. + +.. bpo: 25500 +.. date: 9488 +.. nonce: AV47eF +.. section: Documentation + +Fix documentation to not claim that __import__ is searched for in the global +scope. + +.. + +.. bpo: 26014 +.. date: 9487 +.. nonce: ptdZ_I +.. section: Documentation + +Update 3.x packaging documentation: * "See also" links to the new docs are +now provided in the legacy pages * links to setuptools documentation have +been updated + +.. + +.. bpo: 21916 +.. date: 9486 +.. nonce: muwCyp +.. section: Tests + +Added tests for the turtle module. Patch by ingrid, Gregory Loyse and Jelle +Zijlstra. + +.. + +.. bpo: 26523 +.. date: 9485 +.. nonce: em_Uzt +.. section: Tests + +The multiprocessing thread pool (multiprocessing.dummy.Pool) was untested. + +.. + +.. bpo: 26015 +.. date: 9484 +.. nonce: p3oWK3 +.. section: Tests + +Added new tests for pickling iterators of mutable sequences. + +.. + +.. bpo: 26325 +.. date: 9483 +.. nonce: KOUc82 +.. section: Tests + +Added test.support.check_no_resource_warning() to check that no +ResourceWarning is emitted. + +.. + +.. bpo: 25940 +.. date: 9482 +.. nonce: PgiLVN +.. section: Tests + +Changed test_ssl to use self-signed.pythontest.net. This avoids relying on +svn.python.org, which recently changed root certificate. + +.. + +.. bpo: 25616 +.. date: 9481 +.. nonce: Qr-60p +.. section: Tests + +Tests for OrderedDict are extracted from test_collections into separate file +test_ordered_dict. + +.. + +.. bpo: 26583 +.. date: 9480 +.. nonce: Up7hTl +.. section: Tests + +Skip test_timestamp_overflow in test_import if bytecode files cannot be +written. + +.. + +.. bpo: 26884 +.. date: 9479 +.. nonce: O8-azL +.. section: Build + +Fix linking extension modules for cross builds. Patch by Xavier de Gaye. + +.. + +.. bpo: 22359 +.. date: 9478 +.. nonce: HDjM4s +.. section: Build + +Disable the rules for running _freeze_importlib and pgen when cross- +compiling. The output of these programs is normally saved with the source +code anyway, and is still regenerated when doing a native build. Patch by +Xavier de Gaye. + +.. + +.. bpo: 27229 +.. date: 9477 +.. nonce: C2NDch +.. section: Build + +Fix the cross-compiling pgen rule for in-tree builds. Patch by Xavier de +Gaye. + +.. + +.. bpo: 21668 +.. date: 9476 +.. nonce: 4sMAa1 +.. section: Build + +Link audioop, _datetime, _ctypes_test modules to libm, except on Mac OS X. +Patch written by Xavier de Gaye. + +.. + +.. bpo: 25702 +.. date: 9475 +.. nonce: ipxyJs +.. section: Build + +A --with-lto configure option has been added that will enable link time +optimizations at build time during a make profile-opt. Some compilers and +toolchains are known to not produce stable code when using LTO, be sure to +test things thoroughly before relying on it. It can provide a few % speed up +over profile-opt alone. + +.. + +.. bpo: 26624 +.. date: 9474 +.. nonce: 4fGrTl +.. section: Build + +Adds validation of ucrtbase[d].dll version with warning for old versions. + +.. + +.. bpo: 17603 +.. date: 9473 +.. nonce: 102DA- +.. section: Build + +Avoid error about nonexistant fileblocks.o file by using a lower-level check +for st_blocks in struct stat. + +.. + +.. bpo: 26079 +.. date: 9472 +.. nonce: mEzW0O +.. section: Build + +Fixing the build output folder for tix-8.4.3.6. Patch by Bjoern Thiel. + +.. + +.. bpo: 26465 +.. date: 9471 +.. nonce: _YR608 +.. section: Build + +Update Windows builds to use OpenSSL 1.0.2g. + +.. + +.. bpo: 24421 +.. date: 9470 +.. nonce: 2zY7vM +.. section: Build + +Compile Modules/_math.c once, before building extensions. Previously it +could fail to compile properly if the math and cmath builds were concurrent. + +.. + +.. bpo: 25348 +.. date: 9469 +.. nonce: u6_BaQ +.. section: Build + +Added ``--pgo`` and ``--pgo-job`` arguments to ``PCbuild\build.bat`` for +building with Profile-Guided Optimization. The old +``PCbuild\build_pgo.bat`` script is now deprecated, and simply calls +``PCbuild\build.bat --pgo %*``. + +.. + +.. bpo: 25827 +.. date: 9468 +.. nonce: yg3DMM +.. section: Build + +Add support for building with ICC to ``configure``, including a new +``--with-icc`` flag. + +.. + +.. bpo: 25696 +.. date: 9467 +.. nonce: 2R_wIv +.. section: Build + +Fix installation of Python on UNIX with make -j9. + +.. + +.. bpo: 26930 +.. date: 9466 +.. nonce: Sqz2O3 +.. section: Build + +Update OS X 10.5+ 32-bit-only installer to build and link with OpenSSL +1.0.2h. + +.. + +.. bpo: 26268 +.. date: 9465 +.. nonce: I3-YLh +.. section: Build + +Update Windows builds to use OpenSSL 1.0.2f. + +.. + +.. bpo: 25136 +.. date: 9464 +.. nonce: Vi-fmO +.. section: Build + +Support Apple Xcode 7's new textual SDK stub libraries. + +.. + +.. bpo: 24324 +.. date: 9463 +.. nonce: m6DZMx +.. section: Build + +Do not enable unreachable code warnings when using gcc as the option does +not work correctly in older versions of gcc and has been silently removed as +of gcc-4.5. + +.. + +.. bpo: 27053 +.. date: 9462 +.. nonce: 1IRbae +.. section: Windows + +Updates make_zip.py to correctly generate library ZIP file. + +.. + +.. bpo: 26268 +.. date: 9461 +.. nonce: Z-lJEh +.. section: Windows + +Update the prepare_ssl.py script to handle OpenSSL releases that don't +include the contents of the include directory (that is, 1.0.2e and later). + +.. + +.. bpo: 26071 +.. date: 9460 +.. nonce: wLxL2l +.. section: Windows + +bdist_wininst created binaries fail to start and find 32bit Python + +.. + +.. bpo: 26073 +.. date: 9459 +.. nonce: XwWgHp +.. section: Windows + +Update the list of magic numbers in launcher + +.. + +.. bpo: 26065 +.. date: 9458 +.. nonce: SkVLJp +.. section: Windows + +Excludes venv from library when generating embeddable distro. + +.. + +.. bpo: 26799 +.. date: 9457 +.. nonce: gK2VXX +.. section: Tools/Demos + +Fix python-gdb.py: don't get C types once when the Python code is loaded, +but get C types on demand. The C types can change if python-gdb.py is loaded +before the Python executable. Patch written by Thomas Ilsche. + +.. + +.. bpo: 26271 +.. date: 9456 +.. nonce: wg-rzr +.. section: Tools/Demos + +Fix the Freeze tool to properly use flags passed through configure. Patch by +Daniel Shaulov. + +.. + +.. bpo: 26489 +.. date: 9455 +.. nonce: rJ_U5S +.. section: Tools/Demos + +Add dictionary unpacking support to Tools/parser/unparse.py. Patch by Guo Ci +Teo. + +.. + +.. bpo: 26316 +.. date: 9454 +.. nonce: QJvVOi +.. section: Tools/Demos + +Fix variable name typo in Argument Clinic. + +.. + +.. bpo: 17500 +.. date: 9453 +.. nonce: QTZbRV +.. section: Windows + +Remove unused and outdated icons. (See also: +https://github.com/python/pythondotorg/issues/945) diff --git a/Misc/NEWS.d/3.5.3.rst b/Misc/NEWS.d/3.5.3.rst new file mode 100644 index 00000000000..c3fcb67a456 --- /dev/null +++ b/Misc/NEWS.d/3.5.3.rst @@ -0,0 +1,7 @@ +.. bpo: 0 +.. date: 9899 +.. no changes: True +.. nonce: zYPqUK +.. release date: 2017-01-17 + +There were no code changes between 3.5.3rc1 and 3.5.3 final. diff --git a/Misc/NEWS.d/3.5.3rc1.rst b/Misc/NEWS.d/3.5.3rc1.rst new file mode 100644 index 00000000000..99b4675ed5e --- /dev/null +++ b/Misc/NEWS.d/3.5.3rc1.rst @@ -0,0 +1,2164 @@ +.. bpo: 29073 +.. date: 9898 +.. nonce: EFpHQ7 +.. release date: 2017-01-02 +.. section: Core and Builtins + +bytearray formatting no longer truncates on first null byte. + +.. + +.. bpo: 28932 +.. date: 9897 +.. nonce: QnLx8A +.. section: Core and Builtins + +Do not include if it does not exist. + +.. + +.. bpo: 28147 +.. date: 9896 +.. nonce: EV4bm6 +.. section: Core and Builtins + +Fix a memory leak in split-table dictionaries: setattr() must not convert +combined table into split table. + +.. + +.. bpo: 25677 +.. date: 9895 +.. nonce: RWhZrb +.. section: Core and Builtins + +Correct the positioning of the syntax error caret for indented blocks. +Based on patch by Michael Layzell. + +.. + +.. bpo: 29000 +.. date: 9894 +.. nonce: K6wQ-3 +.. section: Core and Builtins + +Fixed bytes formatting of octals with zero padding in alternate form. + +.. + +.. bpo: 28512 +.. date: 9893 +.. nonce: i-pv6d +.. section: Core and Builtins + +Fixed setting the offset attribute of SyntaxError by +PyErr_SyntaxLocationEx() and PyErr_SyntaxLocationObject(). + +.. + +.. bpo: 28991 +.. date: 9892 +.. nonce: -qOTxS +.. section: Core and Builtins + +functools.lru_cache() was susceptible to an obscure reentrancy bug caused by +a monkey-patched len() function. + +.. + +.. bpo: 28648 +.. date: 9891 +.. nonce: z7B52W +.. section: Core and Builtins + +Fixed crash in Py_DecodeLocale() in debug build on Mac OS X when decode +astral characters. Patch by Xiang Zhang. + +.. + +.. bpo: 19398 +.. date: 9890 +.. nonce: RYbEGH +.. section: Core and Builtins + +Extra slash no longer added to sys.path components in case of empty compile- +time PYTHONPATH components. + +.. + +.. bpo: 28426 +.. date: 9889 +.. nonce: E_quyK +.. section: Core and Builtins + +Fixed potential crash in PyUnicode_AsDecodedObject() in debug build. + +.. + +.. bpo: 23782 +.. date: 9888 +.. nonce: lonDzj +.. section: Core and Builtins + +Fixed possible memory leak in _PyTraceback_Add() and exception loss in +PyTraceBack_Here(). + +.. + +.. bpo: 28379 +.. date: 9887 +.. nonce: DuXlco +.. section: Core and Builtins + +Added sanity checks and tests for PyUnicode_CopyCharacters(). Patch by Xiang +Zhang. + +.. + +.. bpo: 28376 +.. date: 9886 +.. nonce: oPD-5D +.. section: Core and Builtins + +The type of long range iterator is now registered as Iterator. Patch by Oren +Milman. + +.. + +.. bpo: 28376 +.. date: 9885 +.. nonce: fLeHM2 +.. section: Core and Builtins + +The constructor of range_iterator now checks that step is not 0. Patch by +Oren Milman. + +.. + +.. bpo: 26906 +.. date: 9884 +.. nonce: YBjcwI +.. section: Core and Builtins + +Resolving special methods of uninitialized type now causes implicit +initialization of the type instead of a fail. + +.. + +.. bpo: 18287 +.. date: 9883 +.. nonce: k6jffS +.. section: Core and Builtins + +PyType_Ready() now checks that tp_name is not NULL. Original patch by Niklas +Koep. + +.. + +.. bpo: 24098 +.. date: 9882 +.. nonce: XqlP_1 +.. section: Core and Builtins + +Fixed possible crash when AST is changed in process of compiling it. + +.. + +.. bpo: 28350 +.. date: 9881 +.. nonce: 8M5Eg9 +.. section: Core and Builtins + +String constants with null character no longer interned. + +.. + +.. bpo: 26617 +.. date: 9880 +.. nonce: Gh5LvN +.. section: Core and Builtins + +Fix crash when GC runs during weakref callbacks. + +.. + +.. bpo: 27942 +.. date: 9879 +.. nonce: ZGuhns +.. section: Core and Builtins + +String constants now interned recursively in tuples and frozensets. + +.. + +.. bpo: 21578 +.. date: 9878 +.. nonce: GI1bhj +.. section: Core and Builtins + +Fixed misleading error message when ImportError called with invalid keyword +args. + +.. + +.. bpo: 28203 +.. date: 9877 +.. nonce: kOgvtp +.. section: Core and Builtins + +Fix incorrect type in error message from ``complex(1.0, {2:3})``. Patch by +Soumya Sharma. + +.. + +.. bpo: 27955 +.. date: 9876 +.. nonce: HC4pZ4 +.. section: Core and Builtins + +Fallback on reading /dev/urandom device when the getrandom() syscall fails +with EPERM, for example when blocked by SECCOMP. + +.. + +.. bpo: 28131 +.. date: 9875 +.. nonce: owq0wW +.. section: Core and Builtins + +Fix a regression in zipimport's compile_source(). zipimport should use the +same optimization level as the interpreter. + +.. + +.. bpo: 25221 +.. date: 9874 +.. nonce: Zvkz9i +.. section: Core and Builtins + +Fix corrupted result from PyLong_FromLong(0) when Python is compiled with +NSMALLPOSINTS = 0. + +.. + +.. bpo: 25758 +.. date: 9873 +.. nonce: yR-YTD +.. section: Core and Builtins + +Prevents zipimport from unnecessarily encoding a filename (patch by Eryk +Sun) + +.. + +.. bpo: 28189 +.. date: 9872 +.. nonce: c_nbR_ +.. section: Core and Builtins + +dictitems_contains no longer swallows compare errors. (Patch by Xiang Zhang) + +.. + +.. bpo: 27812 +.. date: 9871 +.. nonce: sidcs8 +.. section: Core and Builtins + +Properly clear out a generator's frame's backreference to the generator to +prevent crashes in frame.clear(). + +.. + +.. bpo: 27811 +.. date: 9870 +.. nonce: T4AuBo +.. section: Core and Builtins + +Fix a crash when a coroutine that has not been awaited is finalized with +warnings-as-errors enabled. + +.. + +.. bpo: 27587 +.. date: 9869 +.. nonce: mbavY2 +.. section: Core and Builtins + +Fix another issue found by PVS-Studio: Null pointer check after use of 'def' +in _PyState_AddModule(). Initial patch by Christian Heimes. + +.. + +.. bpo: 26020 +.. date: 9868 +.. nonce: niLbLa +.. section: Core and Builtins + +set literal evaluation order did not match documented behaviour. + +.. + +.. bpo: 27782 +.. date: 9867 +.. nonce: C8OBQD +.. section: Core and Builtins + +Multi-phase extension module import now correctly allows the ``m_methods`` +field to be used to add module level functions to instances of non-module +types returned from ``Py_create_mod``. Patch by Xiang Zhang. + +.. + +.. bpo: 27936 +.. date: 9866 +.. nonce: AdOann +.. section: Core and Builtins + +The round() function accepted a second None argument for some types but not +for others. Fixed the inconsistency by accepting None for all numeric +types. + +.. + +.. bpo: 27487 +.. date: 9865 +.. nonce: jeTQNr +.. section: Core and Builtins + +Warn if a submodule argument to "python -m" or runpy.run_module() is found +in sys.modules after parent packages are imported, but before the submodule +is executed. + +.. + +.. bpo: 27558 +.. date: 9864 +.. nonce: VmltMh +.. section: Core and Builtins + +Fix a SystemError in the implementation of "raise" statement. In a brand new +thread, raise a RuntimeError since there is no active exception to reraise. +Patch written by Xiang Zhang. + +.. + +.. bpo: 27419 +.. date: 9863 +.. nonce: JZ94ju +.. section: Core and Builtins + +Standard __import__() no longer look up "__import__" in globals or builtins +for importing submodules or "from import". Fixed handling an error of non- +string package name. + +.. + +.. bpo: 27083 +.. date: 9862 +.. nonce: F4ZT1C +.. section: Core and Builtins + +Respect the PYTHONCASEOK environment variable under Windows. + +.. + +.. bpo: 27514 +.. date: 9861 +.. nonce: NLbwPG +.. section: Core and Builtins + +Make having too many statically nested blocks a SyntaxError instead of +SystemError. + +.. + +.. bpo: 27473 +.. date: 9860 +.. nonce: _nOtTA +.. section: Core and Builtins + +Fixed possible integer overflow in bytes and bytearray concatenations. +Patch by Xiang Zhang. + +.. + +.. bpo: 27507 +.. date: 9859 +.. nonce: 3pX0Be +.. section: Core and Builtins + +Add integer overflow check in bytearray.extend(). Patch by Xiang Zhang. + +.. + +.. bpo: 27581 +.. date: 9858 +.. nonce: KezjNt +.. section: Core and Builtins + +Don't rely on wrapping for overflow check in PySequence_Tuple(). Patch by +Xiang Zhang. + +.. + +.. bpo: 27443 +.. date: 9857 +.. nonce: 87ZwZ1 +.. section: Core and Builtins + +__length_hint__() of bytearray iterators no longer return a negative integer +for a resized bytearray. + +.. + +.. bpo: 27942 +.. date: 9856 +.. nonce: wCAkW5 +.. section: Core and Builtins + +Fix memory leak in codeobject.c + +.. + +.. bpo: 15812 +.. date: 9855 +.. nonce: R1U-Ec +.. section: Library + +inspect.getframeinfo() now correctly shows the first line of a context. +Patch by Sam Breese. + +.. + +.. bpo: 29094 +.. date: 9854 +.. nonce: 460ZQo +.. section: Library + +Offsets in a ZIP file created with extern file object and modes "w" and "x" +now are relative to the start of the file. + +.. + +.. bpo: 13051 +.. date: 9853 +.. nonce: YzC1Te +.. section: Library + +Fixed recursion errors in large or resized curses.textpad.Textbox. Based on +patch by Tycho Andersen. + +.. + +.. bpo: 29119 +.. date: 9852 +.. nonce: Ov69fr +.. section: Library + +Fix weakrefs in the pure python version of collections.OrderedDict +move_to_end() method. Contributed by Andra Bogildea. + +.. + +.. bpo: 9770 +.. date: 9851 +.. nonce: WJJnwP +.. section: Library + +curses.ascii predicates now work correctly with negative integers. + +.. + +.. bpo: 28427 +.. date: 9850 +.. nonce: vUd-va +.. section: Library + +old keys should not remove new values from WeakValueDictionary when +collecting from another thread. + +.. + +.. bpo: 28923 +.. date: 9849 +.. nonce: naVULD +.. section: Library + +Remove editor artifacts from Tix.py. + +.. + +.. bpo: 28871 +.. date: 9848 +.. nonce: cPMXCJ +.. section: Library + +Fixed a crash when deallocate deep ElementTree. + +.. + +.. bpo: 19542 +.. date: 9847 +.. nonce: 5tCkaK +.. section: Library + +Fix bugs in WeakValueDictionary.setdefault() and WeakValueDictionary.pop() +when a GC collection happens in another thread. + +.. + +.. bpo: 20191 +.. date: 9846 +.. nonce: P_EZ7c +.. section: Library + +Fixed a crash in resource.prlimit() when pass a sequence that doesn't own +its elements as limits. + +.. + +.. bpo: 28779 +.. date: 9845 +.. nonce: t-mjED +.. section: Library + +multiprocessing.set_forkserver_preload() would crash the forkserver process +if a preloaded module instantiated some multiprocessing objects such as +locks. + +.. + +.. bpo: 28847 +.. date: 9844 +.. nonce: J7d3nG +.. section: Library + +dbm.dumb now supports reading read-only files and no longer writes the index +file when it is not changed. + +.. + +.. bpo: 25659 +.. date: 9843 +.. nonce: lE2IlT +.. section: Library + +In ctypes, prevent a crash calling the from_buffer() and from_buffer_copy() +methods on abstract classes like Array. + +.. + +.. bpo: 28732 +.. date: 9842 +.. nonce: xkG8k7 +.. section: Library + +Fix crash in os.spawnv() with no elements in args + +.. + +.. bpo: 28485 +.. date: 9841 +.. nonce: WuKqKh +.. section: Library + +Always raise ValueError for negative compileall.compile_dir(workers=...) +parameter, even when multithreading is unavailable. + +.. + +.. bpo: 28387 +.. date: 9840 +.. nonce: 1clJu7 +.. section: Library + +Fixed possible crash in _io.TextIOWrapper deallocator when the garbage +collector is invoked in other thread. Based on patch by Sebastian Cufre. + +.. + +.. bpo: 27517 +.. date: 9839 +.. nonce: 1CYM8A +.. section: Library + +LZMA compressor and decompressor no longer raise exceptions if given empty +data twice. Patch by Benjamin Fogle. + +.. + +.. bpo: 28549 +.. date: 9838 +.. nonce: ShnM2y +.. section: Library + +Fixed segfault in curses's addch() with ncurses6. + +.. + +.. bpo: 28449 +.. date: 9837 +.. nonce: 5JK6ES +.. section: Library + +tarfile.open() with mode "r" or "r:" now tries to open a tar file with +compression before trying to open it without compression. Otherwise it had +50% chance failed with ignore_zeros=True. + +.. + +.. bpo: 23262 +.. date: 9836 +.. nonce: 6EVB7N +.. section: Library + +The webbrowser module now supports Firefox 36+ and derived browsers. Based +on patch by Oleg Broytman. + +.. + +.. bpo: 27939 +.. date: 9835 +.. nonce: mTfADV +.. section: Library + +Fixed bugs in tkinter.ttk.LabeledScale and tkinter.Scale caused by +representing the scale as float value internally in Tk. tkinter.IntVar now +works if float value is set to underlying Tk variable. + +.. + +.. bpo: 28255 +.. date: 9834 +.. nonce: _ZH4wm +.. section: Library + +calendar.TextCalendar().prmonth() no longer prints a space at the start of +new line after printing a month's calendar. Patch by Xiang Zhang. + +.. + +.. bpo: 20491 +.. date: 9833 +.. nonce: ObgnQ2 +.. section: Library + +The textwrap.TextWrapper class now honors non-breaking spaces. Based on +patch by Kaarle Ritvanen. + +.. + +.. bpo: 28353 +.. date: 9832 +.. nonce: sKGbLL +.. section: Library + +os.fwalk() no longer fails on broken links. + +.. + +.. bpo: 25464 +.. date: 9831 +.. nonce: HDUTCu +.. section: Library + +Fixed HList.header_exists() in tkinter.tix module by addin a workaround to +Tix library bug. + +.. + +.. bpo: 28488 +.. date: 9830 +.. nonce: NlkjBM +.. section: Library + +shutil.make_archive() no longer add entry "./" to ZIP archive. + +.. + +.. bpo: 24452 +.. date: 9829 +.. nonce: m9Kyg3 +.. section: Library + +Make webbrowser support Chrome on Mac OS X. + +.. + +.. bpo: 20766 +.. date: 9828 +.. nonce: 4kvCzx +.. section: Library + +Fix references leaked by pdb in the handling of SIGINT handlers. + +.. + +.. bpo: 26293 +.. date: 9827 +.. nonce: 2mjvwX +.. section: Library + +Fixed writing ZIP files that starts not from the start of the file. Offsets +in ZIP file now are relative to the start of the archive in conforming to +the specification. + +.. + +.. bpo: 28321 +.. date: 9826 +.. nonce: bQ-IIX +.. section: Library + +Fixed writing non-BMP characters with binary format in plistlib. + +.. + +.. bpo: 28322 +.. date: 9825 +.. nonce: l9hzap +.. section: Library + +Fixed possible crashes when unpickle itertools objects from incorrect pickle +data. Based on patch by John Leitch. + +.. + +.. bpo: 0 +.. date: 9824 +.. nonce: 81jNns +.. section: Library + +Fix possible integer overflows and crashes in the mmap module with unusual +usage patterns. + +.. + +.. bpo: 1703178 +.. date: 9823 +.. nonce: meb49K +.. section: Library + +Fix the ability to pass the --link-objects option to the distutils build_ext +command. + +.. + +.. bpo: 28253 +.. date: 9822 +.. nonce: aLfmhe +.. section: Library + +Fixed calendar functions for extreme months: 0001-01 and 9999-12. + +Methods itermonthdays() and itermonthdays2() are reimplemented so that they +don't call itermonthdates() which can cause datetime.date under/overflow. + +.. + +.. bpo: 28275 +.. date: 9821 +.. nonce: EhWIsz +.. section: Library + +Fixed possible use after free in the decompress() methods of the +LZMADecompressor and BZ2Decompressor classes. Original patch by John Leitch. + +.. + +.. bpo: 27897 +.. date: 9820 +.. nonce: I0Ppmx +.. section: Library + +Fixed possible crash in sqlite3.Connection.create_collation() if pass +invalid string-like object as a name. Patch by Xiang Zhang. + +.. + +.. bpo: 18893 +.. date: 9819 +.. nonce: osiX5c +.. section: Library + +Fix invalid exception handling in Lib/ctypes/macholib/dyld.py. Patch by +Madison May. + +.. + +.. bpo: 27611 +.. date: 9818 +.. nonce: qL-UVQ +.. section: Library + +Fixed support of default root window in the tkinter.tix module. + +.. + +.. bpo: 27348 +.. date: 9817 +.. nonce: tDx7Vw +.. section: Library + +In the traceback module, restore the formatting of exception messages like +"Exception: None". This fixes a regression introduced in 3.5a2. + +.. + +.. bpo: 25651 +.. date: 9816 +.. nonce: 3UhyPo +.. section: Library + +Allow falsy values to be used for msg parameter of subTest(). + +.. + +.. bpo: 27932 +.. date: 9815 +.. nonce: mtgl-6 +.. section: Library + +Prevent memory leak in win32_ver(). + +.. + +.. bpo: 0 +.. date: 9814 +.. nonce: iPpjqX +.. section: Library + +Fix UnboundLocalError in socket._sendfile_use_sendfile. + +.. + +.. bpo: 28075 +.. date: 9813 +.. nonce: aLiUs9 +.. section: Library + +Check for ERROR_ACCESS_DENIED in Windows implementation of os.stat(). Patch +by Eryk Sun. + +.. + +.. bpo: 25270 +.. date: 9812 +.. nonce: jrZruM +.. section: Library + +Prevent codecs.escape_encode() from raising SystemError when an empty +bytestring is passed. + +.. + +.. bpo: 28181 +.. date: 9811 +.. nonce: NGc4Yv +.. section: Library + +Get antigravity over HTTPS. Patch by Kaartic Sivaraam. + +.. + +.. bpo: 25895 +.. date: 9810 +.. nonce: j92qoQ +.. section: Library + +Enable WebSocket URL schemes in urllib.parse.urljoin. Patch by Gergely Imreh +and Markus Holtermann. + +.. + +.. bpo: 27599 +.. date: 9809 +.. nonce: itvm8T +.. section: Library + +Fixed buffer overrun in binascii.b2a_qp() and binascii.a2b_qp(). + +.. + +.. bpo: 19003 +.. date: 9808 +.. nonce: UUcK_F +.. section: Library + +m email.generator now replaces only ``\r`` and/or ``\n`` line endings, per +the RFC, instead of all unicode line endings. + +.. + +.. bpo: 28019 +.. date: 9807 +.. nonce: KUhBaS +.. section: Library + +itertools.count() no longer rounds non-integer step in range between 1.0 and +2.0 to 1. + +.. + +.. bpo: 25969 +.. date: 9806 +.. nonce: qSPkl- +.. section: Library + +Update the lib2to3 grammar to handle the unpacking generalizations added in +3.5. + +.. + +.. bpo: 14977 +.. date: 9805 +.. nonce: 4MvALg +.. section: Library + +mailcap now respects the order of the lines in the mailcap files ("first +match"), as required by RFC 1542. Patch by Michael Lazar. + +.. + +.. bpo: 24594 +.. date: 9804 +.. nonce: 9CnFVS +.. section: Library + +Validates persist parameter when opening MSI database + +.. + +.. bpo: 17582 +.. date: 9803 +.. nonce: MXEHxQ +.. section: Library + +xml.etree.ElementTree nows preserves whitespaces in attributes (Patch by +Duane Griffin. Reviewed and approved by Stefan Behnel.) + +.. + +.. bpo: 28047 +.. date: 9802 +.. nonce: pDu3Fm +.. section: Library + +Fixed calculation of line length used for the base64 CTE in the new email +policies. + +.. + +.. bpo: 27445 +.. date: 9801 +.. nonce: wOG0C0 +.. section: Library + +Don't pass str(_charset) to MIMEText.set_payload(). Patch by Claude Paroz. + +.. + +.. bpo: 22450 +.. date: 9800 +.. nonce: T3Sn_J +.. section: Library + +urllib now includes an ``Accept: */*`` header among the default headers. +This makes the results of REST API requests more consistent and predictable +especially when proxy servers are involved. + +.. + +.. bpo: 0 +.. date: 9799 +.. nonce: PVZStR +.. section: Library + +lib2to3.pgen3.driver.load_grammar() now creates a stable cache file between +runs given the same Grammar.txt input regardless of the hash randomization +setting. + +.. + +.. bpo: 27570 +.. date: 9798 +.. nonce: pU0Zie +.. section: Library + +Avoid zero-length memcpy() etc calls with null source pointers in the +"ctypes" and "array" modules. + +.. + +.. bpo: 22233 +.. date: 9797 +.. nonce: uXSN0R +.. section: Library + +Break email header lines *only* on the RFC specified CR and LF characters, +not on arbitrary unicode line breaks. This also fixes a bug in HTTP header +parsing. + +.. + +.. bpo: 27988 +.. date: 9796 +.. nonce: VfMzZH +.. section: Library + +Fix email iter_attachments incorrect mutation of payload list. + +.. + +.. bpo: 27691 +.. date: 9795 +.. nonce: TMYF5_ +.. section: Library + +Fix ssl module's parsing of GEN_RID subject alternative name fields in X.509 +certs. + +.. + +.. bpo: 27850 +.. date: 9794 +.. nonce: kIVQ0m +.. section: Library + +Remove 3DES from ssl module's default cipher list to counter measure sweet32 +attack (CVE-2016-2183). + +.. + +.. bpo: 27766 +.. date: 9793 +.. nonce: WI70Tc +.. section: Library + +Add ChaCha20 Poly1305 to ssl module's default ciper list. (Required OpenSSL +1.1.0 or LibreSSL). + +.. + +.. bpo: 26470 +.. date: 9792 +.. nonce: QGu_wo +.. section: Library + +Port ssl and hashlib module to OpenSSL 1.1.0. + +.. + +.. bpo: 0 +.. date: 9791 +.. nonce: 6TjEgz +.. section: Library + +Remove support for passing a file descriptor to os.access. It never worked +but previously didn't raise. + +.. + +.. bpo: 12885 +.. date: 9790 +.. nonce: r-IV1g +.. section: Library + +Fix error when distutils encounters symlink. + +.. + +.. bpo: 27881 +.. date: 9789 +.. nonce: fkETd9 +.. section: Library + +Fixed possible bugs when setting sqlite3.Connection.isolation_level. Based +on patch by Xiang Zhang. + +.. + +.. bpo: 27861 +.. date: 9788 +.. nonce: DBYuo9 +.. section: Library + +Fixed a crash in sqlite3.Connection.cursor() when a factory creates not a +cursor. Patch by Xiang Zhang. + +.. + +.. bpo: 19884 +.. date: 9787 +.. nonce: MO8AWH +.. section: Library + +Avoid spurious output on OS X with Gnu Readline. + +.. + +.. bpo: 27706 +.. date: 9786 +.. nonce: ZY67yu +.. section: Library + +Restore deterministic behavior of random.Random().seed() for string seeds +using seeding version 1. Allows sequences of calls to random() to exactly +match those obtained in Python 2. Patch by Nofar Schnider. + +.. + +.. bpo: 10513 +.. date: 9785 +.. nonce: tQIQD_ +.. section: Library + +Fix a regression in Connection.commit(). Statements should not be reset +after a commit. + +.. + +.. bpo: 0 +.. date: 9784 +.. nonce: cYraeH +.. section: Library + +A new version of typing.py from https://github.com/python/typing: - +Collection (only for 3.6) (Issue #27598) - Add FrozenSet to __all__ +(upstream #261) - fix crash in _get_type_vars() (upstream #259) - Remove the +dict constraint in ForwardRef._eval_type (upstream #252) + +.. + +.. bpo: 27539 +.. date: 9783 +.. nonce: S4L1cq +.. section: Library + +Fix unnormalised ``Fraction.__pow__`` result in the case of negative +exponent and negative base. + +.. + +.. bpo: 21718 +.. date: 9782 +.. nonce: FUJd-7 +.. section: Library + +cursor.description is now available for queries using CTEs. + +.. + +.. bpo: 2466 +.. date: 9781 +.. nonce: VRNlkg +.. section: Library + +posixpath.ismount now correctly recognizes mount points which the user does +not have permission to access. + +.. + +.. bpo: 27773 +.. date: 9780 +.. nonce: hMSSeX +.. section: Library + +Correct some memory management errors server_hostname in _ssl.wrap_socket(). + +.. + +.. bpo: 26750 +.. date: 9779 +.. nonce: rv76vt +.. section: Library + +unittest.mock.create_autospec() now works properly for subclasses of +property() and other data descriptors. + +.. + +.. bpo: 0 +.. date: 9778 +.. nonce: Ny9oPv +.. section: Library + +In the curses module, raise an error if window.getstr() or window.instr() is +passed a negative value. + +.. + +.. bpo: 27783 +.. date: 9777 +.. nonce: cR1jXH +.. section: Library + +Fix possible usage of uninitialized memory in operator.methodcaller. + +.. + +.. bpo: 27774 +.. date: 9776 +.. nonce: FDcik1 +.. section: Library + +Fix possible Py_DECREF on unowned object in _sre. + +.. + +.. bpo: 27760 +.. date: 9775 +.. nonce: gxMjp4 +.. section: Library + +Fix possible integer overflow in binascii.b2a_qp. + +.. + +.. bpo: 27758 +.. date: 9774 +.. nonce: 0NRV03 +.. section: Library + +Fix possible integer overflow in the _csv module for large record lengths. + +.. + +.. bpo: 27568 +.. date: 9773 +.. nonce: OnuO9s +.. section: Library + +Prevent HTTPoxy attack (CVE-2016-1000110). Ignore the HTTP_PROXY variable +when REQUEST_METHOD environment is set, which indicates that the script is +in CGI mode. + +.. + +.. bpo: 27656 +.. date: 9772 +.. nonce: joTscM +.. section: Library + +Do not assume sched.h defines any SCHED_* constants. + +.. + +.. bpo: 27130 +.. date: 9771 +.. nonce: SUxwXZ +.. section: Library + +In the "zlib" module, fix handling of large buffers (typically 4 GiB) when +compressing and decompressing. Previously, inputs were limited to 4 GiB, +and compression and decompression operations did not properly handle results +of 4 GiB. + +.. + +.. bpo: 27533 +.. date: 9770 +.. nonce: iDmKzV +.. section: Library + +Release GIL in nt._isdir + +.. + +.. bpo: 17711 +.. date: 9769 +.. nonce: 47AILJ +.. section: Library + +Fixed unpickling by the persistent ID with protocol 0. Original patch by +Alexandre Vassalotti. + +.. + +.. bpo: 27522 +.. date: 9768 +.. nonce: 8vVz_t +.. section: Library + +Avoid an unintentional reference cycle in email.feedparser. + +.. + +.. bpo: 26844 +.. date: 9767 +.. nonce: I0wdnY +.. section: Library + +Fix error message for imp.find_module() to refer to 'path' instead of +'name'. Patch by Lev Maximov. + +.. + +.. bpo: 23804 +.. date: 9766 +.. nonce: ipFvxc +.. section: Library + +Fix SSL zero-length recv() calls to not block and not raise an error about +unclean EOF. + +.. + +.. bpo: 27466 +.. date: 9765 +.. nonce: C_3a8E +.. section: Library + +Change time format returned by http.cookie.time2netscape, confirming the +netscape cookie format and making it consistent with documentation. + +.. + +.. bpo: 26664 +.. date: 9764 +.. nonce: OzsSzf +.. section: Library + +Fix activate.fish by removing mis-use of ``$``. + +.. + +.. bpo: 22115 +.. date: 9763 +.. nonce: apoFQ9 +.. section: Library + +Fixed tracing Tkinter variables: trace_vdelete() with wrong mode no longer +break tracing, trace_vinfo() now always returns a list of pairs of strings, +tracing in the "u" mode now works. + +.. + +.. bpo: 0 +.. date: 9762 +.. nonce: oZOeFE +.. section: Library + +Fix a scoping issue in importlib.util.LazyLoader which triggered an +UnboundLocalError when lazy-loading a module that was already put into +sys.modules. + +.. + +.. bpo: 27079 +.. date: 9761 +.. nonce: c7d0Ym +.. section: Library + +Fixed curses.ascii functions isblank(), iscntrl() and ispunct(). + +.. + +.. bpo: 26754 +.. date: 9760 +.. nonce: J3n0QW +.. section: Library + +Some functions (compile() etc) accepted a filename argument encoded as an +iterable of integers. Now only strings and byte-like objects are accepted. + +.. + +.. bpo: 27048 +.. date: 9759 +.. nonce: EVe-Bk +.. section: Library + +Prevents distutils failing on Windows when environment variables contain +non-ASCII characters + +.. + +.. bpo: 27330 +.. date: 9758 +.. nonce: GJaFCV +.. section: Library + +Fixed possible leaks in the ctypes module. + +.. + +.. bpo: 27238 +.. date: 9757 +.. nonce: Q6v6Qv +.. section: Library + +Got rid of bare excepts in the turtle module. Original patch by Jelle +Zijlstra. + +.. + +.. bpo: 27122 +.. date: 9756 +.. nonce: 06t7zN +.. section: Library + +When an exception is raised within the context being managed by a +contextlib.ExitStack() and one of the exit stack generators catches and +raises it in a chain, do not re-raise the original exception when exiting, +let the new chained one through. This avoids the PEP 479 bug described in +issue25782. + +.. + +.. bpo: 27278 +.. date: 9755 +.. nonce: y_HkGw +.. original section: Library +.. section: Security + +Fix os.urandom() implementation using getrandom() on Linux. Truncate size +to INT_MAX and loop until we collected enough random bytes, instead of +casting a directly Py_ssize_t to int. + +.. + +.. bpo: 26386 +.. date: 9754 +.. nonce: 9L3Ut4 +.. section: Library + +Fixed ttk.TreeView selection operations with item id's containing spaces. + +.. + +.. bpo: 22636 +.. date: 9753 +.. nonce: 3fQW_g +.. original section: Library +.. section: Security + +Avoid shell injection problems with ctypes.util.find_library(). + +.. + +.. bpo: 16182 +.. date: 9752 +.. nonce: RgFXyr +.. section: Library + +Fix various functions in the "readline" module to use the locale encoding, +and fix get_begidx() and get_endidx() to return code point indexes. + +.. + +.. bpo: 27392 +.. date: 9751 +.. nonce: obfni7 +.. section: Library + +Add loop.connect_accepted_socket(). Patch by Jim Fulton. + +.. + +.. bpo: 27930 +.. date: 9750 +.. nonce: BkOfSi +.. section: Library + +Improved behaviour of logging.handlers.QueueListener. Thanks to Paulo +Andrade and Petr Viktorin for the analysis and patch. + +.. + +.. bpo: 21201 +.. date: 9749 +.. nonce: wLCKiA +.. section: Library + +Improves readability of multiprocessing error message. Thanks to Wojciech +Walczak for patch. + +.. + +.. bpo: 27456 +.. date: 9748 +.. nonce: lI_IE7 +.. section: Library + +asyncio: Set TCP_NODELAY by default. + +.. + +.. bpo: 27906 +.. date: 9747 +.. nonce: TBBXrv +.. section: Library + +Fix socket accept exhaustion during high TCP traffic. Patch by Kevin Conway. + +.. + +.. bpo: 28174 +.. date: 9746 +.. nonce: CV1UdI +.. section: Library + +Handle when SO_REUSEPORT isn't properly supported. Patch by Seth Michael +Larson. + +.. + +.. bpo: 26654 +.. date: 9745 +.. nonce: XtzTE9 +.. section: Library + +Inspect functools.partial in asyncio.Handle.__repr__. Patch by iceboy. + +.. + +.. bpo: 26909 +.. date: 9744 +.. nonce: ASiakT +.. section: Library + +Fix slow pipes IO in asyncio. Patch by INADA Naoki. + +.. + +.. bpo: 28176 +.. date: 9743 +.. nonce: sU8R6L +.. section: Library + +Fix callbacks race in asyncio.SelectorLoop.sock_connect. + +.. + +.. bpo: 27759 +.. date: 9742 +.. nonce: qpMDGq +.. section: Library + +Fix selectors incorrectly retain invalid file descriptors. Patch by Mark +Williams. + +.. + +.. bpo: 28368 +.. date: 9741 +.. nonce: n594X4 +.. section: Library + +Refuse monitoring processes if the child watcher has no loop attached. Patch +by Vincent Michel. + +.. + +.. bpo: 28369 +.. date: 9740 +.. nonce: 8DTANe +.. section: Library + +Raise RuntimeError when transport's FD is used with add_reader, add_writer, +etc. + +.. + +.. bpo: 28370 +.. date: 9739 +.. nonce: 18jBuZ +.. section: Library + +Speedup asyncio.StreamReader.readexactly. Patch by ????????? ????. + +.. + +.. bpo: 28371 +.. date: 9738 +.. nonce: U9Zqdk +.. section: Library + +Deprecate passing asyncio.Handles to run_in_executor. + +.. + +.. bpo: 28372 +.. date: 9737 +.. nonce: njcIPk +.. section: Library + +Fix asyncio to support formatting of non-python coroutines. + +.. + +.. bpo: 28399 +.. date: 9736 +.. nonce: QKIqRX +.. section: Library + +Remove UNIX socket from FS before binding. Patch by ????????? ????. + +.. + +.. bpo: 27972 +.. date: 9735 +.. nonce: ZK-GFm +.. section: Library + +Prohibit Tasks to await on themselves. + +.. + +.. bpo: 26923 +.. date: 9734 +.. nonce: 8dh3AV +.. section: Library + +Fix asyncio.Gather to refuse being cancelled once all children are done. +Patch by Johannes Ebke. + +.. + +.. bpo: 26796 +.. date: 9733 +.. nonce: TZyAfJ +.. section: Library + +Don't configure the number of workers for default threadpool executor. +Initial patch by Hans Lawrenz. + +.. + +.. bpo: 28600 +.. date: 9732 +.. nonce: 2ThUQV +.. section: Library + +Optimize loop.call_soon(). + +.. + +.. bpo: 28613 +.. date: 9731 +.. nonce: sqUPrv +.. section: Library + +Fix get_event_loop() return the current loop if called from +coroutines/callbacks. + +.. + +.. bpo: 28639 +.. date: 9730 +.. nonce: WUPo1o +.. section: Library + +Fix inspect.isawaitable to always return bool Patch by Justin Mayfield. + +.. + +.. bpo: 28652 +.. date: 9729 +.. nonce: f5M8FG +.. section: Library + +Make loop methods reject socket kinds they do not support. + +.. + +.. bpo: 28653 +.. date: 9728 +.. nonce: S5bA9i +.. section: Library + +Fix a refleak in functools.lru_cache. + +.. + +.. bpo: 28703 +.. date: 9727 +.. nonce: CRLTJc +.. section: Library + +Fix asyncio.iscoroutinefunction to handle Mock objects. + +.. + +.. bpo: 24142 +.. date: 9726 +.. nonce: _BgogI +.. section: Library + +Reading a corrupt config file left the parser in an invalid state. Original +patch by Florian H?ch. + +.. + +.. bpo: 28990 +.. date: 9725 +.. nonce: W8tuYZ +.. section: Library + +Fix SSL hanging if connection is closed before handshake completed. (Patch +by HoHo-Ho) + +.. + +.. bpo: 15308 +.. date: 9724 +.. nonce: zZxn8m +.. section: IDLE + +Add 'interrupt execution' (^C) to Shell menu. Patch by Roger Serwy, updated +by Bayard Randel. + +.. + +.. bpo: 27922 +.. date: 9723 +.. nonce: UEtEv9 +.. section: IDLE + +Stop IDLE tests from 'flashing' gui widgets on the screen. + +.. + +.. bpo: 0 +.. date: 9722 +.. nonce: zWZs6o +.. section: IDLE + +Add version to title of IDLE help window. + +.. + +.. bpo: 25564 +.. date: 9721 +.. nonce: GN0p14 +.. section: IDLE + +In section on IDLE -- console differences, mention that using exec means +that __builtins__ is defined for each statement. + +.. + +.. bpo: 27714 +.. date: 9720 +.. nonce: bUEDsI +.. section: IDLE + +text_textview and test_autocomplete now pass when re-run in the same +process. This occurs when test_idle fails when run with the -w option but +without -jn. Fix warning from test_config. + +.. + +.. bpo: 25507 +.. date: 9719 +.. nonce: lxf68d +.. section: IDLE + +IDLE no longer runs buggy code because of its tkinter imports. Users must +include the same imports required to run directly in Python. + +.. + +.. bpo: 27452 +.. date: 9718 +.. nonce: RtWnyR +.. section: IDLE + +add line counter and crc to IDLE configHandler test dump. + +.. + +.. bpo: 27365 +.. date: 9717 +.. nonce: y7ys_A +.. section: IDLE + +Allow non-ascii chars in IDLE NEWS.txt, for contributor names. + +.. + +.. bpo: 27245 +.. date: 9716 +.. nonce: u9aKO1 +.. section: IDLE + +IDLE: Cleanly delete custom themes and key bindings. Previously, when IDLE +was started from a console or by import, a cascade of warnings was emitted. +Patch by Serhiy Storchaka. + +.. + +.. bpo: 28808 +.. date: 9715 +.. nonce: A03X6r +.. section: C API + +PyUnicode_CompareWithASCIIString() now never raises exceptions. + +.. + +.. bpo: 26754 +.. date: 9714 +.. nonce: j2czHF +.. section: C API + +PyUnicode_FSDecoder() accepted a filename argument encoded as an iterable of +integers. Now only strings and bytes-like objects are accepted. + +.. + +.. bpo: 28513 +.. date: 9713 +.. nonce: L3joAz +.. section: Documentation + +Documented command-line interface of zipfile. + +.. + +.. bpo: 28950 +.. date: 9712 +.. nonce: 9_vY6R +.. section: Tests + +Disallow -j0 to be combined with -T/-l/-M in regrtest command line +arguments. + +.. + +.. bpo: 28666 +.. date: 9711 +.. nonce: RtTk-4 +.. section: Tests + +Now test.support.rmtree is able to remove unwritable or unreadable +directories. + +.. + +.. bpo: 23839 +.. date: 9710 +.. nonce: zsT_L9 +.. section: Tests + +Various caches now are cleared before running every test file. + +.. + +.. bpo: 28409 +.. date: 9709 +.. nonce: Q2IlxJ +.. section: Tests + +regrtest: fix the parser of command line arguments. + +.. + +.. bpo: 27787 +.. date: 9708 +.. nonce: kf0YAt +.. section: Tests + +Call gc.collect() before checking each test for "dangling threads", since +the dangling threads are weak references. + +.. + +.. bpo: 27369 +.. date: 9707 +.. nonce: LG7U2D +.. section: Tests + +In test_pyexpat, avoid testing an error message detail that changed in Expat +2.2.0. + +.. + +.. bpo: 27952 +.. date: 9706 +.. nonce: WX9Ufc +.. section: Tools/Demos + +Get Tools/scripts/fixcid.py working with Python 3 and the current "re" +module, avoid invalid Python backslash escapes, and fix a bug parsing +escaped C quote signs. + +.. + +.. bpo: 27332 +.. date: 9705 +.. nonce: OuRZp9 +.. section: Tools/Demos + +Fixed the type of the first argument of module-level functions generated by +Argument Clinic. Patch by Petr Viktorin. + +.. + +.. bpo: 27418 +.. date: 9704 +.. nonce: W2m_8I +.. section: Tools/Demos + +Fixed Tools/importbench/importbench.py. + +.. + +.. bpo: 28251 +.. date: 9703 +.. nonce: tR_AFs +.. section: Windows + +Improvements to help manuals on Windows. + +.. + +.. bpo: 28110 +.. date: 9702 +.. nonce: cnkP5F +.. section: Windows + +launcher.msi has different product codes between 32-bit and 64-bit + +.. + +.. bpo: 25144 +.. date: 9701 +.. nonce: iUha52 +.. section: Windows + +Ensures TargetDir is set before continuing with custom install. + +.. + +.. bpo: 27469 +.. date: 9700 +.. nonce: 0GwDkX +.. section: Windows + +Adds a shell extension to the launcher so that drag and drop works +correctly. + +.. + +.. bpo: 27309 +.. date: 9699 +.. nonce: 4DPjhF +.. section: Windows + +Enabled proper Windows styles in python[w].exe manifest. + +.. + +.. bpo: 29080 +.. date: 9698 +.. nonce: b3qLQT +.. section: Build + +Removes hard dependency on hg.exe from PCBuild/build.bat + +.. + +.. bpo: 23903 +.. date: 9697 +.. nonce: JXJ889 +.. section: Build + +Added missed names to PC/python3.def. + +.. + +.. bpo: 10656 +.. date: 9696 +.. nonce: pR8FFU +.. section: Build + +Fix out-of-tree building on AIX. Patch by Tristan Carel and Michael +Haubenwallner. + +.. + +.. bpo: 26359 +.. date: 9695 +.. nonce: CLz6qy +.. section: Build + +Rename --with-optimiations to --enable-optimizations. + +.. + +.. bpo: 28444 +.. date: 9694 +.. nonce: zkc9nT +.. section: Build + +Fix missing extensions modules when cross compiling. + +.. + +.. bpo: 28248 +.. date: 9693 +.. nonce: KY_-en +.. section: Build + +Update Windows build and OS X installers to use OpenSSL 1.0.2j. + +.. + +.. bpo: 28258 +.. date: 9692 +.. nonce: iKtAHd +.. section: Build + +Fixed build with Estonian locale (python-config and distclean targets in +Makefile). Patch by Arfrever Frehtes Taifersar Arahesis. + +.. + +.. bpo: 26661 +.. date: 9691 +.. nonce: Z_HNbs +.. section: Build + +setup.py now detects system libffi with multiarch wrapper. + +.. + +.. bpo: 28066 +.. date: 9690 +.. nonce: _3xImV +.. section: Build + +Fix the logic that searches build directories for generated include files +when building outside the source tree. + +.. + +.. bpo: 15819 +.. date: 9689 +.. nonce: QVDr3E +.. section: Build + +Remove redundant include search directory option for building outside the +source tree. + +.. + +.. bpo: 27566 +.. date: 9688 +.. nonce: xDWjEb +.. section: Build + +Fix clean target in freeze makefile (patch by Lisa Roach) + +.. + +.. bpo: 27705 +.. date: 9687 +.. nonce: 8C2Ms3 +.. section: Build + +Update message in validate_ucrtbase.py + +.. + +.. bpo: 27983 +.. date: 9686 +.. nonce: jL_1n8 +.. section: Build + +Cause lack of llvm-profdata tool when using clang as required for PGO +linking to be a configure time error rather than make time when --with- +optimizations is enabled. Also improve our ability to find the llvm- +profdata tool on MacOS and some Linuxes. + +.. + +.. bpo: 26307 +.. date: 9685 +.. nonce: Puk2rd +.. section: Build + +The profile-opt build now applies PGO to the built-in modules. + +.. + +.. bpo: 26359 +.. date: 9684 +.. nonce: WXBL-Y +.. section: Build + +Add the --with-optimizations configure flag. + +.. + +.. bpo: 27713 +.. date: 9683 +.. nonce: _3DgXG +.. section: Build + +Suppress spurious build warnings when updating importlib's bootstrap files. +Patch by Xiang Zhang + +.. + +.. bpo: 25825 +.. date: 9682 +.. nonce: JD8aRp +.. section: Build + +Correct the references to Modules/python.exp and ld_so_aix, which are +required on AIX. This updates references to an installation path that was +changed in 3.2a4, and undoes changed references to the build tree that were +made in 3.5.0a1. + +.. + +.. bpo: 27453 +.. date: 9681 +.. nonce: Pb5DBi +.. section: Build + +CPP invocation in configure must use CPPFLAGS. Patch by Chi Hsuan Yen. + +.. + +.. bpo: 27641 +.. date: 9680 +.. nonce: eGzgCk +.. section: Build + +The configure script now inserts comments into the makefile to prevent the +pgen and _freeze_importlib executables from being cross- compiled. + +.. + +.. bpo: 26662 +.. date: 9679 +.. nonce: XkwRxM +.. section: Build + +Set PYTHON_FOR_GEN in configure as the Python program to be used for file +generation during the build. + +.. + +.. bpo: 10910 +.. date: 9678 +.. nonce: ZdRayb +.. section: Build + +Avoid C++ compilation errors on FreeBSD and OS X. Also update FreedBSD +version checks for the original ctype UTF-8 workaround. + +.. + +.. bpo: 28676 +.. date: 9677 +.. nonce: Wxf6Ds +.. section: Build + +Prevent missing 'getentropy' declaration warning on macOS. Patch by Gareth +Rees. diff --git a/Misc/NEWS.d/next/Build/005.bpo-29643.4WLIJQ.rst b/Misc/NEWS.d/next/Build/005.bpo-29643.4WLIJQ.rst new file mode 100644 index 00000000000..65b958ffef4 --- /dev/null +++ b/Misc/NEWS.d/next/Build/005.bpo-29643.4WLIJQ.rst @@ -0,0 +1 @@ +Fix ``--enable-optimization`` didn't work. diff --git a/Misc/NEWS.d/next/Build/006.bpo-23404.PdYVWg.rst b/Misc/NEWS.d/next/Build/006.bpo-23404.PdYVWg.rst new file mode 100644 index 00000000000..0addfd094f1 --- /dev/null +++ b/Misc/NEWS.d/next/Build/006.bpo-23404.PdYVWg.rst @@ -0,0 +1,2 @@ +Don't regenerate generated files based on file modification time anymore: +the action is now explicit. Replace ``make touch`` with ``make regen-all``. diff --git a/Misc/NEWS.d/next/Build/007.bpo-29243.WDK4hT.rst b/Misc/NEWS.d/next/Build/007.bpo-29243.WDK4hT.rst new file mode 100644 index 00000000000..378e49f67bc --- /dev/null +++ b/Misc/NEWS.d/next/Build/007.bpo-29243.WDK4hT.rst @@ -0,0 +1,3 @@ +Prevent unnecessary rebuilding of Python during ``make test``, ``make +install`` and some other make targets when configured with ``--enable- +optimizations``. diff --git a/Misc/NEWS.d/next/C API/014.bpo-29083.tGTjr_.rst b/Misc/NEWS.d/next/C API/014.bpo-29083.tGTjr_.rst new file mode 100644 index 00000000000..639fc25c972 --- /dev/null +++ b/Misc/NEWS.d/next/C API/014.bpo-29083.tGTjr_.rst @@ -0,0 +1,5 @@ +Fixed the declaration of some public API functions. PyArg_VaParse() and +PyArg_VaParseTupleAndKeywords() were not available in limited API. +PyArg_ValidateKeywordArguments(), PyArg_UnpackTuple() and Py_BuildValue() +were not available in limited API of version < 3.3 when PY_SSIZE_T_CLEAN is +defined. diff --git a/Misc/NEWS.d/next/C API/015.bpo-27867.VMCoJU.rst b/Misc/NEWS.d/next/C API/015.bpo-27867.VMCoJU.rst new file mode 100644 index 00000000000..f2201feccd4 --- /dev/null +++ b/Misc/NEWS.d/next/C API/015.bpo-27867.VMCoJU.rst @@ -0,0 +1,3 @@ +Function PySlice_GetIndicesEx() is replaced with a macro if Py_LIMITED_API +is set to the value between 0x03050400 and 0x03060000 (not including) or +0x03060100 or higher. diff --git a/Misc/NEWS.d/next/Core and Builtins/088.bpo-29478.rTQ-qy.rst b/Misc/NEWS.d/next/Core and Builtins/088.bpo-29478.rTQ-qy.rst new file mode 100644 index 00000000000..a9d4bdbabd1 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/088.bpo-29478.rTQ-qy.rst @@ -0,0 +1,2 @@ +If max_line_length=None is specified while using the Compat32 policy, it is +no longer ignored. Patch by Mircea Cosbuc. diff --git a/Misc/NEWS.d/next/Core and Builtins/089.bpo-29337.bjX8AE.rst b/Misc/NEWS.d/next/Core and Builtins/089.bpo-29337.bjX8AE.rst new file mode 100644 index 00000000000..201325cbf6c --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/089.bpo-29337.bjX8AE.rst @@ -0,0 +1,2 @@ +Fixed possible BytesWarning when compare the code objects. Warnings could be +emitted at compile time. diff --git a/Misc/NEWS.d/next/Core and Builtins/090.bpo-29319.KLDUZf.rst b/Misc/NEWS.d/next/Core and Builtins/090.bpo-29319.KLDUZf.rst new file mode 100644 index 00000000000..254d8731d56 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/090.bpo-29319.KLDUZf.rst @@ -0,0 +1 @@ +Prevent RunMainFromImporter overwriting sys.path[0]. diff --git a/Misc/NEWS.d/next/Core and Builtins/091.bpo-29438.IKxD6I.rst b/Misc/NEWS.d/next/Core and Builtins/091.bpo-29438.IKxD6I.rst new file mode 100644 index 00000000000..e3eecb6136e --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/091.bpo-29438.IKxD6I.rst @@ -0,0 +1 @@ +Fixed use-after-free problem in key sharing dict. diff --git a/Misc/NEWS.d/next/Core and Builtins/092.bpo-29347.1RPPGN.rst b/Misc/NEWS.d/next/Core and Builtins/092.bpo-29347.1RPPGN.rst new file mode 100644 index 00000000000..35fa1066645 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/092.bpo-29347.1RPPGN.rst @@ -0,0 +1,2 @@ +Fixed possibly dereferencing undefined pointers when creating weakref +objects. diff --git a/Misc/NEWS.d/next/Core and Builtins/093.bpo-29602.qyyskC.rst b/Misc/NEWS.d/next/Core and Builtins/093.bpo-29602.qyyskC.rst new file mode 100644 index 00000000000..cc1366caf30 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/093.bpo-29602.qyyskC.rst @@ -0,0 +1,3 @@ +Fix incorrect handling of signed zeros in complex constructor for complex +subclasses and for inputs having a __complex__ method. Patch by Serhiy +Storchaka. diff --git a/Misc/NEWS.d/next/Core and Builtins/094.bpo-28598.QxbzQn.rst b/Misc/NEWS.d/next/Core and Builtins/094.bpo-28598.QxbzQn.rst new file mode 100644 index 00000000000..4757347a3d0 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/094.bpo-28598.QxbzQn.rst @@ -0,0 +1,2 @@ +Support __rmod__ for subclasses of str being called before str.__mod__. +Patch by Martijn Pieters. diff --git a/Misc/NEWS.d/next/Core and Builtins/095.bpo-29537.lu1ysY.rst b/Misc/NEWS.d/next/Core and Builtins/095.bpo-29537.lu1ysY.rst new file mode 100644 index 00000000000..3713ae82918 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/095.bpo-29537.lu1ysY.rst @@ -0,0 +1,5 @@ +Restore runtime compatibility with bytecode files generated by CPython 3.5.0 +to 3.5.2, and adjust the eval loop to avoid the problems that could be +caused by the malformed variant of the BUILD_MAP_UNPACK_WITH_CALL opcode +that they may contain. Patch by Petr Viktorin, Serhiy Storchaka, and Nick +Coghlan. diff --git a/Misc/NEWS.d/next/Core and Builtins/096.bpo-29600.77wQ6C.rst b/Misc/NEWS.d/next/Core and Builtins/096.bpo-29600.77wQ6C.rst new file mode 100644 index 00000000000..136538de3be --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/096.bpo-29600.77wQ6C.rst @@ -0,0 +1 @@ +Fix wrapping coroutine return values in StopIteration. diff --git a/Misc/NEWS.d/next/Core and Builtins/097.bpo-28876.cU-sGT.rst b/Misc/NEWS.d/next/Core and Builtins/097.bpo-28876.cU-sGT.rst new file mode 100644 index 00000000000..76c09e34e1c --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/097.bpo-28876.cU-sGT.rst @@ -0,0 +1 @@ +``bool(range)`` works even if ``len(range)`` raises :exc:`OverflowError`. diff --git a/Misc/NEWS.d/next/Core and Builtins/098.bpo-29935.vgjdJo.rst b/Misc/NEWS.d/next/Core and Builtins/098.bpo-29935.vgjdJo.rst new file mode 100644 index 00000000000..6f96cded835 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/098.bpo-29935.vgjdJo.rst @@ -0,0 +1,2 @@ +Fixed error messages in the index() method of tuple, list and deque when +pass indices of wrong type. diff --git a/Misc/NEWS.d/next/Core and Builtins/099.bpo-25794.xfPwqm.rst b/Misc/NEWS.d/next/Core and Builtins/099.bpo-25794.xfPwqm.rst new file mode 100644 index 00000000000..de46584a64d --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/099.bpo-25794.xfPwqm.rst @@ -0,0 +1,2 @@ +Fixed type.__setattr__() and type.__delattr__() for non-interned attribute +names. Based on patch by Eryk Sun. diff --git a/Misc/NEWS.d/next/Core and Builtins/100.bpo-27945.p29r3O.rst b/Misc/NEWS.d/next/Core and Builtins/100.bpo-27945.p29r3O.rst new file mode 100644 index 00000000000..da5b8d1a2ca --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/100.bpo-27945.p29r3O.rst @@ -0,0 +1,3 @@ +Fixed various segfaults with dict when input collections are mutated during +searching, inserting or comparing. Based on patches by Duane Griffin and +Tim Mitchell. diff --git a/Misc/NEWS.d/next/Documentation/008.bpo-29349.PjSo-t.rst b/Misc/NEWS.d/next/Documentation/008.bpo-29349.PjSo-t.rst new file mode 100644 index 00000000000..09f6f3889b5 --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/008.bpo-29349.PjSo-t.rst @@ -0,0 +1 @@ +Fix Python 2 syntax in code for building the documentation. diff --git a/Misc/NEWS.d/next/Documentation/009.bpo-26355.SDq_8Y.rst b/Misc/NEWS.d/next/Documentation/009.bpo-26355.SDq_8Y.rst new file mode 100644 index 00000000000..2614c0ba850 --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/009.bpo-26355.SDq_8Y.rst @@ -0,0 +1,2 @@ +Add canonical header link on each page to corresponding major version of the +documentation. Patch by Matthias Bussonnier. diff --git a/Misc/NEWS.d/next/Documentation/010.bpo-25008.CeIzyU.rst b/Misc/NEWS.d/next/Documentation/010.bpo-25008.CeIzyU.rst new file mode 100644 index 00000000000..ea4046ead7d --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/010.bpo-25008.CeIzyU.rst @@ -0,0 +1,2 @@ +Document smtpd.py as effectively deprecated and add a pointer to aiosmtpd, a +third-party asyncio-based replacement. diff --git a/Misc/NEWS.d/next/Documentation/011.bpo-28929.Md7kb0.rst b/Misc/NEWS.d/next/Documentation/011.bpo-28929.Md7kb0.rst new file mode 100644 index 00000000000..acacdd01322 --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/011.bpo-28929.Md7kb0.rst @@ -0,0 +1 @@ +Link the documentation to its source file on GitHub. diff --git a/Misc/NEWS.d/next/Documentation/012.bpo-26985.NB5_9S.rst b/Misc/NEWS.d/next/Documentation/012.bpo-26985.NB5_9S.rst new file mode 100644 index 00000000000..3413e054759 --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/012.bpo-26985.NB5_9S.rst @@ -0,0 +1 @@ +Add missing info of code object in inspect documentation. diff --git a/Misc/NEWS.d/next/Documentation/013.bpo-30176.VivmCg.rst b/Misc/NEWS.d/next/Documentation/013.bpo-30176.VivmCg.rst new file mode 100644 index 00000000000..df73aeda646 --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/013.bpo-30176.VivmCg.rst @@ -0,0 +1 @@ +Add missing attribute related constants in curses documentation. diff --git a/Misc/NEWS.d/next/Library/018.bpo-29142.xo6kAv.rst b/Misc/NEWS.d/next/Library/018.bpo-29142.xo6kAv.rst new file mode 100644 index 00000000000..fd5465baa90 --- /dev/null +++ b/Misc/NEWS.d/next/Library/018.bpo-29142.xo6kAv.rst @@ -0,0 +1,3 @@ +In urllib.request, suffixes in no_proxy environment variable with leading +dots could match related hostnames again (e.g. .b.c matches a.b.c). Patch by +Milan Oberkirch. diff --git a/Misc/NEWS.d/next/Library/019.bpo-28969.j3HJYO.rst b/Misc/NEWS.d/next/Library/019.bpo-28969.j3HJYO.rst new file mode 100644 index 00000000000..f2a4171294f --- /dev/null +++ b/Misc/NEWS.d/next/Library/019.bpo-28969.j3HJYO.rst @@ -0,0 +1,3 @@ +Fixed race condition in C implementation of functools.lru_cache. KeyError +could be raised when cached function with full cache was simultaneously +called from differen threads with the same uncached arguments. diff --git a/Misc/NEWS.d/next/Library/020.bpo-29219.kxui7t.rst b/Misc/NEWS.d/next/Library/020.bpo-29219.kxui7t.rst new file mode 100644 index 00000000000..ab6725f596a --- /dev/null +++ b/Misc/NEWS.d/next/Library/020.bpo-29219.kxui7t.rst @@ -0,0 +1 @@ +Fixed infinite recursion in the repr of uninitialized ctypes.CDLL instances. diff --git a/Misc/NEWS.d/next/Library/021.bpo-29011.MI5f2R.rst b/Misc/NEWS.d/next/Library/021.bpo-29011.MI5f2R.rst new file mode 100644 index 00000000000..4d71b40753c --- /dev/null +++ b/Misc/NEWS.d/next/Library/021.bpo-29011.MI5f2R.rst @@ -0,0 +1 @@ +Fix an important omission by adding Deque to the typing module. diff --git a/Misc/NEWS.d/next/Library/022.bpo-28735.admHLO.rst b/Misc/NEWS.d/next/Library/022.bpo-28735.admHLO.rst new file mode 100644 index 00000000000..1ec6247bb9c --- /dev/null +++ b/Misc/NEWS.d/next/Library/022.bpo-28735.admHLO.rst @@ -0,0 +1 @@ +Fixed the comparison of mock.MagickMock with mock.ANY. diff --git a/Misc/NEWS.d/next/Library/023.bpo-29290.XBqptF.rst b/Misc/NEWS.d/next/Library/023.bpo-29290.XBqptF.rst new file mode 100644 index 00000000000..a4ac1f0725f --- /dev/null +++ b/Misc/NEWS.d/next/Library/023.bpo-29290.XBqptF.rst @@ -0,0 +1,2 @@ +Fix a regression in argparse that help messages would wrap at non-breaking +spaces. diff --git a/Misc/NEWS.d/next/Library/024.bpo-29335._KC7IK.rst b/Misc/NEWS.d/next/Library/024.bpo-29335._KC7IK.rst new file mode 100644 index 00000000000..79e17482299 --- /dev/null +++ b/Misc/NEWS.d/next/Library/024.bpo-29335._KC7IK.rst @@ -0,0 +1,2 @@ +Fix subprocess.Popen.wait() when the child process has exited to a stopped +instead of terminated state (ex: when under ptrace). diff --git a/Misc/NEWS.d/next/Library/025.bpo-29444.cEwgmk.rst b/Misc/NEWS.d/next/Library/025.bpo-29444.cEwgmk.rst new file mode 100644 index 00000000000..05e96fb79da --- /dev/null +++ b/Misc/NEWS.d/next/Library/025.bpo-29444.cEwgmk.rst @@ -0,0 +1,2 @@ +Fixed out-of-bounds buffer access in the group() method of the match object. +Based on patch by WGH. diff --git a/Misc/NEWS.d/next/Library/026.bpo-29416.KJGyI_.rst b/Misc/NEWS.d/next/Library/026.bpo-29416.KJGyI_.rst new file mode 100644 index 00000000000..b0b9838b373 --- /dev/null +++ b/Misc/NEWS.d/next/Library/026.bpo-29416.KJGyI_.rst @@ -0,0 +1 @@ +Prevent infinite loop in pathlib.Path.mkdir diff --git a/Misc/NEWS.d/next/Library/027.bpo-29519.oGGgZ4.rst b/Misc/NEWS.d/next/Library/027.bpo-29519.oGGgZ4.rst new file mode 100644 index 00000000000..9b2e39d3318 --- /dev/null +++ b/Misc/NEWS.d/next/Library/027.bpo-29519.oGGgZ4.rst @@ -0,0 +1,2 @@ +Fix weakref spewing exceptions during interpreter shutdown when used with a +rare combination of multiprocessing and custom codecs. diff --git a/Misc/NEWS.d/next/Library/028.bpo-29100.LAAERS.rst b/Misc/NEWS.d/next/Library/028.bpo-29100.LAAERS.rst new file mode 100644 index 00000000000..d12217a34bd --- /dev/null +++ b/Misc/NEWS.d/next/Library/028.bpo-29100.LAAERS.rst @@ -0,0 +1,2 @@ +Fix datetime.fromtimestamp() regression introduced in Python 3.6.0: check +minimum and maximum years. diff --git a/Misc/NEWS.d/next/Library/029.bpo-28556.p6967e.rst b/Misc/NEWS.d/next/Library/029.bpo-28556.p6967e.rst new file mode 100644 index 00000000000..5b1c326f486 --- /dev/null +++ b/Misc/NEWS.d/next/Library/029.bpo-28556.p6967e.rst @@ -0,0 +1,3 @@ +Various updates to typing module: typing.Counter, typing.ChainMap, improved +ABC caching, etc. Original PRs by Jelle Zijlstra, Ivan Levkivskyi, Manuel +Krebber, and ?ukasz Langa. diff --git a/Misc/NEWS.d/next/Library/030.bpo-29532.YCwVQn.rst b/Misc/NEWS.d/next/Library/030.bpo-29532.YCwVQn.rst new file mode 100644 index 00000000000..9e3a25e2908 --- /dev/null +++ b/Misc/NEWS.d/next/Library/030.bpo-29532.YCwVQn.rst @@ -0,0 +1,2 @@ +Altering a kwarg dictionary passed to functools.partial() no longer affects +a partial object after creation. diff --git a/Misc/NEWS.d/next/Library/031.bpo-28961.Rt93vg.rst b/Misc/NEWS.d/next/Library/031.bpo-28961.Rt93vg.rst new file mode 100644 index 00000000000..31d81af9853 --- /dev/null +++ b/Misc/NEWS.d/next/Library/031.bpo-28961.Rt93vg.rst @@ -0,0 +1,2 @@ +Fix unittest.mock._Call helper: don't ignore the name parameter anymore. +Patch written by Jiajun Huang. diff --git a/Misc/NEWS.d/next/Library/032.bpo-29110.wmE-_T.rst b/Misc/NEWS.d/next/Library/032.bpo-29110.wmE-_T.rst new file mode 100644 index 00000000000..10c495cb907 --- /dev/null +++ b/Misc/NEWS.d/next/Library/032.bpo-29110.wmE-_T.rst @@ -0,0 +1,2 @@ +Fix file object leak in aifc.open() when file is given as a filesystem path +and is not in valid AIFF format. Patch by Anthony Zhang. diff --git a/Misc/NEWS.d/next/Library/033.bpo-29376.rrJhJy.rst b/Misc/NEWS.d/next/Library/033.bpo-29376.rrJhJy.rst new file mode 100644 index 00000000000..5b610c45895 --- /dev/null +++ b/Misc/NEWS.d/next/Library/033.bpo-29376.rrJhJy.rst @@ -0,0 +1 @@ +Fix assertion error in threading._DummyThread.is_alive(). diff --git a/Misc/NEWS.d/next/Library/034.bpo-29703.ZdsPCR.rst b/Misc/NEWS.d/next/Library/034.bpo-29703.ZdsPCR.rst new file mode 100644 index 00000000000..ce844f7b2ba --- /dev/null +++ b/Misc/NEWS.d/next/Library/034.bpo-29703.ZdsPCR.rst @@ -0,0 +1 @@ +Fix asyncio to support instantiation of new event loops in child processes. diff --git a/Misc/NEWS.d/next/Library/035.bpo-29704.WHbx27.rst b/Misc/NEWS.d/next/Library/035.bpo-29704.WHbx27.rst new file mode 100644 index 00000000000..c371cedc086 --- /dev/null +++ b/Misc/NEWS.d/next/Library/035.bpo-29704.WHbx27.rst @@ -0,0 +1,2 @@ +asyncio.subprocess.SubprocessStreamProtocol no longer closes before all +pipes are closed. diff --git a/Misc/NEWS.d/next/Library/036.bpo-29615.OpFKzg.rst b/Misc/NEWS.d/next/Library/036.bpo-29615.OpFKzg.rst new file mode 100644 index 00000000000..4cef50404a5 --- /dev/null +++ b/Misc/NEWS.d/next/Library/036.bpo-29615.OpFKzg.rst @@ -0,0 +1,2 @@ +SimpleXMLRPCDispatcher no longer chains KeyError (or any other exception) to +exception(s) raised in the dispatched methods. Patch by Petr Motejlek. diff --git a/Misc/NEWS.d/next/Library/037.bpo-28298.xfm84U.rst b/Misc/NEWS.d/next/Library/037.bpo-28298.xfm84U.rst new file mode 100644 index 00000000000..fd97c125e68 --- /dev/null +++ b/Misc/NEWS.d/next/Library/037.bpo-28298.xfm84U.rst @@ -0,0 +1,2 @@ +Fix a bug that prevented array 'Q', 'L' and 'I' from accepting big intables +(objects that have __int__) as elements. Patch by Oren Milman. diff --git a/Misc/NEWS.d/next/Library/038.bpo-8256.jAwGQH.rst b/Misc/NEWS.d/next/Library/038.bpo-8256.jAwGQH.rst new file mode 100644 index 00000000000..3a9fc7c07bc --- /dev/null +++ b/Misc/NEWS.d/next/Library/038.bpo-8256.jAwGQH.rst @@ -0,0 +1,2 @@ +Fixed possible failing or crashing input() if attributes "encoding" or +"errors" of sys.stdin or sys.stdout are not set or are not strings. diff --git a/Misc/NEWS.d/next/Library/039.bpo-29742.8hqfEO.rst b/Misc/NEWS.d/next/Library/039.bpo-29742.8hqfEO.rst new file mode 100644 index 00000000000..af487f02efe --- /dev/null +++ b/Misc/NEWS.d/next/Library/039.bpo-29742.8hqfEO.rst @@ -0,0 +1,2 @@ +get_extra_info() raises exception if get called on closed ssl transport. +Patch by Nikolay Kim. diff --git a/Misc/NEWS.d/next/Library/040.bpo-29800.d2xASa.rst b/Misc/NEWS.d/next/Library/040.bpo-29800.d2xASa.rst new file mode 100644 index 00000000000..e4aba4b88e6 --- /dev/null +++ b/Misc/NEWS.d/next/Library/040.bpo-29800.d2xASa.rst @@ -0,0 +1,2 @@ +Fix crashes in partial.__repr__ if the keys of partial.keywords are not +strings. Patch by Michael Seifert. diff --git a/Misc/NEWS.d/next/Library/041.bpo-25455.ZsahHN.rst b/Misc/NEWS.d/next/Library/041.bpo-25455.ZsahHN.rst new file mode 100644 index 00000000000..ee68d5b6c86 --- /dev/null +++ b/Misc/NEWS.d/next/Library/041.bpo-25455.ZsahHN.rst @@ -0,0 +1 @@ +Fixed crashes in repr of recursive buffered file-like objects. diff --git a/Misc/NEWS.d/next/Library/042.bpo-29884.kWXR8W.rst b/Misc/NEWS.d/next/Library/042.bpo-29884.kWXR8W.rst new file mode 100644 index 00000000000..90b5f0cf9ac --- /dev/null +++ b/Misc/NEWS.d/next/Library/042.bpo-29884.kWXR8W.rst @@ -0,0 +1,2 @@ +faulthandler: Restore the old sigaltstack during teardown. Patch by +Christophe Zeitouny. diff --git a/Misc/NEWS.d/next/Library/043.bpo-29861.t2ZoRK.rst b/Misc/NEWS.d/next/Library/043.bpo-29861.t2ZoRK.rst new file mode 100644 index 00000000000..c14091ab5bd --- /dev/null +++ b/Misc/NEWS.d/next/Library/043.bpo-29861.t2ZoRK.rst @@ -0,0 +1,2 @@ +Release references to tasks, their arguments and their results as soon as +they are finished in multiprocessing.Pool. diff --git a/Misc/NEWS.d/next/Library/044.bpo-25803.CPDR0W.rst b/Misc/NEWS.d/next/Library/044.bpo-25803.CPDR0W.rst new file mode 100644 index 00000000000..2ca8488f397 --- /dev/null +++ b/Misc/NEWS.d/next/Library/044.bpo-25803.CPDR0W.rst @@ -0,0 +1,2 @@ +Avoid incorrect errors raised by Path.mkdir(exist_ok=True) when the OS gives +priority to errors such as EACCES over EEXIST. diff --git a/Misc/NEWS.d/next/Library/045.bpo-28699.wZztZP.rst b/Misc/NEWS.d/next/Library/045.bpo-28699.wZztZP.rst new file mode 100644 index 00000000000..5ea6808390e --- /dev/null +++ b/Misc/NEWS.d/next/Library/045.bpo-28699.wZztZP.rst @@ -0,0 +1,3 @@ +Fixed a bug in pools in multiprocessing.pool that raising an exception at +the very first of an iterable may swallow the exception or make the program +hang. Patch by Davin Potts and Xiang Zhang. diff --git a/Misc/NEWS.d/next/Library/046.bpo-27863.pPYHHI.rst b/Misc/NEWS.d/next/Library/046.bpo-27863.pPYHHI.rst new file mode 100644 index 00000000000..49f0f03d7bb --- /dev/null +++ b/Misc/NEWS.d/next/Library/046.bpo-27863.pPYHHI.rst @@ -0,0 +1,2 @@ +Fixed multiple crashes in ElementTree caused by race conditions and wrong +types. diff --git a/Misc/NEWS.d/next/Library/047.bpo-29942.CsGNuT.rst b/Misc/NEWS.d/next/Library/047.bpo-29942.CsGNuT.rst new file mode 100644 index 00000000000..39b8ba8f3e0 --- /dev/null +++ b/Misc/NEWS.d/next/Library/047.bpo-29942.CsGNuT.rst @@ -0,0 +1,2 @@ +Fix a crash in itertools.chain.from_iterable when encountering long runs of +empty iterables. diff --git a/Misc/NEWS.d/next/Library/048.bpo-29998.poeIKD.rst b/Misc/NEWS.d/next/Library/048.bpo-29998.poeIKD.rst new file mode 100644 index 00000000000..1999770e5d3 --- /dev/null +++ b/Misc/NEWS.d/next/Library/048.bpo-29998.poeIKD.rst @@ -0,0 +1 @@ +Pickling and copying ImportError now preserves name and path attributes. diff --git a/Misc/NEWS.d/next/Library/049.bpo-29692.oyWrAE.rst b/Misc/NEWS.d/next/Library/049.bpo-29692.oyWrAE.rst new file mode 100644 index 00000000000..118475deca0 --- /dev/null +++ b/Misc/NEWS.d/next/Library/049.bpo-29692.oyWrAE.rst @@ -0,0 +1,2 @@ +Fixed arbitrary unchaining of RuntimeError exceptions in +contextlib.contextmanager. Patch by Siddharth Velankar. diff --git a/Misc/NEWS.d/next/Library/050.bpo-29694.LWKxb1.rst b/Misc/NEWS.d/next/Library/050.bpo-29694.LWKxb1.rst new file mode 100644 index 00000000000..fd91668c3df --- /dev/null +++ b/Misc/NEWS.d/next/Library/050.bpo-29694.LWKxb1.rst @@ -0,0 +1,2 @@ +Fixed race condition in pathlib mkdir with flags parents=True. Patch by +Armin Rigo. diff --git a/Misc/NEWS.d/next/Library/051.bpo-30068.n4q47r.rst b/Misc/NEWS.d/next/Library/051.bpo-30068.n4q47r.rst new file mode 100644 index 00000000000..429673b83ac --- /dev/null +++ b/Misc/NEWS.d/next/Library/051.bpo-30068.n4q47r.rst @@ -0,0 +1 @@ +_io._IOBase.readlines will check if it's closed first when hint is present. diff --git a/Misc/NEWS.d/next/Library/052.bpo-30061.2w_dX9.rst b/Misc/NEWS.d/next/Library/052.bpo-30061.2w_dX9.rst new file mode 100644 index 00000000000..0b181f6084f --- /dev/null +++ b/Misc/NEWS.d/next/Library/052.bpo-30061.2w_dX9.rst @@ -0,0 +1,4 @@ +Fixed crashes in IOBase methods __next__() and readlines() when readline() +or __next__() respectively return non-sizeable object. Fixed possible other +errors caused by not checking results of PyObject_Size(), PySequence_Size(), +or PyMapping_Size(). diff --git a/Misc/NEWS.d/next/Library/053.bpo-30070.XM_B41.rst b/Misc/NEWS.d/next/Library/053.bpo-30070.XM_B41.rst new file mode 100644 index 00000000000..8e31371216a --- /dev/null +++ b/Misc/NEWS.d/next/Library/053.bpo-30070.XM_B41.rst @@ -0,0 +1 @@ +Fixed leaks and crashes in errors handling in the parser module. diff --git a/Misc/NEWS.d/next/Library/054.bpo-30205.BsxO34.rst b/Misc/NEWS.d/next/Library/054.bpo-30205.BsxO34.rst new file mode 100644 index 00000000000..2692614a80a --- /dev/null +++ b/Misc/NEWS.d/next/Library/054.bpo-30205.BsxO34.rst @@ -0,0 +1 @@ +Fix getsockname() for unbound AF_UNIX sockets on Linux. diff --git a/Misc/NEWS.d/next/Library/055.bpo-28556.51gjbP.rst b/Misc/NEWS.d/next/Library/055.bpo-28556.51gjbP.rst new file mode 100644 index 00000000000..dd8fc74567d --- /dev/null +++ b/Misc/NEWS.d/next/Library/055.bpo-28556.51gjbP.rst @@ -0,0 +1,3 @@ +Various updates to typing module: add typing.NoReturn type, use +WrapperDescriptorType, minor bug-fixes. Original PRs by Jim Fasarakis- +Hilliard and Ivan Levkivskyi. diff --git a/Misc/NEWS.d/next/Library/056.bpo-30185.Tiu1n8.rst b/Misc/NEWS.d/next/Library/056.bpo-30185.Tiu1n8.rst new file mode 100644 index 00000000000..f19d47c7af9 --- /dev/null +++ b/Misc/NEWS.d/next/Library/056.bpo-30185.Tiu1n8.rst @@ -0,0 +1,2 @@ +Avoid KeyboardInterrupt tracebacks in forkserver helper process when Ctrl-C +is received. diff --git a/Misc/NEWS.d/next/Library/057.bpo-30243.RHQt0v.rst b/Misc/NEWS.d/next/Library/057.bpo-30243.RHQt0v.rst new file mode 100644 index 00000000000..6037eaf2555 --- /dev/null +++ b/Misc/NEWS.d/next/Library/057.bpo-30243.RHQt0v.rst @@ -0,0 +1,3 @@ +Removed the __init__ methods of _json's scanner and encoder. Misusing them +could cause memory leaks or crashes. Now scanner and encoder objects are +completely initialized in the __new__ methods. diff --git a/Misc/NEWS.d/next/Library/058.bpo-26293.wig0YG.rst b/Misc/NEWS.d/next/Library/058.bpo-26293.wig0YG.rst new file mode 100644 index 00000000000..ae977481643 --- /dev/null +++ b/Misc/NEWS.d/next/Library/058.bpo-26293.wig0YG.rst @@ -0,0 +1 @@ +Change resulted because of zipfile breakage. (See also: bpo-29094) diff --git a/Misc/NEWS.d/next/Library/059.bpo-29990.HWV6KE.rst b/Misc/NEWS.d/next/Library/059.bpo-29990.HWV6KE.rst new file mode 100644 index 00000000000..7a6793095f4 --- /dev/null +++ b/Misc/NEWS.d/next/Library/059.bpo-29990.HWV6KE.rst @@ -0,0 +1 @@ +Fix range checking in GB18030 decoder. Original patch by Ma Lin. diff --git a/Misc/NEWS.d/next/Library/060.bpo-30048.ELRx8R.rst b/Misc/NEWS.d/next/Library/060.bpo-30048.ELRx8R.rst new file mode 100644 index 00000000000..ee47a9e5832 --- /dev/null +++ b/Misc/NEWS.d/next/Library/060.bpo-30048.ELRx8R.rst @@ -0,0 +1,2 @@ +Fixed ``Task.cancel()`` can be ignored when the task is running coroutine +and the coroutine returned without any more ``await``. diff --git a/Misc/NEWS.d/next/Library/061.bpo-30375.9c8qM7.rst b/Misc/NEWS.d/next/Library/061.bpo-30375.9c8qM7.rst new file mode 100644 index 00000000000..cb0f7eb038c --- /dev/null +++ b/Misc/NEWS.d/next/Library/061.bpo-30375.9c8qM7.rst @@ -0,0 +1,3 @@ +Warnings emitted when compile a regular expression now always point to the +line in the user code. Previously they could point into inners of the re +module if emitted from inside of groups or conditionals. diff --git a/Misc/NEWS.d/next/Library/062.bpo-30329.EuT36N.rst b/Misc/NEWS.d/next/Library/062.bpo-30329.EuT36N.rst new file mode 100644 index 00000000000..d9d7be37e44 --- /dev/null +++ b/Misc/NEWS.d/next/Library/062.bpo-30329.EuT36N.rst @@ -0,0 +1,3 @@ +imaplib and poplib now catch the Windows socket WSAEINVAL error (code 10022) +on shutdown(SHUT_RDWR): An invalid operation was attempted. This error +occurs sometimes on SSL connections. diff --git a/Misc/NEWS.d/next/Library/063.bpo-30301.ywOkjN.rst b/Misc/NEWS.d/next/Library/063.bpo-30301.ywOkjN.rst new file mode 100644 index 00000000000..0479f10483f --- /dev/null +++ b/Misc/NEWS.d/next/Library/063.bpo-30301.ywOkjN.rst @@ -0,0 +1,2 @@ +Fix AttributeError when using SimpleQueue.empty() under *spawn* and +*forkserver* start methods. diff --git a/Misc/NEWS.d/next/Library/064.bpo-30003.BOl9HE.rst b/Misc/NEWS.d/next/Library/064.bpo-30003.BOl9HE.rst new file mode 100644 index 00000000000..ac449728fd7 --- /dev/null +++ b/Misc/NEWS.d/next/Library/064.bpo-30003.BOl9HE.rst @@ -0,0 +1 @@ +Fix handling escape characters in HZ codec. Based on patch by Ma Lin. diff --git a/Misc/NEWS.d/next/Library/065.bpo-30414.jGl1Lb.rst b/Misc/NEWS.d/next/Library/065.bpo-30414.jGl1Lb.rst new file mode 100644 index 00000000000..3bd0a23069e --- /dev/null +++ b/Misc/NEWS.d/next/Library/065.bpo-30414.jGl1Lb.rst @@ -0,0 +1,2 @@ +multiprocessing.Queue._feed background running thread do not break from main +loop on exception. diff --git a/Misc/NEWS.d/next/Library/066.bpo-29960.g0wr3r.rst b/Misc/NEWS.d/next/Library/066.bpo-29960.g0wr3r.rst new file mode 100644 index 00000000000..0b37a4b96d5 --- /dev/null +++ b/Misc/NEWS.d/next/Library/066.bpo-29960.g0wr3r.rst @@ -0,0 +1,2 @@ +Preserve generator state when _random.Random.setstate() raises an exception. +Patch by Bryan Olson. diff --git a/Misc/NEWS.d/next/Library/067.bpo-30378.R_19_5.rst b/Misc/NEWS.d/next/Library/067.bpo-30378.R_19_5.rst new file mode 100644 index 00000000000..5994abe142c --- /dev/null +++ b/Misc/NEWS.d/next/Library/067.bpo-30378.R_19_5.rst @@ -0,0 +1,2 @@ +Fix the problem that logging.handlers.SysLogHandler cannot handle IPv6 +addresses. diff --git a/Misc/NEWS.d/next/Library/068.bpo-30418.EwISQm.rst b/Misc/NEWS.d/next/Library/068.bpo-30418.EwISQm.rst new file mode 100644 index 00000000000..43e149daffe --- /dev/null +++ b/Misc/NEWS.d/next/Library/068.bpo-30418.EwISQm.rst @@ -0,0 +1,2 @@ +On Windows, subprocess.Popen.communicate() now also ignore EINVAL on +stdin.write() if the child process is still running but closed the pipe. diff --git a/Misc/NEWS.d/next/Library/069.bpo-27585.0Ugqqu.rst b/Misc/NEWS.d/next/Library/069.bpo-27585.0Ugqqu.rst new file mode 100644 index 00000000000..3e31ab1b855 --- /dev/null +++ b/Misc/NEWS.d/next/Library/069.bpo-27585.0Ugqqu.rst @@ -0,0 +1 @@ +Fix waiter cancellation in asyncio.Lock. Patch by Mathieu Sornay. diff --git a/Misc/NEWS.d/next/Library/070.bpo-29743.en2P4s.rst b/Misc/NEWS.d/next/Library/070.bpo-29743.en2P4s.rst new file mode 100644 index 00000000000..c4264b45ce5 --- /dev/null +++ b/Misc/NEWS.d/next/Library/070.bpo-29743.en2P4s.rst @@ -0,0 +1,2 @@ +Closing transport during handshake process leaks open socket. Patch by +Nikolay Kim diff --git a/Misc/NEWS.d/next/Library/071.bpo-29870.p960Ih.rst b/Misc/NEWS.d/next/Library/071.bpo-29870.p960Ih.rst new file mode 100644 index 00000000000..55b78a7a79b --- /dev/null +++ b/Misc/NEWS.d/next/Library/071.bpo-29870.p960Ih.rst @@ -0,0 +1,2 @@ +Fix ssl sockets leaks when connection is aborted in asyncio/ssl +implementation. Patch by Micha?l Sgha?er. diff --git a/Misc/NEWS.d/next/Library/072.bpo-28556.mESP7G.rst b/Misc/NEWS.d/next/Library/072.bpo-28556.mESP7G.rst new file mode 100644 index 00000000000..96a4eeb3cb9 --- /dev/null +++ b/Misc/NEWS.d/next/Library/072.bpo-28556.mESP7G.rst @@ -0,0 +1,3 @@ +Updates to typing module: Add generic AsyncContextManager, add support for +ContextManager on all versions. Original PRs by Jelle Zijlstra and Ivan +Levkivskyi diff --git a/Misc/NEWS.d/next/Library/073.bpo-30508.wNWRS2.rst b/Misc/NEWS.d/next/Library/073.bpo-30508.wNWRS2.rst new file mode 100644 index 00000000000..c0322082e8b --- /dev/null +++ b/Misc/NEWS.d/next/Library/073.bpo-30508.wNWRS2.rst @@ -0,0 +1 @@ +Don't log exceptions if Task/Future "cancel()" method was called. diff --git a/Misc/NEWS.d/next/Library/074.bpo-28994.9vzun1.rst b/Misc/NEWS.d/next/Library/074.bpo-28994.9vzun1.rst new file mode 100644 index 00000000000..80de944b4e8 --- /dev/null +++ b/Misc/NEWS.d/next/Library/074.bpo-28994.9vzun1.rst @@ -0,0 +1,2 @@ +The traceback no longer displayed for SystemExit raised in a callback +registered by atexit. diff --git a/Misc/NEWS.d/next/Library/075.bpo-24484.vFem8K.rst b/Misc/NEWS.d/next/Library/075.bpo-24484.vFem8K.rst new file mode 100644 index 00000000000..ac5b648a25b --- /dev/null +++ b/Misc/NEWS.d/next/Library/075.bpo-24484.vFem8K.rst @@ -0,0 +1 @@ +Avoid race condition in multiprocessing cleanup. diff --git a/Misc/NEWS.d/next/Library/077.bpo-29931.tfcTwK.rst b/Misc/NEWS.d/next/Library/077.bpo-29931.tfcTwK.rst new file mode 100644 index 00000000000..cb098ff6b05 --- /dev/null +++ b/Misc/NEWS.d/next/Library/077.bpo-29931.tfcTwK.rst @@ -0,0 +1,2 @@ +Fixed comparison check for ipaddress.ip_interface objects. Patch by Sanjay +Sundaresan. diff --git a/Misc/NEWS.d/next/Library/078.bpo-30149.hE649r.rst b/Misc/NEWS.d/next/Library/078.bpo-30149.hE649r.rst new file mode 100644 index 00000000000..44a69f47ce8 --- /dev/null +++ b/Misc/NEWS.d/next/Library/078.bpo-30149.hE649r.rst @@ -0,0 +1,2 @@ +inspect.signature() now supports callables with variable-argument parameters +wrapped with partialmethod. Patch by Dong-hee Na. diff --git a/Misc/NEWS.d/next/Library/079.bpo-23890.GCFAAZ.rst b/Misc/NEWS.d/next/Library/079.bpo-23890.GCFAAZ.rst new file mode 100644 index 00000000000..7a589f1dcdb --- /dev/null +++ b/Misc/NEWS.d/next/Library/079.bpo-23890.GCFAAZ.rst @@ -0,0 +1,2 @@ +unittest.TestCase.assertRaises() now manually breaks a reference cycle to +not keep objects alive longer than expected. diff --git a/Misc/NEWS.d/next/Library/080.bpo-30645.oYzbbW.rst b/Misc/NEWS.d/next/Library/080.bpo-30645.oYzbbW.rst new file mode 100644 index 00000000000..be8637f9fcf --- /dev/null +++ b/Misc/NEWS.d/next/Library/080.bpo-30645.oYzbbW.rst @@ -0,0 +1,2 @@ +Fix path calculation in imp.load_package(), fixing it for cases when a +package is only shipped with bytecodes. Patch by Alexandru Ardelean. diff --git a/Misc/NEWS.d/next/Library/082.bpo-29755.diQcY_.rst b/Misc/NEWS.d/next/Library/082.bpo-29755.diQcY_.rst new file mode 100644 index 00000000000..f4f1b277c18 --- /dev/null +++ b/Misc/NEWS.d/next/Library/082.bpo-29755.diQcY_.rst @@ -0,0 +1,2 @@ +Fixed the lgettext() family of functions in the gettext module. They now +always return bytes. diff --git a/Misc/NEWS.d/next/Library/085.bpo-30746.7drQI0.rst b/Misc/NEWS.d/next/Library/085.bpo-30746.7drQI0.rst new file mode 100644 index 00000000000..94803bb5f1d --- /dev/null +++ b/Misc/NEWS.d/next/Library/085.bpo-30746.7drQI0.rst @@ -0,0 +1,2 @@ +Prohibited the '=' character in environment variable names in +``os.putenv()`` and ``os.spawn*()``. diff --git a/Misc/NEWS.d/next/Library/086.bpo-30879.N3KI-o.rst b/Misc/NEWS.d/next/Library/086.bpo-30879.N3KI-o.rst new file mode 100644 index 00000000000..862c114aef8 --- /dev/null +++ b/Misc/NEWS.d/next/Library/086.bpo-30879.N3KI-o.rst @@ -0,0 +1,2 @@ +os.listdir() and os.scandir() now emit bytes names when called with bytes- +like argument. diff --git a/Misc/NEWS.d/next/Library/087.bpo-29169.8ypApm.rst b/Misc/NEWS.d/next/Library/087.bpo-29169.8ypApm.rst new file mode 100644 index 00000000000..96d066d41d2 --- /dev/null +++ b/Misc/NEWS.d/next/Library/087.bpo-29169.8ypApm.rst @@ -0,0 +1 @@ +Update zlib to 1.2.11. diff --git a/Misc/NEWS.d/next/Security/076.bpo-29591.ExKblw.rst b/Misc/NEWS.d/next/Security/076.bpo-29591.ExKblw.rst new file mode 100644 index 00000000000..7394ac2ff0e --- /dev/null +++ b/Misc/NEWS.d/next/Security/076.bpo-29591.ExKblw.rst @@ -0,0 +1,5 @@ +.. original section: Library + +Update expat copy from 2.1.1 to 2.2.0 to get fixes of CVE-2016-0718 and +CVE-2016-4472. See https://sourceforge.net/p/expat/bugs/537/ for more +information. diff --git a/Misc/NEWS.d/next/Security/081.bpo-30500.1VG7R-.rst b/Misc/NEWS.d/next/Security/081.bpo-30500.1VG7R-.rst new file mode 100644 index 00000000000..adf464567b0 --- /dev/null +++ b/Misc/NEWS.d/next/Security/081.bpo-30500.1VG7R-.rst @@ -0,0 +1,6 @@ +.. original section: Library + +Fix urllib.parse.splithost() to correctly parse fragments. For example, +``splithost('//127.0.0.1#@evil.com/')`` now correctly returns the +``127.0.0.1`` host, instead of treating ``@evil.com`` as the host in an +authentification (``login at host``). diff --git a/Misc/NEWS.d/next/Security/083.bpo-30694.WkMWM_.rst b/Misc/NEWS.d/next/Security/083.bpo-30694.WkMWM_.rst new file mode 100644 index 00000000000..ebbd359e63f --- /dev/null +++ b/Misc/NEWS.d/next/Security/083.bpo-30694.WkMWM_.rst @@ -0,0 +1,10 @@ +.. original section: Library + +Upgrade expat copy from 2.2.0 to 2.2.1 to get fixes of multiple security +vulnerabilities including: CVE-2017-9233 (External entity infinite loop +DoS), CVE-2016-9063 (Integer overflow, re-fix), CVE-2016-0718 (Fix +regression bugs from 2.2.0's fix to CVE-2016-0718) and CVE-2012-0876 +(Counter hash flooding with SipHash). Note: the CVE-2016-5300 (Use os- +specific entropy sources like getrandom) doesn't impact Python, since Python +already gets entropy from the OS to set the expat secret using +``XML_SetHashSalt()``. diff --git a/Misc/NEWS.d/next/Security/084.bpo-30730.rJsyTH.rst b/Misc/NEWS.d/next/Security/084.bpo-30730.rJsyTH.rst new file mode 100644 index 00000000000..008aa706d49 --- /dev/null +++ b/Misc/NEWS.d/next/Security/084.bpo-30730.rJsyTH.rst @@ -0,0 +1,4 @@ +.. original section: Library + +Prevent environment variables injection in subprocess on Windows. Prevent +passing other environment variables and command arguments. diff --git a/Misc/NEWS.d/next/Tests/001.bpo-29571.r6Dixr.rst b/Misc/NEWS.d/next/Tests/001.bpo-29571.r6Dixr.rst new file mode 100644 index 00000000000..ec4c9986ab1 --- /dev/null +++ b/Misc/NEWS.d/next/Tests/001.bpo-29571.r6Dixr.rst @@ -0,0 +1,4 @@ +to match the behaviour of the ``re.LOCALE`` flag, test_re.test_locale_flag +now uses ``locale.getpreferredencoding(False)`` to determine the candidate +encoding for the test regex (allowing it to correctly skip the test when the +default locale encoding is a multi-byte encoding) diff --git a/Misc/NEWS.d/next/Tests/002.bpo-30197.c5wRfu.rst b/Misc/NEWS.d/next/Tests/002.bpo-30197.c5wRfu.rst new file mode 100644 index 00000000000..63461bb478b --- /dev/null +++ b/Misc/NEWS.d/next/Tests/002.bpo-30197.c5wRfu.rst @@ -0,0 +1,5 @@ +Enhanced functions swap_attr() and swap_item() in the test.support module. +They now work when delete replaced attribute or item inside the with +statement. The old value of the attribute or item (or None if it doesn't +exist) now will be assigned to the target of the "as" clause, if there is +one. diff --git a/Misc/NEWS.d/next/Tests/003.bpo-28087.m8dc4R.rst b/Misc/NEWS.d/next/Tests/003.bpo-28087.m8dc4R.rst new file mode 100644 index 00000000000..5e33e56ad4f --- /dev/null +++ b/Misc/NEWS.d/next/Tests/003.bpo-28087.m8dc4R.rst @@ -0,0 +1,3 @@ +Skip test_asyncore and test_eintr poll failures on macOS. Skip some tests of +select.poll when running on macOS due to unresolved issues with the +underlying system poll function on some macOS versions. diff --git a/Misc/NEWS.d/next/Tests/004.bpo-30357.n4CPEa.rst b/Misc/NEWS.d/next/Tests/004.bpo-30357.n4CPEa.rst new file mode 100644 index 00000000000..c7e7b7f242b --- /dev/null +++ b/Misc/NEWS.d/next/Tests/004.bpo-30357.n4CPEa.rst @@ -0,0 +1,3 @@ +test_thread: setUp() now uses support.threading_setup() and +support.threading_cleanup() to wait until threads complete to avoid random +side effects on following tests. Initial patch written by Grzegorz Grzywacz. diff --git a/Misc/NEWS.d/next/Windows/016.bpo-29392.OtqS5t.rst b/Misc/NEWS.d/next/Windows/016.bpo-29392.OtqS5t.rst new file mode 100644 index 00000000000..881b2c8cd3c --- /dev/null +++ b/Misc/NEWS.d/next/Windows/016.bpo-29392.OtqS5t.rst @@ -0,0 +1 @@ +Prevent crash when passing invalid arguments into msvcrt module. diff --git a/Misc/NEWS.d/next/Windows/017.bpo-30687.8mqHnu.rst b/Misc/NEWS.d/next/Windows/017.bpo-30687.8mqHnu.rst new file mode 100644 index 00000000000..9f37c075b84 --- /dev/null +++ b/Misc/NEWS.d/next/Windows/017.bpo-30687.8mqHnu.rst @@ -0,0 +1 @@ +Locate msbuild.exe on Windows when building rather than vcvarsall.bat From solipsis at pitrou.net Tue Jul 25 05:16:25 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Tue, 25 Jul 2017 09:16:25 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=11 Message-ID: <20170725091624.96111.9D7EDF491D1A5B12@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [0, 7, 0] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [-2, 2, 0] memory blocks, sum=0 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogZhqVre', '--timeout', '7200'] From webhook-mailer at python.org Tue Jul 25 08:32:10 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 12:32:10 -0000 Subject: [Python-checkins] Fix a small typo in a comment (#2863) Message-ID: https://github.com/python/cpython/commit/ccfdb60af7b2db578c1aceb7742cec0330766667 commit: ccfdb60af7b2db578c1aceb7742cec0330766667 branch: master author: St?phane Wirtel committer: Victor Stinner date: 2017-07-25T14:32:08+02:00 summary: Fix a small typo in a comment (#2863) files: M Python/pylifecycle.c diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c index 3953fec0f52..eaa7b7f4599 100644 --- a/Python/pylifecycle.c +++ b/Python/pylifecycle.c @@ -535,7 +535,7 @@ _Py_CoerceLegacyLocale(void) * safe to call without calling Py_Initialize first) */ -/* TODO: Progresively move functionality from Py_BeginInitialization to +/* TODO: Progressively move functionality from Py_BeginInitialization to * Py_ReadConfig and Py_EndInitialization */ From webhook-mailer at python.org Tue Jul 25 09:33:58 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Tue, 25 Jul 2017 13:33:58 -0000 Subject: [Python-checkins] bpo-31029: test_tokenize Add missing import unittest (#2865) Message-ID: https://github.com/python/cpython/commit/90addd6d1c1fde4ec12a6b554d1deacfac6a879c commit: 90addd6d1c1fde4ec12a6b554d1deacfac6a879c branch: master author: St?phane Wirtel committer: Serhiy Storchaka date: 2017-07-25T16:33:53+03:00 summary: bpo-31029: test_tokenize Add missing import unittest (#2865) files: M Lib/test/test_tokenize.py diff --git a/Lib/test/test_tokenize.py b/Lib/test/test_tokenize.py index 538612cf94e..21eee6de2d1 100644 --- a/Lib/test/test_tokenize.py +++ b/Lib/test/test_tokenize.py @@ -3,6 +3,7 @@ STRING, ENDMARKER, ENCODING, tok_name, detect_encoding, open as tokenize_open, Untokenizer) from io import BytesIO +import unittest from unittest import TestCase, mock from test.test_grammar import (VALID_UNDERSCORE_LITERALS, INVALID_UNDERSCORE_LITERALS) From webhook-mailer at python.org Tue Jul 25 11:45:58 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 15:45:58 -0000 Subject: [Python-checkins] bpo-31009: Fix support.fd_count() on Windows (#2862) Message-ID: https://github.com/python/cpython/commit/302bbbe9ba5c72559913e2ea006c921f698a729d commit: 302bbbe9ba5c72559913e2ea006c921f698a729d branch: master author: Victor Stinner committer: GitHub date: 2017-07-25T17:45:53+02:00 summary: bpo-31009: Fix support.fd_count() on Windows (#2862) * bpo-31009: Fix support.fd_count() on Windows On Windows, test.support.fd_count() now calls msvcrt.CrtSetReportMode() to not kill the process nor log any error on stderr on os.dup(fd) if the file descriptor is invalid. * Fix for release mode files: M Lib/test/support/__init__.py M Lib/test/test_regrtest.py diff --git a/Lib/test/support/__init__.py b/Lib/test/support/__init__.py index 3a4d27e6b88..7a4671c1b2b 100644 --- a/Lib/test/support/__init__.py +++ b/Lib/test/support/__init__.py @@ -2649,12 +2649,6 @@ def disable_faulthandler(): faulthandler.enable(file=fd, all_threads=True) -try: - MAXFD = os.sysconf("SC_OPEN_MAX") -except Exception: - MAXFD = 256 - - def fd_count(): """Count the number of open file descriptors. """ @@ -2665,16 +2659,48 @@ def fd_count(): except FileNotFoundError: pass - count = 0 - for fd in range(MAXFD): + old_modes = None + if sys.platform == 'win32': + # bpo-25306, bpo-31009: Call CrtSetReportMode() to not kill the process + # on invalid file descriptor if Python is compiled in debug mode try: - # Prefer dup() over fstat(). fstat() can require input/output - # whereas dup() doesn't. - fd2 = os.dup(fd) - except OSError as e: - if e.errno != errno.EBADF: - raise + import msvcrt + msvcrt.CrtSetReportMode + except (AttributeError, ImportError): + # no msvcrt or a release build + pass else: - os.close(fd2) - count += 1 + old_modes = {} + for report_type in (msvcrt.CRT_WARN, + msvcrt.CRT_ERROR, + msvcrt.CRT_ASSERT): + old_modes[report_type] = msvcrt.CrtSetReportMode(report_type, 0) + + MAXFD = 256 + if hasattr(os, 'sysconf'): + try: + MAXFD = os.sysconf("SC_OPEN_MAX") + except OSError: + pass + + try: + count = 0 + for fd in range(MAXFD): + try: + # Prefer dup() over fstat(). fstat() can require input/output + # whereas dup() doesn't. + fd2 = os.dup(fd) + except OSError as e: + if e.errno != errno.EBADF: + raise + else: + os.close(fd2) + count += 1 + finally: + if old_modes is not None: + for report_type in (msvcrt.CRT_WARN, + msvcrt.CRT_ERROR, + msvcrt.CRT_ASSERT): + msvcrt.CrtSetReportMode(report_type, old_modes[report_type]) + return count diff --git a/Lib/test/test_regrtest.py b/Lib/test/test_regrtest.py index f63ed647f80..b756839748a 100644 --- a/Lib/test/test_regrtest.py +++ b/Lib/test/test_regrtest.py @@ -835,22 +835,10 @@ def test_huntrleaks_fd_leak(self): import os import unittest - # Issue #25306: Disable popups and logs to stderr on assertion - # failures in MSCRT - try: - import msvcrt - msvcrt.CrtSetReportMode - except (ImportError, AttributeError): - # no Windows, o release build - pass - else: - for m in [msvcrt.CRT_WARN, msvcrt.CRT_ERROR, msvcrt.CRT_ASSERT]: - msvcrt.CrtSetReportMode(m, 0) - class FDLeakTest(unittest.TestCase): def test_leak(self): fd = os.open(__file__, os.O_RDONLY) - # bug: never cloes the file descriptor + # bug: never close the file descriptor """) self.check_leak(code, 'file descriptors') From webhook-mailer at python.org Tue Jul 25 13:19:14 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 17:19:14 -0000 Subject: [Python-checkins] bpo-31034: Reliable signal handler for test_asyncio (#2867) Message-ID: https://github.com/python/cpython/commit/830080913c22a9834d310294b9f7653234dc6a59 commit: 830080913c22a9834d310294b9f7653234dc6a59 branch: master author: Victor Stinner committer: GitHub date: 2017-07-25T19:19:09+02:00 summary: bpo-31034: Reliable signal handler for test_asyncio (#2867) * bpo-31034: Reliable signal handler for test_asyncio Don't rely on the current SIGHUP signal handler, make sure that it's set to the "default" signal handler: SIG_DFL. * Add comments files: M Lib/test/test_asyncio/test_events.py M Lib/test/test_asyncio/test_subprocess.py diff --git a/Lib/test/test_asyncio/test_events.py b/Lib/test/test_asyncio/test_events.py index 492a84a2313..9746678607c 100644 --- a/Lib/test/test_asyncio/test_events.py +++ b/Lib/test/test_asyncio/test_events.py @@ -1980,19 +1980,26 @@ def test_subprocess_terminate(self): @unittest.skipIf(sys.platform == 'win32', "Don't have SIGHUP") def test_subprocess_send_signal(self): - prog = os.path.join(os.path.dirname(__file__), 'echo.py') - - connect = self.loop.subprocess_exec( - functools.partial(MySubprocessProtocol, self.loop), - sys.executable, prog) - transp, proto = self.loop.run_until_complete(connect) - self.assertIsInstance(proto, MySubprocessProtocol) - self.loop.run_until_complete(proto.connected) - - transp.send_signal(signal.SIGHUP) - self.loop.run_until_complete(proto.completed) - self.assertEqual(-signal.SIGHUP, proto.returncode) - transp.close() + # bpo-31034: Make sure that we get the default signal handler (killing + # the process). The parent process may have decided to ignore SIGHUP, + # and signal handlers are inherited. + old_handler = signal.signal(signal.SIGHUP, signal.SIG_DFL) + try: + prog = os.path.join(os.path.dirname(__file__), 'echo.py') + + connect = self.loop.subprocess_exec( + functools.partial(MySubprocessProtocol, self.loop), + sys.executable, prog) + transp, proto = self.loop.run_until_complete(connect) + self.assertIsInstance(proto, MySubprocessProtocol) + self.loop.run_until_complete(proto.connected) + + transp.send_signal(signal.SIGHUP) + self.loop.run_until_complete(proto.completed) + self.assertEqual(-signal.SIGHUP, proto.returncode) + transp.close() + finally: + signal.signal(signal.SIGHUP, old_handler) def test_subprocess_stderr(self): prog = os.path.join(os.path.dirname(__file__), 'echo2.py') diff --git a/Lib/test/test_asyncio/test_subprocess.py b/Lib/test/test_asyncio/test_subprocess.py index 2e14a8a9735..e8822c36698 100644 --- a/Lib/test/test_asyncio/test_subprocess.py +++ b/Lib/test/test_asyncio/test_subprocess.py @@ -166,25 +166,32 @@ def test_terminate(self): @unittest.skipIf(sys.platform == 'win32', "Don't have SIGHUP") def test_send_signal(self): - code = 'import time; print("sleeping", flush=True); time.sleep(3600)' - args = [sys.executable, '-c', code] - create = asyncio.create_subprocess_exec(*args, - stdout=subprocess.PIPE, - loop=self.loop) - proc = self.loop.run_until_complete(create) - - @asyncio.coroutine - def send_signal(proc): - # basic synchronization to wait until the program is sleeping - line = yield from proc.stdout.readline() - self.assertEqual(line, b'sleeping\n') + # bpo-31034: Make sure that we get the default signal handler (killing + # the process). The parent process may have decided to ignore SIGHUP, + # and signal handlers are inherited. + old_handler = signal.signal(signal.SIGHUP, signal.SIG_DFL) + try: + code = 'import time; print("sleeping", flush=True); time.sleep(3600)' + args = [sys.executable, '-c', code] + create = asyncio.create_subprocess_exec(*args, + stdout=subprocess.PIPE, + loop=self.loop) + proc = self.loop.run_until_complete(create) - proc.send_signal(signal.SIGHUP) - returncode = (yield from proc.wait()) - return returncode - - returncode = self.loop.run_until_complete(send_signal(proc)) - self.assertEqual(-signal.SIGHUP, returncode) + @asyncio.coroutine + def send_signal(proc): + # basic synchronization to wait until the program is sleeping + line = yield from proc.stdout.readline() + self.assertEqual(line, b'sleeping\n') + + proc.send_signal(signal.SIGHUP) + returncode = (yield from proc.wait()) + return returncode + + returncode = self.loop.run_until_complete(send_signal(proc)) + self.assertEqual(-signal.SIGHUP, returncode) + finally: + signal.signal(signal.SIGHUP, old_handler) def prepare_broken_pipe_test(self): # buffer large enough to feed the whole pipe buffer From webhook-mailer at python.org Tue Jul 25 13:20:41 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 17:20:41 -0000 Subject: [Python-checkins] [3.6] bpo-31018: Switch to GH-pragma pack from __declspec(align) (GH-2848) (#2868) Message-ID: https://github.com/python/cpython/commit/d8b5216f998bbb0f921815165f46918b86620ab7 commit: d8b5216f998bbb0f921815165f46918b86620ab7 branch: 3.6 author: Segev Finer committer: Victor Stinner date: 2017-07-25T19:20:38+02:00 summary: [3.6] bpo-31018: Switch to GH-pragma pack from __declspec(align) (GH-2848) (#2868) (cherry picked from commit 39243779f4c97ec6f700fa73c007ca66dfa9408e) files: M Modules/_tracemalloc.c diff --git a/Modules/_tracemalloc.c b/Modules/_tracemalloc.c index 0ce38ffc78c..4f3bb5463f0 100644 --- a/Modules/_tracemalloc.c +++ b/Modules/_tracemalloc.c @@ -77,7 +77,7 @@ typedef struct #ifdef __GNUC__ __attribute__((packed)) #elif defined(_MSC_VER) -_declspec(align(4)) +#pragma pack(push, 4) #endif { /* filename cannot be NULL: "" is used if the Python frame @@ -85,6 +85,9 @@ _declspec(align(4)) PyObject *filename; unsigned int lineno; } frame_t; +#ifdef _MSC_VER +#pragma pack(pop) +#endif typedef struct { From webhook-mailer at python.org Tue Jul 25 13:20:54 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 17:20:54 -0000 Subject: [Python-checkins] [3.5] bpo-31018: Switch to GH-pragma pack from __declspec(align) (GH-2848) (#2869) Message-ID: https://github.com/python/cpython/commit/49175b3b670a4514b5dc5dcf7b58203d2be852c1 commit: 49175b3b670a4514b5dc5dcf7b58203d2be852c1 branch: 3.5 author: Segev Finer committer: Victor Stinner date: 2017-07-25T19:20:51+02:00 summary: [3.5] bpo-31018: Switch to GH-pragma pack from __declspec(align) (GH-2848) (#2869) (cherry picked from commit 39243779f4c97ec6f700fa73c007ca66dfa9408e) files: M Modules/_tracemalloc.c diff --git a/Modules/_tracemalloc.c b/Modules/_tracemalloc.c index a923e798c12..e2a8e692b88 100644 --- a/Modules/_tracemalloc.c +++ b/Modules/_tracemalloc.c @@ -62,12 +62,15 @@ typedef struct #ifdef __GNUC__ __attribute__((packed)) #elif defined(_MSC_VER) -_declspec(align(4)) +#pragma pack(push, 4) #endif { PyObject *filename; unsigned int lineno; } frame_t; +#ifdef _MSC_VER +#pragma pack(pop) +#endif typedef struct { Py_uhash_t hash; From webhook-mailer at python.org Tue Jul 25 14:04:13 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 25 Jul 2017 18:04:13 -0000 Subject: [Python-checkins] bpo-26506: hex() documentation: mention %x % int (GH-2525) (GH-2870) Message-ID: https://github.com/python/cpython/commit/59e6ab15e47d496ac4e5f9d53aac0fae0c708da4 commit: 59e6ab15e47d496ac4e5f9d53aac0fae0c708da4 branch: 3.6 author: Mariatta committer: GitHub date: 2017-07-25T11:04:08-07:00 summary: bpo-26506: hex() documentation: mention %x % int (GH-2525) (GH-2870) (cherry picked from commit 67ba4fa467ffff825d6a0c0a21cc54ff1df2ed1b) files: M Doc/library/functions.rst diff --git a/Doc/library/functions.rst b/Doc/library/functions.rst index 916e3528d79..bd4c94fcae1 100644 --- a/Doc/library/functions.rst +++ b/Doc/library/functions.rst @@ -81,9 +81,24 @@ are always available. They are listed here in alphabetical order. .. function:: bin(x) - Convert an integer number to a binary string. The result is a valid Python - expression. If *x* is not a Python :class:`int` object, it has to define an - :meth:`__index__` method that returns an integer. + Convert an integer number to a binary string prefixed with "0b". The result + is a valid Python expression. If *x* is not a Python :class:`int` object, it + has to define an :meth:`__index__` method that returns an integer. Some + examples: + + >>> bin(3) + '0b11' + >>> bin(-10) + '-0b1010' + + If prefix "0b" is desired or not, you can use either of the following ways. + + >>> format(14, '#b'), format(14, 'b') + ('0b1110', '1110') + >>> f'{14:#b}', f'{14:b}' + ('0b1110', '1110') + + See also :func:`format` for more information. .. class:: bool([x]) @@ -635,16 +650,26 @@ are always available. They are listed here in alphabetical order. .. function:: hex(x) - Convert an integer number to a lowercase hexadecimal string - prefixed with "0x", for example: + Convert an integer number to a lowercase hexadecimal string prefixed with + "0x". If x is not a Python :class:`int` object, it has to define an + __index__() method that returns an integer. Some examples: >>> hex(255) '0xff' >>> hex(-42) '-0x2a' - If x is not a Python :class:`int` object, it has to define an __index__() - method that returns an integer. + If you want to convert an integer number to an uppercase or lower hexadecimal + string with prefix or not, you can use either of the following ways: + + >>> '%#x' % 255, '%x' % 255, '%X' % 255 + ('0xff', 'ff', 'FF') + >>> format(255, '#x'), format(255, 'x'), format(255, 'X') + ('0xff', 'ff', 'FF') + >>> f'{255:#x}', f'{255:x}', f'{255:X}' + ('0xff', 'ff', 'FF') + + See also :func:`format` for more information. See also :func:`int` for converting a hexadecimal string to an integer using a base of 16. @@ -878,10 +903,27 @@ are always available. They are listed here in alphabetical order. .. function:: oct(x) - Convert an integer number to an octal string. The result is a valid Python - expression. If *x* is not a Python :class:`int` object, it has to define an - :meth:`__index__` method that returns an integer. + Convert an integer number to an octal string prefixed with "0o". The result + is a valid Python expression. If *x* is not a Python :class:`int` object, it + has to define an :meth:`__index__` method that returns an integer. For + example: + + >>> oct(8) + '0o10' + >>> oct(-56) + '-0o70' + + If you want to convert an integer number to octal string either with prefix + "0o" or not, you can use either of the following ways. + + >>> '%#o' % 10, '%o' % 10 + ('0o12', '12') + >>> format(10, '#o'), format(10, 'o') + ('0o12', '12') + >>> f'{10:#o}', f'{10:o}' + ('0o12', '12') + See also :func:`format` for more information. .. index:: single: file object; open() built-in function From webhook-mailer at python.org Tue Jul 25 17:00:03 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 25 Jul 2017 21:00:03 -0000 Subject: [Python-checkins] bpo-30304: Improve TestCase.assertMultiLineEqual docs (GH-2847) Message-ID: https://github.com/python/cpython/commit/0666d0e50432e3b0109db96b8e48fb6c496bd49c commit: 0666d0e50432e3b0109db96b8e48fb6c496bd49c branch: 2.7 author: Aditya Hase committer: Mariatta date: 2017-07-25T13:59:52-07:00 summary: bpo-30304: Improve TestCase.assertMultiLineEqual docs (GH-2847) Mention that TestCase.assertMultiLineEqual method is used by default when comparing Unicode string when comparing Unicode strings with assertEqual. files: M Doc/library/unittest.rst diff --git a/Doc/library/unittest.rst b/Doc/library/unittest.rst index 3c0b96ff66d..15765f5ed58 100644 --- a/Doc/library/unittest.rst +++ b/Doc/library/unittest.rst @@ -1138,7 +1138,7 @@ Test cases Test that the multiline string *first* is equal to the string *second*. When not equal a diff of the two strings highlighting the differences will be included in the error message. This method is used by default - when comparing strings with :meth:`assertEqual`. + when comparing Unicode strings with :meth:`assertEqual`. .. versionadded:: 2.7 From webhook-mailer at python.org Tue Jul 25 17:51:39 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Tue, 25 Jul 2017 21:51:39 -0000 Subject: [Python-checkins] bpo-30302 Make timedelta.__repr__ more informative. (#1493) Message-ID: https://github.com/python/cpython/commit/cc5a65cd9025280ea67ef4bbc2a8bfe31ced6c30 commit: cc5a65cd9025280ea67ef4bbc2a8bfe31ced6c30 branch: master author: Utkarsh Upadhyay committer: Victor Stinner date: 2017-07-25T23:51:33+02:00 summary: bpo-30302 Make timedelta.__repr__ more informative. (#1493) files: A Misc/NEWS.d/next/Library/2017-06-30-23-05-47.bpo-30302.itwK_k.rst M Doc/library/datetime.rst M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Modules/_datetimemodule.c diff --git a/Doc/library/datetime.rst b/Doc/library/datetime.rst index e757e5d685b..625e1590a87 100644 --- a/Doc/library/datetime.rst +++ b/Doc/library/datetime.rst @@ -287,11 +287,12 @@ Supported operations: | | ``[D day[s], ][H]H:MM:SS[.UUUUUU]``, where D | | | is negative for negative ``t``. (5) | +--------------------------------+-----------------------------------------------+ -| ``repr(t)`` | Returns a string in the form | -| | ``datetime.timedelta(D[, S[, U]])``, where D | -| | is negative for negative ``t``. (5) | +| ``repr(t)`` | Returns a string representation of the | +| | :class:`timedelta` object as a constructor | +| | call with canonical attribute values. | +--------------------------------+-----------------------------------------------+ + Notes: (1) diff --git a/Lib/datetime.py b/Lib/datetime.py index b95536fb7af..76a6f957e08 100644 --- a/Lib/datetime.py +++ b/Lib/datetime.py @@ -454,20 +454,18 @@ def __new__(cls, days=0, seconds=0, microseconds=0, return self def __repr__(self): - if self._microseconds: - return "%s.%s(%d, %d, %d)" % (self.__class__.__module__, - self.__class__.__qualname__, - self._days, - self._seconds, - self._microseconds) + args = [] + if self._days: + args.append("days=%d" % self._days) if self._seconds: - return "%s.%s(%d, %d)" % (self.__class__.__module__, - self.__class__.__qualname__, - self._days, - self._seconds) - return "%s.%s(%d)" % (self.__class__.__module__, + args.append("seconds=%d" % self._seconds) + if self._microseconds: + args.append("microseconds=%d" % self._microseconds) + if not args: + args.append('0') + return "%s.%s(%s)" % (self.__class__.__module__, self.__class__.__qualname__, - self._days) + ', '.join(args)) def __str__(self): mm, ss = divmod(self._seconds, 60) diff --git a/Lib/test/datetimetester.py b/Lib/test/datetimetester.py index b25e6c17136..22008884b54 100644 --- a/Lib/test/datetimetester.py +++ b/Lib/test/datetimetester.py @@ -658,11 +658,21 @@ def test_str(self): def test_repr(self): name = 'datetime.' + self.theclass.__name__ self.assertEqual(repr(self.theclass(1)), - "%s(1)" % name) + "%s(days=1)" % name) self.assertEqual(repr(self.theclass(10, 2)), - "%s(10, 2)" % name) + "%s(days=10, seconds=2)" % name) self.assertEqual(repr(self.theclass(-10, 2, 400000)), - "%s(-10, 2, 400000)" % name) + "%s(days=-10, seconds=2, microseconds=400000)" % name) + self.assertEqual(repr(self.theclass(seconds=60)), + "%s(seconds=60)" % name) + self.assertEqual(repr(self.theclass()), + "%s(0)" % name) + self.assertEqual(repr(self.theclass(microseconds=100)), + "%s(microseconds=100)" % name) + self.assertEqual(repr(self.theclass(days=1, microseconds=100)), + "%s(days=1, microseconds=100)" % name) + self.assertEqual(repr(self.theclass(seconds=1, microseconds=100)), + "%s(seconds=1, microseconds=100)" % name) def test_roundtrip(self): for td in (timedelta(days=999999999, hours=23, minutes=59, diff --git a/Lib/test/test_datetime.py b/Lib/test/test_datetime.py index d659f369d54..bb22871f2b1 100644 --- a/Lib/test/test_datetime.py +++ b/Lib/test/test_datetime.py @@ -50,6 +50,8 @@ def tearDownClass(cls_): cls.tearDownClass = tearDownClass all_test_classes.extend(test_classes) + all_test_classes.extend(test_classes) + def test_main(): run_unittest(*all_test_classes) diff --git a/Misc/NEWS.d/next/Library/2017-06-30-23-05-47.bpo-30302.itwK_k.rst b/Misc/NEWS.d/next/Library/2017-06-30-23-05-47.bpo-30302.itwK_k.rst new file mode 100644 index 00000000000..927250d04c4 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-06-30-23-05-47.bpo-30302.itwK_k.rst @@ -0,0 +1 @@ +Use keywords in the ``repr`` of ``datetime.timedelta``. diff --git a/Modules/_datetimemodule.c b/Modules/_datetimemodule.c index 3439040d2d9..28805d18da8 100644 --- a/Modules/_datetimemodule.c +++ b/Modules/_datetimemodule.c @@ -2284,21 +2284,50 @@ delta_bool(PyDateTime_Delta *self) static PyObject * delta_repr(PyDateTime_Delta *self) { - if (GET_TD_MICROSECONDS(self) != 0) - return PyUnicode_FromFormat("%s(%d, %d, %d)", - Py_TYPE(self)->tp_name, - GET_TD_DAYS(self), - GET_TD_SECONDS(self), - GET_TD_MICROSECONDS(self)); - if (GET_TD_SECONDS(self) != 0) - return PyUnicode_FromFormat("%s(%d, %d)", - Py_TYPE(self)->tp_name, - GET_TD_DAYS(self), - GET_TD_SECONDS(self)); - - return PyUnicode_FromFormat("%s(%d)", - Py_TYPE(self)->tp_name, - GET_TD_DAYS(self)); + PyObject *args = PyUnicode_FromString(""); + + if (args == NULL) { + return NULL; + } + + const char *sep = ""; + + if (GET_TD_DAYS(self) != 0) { + Py_SETREF(args, PyUnicode_FromFormat("days=%d", GET_TD_DAYS(self))); + if (args == NULL) { + return NULL; + } + sep = ", "; + } + + if (GET_TD_SECONDS(self) != 0) { + Py_SETREF(args, PyUnicode_FromFormat("%U%sseconds=%d", args, sep, + GET_TD_SECONDS(self))); + if (args == NULL) { + return NULL; + } + sep = ", "; + } + + if (GET_TD_MICROSECONDS(self) != 0) { + Py_SETREF(args, PyUnicode_FromFormat("%U%smicroseconds=%d", args, sep, + GET_TD_MICROSECONDS(self))); + if (args == NULL) { + return NULL; + } + } + + if (PyUnicode_GET_LENGTH(args) == 0) { + Py_SETREF(args, PyUnicode_FromString("0")); + if (args == NULL) { + return NULL; + } + } + + PyObject *repr = PyUnicode_FromFormat("%s(%S)", Py_TYPE(self)->tp_name, + args); + Py_DECREF(args); + return repr; } static PyObject * From webhook-mailer at python.org Tue Jul 25 19:03:53 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 25 Jul 2017 23:03:53 -0000 Subject: [Python-checkins] Add the link to asyncio source code in the docs (GH-2373) Message-ID: https://github.com/python/cpython/commit/627d2c8e8dc9cfe6c1cdfd9b34899eb30b600a88 commit: 627d2c8e8dc9cfe6c1cdfd9b34899eb30b600a88 branch: master author: lf committer: Mariatta date: 2017-07-25T16:03:51-07:00 summary: Add the link to asyncio source code in the docs (GH-2373) files: M Doc/library/asyncio-eventloop.rst M Doc/library/asyncio-eventloops.rst M Doc/library/asyncio-protocol.rst M Doc/library/asyncio-queue.rst M Doc/library/asyncio-stream.rst M Doc/library/asyncio-subprocess.rst M Doc/library/asyncio-sync.rst M Doc/library/asyncio-task.rst diff --git a/Doc/library/asyncio-eventloop.rst b/Doc/library/asyncio-eventloop.rst index fa6a29604ca..83bbb70b037 100644 --- a/Doc/library/asyncio-eventloop.rst +++ b/Doc/library/asyncio-eventloop.rst @@ -5,6 +5,8 @@ Base Event Loop =============== +**Source code:** :source:`Lib/asyncio/events.py` + The event loop is the central execution device provided by :mod:`asyncio`. It provides multiple facilities, including: diff --git a/Doc/library/asyncio-eventloops.rst b/Doc/library/asyncio-eventloops.rst index 1dc18fce79d..d74fcb1e07f 100644 --- a/Doc/library/asyncio-eventloops.rst +++ b/Doc/library/asyncio-eventloops.rst @@ -3,6 +3,8 @@ Event loops =========== +**Source code:** :source:`Lib/asyncio/events.py` + Event loop functions -------------------- diff --git a/Doc/library/asyncio-protocol.rst b/Doc/library/asyncio-protocol.rst index dfe37c239d6..cd84ae76b5d 100644 --- a/Doc/library/asyncio-protocol.rst +++ b/Doc/library/asyncio-protocol.rst @@ -1,8 +1,12 @@ .. currentmodule:: asyncio -++++++++++++++++++++++++++++++++++++++++++++++ -Transports and protocols (callback based API) -++++++++++++++++++++++++++++++++++++++++++++++ ++++++++++++++++++++++++++++++++++++++++++++++ +Transports and protocols (callback based API) ++++++++++++++++++++++++++++++++++++++++++++++ + +**Source code:** :source:`Lib/asyncio/transports.py` + +**Source code:** :source:`Lib/asyncio/protocols.py` .. _asyncio-transport: diff --git a/Doc/library/asyncio-queue.rst b/Doc/library/asyncio-queue.rst index f11c09ac290..ea787550082 100644 --- a/Doc/library/asyncio-queue.rst +++ b/Doc/library/asyncio-queue.rst @@ -3,6 +3,8 @@ Queues ====== +**Source code:** :source:`Lib/asyncio/queues.py` + Queues: * :class:`Queue` diff --git a/Doc/library/asyncio-stream.rst b/Doc/library/asyncio-stream.rst index 6177b4bb0f8..491afdd610c 100644 --- a/Doc/library/asyncio-stream.rst +++ b/Doc/library/asyncio-stream.rst @@ -6,6 +6,8 @@ Streams (coroutine based API) +++++++++++++++++++++++++++++ +**Source code:** :source:`Lib/asyncio/streams.py` + Stream functions ================ diff --git a/Doc/library/asyncio-subprocess.rst b/Doc/library/asyncio-subprocess.rst index 16ba9a3cd6c..1c1d0be918d 100644 --- a/Doc/library/asyncio-subprocess.rst +++ b/Doc/library/asyncio-subprocess.rst @@ -5,6 +5,8 @@ Subprocess ========== +**Source code:** :source:`Lib/asyncio/subprocess.py` + Windows event loop ------------------ diff --git a/Doc/library/asyncio-sync.rst b/Doc/library/asyncio-sync.rst index 09093521524..14e3defbf41 100644 --- a/Doc/library/asyncio-sync.rst +++ b/Doc/library/asyncio-sync.rst @@ -4,6 +4,8 @@ Synchronization primitives ========================== +**Source code:** :source:`Lib/asyncio/locks.py` + Locks: * :class:`Lock` diff --git a/Doc/library/asyncio-task.rst b/Doc/library/asyncio-task.rst index 804f1925b40..5298c11058c 100644 --- a/Doc/library/asyncio-task.rst +++ b/Doc/library/asyncio-task.rst @@ -3,6 +3,10 @@ Tasks and coroutines ==================== +**Source code:** :source:`Lib/asyncio/tasks.py` + +**Source code:** :source:`Lib/asyncio/coroutines.py` + .. _coroutine: Coroutines From lp_benchmark_robot at intel.com Tue Jul 25 19:25:25 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Tue, 25 Jul 2017 16:25:25 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-25 Message-ID: Results for project python/master, build date: 2017-07-25 03:04:43-07:00. - commit: 3924377 - previous commit: b364d9f - revision date: 2017-07-25 10:47:43+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.058% | -0.158% | +4.790% | +7.029% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 2.812% | -0.577% | +23.702% | +11.242% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 2.397% | +0.458% | +24.817% | +9.694% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 0.935% | +0.236% | +22.753% | +9.010% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.431% | +0.604% | +6.408% | +10.708% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.097% | +0.373% | +11.601% | +10.943% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.927% | -0.200% | +8.079% | +9.927% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.515% | +0.151% | +5.361% | +4.089% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.460% | -0.459% | +6.079% | +18.176% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 3.620% | +1.004% | +9.374% | +11.474% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.359% | -0.826% | +3.759% | +8.255% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.426% | -0.019% | +5.197% | +4.656% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 1.052% | -0.293% | +3.468% | +6.476% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.561% | -0.036% | +9.295% | +10.592% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.006% | -0.128% | +6.807% | +9.602% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.923% | -0.025% | +7.664% | +8.878% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.818% | +0.048% | +10.366% | +10.544% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.376% | -0.363% | +9.104% | +8.554% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.511% | -0.432% | +2.982% | +9.589% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 3.239% | -0.253% | +1.298% | +12.110% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.066% | +0.549% | +8.426% | +9.674% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.020% | -0.028% | +9.641% | +15.539% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.437% | +0.112% | +9.333% | +10.425% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 1.080% | -0.039% | +18.256% | +13.518% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 6.215% | +1.011% | +4.811% | +14.015% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.587% | -0.447% | +3.742% | +5.981% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.821% | -0.213% | -2.980% | +6.223% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.618% | -0.107% | +2.470% | +6.892% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.130% | -0.260% | +2.423% | +13.465% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 5.491% | +0.277% | +2.667% | +21.927% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.307% | -0.006% | +2.318% | +18.546% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.317% | -0.182% | +5.617% | +18.793% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 2.542% | +0.562% | +13.010% | +9.434% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.169% | +0.086% | +0.366% | +9.997% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.120% | +0.026% | +9.710% | +4.084% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.092% | +0.039% | +1.397% | +4.270% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.775% | -0.598% | +10.126% | +12.068% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.757% | +1.646% | -8.320% | +11.108% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 1.357% | -0.120% | +2.012% | +8.829% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.637% | -0.108% | -1.608% | +4.465% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.840% | +0.100% | +12.253% | +2.961% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.929% | +0.117% | +9.789% | +12.795% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.666% | +0.109% | +1.171% | +1.099% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.294% | -0.447% | +26.700% | +9.307% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.168% | +0.674% | +5.920% | +3.801% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.056% | -0.321% | +16.019% | +7.706% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 6.900% | -0.149% | +0.276% | +1.111% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.624% | +0.278% | +6.625% | +0.188% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.120% | +0.094% | +5.429% | +7.449% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.042% | +0.649% | +5.455% | +4.102% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.566% | -0.643% | +1.309% | +9.825% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.023% | -0.236% | +12.980% | +7.381% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.752% | -0.108% | +10.340% | +6.258% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.150% | -0.058% | +12.172% | +8.853% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.603% | +0.009% | +12.708% | +10.268% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.150% | +2.071% | +22.977% | +10.146% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.077% | -0.006% | +7.010% | +4.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.103% | +0.318% | +2.013% | -3.417% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 8.998% | -2.284% | +6.648% | +21.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.378% | +0.182% | -1.134% | +20.342% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 3.197% | -0.644% | +6.261% | +8.240% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.933% | -0.032% | +5.704% | +8.224% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.602% | -0.663% | +1.408% | +6.813% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.341% | -0.277% | -6.109% | +11.100% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.290% | +0.013% | +6.603% | +7.868% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-25 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Tue Jul 25 20:32:46 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 00:32:46 -0000 Subject: [Python-checkins] bpo-31019: Fix multiprocessing.Process.is_alive() (#2875) Message-ID: https://github.com/python/cpython/commit/2db64823c20538a6cfc6033661fab5711d2d4585 commit: 2db64823c20538a6cfc6033661fab5711d2d4585 branch: master author: Victor Stinner committer: GitHub date: 2017-07-26T02:32:42+02:00 summary: bpo-31019: Fix multiprocessing.Process.is_alive() (#2875) multiprocessing.Process.is_alive() now removes the process from the _children set if the process completed. The change prevents leaking "dangling" processes. files: M Lib/multiprocessing/process.py diff --git a/Lib/multiprocessing/process.py b/Lib/multiprocessing/process.py index ce4ce43cfca..8e500dc93dc 100644 --- a/Lib/multiprocessing/process.py +++ b/Lib/multiprocessing/process.py @@ -148,10 +148,16 @@ def is_alive(self): if self is _current_process: return True assert self._parent_pid == os.getpid(), 'can only test a child process' + if self._popen is None: return False - self._popen.poll() - return self._popen.returncode is None + + returncode = self._popen.poll() + if returncode is None: + return True + else: + _children.discard(self) + return False def close(self): ''' From webhook-mailer at python.org Tue Jul 25 20:33:49 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 00:33:49 -0000 Subject: [Python-checkins] bpo-31034: Reliable signal handler for test_asyncio (#2867) (#2876) Message-ID: https://github.com/python/cpython/commit/efe9fcbd2ca85ba9d6af6d95cc530a9c332f37c5 commit: efe9fcbd2ca85ba9d6af6d95cc530a9c332f37c5 branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-26T02:33:47+02:00 summary: bpo-31034: Reliable signal handler for test_asyncio (#2867) (#2876) * bpo-31034: Reliable signal handler for test_asyncio Don't rely on the current SIGHUP signal handler, make sure that it's set to the "default" signal handler: SIG_DFL. * Add comments (cherry picked from commit 830080913c22a9834d310294b9f7653234dc6a59) files: M Lib/test/test_asyncio/test_events.py M Lib/test/test_asyncio/test_subprocess.py diff --git a/Lib/test/test_asyncio/test_events.py b/Lib/test/test_asyncio/test_events.py index 492a84a2313..9746678607c 100644 --- a/Lib/test/test_asyncio/test_events.py +++ b/Lib/test/test_asyncio/test_events.py @@ -1980,19 +1980,26 @@ def test_subprocess_terminate(self): @unittest.skipIf(sys.platform == 'win32', "Don't have SIGHUP") def test_subprocess_send_signal(self): - prog = os.path.join(os.path.dirname(__file__), 'echo.py') - - connect = self.loop.subprocess_exec( - functools.partial(MySubprocessProtocol, self.loop), - sys.executable, prog) - transp, proto = self.loop.run_until_complete(connect) - self.assertIsInstance(proto, MySubprocessProtocol) - self.loop.run_until_complete(proto.connected) - - transp.send_signal(signal.SIGHUP) - self.loop.run_until_complete(proto.completed) - self.assertEqual(-signal.SIGHUP, proto.returncode) - transp.close() + # bpo-31034: Make sure that we get the default signal handler (killing + # the process). The parent process may have decided to ignore SIGHUP, + # and signal handlers are inherited. + old_handler = signal.signal(signal.SIGHUP, signal.SIG_DFL) + try: + prog = os.path.join(os.path.dirname(__file__), 'echo.py') + + connect = self.loop.subprocess_exec( + functools.partial(MySubprocessProtocol, self.loop), + sys.executable, prog) + transp, proto = self.loop.run_until_complete(connect) + self.assertIsInstance(proto, MySubprocessProtocol) + self.loop.run_until_complete(proto.connected) + + transp.send_signal(signal.SIGHUP) + self.loop.run_until_complete(proto.completed) + self.assertEqual(-signal.SIGHUP, proto.returncode) + transp.close() + finally: + signal.signal(signal.SIGHUP, old_handler) def test_subprocess_stderr(self): prog = os.path.join(os.path.dirname(__file__), 'echo2.py') diff --git a/Lib/test/test_asyncio/test_subprocess.py b/Lib/test/test_asyncio/test_subprocess.py index 2e14a8a9735..e8822c36698 100644 --- a/Lib/test/test_asyncio/test_subprocess.py +++ b/Lib/test/test_asyncio/test_subprocess.py @@ -166,25 +166,32 @@ def test_terminate(self): @unittest.skipIf(sys.platform == 'win32', "Don't have SIGHUP") def test_send_signal(self): - code = 'import time; print("sleeping", flush=True); time.sleep(3600)' - args = [sys.executable, '-c', code] - create = asyncio.create_subprocess_exec(*args, - stdout=subprocess.PIPE, - loop=self.loop) - proc = self.loop.run_until_complete(create) - - @asyncio.coroutine - def send_signal(proc): - # basic synchronization to wait until the program is sleeping - line = yield from proc.stdout.readline() - self.assertEqual(line, b'sleeping\n') + # bpo-31034: Make sure that we get the default signal handler (killing + # the process). The parent process may have decided to ignore SIGHUP, + # and signal handlers are inherited. + old_handler = signal.signal(signal.SIGHUP, signal.SIG_DFL) + try: + code = 'import time; print("sleeping", flush=True); time.sleep(3600)' + args = [sys.executable, '-c', code] + create = asyncio.create_subprocess_exec(*args, + stdout=subprocess.PIPE, + loop=self.loop) + proc = self.loop.run_until_complete(create) - proc.send_signal(signal.SIGHUP) - returncode = (yield from proc.wait()) - return returncode - - returncode = self.loop.run_until_complete(send_signal(proc)) - self.assertEqual(-signal.SIGHUP, returncode) + @asyncio.coroutine + def send_signal(proc): + # basic synchronization to wait until the program is sleeping + line = yield from proc.stdout.readline() + self.assertEqual(line, b'sleeping\n') + + proc.send_signal(signal.SIGHUP) + returncode = (yield from proc.wait()) + return returncode + + returncode = self.loop.run_until_complete(send_signal(proc)) + self.assertEqual(-signal.SIGHUP, returncode) + finally: + signal.signal(signal.SIGHUP, old_handler) def prepare_broken_pipe_test(self): # buffer large enough to feed the whole pipe buffer From webhook-mailer at python.org Tue Jul 25 22:48:58 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 02:48:58 -0000 Subject: [Python-checkins] [3.6] bpo-26762, bpo-31019: Backport multiprocessing fixes from master to 3.6 (#2879) Message-ID: https://github.com/python/cpython/commit/d0adfb25c5082046133a18fd185375508c1c334f commit: d0adfb25c5082046133a18fd185375508c1c334f branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-26T04:48:56+02:00 summary: [3.6] bpo-26762, bpo-31019: Backport multiprocessing fixes from master to 3.6 (#2879) * bpo-26762: Avoid daemon process in _test_multiprocessing (#2842) test_level() of _test_multiprocessing._TestLogging now uses regular processes rather than daemon processes to prevent zombi processes (to not "leak" processes). (cherry picked from commit 06634950c553f8df83330ed468c11483b857b7dc) * test_multiprocessing: Fix dangling process/thread (#2850) bpo-26762: Fix more dangling processes and threads in test_multiprocessing: * Queue: call close() followed by join_thread() * Process: call join() or self.addCleanup(p.join) (cherry picked from commit d7e64d9934d86aa6173229de5af5fe908662a33a) * test_multiprocessing detects dangling per test case (#2841) bpo-26762: test_multiprocessing now detects dangling processes and threads per test case classes: * setUpClass()/tearDownClass() of mixin classes now check if multiprocessing.process._dangling or threading._dangling was modified to detect "dangling" processses and threads. * ManagerMixin.tearDownClass() now also emits a warning if it still has more than one active child process after 5 seconds. * tearDownModule() now checks for dangling processes and threads before sleep 500 ms. And it now only sleeps if there is a least one dangling process or thread. (cherry picked from commit ffb49408f0780ae80a553208aa133bc5bb3ba129) * bpo-26762: test_multiprocessing close more queues (#2855) * Close explicitly queues to make sure that we don't leave dangling threads * test_queue_in_process(): remove unused queue * test_access() joins also the process to fix a random warning (cherry picked from commit b4c52966c810b5c5e088fceff403247f610b7d13) * bpo-31019: Fix multiprocessing.Process.is_alive() (#2875) multiprocessing.Process.is_alive() now removes the process from the _children set if the process completed. The change prevents leaking "dangling" processes. (cherry picked from commit 2db64823c20538a6cfc6033661fab5711d2d4585) files: M Lib/multiprocessing/process.py M Lib/test/_test_multiprocessing.py diff --git a/Lib/multiprocessing/process.py b/Lib/multiprocessing/process.py index f9c22703df2..1d26b5e521e 100644 --- a/Lib/multiprocessing/process.py +++ b/Lib/multiprocessing/process.py @@ -132,10 +132,16 @@ def is_alive(self): if self is _current_process: return True assert self._parent_pid == os.getpid(), 'can only test a child process' + if self._popen is None: return False - self._popen.poll() - return self._popen.returncode is None + + returncode = self._popen.poll() + if returncode is None: + return True + else: + _children.discard(self) + return False @property def name(self): diff --git a/Lib/test/_test_multiprocessing.py b/Lib/test/_test_multiprocessing.py index 871a34e4b26..4d3c6558374 100644 --- a/Lib/test/_test_multiprocessing.py +++ b/Lib/test/_test_multiprocessing.py @@ -32,11 +32,12 @@ # without thread support. import threading -import multiprocessing.dummy import multiprocessing.connection -import multiprocessing.managers +import multiprocessing.dummy import multiprocessing.heap +import multiprocessing.managers import multiprocessing.pool +import multiprocessing.queues from multiprocessing import util @@ -64,6 +65,13 @@ def latin(s): return s.encode('latin') + +def close_queue(queue): + if isinstance(queue, multiprocessing.queues.Queue): + queue.close() + queue.join_thread() + + # # Constants # @@ -275,6 +283,7 @@ def test_process(self): self.assertEqual(p.exitcode, 0) self.assertEqual(p.is_alive(), False) self.assertNotIn(p, self.active_children()) + close_queue(q) @classmethod def _test_terminate(cls): @@ -414,6 +423,7 @@ def test_lose_target_ref(self): p.join() self.assertIs(wr(), None) self.assertEqual(q.get(), 5) + close_queue(q) # @@ -600,6 +610,7 @@ def test_put(self): self.assertEqual(queue_full(queue, MAXSIZE), False) proc.join() + close_queue(queue) @classmethod def _test_get(cls, queue, child_can_start, parent_can_continue): @@ -662,6 +673,7 @@ def test_get(self): self.assertTimingAlmostEqual(get.elapsed, TIMEOUT3) proc.join() + close_queue(queue) @classmethod def _test_fork(cls, queue): @@ -697,6 +709,7 @@ def test_fork(self): self.assertRaises(pyqueue.Empty, queue.get, False) p.join() + close_queue(queue) def test_qsize(self): q = self.Queue() @@ -712,6 +725,7 @@ def test_qsize(self): self.assertEqual(q.qsize(), 1) q.get() self.assertEqual(q.qsize(), 0) + close_queue(q) @classmethod def _test_task_done(cls, q): @@ -739,6 +753,7 @@ def test_task_done(self): for p in workers: p.join() + close_queue(queue) def test_no_import_lock_contention(self): with test.support.temp_cwd(): @@ -769,6 +784,7 @@ def test_timeout(self): # Tolerate a delta of 30 ms because of the bad clock resolution on # Windows (usually 15.6 ms) self.assertGreaterEqual(delta, 0.170) + close_queue(q) def test_queue_feeder_donot_stop_onexc(self): # bpo-30414: verify feeder handles exceptions correctly @@ -782,7 +798,9 @@ def __reduce__(self): q = self.Queue() q.put(NotSerializable()) q.put(True) - self.assertTrue(q.get(timeout=0.1)) + # bpo-30595: use a timeout of 1 second for slow buildbots + self.assertTrue(q.get(timeout=1.0)) + close_queue(q) # # @@ -895,10 +913,12 @@ def test_notify(self): p = self.Process(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) p = threading.Thread(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) # wait for both children to start sleeping sleeping.acquire() @@ -941,11 +961,13 @@ def test_notify_all(self): args=(cond, sleeping, woken, TIMEOUT1)) p.daemon = True p.start() + self.addCleanup(p.join) t = threading.Thread(target=self.f, args=(cond, sleeping, woken, TIMEOUT1)) t.daemon = True t.start() + self.addCleanup(t.join) # wait for them all to sleep for i in range(6): @@ -964,10 +986,12 @@ def test_notify_all(self): p = self.Process(target=self.f, args=(cond, sleeping, woken)) p.daemon = True p.start() + self.addCleanup(p.join) t = threading.Thread(target=self.f, args=(cond, sleeping, woken)) t.daemon = True t.start() + self.addCleanup(t.join) # wait for them to all sleep for i in range(6): @@ -1143,6 +1167,7 @@ def test_event(self): p.daemon = True p.start() self.assertEqual(wait(), True) + p.join() # # Tests for Barrier - adapted from tests in test/lock_tests.py @@ -1318,6 +1343,7 @@ def test_wait_return(self): self.run_threads(self._test_wait_return_f, (self.barrier, queue)) results = [queue.get() for i in range(self.N)] self.assertEqual(results.count(0), 1) + close_queue(queue) @classmethod def _test_action_f(cls, barrier, results): @@ -1488,6 +1514,7 @@ def test_thousand(self): p = self.Process(target=self._test_thousand_f, args=(self.barrier, passes, child_conn, lock)) p.start() + self.addCleanup(p.join) for i in range(passes): for j in range(self.N): @@ -2971,6 +2998,8 @@ def test_access(self): w.close() self.assertEqual(conn.recv(), 'foobar'*2) + p.join() + # # # @@ -3296,16 +3325,16 @@ def test_level(self): logger.setLevel(LEVEL1) p = self.Process(target=self._test_level, args=(writer,)) - p.daemon = True p.start() self.assertEqual(LEVEL1, reader.recv()) + p.join() logger.setLevel(logging.NOTSET) root_logger.setLevel(LEVEL2) p = self.Process(target=self._test_level, args=(writer,)) - p.daemon = True p.start() self.assertEqual(LEVEL2, reader.recv()) + p.join() root_logger.setLevel(root_level) logger.setLevel(level=LOG_LEVEL) @@ -3459,7 +3488,7 @@ def _this_sub_process(q): except pyqueue.Empty: pass -def _test_process(q): +def _test_process(): queue = multiprocessing.Queue() subProc = multiprocessing.Process(target=_this_sub_process, args=(queue,)) subProc.daemon = True @@ -3499,8 +3528,7 @@ def flush(self): class TestStdinBadfiledescriptor(unittest.TestCase): def test_queue_in_process(self): - queue = multiprocessing.Queue() - proc = multiprocessing.Process(target=_test_process, args=(queue,)) + proc = multiprocessing.Process(target=_test_process) proc.start() proc.join() @@ -4108,7 +4136,32 @@ def test_empty(self): # Mixins # -class ProcessesMixin(object): +class BaseMixin(object): + @classmethod + def setUpClass(cls): + cls.dangling = (multiprocessing.process._dangling.copy(), + threading._dangling.copy()) + + @classmethod + def tearDownClass(cls): + # bpo-26762: Some multiprocessing objects like Pool create reference + # cycles. Trigger a garbage collection to break these cycles. + test.support.gc_collect() + + processes = set(multiprocessing.process._dangling) - set(cls.dangling[0]) + if processes: + print('Warning -- Dangling processes: %s' % processes, + file=sys.stderr) + processes = None + + threads = set(threading._dangling) - set(cls.dangling[1]) + if threads: + print('Warning -- Dangling threads: %s' % threads, + file=sys.stderr) + threads = None + + +class ProcessesMixin(BaseMixin): TYPE = 'processes' Process = multiprocessing.Process connection = multiprocessing.connection @@ -4131,7 +4184,7 @@ class ProcessesMixin(object): RawArray = staticmethod(multiprocessing.RawArray) -class ManagerMixin(object): +class ManagerMixin(BaseMixin): TYPE = 'manager' Process = multiprocessing.Process Queue = property(operator.attrgetter('manager.Queue')) @@ -4155,6 +4208,7 @@ def Pool(cls, *args, **kwds): @classmethod def setUpClass(cls): + super().setUpClass() cls.manager = multiprocessing.Manager() @classmethod @@ -4162,23 +4216,35 @@ def tearDownClass(cls): # only the manager process should be returned by active_children() # but this can take a bit on slow machines, so wait a few seconds # if there are other children too (see #17395) + start_time = time.monotonic() t = 0.01 - while len(multiprocessing.active_children()) > 1 and t < 5: + while len(multiprocessing.active_children()) > 1: time.sleep(t) t *= 2 + dt = time.monotonic() - start_time + if dt >= 5.0: + print("Warning -- multiprocessing.Manager still has %s active " + "children after %s seconds" + % (multiprocessing.active_children(), dt), + file=sys.stderr) + break + gc.collect() # do garbage collection if cls.manager._number_of_objects() != 0: # This is not really an error since some tests do not # ensure that all processes which hold a reference to a # managed object have been joined. - print('Shared objects which still exist at manager shutdown:') + print('Warning -- Shared objects which still exist at manager ' + 'shutdown:') print(cls.manager._debug_info()) cls.manager.shutdown() cls.manager.join() cls.manager = None + super().tearDownClass() + -class ThreadsMixin(object): +class ThreadsMixin(BaseMixin): TYPE = 'threads' Process = multiprocessing.dummy.Process connection = multiprocessing.dummy.connection @@ -4255,18 +4321,33 @@ def setUpModule(): multiprocessing.get_logger().setLevel(LOG_LEVEL) def tearDownModule(): + need_sleep = False + + # bpo-26762: Some multiprocessing objects like Pool create reference + # cycles. Trigger a garbage collection to break these cycles. + test.support.gc_collect() + multiprocessing.set_start_method(old_start_method[0], force=True) # pause a bit so we don't get warning about dangling threads/processes - time.sleep(0.5) + processes = set(multiprocessing.process._dangling) - set(dangling[0]) + if processes: + need_sleep = True + print('Warning -- Dangling processes: %s' % processes, + file=sys.stderr) + processes = None + + threads = set(threading._dangling) - set(dangling[1]) + if threads: + need_sleep = True + print('Warning -- Dangling threads: %s' % threads, + file=sys.stderr) + threads = None + + # Sleep 500 ms to give time to child processes to complete. + if need_sleep: + time.sleep(0.5) multiprocessing.process._cleanup() - gc.collect() - tmp = set(multiprocessing.process._dangling) - set(dangling[0]) - if tmp: - print('Dangling processes:', tmp, file=sys.stderr) - del tmp - tmp = set(threading._dangling) - set(dangling[1]) - if tmp: - print('Dangling threads:', tmp, file=sys.stderr) + test.support.gc_collect() remote_globs['setUpModule'] = setUpModule remote_globs['tearDownModule'] = tearDownModule From webhook-mailer at python.org Tue Jul 25 23:05:12 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 03:05:12 -0000 Subject: [Python-checkins] bpo-30845: Enhance test_concurrent_futures cleanup (#2564) (#2880) Message-ID: https://github.com/python/cpython/commit/a6f045224a03f9b5f940c80ee142a2a4b4a9c9d8 commit: a6f045224a03f9b5f940c80ee142a2a4b4a9c9d8 branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-26T05:05:09+02:00 summary: bpo-30845: Enhance test_concurrent_futures cleanup (#2564) (#2880) * bpo-30845: reap_children() now logs warnings * bpo-30845: Enhance test_concurrent_futures cleanup In setUp() and tearDown() methods of test_concurrent_futures tests, make sure that tests don't leak threads nor processes. Clear explicitly the reference to the executor to make it that it's destroyed (to prevent "dangling threads" warning). (cherry picked from commit 3df9dec425b0254df1cdf41922fd8d6b08bf47e4) files: M Lib/test/support/__init__.py M Lib/test/test_concurrent_futures.py diff --git a/Lib/test/support/__init__.py b/Lib/test/support/__init__.py index 677743bb389..a5b8c46f949 100644 --- a/Lib/test/support/__init__.py +++ b/Lib/test/support/__init__.py @@ -2053,7 +2053,6 @@ def reap_children(): stick around to hog resources and create problems when looking for refleaks. """ - # Reap all our dead child processes so we don't leave zombies around. # These hog resources and might be causing some of the buildbots to die. if hasattr(os, 'waitpid'): @@ -2064,6 +2063,8 @@ def reap_children(): pid, status = os.waitpid(any_process, os.WNOHANG) if pid == 0: break + print("Warning -- reap_children() reaped child process %s" + % pid, file=sys.stderr) except: break diff --git a/Lib/test/test_concurrent_futures.py b/Lib/test/test_concurrent_futures.py index 23e95b21244..92a3ebdd886 100644 --- a/Lib/test/test_concurrent_futures.py +++ b/Lib/test/test_concurrent_futures.py @@ -63,6 +63,8 @@ class ExecutorMixin: worker_count = 5 def setUp(self): + self._thread_cleanup = test.support.threading_setup() + self.t1 = time.time() try: self.executor = self.executor_type(max_workers=self.worker_count) @@ -72,11 +74,16 @@ def setUp(self): def tearDown(self): self.executor.shutdown(wait=True) + self.executor = None + dt = time.time() - self.t1 if test.support.verbose: print("%.2fs" % dt, end=' ') self.assertLess(dt, 60, "synchronization issue: test lasted too long") + test.support.threading_cleanup(*self._thread_cleanup) + test.support.reap_children() + def _prime_executor(self): # Make sure that the executor is ready to do work before running the # tests. This should reduce the probability of timeouts in the tests. From webhook-mailer at python.org Tue Jul 25 23:38:25 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 03:38:25 -0000 Subject: [Python-checkins] [3.6] bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) (#2881) Message-ID: https://github.com/python/cpython/commit/e42339d3a08a8fde3349722def85d7a8e49899be commit: e42339d3a08a8fde3349722def85d7a8e49899be branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-26T05:38:22+02:00 summary: [3.6] bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) (#2881) * bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) multiprocessing.Queue.get() with a timeout now polls its reader in non-blocking mode if it succeeded to aquire the lock but the acquire took longer than the timeout. Co-Authored-By: Grzegorz Grzywacz (cherry picked from commit 1b7863c3b6519c6e134c28cab8b8af0dea43e375) * bpo-30595: Increase test_queue_feeder_donot_stop_onexc() timeout (#2148) _test_multiprocessing.test_queue_feeder_donot_stop_onexc() now uses a timeout of 1 second on Queue.get(), instead of 0.1 second, for slow buildbots. (cherry picked from commit 8f6eeaf21cdf4aea25fdefeec814a1ce07453fe9) files: A Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst M Lib/multiprocessing/queues.py diff --git a/Lib/multiprocessing/queues.py b/Lib/multiprocessing/queues.py index 76684172528..513807cafec 100644 --- a/Lib/multiprocessing/queues.py +++ b/Lib/multiprocessing/queues.py @@ -101,7 +101,7 @@ def get(self, block=True, timeout=None): try: if block: timeout = deadline - time.time() - if timeout < 0 or not self._poll(timeout): + if not self._poll(timeout): raise Empty elif not self._poll(): raise Empty diff --git a/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst b/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst new file mode 100644 index 00000000000..4a2a3901cc6 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst @@ -0,0 +1,3 @@ +multiprocessing.Queue.get() with a timeout now polls its reader in non- +blocking mode if it succeeded to aquire the lock but the acquire took longer +than the timeout. From webhook-mailer at python.org Wed Jul 26 00:05:20 2017 From: webhook-mailer at python.org (Mariatta) Date: Wed, 26 Jul 2017 04:05:20 -0000 Subject: [Python-checkins] Add the link to asyncio source code in the docs (GH-2373) (GH-2884) Message-ID: https://github.com/python/cpython/commit/0dbfab2ac7398d5d8f7e93a024a3bc866f5dd472 commit: 0dbfab2ac7398d5d8f7e93a024a3bc866f5dd472 branch: 3.6 author: Mariatta committer: GitHub date: 2017-07-25T21:05:17-07:00 summary: Add the link to asyncio source code in the docs (GH-2373) (GH-2884) (cherry picked from commit 627d2c8e8dc9cfe6c1cdfd9b34899eb30b600a88) files: M Doc/library/asyncio-eventloop.rst M Doc/library/asyncio-eventloops.rst M Doc/library/asyncio-protocol.rst M Doc/library/asyncio-queue.rst M Doc/library/asyncio-stream.rst M Doc/library/asyncio-subprocess.rst M Doc/library/asyncio-sync.rst M Doc/library/asyncio-task.rst diff --git a/Doc/library/asyncio-eventloop.rst b/Doc/library/asyncio-eventloop.rst index fa6a29604ca..83bbb70b037 100644 --- a/Doc/library/asyncio-eventloop.rst +++ b/Doc/library/asyncio-eventloop.rst @@ -5,6 +5,8 @@ Base Event Loop =============== +**Source code:** :source:`Lib/asyncio/events.py` + The event loop is the central execution device provided by :mod:`asyncio`. It provides multiple facilities, including: diff --git a/Doc/library/asyncio-eventloops.rst b/Doc/library/asyncio-eventloops.rst index 1dc18fce79d..d74fcb1e07f 100644 --- a/Doc/library/asyncio-eventloops.rst +++ b/Doc/library/asyncio-eventloops.rst @@ -3,6 +3,8 @@ Event loops =========== +**Source code:** :source:`Lib/asyncio/events.py` + Event loop functions -------------------- diff --git a/Doc/library/asyncio-protocol.rst b/Doc/library/asyncio-protocol.rst index dfe37c239d6..cd84ae76b5d 100644 --- a/Doc/library/asyncio-protocol.rst +++ b/Doc/library/asyncio-protocol.rst @@ -1,8 +1,12 @@ .. currentmodule:: asyncio -++++++++++++++++++++++++++++++++++++++++++++++ -Transports and protocols (callback based API) -++++++++++++++++++++++++++++++++++++++++++++++ ++++++++++++++++++++++++++++++++++++++++++++++ +Transports and protocols (callback based API) ++++++++++++++++++++++++++++++++++++++++++++++ + +**Source code:** :source:`Lib/asyncio/transports.py` + +**Source code:** :source:`Lib/asyncio/protocols.py` .. _asyncio-transport: diff --git a/Doc/library/asyncio-queue.rst b/Doc/library/asyncio-queue.rst index f11c09ac290..ea787550082 100644 --- a/Doc/library/asyncio-queue.rst +++ b/Doc/library/asyncio-queue.rst @@ -3,6 +3,8 @@ Queues ====== +**Source code:** :source:`Lib/asyncio/queues.py` + Queues: * :class:`Queue` diff --git a/Doc/library/asyncio-stream.rst b/Doc/library/asyncio-stream.rst index 6177b4bb0f8..491afdd610c 100644 --- a/Doc/library/asyncio-stream.rst +++ b/Doc/library/asyncio-stream.rst @@ -6,6 +6,8 @@ Streams (coroutine based API) +++++++++++++++++++++++++++++ +**Source code:** :source:`Lib/asyncio/streams.py` + Stream functions ================ diff --git a/Doc/library/asyncio-subprocess.rst b/Doc/library/asyncio-subprocess.rst index 16ba9a3cd6c..1c1d0be918d 100644 --- a/Doc/library/asyncio-subprocess.rst +++ b/Doc/library/asyncio-subprocess.rst @@ -5,6 +5,8 @@ Subprocess ========== +**Source code:** :source:`Lib/asyncio/subprocess.py` + Windows event loop ------------------ diff --git a/Doc/library/asyncio-sync.rst b/Doc/library/asyncio-sync.rst index 09093521524..14e3defbf41 100644 --- a/Doc/library/asyncio-sync.rst +++ b/Doc/library/asyncio-sync.rst @@ -4,6 +4,8 @@ Synchronization primitives ========================== +**Source code:** :source:`Lib/asyncio/locks.py` + Locks: * :class:`Lock` diff --git a/Doc/library/asyncio-task.rst b/Doc/library/asyncio-task.rst index 804f1925b40..5298c11058c 100644 --- a/Doc/library/asyncio-task.rst +++ b/Doc/library/asyncio-task.rst @@ -3,6 +3,10 @@ Tasks and coroutines ==================== +**Source code:** :source:`Lib/asyncio/tasks.py` + +**Source code:** :source:`Lib/asyncio/coroutines.py` + .. _coroutine: Coroutines From webhook-mailer at python.org Wed Jul 26 03:04:44 2017 From: webhook-mailer at python.org (Ned Deily) Date: Wed, 26 Jul 2017 07:04:44 -0000 Subject: [Python-checkins] [3.5] [security] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2887) Message-ID: https://github.com/python/cpython/commit/19b2890014d3098147d16475c492a47a43893768 commit: 19b2890014d3098147d16475c492a47a43893768 branch: 3.5 author: Dong-hee Na committer: Ned Deily date: 2017-07-26T03:04:42-04:00 summary: [3.5] [security] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2887) files: A Misc/NEWS.d/next/Library/2017-07-26-15-11-17.bpo-30119.DZ6C_S.rst M Lib/ftplib.py M Lib/test/test_ftplib.py diff --git a/Lib/ftplib.py b/Lib/ftplib.py index c416d8562b0..2416fc68cd3 100644 --- a/Lib/ftplib.py +++ b/Lib/ftplib.py @@ -187,6 +187,8 @@ def sanitize(self, s): # Internal: send one line to the server, appending CRLF def putline(self, line): + if '\r' in line or '\n' in line: + raise ValueError('an illegal newline character should not be contained') line = line + CRLF if self.debugging > 1: print('*put*', self.sanitize(line)) diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index aef66da98af..583d3b1e1a6 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -482,6 +482,9 @@ def test_sanitize(self): self.assertEqual(self.client.sanitize('PASS 12345'), repr('PASS *****')) def test_exceptions(self): + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r0') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 400') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 499') self.assertRaises(ftplib.error_perm, self.client.sendcmd, 'echo 500') @@ -490,7 +493,8 @@ def test_exceptions(self): def test_all_errors(self): exceptions = (ftplib.error_reply, ftplib.error_temp, ftplib.error_perm, - ftplib.error_proto, ftplib.Error, OSError, EOFError) + ftplib.error_proto, ftplib.Error, OSError, + EOFError) for x in exceptions: try: raise x('exception not included in all_errors set') diff --git a/Misc/NEWS.d/next/Library/2017-07-26-15-11-17.bpo-30119.DZ6C_S.rst b/Misc/NEWS.d/next/Library/2017-07-26-15-11-17.bpo-30119.DZ6C_S.rst new file mode 100644 index 00000000000..a37d3703842 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-15-11-17.bpo-30119.DZ6C_S.rst @@ -0,0 +1,2 @@ +ftplib.FTP.putline() now throws ValueError on commands that contains CR or +LF. Patch by Dong-hee Na. From solipsis at pitrou.net Wed Jul 26 05:10:04 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Wed, 26 Jul 2017 09:10:04 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=13 Message-ID: <20170726091004.58483.D22C4E26E14EFC31@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [7, 0, 0] memory blocks, sum=7 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [0, 0, 2] memory blocks, sum=2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogAL2Mz6', '--timeout', '7200'] From webhook-mailer at python.org Wed Jul 26 06:46:22 2017 From: webhook-mailer at python.org (INADA Naoki) Date: Wed, 26 Jul 2017 10:46:22 -0000 Subject: [Python-checkins] bpo-31043: fixed test_datetime run twice. (GH-2891) Message-ID: https://github.com/python/cpython/commit/ede9084476f88f5a86c7eaaac33cdd938e4cce93 commit: ede9084476f88f5a86c7eaaac33cdd938e4cce93 branch: master author: Utkarsh Upadhyay committer: INADA Naoki date: 2017-07-26T19:46:17+09:00 summary: bpo-31043: fixed test_datetime run twice. (GH-2891) files: M Lib/test/test_datetime.py diff --git a/Lib/test/test_datetime.py b/Lib/test/test_datetime.py index bb22871f2b1..d659f369d54 100644 --- a/Lib/test/test_datetime.py +++ b/Lib/test/test_datetime.py @@ -50,8 +50,6 @@ def tearDownClass(cls_): cls.tearDownClass = tearDownClass all_test_classes.extend(test_classes) - all_test_classes.extend(test_classes) - def test_main(): run_unittest(*all_test_classes) From webhook-mailer at python.org Wed Jul 26 07:49:19 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 11:49:19 -0000 Subject: [Python-checkins] [3.6] bpo-30822: Fix testing of datetime module. (GH-2530) (GH-2783) (#2816) Message-ID: https://github.com/python/cpython/commit/c52cea49544621b612c7f17f45a0c2b8b61a6c67 commit: c52cea49544621b612c7f17f45a0c2b8b61a6c67 branch: 3.6 author: Utkarsh Upadhyay committer: Victor Stinner date: 2017-07-26T13:49:16+02:00 summary: [3.6] bpo-30822: Fix testing of datetime module. (GH-2530) (GH-2783) (#2816) * [3.6] bpo-30822: Fix testing of datetime module. (GH-2530) (GH-2783) Only C implementation was tested. (cherry picked from commit 287c5594edc1ca08db64d1f4739cc36bfe75ae75) * [3.6] bpo-30822: Fix testing of datetime module. (GH-2530) (GH-2783) Only C implementation was tested.. (cherry picked from commit 287c5594edc1ca08db64d1f4739cc36bfe75ae75) files: M Lib/datetime.py M Lib/test/datetimetester.py M Lib/test/test_datetime.py M Misc/ACKS diff --git a/Lib/datetime.py b/Lib/datetime.py index 5d5579c1c6f..b95536fb7af 100644 --- a/Lib/datetime.py +++ b/Lib/datetime.py @@ -2271,7 +2271,8 @@ def _name_from_offset(delta): _check_tzinfo_arg, _check_tzname, _check_utc_offset, _cmp, _cmperror, _date_class, _days_before_month, _days_before_year, _days_in_month, _format_time, _is_leap, _isoweek1monday, _math, _ord2ymd, - _time, _time_class, _tzinfo_class, _wrap_strftime, _ymd2ord) + _time, _time_class, _tzinfo_class, _wrap_strftime, _ymd2ord, + _divide_and_round) # XXX Since import * above excludes names that start with _, # docstring does not get overwritten. In the future, it may be # appropriate to maintain a single module level docstring and diff --git a/Lib/test/datetimetester.py b/Lib/test/datetimetester.py index bccd97aa3c7..b25e6c17136 100644 --- a/Lib/test/datetimetester.py +++ b/Lib/test/datetimetester.py @@ -61,8 +61,9 @@ def test_constants(self): self.assertEqual(datetime.MAXYEAR, 9999) def test_name_cleanup(self): - if '_Fast' not in str(self): - return + if '_Pure' in self.__class__.__name__: + self.skipTest('Only run for Fast C implementation') + datetime = datetime_module names = set(name for name in dir(datetime) if not name.startswith('__') and not name.endswith('__')) @@ -72,8 +73,9 @@ def test_name_cleanup(self): self.assertEqual(names - allowed, set([])) def test_divide_and_round(self): - if '_Fast' in str(self): - return + if '_Fast' in self.__class__.__name__: + self.skipTest('Only run for Pure Python implementation') + dar = datetime_module._divide_and_round self.assertEqual(dar(-10, -3), 3) @@ -2851,7 +2853,7 @@ def tzname(self, dt): return self.tz self.assertRaises(TypeError, t.strftime, "%Z") # Issue #6697: - if '_Fast' in str(self): + if '_Fast' in self.__class__.__name__: Badtzname.tz = '\ud800' self.assertRaises(ValueError, t.strftime, "%Z") diff --git a/Lib/test/test_datetime.py b/Lib/test/test_datetime.py index 242e1bba035..2d00b56c1cc 100644 --- a/Lib/test/test_datetime.py +++ b/Lib/test/test_datetime.py @@ -20,7 +20,7 @@ # XXX(gb) First run all the _Pure tests, then all the _Fast tests. You might # not believe this, but in spite of all the sys.modules trickery running a _Pure # test last will leave a mix of pure and native datetime stuff lying around. -test_classes = [] +all_test_classes = [] for module, suffix in zip(test_modules, test_suffixes): test_classes = [] @@ -33,7 +33,8 @@ suit = cls() test_classes.extend(type(test) for test in suit) for cls in test_classes: - cls.__name__ = name + suffix + cls.__name__ += suffix + cls.__qualname__ += suffix @classmethod def setUpClass(cls_, module=module): cls_._save_sys_modules = sys.modules.copy() @@ -46,9 +47,10 @@ def tearDownClass(cls_): sys.modules.update(cls_._save_sys_modules) cls.setUpClass = setUpClass cls.tearDownClass = tearDownClass + all_test_classes.extend(test_classes) def test_main(): - run_unittest(*test_classes) + run_unittest(*all_test_classes) if __name__ == "__main__": test_main() diff --git a/Misc/ACKS b/Misc/ACKS index f4ccdb88cdc..b6b355b614b 100644 --- a/Misc/ACKS +++ b/Misc/ACKS @@ -1583,6 +1583,7 @@ Doobee R. Tzeck Eren T?rkay Lionel Ulmer Adnan Umer +Utkarsh Upadhyay Roger Upole Daniel Urban Michael Urman From webhook-mailer at python.org Wed Jul 26 08:11:28 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 12:11:28 -0000 Subject: [Python-checkins] [3.6] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2886) Message-ID: https://github.com/python/cpython/commit/8c2d4cf092c5f0335e7982392a33927579c4d512 commit: 8c2d4cf092c5f0335e7982392a33927579c4d512 branch: 3.6 author: Dong-hee Na committer: Victor Stinner date: 2017-07-26T14:11:25+02:00 summary: [3.6] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2886) files: A Misc/NEWS.d/next/Library/2017-07-26-15-15-00.bpo-30119.DZ6C_S.rst M Lib/ftplib.py M Lib/test/test_ftplib.py diff --git a/Lib/ftplib.py b/Lib/ftplib.py index 8f36f537e8a..a02e595cb02 100644 --- a/Lib/ftplib.py +++ b/Lib/ftplib.py @@ -186,6 +186,8 @@ def sanitize(self, s): # Internal: send one line to the server, appending CRLF def putline(self, line): + if '\r' in line or '\n' in line: + raise ValueError('an illegal newline character should not be contained') line = line + CRLF if self.debugging > 1: print('*put*', self.sanitize(line)) diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index 12fabc5e8be..a561e9efa03 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -484,6 +484,9 @@ def test_sanitize(self): self.assertEqual(self.client.sanitize('PASS 12345'), repr('PASS *****')) def test_exceptions(self): + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r0') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 400') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 499') self.assertRaises(ftplib.error_perm, self.client.sendcmd, 'echo 500') @@ -492,7 +495,8 @@ def test_exceptions(self): def test_all_errors(self): exceptions = (ftplib.error_reply, ftplib.error_temp, ftplib.error_perm, - ftplib.error_proto, ftplib.Error, OSError, EOFError) + ftplib.error_proto, ftplib.Error, OSError, + EOFError) for x in exceptions: try: raise x('exception not included in all_errors set') diff --git a/Misc/NEWS.d/next/Library/2017-07-26-15-15-00.bpo-30119.DZ6C_S.rst b/Misc/NEWS.d/next/Library/2017-07-26-15-15-00.bpo-30119.DZ6C_S.rst new file mode 100644 index 00000000000..a37d3703842 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-15-15-00.bpo-30119.DZ6C_S.rst @@ -0,0 +1,2 @@ +ftplib.FTP.putline() now throws ValueError on commands that contains CR or +LF. Patch by Dong-hee Na. From webhook-mailer at python.org Wed Jul 26 10:43:29 2017 From: webhook-mailer at python.org (INADA Naoki) Date: Wed, 26 Jul 2017 14:43:29 -0000 Subject: [Python-checkins] bpo-30188: fix TypeError in test_nntplib (GH-2892) Message-ID: https://github.com/python/cpython/commit/067931dd95ddfa34297be9c602a796d9f8d9bea3 commit: 067931dd95ddfa34297be9c602a796d9f8d9bea3 branch: master author: INADA Naoki committer: GitHub date: 2017-07-26T23:43:22+09:00 summary: bpo-30188: fix TypeError in test_nntplib (GH-2892) fixes regression of 5b4feb7 files: M Lib/test/test_nntplib.py diff --git a/Lib/test/test_nntplib.py b/Lib/test/test_nntplib.py index 482de66e3f4..e2cd36a4d04 100644 --- a/Lib/test/test_nntplib.py +++ b/Lib/test/test_nntplib.py @@ -274,9 +274,9 @@ def is_connected(): NetworkedNNTPTestsMixin.wrap_methods() -EOF_ERRORS = [EOFError] +EOF_ERRORS = (EOFError,) if ssl is not None: - EOF_ERRORS.append(ssl.SSLEOFError) + EOF_ERRORS += (ssl.SSLEOFError,) class NetworkedNNTPTests(NetworkedNNTPTestsMixin, unittest.TestCase): From webhook-mailer at python.org Wed Jul 26 11:50:41 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 15:50:41 -0000 Subject: [Python-checkins] [2.7] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2894) Message-ID: https://github.com/python/cpython/commit/e5eae474c431af2880a68f6329840b9288fc4bc1 commit: e5eae474c431af2880a68f6329840b9288fc4bc1 branch: 2.7 author: Dong-hee Na committer: Victor Stinner date: 2017-07-26T17:50:36+02:00 summary: [2.7] bpo-30119: fix ftplib.FTP.putline() to throw an error for a illegal command (#1214) (#2894) files: A Misc/NEWS.d/next/Library/2017-07-26-22-02-07.bpo-30119.DZ6C_S.rst M Lib/ftplib.py M Lib/test/test_ftplib.py diff --git a/Lib/ftplib.py b/Lib/ftplib.py index 153647ba758..66445547927 100644 --- a/Lib/ftplib.py +++ b/Lib/ftplib.py @@ -171,6 +171,8 @@ def sanitize(self, s): # Internal: send one line to the server, appending CRLF def putline(self, line): + if '\r' in line or '\n' in line: + raise ValueError('an illegal newline character should not be contained') line = line + CRLF if self.debugging > 1: print '*put*', self.sanitize(line) self.sock.sendall(line) diff --git a/Lib/test/test_ftplib.py b/Lib/test/test_ftplib.py index 044ce4594c9..fdfa31387cb 100644 --- a/Lib/test/test_ftplib.py +++ b/Lib/test/test_ftplib.py @@ -439,6 +439,9 @@ def test_sanitize(self): self.assertEqual(self.client.sanitize('PASS 12345'), repr('PASS *****')) def test_exceptions(self): + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\n0') + self.assertRaises(ValueError, self.client.sendcmd, 'echo 40\r0') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 400') self.assertRaises(ftplib.error_temp, self.client.sendcmd, 'echo 499') self.assertRaises(ftplib.error_perm, self.client.sendcmd, 'echo 500') diff --git a/Misc/NEWS.d/next/Library/2017-07-26-22-02-07.bpo-30119.DZ6C_S.rst b/Misc/NEWS.d/next/Library/2017-07-26-22-02-07.bpo-30119.DZ6C_S.rst new file mode 100644 index 00000000000..a37d3703842 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-22-02-07.bpo-30119.DZ6C_S.rst @@ -0,0 +1,2 @@ +ftplib.FTP.putline() now throws ValueError on commands that contains CR or +LF. Patch by Dong-hee Na. From webhook-mailer at python.org Wed Jul 26 11:52:39 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 15:52:39 -0000 Subject: [Python-checkins] [3.6] bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) (#2881) (#2883) Message-ID: https://github.com/python/cpython/commit/ec9a7127b8196dc5ef27c5ee2772ecea7cbb32df commit: ec9a7127b8196dc5ef27c5ee2772ecea7cbb32df branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-26T17:52:36+02:00 summary: [3.6] bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) (#2881) (#2883) * bpo-30595: Fix multiprocessing.Queue.get(timeout) (#2027) multiprocessing.Queue.get() with a timeout now polls its reader in non-blocking mode if it succeeded to aquire the lock but the acquire took longer than the timeout. Co-Authored-By: Grzegorz Grzywacz (cherry picked from commit 1b7863c3b6519c6e134c28cab8b8af0dea43e375) * bpo-30595: Increase test_queue_feeder_donot_stop_onexc() timeout (#2148) _test_multiprocessing.test_queue_feeder_donot_stop_onexc() now uses a timeout of 1 second on Queue.get(), instead of 0.1 second, for slow buildbots. (cherry picked from commit 8f6eeaf21cdf4aea25fdefeec814a1ce07453fe9) (cherry picked from commit e42339d3a08a8fde3349722def85d7a8e49899be) files: A Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst M Lib/multiprocessing/queues.py diff --git a/Lib/multiprocessing/queues.py b/Lib/multiprocessing/queues.py index bb1e7282db8..079cd354d6e 100644 --- a/Lib/multiprocessing/queues.py +++ b/Lib/multiprocessing/queues.py @@ -128,7 +128,7 @@ def get(self, block=True, timeout=None): try: if block: timeout = deadline - time.time() - if timeout < 0 or not self._poll(timeout): + if not self._poll(timeout): raise Empty elif not self._poll(): raise Empty diff --git a/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst b/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst new file mode 100644 index 00000000000..4a2a3901cc6 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-04-46-12.bpo-30595.-zJ7d8.rst @@ -0,0 +1,3 @@ +multiprocessing.Queue.get() with a timeout now polls its reader in non- +blocking mode if it succeeded to aquire the lock but the acquire took longer +than the timeout. From webhook-mailer at python.org Wed Jul 26 11:54:48 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 15:54:48 -0000 Subject: [Python-checkins] bpo-31019: Fix multiprocessing.Process.is_alive() (#2875) (#2882) Message-ID: https://github.com/python/cpython/commit/b65cb8a35641675d44af84c9b18c40c6094f03ef commit: b65cb8a35641675d44af84c9b18c40c6094f03ef branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-26T17:54:42+02:00 summary: bpo-31019: Fix multiprocessing.Process.is_alive() (#2875) (#2882) multiprocessing.Process.is_alive() now removes the process from the _children set if the process completed. The change prevents leaking "dangling" processes. (cherry picked from commit 2db64823c20538a6cfc6033661fab5711d2d4585) files: M Lib/multiprocessing/process.py diff --git a/Lib/multiprocessing/process.py b/Lib/multiprocessing/process.py index 16c4e1eb343..11c8fca360f 100644 --- a/Lib/multiprocessing/process.py +++ b/Lib/multiprocessing/process.py @@ -156,10 +156,16 @@ def is_alive(self): if self is _current_process: return True assert self._parent_pid == os.getpid(), 'can only test a child process' + if self._popen is None: return False - self._popen.poll() - return self._popen.returncode is None + + returncode = self._popen.poll() + if returncode is None: + return True + else: + _current_process._children.discard(self) + return False @property def name(self): From webhook-mailer at python.org Wed Jul 26 11:55:54 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 15:55:54 -0000 Subject: [Python-checkins] bpo-30778: Skip test_bsddb3 on Windows XP (#2877) Message-ID: https://github.com/python/cpython/commit/0cba38d207dc233707b09787e6618cfca44cc2b7 commit: 0cba38d207dc233707b09787e6618cfca44cc2b7 branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-26T17:55:52+02:00 summary: bpo-30778: Skip test_bsddb3 on Windows XP (#2877) * bpo-30778: Skip test_bsddb3 on Windows XP * Fix if, don't skip Windows Vista files: M Lib/test/test_bsddb3.py diff --git a/Lib/test/test_bsddb3.py b/Lib/test/test_bsddb3.py index 099145b460a..1a82325d493 100644 --- a/Lib/test/test_bsddb3.py +++ b/Lib/test/test_bsddb3.py @@ -28,6 +28,10 @@ verbose = False sys.argv.remove('silent') +# bpo-30778: test_bsddb3 crashs randomly on Windows XP +if hasattr(sys, 'getwindowsversion') and sys.getwindowsversion()[:2] < (6, 0): + raise unittest.SkipTest("bpo-30778: skip tests on Windows XP") + class TimingCheck(unittest.TestCase): From webhook-mailer at python.org Wed Jul 26 11:58:28 2017 From: webhook-mailer at python.org (Steve Dower) Date: Wed, 26 Jul 2017 15:58:28 -0000 Subject: [Python-checkins] bpo-9566: Fix a warning in Python/getargs.c (#2890) Message-ID: https://github.com/python/cpython/commit/e7bc7aac3d4a7d92aa5913006b0198820882ca59 commit: e7bc7aac3d4a7d92aa5913006b0198820882ca59 branch: master author: Segev Finer committer: Steve Dower date: 2017-07-26T08:58:25-07:00 summary: bpo-9566: Fix a warning in Python/getargs.c (#2890) files: M Python/getargs.c diff --git a/Python/getargs.c b/Python/getargs.c index c61d9451896..471f72924f6 100644 --- a/Python/getargs.c +++ b/Python/getargs.c @@ -2055,7 +2055,7 @@ vgetargskeywordsfast_impl(PyObject **args, Py_ssize_t nargs, kwtuple = parser->kwtuple; pos = parser->pos; - len = pos + PyTuple_GET_SIZE(kwtuple); + len = pos + (int)PyTuple_GET_SIZE(kwtuple); if (len > STATIC_FREELIST_ENTRIES) { freelist.entries = PyMem_NEW(freelistentry_t, len); From webhook-mailer at python.org Wed Jul 26 12:09:04 2017 From: webhook-mailer at python.org (Steve Dower) Date: Wed, 26 Jul 2017 16:09:04 -0000 Subject: [Python-checkins] Fix build batch files (#2750) Message-ID: https://github.com/python/cpython/commit/f0851910eb8e711bf8f22165cb0df33bb27b09d6 commit: f0851910eb8e711bf8f22165cb0df33bb27b09d6 branch: master author: Steve Dower committer: GitHub date: 2017-07-26T09:09:01-07:00 summary: Fix build batch files (#2750) * Enable building MSI, zip and nuget packages when Py_OutDir is set. * Restore the --build option, which got reverted at some point. * Ensure output directory is created. * Enables BuildForDaily and DailyBuildVersion options for nuget package. files: A Tools/nuget/pythondaily.nuspec M Tools/msi/buildrelease.bat M Tools/msi/make_zip.proj M Tools/msi/make_zip.py M Tools/nuget/build.bat M Tools/nuget/make_pkg.proj diff --git a/Tools/msi/buildrelease.bat b/Tools/msi/buildrelease.bat index 7f9a81b33d4..5dc1b57b668 100644 --- a/Tools/msi/buildrelease.bat +++ b/Tools/msi/buildrelease.bat @@ -29,6 +29,7 @@ set DOWNLOAD_URL=https://www.python.org/ftp/python/{version}/{arch}{releasename} set D=%~dp0 set PCBUILD=%D%..\..\PCBuild\ +if "%Py_OutDir%"=="" set Py_OutDir=%PCBUILD% set EXTERNALS=%D%..\..\externals\windows-installer\ set BUILDX86= @@ -110,12 +111,12 @@ exit /B 0 if "%1" EQU "x86" ( set PGO= - set BUILD=%PCBUILD%win32\ + set BUILD=%Py_OutDir%win32\ set BUILD_PLAT=Win32 set OUTDIR_PLAT=win32 set OBJDIR_PLAT=x86 ) else ( - set BUILD=%PCBUILD%amd64\ + set BUILD=%Py_OutDir%amd64\ set PGO=%~2 set BUILD_PLAT=x64 set OUTDIR_PLAT=amd64 @@ -167,7 +168,7 @@ if not "%SKIPBUILD%" EQU "1" ( if "%OUTDIR_PLAT%" EQU "win32" ( %MSBUILD% "%D%launcher\launcher.wixproj" /p:Platform=x86 %CERTOPTS% /p:ReleaseUri=%RELEASE_URI% if errorlevel 1 exit /B -) else if not exist "%PCBUILD%win32\en-us\launcher.msi" ( +) else if not exist "%Py_OutDir%win32\en-us\launcher.msi" ( %MSBUILD% "%D%launcher\launcher.wixproj" /p:Platform=x86 %CERTOPTS% /p:ReleaseUri=%RELEASE_URI% if errorlevel 1 exit /B ) diff --git a/Tools/msi/make_zip.proj b/Tools/msi/make_zip.proj index b3588b7a0ba..21411173421 100644 --- a/Tools/msi/make_zip.proj +++ b/Tools/msi/make_zip.proj @@ -16,8 +16,9 @@ $(OutputPath)\$(TargetName)$(TargetExt) rmdir /q/s "$(IntermediateOutputPath)\zip_$(ArchName)" "$(PythonExe)" "$(MSBuildThisFileDirectory)\make_zip.py" - $(Arguments) -e -o "$(TargetPath)" -t "$(IntermediateOutputPath)\zip_$(ArchName)" -a $(ArchName) + $(Arguments) -e -o "$(TargetPath)" -t "$(IntermediateOutputPath)\zip_$(ArchName)" -b "$(BuildPath.TrimEnd(`\`))" set DOC_FILENAME=python$(PythonVersion).chm + $(Environment)%0D%0Aset PYTHONPATH=$(PySourcePath)Lib $(Environment)%0D%0Aset VCREDIST_PATH=$(CRTRedist)\$(Platform) diff --git a/Tools/msi/make_zip.py b/Tools/msi/make_zip.py index 0034f6b9b4d..8e35bdc5679 100644 --- a/Tools/msi/make_zip.py +++ b/Tools/msi/make_zip.py @@ -106,23 +106,23 @@ def include_in_tools(p): BASE_NAME = 'python{0.major}{0.minor}'.format(sys.version_info) FULL_LAYOUT = [ - ('/', 'PCBuild/$arch', 'python.exe', is_not_debug), - ('/', 'PCBuild/$arch', 'pythonw.exe', is_not_debug), - ('/', 'PCBuild/$arch', 'python{}.dll'.format(sys.version_info.major), is_not_debug), - ('/', 'PCBuild/$arch', '{}.dll'.format(BASE_NAME), is_not_debug), - ('DLLs/', 'PCBuild/$arch', '*.pyd', is_not_debug), - ('DLLs/', 'PCBuild/$arch', '*.dll', is_not_debug_or_python), + ('/', '$build', 'python.exe', is_not_debug), + ('/', '$build', 'pythonw.exe', is_not_debug), + ('/', '$build', 'python{}.dll'.format(sys.version_info.major), is_not_debug), + ('/', '$build', '{}.dll'.format(BASE_NAME), is_not_debug), + ('DLLs/', '$build', '*.pyd', is_not_debug), + ('DLLs/', '$build', '*.dll', is_not_debug_or_python), ('include/', 'include', '*.h', None), ('include/', 'PC', 'pyconfig.h', None), ('Lib/', 'Lib', '**/*', include_in_lib), - ('libs/', 'PCBuild/$arch', '*.lib', include_in_libs), + ('libs/', '$build', '*.lib', include_in_libs), ('Tools/', 'Tools', '**/*', include_in_tools), ] EMBED_LAYOUT = [ - ('/', 'PCBuild/$arch', 'python*.exe', is_not_debug), - ('/', 'PCBuild/$arch', '*.pyd', is_not_debug), - ('/', 'PCBuild/$arch', '*.dll', is_not_debug), + ('/', '$build', 'python*.exe', is_not_debug), + ('/', '$build', '*.pyd', is_not_debug), + ('/', '$build', '*.dll', is_not_debug), ('{}.zip'.format(BASE_NAME), 'Lib', '**/*', include_in_embeddable_lib), ] @@ -187,15 +187,15 @@ def main(): parser.add_argument('-o', '--out', metavar='file', help='The name of the output archive', type=Path, default=None) parser.add_argument('-t', '--temp', metavar='dir', help='A directory to temporarily extract files into', type=Path, default=None) parser.add_argument('-e', '--embed', help='Create an embedding layout', action='store_true', default=False) - parser.add_argument('-a', '--arch', help='Specify the architecture to use (win32/amd64)', type=str, default="win32") + parser.add_argument('-b', '--build', help='Specify the build directory', type=Path, default=None) ns = parser.parse_args() source = ns.source or (Path(__file__).resolve().parent.parent.parent) out = ns.out - arch = ns.arch + build = ns.build or Path(sys.exec_prefix) assert isinstance(source, Path) assert not out or isinstance(out, Path) - assert isinstance(arch, str) + assert isinstance(build, Path) if ns.temp: temp = ns.temp @@ -218,7 +218,10 @@ def main(): try: for t, s, p, c in layout: - fs = source / s.replace("$arch", arch) + if s == '$build': + fs = build + else: + fs = source / s files = rglob(fs, p, c) extra_files = [] if s == 'Lib' and p == '**/*': diff --git a/Tools/nuget/build.bat b/Tools/nuget/build.bat index 54498ca28a2..0b4f622e078 100644 --- a/Tools/nuget/build.bat +++ b/Tools/nuget/build.bat @@ -2,6 +2,7 @@ setlocal set D=%~dp0 set PCBUILD=%D%..\..\PCBuild\ +if "%Py_OutDir%"=="" set Py_OutDir=%PCBUILD% set BUILDX86= set BUILDX64= @@ -28,7 +29,7 @@ if defined PACKAGES set PACKAGES="/p:Packages=%PACKAGES%" if defined BUILDX86 ( if defined REBUILD ( call "%PCBUILD%build.bat" -e -r - ) else if not exist "%PCBUILD%win32\python.exe" call "%PCBUILD%build.bat" -e + ) else if not exist "%Py_OutDir%win32\python.exe" call "%PCBUILD%build.bat" -e if errorlevel 1 goto :eof %MSBUILD% "%D%make_pkg.proj" /p:Configuration=Release /p:Platform=x86 %OUTPUT% %PACKAGES% @@ -37,7 +38,7 @@ if defined BUILDX86 ( if defined BUILDX64 ( if defined REBUILD ( call "%PCBUILD%build.bat" -p x64 -e -r - ) else if not exist "%PCBUILD%amd64\python.exe" call "%PCBUILD%build.bat" -p x64 -e + ) else if not exist "%Py_OutDir%amd64\python.exe" call "%PCBUILD%build.bat" -p x64 -e if errorlevel 1 goto :eof %MSBUILD% "%D%make_pkg.proj" /p:Configuration=Release /p:Platform=x64 %OUTPUT% %PACKAGES% diff --git a/Tools/nuget/make_pkg.proj b/Tools/nuget/make_pkg.proj index 464ef0456af..3750d8dcc86 100644 --- a/Tools/nuget/make_pkg.proj +++ b/Tools/nuget/make_pkg.proj @@ -4,6 +4,7 @@ {10487945-15D1-4092-A214-338395C4116B} python $(OutputName)x86 + $(OutputName)daily false true @@ -15,6 +16,7 @@ $(ExternalsDir)\windows-installer\nuget\nuget.exe $(MajorVersionNumber).$(MinorVersionNumber).$(MicroVersionNumber) $(NuspecVersion)-$(ReleaseLevelName) + $(MajorVersionNumber).$(MinorVersionNumber).$(DailyBuildVersion) false $(OutputName).$(NuspecVersion) .nupkg @@ -23,7 +25,7 @@ rmdir /q/s "$(IntermediateOutputPath)" "$(PythonExe)" "$(MSBuildThisFileDirectory)\..\msi\make_zip.py" - $(PythonArguments) -t "$(IntermediateOutputPath)" -a $(ArchName) + $(PythonArguments) -t "$(IntermediateOutputPath)" -b "$(BuildPath.TrimEnd(`\`))" "$(IntermediateOutputPath)\python.exe" -B -c "import sys; sys.path.append(r'$(PySourcePath)\Lib'); import ensurepip; ensurepip._main()" "$(IntermediateOutputPath)\python.exe" -B -m pip install -U $(Packages) @@ -35,7 +37,9 @@ $(NugetArguments) -NoPackageAnalysis -NonInteractive set DOC_FILENAME=python$(PythonVersion).chm + $(Environment)%0D%0Aset PYTHONPATH=$(PySourcePath)Lib $(Environment)%0D%0Aset VCREDIST_PATH=$(CRTRedist)\$(Platform) + $(Environment)%0D%0Amkdir "$(OutputPath.Trim(`\`))" >nul 2>nul diff --git a/Tools/nuget/pythondaily.nuspec b/Tools/nuget/pythondaily.nuspec new file mode 100644 index 00000000000..2634ed14a88 --- /dev/null +++ b/Tools/nuget/pythondaily.nuspec @@ -0,0 +1,18 @@ + + + + pythondaily + Python (Daily build) + 0.0.0.0 + Python Software Foundation + https://docs.python.org/3/license.html + https://www.python.org/ + false + Installs an unsigned, untested build of Python for test purposes only. + https://www.python.org/static/favicon.ico + python + + + + + From webhook-mailer at python.org Wed Jul 26 17:20:44 2017 From: webhook-mailer at python.org (Steve Dower) Date: Wed, 26 Jul 2017 21:20:44 -0000 Subject: [Python-checkins] Fix build batch files (#2750) (#2897) Message-ID: https://github.com/python/cpython/commit/bb7fd3f4d08091b2b68333267a4d5fdef03bda44 commit: bb7fd3f4d08091b2b68333267a4d5fdef03bda44 branch: 3.6 author: Steve Dower committer: GitHub date: 2017-07-26T14:20:41-07:00 summary: Fix build batch files (#2750) (#2897) * Enable building MSI, zip and nuget packages when Py_OutDir is set. * Restore the --build option, which got reverted at some point. * Ensure output directory is created. * Enables BuildForDaily and DailyBuildVersion options for nuget package. files: A Tools/nuget/pythondaily.nuspec M Tools/msi/buildrelease.bat M Tools/msi/make_zip.proj M Tools/msi/make_zip.py M Tools/nuget/build.bat M Tools/nuget/make_pkg.proj diff --git a/Tools/msi/buildrelease.bat b/Tools/msi/buildrelease.bat index 1f5278207b4..d19950b659c 100644 --- a/Tools/msi/buildrelease.bat +++ b/Tools/msi/buildrelease.bat @@ -29,6 +29,7 @@ set DOWNLOAD_URL=https://www.python.org/ftp/python/{version}/{arch}{releasename} set D=%~dp0 set PCBUILD=%D%..\..\PCBuild\ +if "%Py_OutDir%"=="" set Py_OutDir=%PCBUILD% set EXTERNALS=%D%..\..\externals\windows-installer\ set BUILDX86= @@ -110,12 +111,12 @@ exit /B 0 if "%1" EQU "x86" ( set PGO= - set BUILD=%PCBUILD%win32\ + set BUILD=%Py_OutDir%win32\ set BUILD_PLAT=Win32 set OUTDIR_PLAT=win32 set OBJDIR_PLAT=x86 ) else ( - set BUILD=%PCBUILD%amd64\ + set BUILD=%Py_OutDir%amd64\ set PGO=%~2 set BUILD_PLAT=x64 set OUTDIR_PLAT=amd64 @@ -167,7 +168,7 @@ if not "%SKIPBUILD%" EQU "1" ( if "%OUTDIR_PLAT%" EQU "win32" ( %MSBUILD% "%D%launcher\launcher.wixproj" /p:Platform=x86 %CERTOPTS% /p:ReleaseUri=%RELEASE_URI% if errorlevel 1 exit /B -) else if not exist "%PCBUILD%win32\en-us\launcher.msi" ( +) else if not exist "%Py_OutDir%win32\en-us\launcher.msi" ( %MSBUILD% "%D%launcher\launcher.wixproj" /p:Platform=x86 %CERTOPTS% /p:ReleaseUri=%RELEASE_URI% if errorlevel 1 exit /B ) diff --git a/Tools/msi/make_zip.proj b/Tools/msi/make_zip.proj index b3588b7a0ba..21411173421 100644 --- a/Tools/msi/make_zip.proj +++ b/Tools/msi/make_zip.proj @@ -16,8 +16,9 @@ $(OutputPath)\$(TargetName)$(TargetExt) rmdir /q/s "$(IntermediateOutputPath)\zip_$(ArchName)" "$(PythonExe)" "$(MSBuildThisFileDirectory)\make_zip.py" - $(Arguments) -e -o "$(TargetPath)" -t "$(IntermediateOutputPath)\zip_$(ArchName)" -a $(ArchName) + $(Arguments) -e -o "$(TargetPath)" -t "$(IntermediateOutputPath)\zip_$(ArchName)" -b "$(BuildPath.TrimEnd(`\`))" set DOC_FILENAME=python$(PythonVersion).chm + $(Environment)%0D%0Aset PYTHONPATH=$(PySourcePath)Lib $(Environment)%0D%0Aset VCREDIST_PATH=$(CRTRedist)\$(Platform) diff --git a/Tools/msi/make_zip.py b/Tools/msi/make_zip.py index 710e4a5c23e..0698c140737 100644 --- a/Tools/msi/make_zip.py +++ b/Tools/msi/make_zip.py @@ -106,23 +106,23 @@ def include_in_tools(p): BASE_NAME = 'python{0.major}{0.minor}'.format(sys.version_info) FULL_LAYOUT = [ - ('/', 'PCBuild/$arch', 'python.exe', is_not_debug), - ('/', 'PCBuild/$arch', 'pythonw.exe', is_not_debug), - ('/', 'PCBuild/$arch', 'python{}.dll'.format(sys.version_info.major), is_not_debug), - ('/', 'PCBuild/$arch', '{}.dll'.format(BASE_NAME), is_not_debug), - ('DLLs/', 'PCBuild/$arch', '*.pyd', is_not_debug), - ('DLLs/', 'PCBuild/$arch', '*.dll', is_not_debug_or_python), + ('/', '$build', 'python.exe', is_not_debug), + ('/', '$build', 'pythonw.exe', is_not_debug), + ('/', '$build', 'python{}.dll'.format(sys.version_info.major), is_not_debug), + ('/', '$build', '{}.dll'.format(BASE_NAME), is_not_debug), + ('DLLs/', '$build', '*.pyd', is_not_debug), + ('DLLs/', '$build', '*.dll', is_not_debug_or_python), ('include/', 'include', '*.h', None), ('include/', 'PC', 'pyconfig.h', None), ('Lib/', 'Lib', '**/*', include_in_lib), - ('libs/', 'PCBuild/$arch', '*.lib', include_in_libs), + ('libs/', '$build', '*.lib', include_in_libs), ('Tools/', 'Tools', '**/*', include_in_tools), ] EMBED_LAYOUT = [ - ('/', 'PCBuild/$arch', 'python*.exe', is_not_debug), - ('/', 'PCBuild/$arch', '*.pyd', is_not_debug), - ('/', 'PCBuild/$arch', '*.dll', is_not_debug), + ('/', '$build', 'python*.exe', is_not_debug), + ('/', '$build', '*.pyd', is_not_debug), + ('/', '$build', '*.dll', is_not_debug), ('{}.zip'.format(BASE_NAME), 'Lib', '**/*', include_in_embeddable_lib), ] @@ -187,15 +187,15 @@ def main(): parser.add_argument('-o', '--out', metavar='file', help='The name of the output archive', type=Path, default=None) parser.add_argument('-t', '--temp', metavar='dir', help='A directory to temporarily extract files into', type=Path, default=None) parser.add_argument('-e', '--embed', help='Create an embedding layout', action='store_true', default=False) - parser.add_argument('-a', '--arch', help='Specify the architecture to use (win32/amd64)', type=str, default="win32") + parser.add_argument('-b', '--build', help='Specify the build directory', type=Path, default=None) ns = parser.parse_args() source = ns.source or (Path(__file__).resolve().parent.parent.parent) out = ns.out - arch = ns.arch + build = ns.build or Path(sys.exec_prefix) assert isinstance(source, Path) assert not out or isinstance(out, Path) - assert isinstance(arch, str) + assert isinstance(build, Path) if ns.temp: temp = ns.temp @@ -218,7 +218,10 @@ def main(): try: for t, s, p, c in layout: - fs = source / s.replace("$arch", arch) + if s == '$build': + fs = build + else: + fs = source / s files = rglob(fs, p, c) extra_files = [] if s == 'Lib' and p == '**/*': diff --git a/Tools/nuget/build.bat b/Tools/nuget/build.bat index 54498ca28a2..0b4f622e078 100644 --- a/Tools/nuget/build.bat +++ b/Tools/nuget/build.bat @@ -2,6 +2,7 @@ setlocal set D=%~dp0 set PCBUILD=%D%..\..\PCBuild\ +if "%Py_OutDir%"=="" set Py_OutDir=%PCBUILD% set BUILDX86= set BUILDX64= @@ -28,7 +29,7 @@ if defined PACKAGES set PACKAGES="/p:Packages=%PACKAGES%" if defined BUILDX86 ( if defined REBUILD ( call "%PCBUILD%build.bat" -e -r - ) else if not exist "%PCBUILD%win32\python.exe" call "%PCBUILD%build.bat" -e + ) else if not exist "%Py_OutDir%win32\python.exe" call "%PCBUILD%build.bat" -e if errorlevel 1 goto :eof %MSBUILD% "%D%make_pkg.proj" /p:Configuration=Release /p:Platform=x86 %OUTPUT% %PACKAGES% @@ -37,7 +38,7 @@ if defined BUILDX86 ( if defined BUILDX64 ( if defined REBUILD ( call "%PCBUILD%build.bat" -p x64 -e -r - ) else if not exist "%PCBUILD%amd64\python.exe" call "%PCBUILD%build.bat" -p x64 -e + ) else if not exist "%Py_OutDir%amd64\python.exe" call "%PCBUILD%build.bat" -p x64 -e if errorlevel 1 goto :eof %MSBUILD% "%D%make_pkg.proj" /p:Configuration=Release /p:Platform=x64 %OUTPUT% %PACKAGES% diff --git a/Tools/nuget/make_pkg.proj b/Tools/nuget/make_pkg.proj index 464ef0456af..3750d8dcc86 100644 --- a/Tools/nuget/make_pkg.proj +++ b/Tools/nuget/make_pkg.proj @@ -4,6 +4,7 @@ {10487945-15D1-4092-A214-338395C4116B} python $(OutputName)x86 + $(OutputName)daily false true @@ -15,6 +16,7 @@ $(ExternalsDir)\windows-installer\nuget\nuget.exe $(MajorVersionNumber).$(MinorVersionNumber).$(MicroVersionNumber) $(NuspecVersion)-$(ReleaseLevelName) + $(MajorVersionNumber).$(MinorVersionNumber).$(DailyBuildVersion) false $(OutputName).$(NuspecVersion) .nupkg @@ -23,7 +25,7 @@ rmdir /q/s "$(IntermediateOutputPath)" "$(PythonExe)" "$(MSBuildThisFileDirectory)\..\msi\make_zip.py" - $(PythonArguments) -t "$(IntermediateOutputPath)" -a $(ArchName) + $(PythonArguments) -t "$(IntermediateOutputPath)" -b "$(BuildPath.TrimEnd(`\`))" "$(IntermediateOutputPath)\python.exe" -B -c "import sys; sys.path.append(r'$(PySourcePath)\Lib'); import ensurepip; ensurepip._main()" "$(IntermediateOutputPath)\python.exe" -B -m pip install -U $(Packages) @@ -35,7 +37,9 @@ $(NugetArguments) -NoPackageAnalysis -NonInteractive set DOC_FILENAME=python$(PythonVersion).chm + $(Environment)%0D%0Aset PYTHONPATH=$(PySourcePath)Lib $(Environment)%0D%0Aset VCREDIST_PATH=$(CRTRedist)\$(Platform) + $(Environment)%0D%0Amkdir "$(OutputPath.Trim(`\`))" >nul 2>nul diff --git a/Tools/nuget/pythondaily.nuspec b/Tools/nuget/pythondaily.nuspec new file mode 100644 index 00000000000..2634ed14a88 --- /dev/null +++ b/Tools/nuget/pythondaily.nuspec @@ -0,0 +1,18 @@ + + + + pythondaily + Python (Daily build) + 0.0.0.0 + Python Software Foundation + https://docs.python.org/3/license.html + https://www.python.org/ + false + Installs an unsigned, untested build of Python for test purposes only. + https://www.python.org/static/favicon.ico + python + + + + + From webhook-mailer at python.org Wed Jul 26 18:18:02 2017 From: webhook-mailer at python.org (Steve Dower) Date: Wed, 26 Jul 2017 22:18:02 -0000 Subject: [Python-checkins] bpo-9566: Fix some Windows x64 compiler warnings (#2492) Message-ID: https://github.com/python/cpython/commit/679b566622ec811c5e5d580f6a538f7a43006e05 commit: 679b566622ec811c5e5d580f6a538f7a43006e05 branch: master author: Segev Finer committer: Steve Dower date: 2017-07-26T15:17:57-07:00 summary: bpo-9566: Fix some Windows x64 compiler warnings (#2492) * bpo-9566: Silence liblzma warnings * bpo-9566: Silence tcl warnings * bpo-9566: Silence tk warnings * bpo-9566: Silence tix warnings * bpo-9566: Fix some library warnings * bpo-9566: Fix msvcrtmodule.c warnings * bpo-9566: Silence _bz2 warnings * bpo-9566: Fixed some _ssl warnings * bpo-9566: Fix _msi warnings * bpo-9566: Silence _ctypes warnings * Revert "bpo-9566: Fixed some _ssl warnings" This reverts commit a639001c949ba53338a9ee047d2ec1efd2505e6f. * bpo-9566: Also consider NULL as a possible error in HANDLE_return_converter * bpo-9566: whitespace fixes files: M Modules/binascii.c M Modules/zlibmodule.c M PC/_msi.c M PC/clinic/msvcrtmodule.c.h M PC/msvcrtmodule.c M PC/winreg.c M PCbuild/_bz2.vcxproj M PCbuild/_ctypes.vcxproj M PCbuild/liblzma.vcxproj M PCbuild/tcl.vcxproj M PCbuild/tix.vcxproj M PCbuild/tk.vcxproj diff --git a/Modules/binascii.c b/Modules/binascii.c index 1f9ff5a57b4..1af6b7f98f2 100644 --- a/Modules/binascii.c +++ b/Modules/binascii.c @@ -372,7 +372,7 @@ binascii_b2a_uu_impl(PyObject *module, Py_buffer *data, int backtick) if (backtick && !bin_len) *ascii_data++ = '`'; else - *ascii_data++ = ' ' + bin_len; + *ascii_data++ = ' ' + (unsigned char)bin_len; for( ; bin_len > 0 || leftbits != 0 ; bin_len--, bin_data++ ) { /* Shift the data (or padding) into our buffer */ diff --git a/Modules/zlibmodule.c b/Modules/zlibmodule.c index cfe7f88dc54..32dd8174347 100644 --- a/Modules/zlibmodule.c +++ b/Modules/zlibmodule.c @@ -142,7 +142,7 @@ PyZlib_Free(voidpf ctx, void *ptr) static void arrange_input_buffer(z_stream *zst, Py_ssize_t *remains) { - zst->avail_in = Py_MIN((size_t)*remains, UINT_MAX); + zst->avail_in = (uInt)Py_MIN((size_t)*remains, UINT_MAX); *remains -= zst->avail_in; } @@ -177,7 +177,7 @@ arrange_output_buffer_with_maximum(z_stream *zst, PyObject **buffer, } } - zst->avail_out = Py_MIN((size_t)(length - occupied), UINT_MAX); + zst->avail_out = (uInt)Py_MIN((size_t)(length - occupied), UINT_MAX); zst->next_out = (Byte *)PyBytes_AS_STRING(*buffer) + occupied; return length; diff --git a/PC/_msi.c b/PC/_msi.c index 9c3f9f6e18a..c028a88e05c 100644 --- a/PC/_msi.c +++ b/PC/_msi.c @@ -948,8 +948,8 @@ static PyTypeObject msidb_Type = { }; #define Py_NOT_PERSIST(x, flag) \ - (x != (int)(flag) && \ - x != ((int)(flag) | MSIDBOPEN_PATCHFILE)) + (x != (SIZE_T)(flag) && \ + x != ((SIZE_T)(flag) | MSIDBOPEN_PATCHFILE)) #define Py_INVALID_PERSIST(x) \ (Py_NOT_PERSIST(x, MSIDBOPEN_READONLY) && \ @@ -972,7 +972,7 @@ static PyObject* msiopendb(PyObject *obj, PyObject *args) behavior. */ if (Py_INVALID_PERSIST(persist)) return msierror(ERROR_INVALID_PARAMETER); - status = MsiOpenDatabase(path, (LPCSTR)persist, &h); + status = MsiOpenDatabase(path, (LPCSTR)(SIZE_T)persist, &h); if (status != ERROR_SUCCESS) return msierror(status); @@ -1038,12 +1038,12 @@ PyInit__msi(void) if (m == NULL) return NULL; - PyModule_AddIntConstant(m, "MSIDBOPEN_CREATEDIRECT", (long)MSIDBOPEN_CREATEDIRECT); - PyModule_AddIntConstant(m, "MSIDBOPEN_CREATE", (long)MSIDBOPEN_CREATE); - PyModule_AddIntConstant(m, "MSIDBOPEN_DIRECT", (long)MSIDBOPEN_DIRECT); - PyModule_AddIntConstant(m, "MSIDBOPEN_READONLY", (long)MSIDBOPEN_READONLY); - PyModule_AddIntConstant(m, "MSIDBOPEN_TRANSACT", (long)MSIDBOPEN_TRANSACT); - PyModule_AddIntConstant(m, "MSIDBOPEN_PATCHFILE", (long)MSIDBOPEN_PATCHFILE); + PyModule_AddIntConstant(m, "MSIDBOPEN_CREATEDIRECT", (long)(SIZE_T)MSIDBOPEN_CREATEDIRECT); + PyModule_AddIntConstant(m, "MSIDBOPEN_CREATE", (long)(SIZE_T)MSIDBOPEN_CREATE); + PyModule_AddIntConstant(m, "MSIDBOPEN_DIRECT", (long)(SIZE_T)MSIDBOPEN_DIRECT); + PyModule_AddIntConstant(m, "MSIDBOPEN_READONLY", (long)(SIZE_T)MSIDBOPEN_READONLY); + PyModule_AddIntConstant(m, "MSIDBOPEN_TRANSACT", (long)(SIZE_T)MSIDBOPEN_TRANSACT); + PyModule_AddIntConstant(m, "MSIDBOPEN_PATCHFILE", (long)(SIZE_T)MSIDBOPEN_PATCHFILE); PyModule_AddIntMacro(m, MSICOLINFO_NAMES); PyModule_AddIntMacro(m, MSICOLINFO_TYPES); diff --git a/PC/clinic/msvcrtmodule.c.h b/PC/clinic/msvcrtmodule.c.h index c6545aca958..debd9b08bdd 100644 --- a/PC/clinic/msvcrtmodule.c.h +++ b/PC/clinic/msvcrtmodule.c.h @@ -113,13 +113,13 @@ PyDoc_STRVAR(msvcrt_open_osfhandle__doc__, {"open_osfhandle", (PyCFunction)msvcrt_open_osfhandle, METH_FASTCALL, msvcrt_open_osfhandle__doc__}, static long -msvcrt_open_osfhandle_impl(PyObject *module, intptr_t handle, int flags); +msvcrt_open_osfhandle_impl(PyObject *module, void *handle, int flags); static PyObject * msvcrt_open_osfhandle(PyObject *module, PyObject **args, Py_ssize_t nargs) { PyObject *return_value = NULL; - intptr_t handle; + void *handle; int flags; long _return_value; @@ -148,7 +148,7 @@ PyDoc_STRVAR(msvcrt_get_osfhandle__doc__, #define MSVCRT_GET_OSFHANDLE_METHODDEF \ {"get_osfhandle", (PyCFunction)msvcrt_get_osfhandle, METH_O, msvcrt_get_osfhandle__doc__}, -static intptr_t +static void * msvcrt_get_osfhandle_impl(PyObject *module, int fd); static PyObject * @@ -156,16 +156,16 @@ msvcrt_get_osfhandle(PyObject *module, PyObject *arg) { PyObject *return_value = NULL; int fd; - intptr_t _return_value; + void *_return_value; if (!PyArg_Parse(arg, "i:get_osfhandle", &fd)) { goto exit; } _return_value = msvcrt_get_osfhandle_impl(module, fd); - if ((_return_value == -1) && PyErr_Occurred()) { + if ((_return_value == NULL || _return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) { goto exit; } - return_value = PyLong_FromVoidPtr((void *)_return_value); + return_value = PyLong_FromVoidPtr(_return_value); exit: return return_value; @@ -426,26 +426,26 @@ PyDoc_STRVAR(msvcrt_CrtSetReportFile__doc__, #define MSVCRT_CRTSETREPORTFILE_METHODDEF \ {"CrtSetReportFile", (PyCFunction)msvcrt_CrtSetReportFile, METH_FASTCALL, msvcrt_CrtSetReportFile__doc__}, -static long -msvcrt_CrtSetReportFile_impl(PyObject *module, int type, int file); +static void * +msvcrt_CrtSetReportFile_impl(PyObject *module, int type, void *file); static PyObject * msvcrt_CrtSetReportFile(PyObject *module, PyObject **args, Py_ssize_t nargs) { PyObject *return_value = NULL; int type; - int file; - long _return_value; + void *file; + void *_return_value; - if (!_PyArg_ParseStack(args, nargs, "ii:CrtSetReportFile", + if (!_PyArg_ParseStack(args, nargs, "i"_Py_PARSE_INTPTR":CrtSetReportFile", &type, &file)) { goto exit; } _return_value = msvcrt_CrtSetReportFile_impl(module, type, file); - if ((_return_value == -1) && PyErr_Occurred()) { + if ((_return_value == NULL || _return_value == INVALID_HANDLE_VALUE) && PyErr_Occurred()) { goto exit; } - return_value = PyLong_FromLong(_return_value); + return_value = PyLong_FromVoidPtr(_return_value); exit: return return_value; @@ -569,4 +569,4 @@ msvcrt_SetErrorMode(PyObject *module, PyObject *arg) #ifndef MSVCRT_SET_ERROR_MODE_METHODDEF #define MSVCRT_SET_ERROR_MODE_METHODDEF #endif /* !defined(MSVCRT_SET_ERROR_MODE_METHODDEF) */ -/*[clinic end generated code: output=8e9e57c48c4defcc input=a9049054013a1b77]*/ +/*[clinic end generated code: output=e86cf578e7f1ffd2 input=a9049054013a1b77]*/ diff --git a/PC/msvcrtmodule.c b/PC/msvcrtmodule.c index 59bf54fa0b7..fa9ad9dfeba 100644 --- a/PC/msvcrtmodule.c +++ b/PC/msvcrtmodule.c @@ -33,14 +33,20 @@ #endif /*[python input] -class intptr_t_converter(CConverter): - type = 'intptr_t' +class HANDLE_converter(CConverter): + type = 'void *' format_unit = '"_Py_PARSE_INTPTR"' -class handle_return_converter(long_return_converter): - type = 'intptr_t' - cast = '(void *)' - conversion_fn = 'PyLong_FromVoidPtr' +class HANDLE_return_converter(CReturnConverter): + type = 'void *' + + def render(self, function, data): + self.declare(data) + self.err_occurred_if( + "_return_value == NULL || _return_value == INVALID_HANDLE_VALUE", + data) + data.return_conversion.append( + 'return_value = PyLong_FromVoidPtr(_return_value);\n') class byte_char_return_converter(CReturnConverter): type = 'int' @@ -59,7 +65,7 @@ class wchar_t_return_converter(CReturnConverter): data.return_conversion.append( 'return_value = PyUnicode_FromOrdinal(_return_value);\n') [python start generated code]*/ -/*[python end generated code: output=da39a3ee5e6b4b0d input=b59f1663dba11997]*/ +/*[python end generated code: output=da39a3ee5e6b4b0d input=2b25dc89e9e59534]*/ /*[clinic input] module msvcrt @@ -152,7 +158,7 @@ msvcrt_setmode_impl(PyObject *module, int fd, int flags) /*[clinic input] msvcrt.open_osfhandle -> long - handle: intptr_t + handle: HANDLE flags: int / @@ -164,13 +170,13 @@ to os.fdopen() to create a file object. [clinic start generated code]*/ static long -msvcrt_open_osfhandle_impl(PyObject *module, intptr_t handle, int flags) -/*[clinic end generated code: output=cede871bf939d6e3 input=cb2108bbea84514e]*/ +msvcrt_open_osfhandle_impl(PyObject *module, void *handle, int flags) +/*[clinic end generated code: output=b2fb97c4b515e4e6 input=d5db190a307cf4bb]*/ { int fd; _Py_BEGIN_SUPPRESS_IPH - fd = _open_osfhandle(handle, flags); + fd = _open_osfhandle((intptr_t)handle, flags); _Py_END_SUPPRESS_IPH if (fd == -1) PyErr_SetFromErrno(PyExc_OSError); @@ -179,7 +185,7 @@ msvcrt_open_osfhandle_impl(PyObject *module, intptr_t handle, int flags) } /*[clinic input] -msvcrt.get_osfhandle -> handle +msvcrt.get_osfhandle -> HANDLE fd: int / @@ -189,9 +195,9 @@ Return the file handle for the file descriptor fd. Raises OSError if fd is not recognized. [clinic start generated code]*/ -static intptr_t +static void * msvcrt_get_osfhandle_impl(PyObject *module, int fd) -/*[clinic end generated code: output=7ce761dd0de2b503 input=305900f4bfab76c7]*/ +/*[clinic end generated code: output=aca01dfe24637374 input=5fcfde9b17136aa2]*/ { intptr_t handle = -1; @@ -201,7 +207,7 @@ msvcrt_get_osfhandle_impl(PyObject *module, int fd) if (handle == -1) PyErr_SetFromErrno(PyExc_OSError); - return handle; + return (HANDLE)handle; } /* Console I/O */ @@ -389,10 +395,10 @@ msvcrt_ungetwch_impl(PyObject *module, int unicode_char) #ifdef _DEBUG /*[clinic input] -msvcrt.CrtSetReportFile -> long +msvcrt.CrtSetReportFile -> HANDLE type: int - file: int + file: HANDLE / Wrapper around _CrtSetReportFile. @@ -400,14 +406,14 @@ Wrapper around _CrtSetReportFile. Only available on Debug builds. [clinic start generated code]*/ -static long -msvcrt_CrtSetReportFile_impl(PyObject *module, int type, int file) -/*[clinic end generated code: output=df291c7fe032eb68 input=bb8f721a604fcc45]*/ +static void * +msvcrt_CrtSetReportFile_impl(PyObject *module, int type, void *file) +/*[clinic end generated code: output=9393e8c77088bbe9 input=290809b5f19e65b9]*/ { - long res; + HANDLE res; _Py_BEGIN_SUPPRESS_IPH - res = (long)_CrtSetReportFile(type, (_HFILE)file); + res = _CrtSetReportFile(type, file); _Py_END_SUPPRESS_IPH return res; @@ -540,6 +546,20 @@ insertint(PyObject *d, char *name, int value) } } +static void +insertptr(PyObject *d, char *name, void *value) +{ + PyObject *v = PyLong_FromVoidPtr(value); + if (v == NULL) { + /* Don't bother reporting this error */ + PyErr_Clear(); + } + else { + PyDict_SetItemString(d, name, v); + Py_DECREF(v); + } +} + PyMODINIT_FUNC PyInit_msvcrt(void) { @@ -568,9 +588,9 @@ PyInit_msvcrt(void) insertint(d, "CRTDBG_MODE_FILE", _CRTDBG_MODE_FILE); insertint(d, "CRTDBG_MODE_WNDW", _CRTDBG_MODE_WNDW); insertint(d, "CRTDBG_REPORT_MODE", _CRTDBG_REPORT_MODE); - insertint(d, "CRTDBG_FILE_STDERR", (int)_CRTDBG_FILE_STDERR); - insertint(d, "CRTDBG_FILE_STDOUT", (int)_CRTDBG_FILE_STDOUT); - insertint(d, "CRTDBG_REPORT_FILE", (int)_CRTDBG_REPORT_FILE); + insertptr(d, "CRTDBG_FILE_STDERR", _CRTDBG_FILE_STDERR); + insertptr(d, "CRTDBG_FILE_STDOUT", _CRTDBG_FILE_STDOUT); + insertptr(d, "CRTDBG_REPORT_FILE", _CRTDBG_REPORT_FILE); #endif /* constants for the crt versions */ diff --git a/PC/winreg.c b/PC/winreg.c index 5efdc5e0efe..2d665f73186 100644 --- a/PC/winreg.c +++ b/PC/winreg.c @@ -905,7 +905,7 @@ winreg_CreateKeyEx_impl(PyObject *module, HKEY key, Py_UNICODE *sub_key, HKEY retKey; long rc; - rc = RegCreateKeyExW(key, sub_key, reserved, NULL, (DWORD)NULL, + rc = RegCreateKeyExW(key, sub_key, reserved, NULL, 0, access, NULL, &retKey, NULL); if (rc != ERROR_SUCCESS) { PyErr_SetFromWindowsErrWithFunction(rc, "CreateKeyEx"); diff --git a/PCbuild/_bz2.vcxproj b/PCbuild/_bz2.vcxproj index 9efb0d9a792..b3ab378c6ed 100644 --- a/PCbuild/_bz2.vcxproj +++ b/PCbuild/_bz2.vcxproj @@ -64,6 +64,7 @@ $(bz2Dir);%(AdditionalIncludeDirectories) WIN32;_FILE_OFFSET_BITS=64;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;%(PreprocessorDefinitions) + 4244;4267;%(DisableSpecificWarnings) 0x1D170000 diff --git a/PCbuild/_ctypes.vcxproj b/PCbuild/_ctypes.vcxproj index 70bea457d2a..43d51f82965 100644 --- a/PCbuild/_ctypes.vcxproj +++ b/PCbuild/_ctypes.vcxproj @@ -83,7 +83,9 @@ - + + 4267;%(DisableSpecificWarnings) + true diff --git a/PCbuild/liblzma.vcxproj b/PCbuild/liblzma.vcxproj index 4ace9d945f4..f408b547855 100644 --- a/PCbuild/liblzma.vcxproj +++ b/PCbuild/liblzma.vcxproj @@ -64,7 +64,7 @@ ProgramDatabase Disabled $(lzmaDir)windows;$(lzmaDir)src/liblzma/common;$(lzmaDir)src/common;$(lzmaDir)src/liblzma/api;$(lzmaDir)src/liblzma/check;$(lzmaDir)src/liblzma/delta;$(lzmaDir)src/liblzma/lz;$(lzmaDir)src/liblzma/lzma;$(lzmaDir)src/liblzma/rangecoder;$(lzmaDir)src/liblzma/simple - 4028;4113;4244;4267;4996 + 4028;4113;4133;4244;4267;4996;%(DisableSpecificWarnings) diff --git a/PCbuild/tcl.vcxproj b/PCbuild/tcl.vcxproj index 28a0ee90994..c940ab186f7 100644 --- a/PCbuild/tcl.vcxproj +++ b/PCbuild/tcl.vcxproj @@ -55,11 +55,12 @@ symbols,msvcrt INSTALLDIR="$(OutDir.TrimEnd(`\`))" INSTALL_DIR="$(OutDir.TrimEnd(`\`))" DEBUGFLAGS="-wd4456 -wd4457 -wd4458 -wd4459 -wd4996" + WARNINGS="-W3 -wd4311 -wd4312" setlocal set VCINSTALLDIR=$(VCInstallDir) cd /D "$(tclDir)win" -nmake -f makefile.vc MACHINE=$(TclMachine) OPTS=$(TclOpts) $(TclDirs) $(DebugFlags) core shell dlls -nmake -f makefile.vc MACHINE=$(TclMachine) OPTS=$(TclOpts) $(TclDirs) $(DebugFlags) install-binaries install-libraries +nmake -f makefile.vc MACHINE=$(TclMachine) OPTS=$(TclOpts) $(TclDirs) $(DebugFlags) $(WarningsFlags) core shell dlls +nmake -f makefile.vc MACHINE=$(TclMachine) OPTS=$(TclOpts) $(TclDirs) $(DebugFlags) $(WarningsFlags) install-binaries install-libraries copy /Y ..\license.terms "$(OutDir)\tcllicense.terms" diff --git a/PCbuild/tix.vcxproj b/PCbuild/tix.vcxproj index 525758c1c61..51682094cb8 100644 --- a/PCbuild/tix.vcxproj +++ b/PCbuild/tix.vcxproj @@ -56,7 +56,7 @@ BUILDDIRTOP="$(BuildDirTop)" TCL_DIR="$(tclDir.TrimEnd(`\`))" TK_DIR="$(tkDir.TrimEnd(`\`))" INSTALL_DIR="$(OutDir.TrimEnd(`\`))" DEBUG=1 NODEBUG=0 TCL_DBGX=g TK_DBGX=g DEBUG=0 NODEBUG=1 - -c -W3 -nologo -MD -wd4028 -wd4090 + -c -W3 -nologo -MD -wd4028 -wd4090 -wd4244 -wd4267 -wd4312 setlocal set VCINSTALLDIR=$(VCInstallDir) cd /D "$(tixDir)win" diff --git a/PCbuild/tk.vcxproj b/PCbuild/tk.vcxproj index f90e482130e..a1b8b9e10e8 100644 --- a/PCbuild/tk.vcxproj +++ b/PCbuild/tk.vcxproj @@ -56,11 +56,12 @@ symbols,msvcrt TCLDIR="$(tclDir.TrimEnd(`\`))" INSTALLDIR="$(OutDir.TrimEnd(`\`))" DEBUGFLAGS="-wd4456 -wd4457 -wd4458 -wd4459 -wd4996" + WARNINGS="-W3 -wd4244 -wd4267 -wd4311 -wd4312 -wd4334" setlocal set VCINSTALLDIR=$(VCInstallDir) cd /D "$(tkDir)win" -nmake /nologo -f makefile.vc RC=rc MACHINE=$(TclMachine) OPTS=$(TkOpts) $(TkDirs) $(DebugFlags) all -nmake /nologo -f makefile.vc RC=rc MACHINE=$(TclMachine) OPTS=$(TkOpts) $(TkDirs) $(DebugFlags) install-binaries install-libraries +nmake /nologo -f makefile.vc RC=rc MACHINE=$(TclMachine) OPTS=$(TkOpts) $(TkDirs) $(DebugFlags) $(WarningsFlags) all +nmake /nologo -f makefile.vc RC=rc MACHINE=$(TclMachine) OPTS=$(TkOpts) $(TkDirs) $(DebugFlags) $(WarningsFlags) install-binaries install-libraries copy /Y ..\license.terms "$(OutDir)\tklicense.terms" From webhook-mailer at python.org Wed Jul 26 18:19:20 2017 From: webhook-mailer at python.org (Steve Dower) Date: Wed, 26 Jul 2017 22:19:20 -0000 Subject: [Python-checkins] bpo-9566: Fixed _ssl module warnings (#2495) Message-ID: https://github.com/python/cpython/commit/5cff6379797967faabbb834a9eb154c3f0839489 commit: 5cff6379797967faabbb834a9eb154c3f0839489 branch: master author: Segev Finer committer: Steve Dower date: 2017-07-26T15:19:17-07:00 summary: bpo-9566: Fixed _ssl module warnings (#2495) * bpo-9566: Fixed some _ssl warnings * bpo-9566: _ssl: Fixup the fixes and also fix the remainings warnings * Add a comment about the downcast files: M Modules/_ssl.c diff --git a/Modules/_ssl.c b/Modules/_ssl.c index 458d2e7fd60..1380c575119 100644 --- a/Modules/_ssl.c +++ b/Modules/_ssl.c @@ -321,7 +321,7 @@ typedef struct { #endif #ifdef HAVE_ALPN unsigned char *alpn_protocols; - int alpn_protocols_len; + unsigned int alpn_protocols_len; #endif #ifndef OPENSSL_NO_TLSEXT PyObject *set_hostname; @@ -1591,7 +1591,8 @@ cipher_to_dict(const SSL_CIPHER *cipher) cipher_protocol = SSL_CIPHER_get_version(cipher); cipher_id = SSL_CIPHER_get_id(cipher); SSL_CIPHER_description(cipher, buf, sizeof(buf) - 1); - len = strlen(buf); + /* Downcast to avoid a warning. Safe since buf is always 512 bytes */ + len = (int)strlen(buf); if (len > 1 && buf[len-1] == '\n') buf[len-1] = '\0'; strength_bits = SSL_CIPHER_get_bits(cipher, &alg_bits); @@ -2975,12 +2976,18 @@ _ssl__SSLContext__set_alpn_protocols_impl(PySSLContext *self, /*[clinic end generated code: output=87599a7f76651a9b input=9bba964595d519be]*/ { #ifdef HAVE_ALPN + if (protos->len > UINT_MAX) { + PyErr_Format(PyExc_OverflowError, + "protocols longer than %d bytes", UINT_MAX); + return NULL; + } + PyMem_FREE(self->alpn_protocols); self->alpn_protocols = PyMem_Malloc(protos->len); if (!self->alpn_protocols) return PyErr_NoMemory(); memcpy(self->alpn_protocols, protos->buf, protos->len); - self->alpn_protocols_len = protos->len; + self->alpn_protocols_len = (unsigned int)protos->len; if (SSL_CTX_set_alpn_protos(self->ctx, self->alpn_protocols, self->alpn_protocols_len)) return PyErr_NoMemory(); @@ -4109,7 +4116,7 @@ memory_bio_dealloc(PySSLMemoryBIO *self) static PyObject * memory_bio_get_pending(PySSLMemoryBIO *self, void *c) { - return PyLong_FromLong(BIO_ctrl_pending(self->bio)); + return PyLong_FromSize_t(BIO_ctrl_pending(self->bio)); } PyDoc_STRVAR(PySSL_memory_bio_pending_doc, @@ -4145,7 +4152,7 @@ _ssl_MemoryBIO_read_impl(PySSLMemoryBIO *self, int len) int avail, nbytes; PyObject *result; - avail = BIO_ctrl_pending(self->bio); + avail = (int)Py_MIN(BIO_ctrl_pending(self->bio), INT_MAX); if ((len < 0) || (len > avail)) len = avail; @@ -4191,7 +4198,7 @@ _ssl_MemoryBIO_write_impl(PySSLMemoryBIO *self, Py_buffer *b) return NULL; } - nbytes = BIO_write(self->bio, b->buf, b->len); + nbytes = BIO_write(self->bio, b->buf, (int)b->len); if (nbytes < 0) { _setSSLError(NULL, 0, __FILE__, __LINE__); return NULL; From lp_benchmark_robot at intel.com Wed Jul 26 19:05:48 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Wed, 26 Jul 2017 16:05:48 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-26 Message-ID: Results for project python/master, build date: 2017-07-26 03:04:43-07:00. - commit: 2db6482 - previous commit: 3924377 - revision date: 2017-07-26 02:32:42+02:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.140% | -0.027% | +4.764% | +7.393% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 3.491% | -0.112% | +23.616% | +9.204% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.634% | +0.687% | +25.334% | +7.665% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 2.135% | -1.116% | +21.891% | +8.644% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.392% | -0.586% | +5.859% | +11.389% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.295% | -0.527% | +11.135% | +11.149% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.655% | +0.125% | +8.194% | +8.384% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.429% | +0.120% | +5.475% | +4.883% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.731% | +0.949% | +6.970% | +18.128% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.880% | -0.696% | +8.743% | +14.334% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.146% | +0.475% | +4.216% | +5.849% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.737% | -0.134% | +5.070% | +5.659% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.566% | +0.465% | +3.917% | +5.339% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.428% | +0.062% | +9.351% | +11.415% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 1.745% | +0.690% | +7.451% | +10.169% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.837% | +0.186% | +7.835% | +9.597% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.575% | +0.195% | +10.541% | +10.390% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.563% | +0.313% | +9.388% | +9.435% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.821% | +0.349% | +3.321% | +10.405% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 4.482% | +0.150% | +1.446% | +12.065% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.597% | -0.437% | +8.026% | +10.995% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 1.829% | +0.391% | +9.994% | +13.781% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.840% | -0.506% | +8.874% | +12.081% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.615% | +0.197% | +18.417% | +11.960% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 9.254% | -2.072% | +2.838% | +16.219% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.688% | +0.924% | +4.632% | +4.905% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.707% | -0.101% | -3.084% | +3.191% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.719% | +0.004% | +2.473% | +8.073% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.262% | -0.621% | +1.816% | +12.795% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 0.979% | +1.190% | +3.824% | +21.319% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.467% | +0.033% | +2.350% | +18.679% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.468% | -0.175% | +5.452% | +16.924% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 5.932% | -2.097% | +11.186% | +10.842% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.215% | -0.005% | +0.361% | +9.788% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.130% | -0.222% | +9.509% | +4.580% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.087% | -0.104% | +1.295% | +4.470% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.238% | +0.455% | +10.535% | +11.648% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.199% | -1.182% | -9.601% | +8.264% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.552% | +0.038% | +2.050% | +9.809% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.503% | -0.070% | -1.679% | +5.974% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.357% | -0.618% | +11.710% | +3.440% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.514% | -0.120% | +9.681% | +12.246% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.483% | +0.082% | +1.252% | +2.465% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.520% | -0.340% | +26.451% | +9.125% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.780% | -0.341% | +5.600% | +5.349% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.088% | +0.053% | +16.064% | +7.742% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 2.153% | +0.911% | +1.185% | +0.092% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.863% | -0.229% | +6.411% | +1.325% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.131% | -0.137% | +5.299% | +6.200% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.291% | -1.106% | +4.409% | +2.661% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.332% | +0.798% | +2.097% | +9.225% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.048% | -0.347% | +12.679% | +7.933% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.679% | +0.028% | +10.366% | +6.162% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.556% | +0.249% | +12.390% | +8.091% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.643% | +0.784% | +13.393% | +8.565% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.771% | -2.956% | +20.701% | +10.576% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 0.983% | -0.095% | +6.921% | +4.828% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.803% | +0.476% | +2.479% | +1.700% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.688% | +1.123% | +7.696% | +22.715% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.195% | -0.011% | -1.145% | +20.382% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.790% | +0.951% | +7.152% | +8.403% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.963% | -0.048% | +5.660% | +8.132% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.413% | +0.031% | +1.439% | +7.539% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.814% | -0.309% | -6.436% | +11.008% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.291% | +0.176% | +6.767% | +8.527% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-26 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Wed Jul 26 19:10:02 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Wed, 26 Jul 2017 23:10:02 -0000 Subject: [Python-checkins] bpo-30853: IDLE: Factor a VarTrace class from configdialog.ConfigDialog. (#2872) Message-ID: https://github.com/python/cpython/commit/45bf723c6c591ec56a18dad8150ae89797450d8b commit: 45bf723c6c591ec56a18dad8150ae89797450d8b branch: master author: csabella committer: Terry Jan Reedy date: 2017-07-26T19:09:58-04:00 summary: bpo-30853: IDLE: Factor a VarTrace class from configdialog.ConfigDialog. (#2872) The new class manages pairs of tk Variables and trace callbacks. It is completely covered by new tests. files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 1832e156dc6..f98af4600ee 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -1846,6 +1846,61 @@ def save_all_changed_extensions(self): self.ext_userCfg.Save() +class VarTrace: + """Maintain Tk variables trace state.""" + + def __init__(self): + """Store Tk variables and callbacks. + + untraced: List of tuples (var, callback) + that do not have the callback attached + to the Tk var. + traced: List of tuples (var, callback) where + that callback has been attached to the var. + """ + self.untraced = [] + self.traced = [] + + def add(self, var, callback): + """Add (var, callback) tuple to untraced list. + + Args: + var: Tk variable instance. + callback: Function to be used as a callback or + a tuple with IdleConf values for default + callback. + + Return: + Tk variable instance. + """ + if isinstance(callback, tuple): + callback = self.make_callback(var, callback) + self.untraced.append((var, callback)) + return var + + @staticmethod + def make_callback(var, config): + "Return default callback function to add values to changes instance." + def default_callback(*params): + "Add config values to changes instance." + changes.add_option(*config, var.get()) + return default_callback + + def attach(self): + "Attach callback to all vars that are not traced." + while self.untraced: + var, callback = self.untraced.pop() + var.trace_add('write', callback) + self.traced.append((var, callback)) + + def detach(self): + "Remove callback from traced vars." + while self.traced: + var, callback = self.traced.pop() + var.trace_remove('write', var.trace_info()[0][1]) + self.untraced.append((var, callback)) + + help_common = '''\ When you click either the Apply or Ok buttons, settings in this dialog that are different from IDLE's default are saved in diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 54b2d78d667..ce02ae4a8e6 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -3,11 +3,12 @@ Half the class creates dialog, half works with user customizations. Coverage: 46% just by creating dialog, 60% with current tests. """ -from idlelib.configdialog import ConfigDialog, idleConf, changes +from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace from test.support import requires requires('gui') -from tkinter import Tk +from tkinter import Tk, IntVar, BooleanVar import unittest +from unittest import mock import idlelib.config as config from idlelib.idle_test.mock_idle import Func @@ -248,5 +249,94 @@ def test_editor_size(self): #def test_help_sources(self): pass # TODO +class TestVarTrace(unittest.TestCase): + + def setUp(self): + changes.clear() + self.v1 = IntVar(root) + self.v2 = BooleanVar(root) + self.called = 0 + self.tracers = VarTrace() + + def tearDown(self): + del self.v1, self.v2 + + def var_changed_increment(self, *params): + self.called += 13 + + def var_changed_boolean(self, *params): + pass + + def test_init(self): + self.assertEqual(self.tracers.untraced, []) + self.assertEqual(self.tracers.traced, []) + + def test_add(self): + tr = self.tracers + func = Func() + cb = tr.make_callback = mock.Mock(return_value=func) + + v1 = tr.add(self.v1, self.var_changed_increment) + self.assertIsInstance(v1, IntVar) + v2 = tr.add(self.v2, self.var_changed_boolean) + self.assertIsInstance(v2, BooleanVar) + + v3 = IntVar(root) + v3 = tr.add(v3, ('main', 'section', 'option')) + cb.assert_called_once() + cb.assert_called_with(v3, ('main', 'section', 'option')) + + expected = [(v1, self.var_changed_increment), + (v2, self.var_changed_boolean), + (v3, func)] + self.assertEqual(tr.traced, []) + self.assertEqual(tr.untraced, expected) + + del tr.make_callback + + def test_make_callback(self): + tr = self.tracers + cb = tr.make_callback(self.v1, ('main', 'section', 'option')) + self.assertTrue(callable(cb)) + self.v1.set(42) + # Not attached, so set didn't invoke the callback. + self.assertNotIn('section', changes['main']) + # Invoke callback manually. + cb() + self.assertIn('section', changes['main']) + self.assertEqual(changes['main']['section']['option'], '42') + + def test_attach_detach(self): + tr = self.tracers + v1 = tr.add(self.v1, self.var_changed_increment) + v2 = tr.add(self.v2, self.var_changed_boolean) + expected = [(v1, self.var_changed_increment), + (v2, self.var_changed_boolean)] + + # Attach callbacks and test call increment. + tr.attach() + self.assertEqual(tr.untraced, []) + self.assertCountEqual(tr.traced, expected) + v1.set(1) + self.assertEqual(v1.get(), 1) + self.assertEqual(self.called, 13) + + # Check that only one callback is attached to a variable. + # If more than one callback were attached, then var_changed_increment + # would be called twice and the counter would be 2. + self.called = 0 + tr.attach() + v1.set(1) + self.assertEqual(self.called, 13) + + # Detach callbacks. + self.called = 0 + tr.detach() + self.assertEqual(tr.traced, []) + self.assertCountEqual(tr.untraced, expected) + v1.set(1) + self.assertEqual(self.called, 0) + + if __name__ == '__main__': unittest.main(verbosity=2) From webhook-mailer at python.org Wed Jul 26 19:24:55 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 23:24:55 -0000 Subject: [Python-checkins] bpo-30980: Fix double close in asyncore.file_wrapper (#2789) (#2900) Message-ID: https://github.com/python/cpython/commit/29094cec7cddd561cac16ce93443ca72d740de4d commit: 29094cec7cddd561cac16ce93443ca72d740de4d branch: 2.7 author: Nir Soffer committer: Victor Stinner date: 2017-07-27T01:24:52+02:00 summary: bpo-30980: Fix double close in asyncore.file_wrapper (#2789) (#2900) * bpo-30980: Fix close test to fail test_close_twice was not considering the fact that file_wrapper is duping the file descriptor. Closing the original descriptor left the duped one open, hiding the fact that close protection is not effective. * bpo-30980: Fix double close protection Invalidated self.fd before closing, handling correctly the case when os.close raises. * bpo-30980: Fix fd leak introduced in the fixed test files: M Lib/asyncore.py M Lib/test/test_asyncore.py diff --git a/Lib/asyncore.py b/Lib/asyncore.py index 29099bdf5c0..105982f790c 100644 --- a/Lib/asyncore.py +++ b/Lib/asyncore.py @@ -633,7 +633,11 @@ def getsockopt(self, level, optname, buflen=None): write = send def close(self): - os.close(self.fd) + if self.fd < 0: + return + fd = self.fd + self.fd = -1 + os.close(fd) def fileno(self): return self.fd diff --git a/Lib/test/test_asyncore.py b/Lib/test/test_asyncore.py index dc2b626f1e7..693d67cd8a3 100644 --- a/Lib/test/test_asyncore.py +++ b/Lib/test/test_asyncore.py @@ -442,6 +442,19 @@ def handle_read(self): asyncore.loop(timeout=0.01, use_poll=True, count=2) self.assertEqual(b"".join(data), self.d) + def test_close_twice(self): + fd = os.open(TESTFN, os.O_RDONLY) + f = asyncore.file_wrapper(fd) + os.close(fd) + + os.close(f.fd) # file_wrapper dupped fd + with self.assertRaises(OSError): + f.close() + + self.assertEqual(f.fd, -1) + # calling close twice should not fail + f.close() + class BaseTestHandler(asyncore.dispatcher): From webhook-mailer at python.org Wed Jul 26 19:27:11 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Wed, 26 Jul 2017 23:27:11 -0000 Subject: [Python-checkins] bpo-30980: Fix double close in asyncore.file_wrapper (#2789) (#2898) Message-ID: https://github.com/python/cpython/commit/25de5baf3eaebddbf879aacf49c0f614f922dc42 commit: 25de5baf3eaebddbf879aacf49c0f614f922dc42 branch: 3.6 author: Nir Soffer committer: Victor Stinner date: 2017-07-27T01:27:08+02:00 summary: bpo-30980: Fix double close in asyncore.file_wrapper (#2789) (#2898) * bpo-30980: Fix close test to fail test_close_twice was not considering the fact that file_wrapper is duping the file descriptor. Closing the original descriptor left the duped one open, hiding the fact that close protection is not effective. * bpo-30980: Fix double close protection Invalidated self.fd before closing, handling correctly the case when os.close raises. * bpo-30980: Fix fd leak introduced in the fixed test files: M Lib/asyncore.py M Lib/test/test_asyncore.py diff --git a/Lib/asyncore.py b/Lib/asyncore.py index 705e4068130..03d16838b73 100644 --- a/Lib/asyncore.py +++ b/Lib/asyncore.py @@ -619,8 +619,9 @@ def getsockopt(self, level, optname, buflen=None): def close(self): if self.fd < 0: return - os.close(self.fd) + fd = self.fd self.fd = -1 + os.close(fd) def fileno(self): return self.fd diff --git a/Lib/test/test_asyncore.py b/Lib/test/test_asyncore.py index dc2f716e0bb..07edf2275be 100644 --- a/Lib/test/test_asyncore.py +++ b/Lib/test/test_asyncore.py @@ -433,7 +433,10 @@ def test_close_twice(self): f = asyncore.file_wrapper(fd) os.close(fd) - f.close() + os.close(f.fd) # file_wrapper dupped fd + with self.assertRaises(OSError): + f.close() + self.assertEqual(f.fd, -1) # calling close twice should not fail f.close() From webhook-mailer at python.org Wed Jul 26 20:53:16 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Thu, 27 Jul 2017 00:53:16 -0000 Subject: [Python-checkins] [3.6] bpo-30853: IDLE: Factor a VarTrace class from configdialog.ConfigDialog. (GH-2872) (#2903) Message-ID: https://github.com/python/cpython/commit/0243bea55dc340067247e635442f2a227705315a commit: 0243bea55dc340067247e635442f2a227705315a branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-26T20:53:13-04:00 summary: [3.6] bpo-30853: IDLE: Factor a VarTrace class from configdialog.ConfigDialog. (GH-2872) (#2903) The new class manages pairs of tk Variables and trace callbacks. It is completely covered by new tests. (cherry picked from commit 45bf723) files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 1832e156dc6..f98af4600ee 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -1846,6 +1846,61 @@ def save_all_changed_extensions(self): self.ext_userCfg.Save() +class VarTrace: + """Maintain Tk variables trace state.""" + + def __init__(self): + """Store Tk variables and callbacks. + + untraced: List of tuples (var, callback) + that do not have the callback attached + to the Tk var. + traced: List of tuples (var, callback) where + that callback has been attached to the var. + """ + self.untraced = [] + self.traced = [] + + def add(self, var, callback): + """Add (var, callback) tuple to untraced list. + + Args: + var: Tk variable instance. + callback: Function to be used as a callback or + a tuple with IdleConf values for default + callback. + + Return: + Tk variable instance. + """ + if isinstance(callback, tuple): + callback = self.make_callback(var, callback) + self.untraced.append((var, callback)) + return var + + @staticmethod + def make_callback(var, config): + "Return default callback function to add values to changes instance." + def default_callback(*params): + "Add config values to changes instance." + changes.add_option(*config, var.get()) + return default_callback + + def attach(self): + "Attach callback to all vars that are not traced." + while self.untraced: + var, callback = self.untraced.pop() + var.trace_add('write', callback) + self.traced.append((var, callback)) + + def detach(self): + "Remove callback from traced vars." + while self.traced: + var, callback = self.traced.pop() + var.trace_remove('write', var.trace_info()[0][1]) + self.untraced.append((var, callback)) + + help_common = '''\ When you click either the Apply or Ok buttons, settings in this dialog that are different from IDLE's default are saved in diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 54b2d78d667..ce02ae4a8e6 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -3,11 +3,12 @@ Half the class creates dialog, half works with user customizations. Coverage: 46% just by creating dialog, 60% with current tests. """ -from idlelib.configdialog import ConfigDialog, idleConf, changes +from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace from test.support import requires requires('gui') -from tkinter import Tk +from tkinter import Tk, IntVar, BooleanVar import unittest +from unittest import mock import idlelib.config as config from idlelib.idle_test.mock_idle import Func @@ -248,5 +249,94 @@ def test_editor_size(self): #def test_help_sources(self): pass # TODO +class TestVarTrace(unittest.TestCase): + + def setUp(self): + changes.clear() + self.v1 = IntVar(root) + self.v2 = BooleanVar(root) + self.called = 0 + self.tracers = VarTrace() + + def tearDown(self): + del self.v1, self.v2 + + def var_changed_increment(self, *params): + self.called += 13 + + def var_changed_boolean(self, *params): + pass + + def test_init(self): + self.assertEqual(self.tracers.untraced, []) + self.assertEqual(self.tracers.traced, []) + + def test_add(self): + tr = self.tracers + func = Func() + cb = tr.make_callback = mock.Mock(return_value=func) + + v1 = tr.add(self.v1, self.var_changed_increment) + self.assertIsInstance(v1, IntVar) + v2 = tr.add(self.v2, self.var_changed_boolean) + self.assertIsInstance(v2, BooleanVar) + + v3 = IntVar(root) + v3 = tr.add(v3, ('main', 'section', 'option')) + cb.assert_called_once() + cb.assert_called_with(v3, ('main', 'section', 'option')) + + expected = [(v1, self.var_changed_increment), + (v2, self.var_changed_boolean), + (v3, func)] + self.assertEqual(tr.traced, []) + self.assertEqual(tr.untraced, expected) + + del tr.make_callback + + def test_make_callback(self): + tr = self.tracers + cb = tr.make_callback(self.v1, ('main', 'section', 'option')) + self.assertTrue(callable(cb)) + self.v1.set(42) + # Not attached, so set didn't invoke the callback. + self.assertNotIn('section', changes['main']) + # Invoke callback manually. + cb() + self.assertIn('section', changes['main']) + self.assertEqual(changes['main']['section']['option'], '42') + + def test_attach_detach(self): + tr = self.tracers + v1 = tr.add(self.v1, self.var_changed_increment) + v2 = tr.add(self.v2, self.var_changed_boolean) + expected = [(v1, self.var_changed_increment), + (v2, self.var_changed_boolean)] + + # Attach callbacks and test call increment. + tr.attach() + self.assertEqual(tr.untraced, []) + self.assertCountEqual(tr.traced, expected) + v1.set(1) + self.assertEqual(v1.get(), 1) + self.assertEqual(self.called, 13) + + # Check that only one callback is attached to a variable. + # If more than one callback were attached, then var_changed_increment + # would be called twice and the counter would be 2. + self.called = 0 + tr.attach() + v1.set(1) + self.assertEqual(self.called, 13) + + # Detach callbacks. + self.called = 0 + tr.detach() + self.assertEqual(tr.traced, []) + self.assertCountEqual(tr.untraced, expected) + v1.set(1) + self.assertEqual(self.called, 0) + + if __name__ == '__main__': unittest.main(verbosity=2) From webhook-mailer at python.org Wed Jul 26 20:54:42 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Thu, 27 Jul 2017 00:54:42 -0000 Subject: [Python-checkins] bpo-31003: IDLE - Add more tests for General tab (#2859) Message-ID: https://github.com/python/cpython/commit/2bc8f0e6867f59e5e8444b2bde99bb0fa3dbefc8 commit: 2bc8f0e6867f59e5e8444b2bde99bb0fa3dbefc8 branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-26T20:54:40-04:00 summary: bpo-31003: IDLE - Add more tests for General tab (#2859) * In configdialog: Document causal pathways in create_page_general. Move related functions to follow this. Simplify some attribute names. * In test_configdialog: Add tests for load and helplist functions. Coverage for the general tab is now complete, and 63% overall. files: A Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/mock_idle.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index f98af4600ee..daaa34459e2 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -160,7 +160,7 @@ def create_page_font_tab(self): corresponding aspect of the font sample on this page and highlight sample on highlight page. - Load_font_cfg initializes font vars and widgets from + Funtion load_font_cfg initializes font vars and widgets from idleConf entries and tk. Fontlist: mouse button 1 click or up or down key invoke @@ -470,7 +470,7 @@ def tem(event, elem=element): event.widget.winfo_toplevel().highlight_target.set(elem) text.tag_bind( self.theme_elements[element][0], '', tem) - text.config(state=DISABLED) + text['state'] = DISABLED self.frame_color_set = Frame(frame_custom, relief=SOLID, borderwidth=1) frame_fg_bg_toggle = Frame(frame_custom) button_set_color = Button( @@ -650,59 +650,61 @@ def create_page_keys(self): frames[1].pack(side=TOP, fill=X, expand=True, pady=2) return frame + def create_page_general(self): """Return frame of widgets for General tab. - Tk Variables: - win_width: Initial window width in characters. - win_height: Initial window height in characters. - startup_edit: Selector for opening in editor or shell mode. - autosave: Selector for save prompt popup when using Run. - - Methods: - load_general_config: - help_source_selected: Bound to list_help button release. - set_helplist_button_states: Toggle based on list. - helplist_item_edit: Command for button_helplist_edit. - helplist_item_add: Command for button_helplist_add. - helplist_item_remove: Command for button_helplist_remove. - update_user_help_changed_items: Fill in changes. + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + var_changed_var_name callback that adds option to changes. + + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. Widget Structure: (*) widgets bound to self frame frame_run: LabelFrame startup_title: Label - (*)radio_startup_edit: Radiobutton - startup_edit - (*)radio_startup_shell: Radiobutton - startup_edit + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit frame_save: LabelFrame run_save_title: Label - (*)radio_save_ask: Radiobutton - autosave - (*)radio_save_auto: Radiobutton - autosave + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave frame_win_size: LabelFrame win_size_title: Label win_width_title: Label - (*)entry_win_width: Entry - win_width + (*)win_width_int: Entry - win_width win_height_title: Label - (*)entry_win_height: Entry - win_height + (*)win_height_int: Entry - win_height frame_help: LabelFrame frame_helplist: Frame frame_helplist_buttons: Frame (*)button_helplist_edit (*)button_helplist_add (*)button_helplist_remove + (*)helplist: ListBox scroll_helplist: Scrollbar - (*)list_help: ListBox """ parent = self.parent - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) self.startup_edit = IntVar(parent) self.autosave = IntVar(parent) + self.win_width = StringVar(parent) + self.win_height = StringVar(parent) - #widget creation - #body + # Create widgets: + # body. frame = self.tab_pages.pages['General'].frame - #body section frames + # body section frames. frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Startup Preferences ') frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -710,41 +712,41 @@ def create_page_general(self): frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Additional Help Sources ') - #frame_run + # frame_run. startup_title = Label(frame_run, text='At Startup') - self.radio_startup_edit = Radiobutton( + self.startup_editor_on = Radiobutton( frame_run, variable=self.startup_edit, value=1, text="Open Edit Window") - self.radio_startup_shell = Radiobutton( + self.startup_shell_on = Radiobutton( frame_run, variable=self.startup_edit, value=0, text='Open Shell Window') - #frame_save + # frame_save. run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.radio_save_ask = Radiobutton( + self.save_ask_on = Radiobutton( frame_save, variable=self.autosave, value=0, text="Prompt to Save") - self.radio_save_auto = Radiobutton( + self.save_auto_on = Radiobutton( frame_save, variable=self.autosave, value=1, text='No Prompt') - #frame_win_size + # frame_win_size. win_size_title = Label( frame_win_size, text='Initial Window Size (in characters)') win_width_title = Label(frame_win_size, text='Width') - self.entry_win_width = Entry( + self.win_width_int = Entry( frame_win_size, textvariable=self.win_width, width=3) win_height_title = Label(frame_win_size, text='Height') - self.entry_win_height = Entry( + self.win_height_int = Entry( frame_win_size, textvariable=self.win_height, width=3) - #frame_help + # frame_help. frame_helplist = Frame(frame_help) frame_helplist_buttons = Frame(frame_helplist) - scroll_helplist = Scrollbar(frame_helplist) - self.list_help = Listbox( + self.helplist = Listbox( frame_helplist, height=5, takefocus=FALSE, exportselection=FALSE) - scroll_helplist.config(command=self.list_help.yview) - self.list_help.config(yscrollcommand=scroll_helplist.set) - self.list_help.bind('', self.help_source_selected) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) self.button_helplist_edit = Button( frame_helplist_buttons, text='Edit', state=DISABLED, width=8, command=self.helplist_item_edit) @@ -755,36 +757,146 @@ def create_page_general(self): frame_helplist_buttons, text='Remove', state=DISABLED, width=8, command=self.helplist_item_remove) - #widget packing - #body + # Pack widgets: + # body. frame_run.pack(side=TOP, padx=5, pady=5, fill=X) frame_save.pack(side=TOP, padx=5, pady=5, fill=X) frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - #frame_run + # frame_run. startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.radio_startup_shell.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.radio_startup_edit.pack(side=RIGHT, anchor=W, padx=5, pady=5) - #frame_save + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.radio_save_auto.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.radio_save_ask.pack(side=RIGHT, anchor=W, padx=5, pady=5) - #frame_win_size + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.entry_win_height.pack(side=RIGHT, anchor=E, padx=10, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.entry_win_width.pack(side=RIGHT, anchor=E, padx=10, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) win_width_title.pack(side=RIGHT, anchor=E, pady=5) - #frame_help + # frame_help. frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.list_help.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) self.button_helplist_add.pack(side=TOP, anchor=W) self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + return frame + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() + + def var_changed_startup_edit(self, *params): + "Store change to toggle for starting IDLE in the editor or shell." + value = self.startup_edit.get() + changes.add_option('main', 'General', 'editor-on-startup', value) + + def var_changed_autosave(self, *params): + "Store change to autosave." + value = self.autosave.get() + changes.add_option('main', 'General', 'autosave', value) + + def var_changed_win_width(self, *params): + "Store change to window width." + value = self.win_width.get() + changes.add_option('main', 'EditorWindow', 'width', value) + + def var_changed_win_height(self, *params): + "Store change to window height." + value = self.win_height.get() + changes.add_option('main', 'EditorWindow', 'height', value) + + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() + + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + + def helplist_item_add(self): + """Handle add button for the help list. + + Query for name and location of new help sources and add + them to the list. + """ + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() + + def helplist_item_edit(self): + """Handle edit button for the help list. + + Query with existing help source information and update + config if the values are changed. + """ + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected + + def helplist_item_remove(self): + """Handle remove button for the help list. + + Delete the help list item from config. + """ + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() + + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) + + def attach_var_callbacks(self): "Attach callbacks to variables that can be changed." self.font_size.trace_add('write', self.var_changed_font) @@ -917,26 +1029,6 @@ def var_changed_are_keys_builtin(self, *params): else: self.var_changed_custom_keys() - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) - - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) - - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) - - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) - def set_theme_type(self): """Set available screen options based on builtin or custom theme. @@ -956,26 +1048,26 @@ def set_theme_type(self): load_theme_cfg """ if self.is_builtin_theme.get(): - self.opt_menu_theme_builtin.config(state=NORMAL) - self.opt_menu_theme_custom.config(state=DISABLED) - self.button_delete_custom_theme.config(state=DISABLED) + self.opt_menu_theme_builtin['state'] = NORMAL + self.opt_menu_theme_custom['state'] = DISABLED + self.button_delete_custom_theme['state'] = DISABLED else: - self.opt_menu_theme_builtin.config(state=DISABLED) - self.radio_theme_custom.config(state=NORMAL) - self.opt_menu_theme_custom.config(state=NORMAL) - self.button_delete_custom_theme.config(state=NORMAL) + self.opt_menu_theme_builtin['state'] = DISABLED + self.radio_theme_custom['state'] = NORMAL + self.opt_menu_theme_custom['state'] = NORMAL + self.button_delete_custom_theme['state'] = NORMAL def set_keys_type(self): "Set available screen options based on builtin or custom key set." if self.are_keys_builtin.get(): - self.opt_menu_keys_builtin.config(state=NORMAL) - self.opt_menu_keys_custom.config(state=DISABLED) - self.button_delete_custom_keys.config(state=DISABLED) + self.opt_menu_keys_builtin['state'] = NORMAL + self.opt_menu_keys_custom['state'] = DISABLED + self.button_delete_custom_keys['state'] = DISABLED else: - self.opt_menu_keys_builtin.config(state=DISABLED) - self.radio_keys_custom.config(state=NORMAL) - self.opt_menu_keys_custom.config(state=NORMAL) - self.button_delete_custom_keys.config(state=NORMAL) + self.opt_menu_keys_builtin['state'] = DISABLED + self.radio_keys_custom['state'] = NORMAL + self.opt_menu_keys_custom['state'] = NORMAL + self.button_delete_custom_keys['state'] = NORMAL def get_new_keys(self): """Handle event to change key binding for selected line. @@ -1037,7 +1129,7 @@ def save_as_new_key_set(self): def keybinding_selected(self, event): "Activate button to assign new keys to selected action." - self.button_new_keys.config(state=NORMAL) + self.button_new_keys['state'] = NORMAL def create_new_key_set(self, new_key_set_name): """Create a new custom key set with the given name. @@ -1115,7 +1207,7 @@ def delete_custom_keys(self): item_list = idleConf.GetSectionList('user', 'keys') item_list.sort() if not item_list: - self.radio_keys_custom.config(state=DISABLED) + self.radio_keys_custom['state'] = DISABLED self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') else: self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) @@ -1164,7 +1256,7 @@ def delete_custom_theme(self): item_list = idleConf.GetSectionList('user', 'highlight') item_list.sort() if not item_list: - self.radio_theme_custom.config(state=DISABLED) + self.radio_theme_custom['state'] = DISABLED self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') else: self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) @@ -1303,12 +1395,12 @@ def set_highlight_target(self): load_theme_cfg """ if self.highlight_target.get() == 'Cursor': # bg not possible - self.radio_fg.config(state=DISABLED) - self.radio_bg.config(state=DISABLED) + self.radio_fg['state'] = DISABLED + self.radio_bg['state'] = DISABLED self.fg_bg_toggle.set(1) else: # Both fg and bg can be set. - self.radio_fg.config(state=NORMAL) - self.radio_bg.config(state=NORMAL) + self.radio_fg['state'] = NORMAL + self.radio_bg['state'] = NORMAL self.fg_bg_toggle.set(1) self.set_color_sample() @@ -1378,76 +1470,6 @@ def paint_theme_sample(self): self.highlight_sample.tag_config(element, **colors) self.set_color_sample() - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_helplist_button_states() - - def set_helplist_button_states(self): - "Toggle the state for the help list buttons based on list entries." - if self.list_help.size() < 1: # No entries in list. - self.button_helplist_edit.config(state=DISABLED) - self.button_helplist_remove.config(state=DISABLED) - else: # Some entries. - if self.list_help.curselection(): # There currently is a selection. - self.button_helplist_edit.config(state=NORMAL) - self.button_helplist_remove.config(state=NORMAL) - else: # There currently is not a selection. - self.button_helplist_edit.config(state=DISABLED) - self.button_helplist_remove.config(state=DISABLED) - - def helplist_item_add(self): - """Handle add button for the help list. - - Query for name and location of new help sources and add - them to the list. - """ - help_source = HelpSource(self, 'New Help Source', - ).result - if help_source: - self.user_helplist.append((help_source[0], help_source[1])) - self.list_help.insert(END, help_source[0]) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def helplist_item_edit(self): - """Handle edit button for the help list. - - Query with existing help source information and update - config if the values are changed. - """ - item_index = self.list_help.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.list_help.delete(item_index) - self.list_help.insert(item_index, new_help_source[0]) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def helplist_item_remove(self): - """Handle remove button for the help list. - - Delete the help list item from config. - """ - item_index = self.list_help.index(ANCHOR) - del(self.user_helplist[item_index]) - self.list_help.delete(item_index) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def update_user_help_changed_items(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) - def load_theme_cfg(self): """Load current configuration settings for the theme options. @@ -1481,7 +1503,7 @@ def load_theme_cfg(self): item_list = idleConf.GetSectionList('user', 'highlight') item_list.sort() if not item_list: - self.radio_theme_custom.config(state=DISABLED) + self.radio_theme_custom['state'] = DISABLED self.custom_theme.set('- no custom themes -') else: self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) @@ -1515,7 +1537,7 @@ def load_key_cfg(self): item_list = idleConf.GetSectionList('user', 'keys') item_list.sort() if not item_list: - self.radio_keys_custom.config(state=DISABLED) + self.radio_keys_custom['state'] = DISABLED self.custom_keys.set('- no custom keys -') else: self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) @@ -1531,25 +1553,6 @@ def load_key_cfg(self): keyset_name = idleConf.CurrentKeys() self.load_keys_list(keyset_name) - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=1, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - for help_item in self.user_helplist: - self.list_help.insert(END, help_item[0]) - self.set_helplist_button_states() - def load_configs(self): """Load configuration for each page. diff --git a/Lib/idlelib/idle_test/mock_idle.py b/Lib/idlelib/idle_test/mock_idle.py index 8f3147b1c5c..f279a52fd51 100644 --- a/Lib/idlelib/idle_test/mock_idle.py +++ b/Lib/idlelib/idle_test/mock_idle.py @@ -13,14 +13,16 @@ class Func: self.args - capture positional arguments. self.kwds - capture keyword arguments. self.result - return or raise value set in __init__. + self.return_self - return self instead, to mock query class return. Most common use will probably be to mock instance methods. Given class instance, can set and delete as instance attribute. Mock_tk.Var and Mbox_func are special variants of this. ''' - def __init__(self, result=None): + def __init__(self, result=None, return_self=False): self.called = 0 self.result = result + self.return_self = return_self self.args = None self.kwds = None def __call__(self, *args, **kwds): @@ -29,6 +31,8 @@ def __call__(self, *args, **kwds): self.kwds = kwds if isinstance(self.result, BaseException): raise self.result + elif self.return_self: + return self else: return self.result diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index ce02ae4a8e6..7296075fbec 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -1,16 +1,17 @@ """Test idlelib.configdialog. Half the class creates dialog, half works with user customizations. -Coverage: 46% just by creating dialog, 60% with current tests. +Coverage: 63%. """ -from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace +from idlelib import configdialog from test.support import requires requires('gui') -from tkinter import Tk, IntVar, BooleanVar import unittest from unittest import mock -import idlelib.config as config from idlelib.idle_test.mock_idle import Func +from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL +from idlelib import config +from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace # Tests should not depend on fortuitous user configurations. # They must not affect actual user .cfg files. @@ -226,27 +227,200 @@ def setUp(self): class GeneralTest(unittest.TestCase): + """Test that general tab widgets enable users to make changes. + + Test that widget actions set vars, that var changes add + options to changes and that helplist works correctly. + """ + @classmethod + def setUpClass(cls): + # Mask instance methods used by help functions. + d = dialog + d.set = d.set_add_delete_state = Func() + d.upc = d.update_help_changes = Func() + + @classmethod + def tearDownClass(cls): + d = dialog + del d.set, d.set_add_delete_state + del d.upc, d.update_help_changes + d.helplist.delete(0, 'end') + d.user_helplist.clear() def setUp(self): changes.clear() + def test_load_general_cfg(self): + # Set to wrong values, load, check right values. + eq = self.assertEqual + d = dialog + d.startup_edit.set(1) + d.autosave.set(1) + d.win_width.set(1) + d.win_height.set(1) + d.helplist.insert('end', 'bad') + d.user_helplist = ['bad', 'worse'] + idleConf.SetOption('main', 'HelpFiles', '1', 'name;file') + d.load_general_cfg() + eq(d.startup_edit.get(), 0) + eq(d.autosave.get(), 0) + eq(d.win_width.get(), '80') + eq(d.win_height.get(), '40') + eq(d.helplist.get(0, 'end'), ('name',)) + eq(d.user_helplist, [('name', 'file', '1')]) + def test_startup(self): - dialog.radio_startup_edit.invoke() + dialog.startup_editor_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '1'}}) + changes.clear() + dialog.startup_shell_on.invoke() + self.assertEqual(mainpage, + {'General': {'editor-on-startup': '0'}}) def test_autosave(self): - dialog.radio_save_auto.invoke() + dialog.save_auto_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '1'}}) + dialog.save_ask_on.invoke() + self.assertEqual(mainpage, {'General': {'autosave': '0'}}) def test_editor_size(self): - dialog.entry_win_height.insert(0, '1') + dialog.win_height_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'height': '140'}}) changes.clear() - dialog.entry_win_width.insert(0, '1') + dialog.win_width_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'width': '180'}}) - #def test_help_sources(self): pass # TODO + def test_source_selected(self): + d = dialog + d.set = d.set_add_delete_state + d.upc = d.update_help_changes + helplist = d.helplist + helplist.insert(0, 'source') + helplist.activate(0) + + helplist.focus_force() + helplist.see(0) + helplist.update() + x, y, dx, dy = helplist.bbox(0) + x += dx // 2 + y += dy // 2 + d.set.called = d.upc.called = 0 + helplist.event_generate('', x=x, y=y) + helplist.event_generate('', x=x, y=y) + self.assertEqual(helplist.get('anchor'), 'source') + self.assertTrue(d.set.called) + self.assertFalse(d.upc.called) + + def test_set_add_delete_state(self): + # Call with 0 items, 1 unselected item, 1 selected item. + eq = self.assertEqual + d = dialog + del d.set_add_delete_state # Unmask method. + sad = d.set_add_delete_state + h = d.helplist + + h.delete(0, 'end') + sad() + eq(d.button_helplist_edit['state'], DISABLED) + eq(d.button_helplist_remove['state'], DISABLED) + + h.insert(0, 'source') + sad() + eq(d.button_helplist_edit['state'], DISABLED) + eq(d.button_helplist_remove['state'], DISABLED) + + h.selection_set(0) + sad() + eq(d.button_helplist_edit['state'], NORMAL) + eq(d.button_helplist_remove['state'], NORMAL) + d.set_add_delete_state = Func() # Mask method. + + def test_helplist_item_add(self): + # Call without and twice with HelpSource result. + # Double call enables check on order. + eq = self.assertEqual + orig_helpsource = configdialog.HelpSource + hs = configdialog.HelpSource = Func(return_self=True) + d = dialog + d.helplist.delete(0, 'end') + d.user_helplist.clear() + d.set.called = d.upc.called = 0 + + hs.result = '' + d.helplist_item_add() + self.assertTrue(list(d.helplist.get(0, 'end')) == + d.user_helplist == []) + self.assertFalse(d.upc.called) + + hs.result = ('name1', 'file1') + d.helplist_item_add() + hs.result = ('name2', 'file2') + d.helplist_item_add() + eq(d.helplist.get(0, 'end'), ('name1', 'name2')) + eq(d.user_helplist, [('name1', 'file1'), ('name2', 'file2')]) + eq(d.upc.called, 2) + self.assertFalse(d.set.called) + + configdialog.HelpSource = orig_helpsource + + def test_helplist_item_edit(self): + # Call without and with HelpSource change. + eq = self.assertEqual + orig_helpsource = configdialog.HelpSource + hs = configdialog.HelpSource = Func(return_self=True) + d = dialog + d.helplist.delete(0, 'end') + d.helplist.insert(0, 'name1') + d.helplist.selection_set(0) + d.helplist.selection_anchor(0) + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.set.called = d.upc.called = 0 + + hs.result = '' + d.helplist_item_edit() + hs.result = ('name1', 'file1') + d.helplist_item_edit() + eq(d.helplist.get(0, 'end'), ('name1',)) + eq(d.user_helplist, [('name1', 'file1')]) + self.assertFalse(d.upc.called) + + hs.result = ('name2', 'file2') + d.helplist_item_edit() + eq(d.helplist.get(0, 'end'), ('name2',)) + eq(d.user_helplist, [('name2', 'file2')]) + self.assertTrue(d.upc.called == d.set.called == 1) + + configdialog.HelpSource = orig_helpsource + + def test_helplist_item_remove(self): + eq = self.assertEqual + d = dialog + d.helplist.delete(0, 'end') + d.helplist.insert(0, 'name1') + d.helplist.selection_set(0) + d.helplist.selection_anchor(0) + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.set.called = d.upc.called = 0 + + d.helplist_item_remove() + eq(d.helplist.get(0, 'end'), ()) + eq(d.user_helplist, []) + self.assertTrue(d.upc.called == d.set.called == 1) + + def test_update_help_changes(self): + d = dialog + del d.update_help_changes + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.user_helplist.append(('name2', 'file2')) + + d.update_help_changes() + self.assertEqual(mainpage['HelpFiles'], + {'1': 'name1;file1', '2': 'name2;file2'}) + d.update_help_changes = Func() class TestVarTrace(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst b/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst new file mode 100644 index 00000000000..f3dab0fd9e6 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst @@ -0,0 +1 @@ +IDLE: Add more tests for General tab. From webhook-mailer at python.org Wed Jul 26 21:41:29 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Thu, 27 Jul 2017 01:41:29 -0000 Subject: [Python-checkins] [3.6] bpo-31003: IDLE - Add more tests for General tab (GH-2859) (#2906) Message-ID: https://github.com/python/cpython/commit/0c4c65104c951c70f3a2a2fd1a45bdf6540f3a8e commit: 0c4c65104c951c70f3a2a2fd1a45bdf6540f3a8e branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-26T21:41:26-04:00 summary: [3.6] bpo-31003: IDLE - Add more tests for General tab (GH-2859) (#2906) * In configdialog: Document causal pathways in create_page_general. Move related functions to follow this. Simplify some attribute names. * In test_configdialog: Add tests for load and helplist functions. Coverage for the general tab is now complete, and 63% overall. (cherry picked from commit 2bc8f0e) files: A Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/mock_idle.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index f98af4600ee..daaa34459e2 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -160,7 +160,7 @@ def create_page_font_tab(self): corresponding aspect of the font sample on this page and highlight sample on highlight page. - Load_font_cfg initializes font vars and widgets from + Funtion load_font_cfg initializes font vars and widgets from idleConf entries and tk. Fontlist: mouse button 1 click or up or down key invoke @@ -470,7 +470,7 @@ def tem(event, elem=element): event.widget.winfo_toplevel().highlight_target.set(elem) text.tag_bind( self.theme_elements[element][0], '', tem) - text.config(state=DISABLED) + text['state'] = DISABLED self.frame_color_set = Frame(frame_custom, relief=SOLID, borderwidth=1) frame_fg_bg_toggle = Frame(frame_custom) button_set_color = Button( @@ -650,59 +650,61 @@ def create_page_keys(self): frames[1].pack(side=TOP, fill=X, expand=True, pady=2) return frame + def create_page_general(self): """Return frame of widgets for General tab. - Tk Variables: - win_width: Initial window width in characters. - win_height: Initial window height in characters. - startup_edit: Selector for opening in editor or shell mode. - autosave: Selector for save prompt popup when using Run. - - Methods: - load_general_config: - help_source_selected: Bound to list_help button release. - set_helplist_button_states: Toggle based on list. - helplist_item_edit: Command for button_helplist_edit. - helplist_item_add: Command for button_helplist_add. - helplist_item_remove: Command for button_helplist_remove. - update_user_help_changed_items: Fill in changes. + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + var_changed_var_name callback that adds option to changes. + + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. Widget Structure: (*) widgets bound to self frame frame_run: LabelFrame startup_title: Label - (*)radio_startup_edit: Radiobutton - startup_edit - (*)radio_startup_shell: Radiobutton - startup_edit + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit frame_save: LabelFrame run_save_title: Label - (*)radio_save_ask: Radiobutton - autosave - (*)radio_save_auto: Radiobutton - autosave + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave frame_win_size: LabelFrame win_size_title: Label win_width_title: Label - (*)entry_win_width: Entry - win_width + (*)win_width_int: Entry - win_width win_height_title: Label - (*)entry_win_height: Entry - win_height + (*)win_height_int: Entry - win_height frame_help: LabelFrame frame_helplist: Frame frame_helplist_buttons: Frame (*)button_helplist_edit (*)button_helplist_add (*)button_helplist_remove + (*)helplist: ListBox scroll_helplist: Scrollbar - (*)list_help: ListBox """ parent = self.parent - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) self.startup_edit = IntVar(parent) self.autosave = IntVar(parent) + self.win_width = StringVar(parent) + self.win_height = StringVar(parent) - #widget creation - #body + # Create widgets: + # body. frame = self.tab_pages.pages['General'].frame - #body section frames + # body section frames. frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Startup Preferences ') frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -710,41 +712,41 @@ def create_page_general(self): frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Additional Help Sources ') - #frame_run + # frame_run. startup_title = Label(frame_run, text='At Startup') - self.radio_startup_edit = Radiobutton( + self.startup_editor_on = Radiobutton( frame_run, variable=self.startup_edit, value=1, text="Open Edit Window") - self.radio_startup_shell = Radiobutton( + self.startup_shell_on = Radiobutton( frame_run, variable=self.startup_edit, value=0, text='Open Shell Window') - #frame_save + # frame_save. run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.radio_save_ask = Radiobutton( + self.save_ask_on = Radiobutton( frame_save, variable=self.autosave, value=0, text="Prompt to Save") - self.radio_save_auto = Radiobutton( + self.save_auto_on = Radiobutton( frame_save, variable=self.autosave, value=1, text='No Prompt') - #frame_win_size + # frame_win_size. win_size_title = Label( frame_win_size, text='Initial Window Size (in characters)') win_width_title = Label(frame_win_size, text='Width') - self.entry_win_width = Entry( + self.win_width_int = Entry( frame_win_size, textvariable=self.win_width, width=3) win_height_title = Label(frame_win_size, text='Height') - self.entry_win_height = Entry( + self.win_height_int = Entry( frame_win_size, textvariable=self.win_height, width=3) - #frame_help + # frame_help. frame_helplist = Frame(frame_help) frame_helplist_buttons = Frame(frame_helplist) - scroll_helplist = Scrollbar(frame_helplist) - self.list_help = Listbox( + self.helplist = Listbox( frame_helplist, height=5, takefocus=FALSE, exportselection=FALSE) - scroll_helplist.config(command=self.list_help.yview) - self.list_help.config(yscrollcommand=scroll_helplist.set) - self.list_help.bind('', self.help_source_selected) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) self.button_helplist_edit = Button( frame_helplist_buttons, text='Edit', state=DISABLED, width=8, command=self.helplist_item_edit) @@ -755,36 +757,146 @@ def create_page_general(self): frame_helplist_buttons, text='Remove', state=DISABLED, width=8, command=self.helplist_item_remove) - #widget packing - #body + # Pack widgets: + # body. frame_run.pack(side=TOP, padx=5, pady=5, fill=X) frame_save.pack(side=TOP, padx=5, pady=5, fill=X) frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - #frame_run + # frame_run. startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.radio_startup_shell.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.radio_startup_edit.pack(side=RIGHT, anchor=W, padx=5, pady=5) - #frame_save + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.radio_save_auto.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.radio_save_ask.pack(side=RIGHT, anchor=W, padx=5, pady=5) - #frame_win_size + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.entry_win_height.pack(side=RIGHT, anchor=E, padx=10, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.entry_win_width.pack(side=RIGHT, anchor=E, padx=10, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) win_width_title.pack(side=RIGHT, anchor=E, pady=5) - #frame_help + # frame_help. frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.list_help.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) self.button_helplist_add.pack(side=TOP, anchor=W) self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + return frame + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() + + def var_changed_startup_edit(self, *params): + "Store change to toggle for starting IDLE in the editor or shell." + value = self.startup_edit.get() + changes.add_option('main', 'General', 'editor-on-startup', value) + + def var_changed_autosave(self, *params): + "Store change to autosave." + value = self.autosave.get() + changes.add_option('main', 'General', 'autosave', value) + + def var_changed_win_width(self, *params): + "Store change to window width." + value = self.win_width.get() + changes.add_option('main', 'EditorWindow', 'width', value) + + def var_changed_win_height(self, *params): + "Store change to window height." + value = self.win_height.get() + changes.add_option('main', 'EditorWindow', 'height', value) + + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() + + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + + def helplist_item_add(self): + """Handle add button for the help list. + + Query for name and location of new help sources and add + them to the list. + """ + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() + + def helplist_item_edit(self): + """Handle edit button for the help list. + + Query with existing help source information and update + config if the values are changed. + """ + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected + + def helplist_item_remove(self): + """Handle remove button for the help list. + + Delete the help list item from config. + """ + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() + + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) + + def attach_var_callbacks(self): "Attach callbacks to variables that can be changed." self.font_size.trace_add('write', self.var_changed_font) @@ -917,26 +1029,6 @@ def var_changed_are_keys_builtin(self, *params): else: self.var_changed_custom_keys() - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) - - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) - - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) - - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) - def set_theme_type(self): """Set available screen options based on builtin or custom theme. @@ -956,26 +1048,26 @@ def set_theme_type(self): load_theme_cfg """ if self.is_builtin_theme.get(): - self.opt_menu_theme_builtin.config(state=NORMAL) - self.opt_menu_theme_custom.config(state=DISABLED) - self.button_delete_custom_theme.config(state=DISABLED) + self.opt_menu_theme_builtin['state'] = NORMAL + self.opt_menu_theme_custom['state'] = DISABLED + self.button_delete_custom_theme['state'] = DISABLED else: - self.opt_menu_theme_builtin.config(state=DISABLED) - self.radio_theme_custom.config(state=NORMAL) - self.opt_menu_theme_custom.config(state=NORMAL) - self.button_delete_custom_theme.config(state=NORMAL) + self.opt_menu_theme_builtin['state'] = DISABLED + self.radio_theme_custom['state'] = NORMAL + self.opt_menu_theme_custom['state'] = NORMAL + self.button_delete_custom_theme['state'] = NORMAL def set_keys_type(self): "Set available screen options based on builtin or custom key set." if self.are_keys_builtin.get(): - self.opt_menu_keys_builtin.config(state=NORMAL) - self.opt_menu_keys_custom.config(state=DISABLED) - self.button_delete_custom_keys.config(state=DISABLED) + self.opt_menu_keys_builtin['state'] = NORMAL + self.opt_menu_keys_custom['state'] = DISABLED + self.button_delete_custom_keys['state'] = DISABLED else: - self.opt_menu_keys_builtin.config(state=DISABLED) - self.radio_keys_custom.config(state=NORMAL) - self.opt_menu_keys_custom.config(state=NORMAL) - self.button_delete_custom_keys.config(state=NORMAL) + self.opt_menu_keys_builtin['state'] = DISABLED + self.radio_keys_custom['state'] = NORMAL + self.opt_menu_keys_custom['state'] = NORMAL + self.button_delete_custom_keys['state'] = NORMAL def get_new_keys(self): """Handle event to change key binding for selected line. @@ -1037,7 +1129,7 @@ def save_as_new_key_set(self): def keybinding_selected(self, event): "Activate button to assign new keys to selected action." - self.button_new_keys.config(state=NORMAL) + self.button_new_keys['state'] = NORMAL def create_new_key_set(self, new_key_set_name): """Create a new custom key set with the given name. @@ -1115,7 +1207,7 @@ def delete_custom_keys(self): item_list = idleConf.GetSectionList('user', 'keys') item_list.sort() if not item_list: - self.radio_keys_custom.config(state=DISABLED) + self.radio_keys_custom['state'] = DISABLED self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') else: self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) @@ -1164,7 +1256,7 @@ def delete_custom_theme(self): item_list = idleConf.GetSectionList('user', 'highlight') item_list.sort() if not item_list: - self.radio_theme_custom.config(state=DISABLED) + self.radio_theme_custom['state'] = DISABLED self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') else: self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) @@ -1303,12 +1395,12 @@ def set_highlight_target(self): load_theme_cfg """ if self.highlight_target.get() == 'Cursor': # bg not possible - self.radio_fg.config(state=DISABLED) - self.radio_bg.config(state=DISABLED) + self.radio_fg['state'] = DISABLED + self.radio_bg['state'] = DISABLED self.fg_bg_toggle.set(1) else: # Both fg and bg can be set. - self.radio_fg.config(state=NORMAL) - self.radio_bg.config(state=NORMAL) + self.radio_fg['state'] = NORMAL + self.radio_bg['state'] = NORMAL self.fg_bg_toggle.set(1) self.set_color_sample() @@ -1378,76 +1470,6 @@ def paint_theme_sample(self): self.highlight_sample.tag_config(element, **colors) self.set_color_sample() - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_helplist_button_states() - - def set_helplist_button_states(self): - "Toggle the state for the help list buttons based on list entries." - if self.list_help.size() < 1: # No entries in list. - self.button_helplist_edit.config(state=DISABLED) - self.button_helplist_remove.config(state=DISABLED) - else: # Some entries. - if self.list_help.curselection(): # There currently is a selection. - self.button_helplist_edit.config(state=NORMAL) - self.button_helplist_remove.config(state=NORMAL) - else: # There currently is not a selection. - self.button_helplist_edit.config(state=DISABLED) - self.button_helplist_remove.config(state=DISABLED) - - def helplist_item_add(self): - """Handle add button for the help list. - - Query for name and location of new help sources and add - them to the list. - """ - help_source = HelpSource(self, 'New Help Source', - ).result - if help_source: - self.user_helplist.append((help_source[0], help_source[1])) - self.list_help.insert(END, help_source[0]) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def helplist_item_edit(self): - """Handle edit button for the help list. - - Query with existing help source information and update - config if the values are changed. - """ - item_index = self.list_help.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.list_help.delete(item_index) - self.list_help.insert(item_index, new_help_source[0]) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def helplist_item_remove(self): - """Handle remove button for the help list. - - Delete the help list item from config. - """ - item_index = self.list_help.index(ANCHOR) - del(self.user_helplist[item_index]) - self.list_help.delete(item_index) - self.update_user_help_changed_items() - self.set_helplist_button_states() - - def update_user_help_changed_items(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) - def load_theme_cfg(self): """Load current configuration settings for the theme options. @@ -1481,7 +1503,7 @@ def load_theme_cfg(self): item_list = idleConf.GetSectionList('user', 'highlight') item_list.sort() if not item_list: - self.radio_theme_custom.config(state=DISABLED) + self.radio_theme_custom['state'] = DISABLED self.custom_theme.set('- no custom themes -') else: self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) @@ -1515,7 +1537,7 @@ def load_key_cfg(self): item_list = idleConf.GetSectionList('user', 'keys') item_list.sort() if not item_list: - self.radio_keys_custom.config(state=DISABLED) + self.radio_keys_custom['state'] = DISABLED self.custom_keys.set('- no custom keys -') else: self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) @@ -1531,25 +1553,6 @@ def load_key_cfg(self): keyset_name = idleConf.CurrentKeys() self.load_keys_list(keyset_name) - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=1, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - for help_item in self.user_helplist: - self.list_help.insert(END, help_item[0]) - self.set_helplist_button_states() - def load_configs(self): """Load configuration for each page. diff --git a/Lib/idlelib/idle_test/mock_idle.py b/Lib/idlelib/idle_test/mock_idle.py index 8f3147b1c5c..f279a52fd51 100644 --- a/Lib/idlelib/idle_test/mock_idle.py +++ b/Lib/idlelib/idle_test/mock_idle.py @@ -13,14 +13,16 @@ class Func: self.args - capture positional arguments. self.kwds - capture keyword arguments. self.result - return or raise value set in __init__. + self.return_self - return self instead, to mock query class return. Most common use will probably be to mock instance methods. Given class instance, can set and delete as instance attribute. Mock_tk.Var and Mbox_func are special variants of this. ''' - def __init__(self, result=None): + def __init__(self, result=None, return_self=False): self.called = 0 self.result = result + self.return_self = return_self self.args = None self.kwds = None def __call__(self, *args, **kwds): @@ -29,6 +31,8 @@ def __call__(self, *args, **kwds): self.kwds = kwds if isinstance(self.result, BaseException): raise self.result + elif self.return_self: + return self else: return self.result diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index ce02ae4a8e6..7296075fbec 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -1,16 +1,17 @@ """Test idlelib.configdialog. Half the class creates dialog, half works with user customizations. -Coverage: 46% just by creating dialog, 60% with current tests. +Coverage: 63%. """ -from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace +from idlelib import configdialog from test.support import requires requires('gui') -from tkinter import Tk, IntVar, BooleanVar import unittest from unittest import mock -import idlelib.config as config from idlelib.idle_test.mock_idle import Func +from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL +from idlelib import config +from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace # Tests should not depend on fortuitous user configurations. # They must not affect actual user .cfg files. @@ -226,27 +227,200 @@ def setUp(self): class GeneralTest(unittest.TestCase): + """Test that general tab widgets enable users to make changes. + + Test that widget actions set vars, that var changes add + options to changes and that helplist works correctly. + """ + @classmethod + def setUpClass(cls): + # Mask instance methods used by help functions. + d = dialog + d.set = d.set_add_delete_state = Func() + d.upc = d.update_help_changes = Func() + + @classmethod + def tearDownClass(cls): + d = dialog + del d.set, d.set_add_delete_state + del d.upc, d.update_help_changes + d.helplist.delete(0, 'end') + d.user_helplist.clear() def setUp(self): changes.clear() + def test_load_general_cfg(self): + # Set to wrong values, load, check right values. + eq = self.assertEqual + d = dialog + d.startup_edit.set(1) + d.autosave.set(1) + d.win_width.set(1) + d.win_height.set(1) + d.helplist.insert('end', 'bad') + d.user_helplist = ['bad', 'worse'] + idleConf.SetOption('main', 'HelpFiles', '1', 'name;file') + d.load_general_cfg() + eq(d.startup_edit.get(), 0) + eq(d.autosave.get(), 0) + eq(d.win_width.get(), '80') + eq(d.win_height.get(), '40') + eq(d.helplist.get(0, 'end'), ('name',)) + eq(d.user_helplist, [('name', 'file', '1')]) + def test_startup(self): - dialog.radio_startup_edit.invoke() + dialog.startup_editor_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '1'}}) + changes.clear() + dialog.startup_shell_on.invoke() + self.assertEqual(mainpage, + {'General': {'editor-on-startup': '0'}}) def test_autosave(self): - dialog.radio_save_auto.invoke() + dialog.save_auto_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '1'}}) + dialog.save_ask_on.invoke() + self.assertEqual(mainpage, {'General': {'autosave': '0'}}) def test_editor_size(self): - dialog.entry_win_height.insert(0, '1') + dialog.win_height_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'height': '140'}}) changes.clear() - dialog.entry_win_width.insert(0, '1') + dialog.win_width_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'width': '180'}}) - #def test_help_sources(self): pass # TODO + def test_source_selected(self): + d = dialog + d.set = d.set_add_delete_state + d.upc = d.update_help_changes + helplist = d.helplist + helplist.insert(0, 'source') + helplist.activate(0) + + helplist.focus_force() + helplist.see(0) + helplist.update() + x, y, dx, dy = helplist.bbox(0) + x += dx // 2 + y += dy // 2 + d.set.called = d.upc.called = 0 + helplist.event_generate('', x=x, y=y) + helplist.event_generate('', x=x, y=y) + self.assertEqual(helplist.get('anchor'), 'source') + self.assertTrue(d.set.called) + self.assertFalse(d.upc.called) + + def test_set_add_delete_state(self): + # Call with 0 items, 1 unselected item, 1 selected item. + eq = self.assertEqual + d = dialog + del d.set_add_delete_state # Unmask method. + sad = d.set_add_delete_state + h = d.helplist + + h.delete(0, 'end') + sad() + eq(d.button_helplist_edit['state'], DISABLED) + eq(d.button_helplist_remove['state'], DISABLED) + + h.insert(0, 'source') + sad() + eq(d.button_helplist_edit['state'], DISABLED) + eq(d.button_helplist_remove['state'], DISABLED) + + h.selection_set(0) + sad() + eq(d.button_helplist_edit['state'], NORMAL) + eq(d.button_helplist_remove['state'], NORMAL) + d.set_add_delete_state = Func() # Mask method. + + def test_helplist_item_add(self): + # Call without and twice with HelpSource result. + # Double call enables check on order. + eq = self.assertEqual + orig_helpsource = configdialog.HelpSource + hs = configdialog.HelpSource = Func(return_self=True) + d = dialog + d.helplist.delete(0, 'end') + d.user_helplist.clear() + d.set.called = d.upc.called = 0 + + hs.result = '' + d.helplist_item_add() + self.assertTrue(list(d.helplist.get(0, 'end')) == + d.user_helplist == []) + self.assertFalse(d.upc.called) + + hs.result = ('name1', 'file1') + d.helplist_item_add() + hs.result = ('name2', 'file2') + d.helplist_item_add() + eq(d.helplist.get(0, 'end'), ('name1', 'name2')) + eq(d.user_helplist, [('name1', 'file1'), ('name2', 'file2')]) + eq(d.upc.called, 2) + self.assertFalse(d.set.called) + + configdialog.HelpSource = orig_helpsource + + def test_helplist_item_edit(self): + # Call without and with HelpSource change. + eq = self.assertEqual + orig_helpsource = configdialog.HelpSource + hs = configdialog.HelpSource = Func(return_self=True) + d = dialog + d.helplist.delete(0, 'end') + d.helplist.insert(0, 'name1') + d.helplist.selection_set(0) + d.helplist.selection_anchor(0) + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.set.called = d.upc.called = 0 + + hs.result = '' + d.helplist_item_edit() + hs.result = ('name1', 'file1') + d.helplist_item_edit() + eq(d.helplist.get(0, 'end'), ('name1',)) + eq(d.user_helplist, [('name1', 'file1')]) + self.assertFalse(d.upc.called) + + hs.result = ('name2', 'file2') + d.helplist_item_edit() + eq(d.helplist.get(0, 'end'), ('name2',)) + eq(d.user_helplist, [('name2', 'file2')]) + self.assertTrue(d.upc.called == d.set.called == 1) + + configdialog.HelpSource = orig_helpsource + + def test_helplist_item_remove(self): + eq = self.assertEqual + d = dialog + d.helplist.delete(0, 'end') + d.helplist.insert(0, 'name1') + d.helplist.selection_set(0) + d.helplist.selection_anchor(0) + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.set.called = d.upc.called = 0 + + d.helplist_item_remove() + eq(d.helplist.get(0, 'end'), ()) + eq(d.user_helplist, []) + self.assertTrue(d.upc.called == d.set.called == 1) + + def test_update_help_changes(self): + d = dialog + del d.update_help_changes + d.user_helplist.clear() + d.user_helplist.append(('name1', 'file1')) + d.user_helplist.append(('name2', 'file2')) + + d.update_help_changes() + self.assertEqual(mainpage['HelpFiles'], + {'1': 'name1;file1', '2': 'name2;file2'}) + d.update_help_changes = Func() class TestVarTrace(unittest.TestCase): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst b/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst new file mode 100644 index 00000000000..f3dab0fd9e6 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-25-01-28-35.bpo-31003.bYINVH.rst @@ -0,0 +1 @@ +IDLE: Add more tests for General tab. From webhook-mailer at python.org Wed Jul 26 23:15:22 2017 From: webhook-mailer at python.org (Steve Dower) Date: Thu, 27 Jul 2017 03:15:22 -0000 Subject: [Python-checkins] bpo-9566: Change HANDLE argument parsing to unsigned in msvcrtmodule.c (#2904) Message-ID: https://github.com/python/cpython/commit/a80e985c493d2ab9df0832c99d9ddb798d2e66cf commit: a80e985c493d2ab9df0832c99d9ddb798d2e66cf branch: master author: Segev Finer committer: Steve Dower date: 2017-07-26T20:15:18-07:00 summary: bpo-9566: Change HANDLE argument parsing to unsigned in msvcrtmodule.c (#2904) files: M PC/clinic/msvcrtmodule.c.h M PC/msvcrtmodule.c diff --git a/PC/clinic/msvcrtmodule.c.h b/PC/clinic/msvcrtmodule.c.h index debd9b08bdd..6d7648a101d 100644 --- a/PC/clinic/msvcrtmodule.c.h +++ b/PC/clinic/msvcrtmodule.c.h @@ -123,7 +123,7 @@ msvcrt_open_osfhandle(PyObject *module, PyObject **args, Py_ssize_t nargs) int flags; long _return_value; - if (!_PyArg_ParseStack(args, nargs, ""_Py_PARSE_INTPTR"i:open_osfhandle", + if (!_PyArg_ParseStack(args, nargs, ""_Py_PARSE_UINTPTR"i:open_osfhandle", &handle, &flags)) { goto exit; } @@ -437,7 +437,7 @@ msvcrt_CrtSetReportFile(PyObject *module, PyObject **args, Py_ssize_t nargs) void *file; void *_return_value; - if (!_PyArg_ParseStack(args, nargs, "i"_Py_PARSE_INTPTR":CrtSetReportFile", + if (!_PyArg_ParseStack(args, nargs, "i"_Py_PARSE_UINTPTR":CrtSetReportFile", &type, &file)) { goto exit; } @@ -569,4 +569,4 @@ msvcrt_SetErrorMode(PyObject *module, PyObject *arg) #ifndef MSVCRT_SET_ERROR_MODE_METHODDEF #define MSVCRT_SET_ERROR_MODE_METHODDEF #endif /* !defined(MSVCRT_SET_ERROR_MODE_METHODDEF) */ -/*[clinic end generated code: output=e86cf578e7f1ffd2 input=a9049054013a1b77]*/ +/*[clinic end generated code: output=66787cb934b8a3c2 input=a9049054013a1b77]*/ diff --git a/PC/msvcrtmodule.c b/PC/msvcrtmodule.c index fa9ad9dfeba..81d2db37903 100644 --- a/PC/msvcrtmodule.c +++ b/PC/msvcrtmodule.c @@ -35,7 +35,7 @@ /*[python input] class HANDLE_converter(CConverter): type = 'void *' - format_unit = '"_Py_PARSE_INTPTR"' + format_unit = '"_Py_PARSE_UINTPTR"' class HANDLE_return_converter(CReturnConverter): type = 'void *' @@ -65,7 +65,7 @@ class wchar_t_return_converter(CReturnConverter): data.return_conversion.append( 'return_value = PyUnicode_FromOrdinal(_return_value);\n') [python start generated code]*/ -/*[python end generated code: output=da39a3ee5e6b4b0d input=2b25dc89e9e59534]*/ +/*[python end generated code: output=da39a3ee5e6b4b0d input=d102511df3cda2eb]*/ /*[clinic input] module msvcrt From solipsis at pitrou.net Thu Jul 27 05:10:18 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Thu, 27 Jul 2017 09:10:18 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=67 Message-ID: <20170727091017.58776.8582E9C34E8E7321@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [0, 0, -2] memory blocks, sum=-2 test_multiprocessing_spawn leaked [0, 44, 0] references, sum=44 test_multiprocessing_spawn leaked [0, 21, -2] memory blocks, sum=19 test_multiprocessing_spawn leaked [0, 2, 0] file descriptors, sum=2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogQL0epR', '--timeout', '7200'] From webhook-mailer at python.org Thu Jul 27 05:21:29 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 09:21:29 -0000 Subject: [Python-checkins] bpo-31028: Fix test_pydoc when run directly (#2864) Message-ID: https://github.com/python/cpython/commit/fd46561167af6cd697191dd7ebb8c2fef5ad6493 commit: fd46561167af6cd697191dd7ebb8c2fef5ad6493 branch: master author: Victor Stinner committer: GitHub date: 2017-07-27T11:21:26+02:00 summary: bpo-31028: Fix test_pydoc when run directly (#2864) * bpo-31028: Fix test_pydoc when run directly Fix get_pydoc_link() of test_pydoc to fix "./python Lib/test/test_pydoc.py": get the absolute path to __file__ to prevent relative directories. * Use realpath() instead of abspath() files: M Lib/test/test_pydoc.py diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py index 6813d153e1e..d68ab5595e8 100644 --- a/Lib/test/test_pydoc.py +++ b/Lib/test/test_pydoc.py @@ -360,7 +360,7 @@ def get_pydoc_html(module): def get_pydoc_link(module): "Returns a documentation web link of a module" dirname = os.path.dirname - basedir = dirname(dirname(__file__)) + basedir = dirname(dirname(os.path.realpath(__file__))) doc = pydoc.TextDoc() loc = doc.getdocloc(module, basedir=basedir) return loc From webhook-mailer at python.org Thu Jul 27 05:24:40 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Thu, 27 Jul 2017 09:24:40 -0000 Subject: [Python-checkins] bpo-30814, bpo-30876: Add new import test files to projects. (#2851) Message-ID: https://github.com/python/cpython/commit/d5ed47dea25e04a3a144eddf99a4ac4a29242dbc commit: d5ed47dea25e04a3a144eddf99a4ac4a29242dbc branch: master author: Serhiy Storchaka committer: GitHub date: 2017-07-27T12:24:36+03:00 summary: bpo-30814, bpo-30876: Add new import test files to projects. (#2851) files: M Makefile.pre.in M PCbuild/lib.pyproj diff --git a/Makefile.pre.in b/Makefile.pre.in index 5602c165463..98934916578 100644 --- a/Makefile.pre.in +++ b/Makefile.pre.in @@ -1204,6 +1204,8 @@ LIBSUBDIRS= tkinter tkinter/test tkinter/test/test_tkinter \ test/test_import/data \ test/test_import/data/circular_imports \ test/test_import/data/circular_imports/subpkg \ + test/test_import/data/package \ + test/test_import/data/package2 \ test/test_importlib/namespace_pkgs \ test/test_importlib/namespace_pkgs/both_portions \ test/test_importlib/namespace_pkgs/both_portions/foo \ diff --git a/PCbuild/lib.pyproj b/PCbuild/lib.pyproj index 73927b33f72..273d5ef7529 100644 --- a/PCbuild/lib.pyproj +++ b/PCbuild/lib.pyproj @@ -1127,6 +1127,10 @@ + + + + @@ -1786,6 +1790,8 @@ + + From webhook-mailer at python.org Thu Jul 27 06:16:03 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Thu, 27 Jul 2017 10:16:03 -0000 Subject: [Python-checkins] [3.6] bpo-30814, bpo-30876: Add new import test files to projects. (GH-2851). (#2912) Message-ID: https://github.com/python/cpython/commit/95b16a9705d6b4d31c016c014e59744fc33d53ea commit: 95b16a9705d6b4d31c016c014e59744fc33d53ea branch: 3.6 author: Serhiy Storchaka committer: GitHub date: 2017-07-27T13:15:59+03:00 summary: [3.6] bpo-30814, bpo-30876: Add new import test files to projects. (GH-2851). (#2912) (cherry picked from commit d5ed47dea25e04a3a144eddf99a4ac4a29242dbc) files: M Makefile.pre.in diff --git a/Makefile.pre.in b/Makefile.pre.in index 82e830727ef..93a2bab6d98 100644 --- a/Makefile.pre.in +++ b/Makefile.pre.in @@ -1206,6 +1206,8 @@ LIBSUBDIRS= tkinter tkinter/test tkinter/test/test_tkinter \ test/test_import/data \ test/test_import/data/circular_imports \ test/test_import/data/circular_imports/subpkg \ + test/test_import/data/package \ + test/test_import/data/package2 \ test/test_importlib/namespace_pkgs \ test/test_importlib/namespace_pkgs/both_portions \ test/test_importlib/namespace_pkgs/both_portions/foo \ From webhook-mailer at python.org Thu Jul 27 06:16:23 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Thu, 27 Jul 2017 10:16:23 -0000 Subject: [Python-checkins] [3.5] bpo-30876: Add new import test files to projects. (GH-2851). (#2913) Message-ID: https://github.com/python/cpython/commit/f9fbed19a964e55ee703005823d8a7408f83d7f4 commit: f9fbed19a964e55ee703005823d8a7408f83d7f4 branch: 3.5 author: Serhiy Storchaka committer: GitHub date: 2017-07-27T13:16:21+03:00 summary: [3.5] bpo-30876: Add new import test files to projects. (GH-2851). (#2913) (cherry picked from commit d5ed47dea25e04a3a144eddf99a4ac4a29242dbc) files: M Makefile.pre.in diff --git a/Makefile.pre.in b/Makefile.pre.in index 144c1f8629b..df791a88eee 100644 --- a/Makefile.pre.in +++ b/Makefile.pre.in @@ -1187,6 +1187,7 @@ LIBSUBDIRS= tkinter tkinter/test tkinter/test/test_tkinter \ test/test_import/data \ test/test_import/data/circular_imports \ test/test_import/data/circular_imports/subpkg \ + test/test_import/data/package2 \ test/test_importlib/namespace_pkgs \ test/test_importlib/namespace_pkgs/both_portions \ test/test_importlib/namespace_pkgs/both_portions/foo \ From webhook-mailer at python.org Thu Jul 27 10:55:58 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 14:55:58 -0000 Subject: [Python-checkins] bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) Message-ID: https://github.com/python/cpython/commit/12953ffe12ac781332b384c36b25d12216b1db62 commit: 12953ffe12ac781332b384c36b25d12216b1db62 branch: master author: Victor Stinner committer: GitHub date: 2017-07-27T16:55:54+02:00 summary: bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) There is a bug in FreeBSD CURRENT with 64-bit dev_t. Skip the test if dev_t is larger than 32-bit, until the bug is fixed in FreeBSD CURRENT. files: M Lib/test/test_posix.py diff --git a/Lib/test/test_posix.py b/Lib/test/test_posix.py index 22b050d4d72..148c0641a99 100644 --- a/Lib/test/test_posix.py +++ b/Lib/test/test_posix.py @@ -540,6 +540,10 @@ def test_makedev(self): self.assertRaises(TypeError, posix.minor) self.assertRaises((ValueError, OverflowError), posix.minor, -1) + if sys.platform.startswith('freebsd') and dev >= 0x1_0000_0000: + self.skipTest("bpo-31044: on FreeBSD CURRENT, minor() truncates " + "64-bit dev to 32-bit") + self.assertEqual(posix.makedev(major, minor), dev) self.assertRaises(TypeError, posix.makedev, float(major), minor) self.assertRaises(TypeError, posix.makedev, major, float(minor)) From webhook-mailer at python.org Thu Jul 27 12:05:47 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 16:05:47 -0000 Subject: [Python-checkins] bpo-31028: Fix test_pydoc when run directly (#2864) (#2911) Message-ID: https://github.com/python/cpython/commit/fd6736d17901e539d6a9ddf50a9927a3a97a9c06 commit: fd6736d17901e539d6a9ddf50a9927a3a97a9c06 branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-27T18:05:44+02:00 summary: bpo-31028: Fix test_pydoc when run directly (#2864) (#2911) * bpo-31028: Fix test_pydoc when run directly Fix get_pydoc_link() of test_pydoc to fix "./python Lib/test/test_pydoc.py": get the absolute path to __file__ to prevent relative directories. * Use realpath() instead of abspath() (cherry picked from commit fd46561167af6cd697191dd7ebb8c2fef5ad6493) files: M Lib/test/test_pydoc.py diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py index 7188d0af75a..83aad0b3b4a 100644 --- a/Lib/test/test_pydoc.py +++ b/Lib/test/test_pydoc.py @@ -257,7 +257,7 @@ def get_pydoc_html(module): def get_pydoc_link(module): "Returns a documentation web link of a module" dirname = os.path.dirname - basedir = dirname(dirname(__file__)) + basedir = dirname(dirname(os.path.realpath(__file__))) doc = pydoc.TextDoc() loc = doc.getdocloc(module, basedir=basedir) return loc From webhook-mailer at python.org Thu Jul 27 12:05:49 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 16:05:49 -0000 Subject: [Python-checkins] bpo-31028: Fix test_pydoc when run directly (#2864) (#2910) Message-ID: https://github.com/python/cpython/commit/d019c7965d411b2132f68ed6bb33e538b4d9eba3 commit: d019c7965d411b2132f68ed6bb33e538b4d9eba3 branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-27T18:05:46+02:00 summary: bpo-31028: Fix test_pydoc when run directly (#2864) (#2910) * bpo-31028: Fix test_pydoc when run directly Fix get_pydoc_link() of test_pydoc to fix "./python Lib/test/test_pydoc.py": get the absolute path to __file__ to prevent relative directories. * Use realpath() instead of abspath() (cherry picked from commit fd46561167af6cd697191dd7ebb8c2fef5ad6493) files: M Lib/test/test_pydoc.py diff --git a/Lib/test/test_pydoc.py b/Lib/test/test_pydoc.py index ed438d5664c..0383a673240 100644 --- a/Lib/test/test_pydoc.py +++ b/Lib/test/test_pydoc.py @@ -361,7 +361,7 @@ def get_pydoc_html(module): def get_pydoc_link(module): "Returns a documentation web link of a module" dirname = os.path.dirname - basedir = dirname(dirname(__file__)) + basedir = dirname(dirname(os.path.realpath(__file__))) doc = pydoc.TextDoc() loc = doc.getdocloc(module, basedir=basedir) return loc From webhook-mailer at python.org Thu Jul 27 12:42:14 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 16:42:14 -0000 Subject: [Python-checkins] bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) (#2917) Message-ID: https://github.com/python/cpython/commit/54cb3400e500f99bd57a0273aa7ef84ffd37558e commit: 54cb3400e500f99bd57a0273aa7ef84ffd37558e branch: 3.6 author: Victor Stinner committer: GitHub date: 2017-07-27T18:42:11+02:00 summary: bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) (#2917) There is a bug in FreeBSD CURRENT with 64-bit dev_t. Skip the test if dev_t is larger than 32-bit, until the bug is fixed in FreeBSD CURRENT. (cherry picked from commit 12953ffe12ac781332b384c36b25d12216b1db62) files: M Lib/test/test_posix.py diff --git a/Lib/test/test_posix.py b/Lib/test/test_posix.py index a6e2fed302f..9df3206324f 100644 --- a/Lib/test/test_posix.py +++ b/Lib/test/test_posix.py @@ -478,6 +478,10 @@ def test_makedev(self): self.assertRaises(TypeError, posix.minor) self.assertRaises((ValueError, OverflowError), posix.minor, -1) + if sys.platform.startswith('freebsd') and dev >= 0x1_0000_0000: + self.skipTest("bpo-31044: on FreeBSD CURRENT, minor() truncates " + "64-bit dev to 32-bit") + self.assertEqual(posix.makedev(major, minor), dev) self.assertRaises(TypeError, posix.makedev, float(major), minor) self.assertRaises(TypeError, posix.makedev, major, float(minor)) From webhook-mailer at python.org Thu Jul 27 12:44:46 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Thu, 27 Jul 2017 16:44:46 -0000 Subject: [Python-checkins] [2.7] bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) (#2918) Message-ID: https://github.com/python/cpython/commit/c2f7fb61511456c62877592988b31714cb8ba266 commit: c2f7fb61511456c62877592988b31714cb8ba266 branch: 2.7 author: Victor Stinner committer: GitHub date: 2017-07-27T18:44:43+02:00 summary: [2.7] bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) (#2918) * bpo-31044: Skip test_posix.test_makedev() on FreeBSD (#2915) There is a bug in FreeBSD CURRENT with 64-bit dev_t. Skip the test if dev_t is larger than 32-bit, until the bug is fixed in FreeBSD CURRENT. (cherry picked from commit 12953ffe12ac781332b384c36b25d12216b1db62) * Fix syntax for Python 2.7 files: M Lib/test/test_posix.py diff --git a/Lib/test/test_posix.py b/Lib/test/test_posix.py index f1626b717fc..bce4e21e992 100644 --- a/Lib/test/test_posix.py +++ b/Lib/test/test_posix.py @@ -287,6 +287,10 @@ def test_makedev(self): self.assertRaises(TypeError, posix.minor) self.assertRaises((ValueError, OverflowError), posix.minor, -1) + if sys.platform.startswith('freebsd') and dev >= 0x100000000: + self.skipTest("bpo-31044: on FreeBSD CURRENT, minor() truncates " + "64-bit dev to 32-bit") + self.assertEqual(posix.makedev(major, minor), dev) self.assertEqual(posix.makedev(int(major), int(minor)), dev) self.assertEqual(posix.makedev(long(major), long(minor)), dev) From webhook-mailer at python.org Thu Jul 27 15:50:06 2017 From: webhook-mailer at python.org (larryhastings) Date: Thu, 27 Jul 2017 19:50:06 -0000 Subject: [Python-checkins] [3.5] bpo-31036: use an existing Misc/NEWS rather than trying to use blurb (#2874) Message-ID: https://github.com/python/cpython/commit/3de144890ad3bc50694368a1b33be6d7f3a780b3 commit: 3de144890ad3bc50694368a1b33be6d7f3a780b3 branch: 3.5 author: Ned Deily committer: larryhastings date: 2017-07-27T12:50:04-07:00 summary: [3.5] bpo-31036: use an existing Misc/NEWS rather than trying to use blurb (#2874) * bpo-31036: use an existing Misc/NEWS rather than trying to use blurb * bpo-31036: avoid echoing comments files: M Doc/Makefile diff --git a/Doc/Makefile b/Doc/Makefile index 5075b0264d0..04da82fea96 100644 --- a/Doc/Makefile +++ b/Doc/Makefile @@ -40,7 +40,19 @@ help: build: -mkdir -p build - $(BLURB) merge -f build/NEWS +# Look first for a Misc/NEWS file (building from a source release tarball +# or old repo) and use that, otherwise look for a Misc/NEWS.d directory +# (building from a newer repo) and use blurb to generate the NEWS file. + @if [ -f ../Misc/NEWS ] ; then \ + echo "Using existing Misc/NEWS file"; \ + cp ../Misc/NEWS build/NEWS; \ + elif [ -d ../Misc/NEWS.d ]; then \ + echo "Building NEWS from Misc/NEWS.d with blurb"; \ + $(BLURB) merge -f build/NEWS; \ + else \ + echo "Neither Misc/NEWS.d nor Misc/NEWS found; cannot build docs"; \ + exit 1; \ + fi $(SPHINXBUILD) $(ALLSPHINXOPTS) @echo From webhook-mailer at python.org Thu Jul 27 18:28:06 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Thu, 27 Jul 2017 22:28:06 -0000 Subject: [Python-checkins] bpo-31060: IDLE: Finish regrouping ConfigDialog methods (#2908) Message-ID: https://github.com/python/cpython/commit/b1660800f4f519dbfab9e5a4ad3eae1cfabab3ed commit: b1660800f4f519dbfab9e5a4ad3eae1cfabab3ed branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-27T18:28:01-04:00 summary: bpo-31060: IDLE: Finish regrouping ConfigDialog methods (#2908) Finish resorting the 72 ConfigDialog methods into 7 groups that represent the dialog, action buttons, and font, highlight, keys, general, and extension pages. This will help with continuing to add tests and improve the pages. It will enable splitting ConfigDialog into 6 or 7 more comprehensible classes. files: A Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst M Lib/idlelib/configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index daaa34459e2..e359ec24cd3 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -30,7 +30,6 @@ changes = ConfigChanges() - class ConfigDialog(Toplevel): """Config dialog for IDLE. """ @@ -112,6 +111,58 @@ def create_widgets(self): self.create_page_extensions() self.create_action_buttons().pack(side=BOTTOM) + def load_configs(self): + """Load configuration for each page. + + Load configuration from default and user config files and populate + the widgets on the config dialog pages. + + Methods: + load_font_cfg + load_tab_cfg + load_theme_cfg + load_key_cfg + load_general_cfg + """ + self.load_font_cfg() + self.load_tab_cfg() + self.load_theme_cfg() + self.load_key_cfg() + self.load_general_cfg() + # note: extension page handled separately + + def attach_var_callbacks(self): + "Attach callbacks to variables that can be changed." + self.font_size.trace_add('write', self.var_changed_font) + self.font_name.trace_add('write', self.var_changed_font) + self.font_bold.trace_add('write', self.var_changed_font) + self.space_num.trace_add('write', self.var_changed_space_num) + self.color.trace_add('write', self.var_changed_color) + self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) + self.custom_theme.trace_add('write', self.var_changed_custom_theme) + self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) + self.highlight_target.trace_add('write', self.var_changed_highlight_target) + self.keybinding.trace_add('write', self.var_changed_keybinding) + self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) + self.custom_keys.trace_add('write', self.var_changed_custom_keys) + self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) + self.win_width.trace_add('write', self.var_changed_win_width) + self.win_height.trace_add('write', self.var_changed_win_height) + self.startup_edit.trace_add('write', self.var_changed_startup_edit) + self.autosave.trace_add('write', self.var_changed_autosave) + + def remove_var_callbacks(self): + "Remove callbacks to prevent memory leaks." + for var in ( + self.font_size, self.font_name, self.font_bold, + self.space_num, self.color, self.builtin_theme, + self.custom_theme, self.is_builtin_theme, self.highlight_target, + self.keybinding, self.builtin_keys, self.custom_keys, + self.are_keys_builtin, self.win_width, self.win_height, + self.startup_edit, self.autosave,): + var.trace_remove('write', var.trace_info()[0][1]) + + def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -150,6 +201,50 @@ def create_action_buttons(self): buttons.pack(side=BOTTOM) return outer + def ok(self): + """Apply config changes, then dismiss dialog. + + Methods: + apply + destroy: inherited + """ + self.apply() + self.destroy() + + def apply(self): + """Apply config changes and leave dialog open. + + Methods: + deactivate_current_config + save_all_changed_extensions + activate_config_changes + """ + self.deactivate_current_config() + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + + def cancel(self): + """Dismiss config dialog. + + Methods: + destroy: inherited + """ + self.destroy() + + def help(self): + """Create textview for config dialog help. + + Attrbutes accessed: + tab_pages + + Methods: + view_text: Method from textview module. + """ + page = self.tab_pages._current_page + view_text(self, title='Help for IDLE preferences', + text=help_common+help_pages.get(page, '')) + def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. @@ -299,16 +394,6 @@ def load_font_cfg(self): # Set font weight. self.font_bold.set(font_bold) - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - def var_changed_font(self, *params): """Store changes to font attributes. @@ -324,6 +409,16 @@ def var_changed_font(self, *params): changes.add_option('main', 'EditorWindow', 'font-bold', value) self.set_samples() + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + def set_samples(self, event=None): """Update update both screen samples with the font settings. @@ -531,466 +626,551 @@ def tem(event, elem=element): self.new_custom_theme.pack(side=TOP, fill=X, pady=5) return frame - def create_page_keys(self): - """Return frame of widgets for Keys tab. + def load_theme_cfg(self): + """Load current configuration settings for the theme options. - Tk Variables: - builtin_keys: Menu variable for built-in keybindings. - custom_keys: Menu variable for custom keybindings. - are_keys_builtin: Selector for built-in or custom keybindings. - keybinding: Action/key bindings. + Based on the is_builtin_theme toggle, the theme is set as + either builtin or custom and the initial widget values + reflect the current settings from idleConf. - Methods: - load_key_config: Set table. - load_keys_list: Reload active set. - keybinding_selected: Bound to list_bindings button release. - get_new_keys: Command for button_new_keys. - get_new_keys_name: Call popup. - create_new_key_set: Combine active keyset and changes. - set_keys_type: Command for are_keys_builtin. - delete_custom_keys: Command for button_delete_custom_keys. - save_as_new_key_set: Command for button_save_custom_keys. - save_new_key_set: Save to idleConf.userCfg['keys'] (is function). - deactivate_current_config: Remove keys bindings in editors. + Attributes updated: + is_builtin_theme: Set from idleConf. + opt_menu_theme_builtin: List of default themes from idleConf. + opt_menu_theme_custom: List of custom themes from idleConf. + radio_theme_custom: Disabled if there are no custom themes. + custom_theme: Message with additional information. + opt_menu_highlight_target: Create menu from self.theme_elements. - Widget Structure: (*) widgets bound to self - frame - frame_custom: LabelFrame - frame_target: Frame - target_title: Label - scroll_target_y: Scrollbar - scroll_target_x: Scrollbar - (*)list_bindings: ListBox - (*)button_new_keys: Button - frame_key_sets: LabelFrame - frames[0]: Frame - (*)radio_keys_builtin: Radiobutton - are_keys_builtin - (*)radio_keys_custom: Radiobutton - are_keys_builtin - (*)opt_menu_keys_builtin: DynOptionMenu - builtin_keys - (*)opt_menu_keys_custom: DynOptionMenu - custom_keys - (*)new_custom_keys: Label - frames[1]: Frame - (*)button_delete_custom_keys: Button - button_save_custom_keys: Button + Methods: + set_theme_type + paint_theme_sample + set_highlight_target """ - parent = self.parent - self.builtin_keys = StringVar(parent) - self.custom_keys = StringVar(parent) - self.are_keys_builtin = BooleanVar(parent) - self.keybinding = StringVar(parent) + # Set current theme type radiobutton. + self.is_builtin_theme.set(idleConf.GetOption( + 'main', 'Theme', 'default', type='bool', default=1)) + # Set current theme. + current_option = idleConf.CurrentTheme() + # Load available theme option menus. + if self.is_builtin_theme.get(): # Default theme selected. + item_list = idleConf.GetSectionList('default', 'highlight') + item_list.sort() + self.opt_menu_theme_builtin.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + if not item_list: + self.radio_theme_custom['state'] = DISABLED + self.custom_theme.set('- no custom themes -') + else: + self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) + else: # User theme selected. + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + self.opt_menu_theme_custom.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('default', 'highlight') + item_list.sort() + self.opt_menu_theme_builtin.SetMenu(item_list, item_list[0]) + self.set_theme_type() + # Load theme element option menu. + theme_names = list(self.theme_elements.keys()) + theme_names.sort(key=lambda x: self.theme_elements[x][1]) + self.opt_menu_highlight_target.SetMenu(theme_names, theme_names[0]) + self.paint_theme_sample() + self.set_highlight_target() - ##widget creation - #body frame - frame = self.tab_pages.pages['Keys'].frame - #body section frames - frame_custom = LabelFrame( - frame, borderwidth=2, relief=GROOVE, - text=' Custom Key Bindings ') - frame_key_sets = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Key Set ') - #frame_custom - frame_target = Frame(frame_custom) - target_title = Label(frame_target, text='Action - Key(s)') - scroll_target_y = Scrollbar(frame_target) - scroll_target_x = Scrollbar(frame_target, orient=HORIZONTAL) - self.list_bindings = Listbox( - frame_target, takefocus=FALSE, exportselection=FALSE) - self.list_bindings.bind('', self.keybinding_selected) - scroll_target_y.config(command=self.list_bindings.yview) - scroll_target_x.config(command=self.list_bindings.xview) - self.list_bindings.config(yscrollcommand=scroll_target_y.set) - self.list_bindings.config(xscrollcommand=scroll_target_x.set) - self.button_new_keys = Button( - frame_custom, text='Get New Keys for Selection', - command=self.get_new_keys, state=DISABLED) - #frame_key_sets - frames = [Frame(frame_key_sets, padx=2, pady=2, borderwidth=0) - for i in range(2)] - self.radio_keys_builtin = Radiobutton( - frames[0], variable=self.are_keys_builtin, value=1, - command=self.set_keys_type, text='Use a Built-in Key Set') - self.radio_keys_custom = Radiobutton( - frames[0], variable=self.are_keys_builtin, value=0, - command=self.set_keys_type, text='Use a Custom Key Set') - self.opt_menu_keys_builtin = DynOptionMenu( - frames[0], self.builtin_keys, None, command=None) - self.opt_menu_keys_custom = DynOptionMenu( - frames[0], self.custom_keys, None, command=None) - self.button_delete_custom_keys = Button( - frames[1], text='Delete Custom Key Set', - command=self.delete_custom_keys) - button_save_custom_keys = Button( - frames[1], text='Save as New Custom Key Set', - command=self.save_as_new_key_set) - self.new_custom_keys = Label(frames[0], bd=2) + def var_changed_builtin_theme(self, *params): + """Process new builtin theme selection. - ##widget packing - #body - frame_custom.pack(side=BOTTOM, padx=5, pady=5, expand=TRUE, fill=BOTH) - frame_key_sets.pack(side=BOTTOM, padx=5, pady=5, fill=BOTH) - #frame_custom - self.button_new_keys.pack(side=BOTTOM, fill=X, padx=5, pady=5) - frame_target.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) - #frame target - frame_target.columnconfigure(0, weight=1) - frame_target.rowconfigure(1, weight=1) - target_title.grid(row=0, column=0, columnspan=2, sticky=W) - self.list_bindings.grid(row=1, column=0, sticky=NSEW) - scroll_target_y.grid(row=1, column=1, sticky=NS) - scroll_target_x.grid(row=2, column=0, sticky=EW) - #frame_key_sets - self.radio_keys_builtin.grid(row=0, column=0, sticky=W+NS) - self.radio_keys_custom.grid(row=1, column=0, sticky=W+NS) - self.opt_menu_keys_builtin.grid(row=0, column=1, sticky=NSEW) - self.opt_menu_keys_custom.grid(row=1, column=1, sticky=NSEW) - self.new_custom_keys.grid(row=0, column=2, sticky=NSEW, padx=5, pady=5) - self.button_delete_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) - button_save_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) - frames[0].pack(side=TOP, fill=BOTH, expand=True) - frames[1].pack(side=TOP, fill=X, expand=True, pady=2) - return frame + Add the changed theme's name to the changed_items and recreate + the sample with the values from the selected theme. + """ + old_themes = ('IDLE Classic', 'IDLE New') + value = self.builtin_theme.get() + if value not in old_themes: + if idleConf.GetOption('main', 'Theme', 'name') not in old_themes: + changes.add_option('main', 'Theme', 'name', old_themes[0]) + changes.add_option('main', 'Theme', 'name2', value) + self.new_custom_theme.config(text='New theme, see Help', + fg='#500000') + else: + changes.add_option('main', 'Theme', 'name', value) + changes.add_option('main', 'Theme', 'name2', '') + self.new_custom_theme.config(text='', fg='black') + self.paint_theme_sample() + def var_changed_custom_theme(self, *params): + """Process new custom theme selection. - def create_page_general(self): - """Return frame of widgets for General tab. + If a new custom theme is selected, add the name to the + changed_items and apply the theme to the sample. + """ + value = self.custom_theme.get() + if value != '- no custom themes -': + changes.add_option('main', 'Theme', 'name', value) + self.paint_theme_sample() - Enable users to provisionally change general options. Function - load_general_cfg intializes tk variables and helplist using - idleConf. Radiobuttons startup_shell_on and startup_editor_on - set var startup_edit. Radiobuttons save_ask_on and save_auto_on - set var autosave. Entry boxes win_width_int and win_height_int - set var win_width and win_height. Setting var_name invokes the - var_changed_var_name callback that adds option to changes. + def var_changed_is_builtin_theme(self, *params): + """Process toggle between builtin and custom theme. - Helplist: load_general_cfg loads list user_helplist with - name, position pairs and copies names to listbox helplist. - Clicking a name invokes help_source selected. Clicking - button_helplist_name invokes helplist_item_name, which also - changes user_helplist. These functions all call - set_add_delete_state. All but load call update_help_changes to - rewrite changes['main']['HelpFiles']. + Update the default toggle value and apply the newly + selected theme type. + """ + value = self.is_builtin_theme.get() + changes.add_option('main', 'Theme', 'default', value) + if value: + self.var_changed_builtin_theme() + else: + self.var_changed_custom_theme() - Widget Structure: (*) widgets bound to self - frame - frame_run: LabelFrame - startup_title: Label - (*)startup_editor_on: Radiobutton - startup_edit - (*)startup_shell_on: Radiobutton - startup_edit - frame_save: LabelFrame - run_save_title: Label - (*)save_ask_on: Radiobutton - autosave - (*)save_auto_on: Radiobutton - autosave - frame_win_size: LabelFrame - win_size_title: Label - win_width_title: Label - (*)win_width_int: Entry - win_width - win_height_title: Label - (*)win_height_int: Entry - win_height - frame_help: LabelFrame - frame_helplist: Frame - frame_helplist_buttons: Frame - (*)button_helplist_edit - (*)button_helplist_add - (*)button_helplist_remove - (*)helplist: ListBox - scroll_helplist: Scrollbar + def var_changed_color(self, *params): + "Process change to color choice." + self.on_new_color_set() + + def var_changed_highlight_target(self, *params): + "Process selection of new target tag for highlighting." + self.set_highlight_target() + + def set_theme_type(self): + """Set available screen options based on builtin or custom theme. + + Attributes accessed: + is_builtin_theme + + Attributes updated: + opt_menu_theme_builtin + opt_menu_theme_custom + button_delete_custom_theme + radio_theme_custom + + Called from: + handler for radio_theme_builtin and radio_theme_custom + delete_custom_theme + create_new_theme + load_theme_cfg """ - parent = self.parent - self.startup_edit = IntVar(parent) - self.autosave = IntVar(parent) - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) + if self.is_builtin_theme.get(): + self.opt_menu_theme_builtin['state'] = NORMAL + self.opt_menu_theme_custom['state'] = DISABLED + self.button_delete_custom_theme['state'] = DISABLED + else: + self.opt_menu_theme_builtin['state'] = DISABLED + self.radio_theme_custom['state'] = NORMAL + self.opt_menu_theme_custom['state'] = NORMAL + self.button_delete_custom_theme['state'] = NORMAL - # Create widgets: - # body. - frame = self.tab_pages.pages['General'].frame - # body section frames. - frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Startup Preferences ') - frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' autosave Preferences ') - frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) - frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Additional Help Sources ') - # frame_run. - startup_title = Label(frame_run, text='At Startup') - self.startup_editor_on = Radiobutton( - frame_run, variable=self.startup_edit, value=1, - text="Open Edit Window") - self.startup_shell_on = Radiobutton( - frame_run, variable=self.startup_edit, value=0, - text='Open Shell Window') - # frame_save. - run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.save_ask_on = Radiobutton( - frame_save, variable=self.autosave, value=0, - text="Prompt to Save") - self.save_auto_on = Radiobutton( - frame_save, variable=self.autosave, value=1, - text='No Prompt') - # frame_win_size. - win_size_title = Label( - frame_win_size, text='Initial Window Size (in characters)') - win_width_title = Label(frame_win_size, text='Width') - self.win_width_int = Entry( - frame_win_size, textvariable=self.win_width, width=3) - win_height_title = Label(frame_win_size, text='Height') - self.win_height_int = Entry( - frame_win_size, textvariable=self.win_height, width=3) - # frame_help. - frame_helplist = Frame(frame_help) - frame_helplist_buttons = Frame(frame_helplist) - self.helplist = Listbox( - frame_helplist, height=5, takefocus=FALSE, - exportselection=FALSE) - scroll_helplist = Scrollbar(frame_helplist) - scroll_helplist['command'] = self.helplist.yview - self.helplist['yscrollcommand'] = scroll_helplist.set - self.helplist.bind('', self.help_source_selected) - self.button_helplist_edit = Button( - frame_helplist_buttons, text='Edit', state=DISABLED, - width=8, command=self.helplist_item_edit) - self.button_helplist_add = Button( - frame_helplist_buttons, text='Add', - width=8, command=self.helplist_item_add) - self.button_helplist_remove = Button( - frame_helplist_buttons, text='Remove', state=DISABLED, - width=8, command=self.helplist_item_remove) + def get_color(self): + """Handle button to select a new color for the target tag. - # Pack widgets: - # body. - frame_run.pack(side=TOP, padx=5, pady=5, fill=X) - frame_save.pack(side=TOP, padx=5, pady=5, fill=X) - frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) - frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - # frame_run. - startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_save. - run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_win_size. - win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_width_title.pack(side=RIGHT, anchor=E, pady=5) - # frame_help. - frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) - frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) - self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) - self.button_helplist_add.pack(side=TOP, anchor=W) - self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + If a new color is selected while using a builtin theme, a + name must be supplied to create a custom theme. + + Attributes accessed: + highlight_target + frame_color_set + is_builtin_theme + + Attributes updated: + color + + Methods: + get_new_theme_name + create_new_theme + """ + target = self.highlight_target.get() + prev_color = self.frame_color_set.cget('bg') + rgbTuplet, color_string = tkColorChooser.askcolor( + parent=self, title='Pick new color for : '+target, + initialcolor=prev_color) + if color_string and (color_string != prev_color): + # User didn't cancel and they chose a new color. + if self.is_builtin_theme.get(): # Current theme is a built-in. + message = ('Your changes will be saved as a new Custom Theme. ' + 'Enter a name for your new Custom Theme below.') + new_theme = self.get_new_theme_name(message) + if not new_theme: # User cancelled custom theme creation. + return + else: # Create new custom theme based on previously active theme. + self.create_new_theme(new_theme) + self.color.set(color_string) + else: # Current theme is user defined. + self.color.set(color_string) + + def on_new_color_set(self): + "Display sample of new color selection on the dialog." + new_color=self.color.get() + self.frame_color_set.config(bg=new_color) # Set sample. + plane ='foreground' if self.fg_bg_toggle.get() else 'background' + sample_element = self.theme_elements[self.highlight_target.get()][0] + self.highlight_sample.tag_config(sample_element, **{plane:new_color}) + theme = self.custom_theme.get() + theme_element = sample_element + '-' + plane + changes.add_option('highlight', theme, theme_element, new_color) + + def get_new_theme_name(self, message): + "Return name of new theme from query popup." + used_names = (idleConf.GetSectionList('user', 'highlight') + + idleConf.GetSectionList('default', 'highlight')) + new_theme = SectionName( + self, 'New Custom Theme', message, used_names).result + return new_theme + + def save_as_new_theme(self): + """Prompt for new theme name and create the theme. + + Methods: + get_new_theme_name + create_new_theme + """ + new_theme_name = self.get_new_theme_name('New Theme Name:') + if new_theme_name: + self.create_new_theme(new_theme_name) + + def create_new_theme(self, new_theme_name): + """Create a new custom theme with the given name. - return frame + Create the new theme based on the previously active theme + with the current changes applied. Once it is saved, then + activate the new theme. - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=0, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - self.helplist.delete(0, 'end') - for help_item in self.user_helplist: - self.helplist.insert(END, help_item[0]) - self.set_add_delete_state() + Attributes accessed: + builtin_theme + custom_theme - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) + Attributes updated: + opt_menu_theme_custom + is_builtin_theme - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) + Method: + save_new_theme + set_theme_type + """ + if self.is_builtin_theme.get(): + theme_type = 'default' + theme_name = self.builtin_theme.get() + else: + theme_type = 'user' + theme_name = self.custom_theme.get() + new_theme = idleConf.GetThemeDict(theme_type, theme_name) + # Apply any of the old theme's unsaved changes to the new theme. + if theme_name in changes['highlight']: + theme_changes = changes['highlight'][theme_name] + for element in theme_changes: + new_theme[element] = theme_changes[element] + # Save the new theme. + self.save_new_theme(new_theme_name, new_theme) + # Change GUI over to the new theme. + custom_theme_list = idleConf.GetSectionList('user', 'highlight') + custom_theme_list.sort() + self.opt_menu_theme_custom.SetMenu(custom_theme_list, new_theme_name) + self.is_builtin_theme.set(0) + self.set_theme_type() - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) + def set_highlight_target(self): + """Set fg/bg toggle and color based on highlight tag target. - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) + Instance variables accessed: + highlight_target - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_add_delete_state() + Attributes updated: + radio_fg + radio_bg + fg_bg_toggle - def set_add_delete_state(self): - "Toggle the state for the help list buttons based on list entries." - if self.helplist.size() < 1: # No entries in list. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - else: # Some entries. - if self.helplist.curselection(): # There currently is a selection. - self.button_helplist_edit['state'] = NORMAL - self.button_helplist_remove['state'] = NORMAL - else: # There currently is not a selection. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED + Methods: + set_color_sample - def helplist_item_add(self): - """Handle add button for the help list. + Called from: + var_changed_highlight_target + load_theme_cfg + """ + if self.highlight_target.get() == 'Cursor': # bg not possible + self.radio_fg['state'] = DISABLED + self.radio_bg['state'] = DISABLED + self.fg_bg_toggle.set(1) + else: # Both fg and bg can be set. + self.radio_fg['state'] = NORMAL + self.radio_bg['state'] = NORMAL + self.fg_bg_toggle.set(1) + self.set_color_sample() - Query for name and location of new help sources and add - them to the list. + def set_color_sample_binding(self, *args): + """Change color sample based on foreground/background toggle. + + Methods: + set_color_sample """ - help_source = HelpSource(self, 'New Help Source').result - if help_source: - self.user_helplist.append(help_source) - self.helplist.insert(END, help_source[0]) - self.update_help_changes() + self.set_color_sample() - def helplist_item_edit(self): - """Handle edit button for the help list. + def set_color_sample(self): + """Set the color of the frame background to reflect the selected target. - Query with existing help source information and update - config if the values are changed. + Instance variables accessed: + theme_elements + highlight_target + fg_bg_toggle + highlight_sample + + Attributes updated: + frame_color_set """ - item_index = self.helplist.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.helplist.delete(item_index) - self.helplist.insert(item_index, new_help_source[0]) - self.update_help_changes() - self.set_add_delete_state() # Selected will be un-selected + # Set the color sample area. + tag = self.theme_elements[self.highlight_target.get()][0] + plane = 'foreground' if self.fg_bg_toggle.get() else 'background' + color = self.highlight_sample.tag_cget(tag, plane) + self.frame_color_set.config(bg=color) - def helplist_item_remove(self): - """Handle remove button for the help list. + def paint_theme_sample(self): + """Apply the theme colors to each element tag in the sample text. - Delete the help list item from config. + Instance attributes accessed: + theme_elements + is_builtin_theme + builtin_theme + custom_theme + + Attributes updated: + highlight_sample: Set the tag elements to the theme. + + Methods: + set_color_sample + + Called from: + var_changed_builtin_theme + var_changed_custom_theme + load_theme_cfg """ - item_index = self.helplist.index(ANCHOR) - del(self.user_helplist[item_index]) - self.helplist.delete(item_index) - self.update_help_changes() - self.set_add_delete_state() + if self.is_builtin_theme.get(): # Default theme + theme = self.builtin_theme.get() + else: # User theme + theme = self.custom_theme.get() + for element_title in self.theme_elements: + element = self.theme_elements[element_title][0] + colors = idleConf.GetHighlight(theme, element) + if element == 'cursor': # Cursor sample needs special painting. + colors['background'] = idleConf.GetHighlight( + theme, 'normal', fgBg='bg') + # Handle any unsaved changes to this theme. + if theme in changes['highlight']: + theme_dict = changes['highlight'][theme] + if element + '-foreground' in theme_dict: + colors['foreground'] = theme_dict[element + '-foreground'] + if element + '-background' in theme_dict: + colors['background'] = theme_dict[element + '-background'] + self.highlight_sample.tag_config(element, **colors) + self.set_color_sample() - def update_help_changes(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) + def save_new_theme(self, theme_name, theme): + """Save a newly created theme to idleConf. + + theme_name - string, the name of the new theme + theme - dictionary containing the new theme + """ + if not idleConf.userCfg['highlight'].has_section(theme_name): + idleConf.userCfg['highlight'].add_section(theme_name) + for element in theme: + value = theme[element] + idleConf.userCfg['highlight'].SetOption(theme_name, element, value) + + def delete_custom_theme(self): + """Handle event to delete custom theme. + + The current theme is deactivated and the default theme is + activated. The custom theme is permanently removed from + the config file. + Attributes accessed: + custom_theme + + Attributes updated: + radio_theme_custom + opt_menu_theme_custom + is_builtin_theme + builtin_theme + + Methods: + deactivate_current_config + save_all_changed_extensions + activate_config_changes + set_theme_type + """ + theme_name = self.custom_theme.get() + delmsg = 'Are you sure you wish to delete the theme %r ?' + if not tkMessageBox.askyesno( + 'Delete Theme', delmsg % theme_name, parent=self): + return + self.deactivate_current_config() + # Remove theme from changes, config, and file. + changes.delete_section('highlight', theme_name) + # Reload user theme list. + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + if not item_list: + self.radio_theme_custom['state'] = DISABLED + self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') + else: + self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) + # Revert to default theme. + self.is_builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'default')) + self.builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'name')) + # User can't back out of these changes, they must be applied now. + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + self.set_theme_type() - def attach_var_callbacks(self): - "Attach callbacks to variables that can be changed." - self.font_size.trace_add('write', self.var_changed_font) - self.font_name.trace_add('write', self.var_changed_font) - self.font_bold.trace_add('write', self.var_changed_font) - self.space_num.trace_add('write', self.var_changed_space_num) - self.color.trace_add('write', self.var_changed_color) - self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) - self.custom_theme.trace_add('write', self.var_changed_custom_theme) - self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) - self.highlight_target.trace_add('write', self.var_changed_highlight_target) - self.keybinding.trace_add('write', self.var_changed_keybinding) - self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) - self.custom_keys.trace_add('write', self.var_changed_custom_keys) - self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) - self.win_width.trace_add('write', self.var_changed_win_width) - self.win_height.trace_add('write', self.var_changed_win_height) - self.startup_edit.trace_add('write', self.var_changed_startup_edit) - self.autosave.trace_add('write', self.var_changed_autosave) - def remove_var_callbacks(self): - "Remove callbacks to prevent memory leaks." - for var in ( - self.font_size, self.font_name, self.font_bold, - self.space_num, self.color, self.builtin_theme, - self.custom_theme, self.is_builtin_theme, self.highlight_target, - self.keybinding, self.builtin_keys, self.custom_keys, - self.are_keys_builtin, self.win_width, self.win_height, - self.startup_edit, self.autosave,): - var.trace_remove('write', var.trace_info()[0][1]) + def create_page_keys(self): + """Return frame of widgets for Keys tab. - def var_changed_color(self, *params): - "Process change to color choice." - self.on_new_color_set() + Tk Variables: + builtin_keys: Menu variable for built-in keybindings. + custom_keys: Menu variable for custom keybindings. + are_keys_builtin: Selector for built-in or custom keybindings. + keybinding: Action/key bindings. - def var_changed_builtin_theme(self, *params): - """Process new builtin theme selection. + Methods: + load_key_config: Set table. + load_keys_list: Reload active set. + keybinding_selected: Bound to list_bindings button release. + get_new_keys: Command for button_new_keys. + get_new_keys_name: Call popup. + create_new_key_set: Combine active keyset and changes. + set_keys_type: Command for are_keys_builtin. + delete_custom_keys: Command for button_delete_custom_keys. + save_as_new_key_set: Command for button_save_custom_keys. + save_new_key_set: Save to idleConf.userCfg['keys'] (is function). + deactivate_current_config: Remove keys bindings in editors. - Add the changed theme's name to the changed_items and recreate - the sample with the values from the selected theme. + Widget Structure: (*) widgets bound to self + frame + frame_custom: LabelFrame + frame_target: Frame + target_title: Label + scroll_target_y: Scrollbar + scroll_target_x: Scrollbar + (*)list_bindings: ListBox + (*)button_new_keys: Button + frame_key_sets: LabelFrame + frames[0]: Frame + (*)radio_keys_builtin: Radiobutton - are_keys_builtin + (*)radio_keys_custom: Radiobutton - are_keys_builtin + (*)opt_menu_keys_builtin: DynOptionMenu - builtin_keys + (*)opt_menu_keys_custom: DynOptionMenu - custom_keys + (*)new_custom_keys: Label + frames[1]: Frame + (*)button_delete_custom_keys: Button + button_save_custom_keys: Button """ - old_themes = ('IDLE Classic', 'IDLE New') - value = self.builtin_theme.get() - if value not in old_themes: - if idleConf.GetOption('main', 'Theme', 'name') not in old_themes: - changes.add_option('main', 'Theme', 'name', old_themes[0]) - changes.add_option('main', 'Theme', 'name2', value) - self.new_custom_theme.config(text='New theme, see Help', - fg='#500000') - else: - changes.add_option('main', 'Theme', 'name', value) - changes.add_option('main', 'Theme', 'name2', '') - self.new_custom_theme.config(text='', fg='black') - self.paint_theme_sample() + parent = self.parent + self.builtin_keys = StringVar(parent) + self.custom_keys = StringVar(parent) + self.are_keys_builtin = BooleanVar(parent) + self.keybinding = StringVar(parent) - def var_changed_custom_theme(self, *params): - """Process new custom theme selection. + ##widget creation + #body frame + frame = self.tab_pages.pages['Keys'].frame + #body section frames + frame_custom = LabelFrame( + frame, borderwidth=2, relief=GROOVE, + text=' Custom Key Bindings ') + frame_key_sets = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Key Set ') + #frame_custom + frame_target = Frame(frame_custom) + target_title = Label(frame_target, text='Action - Key(s)') + scroll_target_y = Scrollbar(frame_target) + scroll_target_x = Scrollbar(frame_target, orient=HORIZONTAL) + self.list_bindings = Listbox( + frame_target, takefocus=FALSE, exportselection=FALSE) + self.list_bindings.bind('', self.keybinding_selected) + scroll_target_y.config(command=self.list_bindings.yview) + scroll_target_x.config(command=self.list_bindings.xview) + self.list_bindings.config(yscrollcommand=scroll_target_y.set) + self.list_bindings.config(xscrollcommand=scroll_target_x.set) + self.button_new_keys = Button( + frame_custom, text='Get New Keys for Selection', + command=self.get_new_keys, state=DISABLED) + #frame_key_sets + frames = [Frame(frame_key_sets, padx=2, pady=2, borderwidth=0) + for i in range(2)] + self.radio_keys_builtin = Radiobutton( + frames[0], variable=self.are_keys_builtin, value=1, + command=self.set_keys_type, text='Use a Built-in Key Set') + self.radio_keys_custom = Radiobutton( + frames[0], variable=self.are_keys_builtin, value=0, + command=self.set_keys_type, text='Use a Custom Key Set') + self.opt_menu_keys_builtin = DynOptionMenu( + frames[0], self.builtin_keys, None, command=None) + self.opt_menu_keys_custom = DynOptionMenu( + frames[0], self.custom_keys, None, command=None) + self.button_delete_custom_keys = Button( + frames[1], text='Delete Custom Key Set', + command=self.delete_custom_keys) + button_save_custom_keys = Button( + frames[1], text='Save as New Custom Key Set', + command=self.save_as_new_key_set) + self.new_custom_keys = Label(frames[0], bd=2) - If a new custom theme is selected, add the name to the - changed_items and apply the theme to the sample. - """ - value = self.custom_theme.get() - if value != '- no custom themes -': - changes.add_option('main', 'Theme', 'name', value) - self.paint_theme_sample() + ##widget packing + #body + frame_custom.pack(side=BOTTOM, padx=5, pady=5, expand=TRUE, fill=BOTH) + frame_key_sets.pack(side=BOTTOM, padx=5, pady=5, fill=BOTH) + #frame_custom + self.button_new_keys.pack(side=BOTTOM, fill=X, padx=5, pady=5) + frame_target.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) + #frame target + frame_target.columnconfigure(0, weight=1) + frame_target.rowconfigure(1, weight=1) + target_title.grid(row=0, column=0, columnspan=2, sticky=W) + self.list_bindings.grid(row=1, column=0, sticky=NSEW) + scroll_target_y.grid(row=1, column=1, sticky=NS) + scroll_target_x.grid(row=2, column=0, sticky=EW) + #frame_key_sets + self.radio_keys_builtin.grid(row=0, column=0, sticky=W+NS) + self.radio_keys_custom.grid(row=1, column=0, sticky=W+NS) + self.opt_menu_keys_builtin.grid(row=0, column=1, sticky=NSEW) + self.opt_menu_keys_custom.grid(row=1, column=1, sticky=NSEW) + self.new_custom_keys.grid(row=0, column=2, sticky=NSEW, padx=5, pady=5) + self.button_delete_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) + button_save_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) + frames[0].pack(side=TOP, fill=BOTH, expand=True) + frames[1].pack(side=TOP, fill=X, expand=True, pady=2) + return frame - def var_changed_is_builtin_theme(self, *params): - """Process toggle between builtin and custom theme. + def load_key_cfg(self): + "Load current configuration settings for the keybinding options." + # Set current keys type radiobutton. + self.are_keys_builtin.set(idleConf.GetOption( + 'main', 'Keys', 'default', type='bool', default=1)) + # Set current keys. + current_option = idleConf.CurrentKeys() + # Load available keyset option menus. + if self.are_keys_builtin.get(): # Default theme selected. + item_list = idleConf.GetSectionList('default', 'keys') + item_list.sort() + self.opt_menu_keys_builtin.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + if not item_list: + self.radio_keys_custom['state'] = DISABLED + self.custom_keys.set('- no custom keys -') + else: + self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) + else: # User key set selected. + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + self.opt_menu_keys_custom.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('default', 'keys') + item_list.sort() + self.opt_menu_keys_builtin.SetMenu(item_list, idleConf.default_keys()) + self.set_keys_type() + # Load keyset element list. + keyset_name = idleConf.CurrentKeys() + self.load_keys_list(keyset_name) - Update the default toggle value and apply the newly - selected theme type. - """ - value = self.is_builtin_theme.get() - changes.add_option('main', 'Theme', 'default', value) - if value: - self.var_changed_builtin_theme() - else: - self.var_changed_custom_theme() - def var_changed_highlight_target(self, *params): - "Process selection of new target tag for highlighting." - self.set_highlight_target() - def var_changed_keybinding(self, *params): - "Store change to a keybinding." - value = self.keybinding.get() - key_set = self.custom_keys.get() - event = self.list_bindings.get(ANCHOR).split()[0] - if idleConf.IsCoreBinding(event): - changes.add_option('keys', key_set, event, value) - else: # Event is an extension binding. - ext_name = idleConf.GetExtnNameForEvent(event) - ext_keybind_section = ext_name + '_cfgBindings' - changes.add_option('extensions', ext_keybind_section, event, value) def var_changed_builtin_keys(self, *params): "Process selection of builtin key set." @@ -1016,46 +1196,30 @@ def var_changed_builtin_keys(self, *params): def var_changed_custom_keys(self, *params): "Process selection of custom key set." value = self.custom_keys.get() - if value != '- no custom keys -': - changes.add_option('main', 'Keys', 'name', value) - self.load_keys_list(value) - - def var_changed_are_keys_builtin(self, *params): - "Process toggle between builtin key set and custom key set." - value = self.are_keys_builtin.get() - changes.add_option('main', 'Keys', 'default', value) - if value: - self.var_changed_builtin_keys() - else: - self.var_changed_custom_keys() - - def set_theme_type(self): - """Set available screen options based on builtin or custom theme. - - Attributes accessed: - is_builtin_theme - - Attributes updated: - opt_menu_theme_builtin - opt_menu_theme_custom - button_delete_custom_theme - radio_theme_custom + if value != '- no custom keys -': + changes.add_option('main', 'Keys', 'name', value) + self.load_keys_list(value) - Called from: - handler for radio_theme_builtin and radio_theme_custom - delete_custom_theme - create_new_theme - load_theme_cfg - """ - if self.is_builtin_theme.get(): - self.opt_menu_theme_builtin['state'] = NORMAL - self.opt_menu_theme_custom['state'] = DISABLED - self.button_delete_custom_theme['state'] = DISABLED + def var_changed_are_keys_builtin(self, *params): + "Process toggle between builtin key set and custom key set." + value = self.are_keys_builtin.get() + changes.add_option('main', 'Keys', 'default', value) + if value: + self.var_changed_builtin_keys() else: - self.opt_menu_theme_builtin['state'] = DISABLED - self.radio_theme_custom['state'] = NORMAL - self.opt_menu_theme_custom['state'] = NORMAL - self.button_delete_custom_theme['state'] = NORMAL + self.var_changed_custom_keys() + + def var_changed_keybinding(self, *params): + "Store change to a keybinding." + value = self.keybinding.get() + key_set = self.custom_keys.get() + event = self.list_bindings.get(ANCHOR).split()[0] + if idleConf.IsCoreBinding(event): + changes.add_option('keys', key_set, event, value) + else: # Event is an extension binding. + ext_name = idleConf.GetExtnNameForEvent(event) + ext_keybind_section = ext_name + '_cfgBindings' + changes.add_option('extensions', ext_keybind_section, event, value) def set_keys_type(self): "Set available screen options based on builtin or custom key set." @@ -1183,489 +1347,329 @@ def load_keys_list(self, keyset_name): if bind_name in changes['keys'][keyset_name]: key = changes['keys'][keyset_name][bind_name] self.list_bindings.insert(END, bind_name+' - '+key) - if reselect: - self.list_bindings.see(list_index) - self.list_bindings.select_set(list_index) - self.list_bindings.select_anchor(list_index) - - def delete_custom_keys(self): - """Handle event to delete a custom key set. - - Applying the delete deactivates the current configuration and - reverts to the default. The custom key set is permanently - deleted from the config file. - """ - keyset_name=self.custom_keys.get() - delmsg = 'Are you sure you wish to delete the key set %r ?' - if not tkMessageBox.askyesno( - 'Delete Key Set', delmsg % keyset_name, parent=self): - return - self.deactivate_current_config() - # Remove key set from changes, config, and file. - changes.delete_section('keys', keyset_name) - # Reload user key set list. - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - if not item_list: - self.radio_keys_custom['state'] = DISABLED - self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') - else: - self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) - # Revert to default key set. - self.are_keys_builtin.set(idleConf.defaultCfg['main'] - .Get('Keys', 'default')) - self.builtin_keys.set(idleConf.defaultCfg['main'].Get('Keys', 'name') - or idleConf.default_keys()) - # User can't back out of these changes, they must be applied now. - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - self.set_keys_type() - - def delete_custom_theme(self): - """Handle event to delete custom theme. - - The current theme is deactivated and the default theme is - activated. The custom theme is permanently removed from - the config file. - - Attributes accessed: - custom_theme - - Attributes updated: - radio_theme_custom - opt_menu_theme_custom - is_builtin_theme - builtin_theme - - Methods: - deactivate_current_config - save_all_changed_extensions - activate_config_changes - set_theme_type - """ - theme_name = self.custom_theme.get() - delmsg = 'Are you sure you wish to delete the theme %r ?' - if not tkMessageBox.askyesno( - 'Delete Theme', delmsg % theme_name, parent=self): - return - self.deactivate_current_config() - # Remove theme from changes, config, and file. - changes.delete_section('highlight', theme_name) - # Reload user theme list. - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - if not item_list: - self.radio_theme_custom['state'] = DISABLED - self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') - else: - self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) - # Revert to default theme. - self.is_builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'default')) - self.builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'name')) - # User can't back out of these changes, they must be applied now. - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - self.set_theme_type() - - def get_color(self): - """Handle button to select a new color for the target tag. - - If a new color is selected while using a builtin theme, a - name must be supplied to create a custom theme. - - Attributes accessed: - highlight_target - frame_color_set - is_builtin_theme - - Attributes updated: - color - - Methods: - get_new_theme_name - create_new_theme - """ - target = self.highlight_target.get() - prev_color = self.frame_color_set.cget('bg') - rgbTuplet, color_string = tkColorChooser.askcolor( - parent=self, title='Pick new color for : '+target, - initialcolor=prev_color) - if color_string and (color_string != prev_color): - # User didn't cancel and they chose a new color. - if self.is_builtin_theme.get(): # Current theme is a built-in. - message = ('Your changes will be saved as a new Custom Theme. ' - 'Enter a name for your new Custom Theme below.') - new_theme = self.get_new_theme_name(message) - if not new_theme: # User cancelled custom theme creation. - return - else: # Create new custom theme based on previously active theme. - self.create_new_theme(new_theme) - self.color.set(color_string) - else: # Current theme is user defined. - self.color.set(color_string) - - def on_new_color_set(self): - "Display sample of new color selection on the dialog." - new_color=self.color.get() - self.frame_color_set.config(bg=new_color) # Set sample. - plane ='foreground' if self.fg_bg_toggle.get() else 'background' - sample_element = self.theme_elements[self.highlight_target.get()][0] - self.highlight_sample.tag_config(sample_element, **{plane:new_color}) - theme = self.custom_theme.get() - theme_element = sample_element + '-' + plane - changes.add_option('highlight', theme, theme_element, new_color) - - def get_new_theme_name(self, message): - "Return name of new theme from query popup." - used_names = (idleConf.GetSectionList('user', 'highlight') + - idleConf.GetSectionList('default', 'highlight')) - new_theme = SectionName( - self, 'New Custom Theme', message, used_names).result - return new_theme - - def save_as_new_theme(self): - """Prompt for new theme name and create the theme. - - Methods: - get_new_theme_name - create_new_theme - """ - new_theme_name = self.get_new_theme_name('New Theme Name:') - if new_theme_name: - self.create_new_theme(new_theme_name) - - def create_new_theme(self, new_theme_name): - """Create a new custom theme with the given name. - - Create the new theme based on the previously active theme - with the current changes applied. Once it is saved, then - activate the new theme. - - Attributes accessed: - builtin_theme - custom_theme - - Attributes updated: - opt_menu_theme_custom - is_builtin_theme - - Method: - save_new_theme - set_theme_type - """ - if self.is_builtin_theme.get(): - theme_type = 'default' - theme_name = self.builtin_theme.get() - else: - theme_type = 'user' - theme_name = self.custom_theme.get() - new_theme = idleConf.GetThemeDict(theme_type, theme_name) - # Apply any of the old theme's unsaved changes to the new theme. - if theme_name in changes['highlight']: - theme_changes = changes['highlight'][theme_name] - for element in theme_changes: - new_theme[element] = theme_changes[element] - # Save the new theme. - self.save_new_theme(new_theme_name, new_theme) - # Change GUI over to the new theme. - custom_theme_list = idleConf.GetSectionList('user', 'highlight') - custom_theme_list.sort() - self.opt_menu_theme_custom.SetMenu(custom_theme_list, new_theme_name) - self.is_builtin_theme.set(0) - self.set_theme_type() - - def set_highlight_target(self): - """Set fg/bg toggle and color based on highlight tag target. - - Instance variables accessed: - highlight_target - - Attributes updated: - radio_fg - radio_bg - fg_bg_toggle - - Methods: - set_color_sample - - Called from: - var_changed_highlight_target - load_theme_cfg - """ - if self.highlight_target.get() == 'Cursor': # bg not possible - self.radio_fg['state'] = DISABLED - self.radio_bg['state'] = DISABLED - self.fg_bg_toggle.set(1) - else: # Both fg and bg can be set. - self.radio_fg['state'] = NORMAL - self.radio_bg['state'] = NORMAL - self.fg_bg_toggle.set(1) - self.set_color_sample() + if reselect: + self.list_bindings.see(list_index) + self.list_bindings.select_set(list_index) + self.list_bindings.select_anchor(list_index) - def set_color_sample_binding(self, *args): - """Change color sample based on foreground/background toggle. + def save_new_key_set(self, keyset_name, keyset): + """Save a newly created core key set. - Methods: - set_color_sample + keyset_name - string, the name of the new key set + keyset - dictionary containing the new key set """ - self.set_color_sample() - - def set_color_sample(self): - """Set the color of the frame background to reflect the selected target. + if not idleConf.userCfg['keys'].has_section(keyset_name): + idleConf.userCfg['keys'].add_section(keyset_name) + for event in keyset: + value = keyset[event] + idleConf.userCfg['keys'].SetOption(keyset_name, event, value) - Instance variables accessed: - theme_elements - highlight_target - fg_bg_toggle - highlight_sample + def delete_custom_keys(self): + """Handle event to delete a custom key set. - Attributes updated: - frame_color_set + Applying the delete deactivates the current configuration and + reverts to the default. The custom key set is permanently + deleted from the config file. """ - # Set the color sample area. - tag = self.theme_elements[self.highlight_target.get()][0] - plane = 'foreground' if self.fg_bg_toggle.get() else 'background' - color = self.highlight_sample.tag_cget(tag, plane) - self.frame_color_set.config(bg=color) - - def paint_theme_sample(self): - """Apply the theme colors to each element tag in the sample text. + keyset_name=self.custom_keys.get() + delmsg = 'Are you sure you wish to delete the key set %r ?' + if not tkMessageBox.askyesno( + 'Delete Key Set', delmsg % keyset_name, parent=self): + return + self.deactivate_current_config() + # Remove key set from changes, config, and file. + changes.delete_section('keys', keyset_name) + # Reload user key set list. + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + if not item_list: + self.radio_keys_custom['state'] = DISABLED + self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') + else: + self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) + # Revert to default key set. + self.are_keys_builtin.set(idleConf.defaultCfg['main'] + .Get('Keys', 'default')) + self.builtin_keys.set(idleConf.defaultCfg['main'].Get('Keys', 'name') + or idleConf.default_keys()) + # User can't back out of these changes, they must be applied now. + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + self.set_keys_type() - Instance attributes accessed: - theme_elements - is_builtin_theme - builtin_theme - custom_theme + def deactivate_current_config(self): + """Remove current key bindings. - Attributes updated: - highlight_sample: Set the tag elements to the theme. + Iterate over window instances defined in parent and remove + the keybindings. + """ + # Before a config is saved, some cleanup of current + # config must be done - remove the previous keybindings. + win_instances = self.parent.instance_dict.keys() + for instance in win_instances: + instance.RemoveKeybindings() - Methods: - set_color_sample + def activate_config_changes(self): + """Apply configuration changes to current windows. - Called from: - var_changed_builtin_theme - var_changed_custom_theme - load_theme_cfg + Dynamically update the current parent window instances + with some of the configuration changes. """ - if self.is_builtin_theme.get(): # Default theme - theme = self.builtin_theme.get() - else: # User theme - theme = self.custom_theme.get() - for element_title in self.theme_elements: - element = self.theme_elements[element_title][0] - colors = idleConf.GetHighlight(theme, element) - if element == 'cursor': # Cursor sample needs special painting. - colors['background'] = idleConf.GetHighlight( - theme, 'normal', fgBg='bg') - # Handle any unsaved changes to this theme. - if theme in changes['highlight']: - theme_dict = changes['highlight'][theme] - if element + '-foreground' in theme_dict: - colors['foreground'] = theme_dict[element + '-foreground'] - if element + '-background' in theme_dict: - colors['background'] = theme_dict[element + '-background'] - self.highlight_sample.tag_config(element, **colors) - self.set_color_sample() - - def load_theme_cfg(self): - """Load current configuration settings for the theme options. + win_instances = self.parent.instance_dict.keys() + for instance in win_instances: + instance.ResetColorizer() + instance.ResetFont() + instance.set_notabs_indentwidth() + instance.ApplyKeybindings() + instance.reset_help_menu_entries() - Based on the is_builtin_theme toggle, the theme is set as - either builtin or custom and the initial widget values - reflect the current settings from idleConf. - Attributes updated: - is_builtin_theme: Set from idleConf. - opt_menu_theme_builtin: List of default themes from idleConf. - opt_menu_theme_custom: List of custom themes from idleConf. - radio_theme_custom: Disabled if there are no custom themes. - custom_theme: Message with additional information. - opt_menu_highlight_target: Create menu from self.theme_elements. + def create_page_general(self): + """Return frame of widgets for General tab. - Methods: - set_theme_type - paint_theme_sample - set_highlight_target - """ - # Set current theme type radiobutton. - self.is_builtin_theme.set(idleConf.GetOption( - 'main', 'Theme', 'default', type='bool', default=1)) - # Set current theme. - current_option = idleConf.CurrentTheme() - # Load available theme option menus. - if self.is_builtin_theme.get(): # Default theme selected. - item_list = idleConf.GetSectionList('default', 'highlight') - item_list.sort() - self.opt_menu_theme_builtin.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - if not item_list: - self.radio_theme_custom['state'] = DISABLED - self.custom_theme.set('- no custom themes -') - else: - self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) - else: # User theme selected. - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - self.opt_menu_theme_custom.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('default', 'highlight') - item_list.sort() - self.opt_menu_theme_builtin.SetMenu(item_list, item_list[0]) - self.set_theme_type() - # Load theme element option menu. - theme_names = list(self.theme_elements.keys()) - theme_names.sort(key=lambda x: self.theme_elements[x][1]) - self.opt_menu_highlight_target.SetMenu(theme_names, theme_names[0]) - self.paint_theme_sample() - self.set_highlight_target() + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + var_changed_var_name callback that adds option to changes. - def load_key_cfg(self): - "Load current configuration settings for the keybinding options." - # Set current keys type radiobutton. - self.are_keys_builtin.set(idleConf.GetOption( - 'main', 'Keys', 'default', type='bool', default=1)) - # Set current keys. - current_option = idleConf.CurrentKeys() - # Load available keyset option menus. - if self.are_keys_builtin.get(): # Default theme selected. - item_list = idleConf.GetSectionList('default', 'keys') - item_list.sort() - self.opt_menu_keys_builtin.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - if not item_list: - self.radio_keys_custom['state'] = DISABLED - self.custom_keys.set('- no custom keys -') - else: - self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) - else: # User key set selected. - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - self.opt_menu_keys_custom.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('default', 'keys') - item_list.sort() - self.opt_menu_keys_builtin.SetMenu(item_list, idleConf.default_keys()) - self.set_keys_type() - # Load keyset element list. - keyset_name = idleConf.CurrentKeys() - self.load_keys_list(keyset_name) + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. - def load_configs(self): - """Load configuration for each page. + Widget Structure: (*) widgets bound to self + frame + frame_run: LabelFrame + startup_title: Label + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit + frame_save: LabelFrame + run_save_title: Label + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave + frame_win_size: LabelFrame + win_size_title: Label + win_width_title: Label + (*)win_width_int: Entry - win_width + win_height_title: Label + (*)win_height_int: Entry - win_height + frame_help: LabelFrame + frame_helplist: Frame + frame_helplist_buttons: Frame + (*)button_helplist_edit + (*)button_helplist_add + (*)button_helplist_remove + (*)helplist: ListBox + scroll_helplist: Scrollbar + """ + parent = self.parent + self.startup_edit = IntVar(parent) + self.autosave = IntVar(parent) + self.win_width = StringVar(parent) + self.win_height = StringVar(parent) - Load configuration from default and user config files and populate - the widgets on the config dialog pages. + # Create widgets: + # body. + frame = self.tab_pages.pages['General'].frame + # body section frames. + frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' Startup Preferences ') + frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' autosave Preferences ') + frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) + frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' Additional Help Sources ') + # frame_run. + startup_title = Label(frame_run, text='At Startup') + self.startup_editor_on = Radiobutton( + frame_run, variable=self.startup_edit, value=1, + text="Open Edit Window") + self.startup_shell_on = Radiobutton( + frame_run, variable=self.startup_edit, value=0, + text='Open Shell Window') + # frame_save. + run_save_title = Label(frame_save, text='At Start of Run (F5) ') + self.save_ask_on = Radiobutton( + frame_save, variable=self.autosave, value=0, + text="Prompt to Save") + self.save_auto_on = Radiobutton( + frame_save, variable=self.autosave, value=1, + text='No Prompt') + # frame_win_size. + win_size_title = Label( + frame_win_size, text='Initial Window Size (in characters)') + win_width_title = Label(frame_win_size, text='Width') + self.win_width_int = Entry( + frame_win_size, textvariable=self.win_width, width=3) + win_height_title = Label(frame_win_size, text='Height') + self.win_height_int = Entry( + frame_win_size, textvariable=self.win_height, width=3) + # frame_help. + frame_helplist = Frame(frame_help) + frame_helplist_buttons = Frame(frame_helplist) + self.helplist = Listbox( + frame_helplist, height=5, takefocus=FALSE, + exportselection=FALSE) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) + self.button_helplist_edit = Button( + frame_helplist_buttons, text='Edit', state=DISABLED, + width=8, command=self.helplist_item_edit) + self.button_helplist_add = Button( + frame_helplist_buttons, text='Add', + width=8, command=self.helplist_item_add) + self.button_helplist_remove = Button( + frame_helplist_buttons, text='Remove', state=DISABLED, + width=8, command=self.helplist_item_remove) - Methods: - load_font_cfg - load_tab_cfg - load_theme_cfg - load_key_cfg - load_general_cfg - """ - self.load_font_cfg() - self.load_tab_cfg() - self.load_theme_cfg() - self.load_key_cfg() - self.load_general_cfg() - # note: extension page handled separately + # Pack widgets: + # body. + frame_run.pack(side=TOP, padx=5, pady=5, fill=X) + frame_save.pack(side=TOP, padx=5, pady=5, fill=X) + frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) + frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + # frame_run. + startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. + run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. + win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_height_title.pack(side=RIGHT, anchor=E, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_width_title.pack(side=RIGHT, anchor=E, pady=5) + # frame_help. + frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) + frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) + self.button_helplist_add.pack(side=TOP, anchor=W) + self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) - def save_new_key_set(self, keyset_name, keyset): - """Save a newly created core key set. + return frame - keyset_name - string, the name of the new key set - keyset - dictionary containing the new key set - """ - if not idleConf.userCfg['keys'].has_section(keyset_name): - idleConf.userCfg['keys'].add_section(keyset_name) - for event in keyset: - value = keyset[event] - idleConf.userCfg['keys'].SetOption(keyset_name, event, value) + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() - def save_new_theme(self, theme_name, theme): - """Save a newly created theme to idleConf. + def var_changed_startup_edit(self, *params): + "Store change to toggle for starting IDLE in the editor or shell." + value = self.startup_edit.get() + changes.add_option('main', 'General', 'editor-on-startup', value) - theme_name - string, the name of the new theme - theme - dictionary containing the new theme - """ - if not idleConf.userCfg['highlight'].has_section(theme_name): - idleConf.userCfg['highlight'].add_section(theme_name) - for element in theme: - value = theme[element] - idleConf.userCfg['highlight'].SetOption(theme_name, element, value) + def var_changed_autosave(self, *params): + "Store change to autosave." + value = self.autosave.get() + changes.add_option('main', 'General', 'autosave', value) - def deactivate_current_config(self): - """Remove current key bindings. + def var_changed_win_width(self, *params): + "Store change to window width." + value = self.win_width.get() + changes.add_option('main', 'EditorWindow', 'width', value) - Iterate over window instances defined in parent and remove - the keybindings. - """ - # Before a config is saved, some cleanup of current - # config must be done - remove the previous keybindings. - win_instances = self.parent.instance_dict.keys() - for instance in win_instances: - instance.RemoveKeybindings() + def var_changed_win_height(self, *params): + "Store change to window height." + value = self.win_height.get() + changes.add_option('main', 'EditorWindow', 'height', value) - def activate_config_changes(self): - """Apply configuration changes to current windows. + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() - Dynamically update the current parent window instances - with some of the configuration changes. - """ - win_instances = self.parent.instance_dict.keys() - for instance in win_instances: - instance.ResetColorizer() - instance.ResetFont() - instance.set_notabs_indentwidth() - instance.ApplyKeybindings() - instance.reset_help_menu_entries() + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED - def cancel(self): - """Dismiss config dialog. + def helplist_item_add(self): + """Handle add button for the help list. - Methods: - destroy: inherited + Query for name and location of new help sources and add + them to the list. """ - self.destroy() + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() - def ok(self): - """Apply config changes, then dismiss dialog. + def helplist_item_edit(self): + """Handle edit button for the help list. - Methods: - apply - destroy: inherited + Query with existing help source information and update + config if the values are changed. """ - self.apply() - self.destroy() + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected - def apply(self): - """Apply config changes and leave dialog open. + def helplist_item_remove(self): + """Handle remove button for the help list. - Methods: - deactivate_current_config - save_all_changed_extensions - activate_config_changes + Delete the help list item from config. """ - self.deactivate_current_config() - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - - def help(self): - """Create textview for config dialog help. + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() - Attrbutes accessed: - tab_pages + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) - Methods: - view_text: Method from textview module. - """ - page = self.tab_pages._current_page - view_text(self, title='Help for IDLE preferences', - text=help_common+help_pages.get(page, '')) def create_page_extensions(self): """Part of the config dialog used for configuring IDLE extensions. diff --git a/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst b/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst new file mode 100644 index 00000000000..1d202c7fa2c --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst @@ -0,0 +1,3 @@ +IDLE - Finish rearranging methods of ConfigDialog Grouping methods +pertaining to each tab and the buttons will aid writing tests and improving +the tabs and will enable splitting the groups into classes. From lp_benchmark_robot at intel.com Thu Jul 27 19:33:14 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Thu, 27 Jul 2017 16:33:14 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-27 Message-ID: Results for project python/master, build date: 2017-07-27 03:03:16-07:00. - commit: d5ed47d - previous commit: 2db6482 - revision date: 2017-07-27 12:24:36+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.056% | +0.255% | +5.006% | +6.529% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 2.105% | +0.292% | +23.839% | +7.624% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.591% | +0.154% | +25.448% | +6.039% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.480% | +0.704% | +22.441% | +7.180% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.118% | +0.694% | +6.513% | +12.347% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 2.154% | -0.245% | +10.918% | +11.807% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.935% | +0.449% | +8.607% | +7.821% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.406% | +0.084% | +5.554% | +4.133% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 5.248% | -0.781% | +6.244% | +18.779% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 5.833% | -0.226% | +8.537% | +14.025% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.001% | -0.118% | +4.102% | +6.170% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.311% | +0.236% | +5.294% | +4.679% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.691% | -0.056% | +3.863% | +5.350% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.401% | +0.147% | +9.485% | +10.871% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.192% | +0.161% | +7.600% | +8.404% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.790% | -0.289% | +7.569% | +9.144% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.464% | +0.038% | +10.575% | +8.841% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.367% | +0.242% | +9.608% | +8.047% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 2.409% | -0.295% | +3.036% | +9.388% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 1.069% | +1.052% | +2.483% | +11.189% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.522% | +0.224% | +8.232% | +9.062% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 1.804% | -0.931% | +9.156% | +14.252% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.540% | -0.171% | +8.719% | +10.735% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.707% | +0.087% | +18.487% | +10.797% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 8.413% | +0.993% | +3.803% | +15.864% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.097% | -0.364% | +4.284% | +5.024% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 0.969% | +0.047% | -3.036% | +3.307% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.724% | -0.029% | +2.445% | +6.229% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.531% | -0.515% | +1.311% | +12.710% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 2.696% | -0.517% | +3.327% | +20.212% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.490% | +0.014% | +2.364% | +14.428% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 0.864% | +0.519% | +5.943% | +14.539% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.008% | +1.998% | +12.961% | +7.713% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.226% | +0.006% | +0.367% | +9.720% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.123% | +0.418% | +9.888% | +4.299% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.091% | +0.318% | +1.609% | +4.271% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.356% | +0.367% | +10.864% | +10.712% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.187% | +0.238% | -9.340% | +12.504% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.744% | +0.173% | +2.219% | +8.621% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.546% | -0.721% | -2.411% | +5.631% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 0.878% | +0.060% | +11.763% | +4.358% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.493% | +0.210% | +9.870% | +11.888% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 1.285% | -0.306% | +0.950% | -2.406% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 2.088% | +0.532% | +26.842% | +9.061% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.768% | +0.046% | +5.643% | +4.597% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.793% | +0.175% | +16.211% | +6.102% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.387% | +0.163% | +1.346% | -1.929% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.860% | -0.062% | +6.353% | +3.237% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.125% | +0.131% | +5.423% | +6.246% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 2.787% | +0.730% | +5.107% | +2.616% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.383% | +0.338% | +2.428% | +8.038% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.013% | +0.369% | +13.001% | +8.031% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.679% | +0.423% | +10.744% | +5.750% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.216% | +0.378% | +12.722% | +8.543% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.017% | +0.184% | +13.552% | +9.594% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 4.530% | +2.303% | +22.527% | +12.424% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.190% | +0.357% | +7.254% | +5.062% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.289% | -0.291% | +2.195% | -1.393% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 8.584% | -1.107% | +6.674% | +22.126% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 1.123% | +0.206% | -0.936% | +17.669% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 3.119% | -0.710% | +6.493% | +7.925% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 0.860% | +0.153% | +5.803% | +7.486% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.544% | +0.261% | +1.696% | +5.539% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.244% | +0.513% | -5.890% | +11.080% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.316% | -0.068% | +6.704% | +7.485% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-27 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Thu Jul 27 20:50:42 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Fri, 28 Jul 2017 00:50:42 -0000 Subject: [Python-checkins] [3.6] bpo-31060: IDLE: Finish regrouping ConfigDialog methods (GH-2908) (#2925) Message-ID: https://github.com/python/cpython/commit/2cbb6733bfe54e87622a6372f83b73bddf3c4078 commit: 2cbb6733bfe54e87622a6372f83b73bddf3c4078 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-27T20:50:39-04:00 summary: [3.6] bpo-31060: IDLE: Finish regrouping ConfigDialog methods (GH-2908) (#2925) Finish resorting the 72 ConfigDialog methods into 7 groups that represent the dialog, action buttons, and font, highlight, keys, general, and extension pages. This will help with continuing to add tests and improve the pages. It will enable splitting ConfigDialog into 6 or 7 more comprehensible classes. (cherry picked from commit b166080) files: A Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst M Lib/idlelib/configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index daaa34459e2..e359ec24cd3 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -30,7 +30,6 @@ changes = ConfigChanges() - class ConfigDialog(Toplevel): """Config dialog for IDLE. """ @@ -112,6 +111,58 @@ def create_widgets(self): self.create_page_extensions() self.create_action_buttons().pack(side=BOTTOM) + def load_configs(self): + """Load configuration for each page. + + Load configuration from default and user config files and populate + the widgets on the config dialog pages. + + Methods: + load_font_cfg + load_tab_cfg + load_theme_cfg + load_key_cfg + load_general_cfg + """ + self.load_font_cfg() + self.load_tab_cfg() + self.load_theme_cfg() + self.load_key_cfg() + self.load_general_cfg() + # note: extension page handled separately + + def attach_var_callbacks(self): + "Attach callbacks to variables that can be changed." + self.font_size.trace_add('write', self.var_changed_font) + self.font_name.trace_add('write', self.var_changed_font) + self.font_bold.trace_add('write', self.var_changed_font) + self.space_num.trace_add('write', self.var_changed_space_num) + self.color.trace_add('write', self.var_changed_color) + self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) + self.custom_theme.trace_add('write', self.var_changed_custom_theme) + self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) + self.highlight_target.trace_add('write', self.var_changed_highlight_target) + self.keybinding.trace_add('write', self.var_changed_keybinding) + self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) + self.custom_keys.trace_add('write', self.var_changed_custom_keys) + self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) + self.win_width.trace_add('write', self.var_changed_win_width) + self.win_height.trace_add('write', self.var_changed_win_height) + self.startup_edit.trace_add('write', self.var_changed_startup_edit) + self.autosave.trace_add('write', self.var_changed_autosave) + + def remove_var_callbacks(self): + "Remove callbacks to prevent memory leaks." + for var in ( + self.font_size, self.font_name, self.font_bold, + self.space_num, self.color, self.builtin_theme, + self.custom_theme, self.is_builtin_theme, self.highlight_target, + self.keybinding, self.builtin_keys, self.custom_keys, + self.are_keys_builtin, self.win_width, self.win_height, + self.startup_edit, self.autosave,): + var.trace_remove('write', var.trace_info()[0][1]) + + def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -150,6 +201,50 @@ def create_action_buttons(self): buttons.pack(side=BOTTOM) return outer + def ok(self): + """Apply config changes, then dismiss dialog. + + Methods: + apply + destroy: inherited + """ + self.apply() + self.destroy() + + def apply(self): + """Apply config changes and leave dialog open. + + Methods: + deactivate_current_config + save_all_changed_extensions + activate_config_changes + """ + self.deactivate_current_config() + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + + def cancel(self): + """Dismiss config dialog. + + Methods: + destroy: inherited + """ + self.destroy() + + def help(self): + """Create textview for config dialog help. + + Attrbutes accessed: + tab_pages + + Methods: + view_text: Method from textview module. + """ + page = self.tab_pages._current_page + view_text(self, title='Help for IDLE preferences', + text=help_common+help_pages.get(page, '')) + def create_page_font_tab(self): """Return frame of widgets for Font/Tabs tab. @@ -299,16 +394,6 @@ def load_font_cfg(self): # Set font weight. self.font_bold.set(font_bold) - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - def var_changed_font(self, *params): """Store changes to font attributes. @@ -324,6 +409,16 @@ def var_changed_font(self, *params): changes.add_option('main', 'EditorWindow', 'font-bold', value) self.set_samples() + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + def set_samples(self, event=None): """Update update both screen samples with the font settings. @@ -531,466 +626,551 @@ def tem(event, elem=element): self.new_custom_theme.pack(side=TOP, fill=X, pady=5) return frame - def create_page_keys(self): - """Return frame of widgets for Keys tab. + def load_theme_cfg(self): + """Load current configuration settings for the theme options. - Tk Variables: - builtin_keys: Menu variable for built-in keybindings. - custom_keys: Menu variable for custom keybindings. - are_keys_builtin: Selector for built-in or custom keybindings. - keybinding: Action/key bindings. + Based on the is_builtin_theme toggle, the theme is set as + either builtin or custom and the initial widget values + reflect the current settings from idleConf. - Methods: - load_key_config: Set table. - load_keys_list: Reload active set. - keybinding_selected: Bound to list_bindings button release. - get_new_keys: Command for button_new_keys. - get_new_keys_name: Call popup. - create_new_key_set: Combine active keyset and changes. - set_keys_type: Command for are_keys_builtin. - delete_custom_keys: Command for button_delete_custom_keys. - save_as_new_key_set: Command for button_save_custom_keys. - save_new_key_set: Save to idleConf.userCfg['keys'] (is function). - deactivate_current_config: Remove keys bindings in editors. + Attributes updated: + is_builtin_theme: Set from idleConf. + opt_menu_theme_builtin: List of default themes from idleConf. + opt_menu_theme_custom: List of custom themes from idleConf. + radio_theme_custom: Disabled if there are no custom themes. + custom_theme: Message with additional information. + opt_menu_highlight_target: Create menu from self.theme_elements. - Widget Structure: (*) widgets bound to self - frame - frame_custom: LabelFrame - frame_target: Frame - target_title: Label - scroll_target_y: Scrollbar - scroll_target_x: Scrollbar - (*)list_bindings: ListBox - (*)button_new_keys: Button - frame_key_sets: LabelFrame - frames[0]: Frame - (*)radio_keys_builtin: Radiobutton - are_keys_builtin - (*)radio_keys_custom: Radiobutton - are_keys_builtin - (*)opt_menu_keys_builtin: DynOptionMenu - builtin_keys - (*)opt_menu_keys_custom: DynOptionMenu - custom_keys - (*)new_custom_keys: Label - frames[1]: Frame - (*)button_delete_custom_keys: Button - button_save_custom_keys: Button + Methods: + set_theme_type + paint_theme_sample + set_highlight_target """ - parent = self.parent - self.builtin_keys = StringVar(parent) - self.custom_keys = StringVar(parent) - self.are_keys_builtin = BooleanVar(parent) - self.keybinding = StringVar(parent) + # Set current theme type radiobutton. + self.is_builtin_theme.set(idleConf.GetOption( + 'main', 'Theme', 'default', type='bool', default=1)) + # Set current theme. + current_option = idleConf.CurrentTheme() + # Load available theme option menus. + if self.is_builtin_theme.get(): # Default theme selected. + item_list = idleConf.GetSectionList('default', 'highlight') + item_list.sort() + self.opt_menu_theme_builtin.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + if not item_list: + self.radio_theme_custom['state'] = DISABLED + self.custom_theme.set('- no custom themes -') + else: + self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) + else: # User theme selected. + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + self.opt_menu_theme_custom.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('default', 'highlight') + item_list.sort() + self.opt_menu_theme_builtin.SetMenu(item_list, item_list[0]) + self.set_theme_type() + # Load theme element option menu. + theme_names = list(self.theme_elements.keys()) + theme_names.sort(key=lambda x: self.theme_elements[x][1]) + self.opt_menu_highlight_target.SetMenu(theme_names, theme_names[0]) + self.paint_theme_sample() + self.set_highlight_target() - ##widget creation - #body frame - frame = self.tab_pages.pages['Keys'].frame - #body section frames - frame_custom = LabelFrame( - frame, borderwidth=2, relief=GROOVE, - text=' Custom Key Bindings ') - frame_key_sets = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Key Set ') - #frame_custom - frame_target = Frame(frame_custom) - target_title = Label(frame_target, text='Action - Key(s)') - scroll_target_y = Scrollbar(frame_target) - scroll_target_x = Scrollbar(frame_target, orient=HORIZONTAL) - self.list_bindings = Listbox( - frame_target, takefocus=FALSE, exportselection=FALSE) - self.list_bindings.bind('', self.keybinding_selected) - scroll_target_y.config(command=self.list_bindings.yview) - scroll_target_x.config(command=self.list_bindings.xview) - self.list_bindings.config(yscrollcommand=scroll_target_y.set) - self.list_bindings.config(xscrollcommand=scroll_target_x.set) - self.button_new_keys = Button( - frame_custom, text='Get New Keys for Selection', - command=self.get_new_keys, state=DISABLED) - #frame_key_sets - frames = [Frame(frame_key_sets, padx=2, pady=2, borderwidth=0) - for i in range(2)] - self.radio_keys_builtin = Radiobutton( - frames[0], variable=self.are_keys_builtin, value=1, - command=self.set_keys_type, text='Use a Built-in Key Set') - self.radio_keys_custom = Radiobutton( - frames[0], variable=self.are_keys_builtin, value=0, - command=self.set_keys_type, text='Use a Custom Key Set') - self.opt_menu_keys_builtin = DynOptionMenu( - frames[0], self.builtin_keys, None, command=None) - self.opt_menu_keys_custom = DynOptionMenu( - frames[0], self.custom_keys, None, command=None) - self.button_delete_custom_keys = Button( - frames[1], text='Delete Custom Key Set', - command=self.delete_custom_keys) - button_save_custom_keys = Button( - frames[1], text='Save as New Custom Key Set', - command=self.save_as_new_key_set) - self.new_custom_keys = Label(frames[0], bd=2) + def var_changed_builtin_theme(self, *params): + """Process new builtin theme selection. - ##widget packing - #body - frame_custom.pack(side=BOTTOM, padx=5, pady=5, expand=TRUE, fill=BOTH) - frame_key_sets.pack(side=BOTTOM, padx=5, pady=5, fill=BOTH) - #frame_custom - self.button_new_keys.pack(side=BOTTOM, fill=X, padx=5, pady=5) - frame_target.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) - #frame target - frame_target.columnconfigure(0, weight=1) - frame_target.rowconfigure(1, weight=1) - target_title.grid(row=0, column=0, columnspan=2, sticky=W) - self.list_bindings.grid(row=1, column=0, sticky=NSEW) - scroll_target_y.grid(row=1, column=1, sticky=NS) - scroll_target_x.grid(row=2, column=0, sticky=EW) - #frame_key_sets - self.radio_keys_builtin.grid(row=0, column=0, sticky=W+NS) - self.radio_keys_custom.grid(row=1, column=0, sticky=W+NS) - self.opt_menu_keys_builtin.grid(row=0, column=1, sticky=NSEW) - self.opt_menu_keys_custom.grid(row=1, column=1, sticky=NSEW) - self.new_custom_keys.grid(row=0, column=2, sticky=NSEW, padx=5, pady=5) - self.button_delete_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) - button_save_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) - frames[0].pack(side=TOP, fill=BOTH, expand=True) - frames[1].pack(side=TOP, fill=X, expand=True, pady=2) - return frame + Add the changed theme's name to the changed_items and recreate + the sample with the values from the selected theme. + """ + old_themes = ('IDLE Classic', 'IDLE New') + value = self.builtin_theme.get() + if value not in old_themes: + if idleConf.GetOption('main', 'Theme', 'name') not in old_themes: + changes.add_option('main', 'Theme', 'name', old_themes[0]) + changes.add_option('main', 'Theme', 'name2', value) + self.new_custom_theme.config(text='New theme, see Help', + fg='#500000') + else: + changes.add_option('main', 'Theme', 'name', value) + changes.add_option('main', 'Theme', 'name2', '') + self.new_custom_theme.config(text='', fg='black') + self.paint_theme_sample() + def var_changed_custom_theme(self, *params): + """Process new custom theme selection. - def create_page_general(self): - """Return frame of widgets for General tab. + If a new custom theme is selected, add the name to the + changed_items and apply the theme to the sample. + """ + value = self.custom_theme.get() + if value != '- no custom themes -': + changes.add_option('main', 'Theme', 'name', value) + self.paint_theme_sample() - Enable users to provisionally change general options. Function - load_general_cfg intializes tk variables and helplist using - idleConf. Radiobuttons startup_shell_on and startup_editor_on - set var startup_edit. Radiobuttons save_ask_on and save_auto_on - set var autosave. Entry boxes win_width_int and win_height_int - set var win_width and win_height. Setting var_name invokes the - var_changed_var_name callback that adds option to changes. + def var_changed_is_builtin_theme(self, *params): + """Process toggle between builtin and custom theme. - Helplist: load_general_cfg loads list user_helplist with - name, position pairs and copies names to listbox helplist. - Clicking a name invokes help_source selected. Clicking - button_helplist_name invokes helplist_item_name, which also - changes user_helplist. These functions all call - set_add_delete_state. All but load call update_help_changes to - rewrite changes['main']['HelpFiles']. + Update the default toggle value and apply the newly + selected theme type. + """ + value = self.is_builtin_theme.get() + changes.add_option('main', 'Theme', 'default', value) + if value: + self.var_changed_builtin_theme() + else: + self.var_changed_custom_theme() - Widget Structure: (*) widgets bound to self - frame - frame_run: LabelFrame - startup_title: Label - (*)startup_editor_on: Radiobutton - startup_edit - (*)startup_shell_on: Radiobutton - startup_edit - frame_save: LabelFrame - run_save_title: Label - (*)save_ask_on: Radiobutton - autosave - (*)save_auto_on: Radiobutton - autosave - frame_win_size: LabelFrame - win_size_title: Label - win_width_title: Label - (*)win_width_int: Entry - win_width - win_height_title: Label - (*)win_height_int: Entry - win_height - frame_help: LabelFrame - frame_helplist: Frame - frame_helplist_buttons: Frame - (*)button_helplist_edit - (*)button_helplist_add - (*)button_helplist_remove - (*)helplist: ListBox - scroll_helplist: Scrollbar + def var_changed_color(self, *params): + "Process change to color choice." + self.on_new_color_set() + + def var_changed_highlight_target(self, *params): + "Process selection of new target tag for highlighting." + self.set_highlight_target() + + def set_theme_type(self): + """Set available screen options based on builtin or custom theme. + + Attributes accessed: + is_builtin_theme + + Attributes updated: + opt_menu_theme_builtin + opt_menu_theme_custom + button_delete_custom_theme + radio_theme_custom + + Called from: + handler for radio_theme_builtin and radio_theme_custom + delete_custom_theme + create_new_theme + load_theme_cfg """ - parent = self.parent - self.startup_edit = IntVar(parent) - self.autosave = IntVar(parent) - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) + if self.is_builtin_theme.get(): + self.opt_menu_theme_builtin['state'] = NORMAL + self.opt_menu_theme_custom['state'] = DISABLED + self.button_delete_custom_theme['state'] = DISABLED + else: + self.opt_menu_theme_builtin['state'] = DISABLED + self.radio_theme_custom['state'] = NORMAL + self.opt_menu_theme_custom['state'] = NORMAL + self.button_delete_custom_theme['state'] = NORMAL - # Create widgets: - # body. - frame = self.tab_pages.pages['General'].frame - # body section frames. - frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Startup Preferences ') - frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' autosave Preferences ') - frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) - frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Additional Help Sources ') - # frame_run. - startup_title = Label(frame_run, text='At Startup') - self.startup_editor_on = Radiobutton( - frame_run, variable=self.startup_edit, value=1, - text="Open Edit Window") - self.startup_shell_on = Radiobutton( - frame_run, variable=self.startup_edit, value=0, - text='Open Shell Window') - # frame_save. - run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.save_ask_on = Radiobutton( - frame_save, variable=self.autosave, value=0, - text="Prompt to Save") - self.save_auto_on = Radiobutton( - frame_save, variable=self.autosave, value=1, - text='No Prompt') - # frame_win_size. - win_size_title = Label( - frame_win_size, text='Initial Window Size (in characters)') - win_width_title = Label(frame_win_size, text='Width') - self.win_width_int = Entry( - frame_win_size, textvariable=self.win_width, width=3) - win_height_title = Label(frame_win_size, text='Height') - self.win_height_int = Entry( - frame_win_size, textvariable=self.win_height, width=3) - # frame_help. - frame_helplist = Frame(frame_help) - frame_helplist_buttons = Frame(frame_helplist) - self.helplist = Listbox( - frame_helplist, height=5, takefocus=FALSE, - exportselection=FALSE) - scroll_helplist = Scrollbar(frame_helplist) - scroll_helplist['command'] = self.helplist.yview - self.helplist['yscrollcommand'] = scroll_helplist.set - self.helplist.bind('', self.help_source_selected) - self.button_helplist_edit = Button( - frame_helplist_buttons, text='Edit', state=DISABLED, - width=8, command=self.helplist_item_edit) - self.button_helplist_add = Button( - frame_helplist_buttons, text='Add', - width=8, command=self.helplist_item_add) - self.button_helplist_remove = Button( - frame_helplist_buttons, text='Remove', state=DISABLED, - width=8, command=self.helplist_item_remove) + def get_color(self): + """Handle button to select a new color for the target tag. - # Pack widgets: - # body. - frame_run.pack(side=TOP, padx=5, pady=5, fill=X) - frame_save.pack(side=TOP, padx=5, pady=5, fill=X) - frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) - frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - # frame_run. - startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_save. - run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_win_size. - win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_width_title.pack(side=RIGHT, anchor=E, pady=5) - # frame_help. - frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) - frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) - self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) - self.button_helplist_add.pack(side=TOP, anchor=W) - self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + If a new color is selected while using a builtin theme, a + name must be supplied to create a custom theme. + + Attributes accessed: + highlight_target + frame_color_set + is_builtin_theme + + Attributes updated: + color + + Methods: + get_new_theme_name + create_new_theme + """ + target = self.highlight_target.get() + prev_color = self.frame_color_set.cget('bg') + rgbTuplet, color_string = tkColorChooser.askcolor( + parent=self, title='Pick new color for : '+target, + initialcolor=prev_color) + if color_string and (color_string != prev_color): + # User didn't cancel and they chose a new color. + if self.is_builtin_theme.get(): # Current theme is a built-in. + message = ('Your changes will be saved as a new Custom Theme. ' + 'Enter a name for your new Custom Theme below.') + new_theme = self.get_new_theme_name(message) + if not new_theme: # User cancelled custom theme creation. + return + else: # Create new custom theme based on previously active theme. + self.create_new_theme(new_theme) + self.color.set(color_string) + else: # Current theme is user defined. + self.color.set(color_string) + + def on_new_color_set(self): + "Display sample of new color selection on the dialog." + new_color=self.color.get() + self.frame_color_set.config(bg=new_color) # Set sample. + plane ='foreground' if self.fg_bg_toggle.get() else 'background' + sample_element = self.theme_elements[self.highlight_target.get()][0] + self.highlight_sample.tag_config(sample_element, **{plane:new_color}) + theme = self.custom_theme.get() + theme_element = sample_element + '-' + plane + changes.add_option('highlight', theme, theme_element, new_color) + + def get_new_theme_name(self, message): + "Return name of new theme from query popup." + used_names = (idleConf.GetSectionList('user', 'highlight') + + idleConf.GetSectionList('default', 'highlight')) + new_theme = SectionName( + self, 'New Custom Theme', message, used_names).result + return new_theme + + def save_as_new_theme(self): + """Prompt for new theme name and create the theme. + + Methods: + get_new_theme_name + create_new_theme + """ + new_theme_name = self.get_new_theme_name('New Theme Name:') + if new_theme_name: + self.create_new_theme(new_theme_name) + + def create_new_theme(self, new_theme_name): + """Create a new custom theme with the given name. - return frame + Create the new theme based on the previously active theme + with the current changes applied. Once it is saved, then + activate the new theme. - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=0, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - self.helplist.delete(0, 'end') - for help_item in self.user_helplist: - self.helplist.insert(END, help_item[0]) - self.set_add_delete_state() + Attributes accessed: + builtin_theme + custom_theme - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) + Attributes updated: + opt_menu_theme_custom + is_builtin_theme - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) + Method: + save_new_theme + set_theme_type + """ + if self.is_builtin_theme.get(): + theme_type = 'default' + theme_name = self.builtin_theme.get() + else: + theme_type = 'user' + theme_name = self.custom_theme.get() + new_theme = idleConf.GetThemeDict(theme_type, theme_name) + # Apply any of the old theme's unsaved changes to the new theme. + if theme_name in changes['highlight']: + theme_changes = changes['highlight'][theme_name] + for element in theme_changes: + new_theme[element] = theme_changes[element] + # Save the new theme. + self.save_new_theme(new_theme_name, new_theme) + # Change GUI over to the new theme. + custom_theme_list = idleConf.GetSectionList('user', 'highlight') + custom_theme_list.sort() + self.opt_menu_theme_custom.SetMenu(custom_theme_list, new_theme_name) + self.is_builtin_theme.set(0) + self.set_theme_type() - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) + def set_highlight_target(self): + """Set fg/bg toggle and color based on highlight tag target. - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) + Instance variables accessed: + highlight_target - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_add_delete_state() + Attributes updated: + radio_fg + radio_bg + fg_bg_toggle - def set_add_delete_state(self): - "Toggle the state for the help list buttons based on list entries." - if self.helplist.size() < 1: # No entries in list. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - else: # Some entries. - if self.helplist.curselection(): # There currently is a selection. - self.button_helplist_edit['state'] = NORMAL - self.button_helplist_remove['state'] = NORMAL - else: # There currently is not a selection. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED + Methods: + set_color_sample - def helplist_item_add(self): - """Handle add button for the help list. + Called from: + var_changed_highlight_target + load_theme_cfg + """ + if self.highlight_target.get() == 'Cursor': # bg not possible + self.radio_fg['state'] = DISABLED + self.radio_bg['state'] = DISABLED + self.fg_bg_toggle.set(1) + else: # Both fg and bg can be set. + self.radio_fg['state'] = NORMAL + self.radio_bg['state'] = NORMAL + self.fg_bg_toggle.set(1) + self.set_color_sample() - Query for name and location of new help sources and add - them to the list. + def set_color_sample_binding(self, *args): + """Change color sample based on foreground/background toggle. + + Methods: + set_color_sample """ - help_source = HelpSource(self, 'New Help Source').result - if help_source: - self.user_helplist.append(help_source) - self.helplist.insert(END, help_source[0]) - self.update_help_changes() + self.set_color_sample() - def helplist_item_edit(self): - """Handle edit button for the help list. + def set_color_sample(self): + """Set the color of the frame background to reflect the selected target. - Query with existing help source information and update - config if the values are changed. + Instance variables accessed: + theme_elements + highlight_target + fg_bg_toggle + highlight_sample + + Attributes updated: + frame_color_set """ - item_index = self.helplist.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.helplist.delete(item_index) - self.helplist.insert(item_index, new_help_source[0]) - self.update_help_changes() - self.set_add_delete_state() # Selected will be un-selected + # Set the color sample area. + tag = self.theme_elements[self.highlight_target.get()][0] + plane = 'foreground' if self.fg_bg_toggle.get() else 'background' + color = self.highlight_sample.tag_cget(tag, plane) + self.frame_color_set.config(bg=color) - def helplist_item_remove(self): - """Handle remove button for the help list. + def paint_theme_sample(self): + """Apply the theme colors to each element tag in the sample text. - Delete the help list item from config. + Instance attributes accessed: + theme_elements + is_builtin_theme + builtin_theme + custom_theme + + Attributes updated: + highlight_sample: Set the tag elements to the theme. + + Methods: + set_color_sample + + Called from: + var_changed_builtin_theme + var_changed_custom_theme + load_theme_cfg """ - item_index = self.helplist.index(ANCHOR) - del(self.user_helplist[item_index]) - self.helplist.delete(item_index) - self.update_help_changes() - self.set_add_delete_state() + if self.is_builtin_theme.get(): # Default theme + theme = self.builtin_theme.get() + else: # User theme + theme = self.custom_theme.get() + for element_title in self.theme_elements: + element = self.theme_elements[element_title][0] + colors = idleConf.GetHighlight(theme, element) + if element == 'cursor': # Cursor sample needs special painting. + colors['background'] = idleConf.GetHighlight( + theme, 'normal', fgBg='bg') + # Handle any unsaved changes to this theme. + if theme in changes['highlight']: + theme_dict = changes['highlight'][theme] + if element + '-foreground' in theme_dict: + colors['foreground'] = theme_dict[element + '-foreground'] + if element + '-background' in theme_dict: + colors['background'] = theme_dict[element + '-background'] + self.highlight_sample.tag_config(element, **colors) + self.set_color_sample() - def update_help_changes(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) + def save_new_theme(self, theme_name, theme): + """Save a newly created theme to idleConf. + + theme_name - string, the name of the new theme + theme - dictionary containing the new theme + """ + if not idleConf.userCfg['highlight'].has_section(theme_name): + idleConf.userCfg['highlight'].add_section(theme_name) + for element in theme: + value = theme[element] + idleConf.userCfg['highlight'].SetOption(theme_name, element, value) + + def delete_custom_theme(self): + """Handle event to delete custom theme. + + The current theme is deactivated and the default theme is + activated. The custom theme is permanently removed from + the config file. + Attributes accessed: + custom_theme + + Attributes updated: + radio_theme_custom + opt_menu_theme_custom + is_builtin_theme + builtin_theme + + Methods: + deactivate_current_config + save_all_changed_extensions + activate_config_changes + set_theme_type + """ + theme_name = self.custom_theme.get() + delmsg = 'Are you sure you wish to delete the theme %r ?' + if not tkMessageBox.askyesno( + 'Delete Theme', delmsg % theme_name, parent=self): + return + self.deactivate_current_config() + # Remove theme from changes, config, and file. + changes.delete_section('highlight', theme_name) + # Reload user theme list. + item_list = idleConf.GetSectionList('user', 'highlight') + item_list.sort() + if not item_list: + self.radio_theme_custom['state'] = DISABLED + self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') + else: + self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) + # Revert to default theme. + self.is_builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'default')) + self.builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'name')) + # User can't back out of these changes, they must be applied now. + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + self.set_theme_type() - def attach_var_callbacks(self): - "Attach callbacks to variables that can be changed." - self.font_size.trace_add('write', self.var_changed_font) - self.font_name.trace_add('write', self.var_changed_font) - self.font_bold.trace_add('write', self.var_changed_font) - self.space_num.trace_add('write', self.var_changed_space_num) - self.color.trace_add('write', self.var_changed_color) - self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) - self.custom_theme.trace_add('write', self.var_changed_custom_theme) - self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) - self.highlight_target.trace_add('write', self.var_changed_highlight_target) - self.keybinding.trace_add('write', self.var_changed_keybinding) - self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) - self.custom_keys.trace_add('write', self.var_changed_custom_keys) - self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) - self.win_width.trace_add('write', self.var_changed_win_width) - self.win_height.trace_add('write', self.var_changed_win_height) - self.startup_edit.trace_add('write', self.var_changed_startup_edit) - self.autosave.trace_add('write', self.var_changed_autosave) - def remove_var_callbacks(self): - "Remove callbacks to prevent memory leaks." - for var in ( - self.font_size, self.font_name, self.font_bold, - self.space_num, self.color, self.builtin_theme, - self.custom_theme, self.is_builtin_theme, self.highlight_target, - self.keybinding, self.builtin_keys, self.custom_keys, - self.are_keys_builtin, self.win_width, self.win_height, - self.startup_edit, self.autosave,): - var.trace_remove('write', var.trace_info()[0][1]) + def create_page_keys(self): + """Return frame of widgets for Keys tab. - def var_changed_color(self, *params): - "Process change to color choice." - self.on_new_color_set() + Tk Variables: + builtin_keys: Menu variable for built-in keybindings. + custom_keys: Menu variable for custom keybindings. + are_keys_builtin: Selector for built-in or custom keybindings. + keybinding: Action/key bindings. - def var_changed_builtin_theme(self, *params): - """Process new builtin theme selection. + Methods: + load_key_config: Set table. + load_keys_list: Reload active set. + keybinding_selected: Bound to list_bindings button release. + get_new_keys: Command for button_new_keys. + get_new_keys_name: Call popup. + create_new_key_set: Combine active keyset and changes. + set_keys_type: Command for are_keys_builtin. + delete_custom_keys: Command for button_delete_custom_keys. + save_as_new_key_set: Command for button_save_custom_keys. + save_new_key_set: Save to idleConf.userCfg['keys'] (is function). + deactivate_current_config: Remove keys bindings in editors. - Add the changed theme's name to the changed_items and recreate - the sample with the values from the selected theme. + Widget Structure: (*) widgets bound to self + frame + frame_custom: LabelFrame + frame_target: Frame + target_title: Label + scroll_target_y: Scrollbar + scroll_target_x: Scrollbar + (*)list_bindings: ListBox + (*)button_new_keys: Button + frame_key_sets: LabelFrame + frames[0]: Frame + (*)radio_keys_builtin: Radiobutton - are_keys_builtin + (*)radio_keys_custom: Radiobutton - are_keys_builtin + (*)opt_menu_keys_builtin: DynOptionMenu - builtin_keys + (*)opt_menu_keys_custom: DynOptionMenu - custom_keys + (*)new_custom_keys: Label + frames[1]: Frame + (*)button_delete_custom_keys: Button + button_save_custom_keys: Button """ - old_themes = ('IDLE Classic', 'IDLE New') - value = self.builtin_theme.get() - if value not in old_themes: - if idleConf.GetOption('main', 'Theme', 'name') not in old_themes: - changes.add_option('main', 'Theme', 'name', old_themes[0]) - changes.add_option('main', 'Theme', 'name2', value) - self.new_custom_theme.config(text='New theme, see Help', - fg='#500000') - else: - changes.add_option('main', 'Theme', 'name', value) - changes.add_option('main', 'Theme', 'name2', '') - self.new_custom_theme.config(text='', fg='black') - self.paint_theme_sample() + parent = self.parent + self.builtin_keys = StringVar(parent) + self.custom_keys = StringVar(parent) + self.are_keys_builtin = BooleanVar(parent) + self.keybinding = StringVar(parent) - def var_changed_custom_theme(self, *params): - """Process new custom theme selection. + ##widget creation + #body frame + frame = self.tab_pages.pages['Keys'].frame + #body section frames + frame_custom = LabelFrame( + frame, borderwidth=2, relief=GROOVE, + text=' Custom Key Bindings ') + frame_key_sets = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Key Set ') + #frame_custom + frame_target = Frame(frame_custom) + target_title = Label(frame_target, text='Action - Key(s)') + scroll_target_y = Scrollbar(frame_target) + scroll_target_x = Scrollbar(frame_target, orient=HORIZONTAL) + self.list_bindings = Listbox( + frame_target, takefocus=FALSE, exportselection=FALSE) + self.list_bindings.bind('', self.keybinding_selected) + scroll_target_y.config(command=self.list_bindings.yview) + scroll_target_x.config(command=self.list_bindings.xview) + self.list_bindings.config(yscrollcommand=scroll_target_y.set) + self.list_bindings.config(xscrollcommand=scroll_target_x.set) + self.button_new_keys = Button( + frame_custom, text='Get New Keys for Selection', + command=self.get_new_keys, state=DISABLED) + #frame_key_sets + frames = [Frame(frame_key_sets, padx=2, pady=2, borderwidth=0) + for i in range(2)] + self.radio_keys_builtin = Radiobutton( + frames[0], variable=self.are_keys_builtin, value=1, + command=self.set_keys_type, text='Use a Built-in Key Set') + self.radio_keys_custom = Radiobutton( + frames[0], variable=self.are_keys_builtin, value=0, + command=self.set_keys_type, text='Use a Custom Key Set') + self.opt_menu_keys_builtin = DynOptionMenu( + frames[0], self.builtin_keys, None, command=None) + self.opt_menu_keys_custom = DynOptionMenu( + frames[0], self.custom_keys, None, command=None) + self.button_delete_custom_keys = Button( + frames[1], text='Delete Custom Key Set', + command=self.delete_custom_keys) + button_save_custom_keys = Button( + frames[1], text='Save as New Custom Key Set', + command=self.save_as_new_key_set) + self.new_custom_keys = Label(frames[0], bd=2) - If a new custom theme is selected, add the name to the - changed_items and apply the theme to the sample. - """ - value = self.custom_theme.get() - if value != '- no custom themes -': - changes.add_option('main', 'Theme', 'name', value) - self.paint_theme_sample() + ##widget packing + #body + frame_custom.pack(side=BOTTOM, padx=5, pady=5, expand=TRUE, fill=BOTH) + frame_key_sets.pack(side=BOTTOM, padx=5, pady=5, fill=BOTH) + #frame_custom + self.button_new_keys.pack(side=BOTTOM, fill=X, padx=5, pady=5) + frame_target.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) + #frame target + frame_target.columnconfigure(0, weight=1) + frame_target.rowconfigure(1, weight=1) + target_title.grid(row=0, column=0, columnspan=2, sticky=W) + self.list_bindings.grid(row=1, column=0, sticky=NSEW) + scroll_target_y.grid(row=1, column=1, sticky=NS) + scroll_target_x.grid(row=2, column=0, sticky=EW) + #frame_key_sets + self.radio_keys_builtin.grid(row=0, column=0, sticky=W+NS) + self.radio_keys_custom.grid(row=1, column=0, sticky=W+NS) + self.opt_menu_keys_builtin.grid(row=0, column=1, sticky=NSEW) + self.opt_menu_keys_custom.grid(row=1, column=1, sticky=NSEW) + self.new_custom_keys.grid(row=0, column=2, sticky=NSEW, padx=5, pady=5) + self.button_delete_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) + button_save_custom_keys.pack(side=LEFT, fill=X, expand=True, padx=2) + frames[0].pack(side=TOP, fill=BOTH, expand=True) + frames[1].pack(side=TOP, fill=X, expand=True, pady=2) + return frame - def var_changed_is_builtin_theme(self, *params): - """Process toggle between builtin and custom theme. + def load_key_cfg(self): + "Load current configuration settings for the keybinding options." + # Set current keys type radiobutton. + self.are_keys_builtin.set(idleConf.GetOption( + 'main', 'Keys', 'default', type='bool', default=1)) + # Set current keys. + current_option = idleConf.CurrentKeys() + # Load available keyset option menus. + if self.are_keys_builtin.get(): # Default theme selected. + item_list = idleConf.GetSectionList('default', 'keys') + item_list.sort() + self.opt_menu_keys_builtin.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + if not item_list: + self.radio_keys_custom['state'] = DISABLED + self.custom_keys.set('- no custom keys -') + else: + self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) + else: # User key set selected. + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + self.opt_menu_keys_custom.SetMenu(item_list, current_option) + item_list = idleConf.GetSectionList('default', 'keys') + item_list.sort() + self.opt_menu_keys_builtin.SetMenu(item_list, idleConf.default_keys()) + self.set_keys_type() + # Load keyset element list. + keyset_name = idleConf.CurrentKeys() + self.load_keys_list(keyset_name) - Update the default toggle value and apply the newly - selected theme type. - """ - value = self.is_builtin_theme.get() - changes.add_option('main', 'Theme', 'default', value) - if value: - self.var_changed_builtin_theme() - else: - self.var_changed_custom_theme() - def var_changed_highlight_target(self, *params): - "Process selection of new target tag for highlighting." - self.set_highlight_target() - def var_changed_keybinding(self, *params): - "Store change to a keybinding." - value = self.keybinding.get() - key_set = self.custom_keys.get() - event = self.list_bindings.get(ANCHOR).split()[0] - if idleConf.IsCoreBinding(event): - changes.add_option('keys', key_set, event, value) - else: # Event is an extension binding. - ext_name = idleConf.GetExtnNameForEvent(event) - ext_keybind_section = ext_name + '_cfgBindings' - changes.add_option('extensions', ext_keybind_section, event, value) def var_changed_builtin_keys(self, *params): "Process selection of builtin key set." @@ -1016,46 +1196,30 @@ def var_changed_builtin_keys(self, *params): def var_changed_custom_keys(self, *params): "Process selection of custom key set." value = self.custom_keys.get() - if value != '- no custom keys -': - changes.add_option('main', 'Keys', 'name', value) - self.load_keys_list(value) - - def var_changed_are_keys_builtin(self, *params): - "Process toggle between builtin key set and custom key set." - value = self.are_keys_builtin.get() - changes.add_option('main', 'Keys', 'default', value) - if value: - self.var_changed_builtin_keys() - else: - self.var_changed_custom_keys() - - def set_theme_type(self): - """Set available screen options based on builtin or custom theme. - - Attributes accessed: - is_builtin_theme - - Attributes updated: - opt_menu_theme_builtin - opt_menu_theme_custom - button_delete_custom_theme - radio_theme_custom + if value != '- no custom keys -': + changes.add_option('main', 'Keys', 'name', value) + self.load_keys_list(value) - Called from: - handler for radio_theme_builtin and radio_theme_custom - delete_custom_theme - create_new_theme - load_theme_cfg - """ - if self.is_builtin_theme.get(): - self.opt_menu_theme_builtin['state'] = NORMAL - self.opt_menu_theme_custom['state'] = DISABLED - self.button_delete_custom_theme['state'] = DISABLED + def var_changed_are_keys_builtin(self, *params): + "Process toggle between builtin key set and custom key set." + value = self.are_keys_builtin.get() + changes.add_option('main', 'Keys', 'default', value) + if value: + self.var_changed_builtin_keys() else: - self.opt_menu_theme_builtin['state'] = DISABLED - self.radio_theme_custom['state'] = NORMAL - self.opt_menu_theme_custom['state'] = NORMAL - self.button_delete_custom_theme['state'] = NORMAL + self.var_changed_custom_keys() + + def var_changed_keybinding(self, *params): + "Store change to a keybinding." + value = self.keybinding.get() + key_set = self.custom_keys.get() + event = self.list_bindings.get(ANCHOR).split()[0] + if idleConf.IsCoreBinding(event): + changes.add_option('keys', key_set, event, value) + else: # Event is an extension binding. + ext_name = idleConf.GetExtnNameForEvent(event) + ext_keybind_section = ext_name + '_cfgBindings' + changes.add_option('extensions', ext_keybind_section, event, value) def set_keys_type(self): "Set available screen options based on builtin or custom key set." @@ -1183,489 +1347,329 @@ def load_keys_list(self, keyset_name): if bind_name in changes['keys'][keyset_name]: key = changes['keys'][keyset_name][bind_name] self.list_bindings.insert(END, bind_name+' - '+key) - if reselect: - self.list_bindings.see(list_index) - self.list_bindings.select_set(list_index) - self.list_bindings.select_anchor(list_index) - - def delete_custom_keys(self): - """Handle event to delete a custom key set. - - Applying the delete deactivates the current configuration and - reverts to the default. The custom key set is permanently - deleted from the config file. - """ - keyset_name=self.custom_keys.get() - delmsg = 'Are you sure you wish to delete the key set %r ?' - if not tkMessageBox.askyesno( - 'Delete Key Set', delmsg % keyset_name, parent=self): - return - self.deactivate_current_config() - # Remove key set from changes, config, and file. - changes.delete_section('keys', keyset_name) - # Reload user key set list. - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - if not item_list: - self.radio_keys_custom['state'] = DISABLED - self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') - else: - self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) - # Revert to default key set. - self.are_keys_builtin.set(idleConf.defaultCfg['main'] - .Get('Keys', 'default')) - self.builtin_keys.set(idleConf.defaultCfg['main'].Get('Keys', 'name') - or idleConf.default_keys()) - # User can't back out of these changes, they must be applied now. - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - self.set_keys_type() - - def delete_custom_theme(self): - """Handle event to delete custom theme. - - The current theme is deactivated and the default theme is - activated. The custom theme is permanently removed from - the config file. - - Attributes accessed: - custom_theme - - Attributes updated: - radio_theme_custom - opt_menu_theme_custom - is_builtin_theme - builtin_theme - - Methods: - deactivate_current_config - save_all_changed_extensions - activate_config_changes - set_theme_type - """ - theme_name = self.custom_theme.get() - delmsg = 'Are you sure you wish to delete the theme %r ?' - if not tkMessageBox.askyesno( - 'Delete Theme', delmsg % theme_name, parent=self): - return - self.deactivate_current_config() - # Remove theme from changes, config, and file. - changes.delete_section('highlight', theme_name) - # Reload user theme list. - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - if not item_list: - self.radio_theme_custom['state'] = DISABLED - self.opt_menu_theme_custom.SetMenu(item_list, '- no custom themes -') - else: - self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) - # Revert to default theme. - self.is_builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'default')) - self.builtin_theme.set(idleConf.defaultCfg['main'].Get('Theme', 'name')) - # User can't back out of these changes, they must be applied now. - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - self.set_theme_type() - - def get_color(self): - """Handle button to select a new color for the target tag. - - If a new color is selected while using a builtin theme, a - name must be supplied to create a custom theme. - - Attributes accessed: - highlight_target - frame_color_set - is_builtin_theme - - Attributes updated: - color - - Methods: - get_new_theme_name - create_new_theme - """ - target = self.highlight_target.get() - prev_color = self.frame_color_set.cget('bg') - rgbTuplet, color_string = tkColorChooser.askcolor( - parent=self, title='Pick new color for : '+target, - initialcolor=prev_color) - if color_string and (color_string != prev_color): - # User didn't cancel and they chose a new color. - if self.is_builtin_theme.get(): # Current theme is a built-in. - message = ('Your changes will be saved as a new Custom Theme. ' - 'Enter a name for your new Custom Theme below.') - new_theme = self.get_new_theme_name(message) - if not new_theme: # User cancelled custom theme creation. - return - else: # Create new custom theme based on previously active theme. - self.create_new_theme(new_theme) - self.color.set(color_string) - else: # Current theme is user defined. - self.color.set(color_string) - - def on_new_color_set(self): - "Display sample of new color selection on the dialog." - new_color=self.color.get() - self.frame_color_set.config(bg=new_color) # Set sample. - plane ='foreground' if self.fg_bg_toggle.get() else 'background' - sample_element = self.theme_elements[self.highlight_target.get()][0] - self.highlight_sample.tag_config(sample_element, **{plane:new_color}) - theme = self.custom_theme.get() - theme_element = sample_element + '-' + plane - changes.add_option('highlight', theme, theme_element, new_color) - - def get_new_theme_name(self, message): - "Return name of new theme from query popup." - used_names = (idleConf.GetSectionList('user', 'highlight') + - idleConf.GetSectionList('default', 'highlight')) - new_theme = SectionName( - self, 'New Custom Theme', message, used_names).result - return new_theme - - def save_as_new_theme(self): - """Prompt for new theme name and create the theme. - - Methods: - get_new_theme_name - create_new_theme - """ - new_theme_name = self.get_new_theme_name('New Theme Name:') - if new_theme_name: - self.create_new_theme(new_theme_name) - - def create_new_theme(self, new_theme_name): - """Create a new custom theme with the given name. - - Create the new theme based on the previously active theme - with the current changes applied. Once it is saved, then - activate the new theme. - - Attributes accessed: - builtin_theme - custom_theme - - Attributes updated: - opt_menu_theme_custom - is_builtin_theme - - Method: - save_new_theme - set_theme_type - """ - if self.is_builtin_theme.get(): - theme_type = 'default' - theme_name = self.builtin_theme.get() - else: - theme_type = 'user' - theme_name = self.custom_theme.get() - new_theme = idleConf.GetThemeDict(theme_type, theme_name) - # Apply any of the old theme's unsaved changes to the new theme. - if theme_name in changes['highlight']: - theme_changes = changes['highlight'][theme_name] - for element in theme_changes: - new_theme[element] = theme_changes[element] - # Save the new theme. - self.save_new_theme(new_theme_name, new_theme) - # Change GUI over to the new theme. - custom_theme_list = idleConf.GetSectionList('user', 'highlight') - custom_theme_list.sort() - self.opt_menu_theme_custom.SetMenu(custom_theme_list, new_theme_name) - self.is_builtin_theme.set(0) - self.set_theme_type() - - def set_highlight_target(self): - """Set fg/bg toggle and color based on highlight tag target. - - Instance variables accessed: - highlight_target - - Attributes updated: - radio_fg - radio_bg - fg_bg_toggle - - Methods: - set_color_sample - - Called from: - var_changed_highlight_target - load_theme_cfg - """ - if self.highlight_target.get() == 'Cursor': # bg not possible - self.radio_fg['state'] = DISABLED - self.radio_bg['state'] = DISABLED - self.fg_bg_toggle.set(1) - else: # Both fg and bg can be set. - self.radio_fg['state'] = NORMAL - self.radio_bg['state'] = NORMAL - self.fg_bg_toggle.set(1) - self.set_color_sample() + if reselect: + self.list_bindings.see(list_index) + self.list_bindings.select_set(list_index) + self.list_bindings.select_anchor(list_index) - def set_color_sample_binding(self, *args): - """Change color sample based on foreground/background toggle. + def save_new_key_set(self, keyset_name, keyset): + """Save a newly created core key set. - Methods: - set_color_sample + keyset_name - string, the name of the new key set + keyset - dictionary containing the new key set """ - self.set_color_sample() - - def set_color_sample(self): - """Set the color of the frame background to reflect the selected target. + if not idleConf.userCfg['keys'].has_section(keyset_name): + idleConf.userCfg['keys'].add_section(keyset_name) + for event in keyset: + value = keyset[event] + idleConf.userCfg['keys'].SetOption(keyset_name, event, value) - Instance variables accessed: - theme_elements - highlight_target - fg_bg_toggle - highlight_sample + def delete_custom_keys(self): + """Handle event to delete a custom key set. - Attributes updated: - frame_color_set + Applying the delete deactivates the current configuration and + reverts to the default. The custom key set is permanently + deleted from the config file. """ - # Set the color sample area. - tag = self.theme_elements[self.highlight_target.get()][0] - plane = 'foreground' if self.fg_bg_toggle.get() else 'background' - color = self.highlight_sample.tag_cget(tag, plane) - self.frame_color_set.config(bg=color) - - def paint_theme_sample(self): - """Apply the theme colors to each element tag in the sample text. + keyset_name=self.custom_keys.get() + delmsg = 'Are you sure you wish to delete the key set %r ?' + if not tkMessageBox.askyesno( + 'Delete Key Set', delmsg % keyset_name, parent=self): + return + self.deactivate_current_config() + # Remove key set from changes, config, and file. + changes.delete_section('keys', keyset_name) + # Reload user key set list. + item_list = idleConf.GetSectionList('user', 'keys') + item_list.sort() + if not item_list: + self.radio_keys_custom['state'] = DISABLED + self.opt_menu_keys_custom.SetMenu(item_list, '- no custom keys -') + else: + self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) + # Revert to default key set. + self.are_keys_builtin.set(idleConf.defaultCfg['main'] + .Get('Keys', 'default')) + self.builtin_keys.set(idleConf.defaultCfg['main'].Get('Keys', 'name') + or idleConf.default_keys()) + # User can't back out of these changes, they must be applied now. + changes.save_all() + self.save_all_changed_extensions() + self.activate_config_changes() + self.set_keys_type() - Instance attributes accessed: - theme_elements - is_builtin_theme - builtin_theme - custom_theme + def deactivate_current_config(self): + """Remove current key bindings. - Attributes updated: - highlight_sample: Set the tag elements to the theme. + Iterate over window instances defined in parent and remove + the keybindings. + """ + # Before a config is saved, some cleanup of current + # config must be done - remove the previous keybindings. + win_instances = self.parent.instance_dict.keys() + for instance in win_instances: + instance.RemoveKeybindings() - Methods: - set_color_sample + def activate_config_changes(self): + """Apply configuration changes to current windows. - Called from: - var_changed_builtin_theme - var_changed_custom_theme - load_theme_cfg + Dynamically update the current parent window instances + with some of the configuration changes. """ - if self.is_builtin_theme.get(): # Default theme - theme = self.builtin_theme.get() - else: # User theme - theme = self.custom_theme.get() - for element_title in self.theme_elements: - element = self.theme_elements[element_title][0] - colors = idleConf.GetHighlight(theme, element) - if element == 'cursor': # Cursor sample needs special painting. - colors['background'] = idleConf.GetHighlight( - theme, 'normal', fgBg='bg') - # Handle any unsaved changes to this theme. - if theme in changes['highlight']: - theme_dict = changes['highlight'][theme] - if element + '-foreground' in theme_dict: - colors['foreground'] = theme_dict[element + '-foreground'] - if element + '-background' in theme_dict: - colors['background'] = theme_dict[element + '-background'] - self.highlight_sample.tag_config(element, **colors) - self.set_color_sample() - - def load_theme_cfg(self): - """Load current configuration settings for the theme options. + win_instances = self.parent.instance_dict.keys() + for instance in win_instances: + instance.ResetColorizer() + instance.ResetFont() + instance.set_notabs_indentwidth() + instance.ApplyKeybindings() + instance.reset_help_menu_entries() - Based on the is_builtin_theme toggle, the theme is set as - either builtin or custom and the initial widget values - reflect the current settings from idleConf. - Attributes updated: - is_builtin_theme: Set from idleConf. - opt_menu_theme_builtin: List of default themes from idleConf. - opt_menu_theme_custom: List of custom themes from idleConf. - radio_theme_custom: Disabled if there are no custom themes. - custom_theme: Message with additional information. - opt_menu_highlight_target: Create menu from self.theme_elements. + def create_page_general(self): + """Return frame of widgets for General tab. - Methods: - set_theme_type - paint_theme_sample - set_highlight_target - """ - # Set current theme type radiobutton. - self.is_builtin_theme.set(idleConf.GetOption( - 'main', 'Theme', 'default', type='bool', default=1)) - # Set current theme. - current_option = idleConf.CurrentTheme() - # Load available theme option menus. - if self.is_builtin_theme.get(): # Default theme selected. - item_list = idleConf.GetSectionList('default', 'highlight') - item_list.sort() - self.opt_menu_theme_builtin.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - if not item_list: - self.radio_theme_custom['state'] = DISABLED - self.custom_theme.set('- no custom themes -') - else: - self.opt_menu_theme_custom.SetMenu(item_list, item_list[0]) - else: # User theme selected. - item_list = idleConf.GetSectionList('user', 'highlight') - item_list.sort() - self.opt_menu_theme_custom.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('default', 'highlight') - item_list.sort() - self.opt_menu_theme_builtin.SetMenu(item_list, item_list[0]) - self.set_theme_type() - # Load theme element option menu. - theme_names = list(self.theme_elements.keys()) - theme_names.sort(key=lambda x: self.theme_elements[x][1]) - self.opt_menu_highlight_target.SetMenu(theme_names, theme_names[0]) - self.paint_theme_sample() - self.set_highlight_target() + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + var_changed_var_name callback that adds option to changes. - def load_key_cfg(self): - "Load current configuration settings for the keybinding options." - # Set current keys type radiobutton. - self.are_keys_builtin.set(idleConf.GetOption( - 'main', 'Keys', 'default', type='bool', default=1)) - # Set current keys. - current_option = idleConf.CurrentKeys() - # Load available keyset option menus. - if self.are_keys_builtin.get(): # Default theme selected. - item_list = idleConf.GetSectionList('default', 'keys') - item_list.sort() - self.opt_menu_keys_builtin.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - if not item_list: - self.radio_keys_custom['state'] = DISABLED - self.custom_keys.set('- no custom keys -') - else: - self.opt_menu_keys_custom.SetMenu(item_list, item_list[0]) - else: # User key set selected. - item_list = idleConf.GetSectionList('user', 'keys') - item_list.sort() - self.opt_menu_keys_custom.SetMenu(item_list, current_option) - item_list = idleConf.GetSectionList('default', 'keys') - item_list.sort() - self.opt_menu_keys_builtin.SetMenu(item_list, idleConf.default_keys()) - self.set_keys_type() - # Load keyset element list. - keyset_name = idleConf.CurrentKeys() - self.load_keys_list(keyset_name) + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. - def load_configs(self): - """Load configuration for each page. + Widget Structure: (*) widgets bound to self + frame + frame_run: LabelFrame + startup_title: Label + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit + frame_save: LabelFrame + run_save_title: Label + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave + frame_win_size: LabelFrame + win_size_title: Label + win_width_title: Label + (*)win_width_int: Entry - win_width + win_height_title: Label + (*)win_height_int: Entry - win_height + frame_help: LabelFrame + frame_helplist: Frame + frame_helplist_buttons: Frame + (*)button_helplist_edit + (*)button_helplist_add + (*)button_helplist_remove + (*)helplist: ListBox + scroll_helplist: Scrollbar + """ + parent = self.parent + self.startup_edit = IntVar(parent) + self.autosave = IntVar(parent) + self.win_width = StringVar(parent) + self.win_height = StringVar(parent) - Load configuration from default and user config files and populate - the widgets on the config dialog pages. + # Create widgets: + # body. + frame = self.tab_pages.pages['General'].frame + # body section frames. + frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' Startup Preferences ') + frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' autosave Preferences ') + frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) + frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, + text=' Additional Help Sources ') + # frame_run. + startup_title = Label(frame_run, text='At Startup') + self.startup_editor_on = Radiobutton( + frame_run, variable=self.startup_edit, value=1, + text="Open Edit Window") + self.startup_shell_on = Radiobutton( + frame_run, variable=self.startup_edit, value=0, + text='Open Shell Window') + # frame_save. + run_save_title = Label(frame_save, text='At Start of Run (F5) ') + self.save_ask_on = Radiobutton( + frame_save, variable=self.autosave, value=0, + text="Prompt to Save") + self.save_auto_on = Radiobutton( + frame_save, variable=self.autosave, value=1, + text='No Prompt') + # frame_win_size. + win_size_title = Label( + frame_win_size, text='Initial Window Size (in characters)') + win_width_title = Label(frame_win_size, text='Width') + self.win_width_int = Entry( + frame_win_size, textvariable=self.win_width, width=3) + win_height_title = Label(frame_win_size, text='Height') + self.win_height_int = Entry( + frame_win_size, textvariable=self.win_height, width=3) + # frame_help. + frame_helplist = Frame(frame_help) + frame_helplist_buttons = Frame(frame_helplist) + self.helplist = Listbox( + frame_helplist, height=5, takefocus=FALSE, + exportselection=FALSE) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) + self.button_helplist_edit = Button( + frame_helplist_buttons, text='Edit', state=DISABLED, + width=8, command=self.helplist_item_edit) + self.button_helplist_add = Button( + frame_helplist_buttons, text='Add', + width=8, command=self.helplist_item_add) + self.button_helplist_remove = Button( + frame_helplist_buttons, text='Remove', state=DISABLED, + width=8, command=self.helplist_item_remove) - Methods: - load_font_cfg - load_tab_cfg - load_theme_cfg - load_key_cfg - load_general_cfg - """ - self.load_font_cfg() - self.load_tab_cfg() - self.load_theme_cfg() - self.load_key_cfg() - self.load_general_cfg() - # note: extension page handled separately + # Pack widgets: + # body. + frame_run.pack(side=TOP, padx=5, pady=5, fill=X) + frame_save.pack(side=TOP, padx=5, pady=5, fill=X) + frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) + frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + # frame_run. + startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. + run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. + win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_height_title.pack(side=RIGHT, anchor=E, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_width_title.pack(side=RIGHT, anchor=E, pady=5) + # frame_help. + frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) + frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) + self.button_helplist_add.pack(side=TOP, anchor=W) + self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) - def save_new_key_set(self, keyset_name, keyset): - """Save a newly created core key set. + return frame - keyset_name - string, the name of the new key set - keyset - dictionary containing the new key set - """ - if not idleConf.userCfg['keys'].has_section(keyset_name): - idleConf.userCfg['keys'].add_section(keyset_name) - for event in keyset: - value = keyset[event] - idleConf.userCfg['keys'].SetOption(keyset_name, event, value) + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() - def save_new_theme(self, theme_name, theme): - """Save a newly created theme to idleConf. + def var_changed_startup_edit(self, *params): + "Store change to toggle for starting IDLE in the editor or shell." + value = self.startup_edit.get() + changes.add_option('main', 'General', 'editor-on-startup', value) - theme_name - string, the name of the new theme - theme - dictionary containing the new theme - """ - if not idleConf.userCfg['highlight'].has_section(theme_name): - idleConf.userCfg['highlight'].add_section(theme_name) - for element in theme: - value = theme[element] - idleConf.userCfg['highlight'].SetOption(theme_name, element, value) + def var_changed_autosave(self, *params): + "Store change to autosave." + value = self.autosave.get() + changes.add_option('main', 'General', 'autosave', value) - def deactivate_current_config(self): - """Remove current key bindings. + def var_changed_win_width(self, *params): + "Store change to window width." + value = self.win_width.get() + changes.add_option('main', 'EditorWindow', 'width', value) - Iterate over window instances defined in parent and remove - the keybindings. - """ - # Before a config is saved, some cleanup of current - # config must be done - remove the previous keybindings. - win_instances = self.parent.instance_dict.keys() - for instance in win_instances: - instance.RemoveKeybindings() + def var_changed_win_height(self, *params): + "Store change to window height." + value = self.win_height.get() + changes.add_option('main', 'EditorWindow', 'height', value) - def activate_config_changes(self): - """Apply configuration changes to current windows. + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() - Dynamically update the current parent window instances - with some of the configuration changes. - """ - win_instances = self.parent.instance_dict.keys() - for instance in win_instances: - instance.ResetColorizer() - instance.ResetFont() - instance.set_notabs_indentwidth() - instance.ApplyKeybindings() - instance.reset_help_menu_entries() + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED - def cancel(self): - """Dismiss config dialog. + def helplist_item_add(self): + """Handle add button for the help list. - Methods: - destroy: inherited + Query for name and location of new help sources and add + them to the list. """ - self.destroy() + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() - def ok(self): - """Apply config changes, then dismiss dialog. + def helplist_item_edit(self): + """Handle edit button for the help list. - Methods: - apply - destroy: inherited + Query with existing help source information and update + config if the values are changed. """ - self.apply() - self.destroy() + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected - def apply(self): - """Apply config changes and leave dialog open. + def helplist_item_remove(self): + """Handle remove button for the help list. - Methods: - deactivate_current_config - save_all_changed_extensions - activate_config_changes + Delete the help list item from config. """ - self.deactivate_current_config() - changes.save_all() - self.save_all_changed_extensions() - self.activate_config_changes() - - def help(self): - """Create textview for config dialog help. + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() - Attrbutes accessed: - tab_pages + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) - Methods: - view_text: Method from textview module. - """ - page = self.tab_pages._current_page - view_text(self, title='Help for IDLE preferences', - text=help_common+help_pages.get(page, '')) def create_page_extensions(self): """Part of the config dialog used for configuring IDLE extensions. diff --git a/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst b/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst new file mode 100644 index 00000000000..1d202c7fa2c --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-27-14-48-42.bpo-31060.GdY_VY.rst @@ -0,0 +1,3 @@ +IDLE - Finish rearranging methods of ConfigDialog Grouping methods +pertaining to each tab and the buttons will aid writing tests and improving +the tabs and will enable splitting the groups into classes. From webhook-mailer at python.org Fri Jul 28 03:02:13 2017 From: webhook-mailer at python.org (Ned Deily) Date: Fri, 28 Jul 2017 07:02:13 -0000 Subject: [Python-checkins] bpo-28095: Re-enable temporarily disabled part of test_startup_imports on macOS (#2927) Message-ID: https://github.com/python/cpython/commit/c22bd58d933efaec26d1f77f263b2845473b7e15 commit: c22bd58d933efaec26d1f77f263b2845473b7e15 branch: master author: Ned Deily committer: GitHub date: 2017-07-28T03:02:10-04:00 summary: bpo-28095: Re-enable temporarily disabled part of test_startup_imports on macOS (#2927) The changes for bpo-29585 eliminate the extra imports on macOS that caused the original test failure. This reverts commit 8a2150aae6db4d664c96a038ef6abacd4bcbcdc9. files: M Lib/test/test_site.py diff --git a/Lib/test/test_site.py b/Lib/test/test_site.py index bf7be4ec1c6..4975a770220 100644 --- a/Lib/test/test_site.py +++ b/Lib/test/test_site.py @@ -492,9 +492,7 @@ def test_startup_imports(self): 'heapq', 'itertools', 'keyword', 'operator', 'reprlib', 'types', 'weakref' }.difference(sys.builtin_module_names) - # http://bugs.python.org/issue28095 - if sys.platform != 'darwin': - self.assertFalse(modules.intersection(collection_mods), stderr) + self.assertFalse(modules.intersection(collection_mods), stderr) def test_startup_interactivehook(self): r = subprocess.Popen([sys.executable, '-c', From solipsis at pitrou.net Fri Jul 28 05:15:11 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Fri, 28 Jul 2017 09:15:11 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=0 Message-ID: <20170728091510.3777.6FB84FF27ECE8A2F@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_fork leaked [0, -2, 0] memory blocks, sum=-2 test_multiprocessing_forkserver leaked [0, 0, -2] memory blocks, sum=-2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogPz9FJY', '--timeout', '7200'] From webhook-mailer at python.org Fri Jul 28 08:28:23 2017 From: webhook-mailer at python.org (INADA Naoki) Date: Fri, 28 Jul 2017 12:28:23 -0000 Subject: [Python-checkins] bpo-29585: fix test fail on macOS Framework build (GH-2928) Message-ID: https://github.com/python/cpython/commit/ba9ddb7eea39a651ba7f1ab3eb012e4129c03620 commit: ba9ddb7eea39a651ba7f1ab3eb012e4129c03620 branch: master author: INADA Naoki committer: GitHub date: 2017-07-28T21:28:19+09:00 summary: bpo-29585: fix test fail on macOS Framework build (GH-2928) files: M Lib/test/test_site.py diff --git a/Lib/test/test_site.py b/Lib/test/test_site.py index 4975a770220..99e7b4f8402 100644 --- a/Lib/test/test_site.py +++ b/Lib/test/test_site.py @@ -184,8 +184,12 @@ def test_getuserbase(self): self.assertEqual(site._getuserbase(), sysconfig._getuserbase()) def test_get_path(self): + if sys.platform == 'darwin' and sys._framework: + scheme = 'osx_framework_user' + else: + scheme = os.name + '_user' self.assertEqual(site._get_path(site._getuserbase()), - sysconfig.get_path('purelib', os.name + '_user')) + sysconfig.get_path('purelib', scheme)) @unittest.skipUnless(site.ENABLE_USER_SITE, "requires access to PEP 370 " "user-site (site.ENABLE_USER_SITE)") From webhook-mailer at python.org Fri Jul 28 08:42:59 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Fri, 28 Jul 2017 12:42:59 -0000 Subject: [Python-checkins] bpo-30302: Update WhatsNew and documentation. (#2929) Message-ID: https://github.com/python/cpython/commit/8e45318b0d8df9340ac41b1d0447ffc83c7f5102 commit: 8e45318b0d8df9340ac41b1d0447ffc83c7f5102 branch: master author: Utkarsh Upadhyay committer: Victor Stinner date: 2017-07-28T14:42:56+02:00 summary: bpo-30302: Update WhatsNew and documentation. (#2929) * Update 'Porting to .37' section. * Fix a minor example in the doc. files: M Doc/library/datetime.rst M Doc/whatsnew/3.7.rst diff --git a/Doc/library/datetime.rst b/Doc/library/datetime.rst index 625e1590a87..3880c2eb0b7 100644 --- a/Doc/library/datetime.rst +++ b/Doc/library/datetime.rst @@ -313,7 +313,7 @@ Notes: unusual results for negative timedeltas. For example: >>> timedelta(hours=-5) - datetime.timedelta(-1, 68400) + datetime.timedelta(days=-1, seconds=68400) >>> print(_) -1 day, 19:00:00 diff --git a/Doc/whatsnew/3.7.rst b/Doc/whatsnew/3.7.rst index 023d0a1b238..21e9c568ae4 100644 --- a/Doc/whatsnew/3.7.rst +++ b/Doc/whatsnew/3.7.rst @@ -455,6 +455,9 @@ Changes in the Python API :func:`socket.fromshare` a socket :func:`~socket.socket.share`-ed in older Python versions. +* ``repr`` for :class:`datetime.timedelta` has changed to include keyword arguments + in the output. (Contributed by Utkarsh Upadhyay in :issue:`30302`.) + CPython bytecode changes ------------------------ From webhook-mailer at python.org Fri Jul 28 12:00:25 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Fri, 28 Jul 2017 16:00:25 -0000 Subject: [Python-checkins] bpo-31067: test_subprocess calls reap_children() (#2931) Message-ID: https://github.com/python/cpython/commit/cc42c121eb5346f673247f95dac575aadb77d66c commit: cc42c121eb5346f673247f95dac575aadb77d66c branch: master author: Victor Stinner committer: GitHub date: 2017-07-28T18:00:22+02:00 summary: bpo-31067: test_subprocess calls reap_children() (#2931) test_subprocess now also calls reap_children() in tearDown(), not only on setUp(). files: M Lib/test/test_subprocess.py diff --git a/Lib/test/test_subprocess.py b/Lib/test/test_subprocess.py index 4052c5ef525..a99976aa56f 100644 --- a/Lib/test/test_subprocess.py +++ b/Lib/test/test_subprocess.py @@ -56,6 +56,8 @@ def tearDown(self): inst.wait() subprocess._cleanup() self.assertFalse(subprocess._active, "subprocess._active not empty") + self.doCleanups() + support.reap_children() def assertStderrEqual(self, stderr, expected, msg=None): # In a debug build, stuff like "[6580 refs]" is printed to stderr at From webhook-mailer at python.org Fri Jul 28 12:15:05 2017 From: webhook-mailer at python.org (Victor Stinner) Date: Fri, 28 Jul 2017 16:15:05 -0000 Subject: [Python-checkins] bpo-31066: Fix test_httpservers.test_last_modified() (#2933) Message-ID: https://github.com/python/cpython/commit/28ce07ae9e34c70eea6b52515c7e00001cefd41e commit: 28ce07ae9e34c70eea6b52515c7e00001cefd41e branch: master author: Victor Stinner committer: GitHub date: 2017-07-28T18:15:02+02:00 summary: bpo-31066: Fix test_httpservers.test_last_modified() (#2933) Write the temporary file on disk and then get its modification time. files: M Lib/test/test_httpservers.py diff --git a/Lib/test/test_httpservers.py b/Lib/test/test_httpservers.py index cdc52021013..fb4ae1928ba 100644 --- a/Lib/test/test_httpservers.py +++ b/Lib/test/test_httpservers.py @@ -335,9 +335,11 @@ def setUp(self): self.tempdir = tempfile.mkdtemp(dir=basetempdir) self.tempdir_name = os.path.basename(self.tempdir) self.base_url = '/' + self.tempdir_name - with open(os.path.join(self.tempdir, 'test'), 'wb') as temp: + tempname = os.path.join(self.tempdir, 'test') + with open(tempname, 'wb') as temp: temp.write(self.data) - mtime = os.fstat(temp.fileno()).st_mtime + temp.flush() + mtime = os.stat(tempname).st_mtime # compute last modification datetime for browser cache tests last_modif = datetime.datetime.fromtimestamp(mtime, datetime.timezone.utc) @@ -471,7 +473,7 @@ def test_browser_cache(self): headers['If-Modified-Since'] = email.utils.format_datetime(new_dt, usegmt=True) response = self.request(self.base_url + '/test', headers=headers) - self.check_status_and_reason(response, HTTPStatus.NOT_MODIFIED) + self.check_status_and_reason(response, HTTPStatus.NOT_MODIFIED) def test_browser_cache_file_changed(self): # with If-Modified-Since earlier than Last-Modified, must return 200 @@ -491,7 +493,7 @@ def test_browser_cache_with_If_None_Match_header(self): headers['If-Modified-Since'] = self.last_modif_header headers['If-None-Match'] = "*" response = self.request(self.base_url + '/test', headers=headers) - self.check_status_and_reason(response, HTTPStatus.OK) + self.check_status_and_reason(response, HTTPStatus.OK) def test_invalid_requests(self): response = self.request('/', method='FOO') From webhook-mailer at python.org Fri Jul 28 13:39:40 2017 From: webhook-mailer at python.org (Mariatta) Date: Fri, 28 Jul 2017 17:39:40 -0000 Subject: [Python-checkins] Fix trivial typo in multiprocessing documentation (GH-2930) Message-ID: https://github.com/python/cpython/commit/6fcb69dad579cc9a7dc15eabead43b6c37464f8c commit: 6fcb69dad579cc9a7dc15eabead43b6c37464f8c branch: master author: Yuval Langer committer: Mariatta date: 2017-07-28T10:39:35-07:00 summary: Fix trivial typo in multiprocessing documentation (GH-2930) files: M Doc/library/multiprocessing.rst diff --git a/Doc/library/multiprocessing.rst b/Doc/library/multiprocessing.rst index 9318a750919..8d6d8707a0e 100644 --- a/Doc/library/multiprocessing.rst +++ b/Doc/library/multiprocessing.rst @@ -1040,7 +1040,7 @@ Connection objects are usually created using :func:`Pipe` -- see also .. method:: recv() Return an object sent from the other end of the connection using - :meth:`send`. Blocks until there its something to receive. Raises + :meth:`send`. Blocks until there is something to receive. Raises :exc:`EOFError` if there is nothing left to receive and the other end was closed. From webhook-mailer at python.org Fri Jul 28 14:41:03 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Fri, 28 Jul 2017 18:41:03 -0000 Subject: [Python-checkins] bpo-30853: IDLE: Convert font and general vars to use VarTrace (#2914) Message-ID: https://github.com/python/cpython/commit/5b59154c0d3d91c0766b9177f6b737b1abcbf3f6 commit: 5b59154c0d3d91c0766b9177f6b737b1abcbf3f6 branch: master author: csabella committer: Terry Jan Reedy date: 2017-07-28T14:40:59-04:00 summary: bpo-30853: IDLE: Convert font and general vars to use VarTrace (#2914) Instance tracers manages pairs consisting of a tk variable and a callback function. When tracing is turned on, setting the variable calls the function. Test coverage for the new class is 100%. files: A Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst M Lib/idlelib/configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index e359ec24cd3..92155e3726c 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -30,6 +30,7 @@ changes = ConfigChanges() + class ConfigDialog(Toplevel): """Config dialog for IDLE. """ @@ -75,13 +76,15 @@ def __init__(self, parent, title='', _htest=False, _utest=False): # self.bind('', self.Apply) #apply changes, save # self.bind('', self.Help) #context help self.load_configs() - self.attach_var_callbacks() # Avoid callbacks during load_configs. + # Avoid callbacks during load_configs. + tracers.attach() if not _utest: self.grab_set() self.wm_deiconify() self.wait_window() + def create_widgets(self): """Create and place widgets for tabbed dialog. @@ -96,7 +99,6 @@ def create_widgets(self): create_page_extensions create_action_buttons load_configs: Load pages except for extensions. - attach_var_callbacks remove_var_callbacks activate_config_changes: Tell editors to reload. """ @@ -131,37 +133,9 @@ def load_configs(self): self.load_general_cfg() # note: extension page handled separately - def attach_var_callbacks(self): - "Attach callbacks to variables that can be changed." - self.font_size.trace_add('write', self.var_changed_font) - self.font_name.trace_add('write', self.var_changed_font) - self.font_bold.trace_add('write', self.var_changed_font) - self.space_num.trace_add('write', self.var_changed_space_num) - self.color.trace_add('write', self.var_changed_color) - self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) - self.custom_theme.trace_add('write', self.var_changed_custom_theme) - self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) - self.highlight_target.trace_add('write', self.var_changed_highlight_target) - self.keybinding.trace_add('write', self.var_changed_keybinding) - self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) - self.custom_keys.trace_add('write', self.var_changed_custom_keys) - self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) - self.win_width.trace_add('write', self.var_changed_win_width) - self.win_height.trace_add('write', self.var_changed_win_height) - self.startup_edit.trace_add('write', self.var_changed_startup_edit) - self.autosave.trace_add('write', self.var_changed_autosave) - def remove_var_callbacks(self): "Remove callbacks to prevent memory leaks." - for var in ( - self.font_size, self.font_name, self.font_bold, - self.space_num, self.color, self.builtin_theme, - self.custom_theme, self.is_builtin_theme, self.highlight_target, - self.keybinding, self.builtin_keys, self.custom_keys, - self.are_keys_builtin, self.win_width, self.win_height, - self.startup_edit, self.autosave,): - var.trace_remove('write', var.trace_info()[0][1]) - + tracers.detach() def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -273,7 +247,7 @@ def create_page_font_tab(self): Tabs: Enable users to change spaces entered for indent tabs. Changing indent_scale value with the mouse sets Var space_num, - which invokes var_changed_space_num, which adds an entry to + which invokes the default callback to add an entry to changes. Load_tab_cfg initializes space_num to default. Widget Structure: (*) widgets bound to self @@ -294,10 +268,10 @@ def create_page_font_tab(self): (*)indent_scale: Scale - space_num """ parent = self.parent - self.font_name = StringVar(parent) - self.font_size = StringVar(parent) - self.font_bold = BooleanVar(parent) - self.space_num = IntVar(parent) + self.font_name = tracers.add(StringVar(parent), self.var_changed_font) + self.font_size = tracers.add(StringVar(parent), self.var_changed_font) + self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) + self.space_num = tracers.add(IntVar(parent), ('main', 'Indent', 'num-spaces')) # Create widgets: # body and body section frames. @@ -443,12 +417,6 @@ def load_tab_cfg(self): 'main', 'Indent', 'num-spaces', default=4, type='int') self.space_num.set(space_num) - def var_changed_space_num(self, *params): - "Store change to indentation size." - value = self.space_num.get() - changes.add_option('main', 'Indent', 'num-spaces', value) - - def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -518,12 +486,17 @@ def create_page_highlight(self): 'Shell Stderr Text': ('stderr', '13'), } parent = self.parent - self.builtin_theme = StringVar(parent) - self.custom_theme = StringVar(parent) + self.builtin_theme = tracers.add( + StringVar(parent), self.var_changed_builtin_theme) + self.custom_theme = tracers.add( + StringVar(parent), self.var_changed_custom_theme) self.fg_bg_toggle = BooleanVar(parent) - self.color = StringVar(parent) - self.is_builtin_theme = BooleanVar(parent) - self.highlight_target = StringVar(parent) + self.color = tracers.add( + StringVar(parent), self.var_changed_color) + self.is_builtin_theme = tracers.add( + BooleanVar(parent), self.var_changed_is_builtin_theme) + self.highlight_target = tracers.add( + StringVar(parent), self.var_changed_highlight_target) ##widget creation #body frame @@ -1062,10 +1035,14 @@ def create_page_keys(self): button_save_custom_keys: Button """ parent = self.parent - self.builtin_keys = StringVar(parent) - self.custom_keys = StringVar(parent) - self.are_keys_builtin = BooleanVar(parent) - self.keybinding = StringVar(parent) + self.builtin_keys = tracers.add( + StringVar(parent), self.var_changed_builtin_keys) + self.custom_keys = tracers.add( + StringVar(parent), self.var_changed_custom_keys) + self.are_keys_builtin = tracers.add( + BooleanVar(parent), self.var_changed_are_keys_builtin) + self.keybinding = tracers.add( + StringVar(parent), self.var_changed_keybinding) ##widget creation #body frame @@ -1169,9 +1146,6 @@ def load_key_cfg(self): keyset_name = idleConf.CurrentKeys() self.load_keys_list(keyset_name) - - - def var_changed_builtin_keys(self, *params): "Process selection of builtin key set." old_keys = ( @@ -1434,7 +1408,7 @@ def create_page_general(self): set var startup_edit. Radiobuttons save_ask_on and save_auto_on set var autosave. Entry boxes win_width_int and win_height_int set var win_width and win_height. Setting var_name invokes the - var_changed_var_name callback that adds option to changes. + default callback that adds option to changes. Helplist: load_general_cfg loads list user_helplist with name, position pairs and copies names to listbox helplist. @@ -1470,10 +1444,14 @@ def create_page_general(self): scroll_helplist: Scrollbar """ parent = self.parent - self.startup_edit = IntVar(parent) - self.autosave = IntVar(parent) - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) + self.startup_edit = tracers.add( + IntVar(parent), ('main', 'General', 'editor-on-startup')) + self.autosave = tracers.add( + IntVar(parent), ('main', 'General', 'autosave')) + self.win_width = tracers.add( + StringVar(parent), ('main', 'EditorWindow', 'width')) + self.win_height = tracers.add( + StringVar(parent), ('main', 'EditorWindow', 'height')) # Create widgets: # body. @@ -1873,9 +1851,9 @@ def add(self, var, callback): Args: var: Tk variable instance. - callback: Function to be used as a callback or - a tuple with IdleConf values for default - callback. + callback: Either function name to be used as a callback + or a tuple with IdleConf config-type, section, and + option names used in the default callback. Return: Tk variable instance. @@ -1908,6 +1886,8 @@ def detach(self): self.untraced.append((var, callback)) +tracers = VarTrace() + help_common = '''\ When you click either the Apply or Ok buttons, settings in this dialog that are different from IDLE's default are saved in diff --git a/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst b/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst new file mode 100644 index 00000000000..9cabca193b9 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst @@ -0,0 +1,5 @@ +IDLE -- Factor a VarTrace class out of ConfigDialog. + +Instance tracers manages pairs consisting of a tk variable and a +callback function. When tracing is turned on, setting the variable +calls the function. Test coverage for the new class is 100%. From webhook-mailer at python.org Fri Jul 28 15:42:46 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Fri, 28 Jul 2017 19:42:46 -0000 Subject: [Python-checkins] [3.6] bpo-30853: IDLE: Convert font and general vars to use VarTrace (GH-2914) (#2935) Message-ID: https://github.com/python/cpython/commit/02f88d2a411a6a789b33be281adfc3570c49efd5 commit: 02f88d2a411a6a789b33be281adfc3570c49efd5 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-28T15:42:43-04:00 summary: [3.6] bpo-30853: IDLE: Convert font and general vars to use VarTrace (GH-2914) (#2935) Instance tracers manages pairs consisting of a tk variable and a callback function. When tracing is turned on, setting the variable calls the function. Test coverage for the new class is 100%. (cherry picked from commit 5b59154) files: A Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst M Lib/idlelib/configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index e359ec24cd3..92155e3726c 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -30,6 +30,7 @@ changes = ConfigChanges() + class ConfigDialog(Toplevel): """Config dialog for IDLE. """ @@ -75,13 +76,15 @@ def __init__(self, parent, title='', _htest=False, _utest=False): # self.bind('', self.Apply) #apply changes, save # self.bind('', self.Help) #context help self.load_configs() - self.attach_var_callbacks() # Avoid callbacks during load_configs. + # Avoid callbacks during load_configs. + tracers.attach() if not _utest: self.grab_set() self.wm_deiconify() self.wait_window() + def create_widgets(self): """Create and place widgets for tabbed dialog. @@ -96,7 +99,6 @@ def create_widgets(self): create_page_extensions create_action_buttons load_configs: Load pages except for extensions. - attach_var_callbacks remove_var_callbacks activate_config_changes: Tell editors to reload. """ @@ -131,37 +133,9 @@ def load_configs(self): self.load_general_cfg() # note: extension page handled separately - def attach_var_callbacks(self): - "Attach callbacks to variables that can be changed." - self.font_size.trace_add('write', self.var_changed_font) - self.font_name.trace_add('write', self.var_changed_font) - self.font_bold.trace_add('write', self.var_changed_font) - self.space_num.trace_add('write', self.var_changed_space_num) - self.color.trace_add('write', self.var_changed_color) - self.builtin_theme.trace_add('write', self.var_changed_builtin_theme) - self.custom_theme.trace_add('write', self.var_changed_custom_theme) - self.is_builtin_theme.trace_add('write', self.var_changed_is_builtin_theme) - self.highlight_target.trace_add('write', self.var_changed_highlight_target) - self.keybinding.trace_add('write', self.var_changed_keybinding) - self.builtin_keys.trace_add('write', self.var_changed_builtin_keys) - self.custom_keys.trace_add('write', self.var_changed_custom_keys) - self.are_keys_builtin.trace_add('write', self.var_changed_are_keys_builtin) - self.win_width.trace_add('write', self.var_changed_win_width) - self.win_height.trace_add('write', self.var_changed_win_height) - self.startup_edit.trace_add('write', self.var_changed_startup_edit) - self.autosave.trace_add('write', self.var_changed_autosave) - def remove_var_callbacks(self): "Remove callbacks to prevent memory leaks." - for var in ( - self.font_size, self.font_name, self.font_bold, - self.space_num, self.color, self.builtin_theme, - self.custom_theme, self.is_builtin_theme, self.highlight_target, - self.keybinding, self.builtin_keys, self.custom_keys, - self.are_keys_builtin, self.win_width, self.win_height, - self.startup_edit, self.autosave,): - var.trace_remove('write', var.trace_info()[0][1]) - + tracers.detach() def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -273,7 +247,7 @@ def create_page_font_tab(self): Tabs: Enable users to change spaces entered for indent tabs. Changing indent_scale value with the mouse sets Var space_num, - which invokes var_changed_space_num, which adds an entry to + which invokes the default callback to add an entry to changes. Load_tab_cfg initializes space_num to default. Widget Structure: (*) widgets bound to self @@ -294,10 +268,10 @@ def create_page_font_tab(self): (*)indent_scale: Scale - space_num """ parent = self.parent - self.font_name = StringVar(parent) - self.font_size = StringVar(parent) - self.font_bold = BooleanVar(parent) - self.space_num = IntVar(parent) + self.font_name = tracers.add(StringVar(parent), self.var_changed_font) + self.font_size = tracers.add(StringVar(parent), self.var_changed_font) + self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) + self.space_num = tracers.add(IntVar(parent), ('main', 'Indent', 'num-spaces')) # Create widgets: # body and body section frames. @@ -443,12 +417,6 @@ def load_tab_cfg(self): 'main', 'Indent', 'num-spaces', default=4, type='int') self.space_num.set(space_num) - def var_changed_space_num(self, *params): - "Store change to indentation size." - value = self.space_num.get() - changes.add_option('main', 'Indent', 'num-spaces', value) - - def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -518,12 +486,17 @@ def create_page_highlight(self): 'Shell Stderr Text': ('stderr', '13'), } parent = self.parent - self.builtin_theme = StringVar(parent) - self.custom_theme = StringVar(parent) + self.builtin_theme = tracers.add( + StringVar(parent), self.var_changed_builtin_theme) + self.custom_theme = tracers.add( + StringVar(parent), self.var_changed_custom_theme) self.fg_bg_toggle = BooleanVar(parent) - self.color = StringVar(parent) - self.is_builtin_theme = BooleanVar(parent) - self.highlight_target = StringVar(parent) + self.color = tracers.add( + StringVar(parent), self.var_changed_color) + self.is_builtin_theme = tracers.add( + BooleanVar(parent), self.var_changed_is_builtin_theme) + self.highlight_target = tracers.add( + StringVar(parent), self.var_changed_highlight_target) ##widget creation #body frame @@ -1062,10 +1035,14 @@ def create_page_keys(self): button_save_custom_keys: Button """ parent = self.parent - self.builtin_keys = StringVar(parent) - self.custom_keys = StringVar(parent) - self.are_keys_builtin = BooleanVar(parent) - self.keybinding = StringVar(parent) + self.builtin_keys = tracers.add( + StringVar(parent), self.var_changed_builtin_keys) + self.custom_keys = tracers.add( + StringVar(parent), self.var_changed_custom_keys) + self.are_keys_builtin = tracers.add( + BooleanVar(parent), self.var_changed_are_keys_builtin) + self.keybinding = tracers.add( + StringVar(parent), self.var_changed_keybinding) ##widget creation #body frame @@ -1169,9 +1146,6 @@ def load_key_cfg(self): keyset_name = idleConf.CurrentKeys() self.load_keys_list(keyset_name) - - - def var_changed_builtin_keys(self, *params): "Process selection of builtin key set." old_keys = ( @@ -1434,7 +1408,7 @@ def create_page_general(self): set var startup_edit. Radiobuttons save_ask_on and save_auto_on set var autosave. Entry boxes win_width_int and win_height_int set var win_width and win_height. Setting var_name invokes the - var_changed_var_name callback that adds option to changes. + default callback that adds option to changes. Helplist: load_general_cfg loads list user_helplist with name, position pairs and copies names to listbox helplist. @@ -1470,10 +1444,14 @@ def create_page_general(self): scroll_helplist: Scrollbar """ parent = self.parent - self.startup_edit = IntVar(parent) - self.autosave = IntVar(parent) - self.win_width = StringVar(parent) - self.win_height = StringVar(parent) + self.startup_edit = tracers.add( + IntVar(parent), ('main', 'General', 'editor-on-startup')) + self.autosave = tracers.add( + IntVar(parent), ('main', 'General', 'autosave')) + self.win_width = tracers.add( + StringVar(parent), ('main', 'EditorWindow', 'width')) + self.win_height = tracers.add( + StringVar(parent), ('main', 'EditorWindow', 'height')) # Create widgets: # body. @@ -1873,9 +1851,9 @@ def add(self, var, callback): Args: var: Tk variable instance. - callback: Function to be used as a callback or - a tuple with IdleConf values for default - callback. + callback: Either function name to be used as a callback + or a tuple with IdleConf config-type, section, and + option names used in the default callback. Return: Tk variable instance. @@ -1908,6 +1886,8 @@ def detach(self): self.untraced.append((var, callback)) +tracers = VarTrace() + help_common = '''\ When you click either the Apply or Ok buttons, settings in this dialog that are different from IDLE's default are saved in diff --git a/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst b/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst new file mode 100644 index 00000000000..9cabca193b9 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-27-10-01-14.bpo-30853.enPvvc.rst @@ -0,0 +1,5 @@ +IDLE -- Factor a VarTrace class out of ConfigDialog. + +Instance tracers manages pairs consisting of a tk variable and a +callback function. When tracing is turned on, setting the variable +calls the function. Test coverage for the new class is 100%. From webhook-mailer at python.org Fri Jul 28 17:00:05 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Fri, 28 Jul 2017 21:00:05 -0000 Subject: [Python-checkins] bpo-30853: IDLE - touch-up configdialog.VarTrace and tests. (#2936) Message-ID: https://github.com/python/cpython/commit/5d0f30aae5fccc99690923fc5c7cb58de8ad7eec commit: 5d0f30aae5fccc99690923fc5c7cb58de8ad7eec branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-28T17:00:02-04:00 summary: bpo-30853: IDLE - touch-up configdialog.VarTrace and tests. (#2936) Add clear method for tests. Adjust tests to use global instance. Remove unneeded ConfigDialog method. files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 92155e3726c..87e0d685b77 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -99,7 +99,6 @@ def create_widgets(self): create_page_extensions create_action_buttons load_configs: Load pages except for extensions. - remove_var_callbacks activate_config_changes: Tell editors to reload. """ self.tab_pages = TabbedPageSet(self, @@ -133,10 +132,6 @@ def load_configs(self): self.load_general_cfg() # note: extension page handled separately - def remove_var_callbacks(self): - "Remove callbacks to prevent memory leaks." - tracers.detach() - def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -1846,6 +1841,11 @@ def __init__(self): self.untraced = [] self.traced = [] + def clear(self): + "Clear lists (for tests)." + self.untraced.clear() + self.traced.clear() + def add(self, var, callback): """Add (var, callback) tuple to untraced list. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 7296075fbec..cf6c3b31ed5 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -11,7 +11,7 @@ from idlelib.idle_test.mock_idle import Func from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL from idlelib import config -from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace +from idlelib.configdialog import idleConf, changes, tracers # Tests should not depend on fortuitous user configurations. # They must not affect actual user .cfg files. @@ -35,12 +35,12 @@ def setUpModule(): idleConf.userCfg = testcfg root = Tk() # root.withdraw() # Comment out, see issue 30870 - dialog = ConfigDialog(root, 'Test', _utest=True) + dialog = configdialog.ConfigDialog(root, 'Test', _utest=True) def tearDownModule(): global root, dialog idleConf.userCfg = usercfg - dialog.remove_var_callbacks() + tracers.detach() del dialog root.update_idletasks() root.destroy() @@ -423,14 +423,14 @@ def test_update_help_changes(self): d.update_help_changes = Func() -class TestVarTrace(unittest.TestCase): +class VarTraceTest(unittest.TestCase): def setUp(self): changes.clear() + tracers.clear() self.v1 = IntVar(root) self.v2 = BooleanVar(root) self.called = 0 - self.tracers = VarTrace() def tearDown(self): del self.v1, self.v2 @@ -442,11 +442,19 @@ def var_changed_boolean(self, *params): pass def test_init(self): - self.assertEqual(self.tracers.untraced, []) - self.assertEqual(self.tracers.traced, []) + tracers.__init__() + self.assertEqual(tracers.untraced, []) + self.assertEqual(tracers.traced, []) + + def test_clear(self): + tracers.untraced.append(0) + tracers.traced.append(1) + tracers.clear() + self.assertEqual(tracers.untraced, []) + self.assertEqual(tracers.traced, []) def test_add(self): - tr = self.tracers + tr = tracers func = Func() cb = tr.make_callback = mock.Mock(return_value=func) @@ -469,8 +477,7 @@ def test_add(self): del tr.make_callback def test_make_callback(self): - tr = self.tracers - cb = tr.make_callback(self.v1, ('main', 'section', 'option')) + cb = tracers.make_callback(self.v1, ('main', 'section', 'option')) self.assertTrue(callable(cb)) self.v1.set(42) # Not attached, so set didn't invoke the callback. @@ -481,7 +488,7 @@ def test_make_callback(self): self.assertEqual(changes['main']['section']['option'], '42') def test_attach_detach(self): - tr = self.tracers + tr = tracers v1 = tr.add(self.v1, self.var_changed_increment) v2 = tr.add(self.v2, self.var_changed_boolean) expected = [(v1, self.var_changed_increment), From lp_benchmark_robot at intel.com Fri Jul 28 18:01:59 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Fri, 28 Jul 2017 15:01:59 -0700 Subject: [Python-checkins] [65 flat] Results for Python (master branch) 2017-07-28 Message-ID: <31688e64-f604-4591-947a-24187499cb6e@orsmsx103.amr.corp.intel.com> Results for project python/master, build date: 2017-07-28 10:39:44-07:00. - commit: 6fcb69d - previous commit: d5ed47d - revision date: 2017-07-28 10:39:35-07:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.069% | +0.033% | +5.038% | +6.735% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.381% | +1.012% | +24.610% | +6.239% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 2.374% | -0.886% | +24.788% | +7.248% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.344% | +0.075% | +22.499% | +6.056% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.446% | -0.202% | +6.324% | +12.541% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.466% | +0.128% | +11.032% | +10.375% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 1.056% | -0.413% | +8.229% | +8.217% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 1.256% | -0.327% | +5.245% | +4.171% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 4.356% | +0.833% | +7.024% | +18.620% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.479% | +0.622% | +9.105% | +13.381% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.209% | -0.397% | +3.722% | +7.250% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.690% | -0.311% | +5.000% | +5.430% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.581% | -0.083% | +3.783% | +5.925% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.617% | -0.242% | +9.265% | +10.332% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.471% | -0.521% | +7.118% | +9.439% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 0.843% | -0.089% | +7.487% | +9.460% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 0.783% | -0.137% | +10.452% | +9.356% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.405% | -0.663% | +9.009% | +7.782% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.904% | -0.170% | +2.871% | +10.111% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 3.264% | -0.589% | +1.909% | +11.877% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.276% | -0.900% | +7.406% | +10.998% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_silent| 2.198% | +0.535% | +9.642% | +14.705% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.456% | -0.684% | +8.095% | +11.838% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 1.252% | -0.127% | +18.384% | +12.361% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 5.794% | +1.888% | +5.620% | +14.146% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 1.959% | +0.101% | +4.382% | +5.269% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 1.192% | -0.121% | -3.160% | +3.639% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 0.578% | +0.165% | +2.606% | +6.236% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.272% | +0.729% | +2.030% | +13.054% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 0.918% | +1.042% | +4.334% | +18.903% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.587% | +0.092% | +2.454% | +15.490% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 4.689% | -1.182% | +4.832% | +16.518% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.171% | -0.061% | +12.907% | +8.525% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.207% | +0.003% | +0.369% | +9.992% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.121% | -0.109% | +9.789% | +4.112% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.089% | -0.125% | +1.487% | +4.253% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 1.006% | +0.176% | +11.021% | +11.129% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 5.028% | -0.269% | -9.635% | +11.978% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 1.931% | -0.455% | +1.774% | +8.464% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 2.406% | +0.516% | -1.883% | +5.315% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 1.519% | -0.097% | +11.678% | +2.413% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 1.717% | -0.370% | +9.537% | +11.934% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.413% | +0.318% | +1.264% | +2.173% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.826% | +0.552% | +27.246% | +8.748% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.652% | +0.170% | +5.803% | +4.495% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 0.853% | -0.110% | +16.118% | +4.695% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 1.813% | -0.102% | +1.245% | -0.895% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.556% | +0.275% | +6.610% | -3.732% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.175% | -0.231% | +5.204% | +7.324% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.254% | -1.182% | +3.986% | +4.411% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 4.247% | -1.553% | +0.912% | +10.126% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.233% | -0.141% | +12.878% | +7.098% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.538% | -0.354% | +10.428% | +6.090% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 4.436% | -1.418% | +11.484% | +9.321% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.584% | -0.901% | +12.773% | +10.101% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 3.742% | +0.159% | +22.650% | +10.035% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.252% | -0.517% | +6.774% | +2.982% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 0.984% | -0.066% | +2.131% | +0.004% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 7.074% | +1.407% | +7.987% | +21.590% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.968% | -0.773% | -1.716% | +18.520% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 1.335% | +0.622% | +7.075% | +6.962% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.020% | -0.281% | +5.539% | +8.143% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.309% | -0.127% | +1.571% | +7.333% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 2.695% | -0.552% | -6.474% | +12.091% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.232% | +0.108% | +6.805% | +7.717% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/65-flat-results-for-python-master-branch-2017-07-28 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Fri Jul 28 18:36:33 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Fri, 28 Jul 2017 22:36:33 -0000 Subject: [Python-checkins] [3.6] bpo-30853: IDLE - touch-up configdialog.VarTrace and tests. (GH-2936) (#2937) Message-ID: https://github.com/python/cpython/commit/ecc80b3f1b56f1e4df9e592f8527e622a6b45e01 commit: ecc80b3f1b56f1e4df9e592f8527e622a6b45e01 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-28T18:36:30-04:00 summary: [3.6] bpo-30853: IDLE - touch-up configdialog.VarTrace and tests. (GH-2936) (#2937) Add clear method for tests. Adjust tests to use global instance. Remove unneeded ConfigDialog method. (cherry picked from commit 5d0f30a) files: M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 92155e3726c..87e0d685b77 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -99,7 +99,6 @@ def create_widgets(self): create_page_extensions create_action_buttons load_configs: Load pages except for extensions. - remove_var_callbacks activate_config_changes: Tell editors to reload. """ self.tab_pages = TabbedPageSet(self, @@ -133,10 +132,6 @@ def load_configs(self): self.load_general_cfg() # note: extension page handled separately - def remove_var_callbacks(self): - "Remove callbacks to prevent memory leaks." - tracers.detach() - def create_action_buttons(self): """Return frame of action buttons for dialog. @@ -1846,6 +1841,11 @@ def __init__(self): self.untraced = [] self.traced = [] + def clear(self): + "Clear lists (for tests)." + self.untraced.clear() + self.traced.clear() + def add(self, var, callback): """Add (var, callback) tuple to untraced list. diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 7296075fbec..cf6c3b31ed5 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -11,7 +11,7 @@ from idlelib.idle_test.mock_idle import Func from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL from idlelib import config -from idlelib.configdialog import ConfigDialog, idleConf, changes, VarTrace +from idlelib.configdialog import idleConf, changes, tracers # Tests should not depend on fortuitous user configurations. # They must not affect actual user .cfg files. @@ -35,12 +35,12 @@ def setUpModule(): idleConf.userCfg = testcfg root = Tk() # root.withdraw() # Comment out, see issue 30870 - dialog = ConfigDialog(root, 'Test', _utest=True) + dialog = configdialog.ConfigDialog(root, 'Test', _utest=True) def tearDownModule(): global root, dialog idleConf.userCfg = usercfg - dialog.remove_var_callbacks() + tracers.detach() del dialog root.update_idletasks() root.destroy() @@ -423,14 +423,14 @@ def test_update_help_changes(self): d.update_help_changes = Func() -class TestVarTrace(unittest.TestCase): +class VarTraceTest(unittest.TestCase): def setUp(self): changes.clear() + tracers.clear() self.v1 = IntVar(root) self.v2 = BooleanVar(root) self.called = 0 - self.tracers = VarTrace() def tearDown(self): del self.v1, self.v2 @@ -442,11 +442,19 @@ def var_changed_boolean(self, *params): pass def test_init(self): - self.assertEqual(self.tracers.untraced, []) - self.assertEqual(self.tracers.traced, []) + tracers.__init__() + self.assertEqual(tracers.untraced, []) + self.assertEqual(tracers.traced, []) + + def test_clear(self): + tracers.untraced.append(0) + tracers.traced.append(1) + tracers.clear() + self.assertEqual(tracers.untraced, []) + self.assertEqual(tracers.traced, []) def test_add(self): - tr = self.tracers + tr = tracers func = Func() cb = tr.make_callback = mock.Mock(return_value=func) @@ -469,8 +477,7 @@ def test_add(self): del tr.make_callback def test_make_callback(self): - tr = self.tracers - cb = tr.make_callback(self.v1, ('main', 'section', 'option')) + cb = tracers.make_callback(self.v1, ('main', 'section', 'option')) self.assertTrue(callable(cb)) self.v1.set(42) # Not attached, so set didn't invoke the callback. @@ -481,7 +488,7 @@ def test_make_callback(self): self.assertEqual(changes['main']['section']['option'], '42') def test_attach_detach(self): - tr = self.tracers + tr = tracers v1 = tr.add(self.v1, self.var_changed_increment) v2 = tr.add(self.v2, self.var_changed_boolean) expected = [(v1, self.var_changed_increment), From webhook-mailer at python.org Fri Jul 28 22:55:07 2017 From: webhook-mailer at python.org (Mariatta) Date: Sat, 29 Jul 2017 02:55:07 -0000 Subject: [Python-checkins] Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2942) Message-ID: https://github.com/python/cpython/commit/fa90179e071668c431e725a29f8c88d8d25ec887 commit: fa90179e071668c431e725a29f8c88d8d25ec887 branch: 2.7 author: Mariatta committer: GitHub date: 2017-07-28T19:55:04-07:00 summary: Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2942) (cherry picked from commit 6fcb69dad579cc9a7dc15eabead43b6c37464f8c) files: M Doc/library/multiprocessing.rst diff --git a/Doc/library/multiprocessing.rst b/Doc/library/multiprocessing.rst index b393ad13451..97a7b536670 100644 --- a/Doc/library/multiprocessing.rst +++ b/Doc/library/multiprocessing.rst @@ -822,7 +822,7 @@ Connection objects are usually created using :func:`Pipe` -- see also .. method:: recv() Return an object sent from the other end of the connection using - :meth:`send`. Blocks until there its something to receive. Raises + :meth:`send`. Blocks until there is something to receive. Raises :exc:`EOFError` if there is nothing left to receive and the other end was closed. From webhook-mailer at python.org Fri Jul 28 22:55:26 2017 From: webhook-mailer at python.org (Mariatta) Date: Sat, 29 Jul 2017 02:55:26 -0000 Subject: [Python-checkins] Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2940) Message-ID: https://github.com/python/cpython/commit/e05119ad4e8285dfc48050a15ebe0cbaa066e310 commit: e05119ad4e8285dfc48050a15ebe0cbaa066e310 branch: 3.6 author: Mariatta committer: GitHub date: 2017-07-28T19:55:23-07:00 summary: Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2940) (cherry picked from commit 6fcb69dad579cc9a7dc15eabead43b6c37464f8c) files: M Doc/library/multiprocessing.rst diff --git a/Doc/library/multiprocessing.rst b/Doc/library/multiprocessing.rst index 96d1424126c..2f770b63223 100644 --- a/Doc/library/multiprocessing.rst +++ b/Doc/library/multiprocessing.rst @@ -1024,7 +1024,7 @@ Connection objects are usually created using :func:`Pipe` -- see also .. method:: recv() Return an object sent from the other end of the connection using - :meth:`send`. Blocks until there its something to receive. Raises + :meth:`send`. Blocks until there is something to receive. Raises :exc:`EOFError` if there is nothing left to receive and the other end was closed. From webhook-mailer at python.org Fri Jul 28 22:56:16 2017 From: webhook-mailer at python.org (Mariatta) Date: Sat, 29 Jul 2017 02:56:16 -0000 Subject: [Python-checkins] Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2941) Message-ID: https://github.com/python/cpython/commit/52c41f18086f3d8b1eb3854b568f04717c724e3d commit: 52c41f18086f3d8b1eb3854b568f04717c724e3d branch: 3.5 author: Mariatta committer: GitHub date: 2017-07-28T19:56:13-07:00 summary: Fix trivial typo in multiprocessing documentation (GH-2930) (GH-2941) (cherry picked from commit 6fcb69dad579cc9a7dc15eabead43b6c37464f8c) files: M Doc/library/multiprocessing.rst diff --git a/Doc/library/multiprocessing.rst b/Doc/library/multiprocessing.rst index d45bc2065dc..04ce8d86c17 100644 --- a/Doc/library/multiprocessing.rst +++ b/Doc/library/multiprocessing.rst @@ -1018,7 +1018,7 @@ Connection objects are usually created using :func:`Pipe` -- see also .. method:: recv() Return an object sent from the other end of the connection using - :meth:`send`. Blocks until there its something to receive. Raises + :meth:`send`. Blocks until there is something to receive. Raises :exc:`EOFError` if there is nothing left to receive and the other end was closed. From webhook-mailer at python.org Sat Jul 29 00:49:41 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 04:49:41 -0000 Subject: [Python-checkins] bpo-30781: IDLE - Use ttk Notebook in ConfigDialog (#2938) Message-ID: https://github.com/python/cpython/commit/b331f80b4765c3201674a7ca8b35c9d4a65efe79 commit: b331f80b4765c3201674a7ca8b35c9d4a65efe79 branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-29T00:49:39-04:00 summary: bpo-30781: IDLE - Use ttk Notebook in ConfigDialog (#2938) The notebook looks a bit better. It will work better with separate page classes. Traversal of widgets by Tab works better. Switching tabs with keys becomes possible. The font sample box works better at large font sizes. One of the two simulated click tests no longer works. This will be investigated while fixing a bug with the widget itself. files: A Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 87e0d685b77..67165298a99 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -15,7 +15,7 @@ TOP, BOTTOM, RIGHT, LEFT, SOLID, GROOVE, NORMAL, DISABLED, NONE, BOTH, X, Y, W, E, EW, NS, NSEW, NW, HORIZONTAL, VERTICAL, ANCHOR, ACTIVE, END) -from tkinter.ttk import Scrollbar +from tkinter.ttk import Notebook, Scrollbar import tkinter.colorchooser as tkColorChooser import tkinter.font as tkFont import tkinter.messagebox as tkMessageBox @@ -101,15 +101,19 @@ def create_widgets(self): load_configs: Load pages except for extensions. activate_config_changes: Tell editors to reload. """ - self.tab_pages = TabbedPageSet(self, - page_names=['Fonts/Tabs', 'Highlighting', 'Keys', 'General', - 'Extensions']) - self.tab_pages.pack(side=TOP, expand=TRUE, fill=BOTH) - self.create_page_font_tab() - self.create_page_highlight() - self.create_page_keys() - self.create_page_general() - self.create_page_extensions() + self.note = note = Notebook(self, width=450, height=450) + fontpage = self.create_page_font_tab() + highpage = self.create_page_highlight() + keyspage = self.create_page_keys() + genpage = self.create_page_general() + extpage = self.create_page_extensions() + note.add(fontpage, text='Fonts/Tabs') + note.add(highpage, text='Highlights') + note.add(keyspage, text=' Keys ') + note.add(genpage, text=' General ') + note.add(extpage, text='Extensions') + note.enable_traversal() + note.pack(side=TOP, expand=TRUE, fill=BOTH) self.create_action_buttons().pack(side=BOTTOM) def load_configs(self): @@ -270,7 +274,7 @@ def create_page_font_tab(self): # Create widgets: # body and body section frames. - frame = self.tab_pages.pages['Fonts/Tabs'].frame + frame = Frame(self.note) frame_font = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') frame_indent = LabelFrame( @@ -281,7 +285,7 @@ def create_page_font_tab(self): font_name_title = Label( frame_font_name, justify=LEFT, text='Font Face :') self.fontlist = Listbox(frame_font_name, height=5, - takefocus=FALSE, exportselection=FALSE) + takefocus=True, exportselection=FALSE) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) @@ -297,7 +301,7 @@ def create_page_font_tab(self): temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( frame_font_sample, justify=LEFT, font=temp_font, - text='AaBbCcDdEe\nFfGgHhIiJjK\n1234567890\n#:+=(){}[]') + text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') # frame_indent. indent_title = Label( frame_indent, justify=LEFT, @@ -493,10 +497,9 @@ def create_page_highlight(self): self.highlight_target = tracers.add( StringVar(parent), self.var_changed_highlight_target) - ##widget creation - #body frame - frame = self.tab_pages.pages['Highlighting'].frame - #body section frames + # Widget creation: + # body frame and section frames + frame = Frame(self.note) frame_custom = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Custom Highlighting ') frame_theme = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -504,12 +507,12 @@ def create_page_highlight(self): #frame_custom self.highlight_sample=Text( frame_custom, relief=SOLID, borderwidth=1, - font=('courier', 12, ''), cursor='hand2', width=21, height=11, + font=('courier', 12, ''), cursor='hand2', width=21, height=13, takefocus=FALSE, highlightthickness=0, wrap=NONE) text=self.highlight_sample text.bind('', lambda e: 'break') text.bind('', lambda e: 'break') - text_and_tags=( + text_and_tags=(('\n', 'normal'), ('#you can click here', 'comment'), ('\n', 'normal'), ('#to choose items', 'comment'), ('\n', 'normal'), ('def', 'keyword'), (' ', 'normal'), @@ -525,7 +528,7 @@ def create_page_highlight(self): ('cursor |', 'cursor'), ('\n ', 'normal'), ('shell', 'console'), (' ', 'normal'), ('stdout', 'stdout'), (' ', 'normal'), - ('stderr', 'stderr'), ('\n', 'normal')) + ('stderr', 'stderr'), ('\n\n', 'normal')) for texttag in text_and_tags: text.insert(END, texttag[0], texttag[1]) for element in self.theme_elements: @@ -1039,10 +1042,9 @@ def create_page_keys(self): self.keybinding = tracers.add( StringVar(parent), self.var_changed_keybinding) - ##widget creation - #body frame - frame = self.tab_pages.pages['Keys'].frame - #body section frames + # Widget creation: + # body and section frames. + frame = Frame(self.note) frame_custom = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Custom Key Bindings ') @@ -1449,9 +1451,8 @@ def create_page_general(self): StringVar(parent), ('main', 'EditorWindow', 'height')) # Create widgets: - # body. - frame = self.tab_pages.pages['General'].frame - # body section frames. + # body and section frames. + frame = Frame(self.note) frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Startup Preferences ') frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -1488,7 +1489,7 @@ def create_page_general(self): frame_helplist = Frame(frame_help) frame_helplist_buttons = Frame(frame_helplist) self.helplist = Listbox( - frame_helplist, height=5, takefocus=FALSE, + frame_helplist, height=5, takefocus=True, exportselection=FALSE) scroll_helplist = Scrollbar(frame_helplist) scroll_helplist['command'] = self.helplist.yview @@ -1669,7 +1670,7 @@ def create_page_extensions(self): save_all_changed_extensions: Call extension page Save(). """ parent = self.parent - frame = self.tab_pages.pages['Extensions'].frame + frame = Frame(self.note) self.ext_defaultCfg = idleConf.defaultCfg['extensions'] self.ext_userCfg = idleConf.userCfg['extensions'] self.is_int = self.register(is_int) @@ -1704,6 +1705,8 @@ def create_page_extensions(self): self.extension_list.selection_set(0) self.extension_selected(None) + return frame + def load_extensions(self): "Fill self.extensions with data from the default and user configs." self.extensions = {} diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index cf6c3b31ed5..aff3c2fdc3b 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -296,20 +296,24 @@ def test_source_selected(self): d.set = d.set_add_delete_state d.upc = d.update_help_changes helplist = d.helplist - helplist.insert(0, 'source') - helplist.activate(0) + dex = 'end' + helplist.insert(dex, 'source') + helplist.activate(dex) helplist.focus_force() - helplist.see(0) + helplist.see(dex) helplist.update() - x, y, dx, dy = helplist.bbox(0) + x, y, dx, dy = helplist.bbox(dex) x += dx // 2 y += dy // 2 d.set.called = d.upc.called = 0 + helplist.event_generate('', x=0, y=0) + helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) - self.assertEqual(helplist.get('anchor'), 'source') - self.assertTrue(d.set.called) + # The following fail after the switch to + # self.assertEqual(helplist.get('anchor'), 'source') + # self.assertTrue(d.set.called) self.assertFalse(d.upc.called) def test_set_add_delete_state(self): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst b/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst new file mode 100644 index 00000000000..18f40a41f29 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst @@ -0,0 +1 @@ +IDLE - Use ttk Notebook in ConfigDialog From webhook-mailer at python.org Sat Jul 29 01:28:08 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 05:28:08 -0000 Subject: [Python-checkins] [3.6] bpo-30781: IDLE - Use ttk Notebook in ConfigDialog (GH-2938) (#2944) Message-ID: https://github.com/python/cpython/commit/8364feff6730f54063116b607605167d9027ce85 commit: 8364feff6730f54063116b607605167d9027ce85 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-29T01:28:05-04:00 summary: [3.6] bpo-30781: IDLE - Use ttk Notebook in ConfigDialog (GH-2938) (#2944) The notebook looks a bit better. It will work better with separate page classes. Traversal of widgets by Tab works better. Switching tabs with keys becomes possible. The font sample box works better at large font sizes. One of the two simulated click tests no longer works. This will be investigated while fixing a bug with the widget itself. (cherry picked from commit b331f80) files: A Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 87e0d685b77..67165298a99 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -15,7 +15,7 @@ TOP, BOTTOM, RIGHT, LEFT, SOLID, GROOVE, NORMAL, DISABLED, NONE, BOTH, X, Y, W, E, EW, NS, NSEW, NW, HORIZONTAL, VERTICAL, ANCHOR, ACTIVE, END) -from tkinter.ttk import Scrollbar +from tkinter.ttk import Notebook, Scrollbar import tkinter.colorchooser as tkColorChooser import tkinter.font as tkFont import tkinter.messagebox as tkMessageBox @@ -101,15 +101,19 @@ def create_widgets(self): load_configs: Load pages except for extensions. activate_config_changes: Tell editors to reload. """ - self.tab_pages = TabbedPageSet(self, - page_names=['Fonts/Tabs', 'Highlighting', 'Keys', 'General', - 'Extensions']) - self.tab_pages.pack(side=TOP, expand=TRUE, fill=BOTH) - self.create_page_font_tab() - self.create_page_highlight() - self.create_page_keys() - self.create_page_general() - self.create_page_extensions() + self.note = note = Notebook(self, width=450, height=450) + fontpage = self.create_page_font_tab() + highpage = self.create_page_highlight() + keyspage = self.create_page_keys() + genpage = self.create_page_general() + extpage = self.create_page_extensions() + note.add(fontpage, text='Fonts/Tabs') + note.add(highpage, text='Highlights') + note.add(keyspage, text=' Keys ') + note.add(genpage, text=' General ') + note.add(extpage, text='Extensions') + note.enable_traversal() + note.pack(side=TOP, expand=TRUE, fill=BOTH) self.create_action_buttons().pack(side=BOTTOM) def load_configs(self): @@ -270,7 +274,7 @@ def create_page_font_tab(self): # Create widgets: # body and body section frames. - frame = self.tab_pages.pages['Fonts/Tabs'].frame + frame = Frame(self.note) frame_font = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') frame_indent = LabelFrame( @@ -281,7 +285,7 @@ def create_page_font_tab(self): font_name_title = Label( frame_font_name, justify=LEFT, text='Font Face :') self.fontlist = Listbox(frame_font_name, height=5, - takefocus=FALSE, exportselection=FALSE) + takefocus=True, exportselection=FALSE) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) self.fontlist.bind('', self.on_fontlist_select) @@ -297,7 +301,7 @@ def create_page_font_tab(self): temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) self.font_sample = Label( frame_font_sample, justify=LEFT, font=temp_font, - text='AaBbCcDdEe\nFfGgHhIiJjK\n1234567890\n#:+=(){}[]') + text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') # frame_indent. indent_title = Label( frame_indent, justify=LEFT, @@ -493,10 +497,9 @@ def create_page_highlight(self): self.highlight_target = tracers.add( StringVar(parent), self.var_changed_highlight_target) - ##widget creation - #body frame - frame = self.tab_pages.pages['Highlighting'].frame - #body section frames + # Widget creation: + # body frame and section frames + frame = Frame(self.note) frame_custom = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Custom Highlighting ') frame_theme = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -504,12 +507,12 @@ def create_page_highlight(self): #frame_custom self.highlight_sample=Text( frame_custom, relief=SOLID, borderwidth=1, - font=('courier', 12, ''), cursor='hand2', width=21, height=11, + font=('courier', 12, ''), cursor='hand2', width=21, height=13, takefocus=FALSE, highlightthickness=0, wrap=NONE) text=self.highlight_sample text.bind('', lambda e: 'break') text.bind('', lambda e: 'break') - text_and_tags=( + text_and_tags=(('\n', 'normal'), ('#you can click here', 'comment'), ('\n', 'normal'), ('#to choose items', 'comment'), ('\n', 'normal'), ('def', 'keyword'), (' ', 'normal'), @@ -525,7 +528,7 @@ def create_page_highlight(self): ('cursor |', 'cursor'), ('\n ', 'normal'), ('shell', 'console'), (' ', 'normal'), ('stdout', 'stdout'), (' ', 'normal'), - ('stderr', 'stderr'), ('\n', 'normal')) + ('stderr', 'stderr'), ('\n\n', 'normal')) for texttag in text_and_tags: text.insert(END, texttag[0], texttag[1]) for element in self.theme_elements: @@ -1039,10 +1042,9 @@ def create_page_keys(self): self.keybinding = tracers.add( StringVar(parent), self.var_changed_keybinding) - ##widget creation - #body frame - frame = self.tab_pages.pages['Keys'].frame - #body section frames + # Widget creation: + # body and section frames. + frame = Frame(self.note) frame_custom = LabelFrame( frame, borderwidth=2, relief=GROOVE, text=' Custom Key Bindings ') @@ -1449,9 +1451,8 @@ def create_page_general(self): StringVar(parent), ('main', 'EditorWindow', 'height')) # Create widgets: - # body. - frame = self.tab_pages.pages['General'].frame - # body section frames. + # body and section frames. + frame = Frame(self.note) frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Startup Preferences ') frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, @@ -1488,7 +1489,7 @@ def create_page_general(self): frame_helplist = Frame(frame_help) frame_helplist_buttons = Frame(frame_helplist) self.helplist = Listbox( - frame_helplist, height=5, takefocus=FALSE, + frame_helplist, height=5, takefocus=True, exportselection=FALSE) scroll_helplist = Scrollbar(frame_helplist) scroll_helplist['command'] = self.helplist.yview @@ -1669,7 +1670,7 @@ def create_page_extensions(self): save_all_changed_extensions: Call extension page Save(). """ parent = self.parent - frame = self.tab_pages.pages['Extensions'].frame + frame = Frame(self.note) self.ext_defaultCfg = idleConf.defaultCfg['extensions'] self.ext_userCfg = idleConf.userCfg['extensions'] self.is_int = self.register(is_int) @@ -1704,6 +1705,8 @@ def create_page_extensions(self): self.extension_list.selection_set(0) self.extension_selected(None) + return frame + def load_extensions(self): "Fill self.extensions with data from the default and user configs." self.extensions = {} diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index cf6c3b31ed5..aff3c2fdc3b 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -296,20 +296,24 @@ def test_source_selected(self): d.set = d.set_add_delete_state d.upc = d.update_help_changes helplist = d.helplist - helplist.insert(0, 'source') - helplist.activate(0) + dex = 'end' + helplist.insert(dex, 'source') + helplist.activate(dex) helplist.focus_force() - helplist.see(0) + helplist.see(dex) helplist.update() - x, y, dx, dy = helplist.bbox(0) + x, y, dx, dy = helplist.bbox(dex) x += dx // 2 y += dy // 2 d.set.called = d.upc.called = 0 + helplist.event_generate('', x=0, y=0) + helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) - self.assertEqual(helplist.get('anchor'), 'source') - self.assertTrue(d.set.called) + # The following fail after the switch to + # self.assertEqual(helplist.get('anchor'), 'source') + # self.assertTrue(d.set.called) self.assertFalse(d.upc.called) def test_set_add_delete_state(self): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst b/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst new file mode 100644 index 00000000000..18f40a41f29 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-28-18-59-06.bpo-30781.ud5m18.rst @@ -0,0 +1 @@ +IDLE - Use ttk Notebook in ConfigDialog From solipsis at pitrou.net Sat Jul 29 05:06:58 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sat, 29 Jul 2017 09:06:58 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=5 Message-ID: <20170729090658.15224.8005525B8F5BDB4B@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [7, -7, 1] memory blocks, sum=1 test_functools leaked [0, 3, 1] memory blocks, sum=4 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogmoPpUi', '--timeout', '7200'] From webhook-mailer at python.org Sat Jul 29 12:05:58 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 16:05:58 -0000 Subject: [Python-checkins] bpo-31027: Fix test_listcomps failure when run directly (#2939) Message-ID: https://github.com/python/cpython/commit/ceb93f4540981e3f9af66bd936920186aba813fc commit: ceb93f4540981e3f9af66bd936920186aba813fc branch: master author: Zackery Spytz committer: Terry Jan Reedy date: 2017-07-29T12:05:55-04:00 summary: bpo-31027: Fix test_listcomps failure when run directly (#2939) Bug appears to be incomplete copy-paste-edit. files: M Lib/test/test_listcomps.py diff --git a/Lib/test/test_listcomps.py b/Lib/test/test_listcomps.py index 1f8265f077e..ddb169fe589 100644 --- a/Lib/test/test_listcomps.py +++ b/Lib/test/test_listcomps.py @@ -139,7 +139,7 @@ def test_main(verbose=None): import gc counts = [None] * 5 for i in range(len(counts)): - support.run_doctest(test_genexps, verbose) + support.run_doctest(test_listcomps, verbose) gc.collect() counts[i] = sys.gettotalrefcount() print(counts) From webhook-mailer at python.org Sat Jul 29 14:38:27 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 18:38:27 -0000 Subject: [Python-checkins] [3.6] bpo-31027: Fix test_listcomps failure when run directly (GH-2939) (#2945) Message-ID: https://github.com/python/cpython/commit/b26cc82b2252dd54e73661a026b32e7808fef945 commit: b26cc82b2252dd54e73661a026b32e7808fef945 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-29T14:38:24-04:00 summary: [3.6] bpo-31027: Fix test_listcomps failure when run directly (GH-2939) (#2945) Bug appears to be incomplete copy-paste-edit. (cherry picked from commit ceb93f4) files: M Lib/test/test_listcomps.py diff --git a/Lib/test/test_listcomps.py b/Lib/test/test_listcomps.py index 1f8265f077e..ddb169fe589 100644 --- a/Lib/test/test_listcomps.py +++ b/Lib/test/test_listcomps.py @@ -139,7 +139,7 @@ def test_main(verbose=None): import gc counts = [None] * 5 for i in range(len(counts)): - support.run_doctest(test_genexps, verbose) + support.run_doctest(test_listcomps, verbose) gc.collect() counts[i] = sys.gettotalrefcount() print(counts) From webhook-mailer at python.org Sat Jul 29 15:18:16 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 19:18:16 -0000 Subject: [Python-checkins] bpo-30803: clarify truth value testing documentation (#2508) Message-ID: https://github.com/python/cpython/commit/caa1280d1ee5f828f346b585169a7592371d3faa commit: caa1280d1ee5f828f346b585169a7592371d3faa branch: master author: Peter Thomassen committer: Terry Jan Reedy date: 2017-07-29T15:18:13-04:00 summary: bpo-30803: clarify truth value testing documentation (#2508) Initial patch by Peter Thomassen. files: A Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst M Doc/library/stdtypes.rst diff --git a/Doc/library/stdtypes.rst b/Doc/library/stdtypes.rst index 564579e70c5..2fce851e2e0 100644 --- a/Doc/library/stdtypes.rst +++ b/Doc/library/stdtypes.rst @@ -39,31 +39,26 @@ Truth Value Testing single: false Any object can be tested for truth value, for use in an :keyword:`if` or -:keyword:`while` condition or as operand of the Boolean operations below. The -following values are considered false: +:keyword:`while` condition or as operand of the Boolean operations below. - .. index:: single: None (Built-in object) - -* ``None`` - - .. index:: single: False (Built-in object) - -* ``False`` - -* zero of any numeric type, for example, ``0``, ``0.0``, ``0j``. +.. index:: single: true -* any empty sequence, for example, ``''``, ``()``, ``[]``. +By default, an object is considered true unless its class defines either a +:meth:`__bool__` method that returns ``False`` or a :meth:`__len__` method that +returns zero, when called with the object. [1]_ Here are most of the built-in +objects considered false: -* any empty mapping, for example, ``{}``. + .. index:: + single: None (Built-in object) + single: False (Built-in object) -* instances of user-defined classes, if the class defines a :meth:`__bool__` or - :meth:`__len__` method, when that method returns the integer zero or - :class:`bool` value ``False``. [1]_ +* constants defined to be false: ``None`` and ``False``. -.. index:: single: true +* zero of any numeric type: ``0``, ``0.0``, ``0j``, ``Decimal(0)``, + ``Fraction(0, 1)`` -All other values are considered true --- so objects of many types are always -true. +* empty sequences and collections: ``''``, ``()``, ``[]``, ``{}``, ``set()``, + ``range(0)`` .. index:: operator: or diff --git a/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst b/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst new file mode 100644 index 00000000000..4699713ee6e --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst @@ -0,0 +1 @@ +Clarify doc on truth value testing. Original patch by Peter Thomassen. From webhook-mailer at python.org Sat Jul 29 18:56:09 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sat, 29 Jul 2017 22:56:09 -0000 Subject: [Python-checkins] [3.6] bpo-30803: clarify truth value testing documentation (GH-2508) (#2946) Message-ID: https://github.com/python/cpython/commit/4c7b368de7bcabdd821059c023c46c9d85668d3f commit: 4c7b368de7bcabdd821059c023c46c9d85668d3f branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-29T18:56:06-04:00 summary: [3.6] bpo-30803: clarify truth value testing documentation (GH-2508) (#2946) Initial patch by Peter Thomassen. (cherry picked from commit caa1280) files: A Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst M Doc/library/stdtypes.rst diff --git a/Doc/library/stdtypes.rst b/Doc/library/stdtypes.rst index e929f0b6876..b8c4d59363d 100644 --- a/Doc/library/stdtypes.rst +++ b/Doc/library/stdtypes.rst @@ -39,31 +39,26 @@ Truth Value Testing single: false Any object can be tested for truth value, for use in an :keyword:`if` or -:keyword:`while` condition or as operand of the Boolean operations below. The -following values are considered false: +:keyword:`while` condition or as operand of the Boolean operations below. - .. index:: single: None (Built-in object) - -* ``None`` - - .. index:: single: False (Built-in object) - -* ``False`` - -* zero of any numeric type, for example, ``0``, ``0.0``, ``0j``. +.. index:: single: true -* any empty sequence, for example, ``''``, ``()``, ``[]``. +By default, an object is considered true unless its class defines either a +:meth:`__bool__` method that returns ``False`` or a :meth:`__len__` method that +returns zero, when called with the object. [1]_ Here are most of the built-in +objects considered false: -* any empty mapping, for example, ``{}``. + .. index:: + single: None (Built-in object) + single: False (Built-in object) -* instances of user-defined classes, if the class defines a :meth:`__bool__` or - :meth:`__len__` method, when that method returns the integer zero or - :class:`bool` value ``False``. [1]_ +* constants defined to be false: ``None`` and ``False``. -.. index:: single: true +* zero of any numeric type: ``0``, ``0.0``, ``0j``, ``Decimal(0)``, + ``Fraction(0, 1)`` -All other values are considered true --- so objects of many types are always -true. +* empty sequences and collections: ``''``, ``()``, ``[]``, ``{}``, ``set()``, + ``range(0)`` .. index:: operator: or diff --git a/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst b/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst new file mode 100644 index 00000000000..4699713ee6e --- /dev/null +++ b/Misc/NEWS.d/next/Documentation/2017-07-29-14-55-50.bpo-30803.6hutqQ.rst @@ -0,0 +1 @@ +Clarify doc on truth value testing. Original patch by Peter Thomassen. From solipsis at pitrou.net Sun Jul 30 05:07:22 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Sun, 30 Jul 2017 09:07:22 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=5 Message-ID: <20170730090722.118981.32CDB3A1CDB5518B@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_asyncio leaked [0, 0, 3] memory blocks, sum=3 test_collections leaked [0, 7, -7] memory blocks, sum=0 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [0, 0, -2] memory blocks, sum=-2 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogSklKPW', '--timeout', '7200'] From webhook-mailer at python.org Sun Jul 30 05:36:36 2017 From: webhook-mailer at python.org (Vinay Sajip) Date: Sun, 30 Jul 2017 09:36:36 -0000 Subject: [Python-checkins] bpo-30962: Added caching to Logger.isEnabledFor() (GH-2752) Message-ID: https://github.com/python/cpython/commit/78c18a9b9a1445f7c755929917a790ba02b4a5e0 commit: 78c18a9b9a1445f7c755929917a790ba02b4a5e0 branch: master author: Avram Lubkin committer: Vinay Sajip date: 2017-07-30T10:36:33+01:00 summary: bpo-30962: Added caching to Logger.isEnabledFor() (GH-2752) files: M Lib/logging/__init__.py M Lib/test/test_logging.py diff --git a/Lib/logging/__init__.py b/Lib/logging/__init__.py index 64e24eef50e..f9bfb79ae66 100644 --- a/Lib/logging/__init__.py +++ b/Lib/logging/__init__.py @@ -1244,6 +1244,19 @@ def _fixupChildren(self, ph, alogger): alogger.parent = c.parent c.parent = alogger + def _clear_cache(self): + """ + Clear the cache for all loggers in loggerDict + Called when level changes are made + """ + + _acquireLock() + for logger in self.loggerDict.values(): + if isinstance(logger, Logger): + logger._cache.clear() + self.root._cache.clear() + _releaseLock() + #--------------------------------------------------------------------------- # Logger classes and functions #--------------------------------------------------------------------------- @@ -1274,12 +1287,14 @@ def __init__(self, name, level=NOTSET): self.propagate = True self.handlers = [] self.disabled = False + self._cache = {} def setLevel(self, level): """ Set the logging level of this logger. level must be an int or a str. """ self.level = _checkLevel(level) + self.manager._clear_cache() def debug(self, msg, *args, **kwargs): """ @@ -1543,9 +1558,17 @@ def isEnabledFor(self, level): """ Is this logger enabled for level 'level'? """ - if self.manager.disable >= level: - return False - return level >= self.getEffectiveLevel() + try: + return self._cache[level] + except KeyError: + _acquireLock() + if self.manager.disable >= level: + is_enabled = self._cache[level] = False + else: + is_enabled = self._cache[level] = level >= self.getEffectiveLevel() + _releaseLock() + + return is_enabled def getChild(self, suffix): """ @@ -1910,6 +1933,7 @@ def disable(level=CRITICAL): Disable all logging calls of severity 'level' and below. """ root.manager.disable = level + root.manager._clear_cache() def shutdown(handlerList=_handlerList): """ diff --git a/Lib/test/test_logging.py b/Lib/test/test_logging.py index 880f4e89fb0..88845629614 100644 --- a/Lib/test/test_logging.py +++ b/Lib/test/test_logging.py @@ -135,7 +135,9 @@ def tearDown(self): logging._handlers.clear() logging._handlers.update(self.saved_handlers) logging._handlerList[:] = self.saved_handler_list - loggerDict = logging.getLogger().manager.loggerDict + manager = logging.getLogger().manager + manager.disable = 0 + loggerDict = manager.loggerDict loggerDict.clear() loggerDict.update(self.saved_loggers) logger_states = self.logger_states @@ -4094,6 +4096,62 @@ def test_pickling(self): unpickled = pickle.loads(s) self.assertIs(unpickled, logger) + def test_caching(self): + root = self.root_logger + logger1 = logging.getLogger("abc") + logger2 = logging.getLogger("abc.def") + + # Set root logger level and ensure cache is empty + root.setLevel(logging.ERROR) + self.assertEqual(logger2.getEffectiveLevel(), logging.ERROR) + self.assertEqual(logger2._cache, {}) + + # Ensure cache is populated and calls are consistent + self.assertTrue(logger2.isEnabledFor(logging.ERROR)) + self.assertFalse(logger2.isEnabledFor(logging.DEBUG)) + self.assertEqual(logger2._cache, {logging.ERROR: True, logging.DEBUG: False}) + self.assertEqual(root._cache, {}) + self.assertTrue(logger2.isEnabledFor(logging.ERROR)) + + # Ensure root cache gets populated + self.assertEqual(root._cache, {}) + self.assertTrue(root.isEnabledFor(logging.ERROR)) + self.assertEqual(root._cache, {logging.ERROR: True}) + + # Set parent logger level and ensure caches are emptied + logger1.setLevel(logging.CRITICAL) + self.assertEqual(logger2.getEffectiveLevel(), logging.CRITICAL) + self.assertEqual(logger2._cache, {}) + + # Ensure logger2 uses parent logger's effective level + self.assertFalse(logger2.isEnabledFor(logging.ERROR)) + + # Set level to NOTSET and ensure caches are empty + logger2.setLevel(logging.NOTSET) + self.assertEqual(logger2.getEffectiveLevel(), logging.CRITICAL) + self.assertEqual(logger2._cache, {}) + self.assertEqual(logger1._cache, {}) + self.assertEqual(root._cache, {}) + + # Verify logger2 follows parent and not root + self.assertFalse(logger2.isEnabledFor(logging.ERROR)) + self.assertTrue(logger2.isEnabledFor(logging.CRITICAL)) + self.assertFalse(logger1.isEnabledFor(logging.ERROR)) + self.assertTrue(logger1.isEnabledFor(logging.CRITICAL)) + self.assertTrue(root.isEnabledFor(logging.ERROR)) + + # Disable logging in manager and ensure caches are clear + logging.disable() + self.assertEqual(logger2.getEffectiveLevel(), logging.CRITICAL) + self.assertEqual(logger2._cache, {}) + self.assertEqual(logger1._cache, {}) + self.assertEqual(root._cache, {}) + + # Ensure no loggers are enabled + self.assertFalse(logger1.isEnabledFor(logging.CRITICAL)) + self.assertFalse(logger2.isEnabledFor(logging.CRITICAL)) + self.assertFalse(root.isEnabledFor(logging.CRITICAL)) + class BaseFileTest(BaseTest): "Base class for handler tests that write log files" From webhook-mailer at python.org Sun Jul 30 05:41:48 2017 From: webhook-mailer at python.org (Vinay Sajip) Date: Sun, 30 Jul 2017 09:41:48 -0000 Subject: [Python-checkins] bpo-30522: Implemented a method to allow setting a logging.StreamHander's stream. (GH-2921) Message-ID: https://github.com/python/cpython/commit/2543f50033208c1a8df04999082b11aa09e82a04 commit: 2543f50033208c1a8df04999082b11aa09e82a04 branch: master author: Vinay Sajip committer: GitHub date: 2017-07-30T10:41:45+01:00 summary: bpo-30522: Implemented a method to allow setting a logging.StreamHander's stream. (GH-2921) files: A Misc/NEWS.d/next/Library/2017-07-30-10-07-58.bpo-30522.gAX1N-.rst M Doc/library/logging.handlers.rst M Lib/logging/__init__.py M Lib/test/test_logging.py diff --git a/Doc/library/logging.handlers.rst b/Doc/library/logging.handlers.rst index f13f765c019..0974286e55d 100644 --- a/Doc/library/logging.handlers.rst +++ b/Doc/library/logging.handlers.rst @@ -59,6 +59,18 @@ and :meth:`flush` methods). :meth:`close` method is inherited from :class:`~logging.Handler` and so does no output, so an explicit :meth:`flush` call may be needed at times. + .. method:: setStream(stream) + + Sets the instance's stream to the specified value, if it is different. + The old stream is flushed before the new stream is set. + + :param stream: The stream that the handler should use. + + :return: the old stream, if the stream was changed, or *None* if it wasn't. + + .. versionadded:: 3.7 + + .. versionchanged:: 3.2 The ``StreamHandler`` class now has a ``terminator`` attribute, default value ``'\n'``, which is used as the terminator when writing a formatted @@ -66,6 +78,7 @@ and :meth:`flush` methods). set the handler instance's ``terminator`` attribute to the empty string. In earlier versions, the terminator was hardcoded as ``'\n'``. + .. _file-handler: FileHandler diff --git a/Lib/logging/__init__.py b/Lib/logging/__init__.py index f9bfb79ae66..54d4e883d97 100644 --- a/Lib/logging/__init__.py +++ b/Lib/logging/__init__.py @@ -997,6 +997,26 @@ def emit(self, record): except Exception: self.handleError(record) + def setStream(self, stream): + """ + Sets the StreamHandler's stream to the specified value, + if it is different. + + Returns the old stream, if the stream was changed, or None + if it wasn't. + """ + if stream is self.stream: + result = None + else: + result = self.stream + self.acquire() + try: + self.flush() + self.stream = stream + finally: + self.release() + return result + def __repr__(self): level = getLevelName(self.level) name = getattr(self.stream, 'name', '') diff --git a/Lib/test/test_logging.py b/Lib/test/test_logging.py index 88845629614..6d0b23441ba 100644 --- a/Lib/test/test_logging.py +++ b/Lib/test/test_logging.py @@ -698,6 +698,20 @@ def test_error_handling(self): finally: logging.raiseExceptions = old_raise + def test_stream_setting(self): + """ + Test setting the handler's stream + """ + h = logging.StreamHandler() + stream = io.StringIO() + old = h.setStream(stream) + self.assertIs(old, sys.stderr) + actual = h.setStream(old) + self.assertIs(actual, stream) + # test that setting to existing value returns None + actual = h.setStream(old) + self.assertIsNone(actual) + # -- The following section could be moved into a server_helper.py module # -- if it proves to be of wider utility than just test_logging diff --git a/Misc/NEWS.d/next/Library/2017-07-30-10-07-58.bpo-30522.gAX1N-.rst b/Misc/NEWS.d/next/Library/2017-07-30-10-07-58.bpo-30522.gAX1N-.rst new file mode 100644 index 00000000000..214f98e101c --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-30-10-07-58.bpo-30522.gAX1N-.rst @@ -0,0 +1,2 @@ +Added a ``setStream`` method to ``logging.StreamHandler`` to allow the +stream to be set after creation. From webhook-mailer at python.org Sun Jul 30 06:25:26 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 10:25:26 -0000 Subject: [Python-checkins] bpo-30928: Update IDLE News.txt. (#2948) Message-ID: https://github.com/python/cpython/commit/c3aa47f655abe564a2c2fb6d091ab19bdc0113b5 commit: c3aa47f655abe564a2c2fb6d091ab19bdc0113b5 branch: master author: Terry Jan Reedy committer: GitHub date: 2017-07-30T06:25:22-04:00 summary: bpo-30928: Update IDLE News.txt. (#2948) files: M Lib/idlelib/NEWS.txt diff --git a/Lib/idlelib/NEWS.txt b/Lib/idlelib/NEWS.txt index 9cde4a6bc5b..7d6d362e2d5 100644 --- a/Lib/idlelib/NEWS.txt +++ b/Lib/idlelib/NEWS.txt @@ -3,6 +3,44 @@ Released on 2018-06-18? ======================== +bpo-30781: IDLE - Use ttk Notebook in ConfigDialog. +Patch by Terry Jan Reedy. + +bpo-31060: IDLE - Finish rearranging methods of ConfigDialog. +Grouping methods pertaining to each tab and the buttons will aid +writing tests and improving the tabs and will enable splitting the +groups into classes. +Patch by Terry Jan Reedy. + +bpo-30853: IDLE -- Factor a VarTrace class out of ConfigDialog. +Instance tracers manages pairs consisting of a tk variable and a +callback function. When tracing is turned on, setting the variable +calls the function. Test coverage for the new class is 100%. +Patch by Terry Jan Reedy. + +bpo-31003: IDLE: Add more tests for General tab. +Patch by Terry Jan Reedy. + +bpo-30993: IDLE - Improve configdialog font page and tests. +*In configdialog: Document causal pathways in create_font_tab +docstring. Simplify some attribute names. Move set_samples calls to +var_changed_font (idea from Cheryl Sabella). Move related functions to +positions after the create widgets function. +* In test_configdialog: Fix test_font_set so not order dependent. Fix +renamed test_indent_scale so it tests the widget. Adjust tests for +movement of set_samples call. Add tests for load functions. Put all +font tests in one class and tab indent tests in another. Except for +two lines, these tests completely cover the related functions. +Patch by Terry Jan Reedy. + +bpo-30981: IDLE -- Add more configdialog font page tests. + +bpo-28523: IDLE: replace 'colour' with 'color' in configdialog. + +bpo-30917: Add tests for idlelib.config.IdleConf. +Increase coverage from 46% to 96%. +Patch by Louie Lu. + bpo-30913: Document ConfigDialog tk Vars, methods, and widgets in docstrings This will facilitate improving the dialog and splitting up the class. Original patch by Cheryl Sabella. @@ -11,7 +49,7 @@ bpo-30899: Add tests for ConfigParser subclasses in config. Coverage is 100% for those classes and ConfigChanges. Patch by Louie Lu. -bpo-30881: Add docstrings to browser.py. +bpo-30881: Add docstrings to browser.py. Patch by Cheryl Sabella. bpo-30851: Remove unused tk variables in configdialog. @@ -48,7 +86,7 @@ bp0-30723: Make several improvements to parenmatch. * Make 'default' style, which is not default, a synonym for 'opener'. * Make time-delay work the same with all styles. * Add help for config dialog extensions tab, including parenmatch. -* Add new tests. +* Add new tests. Original patch by Charles Wohlganger. Revisions by Terry Jan Reedy bpo-30674: Grep -- Add docstrings. Patch by Cheryl Sabella. From webhook-mailer at python.org Sun Jul 30 13:34:28 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 17:34:28 -0000 Subject: [Python-checkins] bpo-31004: IDLE: Factor out FontPage class from configdialog (step 1) (#2905) Message-ID: https://github.com/python/cpython/commit/9397e2a87ed6e0e724ad71a0c751553620cb775e commit: 9397e2a87ed6e0e724ad71a0c751553620cb775e branch: master author: csabella committer: Terry Jan Reedy date: 2017-07-30T13:34:25-04:00 summary: bpo-31004: IDLE: Factor out FontPage class from configdialog (step 1) (#2905) The slightly modified tests continue to pass. The General test broken by the switch to Notebook is fixed. Patch mostly by Cheryl Sabella. files: A Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 67165298a99..92bbc106344 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -69,7 +69,7 @@ def __init__(self, parent, title='', _htest=False, _utest=False): self.resizable(height=FALSE, width=FALSE) self.transient(parent) self.protocol("WM_DELETE_WINDOW", self.cancel) - self.fontlist.focus_set() + self.fontpage.fontlist.focus_set() # XXX Decide whether to keep or delete these key bindings. # Key bindings for this dialog. # self.bind('', self.Cancel) #dismiss dialog, no save @@ -102,16 +102,16 @@ def create_widgets(self): activate_config_changes: Tell editors to reload. """ self.note = note = Notebook(self, width=450, height=450) - fontpage = self.create_page_font_tab() - highpage = self.create_page_highlight() - keyspage = self.create_page_keys() - genpage = self.create_page_general() - extpage = self.create_page_extensions() - note.add(fontpage, text='Fonts/Tabs') - note.add(highpage, text='Highlights') - note.add(keyspage, text=' Keys ') - note.add(genpage, text=' General ') - note.add(extpage, text='Extensions') + self.highpage = self.create_page_highlight() + self.fontpage = FontPage(note, self.highpage) + self.keyspage = self.create_page_keys() + self.genpage = self.create_page_general() + self.extpage = self.create_page_extensions() + note.add(self.fontpage, text='Fonts/Tabs') + note.add(self.highpage, text='Highlights') + note.add(self.keyspage, text=' Keys ') + note.add(self.genpage, text=' General ') + note.add(self.extpage, text='Extensions') note.enable_traversal() note.pack(side=TOP, expand=TRUE, fill=BOTH) self.create_action_buttons().pack(side=BOTTOM) @@ -129,8 +129,8 @@ def load_configs(self): load_key_cfg load_general_cfg """ - self.load_font_cfg() - self.load_tab_cfg() + #self.load_font_cfg() + #self.load_tab_cfg() self.load_theme_cfg() self.load_key_cfg() self.load_general_cfg() @@ -219,203 +219,6 @@ def help(self): text=help_common+help_pages.get(page, '')) - def create_page_font_tab(self): - """Return frame of widgets for Font/Tabs tab. - - Fonts: Enable users to provisionally change font face, size, or - boldness and to see the consequence of proposed choices. Each - action set 3 options in changes structuree and changes the - corresponding aspect of the font sample on this page and - highlight sample on highlight page. - - Funtion load_font_cfg initializes font vars and widgets from - idleConf entries and tk. - - Fontlist: mouse button 1 click or up or down key invoke - on_fontlist_select(), which sets var font_name. - - Sizelist: clicking the menubutton opens the dropdown menu. A - mouse button 1 click or return key sets var font_size. - - Bold_toggle: clicking the box toggles var font_bold. - - Changing any of the font vars invokes var_changed_font, which - adds all 3 font options to changes and calls set_samples. - Set_samples applies a new font constructed from the font vars to - font_sample and to highlight_sample on the hightlight page. - - Tabs: Enable users to change spaces entered for indent tabs. - Changing indent_scale value with the mouse sets Var space_num, - which invokes the default callback to add an entry to - changes. Load_tab_cfg initializes space_num to default. - - Widget Structure: (*) widgets bound to self - frame (of tab_pages) - frame_font: LabelFrame - frame_font_name: Frame - font_name_title: Label - (*)fontlist: ListBox - font_name - scroll_font: Scrollbar - frame_font_param: Frame - font_size_title: Label - (*)sizelist: DynOptionMenu - font_size - (*)bold_toggle: Checkbutton - font_bold - frame_font_sample: Frame - (*)font_sample: Label - frame_indent: LabelFrame - indent_title: Label - (*)indent_scale: Scale - space_num - """ - parent = self.parent - self.font_name = tracers.add(StringVar(parent), self.var_changed_font) - self.font_size = tracers.add(StringVar(parent), self.var_changed_font) - self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) - self.space_num = tracers.add(IntVar(parent), ('main', 'Indent', 'num-spaces')) - - # Create widgets: - # body and body section frames. - frame = Frame(self.note) - frame_font = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') - frame_indent = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') - # frame_font. - frame_font_name = Frame(frame_font) - frame_font_param = Frame(frame_font) - font_name_title = Label( - frame_font_name, justify=LEFT, text='Font Face :') - self.fontlist = Listbox(frame_font_name, height=5, - takefocus=True, exportselection=FALSE) - self.fontlist.bind('', self.on_fontlist_select) - self.fontlist.bind('', self.on_fontlist_select) - self.fontlist.bind('', self.on_fontlist_select) - scroll_font = Scrollbar(frame_font_name) - scroll_font.config(command=self.fontlist.yview) - self.fontlist.config(yscrollcommand=scroll_font.set) - font_size_title = Label(frame_font_param, text='Size :') - self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) - self.bold_toggle = Checkbutton( - frame_font_param, variable=self.font_bold, - onvalue=1, offvalue=0, text='Bold') - frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) - temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) - self.font_sample = Label( - frame_font_sample, justify=LEFT, font=temp_font, - text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') - # frame_indent. - indent_title = Label( - frame_indent, justify=LEFT, - text='Python Standard: 4 Spaces!') - self.indent_scale = Scale( - frame_indent, variable=self.space_num, - orient='horizontal', tickinterval=2, from_=2, to=16) - - # Pack widgets: - # body. - frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) - frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) - # frame_font. - frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) - frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) - font_name_title.pack(side=TOP, anchor=W) - self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) - scroll_font.pack(side=LEFT, fill=Y) - font_size_title.pack(side=LEFT, anchor=W) - self.sizelist.pack(side=LEFT, anchor=W) - self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) - frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - self.font_sample.pack(expand=TRUE, fill=BOTH) - # frame_indent. - frame_indent.pack(side=TOP, fill=X) - indent_title.pack(side=TOP, anchor=W, padx=5) - self.indent_scale.pack(side=TOP, padx=5, fill=X) - - return frame - - def load_font_cfg(self): - """Load current configuration settings for the font options. - - Retrieve current font with idleConf.GetFont and font families - from tk. Setup fontlist and set font_name. Setup sizelist, - which sets font_size. Set font_bold. Setting font variables - calls set_samples (thrice). - """ - configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') - font_name = configured_font[0].lower() - font_size = configured_font[1] - font_bold = configured_font[2]=='bold' - - # Set editor font selection list and font_name. - fonts = list(tkFont.families(self)) - fonts.sort() - for font in fonts: - self.fontlist.insert(END, font) - self.font_name.set(font_name) - lc_fonts = [s.lower() for s in fonts] - try: - current_font_index = lc_fonts.index(font_name) - self.fontlist.see(current_font_index) - self.fontlist.select_set(current_font_index) - self.fontlist.select_anchor(current_font_index) - self.fontlist.activate(current_font_index) - except ValueError: - pass - # Set font size dropdown. - self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', - '16', '18', '20', '22', '25', '29', '34', '40'), - font_size) - # Set font weight. - self.font_bold.set(font_bold) - - def var_changed_font(self, *params): - """Store changes to font attributes. - - When one font attribute changes, save them all, as they are - not independent from each other. In particular, when we are - overriding the default font, we need to write out everything. - """ - value = self.font_name.get() - changes.add_option('main', 'EditorWindow', 'font', value) - value = self.font_size.get() - changes.add_option('main', 'EditorWindow', 'font-size', value) - value = self.font_bold.get() - changes.add_option('main', 'EditorWindow', 'font-bold', value) - self.set_samples() - - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - - def set_samples(self, event=None): - """Update update both screen samples with the font settings. - - Called on font initialization and change events. - Accesses font_name, font_size, and font_bold Variables. - Updates font_sample and hightlight page highlight_sample. - """ - font_name = self.font_name.get() - font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL - new_font = (font_name, self.font_size.get(), font_weight) - self.font_sample['font'] = new_font - self.highlight_sample['font'] = new_font - - def load_tab_cfg(self): - """Load current configuration settings for the tab options. - - Attributes updated: - space_num: Set to value from idleConf. - """ - # Set indent sizes. - space_num = idleConf.GetOption( - 'main', 'Indent', 'num-spaces', default=4, type='int') - self.space_num.set(space_num) - def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -505,7 +308,7 @@ def create_page_highlight(self): frame_theme = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Highlighting Theme ') #frame_custom - self.highlight_sample=Text( + text = self.highlight_sample = frame.highlight_sample = Text( frame_custom, relief=SOLID, borderwidth=1, font=('courier', 12, ''), cursor='hand2', width=21, height=13, takefocus=FALSE, highlightthickness=0, wrap=NONE) @@ -1829,6 +1632,219 @@ def save_all_changed_extensions(self): self.ext_userCfg.Save() +class FontPage(Frame): + + def __init__(self, parent, highpage): + super().__init__(parent) + self.parent = parent + self.highlight_sample = highpage.highlight_sample + self.create_page_font_tab() + self.load_font_cfg() + self.load_tab_cfg() + + def create_page_font_tab(self): + """Return frame of widgets for Font/Tabs tab. + + Fonts: Enable users to provisionally change font face, size, or + boldness and to see the consequence of proposed choices. Each + action set 3 options in changes structuree and changes the + corresponding aspect of the font sample on this page and + highlight sample on highlight page. + + Function load_font_cfg initializes font vars and widgets from + idleConf entries and tk. + + Fontlist: mouse button 1 click or up or down key invoke + on_fontlist_select(), which sets var font_name. + + Sizelist: clicking the menubutton opens the dropdown menu. A + mouse button 1 click or return key sets var font_size. + + Bold_toggle: clicking the box toggles var font_bold. + + Changing any of the font vars invokes var_changed_font, which + adds all 3 font options to changes and calls set_samples. + Set_samples applies a new font constructed from the font vars to + font_sample and to highlight_sample on the hightlight page. + + Tabs: Enable users to change spaces entered for indent tabs. + Changing indent_scale value with the mouse sets Var space_num, + which invokes the default callback to add an entry to + changes. Load_tab_cfg initializes space_num to default. + + Widget Structure: (*) widgets bound to self + frame (of tab_pages) + frame_font: LabelFrame + frame_font_name: Frame + font_name_title: Label + (*)fontlist: ListBox - font_name + scroll_font: Scrollbar + frame_font_param: Frame + font_size_title: Label + (*)sizelist: DynOptionMenu - font_size + (*)bold_toggle: Checkbutton - font_bold + frame_font_sample: Frame + (*)font_sample: Label + frame_indent: LabelFrame + indent_title: Label + (*)indent_scale: Scale - space_num + """ + parent = self.parent + self.font_name = tracers.add(StringVar(parent), self.var_changed_font) + self.font_size = tracers.add(StringVar(parent), self.var_changed_font) + self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) + self.space_num = tracers.add(IntVar(self), ('main', 'Indent', 'num-spaces')) + + # Create widgets: + # body and body section frames. + frame = self + frame_font = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') + frame_indent = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') + # frame_font. + frame_font_name = Frame(frame_font) + frame_font_param = Frame(frame_font) + font_name_title = Label( + frame_font_name, justify=LEFT, text='Font Face :') + self.fontlist = Listbox(frame_font_name, height=5, + takefocus=True, exportselection=FALSE) + self.fontlist.bind('', self.on_fontlist_select) + self.fontlist.bind('', self.on_fontlist_select) + self.fontlist.bind('', self.on_fontlist_select) + scroll_font = Scrollbar(frame_font_name) + scroll_font.config(command=self.fontlist.yview) + self.fontlist.config(yscrollcommand=scroll_font.set) + font_size_title = Label(frame_font_param, text='Size :') + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) + self.bold_toggle = Checkbutton( + frame_font_param, variable=self.font_bold, + onvalue=1, offvalue=0, text='Bold') + frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) + temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) + self.font_sample = Label( + frame_font_sample, justify=LEFT, font=temp_font, + text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') + # frame_indent. + indent_title = Label( + frame_indent, justify=LEFT, + text='Python Standard: 4 Spaces!') + self.indent_scale = Scale( + frame_indent, variable=self.space_num, + orient='horizontal', tickinterval=2, from_=2, to=16) + + # Pack widgets: + # body. + frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) + frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) + # frame_font. + frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) + frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) + font_name_title.pack(side=TOP, anchor=W) + self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) + scroll_font.pack(side=LEFT, fill=Y) + font_size_title.pack(side=LEFT, anchor=W) + self.sizelist.pack(side=LEFT, anchor=W) + self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) + frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + self.font_sample.pack(expand=TRUE, fill=BOTH) + # frame_indent. + frame_indent.pack(side=TOP, fill=X) + indent_title.pack(side=TOP, anchor=W, padx=5) + self.indent_scale.pack(side=TOP, padx=5, fill=X) + + return frame + + def load_font_cfg(self): + """Load current configuration settings for the font options. + + Retrieve current font with idleConf.GetFont and font families + from tk. Setup fontlist and set font_name. Setup sizelist, + which sets font_size. Set font_bold. Call set_samples. + """ + configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') + font_name = configured_font[0].lower() + font_size = configured_font[1] + font_bold = configured_font[2]=='bold' + + # Set editor font selection list and font_name. + fonts = list(tkFont.families(self)) + fonts.sort() + for font in fonts: + self.fontlist.insert(END, font) + self.font_name.set(font_name) + lc_fonts = [s.lower() for s in fonts] + try: + current_font_index = lc_fonts.index(font_name) + self.fontlist.see(current_font_index) + self.fontlist.select_set(current_font_index) + self.fontlist.select_anchor(current_font_index) + self.fontlist.activate(current_font_index) + except ValueError: + pass + # Set font size dropdown. + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) + # Set font weight. + self.font_bold.set(font_bold) + self.set_samples() + + def var_changed_font(self, *params): + """Store changes to font attributes. + + When one font attribute changes, save them all, as they are + not independent from each other. In particular, when we are + overriding the default font, we need to write out everything. + """ + value = self.font_name.get() + changes.add_option('main', 'EditorWindow', 'font', value) + value = self.font_size.get() + changes.add_option('main', 'EditorWindow', 'font-size', value) + value = self.font_bold.get() + changes.add_option('main', 'EditorWindow', 'font-bold', value) + self.set_samples() + + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + + def set_samples(self, event=None): + """Update update both screen samples with the font settings. + + Called on font initialization and change events. + Accesses font_name, font_size, and font_bold Variables. + Updates font_sample and hightlight page highlight_sample. + """ + font_name = self.font_name.get() + font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL + new_font = (font_name, self.font_size.get(), font_weight) + self.font_sample['font'] = new_font + self.highlight_sample['font'] = new_font + + def load_tab_cfg(self): + """Load current configuration settings for the tab options. + + Attributes updated: + space_num: Set to value from idleConf. + """ + # Set indent sizes. + space_num = idleConf.GetOption( + 'main', 'Indent', 'num-spaces', default=4, type='int') + self.space_num.set(space_num) + + def var_changed_space_num(self, *params): + "Store change to indentation size." + value = self.space_num.get() + changes.add_option('main', 'Indent', 'num-spaces', value) + + class VarTrace: """Maintain Tk variables trace state.""" diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index aff3c2fdc3b..8da726b80c0 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -9,7 +9,7 @@ import unittest from unittest import mock from idlelib.idle_test.mock_idle import Func -from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL +from tkinter import Tk, Frame, IntVar, BooleanVar, DISABLED, NORMAL from idlelib import config from idlelib.configdialog import idleConf, changes, tracers @@ -47,7 +47,7 @@ def tearDownModule(): del root -class FontTest(unittest.TestCase): +class FontPageTest(unittest.TestCase): """Test that font widgets enable users to make font changes. Test that widget actions set vars, that var changes add three @@ -56,11 +56,15 @@ class FontTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - dialog.set_samples = Func() # Mask instance method. + page = cls.page = dialog.fontpage + #dialog.note.insert(0, page, text='copy') + #dialog.note.add(page, text='copyfgfg') + dialog.note.select(page) + page.set_samples = Func() # Mask instance method. @classmethod def tearDownClass(cls): - del dialog.set_samples # Unmask instance method. + del cls.page.set_samples # Unmask instance method. def setUp(self): changes.clear() @@ -68,7 +72,8 @@ def setUp(self): def test_load_font_cfg(self): # Leave widget load test to human visual check. # TODO Improve checks when add IdleConf.get_font_values. - d = dialog + tracers.detach() + d = self.page d.font_name.set('Fake') d.font_size.set('1') d.font_bold.set(True) @@ -77,16 +82,17 @@ def test_load_font_cfg(self): self.assertNotEqual(d.font_name.get(), 'Fake') self.assertNotEqual(d.font_size.get(), '1') self.assertFalse(d.font_bold.get()) - self.assertEqual(d.set_samples.called, 3) + self.assertEqual(d.set_samples.called, 1) + tracers.attach() def test_fontlist_key(self): # Up and Down keys should select a new font. - - if dialog.fontlist.size() < 2: - cls.skipTest('need at least 2 fonts') - fontlist = dialog.fontlist + d = self.page + if d.fontlist.size() < 2: + self.skipTest('need at least 2 fonts') + fontlist = d.fontlist fontlist.activate(0) - font = dialog.fontlist.get('active') + font = d.fontlist.get('active') # Test Down key. fontlist.focus_force() @@ -96,7 +102,7 @@ def test_fontlist_key(self): down_font = fontlist.get('active') self.assertNotEqual(down_font, font) - self.assertIn(dialog.font_name.get(), down_font.lower()) + self.assertIn(d.font_name.get(), down_font.lower()) # Test Up key. fontlist.focus_force() @@ -106,14 +112,14 @@ def test_fontlist_key(self): up_font = fontlist.get('active') self.assertEqual(up_font, font) - self.assertIn(dialog.font_name.get(), up_font.lower()) + self.assertIn(d.font_name.get(), up_font.lower()) def test_fontlist_mouse(self): # Click on item should select that item. - - if dialog.fontlist.size() < 2: + d = self.page + if d.fontlist.size() < 2: cls.skipTest('need at least 2 fonts') - fontlist = dialog.fontlist + fontlist = d.fontlist fontlist.activate(0) # Select next item in listbox @@ -129,17 +135,17 @@ def test_fontlist_mouse(self): font1 = fontlist.get(1) select_font = fontlist.get('anchor') self.assertEqual(select_font, font1) - self.assertIn(dialog.font_name.get(), font1.lower()) + self.assertIn(d.font_name.get(), font1.lower()) def test_sizelist(self): # Click on number shouod select that number - d = dialog + d = self.page d.sizelist.variable.set(40) self.assertEqual(d.font_size.get(), '40') def test_bold_toggle(self): # Click on checkbutton should invert it. - d = dialog + d = self.page d.font_bold.set(False) d.bold_toggle.invoke() self.assertTrue(d.font_bold.get()) @@ -154,7 +160,7 @@ def test_font_set(self): default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' - d = dialog + d = self.page d.font_size.set(default_size) d.font_bold.set(default_bold) d.set_samples.called = 0 @@ -183,7 +189,7 @@ def test_font_set(self): self.assertEqual(d.set_samples.called, 3) def test_set_samples(self): - d = dialog + d = self.page del d.set_samples # Unmask method for test d.font_sample, d.highlight_sample = {}, {} d.font_name.set('test') @@ -201,16 +207,21 @@ def test_set_samples(self): class IndentTest(unittest.TestCase): + @classmethod + def setUpClass(cls): + cls.page = dialog.fontpage + def test_load_tab_cfg(self): - d = dialog + d = self.page d.space_num.set(16) d.load_tab_cfg() self.assertEqual(d.space_num.get(), 4) def test_indent_scale(self): + d = self.page changes.clear() - dialog.indent_scale.set(26) - self.assertEqual(dialog.space_num.get(), 16) + d.indent_scale.set(20) + self.assertEqual(d.space_num.get(), 16) self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) @@ -234,8 +245,10 @@ class GeneralTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - # Mask instance methods used by help functions. d = dialog + # Select General tab so can force focus on helplist. + d.note.select(d.genpage) + # Mask instance methods used by help functions. d.set = d.set_add_delete_state = Func() d.upc = d.update_help_changes = Func() @@ -311,9 +324,8 @@ def test_source_selected(self): helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) - # The following fail after the switch to - # self.assertEqual(helplist.get('anchor'), 'source') - # self.assertTrue(d.set.called) + self.assertEqual(helplist.get('anchor'), 'source') + self.assertTrue(d.set.called) self.assertFalse(d.upc.called) def test_set_add_delete_state(self): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst b/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst new file mode 100644 index 00000000000..47fed949d10 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst @@ -0,0 +1,4 @@ +IDLE - Factor FontPage(Frame) class from ConfigDialog. + +Slightly modified tests continue to pass. Fix General tests. Patch mostly by +Cheryl Sabella. From webhook-mailer at python.org Sun Jul 30 13:35:49 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 17:35:49 -0000 Subject: [Python-checkins] [3.6] bpo-30928: Update IDLE News.txt. (GH-2948) (#2949) Message-ID: https://github.com/python/cpython/commit/c9c85321df7803137a413d26db41aaa377b13d79 commit: c9c85321df7803137a413d26db41aaa377b13d79 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-30T13:35:46-04:00 summary: [3.6] bpo-30928: Update IDLE News.txt. (GH-2948) (#2949) (cherry picked from commit c3aa47f655abe564a2c2fb6d091ab19bdc0113b5) files: M Lib/idlelib/NEWS.txt diff --git a/Lib/idlelib/NEWS.txt b/Lib/idlelib/NEWS.txt index 3c5cba6af47..35a0115c73b 100644 --- a/Lib/idlelib/NEWS.txt +++ b/Lib/idlelib/NEWS.txt @@ -3,6 +3,44 @@ Released on 2017-09-25? ======================== +bpo-30781: IDLE - Use ttk Notebook in ConfigDialog. +Patch by Terry Jan Reedy. + +bpo-31060: IDLE - Finish rearranging methods of ConfigDialog. +Grouping methods pertaining to each tab and the buttons will aid +writing tests and improving the tabs and will enable splitting the +groups into classes. +Patch by Terry Jan Reedy. + +bpo-30853: IDLE -- Factor a VarTrace class out of ConfigDialog. +Instance tracers manages pairs consisting of a tk variable and a +callback function. When tracing is turned on, setting the variable +calls the function. Test coverage for the new class is 100%. +Patch by Terry Jan Reedy. + +bpo-31003: IDLE: Add more tests for General tab. +Patch by Terry Jan Reedy. + +bpo-30993: IDLE - Improve configdialog font page and tests. +*In configdialog: Document causal pathways in create_font_tab +docstring. Simplify some attribute names. Move set_samples calls to +var_changed_font (idea from Cheryl Sabella). Move related functions to +positions after the create widgets function. +* In test_configdialog: Fix test_font_set so not order dependent. Fix +renamed test_indent_scale so it tests the widget. Adjust tests for +movement of set_samples call. Add tests for load functions. Put all +font tests in one class and tab indent tests in another. Except for +two lines, these tests completely cover the related functions. +Patch by Terry Jan Reedy. + +bpo-30981: IDLE -- Add more configdialog font page tests. + +bpo-28523: IDLE: replace 'colour' with 'color' in configdialog. + +bpo-30917: Add tests for idlelib.config.IdleConf. +Increase coverage from 46% to 96%. +Patch by Louie Lu. + bpo-30913: Document ConfigDialog tk Vars, methods, and widgets in docstrings This will facilitate improving the dialog and splitting up the class. Original patch by Cheryl Sabella. @@ -11,7 +49,7 @@ bpo-30899: Add tests for ConfigParser subclasses in config. Coverage is 100% for those classes and ConfigChanges. Patch by Louie Lu. -bpo-30881: Add docstrings to browser.py. +bpo-30881: Add docstrings to browser.py. Patch by Cheryl Sabella. bpo-30851: Remove unused tk variables in configdialog. @@ -48,7 +86,7 @@ bp0-30723: Make several improvements to parenmatch. * Make 'default' style, which is not default, a synonym for 'opener'. * Make time-delay work the same with all styles. * Add help for config dialog extensions tab, including parenmatch. -* Add new tests. +* Add new tests. Original patch by Charles Wohlganger. Revisions by Terry Jan Reedy bpo-30674: Grep -- Add docstrings. Patch by Cheryl Sabella. From webhook-mailer at python.org Sun Jul 30 15:00:53 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 19:00:53 -0000 Subject: [Python-checkins] [3.6] bpo-31004: IDLE: Factor out FontPage class from configdialog (step 1) (GH-2905) (#2950) Message-ID: https://github.com/python/cpython/commit/7582226a92481ca63dedbfe14ef465d1349d66a9 commit: 7582226a92481ca63dedbfe14ef465d1349d66a9 branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-30T15:00:50-04:00 summary: [3.6] bpo-31004: IDLE: Factor out FontPage class from configdialog (step 1) (GH-2905) (#2950) The slightly modified tests continue to pass. The General test broken by the switch to Notebook is fixed. Patch mostly by Cheryl Sabella. (cherry picked from commit 9397e2a) files: A Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 67165298a99..92bbc106344 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -69,7 +69,7 @@ def __init__(self, parent, title='', _htest=False, _utest=False): self.resizable(height=FALSE, width=FALSE) self.transient(parent) self.protocol("WM_DELETE_WINDOW", self.cancel) - self.fontlist.focus_set() + self.fontpage.fontlist.focus_set() # XXX Decide whether to keep or delete these key bindings. # Key bindings for this dialog. # self.bind('', self.Cancel) #dismiss dialog, no save @@ -102,16 +102,16 @@ def create_widgets(self): activate_config_changes: Tell editors to reload. """ self.note = note = Notebook(self, width=450, height=450) - fontpage = self.create_page_font_tab() - highpage = self.create_page_highlight() - keyspage = self.create_page_keys() - genpage = self.create_page_general() - extpage = self.create_page_extensions() - note.add(fontpage, text='Fonts/Tabs') - note.add(highpage, text='Highlights') - note.add(keyspage, text=' Keys ') - note.add(genpage, text=' General ') - note.add(extpage, text='Extensions') + self.highpage = self.create_page_highlight() + self.fontpage = FontPage(note, self.highpage) + self.keyspage = self.create_page_keys() + self.genpage = self.create_page_general() + self.extpage = self.create_page_extensions() + note.add(self.fontpage, text='Fonts/Tabs') + note.add(self.highpage, text='Highlights') + note.add(self.keyspage, text=' Keys ') + note.add(self.genpage, text=' General ') + note.add(self.extpage, text='Extensions') note.enable_traversal() note.pack(side=TOP, expand=TRUE, fill=BOTH) self.create_action_buttons().pack(side=BOTTOM) @@ -129,8 +129,8 @@ def load_configs(self): load_key_cfg load_general_cfg """ - self.load_font_cfg() - self.load_tab_cfg() + #self.load_font_cfg() + #self.load_tab_cfg() self.load_theme_cfg() self.load_key_cfg() self.load_general_cfg() @@ -219,203 +219,6 @@ def help(self): text=help_common+help_pages.get(page, '')) - def create_page_font_tab(self): - """Return frame of widgets for Font/Tabs tab. - - Fonts: Enable users to provisionally change font face, size, or - boldness and to see the consequence of proposed choices. Each - action set 3 options in changes structuree and changes the - corresponding aspect of the font sample on this page and - highlight sample on highlight page. - - Funtion load_font_cfg initializes font vars and widgets from - idleConf entries and tk. - - Fontlist: mouse button 1 click or up or down key invoke - on_fontlist_select(), which sets var font_name. - - Sizelist: clicking the menubutton opens the dropdown menu. A - mouse button 1 click or return key sets var font_size. - - Bold_toggle: clicking the box toggles var font_bold. - - Changing any of the font vars invokes var_changed_font, which - adds all 3 font options to changes and calls set_samples. - Set_samples applies a new font constructed from the font vars to - font_sample and to highlight_sample on the hightlight page. - - Tabs: Enable users to change spaces entered for indent tabs. - Changing indent_scale value with the mouse sets Var space_num, - which invokes the default callback to add an entry to - changes. Load_tab_cfg initializes space_num to default. - - Widget Structure: (*) widgets bound to self - frame (of tab_pages) - frame_font: LabelFrame - frame_font_name: Frame - font_name_title: Label - (*)fontlist: ListBox - font_name - scroll_font: Scrollbar - frame_font_param: Frame - font_size_title: Label - (*)sizelist: DynOptionMenu - font_size - (*)bold_toggle: Checkbutton - font_bold - frame_font_sample: Frame - (*)font_sample: Label - frame_indent: LabelFrame - indent_title: Label - (*)indent_scale: Scale - space_num - """ - parent = self.parent - self.font_name = tracers.add(StringVar(parent), self.var_changed_font) - self.font_size = tracers.add(StringVar(parent), self.var_changed_font) - self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) - self.space_num = tracers.add(IntVar(parent), ('main', 'Indent', 'num-spaces')) - - # Create widgets: - # body and body section frames. - frame = Frame(self.note) - frame_font = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') - frame_indent = LabelFrame( - frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') - # frame_font. - frame_font_name = Frame(frame_font) - frame_font_param = Frame(frame_font) - font_name_title = Label( - frame_font_name, justify=LEFT, text='Font Face :') - self.fontlist = Listbox(frame_font_name, height=5, - takefocus=True, exportselection=FALSE) - self.fontlist.bind('', self.on_fontlist_select) - self.fontlist.bind('', self.on_fontlist_select) - self.fontlist.bind('', self.on_fontlist_select) - scroll_font = Scrollbar(frame_font_name) - scroll_font.config(command=self.fontlist.yview) - self.fontlist.config(yscrollcommand=scroll_font.set) - font_size_title = Label(frame_font_param, text='Size :') - self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) - self.bold_toggle = Checkbutton( - frame_font_param, variable=self.font_bold, - onvalue=1, offvalue=0, text='Bold') - frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) - temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) - self.font_sample = Label( - frame_font_sample, justify=LEFT, font=temp_font, - text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') - # frame_indent. - indent_title = Label( - frame_indent, justify=LEFT, - text='Python Standard: 4 Spaces!') - self.indent_scale = Scale( - frame_indent, variable=self.space_num, - orient='horizontal', tickinterval=2, from_=2, to=16) - - # Pack widgets: - # body. - frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) - frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) - # frame_font. - frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) - frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) - font_name_title.pack(side=TOP, anchor=W) - self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) - scroll_font.pack(side=LEFT, fill=Y) - font_size_title.pack(side=LEFT, anchor=W) - self.sizelist.pack(side=LEFT, anchor=W) - self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) - frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - self.font_sample.pack(expand=TRUE, fill=BOTH) - # frame_indent. - frame_indent.pack(side=TOP, fill=X) - indent_title.pack(side=TOP, anchor=W, padx=5) - self.indent_scale.pack(side=TOP, padx=5, fill=X) - - return frame - - def load_font_cfg(self): - """Load current configuration settings for the font options. - - Retrieve current font with idleConf.GetFont and font families - from tk. Setup fontlist and set font_name. Setup sizelist, - which sets font_size. Set font_bold. Setting font variables - calls set_samples (thrice). - """ - configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') - font_name = configured_font[0].lower() - font_size = configured_font[1] - font_bold = configured_font[2]=='bold' - - # Set editor font selection list and font_name. - fonts = list(tkFont.families(self)) - fonts.sort() - for font in fonts: - self.fontlist.insert(END, font) - self.font_name.set(font_name) - lc_fonts = [s.lower() for s in fonts] - try: - current_font_index = lc_fonts.index(font_name) - self.fontlist.see(current_font_index) - self.fontlist.select_set(current_font_index) - self.fontlist.select_anchor(current_font_index) - self.fontlist.activate(current_font_index) - except ValueError: - pass - # Set font size dropdown. - self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', - '16', '18', '20', '22', '25', '29', '34', '40'), - font_size) - # Set font weight. - self.font_bold.set(font_bold) - - def var_changed_font(self, *params): - """Store changes to font attributes. - - When one font attribute changes, save them all, as they are - not independent from each other. In particular, when we are - overriding the default font, we need to write out everything. - """ - value = self.font_name.get() - changes.add_option('main', 'EditorWindow', 'font', value) - value = self.font_size.get() - changes.add_option('main', 'EditorWindow', 'font-size', value) - value = self.font_bold.get() - changes.add_option('main', 'EditorWindow', 'font-bold', value) - self.set_samples() - - def on_fontlist_select(self, event): - """Handle selecting a font from the list. - - Event can result from either mouse click or Up or Down key. - Set font_name and example displays to selection. - """ - font = self.fontlist.get( - ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) - self.font_name.set(font.lower()) - - def set_samples(self, event=None): - """Update update both screen samples with the font settings. - - Called on font initialization and change events. - Accesses font_name, font_size, and font_bold Variables. - Updates font_sample and hightlight page highlight_sample. - """ - font_name = self.font_name.get() - font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL - new_font = (font_name, self.font_size.get(), font_weight) - self.font_sample['font'] = new_font - self.highlight_sample['font'] = new_font - - def load_tab_cfg(self): - """Load current configuration settings for the tab options. - - Attributes updated: - space_num: Set to value from idleConf. - """ - # Set indent sizes. - space_num = idleConf.GetOption( - 'main', 'Indent', 'num-spaces', default=4, type='int') - self.space_num.set(space_num) - def create_page_highlight(self): """Return frame of widgets for Highlighting tab. @@ -505,7 +308,7 @@ def create_page_highlight(self): frame_theme = LabelFrame(frame, borderwidth=2, relief=GROOVE, text=' Highlighting Theme ') #frame_custom - self.highlight_sample=Text( + text = self.highlight_sample = frame.highlight_sample = Text( frame_custom, relief=SOLID, borderwidth=1, font=('courier', 12, ''), cursor='hand2', width=21, height=13, takefocus=FALSE, highlightthickness=0, wrap=NONE) @@ -1829,6 +1632,219 @@ def save_all_changed_extensions(self): self.ext_userCfg.Save() +class FontPage(Frame): + + def __init__(self, parent, highpage): + super().__init__(parent) + self.parent = parent + self.highlight_sample = highpage.highlight_sample + self.create_page_font_tab() + self.load_font_cfg() + self.load_tab_cfg() + + def create_page_font_tab(self): + """Return frame of widgets for Font/Tabs tab. + + Fonts: Enable users to provisionally change font face, size, or + boldness and to see the consequence of proposed choices. Each + action set 3 options in changes structuree and changes the + corresponding aspect of the font sample on this page and + highlight sample on highlight page. + + Function load_font_cfg initializes font vars and widgets from + idleConf entries and tk. + + Fontlist: mouse button 1 click or up or down key invoke + on_fontlist_select(), which sets var font_name. + + Sizelist: clicking the menubutton opens the dropdown menu. A + mouse button 1 click or return key sets var font_size. + + Bold_toggle: clicking the box toggles var font_bold. + + Changing any of the font vars invokes var_changed_font, which + adds all 3 font options to changes and calls set_samples. + Set_samples applies a new font constructed from the font vars to + font_sample and to highlight_sample on the hightlight page. + + Tabs: Enable users to change spaces entered for indent tabs. + Changing indent_scale value with the mouse sets Var space_num, + which invokes the default callback to add an entry to + changes. Load_tab_cfg initializes space_num to default. + + Widget Structure: (*) widgets bound to self + frame (of tab_pages) + frame_font: LabelFrame + frame_font_name: Frame + font_name_title: Label + (*)fontlist: ListBox - font_name + scroll_font: Scrollbar + frame_font_param: Frame + font_size_title: Label + (*)sizelist: DynOptionMenu - font_size + (*)bold_toggle: Checkbutton - font_bold + frame_font_sample: Frame + (*)font_sample: Label + frame_indent: LabelFrame + indent_title: Label + (*)indent_scale: Scale - space_num + """ + parent = self.parent + self.font_name = tracers.add(StringVar(parent), self.var_changed_font) + self.font_size = tracers.add(StringVar(parent), self.var_changed_font) + self.font_bold = tracers.add(BooleanVar(parent), self.var_changed_font) + self.space_num = tracers.add(IntVar(self), ('main', 'Indent', 'num-spaces')) + + # Create widgets: + # body and body section frames. + frame = self + frame_font = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Base Editor Font ') + frame_indent = LabelFrame( + frame, borderwidth=2, relief=GROOVE, text=' Indentation Width ') + # frame_font. + frame_font_name = Frame(frame_font) + frame_font_param = Frame(frame_font) + font_name_title = Label( + frame_font_name, justify=LEFT, text='Font Face :') + self.fontlist = Listbox(frame_font_name, height=5, + takefocus=True, exportselection=FALSE) + self.fontlist.bind('', self.on_fontlist_select) + self.fontlist.bind('', self.on_fontlist_select) + self.fontlist.bind('', self.on_fontlist_select) + scroll_font = Scrollbar(frame_font_name) + scroll_font.config(command=self.fontlist.yview) + self.fontlist.config(yscrollcommand=scroll_font.set) + font_size_title = Label(frame_font_param, text='Size :') + self.sizelist = DynOptionMenu(frame_font_param, self.font_size, None) + self.bold_toggle = Checkbutton( + frame_font_param, variable=self.font_bold, + onvalue=1, offvalue=0, text='Bold') + frame_font_sample = Frame(frame_font, relief=SOLID, borderwidth=1) + temp_font = tkFont.Font(parent, ('courier', 10, 'normal')) + self.font_sample = Label( + frame_font_sample, justify=LEFT, font=temp_font, + text='AaBbCcDdEe\nFfGgHhIiJj\n1234567890\n#:+=(){}[]') + # frame_indent. + indent_title = Label( + frame_indent, justify=LEFT, + text='Python Standard: 4 Spaces!') + self.indent_scale = Scale( + frame_indent, variable=self.space_num, + orient='horizontal', tickinterval=2, from_=2, to=16) + + # Pack widgets: + # body. + frame_font.pack(side=LEFT, padx=5, pady=5, expand=TRUE, fill=BOTH) + frame_indent.pack(side=LEFT, padx=5, pady=5, fill=Y) + # frame_font. + frame_font_name.pack(side=TOP, padx=5, pady=5, fill=X) + frame_font_param.pack(side=TOP, padx=5, pady=5, fill=X) + font_name_title.pack(side=TOP, anchor=W) + self.fontlist.pack(side=LEFT, expand=TRUE, fill=X) + scroll_font.pack(side=LEFT, fill=Y) + font_size_title.pack(side=LEFT, anchor=W) + self.sizelist.pack(side=LEFT, anchor=W) + self.bold_toggle.pack(side=LEFT, anchor=W, padx=20) + frame_font_sample.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + self.font_sample.pack(expand=TRUE, fill=BOTH) + # frame_indent. + frame_indent.pack(side=TOP, fill=X) + indent_title.pack(side=TOP, anchor=W, padx=5) + self.indent_scale.pack(side=TOP, padx=5, fill=X) + + return frame + + def load_font_cfg(self): + """Load current configuration settings for the font options. + + Retrieve current font with idleConf.GetFont and font families + from tk. Setup fontlist and set font_name. Setup sizelist, + which sets font_size. Set font_bold. Call set_samples. + """ + configured_font = idleConf.GetFont(self, 'main', 'EditorWindow') + font_name = configured_font[0].lower() + font_size = configured_font[1] + font_bold = configured_font[2]=='bold' + + # Set editor font selection list and font_name. + fonts = list(tkFont.families(self)) + fonts.sort() + for font in fonts: + self.fontlist.insert(END, font) + self.font_name.set(font_name) + lc_fonts = [s.lower() for s in fonts] + try: + current_font_index = lc_fonts.index(font_name) + self.fontlist.see(current_font_index) + self.fontlist.select_set(current_font_index) + self.fontlist.select_anchor(current_font_index) + self.fontlist.activate(current_font_index) + except ValueError: + pass + # Set font size dropdown. + self.sizelist.SetMenu(('7', '8', '9', '10', '11', '12', '13', '14', + '16', '18', '20', '22', '25', '29', '34', '40'), + font_size) + # Set font weight. + self.font_bold.set(font_bold) + self.set_samples() + + def var_changed_font(self, *params): + """Store changes to font attributes. + + When one font attribute changes, save them all, as they are + not independent from each other. In particular, when we are + overriding the default font, we need to write out everything. + """ + value = self.font_name.get() + changes.add_option('main', 'EditorWindow', 'font', value) + value = self.font_size.get() + changes.add_option('main', 'EditorWindow', 'font-size', value) + value = self.font_bold.get() + changes.add_option('main', 'EditorWindow', 'font-bold', value) + self.set_samples() + + def on_fontlist_select(self, event): + """Handle selecting a font from the list. + + Event can result from either mouse click or Up or Down key. + Set font_name and example displays to selection. + """ + font = self.fontlist.get( + ACTIVE if event.type.name == 'KeyRelease' else ANCHOR) + self.font_name.set(font.lower()) + + def set_samples(self, event=None): + """Update update both screen samples with the font settings. + + Called on font initialization and change events. + Accesses font_name, font_size, and font_bold Variables. + Updates font_sample and hightlight page highlight_sample. + """ + font_name = self.font_name.get() + font_weight = tkFont.BOLD if self.font_bold.get() else tkFont.NORMAL + new_font = (font_name, self.font_size.get(), font_weight) + self.font_sample['font'] = new_font + self.highlight_sample['font'] = new_font + + def load_tab_cfg(self): + """Load current configuration settings for the tab options. + + Attributes updated: + space_num: Set to value from idleConf. + """ + # Set indent sizes. + space_num = idleConf.GetOption( + 'main', 'Indent', 'num-spaces', default=4, type='int') + self.space_num.set(space_num) + + def var_changed_space_num(self, *params): + "Store change to indentation size." + value = self.space_num.get() + changes.add_option('main', 'Indent', 'num-spaces', value) + + class VarTrace: """Maintain Tk variables trace state.""" diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index aff3c2fdc3b..8da726b80c0 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -9,7 +9,7 @@ import unittest from unittest import mock from idlelib.idle_test.mock_idle import Func -from tkinter import Tk, IntVar, BooleanVar, DISABLED, NORMAL +from tkinter import Tk, Frame, IntVar, BooleanVar, DISABLED, NORMAL from idlelib import config from idlelib.configdialog import idleConf, changes, tracers @@ -47,7 +47,7 @@ def tearDownModule(): del root -class FontTest(unittest.TestCase): +class FontPageTest(unittest.TestCase): """Test that font widgets enable users to make font changes. Test that widget actions set vars, that var changes add three @@ -56,11 +56,15 @@ class FontTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - dialog.set_samples = Func() # Mask instance method. + page = cls.page = dialog.fontpage + #dialog.note.insert(0, page, text='copy') + #dialog.note.add(page, text='copyfgfg') + dialog.note.select(page) + page.set_samples = Func() # Mask instance method. @classmethod def tearDownClass(cls): - del dialog.set_samples # Unmask instance method. + del cls.page.set_samples # Unmask instance method. def setUp(self): changes.clear() @@ -68,7 +72,8 @@ def setUp(self): def test_load_font_cfg(self): # Leave widget load test to human visual check. # TODO Improve checks when add IdleConf.get_font_values. - d = dialog + tracers.detach() + d = self.page d.font_name.set('Fake') d.font_size.set('1') d.font_bold.set(True) @@ -77,16 +82,17 @@ def test_load_font_cfg(self): self.assertNotEqual(d.font_name.get(), 'Fake') self.assertNotEqual(d.font_size.get(), '1') self.assertFalse(d.font_bold.get()) - self.assertEqual(d.set_samples.called, 3) + self.assertEqual(d.set_samples.called, 1) + tracers.attach() def test_fontlist_key(self): # Up and Down keys should select a new font. - - if dialog.fontlist.size() < 2: - cls.skipTest('need at least 2 fonts') - fontlist = dialog.fontlist + d = self.page + if d.fontlist.size() < 2: + self.skipTest('need at least 2 fonts') + fontlist = d.fontlist fontlist.activate(0) - font = dialog.fontlist.get('active') + font = d.fontlist.get('active') # Test Down key. fontlist.focus_force() @@ -96,7 +102,7 @@ def test_fontlist_key(self): down_font = fontlist.get('active') self.assertNotEqual(down_font, font) - self.assertIn(dialog.font_name.get(), down_font.lower()) + self.assertIn(d.font_name.get(), down_font.lower()) # Test Up key. fontlist.focus_force() @@ -106,14 +112,14 @@ def test_fontlist_key(self): up_font = fontlist.get('active') self.assertEqual(up_font, font) - self.assertIn(dialog.font_name.get(), up_font.lower()) + self.assertIn(d.font_name.get(), up_font.lower()) def test_fontlist_mouse(self): # Click on item should select that item. - - if dialog.fontlist.size() < 2: + d = self.page + if d.fontlist.size() < 2: cls.skipTest('need at least 2 fonts') - fontlist = dialog.fontlist + fontlist = d.fontlist fontlist.activate(0) # Select next item in listbox @@ -129,17 +135,17 @@ def test_fontlist_mouse(self): font1 = fontlist.get(1) select_font = fontlist.get('anchor') self.assertEqual(select_font, font1) - self.assertIn(dialog.font_name.get(), font1.lower()) + self.assertIn(d.font_name.get(), font1.lower()) def test_sizelist(self): # Click on number shouod select that number - d = dialog + d = self.page d.sizelist.variable.set(40) self.assertEqual(d.font_size.get(), '40') def test_bold_toggle(self): # Click on checkbutton should invert it. - d = dialog + d = self.page d.font_bold.set(False) d.bold_toggle.invoke() self.assertTrue(d.font_bold.get()) @@ -154,7 +160,7 @@ def test_font_set(self): default_font = idleConf.GetFont(root, 'main', 'EditorWindow') default_size = str(default_font[1]) default_bold = default_font[2] == 'bold' - d = dialog + d = self.page d.font_size.set(default_size) d.font_bold.set(default_bold) d.set_samples.called = 0 @@ -183,7 +189,7 @@ def test_font_set(self): self.assertEqual(d.set_samples.called, 3) def test_set_samples(self): - d = dialog + d = self.page del d.set_samples # Unmask method for test d.font_sample, d.highlight_sample = {}, {} d.font_name.set('test') @@ -201,16 +207,21 @@ def test_set_samples(self): class IndentTest(unittest.TestCase): + @classmethod + def setUpClass(cls): + cls.page = dialog.fontpage + def test_load_tab_cfg(self): - d = dialog + d = self.page d.space_num.set(16) d.load_tab_cfg() self.assertEqual(d.space_num.get(), 4) def test_indent_scale(self): + d = self.page changes.clear() - dialog.indent_scale.set(26) - self.assertEqual(dialog.space_num.get(), 16) + d.indent_scale.set(20) + self.assertEqual(d.space_num.get(), 16) self.assertEqual(mainpage, {'Indent': {'num-spaces': '16'}}) @@ -234,8 +245,10 @@ class GeneralTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - # Mask instance methods used by help functions. d = dialog + # Select General tab so can force focus on helplist. + d.note.select(d.genpage) + # Mask instance methods used by help functions. d.set = d.set_add_delete_state = Func() d.upc = d.update_help_changes = Func() @@ -311,9 +324,8 @@ def test_source_selected(self): helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) helplist.event_generate('', x=x, y=y) - # The following fail after the switch to - # self.assertEqual(helplist.get('anchor'), 'source') - # self.assertTrue(d.set.called) + self.assertEqual(helplist.get('anchor'), 'source') + self.assertTrue(d.set.called) self.assertFalse(d.upc.called) def test_set_add_delete_state(self): diff --git a/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst b/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst new file mode 100644 index 00000000000..47fed949d10 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-30-01-00-58.bpo-31004.m8cc1t.rst @@ -0,0 +1,4 @@ +IDLE - Factor FontPage(Frame) class from ConfigDialog. + +Slightly modified tests continue to pass. Fix General tests. Patch mostly by +Cheryl Sabella. From webhook-mailer at python.org Sun Jul 30 15:15:21 2017 From: webhook-mailer at python.org (Vinay Sajip) Date: Sun, 30 Jul 2017 19:15:21 -0000 Subject: [Python-checkins] Updated LoggerAdapter.isEnabledFor to take advantage of caching. (GH-2951) Message-ID: https://github.com/python/cpython/commit/75f0b5dbac3376a3b36c943ec867c0daed35eb4f commit: 75f0b5dbac3376a3b36c943ec867c0daed35eb4f branch: master author: Vinay Sajip committer: GitHub date: 2017-07-30T20:15:18+01:00 summary: Updated LoggerAdapter.isEnabledFor to take advantage of caching. (GH-2951) files: M Lib/logging/__init__.py diff --git a/Lib/logging/__init__.py b/Lib/logging/__init__.py index 54d4e883d97..83db8273380 100644 --- a/Lib/logging/__init__.py +++ b/Lib/logging/__init__.py @@ -1729,9 +1729,7 @@ def isEnabledFor(self, level): """ Is this logger enabled for level 'level'? """ - if self.logger.manager.disable >= level: - return False - return level >= self.getEffectiveLevel() + return self.logger.isEnabledFor(level) def setLevel(self, level): """ From webhook-mailer at python.org Sun Jul 30 18:39:20 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 22:39:20 -0000 Subject: [Python-checkins] bpo-31050: IDLE: Factor GenPage class from ConfigDialog (#2952) Message-ID: https://github.com/python/cpython/commit/e8eb17b2c11dcd1550a94b175e557c234a804482 commit: e8eb17b2c11dcd1550a94b175e557c234a804482 branch: master author: csabella committer: Terry Jan Reedy date: 2017-07-30T18:39:17-04:00 summary: bpo-31050: IDLE: Factor GenPage class from ConfigDialog (#2952) The slightly modified tests for the General tab continue to pass. Patch by Cheryl Sabella. files: A Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 92bbc106344..28070a51709 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -89,14 +89,14 @@ def create_widgets(self): """Create and place widgets for tabbed dialog. Widgets Bound to self: - tab_pages: TabbedPageSet + note: Notebook + highpage: self.create_page_highlight + fontpage: FontPage + keyspage: self.create_page_keys + genpage: GenPage + extpageL self.create_page_extensions Methods: - create_page_font_tab - create_page_highlight - create_page_keys - create_page_general - create_page_extensions create_action_buttons load_configs: Load pages except for extensions. activate_config_changes: Tell editors to reload. @@ -105,7 +105,7 @@ def create_widgets(self): self.highpage = self.create_page_highlight() self.fontpage = FontPage(note, self.highpage) self.keyspage = self.create_page_keys() - self.genpage = self.create_page_general() + self.genpage = GenPage(note) self.extpage = self.create_page_extensions() note.add(self.fontpage, text='Fonts/Tabs') note.add(self.highpage, text='Highlights') @@ -133,7 +133,7 @@ def load_configs(self): #self.load_tab_cfg() self.load_theme_cfg() self.load_key_cfg() - self.load_general_cfg() + # self.load_general_cfg() # note: extension page handled separately def create_action_buttons(self): @@ -1198,256 +1198,6 @@ def activate_config_changes(self): instance.ApplyKeybindings() instance.reset_help_menu_entries() - - def create_page_general(self): - """Return frame of widgets for General tab. - - Enable users to provisionally change general options. Function - load_general_cfg intializes tk variables and helplist using - idleConf. Radiobuttons startup_shell_on and startup_editor_on - set var startup_edit. Radiobuttons save_ask_on and save_auto_on - set var autosave. Entry boxes win_width_int and win_height_int - set var win_width and win_height. Setting var_name invokes the - default callback that adds option to changes. - - Helplist: load_general_cfg loads list user_helplist with - name, position pairs and copies names to listbox helplist. - Clicking a name invokes help_source selected. Clicking - button_helplist_name invokes helplist_item_name, which also - changes user_helplist. These functions all call - set_add_delete_state. All but load call update_help_changes to - rewrite changes['main']['HelpFiles']. - - Widget Structure: (*) widgets bound to self - frame - frame_run: LabelFrame - startup_title: Label - (*)startup_editor_on: Radiobutton - startup_edit - (*)startup_shell_on: Radiobutton - startup_edit - frame_save: LabelFrame - run_save_title: Label - (*)save_ask_on: Radiobutton - autosave - (*)save_auto_on: Radiobutton - autosave - frame_win_size: LabelFrame - win_size_title: Label - win_width_title: Label - (*)win_width_int: Entry - win_width - win_height_title: Label - (*)win_height_int: Entry - win_height - frame_help: LabelFrame - frame_helplist: Frame - frame_helplist_buttons: Frame - (*)button_helplist_edit - (*)button_helplist_add - (*)button_helplist_remove - (*)helplist: ListBox - scroll_helplist: Scrollbar - """ - parent = self.parent - self.startup_edit = tracers.add( - IntVar(parent), ('main', 'General', 'editor-on-startup')) - self.autosave = tracers.add( - IntVar(parent), ('main', 'General', 'autosave')) - self.win_width = tracers.add( - StringVar(parent), ('main', 'EditorWindow', 'width')) - self.win_height = tracers.add( - StringVar(parent), ('main', 'EditorWindow', 'height')) - - # Create widgets: - # body and section frames. - frame = Frame(self.note) - frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Startup Preferences ') - frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' autosave Preferences ') - frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) - frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Additional Help Sources ') - # frame_run. - startup_title = Label(frame_run, text='At Startup') - self.startup_editor_on = Radiobutton( - frame_run, variable=self.startup_edit, value=1, - text="Open Edit Window") - self.startup_shell_on = Radiobutton( - frame_run, variable=self.startup_edit, value=0, - text='Open Shell Window') - # frame_save. - run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.save_ask_on = Radiobutton( - frame_save, variable=self.autosave, value=0, - text="Prompt to Save") - self.save_auto_on = Radiobutton( - frame_save, variable=self.autosave, value=1, - text='No Prompt') - # frame_win_size. - win_size_title = Label( - frame_win_size, text='Initial Window Size (in characters)') - win_width_title = Label(frame_win_size, text='Width') - self.win_width_int = Entry( - frame_win_size, textvariable=self.win_width, width=3) - win_height_title = Label(frame_win_size, text='Height') - self.win_height_int = Entry( - frame_win_size, textvariable=self.win_height, width=3) - # frame_help. - frame_helplist = Frame(frame_help) - frame_helplist_buttons = Frame(frame_helplist) - self.helplist = Listbox( - frame_helplist, height=5, takefocus=True, - exportselection=FALSE) - scroll_helplist = Scrollbar(frame_helplist) - scroll_helplist['command'] = self.helplist.yview - self.helplist['yscrollcommand'] = scroll_helplist.set - self.helplist.bind('', self.help_source_selected) - self.button_helplist_edit = Button( - frame_helplist_buttons, text='Edit', state=DISABLED, - width=8, command=self.helplist_item_edit) - self.button_helplist_add = Button( - frame_helplist_buttons, text='Add', - width=8, command=self.helplist_item_add) - self.button_helplist_remove = Button( - frame_helplist_buttons, text='Remove', state=DISABLED, - width=8, command=self.helplist_item_remove) - - # Pack widgets: - # body. - frame_run.pack(side=TOP, padx=5, pady=5, fill=X) - frame_save.pack(side=TOP, padx=5, pady=5, fill=X) - frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) - frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - # frame_run. - startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_save. - run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_win_size. - win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_width_title.pack(side=RIGHT, anchor=E, pady=5) - # frame_help. - frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) - frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) - self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) - self.button_helplist_add.pack(side=TOP, anchor=W) - self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) - - return frame - - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=0, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - self.helplist.delete(0, 'end') - for help_item in self.user_helplist: - self.helplist.insert(END, help_item[0]) - self.set_add_delete_state() - - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) - - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) - - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) - - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) - - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_add_delete_state() - - def set_add_delete_state(self): - "Toggle the state for the help list buttons based on list entries." - if self.helplist.size() < 1: # No entries in list. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - else: # Some entries. - if self.helplist.curselection(): # There currently is a selection. - self.button_helplist_edit['state'] = NORMAL - self.button_helplist_remove['state'] = NORMAL - else: # There currently is not a selection. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - - def helplist_item_add(self): - """Handle add button for the help list. - - Query for name and location of new help sources and add - them to the list. - """ - help_source = HelpSource(self, 'New Help Source').result - if help_source: - self.user_helplist.append(help_source) - self.helplist.insert(END, help_source[0]) - self.update_help_changes() - - def helplist_item_edit(self): - """Handle edit button for the help list. - - Query with existing help source information and update - config if the values are changed. - """ - item_index = self.helplist.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.helplist.delete(item_index) - self.helplist.insert(item_index, new_help_source[0]) - self.update_help_changes() - self.set_add_delete_state() # Selected will be un-selected - - def helplist_item_remove(self): - """Handle remove button for the help list. - - Delete the help list item from config. - """ - item_index = self.helplist.index(ANCHOR) - del(self.user_helplist[item_index]) - self.helplist.delete(item_index) - self.update_help_changes() - self.set_add_delete_state() - - def update_help_changes(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) - - def create_page_extensions(self): """Part of the config dialog used for configuring IDLE extensions. @@ -1845,6 +1595,238 @@ def var_changed_space_num(self, *params): changes.add_option('main', 'Indent', 'num-spaces', value) +class GenPage(Frame): + + def __init__(self, parent): + super().__init__(parent) + self.create_page_general() + self.load_general_cfg() + + def create_page_general(self): + """Return frame of widgets for General tab. + + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + default callback that adds option to changes. + + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. + + Widget Structure: (*) widgets bound to self + frame + frame_run: LabelFrame + startup_title: Label + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit + frame_save: LabelFrame + run_save_title: Label + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave + frame_win_size: LabelFrame + win_size_title: Label + win_width_title: Label + (*)win_width_int: Entry - win_width + win_height_title: Label + (*)win_height_int: Entry - win_height + frame_help: LabelFrame + frame_helplist: Frame + frame_helplist_buttons: Frame + (*)button_helplist_edit + (*)button_helplist_add + (*)button_helplist_remove + (*)helplist: ListBox + scroll_helplist: Scrollbar + """ + self.startup_edit = tracers.add( + IntVar(self), ('main', 'General', 'editor-on-startup')) + self.autosave = tracers.add( + IntVar(self), ('main', 'General', 'autosave')) + self.win_width = tracers.add( + StringVar(self), ('main', 'EditorWindow', 'width')) + self.win_height = tracers.add( + StringVar(self), ('main', 'EditorWindow', 'height')) + + # Create widgets: + # Section frames. + frame_run = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' Startup Preferences ') + frame_save = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' autosave Preferences ') + frame_win_size = Frame(self, borderwidth=2, relief=GROOVE) + frame_help = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' Additional Help Sources ') + # frame_run. + startup_title = Label(frame_run, text='At Startup') + self.startup_editor_on = Radiobutton( + frame_run, variable=self.startup_edit, value=1, + text="Open Edit Window") + self.startup_shell_on = Radiobutton( + frame_run, variable=self.startup_edit, value=0, + text='Open Shell Window') + # frame_save. + run_save_title = Label(frame_save, text='At Start of Run (F5) ') + self.save_ask_on = Radiobutton( + frame_save, variable=self.autosave, value=0, + text="Prompt to Save") + self.save_auto_on = Radiobutton( + frame_save, variable=self.autosave, value=1, + text='No Prompt') + # frame_win_size. + win_size_title = Label( + frame_win_size, text='Initial Window Size (in characters)') + win_width_title = Label(frame_win_size, text='Width') + self.win_width_int = Entry( + frame_win_size, textvariable=self.win_width, width=3) + win_height_title = Label(frame_win_size, text='Height') + self.win_height_int = Entry( + frame_win_size, textvariable=self.win_height, width=3) + # frame_help. + frame_helplist = Frame(frame_help) + frame_helplist_buttons = Frame(frame_helplist) + self.helplist = Listbox( + frame_helplist, height=5, takefocus=True, + exportselection=FALSE) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) + self.button_helplist_edit = Button( + frame_helplist_buttons, text='Edit', state=DISABLED, + width=8, command=self.helplist_item_edit) + self.button_helplist_add = Button( + frame_helplist_buttons, text='Add', + width=8, command=self.helplist_item_add) + self.button_helplist_remove = Button( + frame_helplist_buttons, text='Remove', state=DISABLED, + width=8, command=self.helplist_item_remove) + + # Pack widgets: + # body. + frame_run.pack(side=TOP, padx=5, pady=5, fill=X) + frame_save.pack(side=TOP, padx=5, pady=5, fill=X) + frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) + frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + # frame_run. + startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. + run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. + win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_height_title.pack(side=RIGHT, anchor=E, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_width_title.pack(side=RIGHT, anchor=E, pady=5) + # frame_help. + frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) + frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) + self.button_helplist_add.pack(side=TOP, anchor=W) + self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() + + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() + + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + + def helplist_item_add(self): + """Handle add button for the help list. + + Query for name and location of new help sources and add + them to the list. + """ + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() + + def helplist_item_edit(self): + """Handle edit button for the help list. + + Query with existing help source information and update + config if the values are changed. + """ + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected + + def helplist_item_remove(self): + """Handle remove button for the help list. + + Delete the help list item from config. + """ + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() + + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) + + class VarTrace: """Maintain Tk variables trace state.""" diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 8da726b80c0..caeb2b56787 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -237,7 +237,7 @@ def setUp(self): changes.clear() -class GeneralTest(unittest.TestCase): +class GenPageTest(unittest.TestCase): """Test that general tab widgets enable users to make changes. Test that widget actions set vars, that var changes add @@ -245,20 +245,18 @@ class GeneralTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - d = dialog - # Select General tab so can force focus on helplist. - d.note.select(d.genpage) - # Mask instance methods used by help functions. - d.set = d.set_add_delete_state = Func() - d.upc = d.update_help_changes = Func() + page = cls.page = dialog.genpage + dialog.note.select(page) + page.set = page.set_add_delete_state = Func() + page.upc = page.update_help_changes = Func() @classmethod def tearDownClass(cls): - d = dialog - del d.set, d.set_add_delete_state - del d.upc, d.update_help_changes - d.helplist.delete(0, 'end') - d.user_helplist.clear() + page = cls.page + del page.set, page.set_add_delete_state + del page.upc, page.update_help_changes + page.helplist.delete(0, 'end') + page.user_helplist.clear() def setUp(self): changes.clear() @@ -266,7 +264,7 @@ def setUp(self): def test_load_general_cfg(self): # Set to wrong values, load, check right values. eq = self.assertEqual - d = dialog + d = self.page d.startup_edit.set(1) d.autosave.set(1) d.win_width.set(1) @@ -283,29 +281,32 @@ def test_load_general_cfg(self): eq(d.user_helplist, [('name', 'file', '1')]) def test_startup(self): - dialog.startup_editor_on.invoke() + d = self.page + d.startup_editor_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '1'}}) changes.clear() - dialog.startup_shell_on.invoke() + d.startup_shell_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '0'}}) def test_autosave(self): - dialog.save_auto_on.invoke() + d = self.page + d.save_auto_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '1'}}) - dialog.save_ask_on.invoke() + d.save_ask_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '0'}}) def test_editor_size(self): - dialog.win_height_int.insert(0, '1') + d = self.page + d.win_height_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'height': '140'}}) changes.clear() - dialog.win_width_int.insert(0, '1') + d.win_width_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'width': '180'}}) def test_source_selected(self): - d = dialog + d = self.page d.set = d.set_add_delete_state d.upc = d.update_help_changes helplist = d.helplist @@ -331,7 +332,7 @@ def test_source_selected(self): def test_set_add_delete_state(self): # Call with 0 items, 1 unselected item, 1 selected item. eq = self.assertEqual - d = dialog + d = self.page del d.set_add_delete_state # Unmask method. sad = d.set_add_delete_state h = d.helplist @@ -358,7 +359,7 @@ def test_helplist_item_add(self): eq = self.assertEqual orig_helpsource = configdialog.HelpSource hs = configdialog.HelpSource = Func(return_self=True) - d = dialog + d = self.page d.helplist.delete(0, 'end') d.user_helplist.clear() d.set.called = d.upc.called = 0 @@ -385,7 +386,7 @@ def test_helplist_item_edit(self): eq = self.assertEqual orig_helpsource = configdialog.HelpSource hs = configdialog.HelpSource = Func(return_self=True) - d = dialog + d = self.page d.helplist.delete(0, 'end') d.helplist.insert(0, 'name1') d.helplist.selection_set(0) @@ -412,7 +413,7 @@ def test_helplist_item_edit(self): def test_helplist_item_remove(self): eq = self.assertEqual - d = dialog + d = self.page d.helplist.delete(0, 'end') d.helplist.insert(0, 'name1') d.helplist.selection_set(0) @@ -427,7 +428,7 @@ def test_helplist_item_remove(self): self.assertTrue(d.upc.called == d.set.called == 1) def test_update_help_changes(self): - d = dialog + d = self.page del d.update_help_changes d.user_helplist.clear() d.user_helplist.append(('name1', 'file1')) @@ -435,7 +436,7 @@ def test_update_help_changes(self): d.update_help_changes() self.assertEqual(mainpage['HelpFiles'], - {'1': 'name1;file1', '2': 'name2;file2'}) + {'1': 'name1;file1', '2': 'name2;file2'}) d.update_help_changes = Func() diff --git a/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst b/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst new file mode 100644 index 00000000000..e33b2e231d6 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst @@ -0,0 +1,2 @@ +Factor GenPage(Frame) class from ConfigDialog. The slightly modified tests +continue to pass. Patch by Cheryl Sabella. From webhook-mailer at python.org Sun Jul 30 19:02:54 2017 From: webhook-mailer at python.org (Terry Jan Reedy) Date: Sun, 30 Jul 2017 23:02:54 -0000 Subject: [Python-checkins] [3.6] bpo-31050: IDLE: Factor GenPage class from ConfigDialog (GH-2952) (#2955) Message-ID: https://github.com/python/cpython/commit/8c4e5be1dfb4d1c74e8cc7ac925e3196818e07ac commit: 8c4e5be1dfb4d1c74e8cc7ac925e3196818e07ac branch: 3.6 author: Terry Jan Reedy committer: GitHub date: 2017-07-30T19:02:51-04:00 summary: [3.6] bpo-31050: IDLE: Factor GenPage class from ConfigDialog (GH-2952) (#2955) The slightly modified tests for the General tab continue to pass. Patch by Cheryl Sabella. (cherry picked from commit e8eb17b) files: A Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst M Lib/idlelib/configdialog.py M Lib/idlelib/idle_test/test_configdialog.py diff --git a/Lib/idlelib/configdialog.py b/Lib/idlelib/configdialog.py index 92bbc106344..28070a51709 100644 --- a/Lib/idlelib/configdialog.py +++ b/Lib/idlelib/configdialog.py @@ -89,14 +89,14 @@ def create_widgets(self): """Create and place widgets for tabbed dialog. Widgets Bound to self: - tab_pages: TabbedPageSet + note: Notebook + highpage: self.create_page_highlight + fontpage: FontPage + keyspage: self.create_page_keys + genpage: GenPage + extpageL self.create_page_extensions Methods: - create_page_font_tab - create_page_highlight - create_page_keys - create_page_general - create_page_extensions create_action_buttons load_configs: Load pages except for extensions. activate_config_changes: Tell editors to reload. @@ -105,7 +105,7 @@ def create_widgets(self): self.highpage = self.create_page_highlight() self.fontpage = FontPage(note, self.highpage) self.keyspage = self.create_page_keys() - self.genpage = self.create_page_general() + self.genpage = GenPage(note) self.extpage = self.create_page_extensions() note.add(self.fontpage, text='Fonts/Tabs') note.add(self.highpage, text='Highlights') @@ -133,7 +133,7 @@ def load_configs(self): #self.load_tab_cfg() self.load_theme_cfg() self.load_key_cfg() - self.load_general_cfg() + # self.load_general_cfg() # note: extension page handled separately def create_action_buttons(self): @@ -1198,256 +1198,6 @@ def activate_config_changes(self): instance.ApplyKeybindings() instance.reset_help_menu_entries() - - def create_page_general(self): - """Return frame of widgets for General tab. - - Enable users to provisionally change general options. Function - load_general_cfg intializes tk variables and helplist using - idleConf. Radiobuttons startup_shell_on and startup_editor_on - set var startup_edit. Radiobuttons save_ask_on and save_auto_on - set var autosave. Entry boxes win_width_int and win_height_int - set var win_width and win_height. Setting var_name invokes the - default callback that adds option to changes. - - Helplist: load_general_cfg loads list user_helplist with - name, position pairs and copies names to listbox helplist. - Clicking a name invokes help_source selected. Clicking - button_helplist_name invokes helplist_item_name, which also - changes user_helplist. These functions all call - set_add_delete_state. All but load call update_help_changes to - rewrite changes['main']['HelpFiles']. - - Widget Structure: (*) widgets bound to self - frame - frame_run: LabelFrame - startup_title: Label - (*)startup_editor_on: Radiobutton - startup_edit - (*)startup_shell_on: Radiobutton - startup_edit - frame_save: LabelFrame - run_save_title: Label - (*)save_ask_on: Radiobutton - autosave - (*)save_auto_on: Radiobutton - autosave - frame_win_size: LabelFrame - win_size_title: Label - win_width_title: Label - (*)win_width_int: Entry - win_width - win_height_title: Label - (*)win_height_int: Entry - win_height - frame_help: LabelFrame - frame_helplist: Frame - frame_helplist_buttons: Frame - (*)button_helplist_edit - (*)button_helplist_add - (*)button_helplist_remove - (*)helplist: ListBox - scroll_helplist: Scrollbar - """ - parent = self.parent - self.startup_edit = tracers.add( - IntVar(parent), ('main', 'General', 'editor-on-startup')) - self.autosave = tracers.add( - IntVar(parent), ('main', 'General', 'autosave')) - self.win_width = tracers.add( - StringVar(parent), ('main', 'EditorWindow', 'width')) - self.win_height = tracers.add( - StringVar(parent), ('main', 'EditorWindow', 'height')) - - # Create widgets: - # body and section frames. - frame = Frame(self.note) - frame_run = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Startup Preferences ') - frame_save = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' autosave Preferences ') - frame_win_size = Frame(frame, borderwidth=2, relief=GROOVE) - frame_help = LabelFrame(frame, borderwidth=2, relief=GROOVE, - text=' Additional Help Sources ') - # frame_run. - startup_title = Label(frame_run, text='At Startup') - self.startup_editor_on = Radiobutton( - frame_run, variable=self.startup_edit, value=1, - text="Open Edit Window") - self.startup_shell_on = Radiobutton( - frame_run, variable=self.startup_edit, value=0, - text='Open Shell Window') - # frame_save. - run_save_title = Label(frame_save, text='At Start of Run (F5) ') - self.save_ask_on = Radiobutton( - frame_save, variable=self.autosave, value=0, - text="Prompt to Save") - self.save_auto_on = Radiobutton( - frame_save, variable=self.autosave, value=1, - text='No Prompt') - # frame_win_size. - win_size_title = Label( - frame_win_size, text='Initial Window Size (in characters)') - win_width_title = Label(frame_win_size, text='Width') - self.win_width_int = Entry( - frame_win_size, textvariable=self.win_width, width=3) - win_height_title = Label(frame_win_size, text='Height') - self.win_height_int = Entry( - frame_win_size, textvariable=self.win_height, width=3) - # frame_help. - frame_helplist = Frame(frame_help) - frame_helplist_buttons = Frame(frame_helplist) - self.helplist = Listbox( - frame_helplist, height=5, takefocus=True, - exportselection=FALSE) - scroll_helplist = Scrollbar(frame_helplist) - scroll_helplist['command'] = self.helplist.yview - self.helplist['yscrollcommand'] = scroll_helplist.set - self.helplist.bind('', self.help_source_selected) - self.button_helplist_edit = Button( - frame_helplist_buttons, text='Edit', state=DISABLED, - width=8, command=self.helplist_item_edit) - self.button_helplist_add = Button( - frame_helplist_buttons, text='Add', - width=8, command=self.helplist_item_add) - self.button_helplist_remove = Button( - frame_helplist_buttons, text='Remove', state=DISABLED, - width=8, command=self.helplist_item_remove) - - # Pack widgets: - # body. - frame_run.pack(side=TOP, padx=5, pady=5, fill=X) - frame_save.pack(side=TOP, padx=5, pady=5, fill=X) - frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) - frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - # frame_run. - startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_save. - run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) - # frame_win_size. - win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) - self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_height_title.pack(side=RIGHT, anchor=E, pady=5) - self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) - win_width_title.pack(side=RIGHT, anchor=E, pady=5) - # frame_help. - frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) - frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) - scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) - self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) - self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) - self.button_helplist_add.pack(side=TOP, anchor=W) - self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) - - return frame - - def load_general_cfg(self): - "Load current configuration settings for the general options." - # Set startup state. - self.startup_edit.set(idleConf.GetOption( - 'main', 'General', 'editor-on-startup', default=0, type='bool')) - # Set autosave state. - self.autosave.set(idleConf.GetOption( - 'main', 'General', 'autosave', default=0, type='bool')) - # Set initial window size. - self.win_width.set(idleConf.GetOption( - 'main', 'EditorWindow', 'width', type='int')) - self.win_height.set(idleConf.GetOption( - 'main', 'EditorWindow', 'height', type='int')) - # Set additional help sources. - self.user_helplist = idleConf.GetAllExtraHelpSourcesList() - self.helplist.delete(0, 'end') - for help_item in self.user_helplist: - self.helplist.insert(END, help_item[0]) - self.set_add_delete_state() - - def var_changed_startup_edit(self, *params): - "Store change to toggle for starting IDLE in the editor or shell." - value = self.startup_edit.get() - changes.add_option('main', 'General', 'editor-on-startup', value) - - def var_changed_autosave(self, *params): - "Store change to autosave." - value = self.autosave.get() - changes.add_option('main', 'General', 'autosave', value) - - def var_changed_win_width(self, *params): - "Store change to window width." - value = self.win_width.get() - changes.add_option('main', 'EditorWindow', 'width', value) - - def var_changed_win_height(self, *params): - "Store change to window height." - value = self.win_height.get() - changes.add_option('main', 'EditorWindow', 'height', value) - - def help_source_selected(self, event): - "Handle event for selecting additional help." - self.set_add_delete_state() - - def set_add_delete_state(self): - "Toggle the state for the help list buttons based on list entries." - if self.helplist.size() < 1: # No entries in list. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - else: # Some entries. - if self.helplist.curselection(): # There currently is a selection. - self.button_helplist_edit['state'] = NORMAL - self.button_helplist_remove['state'] = NORMAL - else: # There currently is not a selection. - self.button_helplist_edit['state'] = DISABLED - self.button_helplist_remove['state'] = DISABLED - - def helplist_item_add(self): - """Handle add button for the help list. - - Query for name and location of new help sources and add - them to the list. - """ - help_source = HelpSource(self, 'New Help Source').result - if help_source: - self.user_helplist.append(help_source) - self.helplist.insert(END, help_source[0]) - self.update_help_changes() - - def helplist_item_edit(self): - """Handle edit button for the help list. - - Query with existing help source information and update - config if the values are changed. - """ - item_index = self.helplist.index(ANCHOR) - help_source = self.user_helplist[item_index] - new_help_source = HelpSource( - self, 'Edit Help Source', - menuitem=help_source[0], - filepath=help_source[1], - ).result - if new_help_source and new_help_source != help_source: - self.user_helplist[item_index] = new_help_source - self.helplist.delete(item_index) - self.helplist.insert(item_index, new_help_source[0]) - self.update_help_changes() - self.set_add_delete_state() # Selected will be un-selected - - def helplist_item_remove(self): - """Handle remove button for the help list. - - Delete the help list item from config. - """ - item_index = self.helplist.index(ANCHOR) - del(self.user_helplist[item_index]) - self.helplist.delete(item_index) - self.update_help_changes() - self.set_add_delete_state() - - def update_help_changes(self): - "Clear and rebuild the HelpFiles section in changes" - changes['main']['HelpFiles'] = {} - for num in range(1, len(self.user_helplist) + 1): - changes.add_option( - 'main', 'HelpFiles', str(num), - ';'.join(self.user_helplist[num-1][:2])) - - def create_page_extensions(self): """Part of the config dialog used for configuring IDLE extensions. @@ -1845,6 +1595,238 @@ def var_changed_space_num(self, *params): changes.add_option('main', 'Indent', 'num-spaces', value) +class GenPage(Frame): + + def __init__(self, parent): + super().__init__(parent) + self.create_page_general() + self.load_general_cfg() + + def create_page_general(self): + """Return frame of widgets for General tab. + + Enable users to provisionally change general options. Function + load_general_cfg intializes tk variables and helplist using + idleConf. Radiobuttons startup_shell_on and startup_editor_on + set var startup_edit. Radiobuttons save_ask_on and save_auto_on + set var autosave. Entry boxes win_width_int and win_height_int + set var win_width and win_height. Setting var_name invokes the + default callback that adds option to changes. + + Helplist: load_general_cfg loads list user_helplist with + name, position pairs and copies names to listbox helplist. + Clicking a name invokes help_source selected. Clicking + button_helplist_name invokes helplist_item_name, which also + changes user_helplist. These functions all call + set_add_delete_state. All but load call update_help_changes to + rewrite changes['main']['HelpFiles']. + + Widget Structure: (*) widgets bound to self + frame + frame_run: LabelFrame + startup_title: Label + (*)startup_editor_on: Radiobutton - startup_edit + (*)startup_shell_on: Radiobutton - startup_edit + frame_save: LabelFrame + run_save_title: Label + (*)save_ask_on: Radiobutton - autosave + (*)save_auto_on: Radiobutton - autosave + frame_win_size: LabelFrame + win_size_title: Label + win_width_title: Label + (*)win_width_int: Entry - win_width + win_height_title: Label + (*)win_height_int: Entry - win_height + frame_help: LabelFrame + frame_helplist: Frame + frame_helplist_buttons: Frame + (*)button_helplist_edit + (*)button_helplist_add + (*)button_helplist_remove + (*)helplist: ListBox + scroll_helplist: Scrollbar + """ + self.startup_edit = tracers.add( + IntVar(self), ('main', 'General', 'editor-on-startup')) + self.autosave = tracers.add( + IntVar(self), ('main', 'General', 'autosave')) + self.win_width = tracers.add( + StringVar(self), ('main', 'EditorWindow', 'width')) + self.win_height = tracers.add( + StringVar(self), ('main', 'EditorWindow', 'height')) + + # Create widgets: + # Section frames. + frame_run = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' Startup Preferences ') + frame_save = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' autosave Preferences ') + frame_win_size = Frame(self, borderwidth=2, relief=GROOVE) + frame_help = LabelFrame(self, borderwidth=2, relief=GROOVE, + text=' Additional Help Sources ') + # frame_run. + startup_title = Label(frame_run, text='At Startup') + self.startup_editor_on = Radiobutton( + frame_run, variable=self.startup_edit, value=1, + text="Open Edit Window") + self.startup_shell_on = Radiobutton( + frame_run, variable=self.startup_edit, value=0, + text='Open Shell Window') + # frame_save. + run_save_title = Label(frame_save, text='At Start of Run (F5) ') + self.save_ask_on = Radiobutton( + frame_save, variable=self.autosave, value=0, + text="Prompt to Save") + self.save_auto_on = Radiobutton( + frame_save, variable=self.autosave, value=1, + text='No Prompt') + # frame_win_size. + win_size_title = Label( + frame_win_size, text='Initial Window Size (in characters)') + win_width_title = Label(frame_win_size, text='Width') + self.win_width_int = Entry( + frame_win_size, textvariable=self.win_width, width=3) + win_height_title = Label(frame_win_size, text='Height') + self.win_height_int = Entry( + frame_win_size, textvariable=self.win_height, width=3) + # frame_help. + frame_helplist = Frame(frame_help) + frame_helplist_buttons = Frame(frame_helplist) + self.helplist = Listbox( + frame_helplist, height=5, takefocus=True, + exportselection=FALSE) + scroll_helplist = Scrollbar(frame_helplist) + scroll_helplist['command'] = self.helplist.yview + self.helplist['yscrollcommand'] = scroll_helplist.set + self.helplist.bind('', self.help_source_selected) + self.button_helplist_edit = Button( + frame_helplist_buttons, text='Edit', state=DISABLED, + width=8, command=self.helplist_item_edit) + self.button_helplist_add = Button( + frame_helplist_buttons, text='Add', + width=8, command=self.helplist_item_add) + self.button_helplist_remove = Button( + frame_helplist_buttons, text='Remove', state=DISABLED, + width=8, command=self.helplist_item_remove) + + # Pack widgets: + # body. + frame_run.pack(side=TOP, padx=5, pady=5, fill=X) + frame_save.pack(side=TOP, padx=5, pady=5, fill=X) + frame_win_size.pack(side=TOP, padx=5, pady=5, fill=X) + frame_help.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + # frame_run. + startup_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.startup_shell_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.startup_editor_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_save. + run_save_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.save_auto_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + self.save_ask_on.pack(side=RIGHT, anchor=W, padx=5, pady=5) + # frame_win_size. + win_size_title.pack(side=LEFT, anchor=W, padx=5, pady=5) + self.win_height_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_height_title.pack(side=RIGHT, anchor=E, pady=5) + self.win_width_int.pack(side=RIGHT, anchor=E, padx=10, pady=5) + win_width_title.pack(side=RIGHT, anchor=E, pady=5) + # frame_help. + frame_helplist_buttons.pack(side=RIGHT, padx=5, pady=5, fill=Y) + frame_helplist.pack(side=TOP, padx=5, pady=5, expand=TRUE, fill=BOTH) + scroll_helplist.pack(side=RIGHT, anchor=W, fill=Y) + self.helplist.pack(side=LEFT, anchor=E, expand=TRUE, fill=BOTH) + self.button_helplist_edit.pack(side=TOP, anchor=W, pady=5) + self.button_helplist_add.pack(side=TOP, anchor=W) + self.button_helplist_remove.pack(side=TOP, anchor=W, pady=5) + + def load_general_cfg(self): + "Load current configuration settings for the general options." + # Set startup state. + self.startup_edit.set(idleConf.GetOption( + 'main', 'General', 'editor-on-startup', default=0, type='bool')) + # Set autosave state. + self.autosave.set(idleConf.GetOption( + 'main', 'General', 'autosave', default=0, type='bool')) + # Set initial window size. + self.win_width.set(idleConf.GetOption( + 'main', 'EditorWindow', 'width', type='int')) + self.win_height.set(idleConf.GetOption( + 'main', 'EditorWindow', 'height', type='int')) + # Set additional help sources. + self.user_helplist = idleConf.GetAllExtraHelpSourcesList() + self.helplist.delete(0, 'end') + for help_item in self.user_helplist: + self.helplist.insert(END, help_item[0]) + self.set_add_delete_state() + + def help_source_selected(self, event): + "Handle event for selecting additional help." + self.set_add_delete_state() + + def set_add_delete_state(self): + "Toggle the state for the help list buttons based on list entries." + if self.helplist.size() < 1: # No entries in list. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + else: # Some entries. + if self.helplist.curselection(): # There currently is a selection. + self.button_helplist_edit['state'] = NORMAL + self.button_helplist_remove['state'] = NORMAL + else: # There currently is not a selection. + self.button_helplist_edit['state'] = DISABLED + self.button_helplist_remove['state'] = DISABLED + + def helplist_item_add(self): + """Handle add button for the help list. + + Query for name and location of new help sources and add + them to the list. + """ + help_source = HelpSource(self, 'New Help Source').result + if help_source: + self.user_helplist.append(help_source) + self.helplist.insert(END, help_source[0]) + self.update_help_changes() + + def helplist_item_edit(self): + """Handle edit button for the help list. + + Query with existing help source information and update + config if the values are changed. + """ + item_index = self.helplist.index(ANCHOR) + help_source = self.user_helplist[item_index] + new_help_source = HelpSource( + self, 'Edit Help Source', + menuitem=help_source[0], + filepath=help_source[1], + ).result + if new_help_source and new_help_source != help_source: + self.user_helplist[item_index] = new_help_source + self.helplist.delete(item_index) + self.helplist.insert(item_index, new_help_source[0]) + self.update_help_changes() + self.set_add_delete_state() # Selected will be un-selected + + def helplist_item_remove(self): + """Handle remove button for the help list. + + Delete the help list item from config. + """ + item_index = self.helplist.index(ANCHOR) + del(self.user_helplist[item_index]) + self.helplist.delete(item_index) + self.update_help_changes() + self.set_add_delete_state() + + def update_help_changes(self): + "Clear and rebuild the HelpFiles section in changes" + changes['main']['HelpFiles'] = {} + for num in range(1, len(self.user_helplist) + 1): + changes.add_option( + 'main', 'HelpFiles', str(num), + ';'.join(self.user_helplist[num-1][:2])) + + class VarTrace: """Maintain Tk variables trace state.""" diff --git a/Lib/idlelib/idle_test/test_configdialog.py b/Lib/idlelib/idle_test/test_configdialog.py index 8da726b80c0..caeb2b56787 100644 --- a/Lib/idlelib/idle_test/test_configdialog.py +++ b/Lib/idlelib/idle_test/test_configdialog.py @@ -237,7 +237,7 @@ def setUp(self): changes.clear() -class GeneralTest(unittest.TestCase): +class GenPageTest(unittest.TestCase): """Test that general tab widgets enable users to make changes. Test that widget actions set vars, that var changes add @@ -245,20 +245,18 @@ class GeneralTest(unittest.TestCase): """ @classmethod def setUpClass(cls): - d = dialog - # Select General tab so can force focus on helplist. - d.note.select(d.genpage) - # Mask instance methods used by help functions. - d.set = d.set_add_delete_state = Func() - d.upc = d.update_help_changes = Func() + page = cls.page = dialog.genpage + dialog.note.select(page) + page.set = page.set_add_delete_state = Func() + page.upc = page.update_help_changes = Func() @classmethod def tearDownClass(cls): - d = dialog - del d.set, d.set_add_delete_state - del d.upc, d.update_help_changes - d.helplist.delete(0, 'end') - d.user_helplist.clear() + page = cls.page + del page.set, page.set_add_delete_state + del page.upc, page.update_help_changes + page.helplist.delete(0, 'end') + page.user_helplist.clear() def setUp(self): changes.clear() @@ -266,7 +264,7 @@ def setUp(self): def test_load_general_cfg(self): # Set to wrong values, load, check right values. eq = self.assertEqual - d = dialog + d = self.page d.startup_edit.set(1) d.autosave.set(1) d.win_width.set(1) @@ -283,29 +281,32 @@ def test_load_general_cfg(self): eq(d.user_helplist, [('name', 'file', '1')]) def test_startup(self): - dialog.startup_editor_on.invoke() + d = self.page + d.startup_editor_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '1'}}) changes.clear() - dialog.startup_shell_on.invoke() + d.startup_shell_on.invoke() self.assertEqual(mainpage, {'General': {'editor-on-startup': '0'}}) def test_autosave(self): - dialog.save_auto_on.invoke() + d = self.page + d.save_auto_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '1'}}) - dialog.save_ask_on.invoke() + d.save_ask_on.invoke() self.assertEqual(mainpage, {'General': {'autosave': '0'}}) def test_editor_size(self): - dialog.win_height_int.insert(0, '1') + d = self.page + d.win_height_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'height': '140'}}) changes.clear() - dialog.win_width_int.insert(0, '1') + d.win_width_int.insert(0, '1') self.assertEqual(mainpage, {'EditorWindow': {'width': '180'}}) def test_source_selected(self): - d = dialog + d = self.page d.set = d.set_add_delete_state d.upc = d.update_help_changes helplist = d.helplist @@ -331,7 +332,7 @@ def test_source_selected(self): def test_set_add_delete_state(self): # Call with 0 items, 1 unselected item, 1 selected item. eq = self.assertEqual - d = dialog + d = self.page del d.set_add_delete_state # Unmask method. sad = d.set_add_delete_state h = d.helplist @@ -358,7 +359,7 @@ def test_helplist_item_add(self): eq = self.assertEqual orig_helpsource = configdialog.HelpSource hs = configdialog.HelpSource = Func(return_self=True) - d = dialog + d = self.page d.helplist.delete(0, 'end') d.user_helplist.clear() d.set.called = d.upc.called = 0 @@ -385,7 +386,7 @@ def test_helplist_item_edit(self): eq = self.assertEqual orig_helpsource = configdialog.HelpSource hs = configdialog.HelpSource = Func(return_self=True) - d = dialog + d = self.page d.helplist.delete(0, 'end') d.helplist.insert(0, 'name1') d.helplist.selection_set(0) @@ -412,7 +413,7 @@ def test_helplist_item_edit(self): def test_helplist_item_remove(self): eq = self.assertEqual - d = dialog + d = self.page d.helplist.delete(0, 'end') d.helplist.insert(0, 'name1') d.helplist.selection_set(0) @@ -427,7 +428,7 @@ def test_helplist_item_remove(self): self.assertTrue(d.upc.called == d.set.called == 1) def test_update_help_changes(self): - d = dialog + d = self.page del d.update_help_changes d.user_helplist.clear() d.user_helplist.append(('name1', 'file1')) @@ -435,7 +436,7 @@ def test_update_help_changes(self): d.update_help_changes() self.assertEqual(mainpage['HelpFiles'], - {'1': 'name1;file1', '2': 'name2;file2'}) + {'1': 'name1;file1', '2': 'name2;file2'}) d.update_help_changes = Func() diff --git a/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst b/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst new file mode 100644 index 00000000000..e33b2e231d6 --- /dev/null +++ b/Misc/NEWS.d/next/IDLE/2017-07-30-17-39-59.bpo-31050.AXR3kP.rst @@ -0,0 +1,2 @@ +Factor GenPage(Frame) class from ConfigDialog. The slightly modified tests +continue to pass. Patch by Cheryl Sabella. From solipsis at pitrou.net Mon Jul 31 05:06:01 2017 From: solipsis at pitrou.net (solipsis at pitrou.net) Date: Mon, 31 Jul 2017 09:06:01 +0000 Subject: [Python-checkins] Daily reference leaks (4243df51fe43): sum=3 Message-ID: <20170731090600.3598.6A79C998D8A510D8@psf.io> results for 4243df51fe43 on branch "default" -------------------------------------------- test_collections leaked [7, 0, -7] memory blocks, sum=0 test_functools leaked [0, 3, 1] memory blocks, sum=4 test_multiprocessing_forkserver leaked [-2, 2, -1] memory blocks, sum=-1 Command line was: ['./python', '-m', 'test.regrtest', '-uall', '-R', '3:3:/home/psf-users/antoine/refleaks/reflogZMppdc', '--timeout', '7200'] From webhook-mailer at python.org Mon Jul 31 05:30:12 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Mon, 31 Jul 2017 09:30:12 -0000 Subject: [Python-checkins] bpo-25684: ttk.OptionMenu radiobuttons weren't unique (#2276) Message-ID: https://github.com/python/cpython/commit/a568e5273382a5dca0c27274f7d8e34c41a87d4d commit: a568e5273382a5dca0c27274f7d8e34c41a87d4d branch: master author: csabella committer: Serhiy Storchaka date: 2017-07-31T12:30:09+03:00 summary: bpo-25684: ttk.OptionMenu radiobuttons weren't unique (#2276) between instances of OptionMenu. files: A Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst M Lib/tkinter/test/test_ttk/test_extensions.py M Lib/tkinter/ttk.py diff --git a/Lib/tkinter/test/test_ttk/test_extensions.py b/Lib/tkinter/test/test_ttk/test_extensions.py index 218b27fc30e..a45f882bb00 100644 --- a/Lib/tkinter/test/test_ttk/test_extensions.py +++ b/Lib/tkinter/test/test_ttk/test_extensions.py @@ -291,6 +291,31 @@ def cb_test(item): optmenu.destroy() + def test_unique_radiobuttons(self): + # check that radiobuttons are unique across instances (bpo25684) + items = ('a', 'b', 'c') + default = 'a' + optmenu = ttk.OptionMenu(self.root, self.textvar, default, *items) + textvar2 = tkinter.StringVar(self.root) + optmenu2 = ttk.OptionMenu(self.root, textvar2, default, *items) + optmenu.pack() + optmenu.wait_visibility() + optmenu2.pack() + optmenu2.wait_visibility() + optmenu['menu'].invoke(1) + optmenu2['menu'].invoke(2) + optmenu_stringvar_name = optmenu['menu'].entrycget(0, 'variable') + optmenu2_stringvar_name = optmenu2['menu'].entrycget(0, 'variable') + self.assertNotEqual(optmenu_stringvar_name, + optmenu2_stringvar_name) + self.assertEqual(self.root.tk.globalgetvar(optmenu_stringvar_name), + items[1]) + self.assertEqual(self.root.tk.globalgetvar(optmenu2_stringvar_name), + items[2]) + + optmenu.destroy() + optmenu2.destroy() + tests_gui = (LabeledScaleTest, OptionMenuTest) diff --git a/Lib/tkinter/ttk.py b/Lib/tkinter/ttk.py index cbaad76e008..3ecc004f0e0 100644 --- a/Lib/tkinter/ttk.py +++ b/Lib/tkinter/ttk.py @@ -1635,7 +1635,8 @@ def set_menu(self, default=None, *values): menu.delete(0, 'end') for val in values: menu.add_radiobutton(label=val, - command=tkinter._setit(self._variable, val, self._callback)) + command=tkinter._setit(self._variable, val, self._callback), + variable=self._variable) if default: self._variable.set(default) diff --git a/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst b/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst new file mode 100644 index 00000000000..61d6b29cafc --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst @@ -0,0 +1,2 @@ +Change ``ttk.OptionMenu`` radiobuttons to be unique across instances of +``OptionMenu``. From webhook-mailer at python.org Mon Jul 31 10:24:44 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Mon, 31 Jul 2017 14:24:44 -0000 Subject: [Python-checkins] bpo-30640: Fix undefined behavior in _PyFunction_FastCallDict() and PyEval_EvalCodeEx() (#2919) Message-ID: https://github.com/python/cpython/commit/c6ea8974e2d939223bfd6d64ee13ec89c090d2e0 commit: c6ea8974e2d939223bfd6d64ee13ec89c090d2e0 branch: master author: Zackery Spytz committer: Serhiy Storchaka date: 2017-07-31T17:24:37+03:00 summary: bpo-30640: Fix undefined behavior in _PyFunction_FastCallDict() and PyEval_EvalCodeEx() (#2919) k + 1 was calculated with k = NULL. files: M Objects/call.c M Python/ceval.c diff --git a/Objects/call.c b/Objects/call.c index c3cc31dba9b..3b08cb25926 100644 --- a/Objects/call.c +++ b/Objects/call.c @@ -374,7 +374,7 @@ _PyFunction_FastCallDict(PyObject *func, PyObject **args, Py_ssize_t nargs, result = _PyEval_EvalCodeWithName((PyObject*)co, globals, (PyObject *)NULL, args, nargs, - k, k + 1, nk, 2, + k, k != NULL ? k + 1 : NULL, nk, 2, d, nd, kwdefs, closure, name, qualname); Py_XDECREF(kwtuple); diff --git a/Python/ceval.c b/Python/ceval.c index 59fc070f9e7..dd90e18a855 100644 --- a/Python/ceval.c +++ b/Python/ceval.c @@ -4220,7 +4220,8 @@ PyEval_EvalCodeEx(PyObject *_co, PyObject *globals, PyObject *locals, { return _PyEval_EvalCodeWithName(_co, globals, locals, args, argcount, - kws, kws + 1, kwcount, 2, + kws, kws != NULL ? kws + 1 : NULL, + kwcount, 2, defs, defcount, kwdefs, closure, NULL, NULL); From webhook-mailer at python.org Mon Jul 31 10:26:53 2017 From: webhook-mailer at python.org (Alexander Belopolsky) Date: Mon, 31 Jul 2017 14:26:53 -0000 Subject: [Python-checkins] Closes issue bpo-5288: Allow tzinfo objects with sub-minute offsets. (#2896) Message-ID: https://github.com/python/cpython/commit/018d353c1c8c87767d2335cd884017c2ce12e045 commit: 018d353c1c8c87767d2335cd884017c2ce12e045 branch: master author: Alexander Belopolsky committer: GitHub date: 2017-07-31T10:26:50-04:00 summary: Closes issue bpo-5288: Allow tzinfo objects with sub-minute offsets. (#2896) * Closes issue bpo-5288: Allow tzinfo objects with sub-minute offsets. * bpo-5288: Implemented %z formatting of sub-minute offsets. * bpo-5288: Removed mentions of the whole minute limitation on TZ offsets. * bpo-5288: Removed one more mention of the whole minute limitation. Thanks @csabella! * Fix a formatting error in the docs * Addressed review comments. Thanks, @haypo. files: A Misc/NEWS.d/next/Library/2017-07-26-13-18-29.bpo-5288.o_xEGj.rst M Doc/library/datetime.rst M Lib/datetime.py M Lib/test/datetimetester.py M Modules/_datetimemodule.c diff --git a/Doc/library/datetime.rst b/Doc/library/datetime.rst index 3880c2eb0b7..55be8694a06 100644 --- a/Doc/library/datetime.rst +++ b/Doc/library/datetime.rst @@ -1071,16 +1071,20 @@ Instance methods: If :attr:`.tzinfo` is ``None``, returns ``None``, else returns ``self.tzinfo.utcoffset(self)``, and raises an exception if the latter doesn't - return ``None``, or a :class:`timedelta` object representing a whole number of - minutes with magnitude less than one day. + return ``None`` or a :class:`timedelta` object with magnitude less than one day. + + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. .. method:: datetime.dst() If :attr:`.tzinfo` is ``None``, returns ``None``, else returns ``self.tzinfo.dst(self)``, and raises an exception if the latter doesn't return - ``None``, or a :class:`timedelta` object representing a whole number of minutes - with magnitude less than one day. + ``None`` or a :class:`timedelta` object with magnitude less than one day. + + .. versionchanged:: 3.7 + The DST offset is not restricted to a whole number of minutes. .. method:: datetime.tzname() @@ -1562,17 +1566,20 @@ Instance methods: If :attr:`.tzinfo` is ``None``, returns ``None``, else returns ``self.tzinfo.utcoffset(None)``, and raises an exception if the latter doesn't - return ``None`` or a :class:`timedelta` object representing a whole number of - minutes with magnitude less than one day. + return ``None`` or a :class:`timedelta` object with magnitude less than one day. + + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. .. method:: time.dst() If :attr:`.tzinfo` is ``None``, returns ``None``, else returns ``self.tzinfo.dst(None)``, and raises an exception if the latter doesn't return - ``None``, or a :class:`timedelta` object representing a whole number of minutes - with magnitude less than one day. + ``None``, or a :class:`timedelta` object with magnitude less than one day. + .. versionchanged:: 3.7 + The DST offset is not restricted to a whole number of minutes. .. method:: time.tzname() @@ -1641,13 +1648,14 @@ Example: .. method:: tzinfo.utcoffset(dt) - Return offset of local time from UTC, in minutes east of UTC. If local time is + Return offset of local time from UTC, as a :class:`timedelta` object that is + positive east of UTC. If local time is west of UTC, this should be negative. Note that this is intended to be the total offset from UTC; for example, if a :class:`tzinfo` object represents both time zone and DST adjustments, :meth:`utcoffset` should return their sum. If the UTC offset isn't known, return ``None``. Else the value returned must be a - :class:`timedelta` object specifying a whole number of minutes in the range - -1439 to 1439 inclusive (1440 = 24\*60; the magnitude of the offset must be less + :class:`timedelta` object strictly between ``-timedelta(hours=24)`` and + ``timedelta(hours=24)`` (the magnitude of the offset must be less than one day). Most implementations of :meth:`utcoffset` will probably look like one of these two:: @@ -1660,10 +1668,14 @@ Example: The default implementation of :meth:`utcoffset` raises :exc:`NotImplementedError`. + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. + .. method:: tzinfo.dst(dt) - Return the daylight saving time (DST) adjustment, in minutes east of UTC, or + Return the daylight saving time (DST) adjustment, as a :class:`timedelta` + object or ``None`` if DST information isn't known. Return ``timedelta(0)`` if DST is not in effect. If DST is in effect, return the offset as a :class:`timedelta` object (see :meth:`utcoffset` for details). Note that DST offset, if applicable, has @@ -1708,6 +1720,9 @@ Example: The default implementation of :meth:`dst` raises :exc:`NotImplementedError`. + .. versionchanged:: 3.7 + The DST offset is not restricted to a whole number of minutes. + .. method:: tzinfo.tzname(dt) @@ -1887,14 +1902,17 @@ made to civil time. The *offset* argument must be specified as a :class:`timedelta` object representing the difference between the local time and UTC. It must be strictly between ``-timedelta(hours=24)`` and - ``timedelta(hours=24)`` and represent a whole number of minutes, - otherwise :exc:`ValueError` is raised. + ``timedelta(hours=24)``, otherwise :exc:`ValueError` is raised. The *name* argument is optional. If specified it must be a string that will be used as the value returned by the :meth:`datetime.tzname` method. .. versionadded:: 3.2 + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. + + .. method:: timezone.utcoffset(dt) Return the fixed value specified when the :class:`timezone` instance is @@ -1902,6 +1920,9 @@ made to civil time. :class:`timedelta` instance equal to the difference between the local time and UTC. + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. + .. method:: timezone.tzname(dt) Return the fixed value specified when the :class:`timezone` instance @@ -2025,8 +2046,8 @@ format codes. | | number, zero-padded on the | 999999 | | | | left. | | | +-----------+--------------------------------+------------------------+-------+ -| ``%z`` | UTC offset in the form +HHMM | (empty), +0000, -0400, | \(6) | -| | or -HHMM (empty string if the | +1030 | | +| ``%z`` | UTC offset in the form | (empty), +0000, -0400, | \(6) | +| | ?HHMM[SS] (empty string if the | +1030 | | | | object is naive). | | | +-----------+--------------------------------+------------------------+-------+ | ``%Z`` | Time zone name (empty string | (empty), UTC, EST, CST | | @@ -2139,12 +2160,19 @@ Notes: For an aware object: ``%z`` - :meth:`utcoffset` is transformed into a 5-character string of the form - +HHMM or -HHMM, where HH is a 2-digit string giving the number of UTC + :meth:`utcoffset` is transformed into a string of the form + ?HHMM[SS[.uuuuuu]], where HH is a 2-digit string giving the number of UTC offset hours, and MM is a 2-digit string giving the number of UTC offset - minutes. For example, if :meth:`utcoffset` returns - ``timedelta(hours=-3, minutes=-30)``, ``%z`` is replaced with the string - ``'-0330'``. + minutes, SS is a 2-digit string string giving the number of UTC offset + seconds and uuuuuu is a 2-digit string string giving the number of UTC + offset microseconds. The uuuuuu part is omitted when the offset is a + whole number of minutes and both the uuuuuu and the SS parts are omitted + when the offset is a whole number of minutes. For example, if + :meth:`utcoffset` returns ``timedelta(hours=-3, minutes=-30)``, ``%z`` is + replaced with the string ``'-0330'``. + + .. versionchanged:: 3.7 + The UTC offset is not restricted to a whole number of minutes. ``%Z`` If :meth:`tzname` returns ``None``, ``%Z`` is replaced by an empty diff --git a/Lib/datetime.py b/Lib/datetime.py index 76a6f957e08..2f03847be0a 100644 --- a/Lib/datetime.py +++ b/Lib/datetime.py @@ -206,10 +206,16 @@ def _wrap_strftime(object, format, timetuple): if offset.days < 0: offset = -offset sign = '-' - h, m = divmod(offset, timedelta(hours=1)) - assert not m % timedelta(minutes=1), "whole minute" - m //= timedelta(minutes=1) - zreplace = '%c%02d%02d' % (sign, h, m) + h, rest = divmod(offset, timedelta(hours=1)) + m, rest = divmod(rest, timedelta(minutes=1)) + s = rest.seconds + u = offset.microseconds + if u: + zreplace = '%c%02d%02d%02d.%06d' % (sign, h, m, s, u) + elif s: + zreplace = '%c%02d%02d%02d' % (sign, h, m, s) + else: + zreplace = '%c%02d%02d' % (sign, h, m) assert '%' not in zreplace newformat.append(zreplace) elif ch == 'Z': @@ -241,7 +247,7 @@ def _check_tzname(name): # offset is what it returned. # If offset isn't None or timedelta, raises TypeError. # If offset is None, returns None. -# Else offset is checked for being in range, and a whole # of minutes. +# Else offset is checked for being in range. # If it is, its integer value is returned. Else ValueError is raised. def _check_utc_offset(name, offset): assert name in ("utcoffset", "dst") @@ -250,9 +256,6 @@ def _check_utc_offset(name, offset): if not isinstance(offset, timedelta): raise TypeError("tzinfo.%s() must return None " "or timedelta, not '%s'" % (name, type(offset))) - if offset.microseconds: - raise ValueError("tzinfo.%s() must return a whole number " - "of seconds, got %s" % (name, offset)) if not -timedelta(1) < offset < timedelta(1): raise ValueError("%s()=%s, must be strictly between " "-timedelta(hours=24) and timedelta(hours=24)" % @@ -960,11 +963,11 @@ def tzname(self, dt): raise NotImplementedError("tzinfo subclass must override tzname()") def utcoffset(self, dt): - "datetime -> minutes east of UTC (negative for west of UTC)" + "datetime -> timedelta, positive for east of UTC, negative for west of UTC" raise NotImplementedError("tzinfo subclass must override utcoffset()") def dst(self, dt): - """datetime -> DST offset in minutes east of UTC. + """datetime -> DST offset as timedelta, positive for east of UTC. Return 0 if DST not in effect. utcoffset() must include the DST offset. @@ -1262,8 +1265,8 @@ def __format__(self, fmt): # Timezone functions def utcoffset(self): - """Return the timezone offset in minutes east of UTC (negative west of - UTC).""" + """Return the timezone offset as timedelta, positive east of UTC + (negative west of UTC).""" if self._tzinfo is None: return None offset = self._tzinfo.utcoffset(None) @@ -1284,8 +1287,8 @@ def tzname(self): return name def dst(self): - """Return 0 if DST is not in effect, or the DST offset (in minutes - eastward) if DST is in effect. + """Return 0 if DST is not in effect, or the DST offset (as timedelta + positive eastward) if DST is in effect. This is purely informational; the DST offset has already been added to the UTC offset returned by utcoffset() if applicable, so there's no @@ -1714,7 +1717,7 @@ def strptime(cls, date_string, format): return _strptime._strptime_datetime(cls, date_string, format) def utcoffset(self): - """Return the timezone offset in minutes east of UTC (negative west of + """Return the timezone offset as timedelta positive east of UTC (negative west of UTC).""" if self._tzinfo is None: return None @@ -1736,8 +1739,8 @@ def tzname(self): return name def dst(self): - """Return 0 if DST is not in effect, or the DST offset (in minutes - eastward) if DST is in effect. + """Return 0 if DST is not in effect, or the DST offset (as timedelta + positive eastward) if DST is in effect. This is purely informational; the DST offset has already been added to the UTC offset returned by utcoffset() if applicable, so there's no @@ -1962,9 +1965,6 @@ def __new__(cls, offset, name=_Omitted): raise ValueError("offset must be a timedelta " "strictly between -timedelta(hours=24) and " "timedelta(hours=24).") - if (offset.microseconds != 0 or offset.seconds % 60 != 0): - raise ValueError("offset must be a timedelta " - "representing a whole number of minutes") return cls._create(offset, name) @classmethod @@ -2053,8 +2053,15 @@ def _name_from_offset(delta): else: sign = '+' hours, rest = divmod(delta, timedelta(hours=1)) - minutes = rest // timedelta(minutes=1) - return 'UTC{}{:02d}:{:02d}'.format(sign, hours, minutes) + minutes, rest = divmod(rest, timedelta(minutes=1)) + seconds = rest.seconds + microseconds = rest.microseconds + if microseconds: + return (f'UTC{sign}{hours:02d}:{minutes:02d}:{seconds:02d}' + f'.{microseconds:06d}') + if seconds: + return f'UTC{sign}{hours:02d}:{minutes:02d}:{seconds:02d}' + return f'UTC{sign}{hours:02d}:{minutes:02d}' timezone.utc = timezone._create(timedelta(0)) timezone.min = timezone._create(timezone._minoffset) diff --git a/Lib/test/datetimetester.py b/Lib/test/datetimetester.py index 22008884b54..29b70e1a8a0 100644 --- a/Lib/test/datetimetester.py +++ b/Lib/test/datetimetester.py @@ -255,14 +255,15 @@ def test_class_members(self): self.assertEqual(timezone.min.utcoffset(None), -limit) self.assertEqual(timezone.max.utcoffset(None), limit) - def test_constructor(self): self.assertIs(timezone.utc, timezone(timedelta(0))) self.assertIsNot(timezone.utc, timezone(timedelta(0), 'UTC')) self.assertEqual(timezone.utc, timezone(timedelta(0), 'UTC')) + for subminute in [timedelta(microseconds=1), timedelta(seconds=1)]: + tz = timezone(subminute) + self.assertNotEqual(tz.utcoffset(None) % timedelta(minutes=1), 0) # invalid offsets - for invalid in [timedelta(microseconds=1), timedelta(1, 1), - timedelta(seconds=1), timedelta(1), -timedelta(1)]: + for invalid in [timedelta(1, 1), timedelta(1)]: self.assertRaises(ValueError, timezone, invalid) self.assertRaises(ValueError, timezone, -invalid) @@ -301,6 +302,15 @@ def test_tzname(self): self.assertEqual('UTC-00:01', timezone(timedelta(minutes=-1)).tzname(None)) self.assertEqual('XYZ', timezone(-5 * HOUR, 'XYZ').tzname(None)) + # Sub-minute offsets: + self.assertEqual('UTC+01:06:40', timezone(timedelta(0, 4000)).tzname(None)) + self.assertEqual('UTC-01:06:40', + timezone(-timedelta(0, 4000)).tzname(None)) + self.assertEqual('UTC+01:06:40.000001', + timezone(timedelta(0, 4000, 1)).tzname(None)) + self.assertEqual('UTC-01:06:40.000001', + timezone(-timedelta(0, 4000, 1)).tzname(None)) + with self.assertRaises(TypeError): self.EST.tzname('') with self.assertRaises(TypeError): self.EST.tzname(5) @@ -2152,6 +2162,9 @@ def test_more_strftime(self): t = self.theclass(2004, 12, 31, 6, 22, 33, 47) self.assertEqual(t.strftime("%m %d %y %f %S %M %H %j"), "12 31 04 000047 33 22 06 366") + tz = timezone(-timedelta(hours=2, seconds=33, microseconds=123)) + t = t.replace(tzinfo=tz) + self.assertEqual(t.strftime("%z"), "-020033.000123") def test_extract(self): dt = self.theclass(2002, 3, 4, 18, 45, 3, 1234) @@ -2717,8 +2730,8 @@ class C7(tzinfo): def utcoffset(self, dt): return timedelta(microseconds=61) def dst(self, dt): return timedelta(microseconds=-81) t = cls(1, 1, 1, tzinfo=C7()) - self.assertRaises(ValueError, t.utcoffset) - self.assertRaises(ValueError, t.dst) + self.assertEqual(t.utcoffset(), timedelta(microseconds=61)) + self.assertEqual(t.dst(), timedelta(microseconds=-81)) def test_aware_compare(self): cls = self.theclass @@ -4297,7 +4310,6 @@ def test_vilnius_1941_toutc(self): self.assertEqual(gdt.strftime("%c %Z"), 'Mon Jun 23 22:00:00 1941 UTC') - def test_constructors(self): t = time(0, fold=1) dt = datetime(1, 1, 1, fold=1) @@ -4372,7 +4384,6 @@ def test_fromtimestamp_lord_howe(self): self.assertEqual(t0.fold, 0) self.assertEqual(t1.fold, 1) - @support.run_with_tz('EST+05EDT,M3.2.0,M11.1.0') def test_timestamp(self): dt0 = datetime(2014, 11, 2, 1, 30) @@ -4390,7 +4401,6 @@ def test_timestamp_lord_howe(self): s1 = t.replace(fold=1).timestamp() self.assertEqual(s0 + 1800, s1) - @support.run_with_tz('EST+05EDT,M3.2.0,M11.1.0') def test_astimezone(self): dt0 = datetime(2014, 11, 2, 1, 30) @@ -4406,7 +4416,6 @@ def test_astimezone(self): self.assertEqual(adt0.fold, 0) self.assertEqual(adt1.fold, 0) - def test_pickle_fold(self): t = time(fold=1) dt = datetime(1, 1, 1, fold=1) diff --git a/Misc/NEWS.d/next/Library/2017-07-26-13-18-29.bpo-5288.o_xEGj.rst b/Misc/NEWS.d/next/Library/2017-07-26-13-18-29.bpo-5288.o_xEGj.rst new file mode 100644 index 00000000000..a7eaa06107f --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-26-13-18-29.bpo-5288.o_xEGj.rst @@ -0,0 +1 @@ +Support tzinfo objects with sub-minute offsets. diff --git a/Modules/_datetimemodule.c b/Modules/_datetimemodule.c index 28805d18da8..1b68ff3b372 100644 --- a/Modules/_datetimemodule.c +++ b/Modules/_datetimemodule.c @@ -859,12 +859,6 @@ new_timezone(PyObject *offset, PyObject *name) Py_INCREF(PyDateTime_TimeZone_UTC); return PyDateTime_TimeZone_UTC; } - if (GET_TD_MICROSECONDS(offset) != 0 || GET_TD_SECONDS(offset) % 60 != 0) { - PyErr_Format(PyExc_ValueError, "offset must be a timedelta" - " representing a whole number of minutes," - " not %R.", offset); - return NULL; - } if ((GET_TD_DAYS(offset) == -1 && GET_TD_SECONDS(offset) == 0) || GET_TD_DAYS(offset) < -1 || GET_TD_DAYS(offset) >= 1) { PyErr_Format(PyExc_ValueError, "offset must be a timedelta" @@ -935,12 +929,6 @@ call_tzinfo_method(PyObject *tzinfo, const char *name, PyObject *tzinfoarg) if (offset == Py_None || offset == NULL) return offset; if (PyDelta_Check(offset)) { - if (GET_TD_MICROSECONDS(offset) != 0) { - Py_DECREF(offset); - PyErr_Format(PyExc_ValueError, "offset must be a timedelta" - " representing a whole number of seconds"); - return NULL; - } if ((GET_TD_DAYS(offset) == -1 && GET_TD_SECONDS(offset) == 0) || GET_TD_DAYS(offset) < -1 || GET_TD_DAYS(offset) >= 1) { Py_DECREF(offset); @@ -966,9 +954,9 @@ call_tzinfo_method(PyObject *tzinfo, const char *name, PyObject *tzinfoarg) * result. tzinfo must be an instance of the tzinfo class. If utcoffset() * returns None, call_utcoffset returns 0 and sets *none to 1. If uctoffset() * doesn't return None or timedelta, TypeError is raised and this returns -1. - * If utcoffset() returns an invalid timedelta (out of range, or not a whole - * # of minutes), ValueError is raised and this returns -1. Else *none is - * set to 0 and the offset is returned (as int # of minutes east of UTC). + * If utcoffset() returns an out of range timedelta, + * ValueError is raised and this returns -1. Else *none is + * set to 0 and the offset is returned (as timedelta, positive east of UTC). */ static PyObject * call_utcoffset(PyObject *tzinfo, PyObject *tzinfoarg) @@ -979,10 +967,10 @@ call_utcoffset(PyObject *tzinfo, PyObject *tzinfoarg) /* Call tzinfo.dst(tzinfoarg), and extract an integer from the * result. tzinfo must be an instance of the tzinfo class. If dst() * returns None, call_dst returns 0 and sets *none to 1. If dst() - & doesn't return None or timedelta, TypeError is raised and this + * doesn't return None or timedelta, TypeError is raised and this * returns -1. If dst() returns an invalid timedelta for a UTC offset, * ValueError is raised and this returns -1. Else *none is set to 0 and - * the offset is returned (as an int # of minutes east of UTC). + * the offset is returned (as timedelta, positive east of UTC). */ static PyObject * call_dst(PyObject *tzinfo, PyObject *tzinfoarg) @@ -1100,13 +1088,13 @@ format_ctime(PyDateTime_Date *date, int hours, int minutes, int seconds) static PyObject *delta_negative(PyDateTime_Delta *self); -/* Add an hours & minutes UTC offset string to buf. buf has no more than +/* Add formatted UTC offset string to buf. buf has no more than * buflen bytes remaining. The UTC offset is gotten by calling * tzinfo.uctoffset(tzinfoarg). If that returns None, \0 is stored into * *buf, and that's all. Else the returned value is checked for sanity (an * integer in range), and if that's OK it's converted to an hours & minutes * string of the form - * sign HH sep MM + * sign HH sep MM [sep SS [. UUUUUU]] * Returns 0 if everything is OK. If the return value from utcoffset() is * bogus, an appropriate exception is set and -1 is returned. */ @@ -1115,7 +1103,7 @@ format_utcoffset(char *buf, size_t buflen, const char *sep, PyObject *tzinfo, PyObject *tzinfoarg) { PyObject *offset; - int hours, minutes, seconds; + int hours, minutes, seconds, microseconds; char sign; assert(buflen >= 1); @@ -1139,15 +1127,22 @@ format_utcoffset(char *buf, size_t buflen, const char *sep, sign = '+'; } /* Offset is not negative here. */ + microseconds = GET_TD_MICROSECONDS(offset); seconds = GET_TD_SECONDS(offset); Py_DECREF(offset); minutes = divmod(seconds, 60, &seconds); hours = divmod(minutes, 60, &minutes); - if (seconds == 0) - PyOS_snprintf(buf, buflen, "%c%02d%s%02d", sign, hours, sep, minutes); - else + if (microseconds) { + PyOS_snprintf(buf, buflen, "%c%02d%s%02d%s%02d.%06d", sign, + hours, sep, minutes, sep, seconds, microseconds); + return 0; + } + if (seconds) { PyOS_snprintf(buf, buflen, "%c%02d%s%02d%s%02d", sign, hours, sep, minutes, sep, seconds); + return 0; + } + PyOS_snprintf(buf, buflen, "%c%02d%s%02d", sign, hours, sep, minutes); return 0; } @@ -3241,7 +3236,7 @@ static PyMethodDef tzinfo_methods[] = { "values indicating West of UTC")}, {"dst", (PyCFunction)tzinfo_dst, METH_O, - PyDoc_STR("datetime -> DST offset in minutes east of UTC.")}, + PyDoc_STR("datetime -> DST offset as timedelta positive east of UTC.")}, {"fromutc", (PyCFunction)tzinfo_fromutc, METH_O, PyDoc_STR("datetime in UTC -> datetime in local time.")}, @@ -3375,7 +3370,7 @@ timezone_repr(PyDateTime_TimeZone *self) static PyObject * timezone_str(PyDateTime_TimeZone *self) { - int hours, minutes, seconds; + int hours, minutes, seconds, microseconds; PyObject *offset; char sign; @@ -3401,12 +3396,20 @@ timezone_str(PyDateTime_TimeZone *self) Py_INCREF(offset); } /* Offset is not negative here. */ + microseconds = GET_TD_MICROSECONDS(offset); seconds = GET_TD_SECONDS(offset); Py_DECREF(offset); minutes = divmod(seconds, 60, &seconds); hours = divmod(minutes, 60, &minutes); - /* XXX ignore sub-minute data, currently not allowed. */ - assert(seconds == 0); + if (microseconds != 0) { + return PyUnicode_FromFormat("UTC%c%02d:%02d:%02d.%06d", + sign, hours, minutes, + seconds, microseconds); + } + if (seconds != 0) { + return PyUnicode_FromFormat("UTC%c%02d:%02d:%02d", + sign, hours, minutes, seconds); + } return PyUnicode_FromFormat("UTC%c%02d:%02d", sign, hours, minutes); } From webhook-mailer at python.org Mon Jul 31 13:52:49 2017 From: webhook-mailer at python.org (=?utf-8?q?=C5=81ukasz?= Langa) Date: Mon, 31 Jul 2017 17:52:49 -0000 Subject: [Python-checkins] bpo-29519: weakref spewing exceptions during interp finalization (#2958) Message-ID: https://github.com/python/cpython/commit/3e37f4a11547a226c3c2f8bd612510465db397b9 commit: 3e37f4a11547a226c3c2f8bd612510465db397b9 branch: 2.7 author: INADA Naoki committer: ?ukasz Langa date: 2017-07-31T10:52:46-07:00 summary: bpo-29519: weakref spewing exceptions during interp finalization (#2958) (cherry pick from 9cd7e17640a49635d1c1f8c2989578a8fc2c1de6) files: A Misc/NEWS.d/next/Library/2017-07-31-19-32-57.bpo-29519._j1awg.rst M Lib/weakref.py diff --git a/Lib/weakref.py b/Lib/weakref.py index c66943f02e2..3e1fb815806 100644 --- a/Lib/weakref.py +++ b/Lib/weakref.py @@ -53,7 +53,7 @@ def __init__(*args, **kw): args = args[1:] if len(args) > 1: raise TypeError('expected at most 1 arguments, got %d' % len(args)) - def remove(wr, selfref=ref(self)): + def remove(wr, selfref=ref(self), _atomic_removal=_remove_dead_weakref): self = selfref() if self is not None: if self._iterating: @@ -61,7 +61,7 @@ def remove(wr, selfref=ref(self)): else: # Atomic removal is necessary since this function # can be called asynchronously by the GC - _remove_dead_weakref(self.data, wr.key) + _atomic_removal(self.data, wr.key) self._remove = remove # A list of keys to be removed self._pending_removals = [] diff --git a/Misc/NEWS.d/next/Library/2017-07-31-19-32-57.bpo-29519._j1awg.rst b/Misc/NEWS.d/next/Library/2017-07-31-19-32-57.bpo-29519._j1awg.rst new file mode 100644 index 00000000000..9b2e39d3318 --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-31-19-32-57.bpo-29519._j1awg.rst @@ -0,0 +1,2 @@ +Fix weakref spewing exceptions during interpreter shutdown when used with a +rare combination of multiprocessing and custom codecs. From webhook-mailer at python.org Mon Jul 31 14:16:17 2017 From: webhook-mailer at python.org (Mariatta) Date: Mon, 31 Jul 2017 18:16:17 -0000 Subject: [Python-checkins] bpo-25910: Update LICENSE (GH-2873) Message-ID: https://github.com/python/cpython/commit/8474d87165593bac2bc231287f42c4cff3fd6aaf commit: 8474d87165593bac2bc231287f42c4cff3fd6aaf branch: master author: Mariatta committer: GitHub date: 2017-07-31T11:16:14-07:00 summary: bpo-25910: Update LICENSE (GH-2873) Use the copy provided in https://bugs.python.org/issue25910#msg295200 files: M LICENSE diff --git a/LICENSE b/LICENSE index f5d0b39a0cd..529349e4b38 100644 --- a/LICENSE +++ b/LICENSE @@ -13,12 +13,11 @@ software. In May 2000, Guido and the Python core development team moved to BeOpen.com to form the BeOpen PythonLabs team. In October of the same -year, the PythonLabs team moved to Digital Creations (now Zope -Corporation, see http://www.zope.com). In 2001, the Python Software -Foundation (PSF, see http://www.python.org/psf/) was formed, a -non-profit organization created specifically to own Python-related -Intellectual Property. Zope Corporation is a sponsoring member of -the PSF. +year, the PythonLabs team moved to Digital Creations, which became +Zope Corporation. In 2001, the Python Software Foundation (PSF, see +https://www.python.org/psf/) was formed, a non-profit organization +created specifically to own Python-related Intellectual Property. +Zope Corporation was a sponsoring member of the PSF. All Python releases are Open Source (see http://www.opensource.org for the Open Source Definition). Historically, most, but not all, Python From webhook-mailer at python.org Mon Jul 31 15:10:16 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Mon, 31 Jul 2017 19:10:16 -0000 Subject: [Python-checkins] [3.6] bpo-25684: ttk.OptionMenu radiobuttons weren't unique (GH-2276) (#2959) Message-ID: https://github.com/python/cpython/commit/2bf1586e60a6639b532cd8e3442ae33064523eb1 commit: 2bf1586e60a6639b532cd8e3442ae33064523eb1 branch: 3.6 author: csabella committer: Serhiy Storchaka date: 2017-07-31T22:10:13+03:00 summary: [3.6] bpo-25684: ttk.OptionMenu radiobuttons weren't unique (GH-2276) (#2959) between instances of OptionMenu. (cherry picked from commit a568e5273382a5dca0c27274f7d8e34c41a87d4d) * Update Misc/ACKS files: A Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst M Lib/tkinter/test/test_ttk/test_extensions.py M Lib/tkinter/ttk.py M Misc/ACKS diff --git a/Lib/tkinter/test/test_ttk/test_extensions.py b/Lib/tkinter/test/test_ttk/test_extensions.py index 218b27fc30e..a45f882bb00 100644 --- a/Lib/tkinter/test/test_ttk/test_extensions.py +++ b/Lib/tkinter/test/test_ttk/test_extensions.py @@ -291,6 +291,31 @@ def cb_test(item): optmenu.destroy() + def test_unique_radiobuttons(self): + # check that radiobuttons are unique across instances (bpo25684) + items = ('a', 'b', 'c') + default = 'a' + optmenu = ttk.OptionMenu(self.root, self.textvar, default, *items) + textvar2 = tkinter.StringVar(self.root) + optmenu2 = ttk.OptionMenu(self.root, textvar2, default, *items) + optmenu.pack() + optmenu.wait_visibility() + optmenu2.pack() + optmenu2.wait_visibility() + optmenu['menu'].invoke(1) + optmenu2['menu'].invoke(2) + optmenu_stringvar_name = optmenu['menu'].entrycget(0, 'variable') + optmenu2_stringvar_name = optmenu2['menu'].entrycget(0, 'variable') + self.assertNotEqual(optmenu_stringvar_name, + optmenu2_stringvar_name) + self.assertEqual(self.root.tk.globalgetvar(optmenu_stringvar_name), + items[1]) + self.assertEqual(self.root.tk.globalgetvar(optmenu2_stringvar_name), + items[2]) + + optmenu.destroy() + optmenu2.destroy() + tests_gui = (LabeledScaleTest, OptionMenuTest) diff --git a/Lib/tkinter/ttk.py b/Lib/tkinter/ttk.py index c474e60713f..9cd0c2073a9 100644 --- a/Lib/tkinter/ttk.py +++ b/Lib/tkinter/ttk.py @@ -1638,7 +1638,8 @@ def set_menu(self, default=None, *values): menu.delete(0, 'end') for val in values: menu.add_radiobutton(label=val, - command=tkinter._setit(self._variable, val, self._callback)) + command=tkinter._setit(self._variable, val, self._callback), + variable=self._variable) if default: self._variable.set(default) diff --git a/Misc/ACKS b/Misc/ACKS index b6b355b614b..7bc13ff0c9e 100644 --- a/Misc/ACKS +++ b/Misc/ACKS @@ -1340,6 +1340,7 @@ Chris Ryland Bernt R?skar Brenna Constantina S. Matthieu S +Cheryl Sabella Patrick Sabin S?bastien Sabl? Amit Saha diff --git a/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst b/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst new file mode 100644 index 00000000000..61d6b29cafc --- /dev/null +++ b/Misc/NEWS.d/next/Library/2017-07-17-11-35-00.bpo-25684.usELVx.rst @@ -0,0 +1,2 @@ +Change ``ttk.OptionMenu`` radiobuttons to be unique across instances of +``OptionMenu``. From webhook-mailer at python.org Mon Jul 31 16:27:51 2017 From: webhook-mailer at python.org (Serhiy Storchaka) Date: Mon, 31 Jul 2017 20:27:51 -0000 Subject: [Python-checkins] bpo-31091: Remove dead code in PyErr_GivenExceptionMatches(). (#2963) Message-ID: https://github.com/python/cpython/commit/e4c06bcca358c6dcb6393a75a1589ff6a2d45cde commit: e4c06bcca358c6dcb6393a75a1589ff6a2d45cde branch: master author: scoder committer: Serhiy Storchaka date: 2017-07-31T23:27:46+03:00 summary: bpo-31091: Remove dead code in PyErr_GivenExceptionMatches(). (#2963) According to the comment, there was previously a call to PyObject_IsSubclass() involved which could fail, but since it was replaced with a call to PyType_IsSubtype(), it can no longer fail. files: M Python/errors.c diff --git a/Python/errors.c b/Python/errors.c index 3785e6981c6..261dd7b27cb 100644 --- a/Python/errors.c +++ b/Python/errors.c @@ -191,19 +191,7 @@ PyErr_GivenExceptionMatches(PyObject *err, PyObject *exc) err = PyExceptionInstance_Class(err); if (PyExceptionClass_Check(err) && PyExceptionClass_Check(exc)) { - int res = 0; - PyObject *exception, *value, *tb; - PyErr_Fetch(&exception, &value, &tb); - /* PyObject_IsSubclass() can recurse and therefore is - not safe (see test_bad_getattr in test.pickletester). */ - res = PyType_IsSubtype((PyTypeObject *)err, (PyTypeObject *)exc); - /* This function must not fail, so print the error here */ - if (res == -1) { - PyErr_WriteUnraisable(err); - res = 0; - } - PyErr_Restore(exception, value, tb); - return res; + return PyType_IsSubtype((PyTypeObject *)err, (PyTypeObject *)exc); } return err == exc; From lp_benchmark_robot at intel.com Mon Jul 31 20:16:36 2017 From: lp_benchmark_robot at intel.com (lp_benchmark_robot at intel.com) Date: Mon, 31 Jul 2017 17:16:36 -0700 Subject: [Python-checkins] [1 up, 64 flat] Results for Python (master branch) 2017-07-31 Message-ID: <0ad95edb-1a28-42f3-9c17-2fd75c99ef7b@orsmsx156.amr.corp.intel.com> Results for project python/master, build date: 2017-07-31 03:03:23-07:00. - commit: a568e52 - previous commit: 6fcb69d - revision date: 2017-07-31 12:30:09+03:00 - environment: Broadwell-EP - cpu: Intel(R) Xeon(R) CPU E5-2699 v4 @ 2.20GHz 2x22 cores, stepping 1, LLC 55 MB - mem: 128 GB - os: Ubuntu 16.04.2 LTS - kernel: 4.4.0-62-generic x86_64 GNU/Linux Baseline results were generated using release v3.6.0, with hash 5c4568a from 2016-12-22 23:38:47+00:00. +-----+------------------------+--------+------------+------------+------------+ | | |relative|change since|change since|current rev | | | benchmark|std_dev*| last run | baseline |run with PGO| +-----+------------------------+--------+------------+------------+------------+ | :-| | 2to3| 1.014% | -0.055% | +4.986% | +6.226% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method| 1.919% | -0.809% | +24.000% | +3.105% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_slots| 1.598% | +0.656% | +25.281% | +2.686% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_method_unknown| 1.628% | -0.346% | +22.231% | +4.553% | +-----+------------------------+--------+------------+------------+------------+ | :-| | call_simple| 3.424% | -0.666% | +5.701% | +9.842% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chameleon| 1.486% | +0.239% | +11.244% | +9.706% | +-----+------------------------+--------+------------+------------+------------+ | :-| | chaos| 0.709% | +0.424% | +8.618% | +7.874% | +-----+------------------------+--------+------------+------------+------------+ | :-| | crypto_pyaes| 0.521% | +0.234% | +5.467% | +4.227% | +-----+------------------------+--------+------------+------------+------------+ | :-| | deltablue| 3.200% | -0.158% | +6.877% | +18.139% | +-----+------------------------+--------+------------+------------+------------+ | :-| | django_template| 4.778% | +0.448% | +9.512% | +12.062% | +-----+------------------------+--------+------------+------------+------------+ | :-| | dulwich_log| 1.354% | +0.178% | +3.893% | +6.344% | +-----+------------------------+--------+------------+------------+------------+ | :-| | fannkuch| 0.831% | +0.064% | +5.060% | +5.819% | +-----+------------------------+--------+------------+------------+------------+ | :-| | float| 0.954% | -0.150% | +3.639% | +5.357% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_text| 1.536% | -0.090% | +9.184% | +11.541% | +-----+------------------------+--------+------------+------------+------------+ | :-| | genshi_xml| 2.609% | +0.298% | +7.395% | +9.356% | +-----+------------------------+--------+------------+------------+------------+ | :-| | go| 1.018% | +0.137% | +7.614% | +9.418% | +-----+------------------------+--------+------------+------------+------------+ | :-| | hexiom| 1.351% | -0.107% | +10.356% | +10.394% | +-----+------------------------+--------+------------+------------+------------+ | :-| | html5lib| 3.376% | +0.179% | +9.172% | +7.094% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_dumps| 1.468% | +0.653% | +3.505% | +9.449% | +-----+------------------------+--------+------------+------------+------------+ | :-| | json_loads| 4.005% | -0.142% | +1.770% | +11.039% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_format| 1.443% | +3.355% | +10.513% | +10.787% | +-----+------------------------+--------+------------+------------+------------+ | :-) | logging_silent| 2.755% | +41.508% | +47.148% | +11.714% | +-----+------------------------+--------+------------+------------+------------+ | :-| | logging_simple| 1.432% | +3.433% | +11.250% | +10.681% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mako| 0.555% | +0.104% | +18.469% | +12.256% | +-----+------------------------+--------+------------+------------+------------+ | :-| | mdp| 7.063% | -0.172% | +5.457% | +13.246% | +-----+------------------------+--------+------------+------------+------------+ | :-| | meteor_contest| 2.354% | +0.127% | +4.503% | +4.746% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nbody| 1.730% | -0.185% | -3.352% | +3.991% | +-----+------------------------+--------+------------+------------+------------+ | :-| | nqueens| 1.204% | -0.067% | +2.541% | +6.440% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pathlib| 1.151% | +0.675% | +2.692% | +12.220% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle| 3.555% | -1.340% | +3.052% | +21.767% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_dict| 0.455% | -0.157% | +2.301% | +16.047% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_list| 1.088% | +0.932% | +5.719% | +15.614% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pickle_pure_python| 3.659% | -0.572% | +12.409% | +9.080% | +-----+------------------------+--------+------------+------------+------------+ | :-| | pidigits| 0.083% | +0.021% | +0.391% | +9.427% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup| 0.124% | +0.046% | +9.831% | +3.843% | +-----+------------------------+--------+------------+------------+------------+ | :-| | python_startup_no_site| 0.093% | +0.159% | +1.644% | +3.875% | +-----+------------------------+--------+------------+------------+------------+ | :-| | raytrace| 0.704% | -0.044% | +10.982% | +10.737% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_compile| 4.937% | +1.243% | -8.272% | +7.384% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_dna| 0.493% | +0.401% | +2.167% | +7.999% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_effbot| 1.542% | -0.137% | -2.023% | +4.415% | +-----+------------------------+--------+------------+------------+------------+ | :-| | regex_v8| 2.046% | -0.088% | +11.600% | +3.683% | +-----+------------------------+--------+------------+------------+------------+ | :-| | richards| 2.036% | -0.335% | +9.234% | +13.045% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_fft| 0.478% | -0.078% | +1.188% | +2.177% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_lu| 1.488% | -0.511% | +26.873% | +9.008% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_monte_carlo| 1.486% | -0.585% | +5.252% | +4.702% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sor| 1.194% | -0.109% | +16.027% | +5.663% | +-----+------------------------+--------+------------+------------+------------+ | :-| | scimark_sparse_mat_mult| 2.895% | -0.432% | +0.818% | -3.529% | +-----+------------------------+--------+------------+------------+------------+ | :-| | spectral_norm| 0.804% | -0.242% | +6.384% | +0.754% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_declarative| 1.537% | +1.272% | +6.410% | +5.428% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlalchemy_imperative| 3.548% | +0.823% | +4.776% | +4.811% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sqlite_synth| 3.927% | +1.371% | +2.271% | +9.270% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_expand| 2.278% | -0.106% | +12.786% | +7.110% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_integrate| 1.595% | +0.315% | +10.710% | +5.531% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_str| 3.705% | +0.972% | +12.344% | +7.369% | +-----+------------------------+--------+------------+------------+------------+ | :-| | sympy_sum| 4.265% | +0.730% | +13.410% | +8.651% | +-----+------------------------+--------+------------+------------+------------+ | :-| | telco| 5.687% | -1.771% | +21.280% | +8.267% | +-----+------------------------+--------+------------+------------+------------+ | :-| | tornado_http| 1.152% | +0.221% | +6.979% | +5.647% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpack_sequence| 1.382% | -0.157% | +1.977% | +0.618% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle| 5.908% | +0.432% | +8.384% | +20.922% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_list| 0.947% | +0.285% | -1.427% | +17.364% | +-----+------------------------+--------+------------+------------+------------+ | :-| | unpickle_pure_python| 2.361% | -0.034% | +7.043% | +6.487% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_generate| 1.317% | -0.056% | +5.487% | +7.177% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_iterparse| 2.531% | -0.075% | +1.497% | +7.770% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_parse| 1.683% | +0.939% | -5.474% | +10.630% | +-----+------------------------+--------+------------+------------+------------+ | :-| | xml_etree_process| 1.450% | -0.290% | +6.535% | +7.298% | +-----+------------------------+--------+------------+------------+------------+ * Relative Standard Deviation (Standard Deviation/Average) If this is not displayed properly please visit our results page here: http://languagesperformance.intel.com/1-up-64-flat-results-for-python-master-branch-2017-07-31 Our lab does a nightly source pull and build of the Python project and measures performance changes against the previous stable version and the previous nightly measurement. This is provided as a service to the community so that quality issues with current hardware can be identified quickly. Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. From webhook-mailer at python.org Mon Jul 31 22:53:46 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 01 Aug 2017 02:53:46 -0000 Subject: [Python-checkins] bpo-25910: Update LICENSE (GH-2873) (GH-2968) Message-ID: https://github.com/python/cpython/commit/f6306e737203ac1bf1717bbf62bc58dac24b68db commit: f6306e737203ac1bf1717bbf62bc58dac24b68db branch: 3.5 author: Mariatta committer: GitHub date: 2017-07-31T19:53:43-07:00 summary: bpo-25910: Update LICENSE (GH-2873) (GH-2968) Use the copy provided in https://bugs.python.org/issue25910GH-msg295200 (cherry picked from commit 8474d87165593bac2bc231287f42c4cff3fd6aaf) files: M LICENSE diff --git a/LICENSE b/LICENSE index f5d0b39a0cd..529349e4b38 100644 --- a/LICENSE +++ b/LICENSE @@ -13,12 +13,11 @@ software. In May 2000, Guido and the Python core development team moved to BeOpen.com to form the BeOpen PythonLabs team. In October of the same -year, the PythonLabs team moved to Digital Creations (now Zope -Corporation, see http://www.zope.com). In 2001, the Python Software -Foundation (PSF, see http://www.python.org/psf/) was formed, a -non-profit organization created specifically to own Python-related -Intellectual Property. Zope Corporation is a sponsoring member of -the PSF. +year, the PythonLabs team moved to Digital Creations, which became +Zope Corporation. In 2001, the Python Software Foundation (PSF, see +https://www.python.org/psf/) was formed, a non-profit organization +created specifically to own Python-related Intellectual Property. +Zope Corporation was a sponsoring member of the PSF. All Python releases are Open Source (see http://www.opensource.org for the Open Source Definition). Historically, most, but not all, Python From webhook-mailer at python.org Mon Jul 31 22:55:23 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 01 Aug 2017 02:55:23 -0000 Subject: [Python-checkins] bpo-25910: Update LICENSE (GH-2873) (GH-2969) Message-ID: https://github.com/python/cpython/commit/b3c7d37c5ac8dbba4f1ebcf279bfceb570fb6c19 commit: b3c7d37c5ac8dbba4f1ebcf279bfceb570fb6c19 branch: 2.7 author: Mariatta committer: GitHub date: 2017-07-31T19:55:20-07:00 summary: bpo-25910: Update LICENSE (GH-2873) (GH-2969) Use the copy provided in https://bugs.python.org/issue25910GH-msg295200 (cherry picked from commit 8474d87165593bac2bc231287f42c4cff3fd6aaf) files: M LICENSE diff --git a/LICENSE b/LICENSE index f5d0b39a0cd..529349e4b38 100644 --- a/LICENSE +++ b/LICENSE @@ -13,12 +13,11 @@ software. In May 2000, Guido and the Python core development team moved to BeOpen.com to form the BeOpen PythonLabs team. In October of the same -year, the PythonLabs team moved to Digital Creations (now Zope -Corporation, see http://www.zope.com). In 2001, the Python Software -Foundation (PSF, see http://www.python.org/psf/) was formed, a -non-profit organization created specifically to own Python-related -Intellectual Property. Zope Corporation is a sponsoring member of -the PSF. +year, the PythonLabs team moved to Digital Creations, which became +Zope Corporation. In 2001, the Python Software Foundation (PSF, see +https://www.python.org/psf/) was formed, a non-profit organization +created specifically to own Python-related Intellectual Property. +Zope Corporation was a sponsoring member of the PSF. All Python releases are Open Source (see http://www.opensource.org for the Open Source Definition). Historically, most, but not all, Python From webhook-mailer at python.org Mon Jul 31 22:59:53 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 01 Aug 2017 02:59:53 -0000 Subject: [Python-checkins] bpo-25910: Update LICENSE (GH-2873) (GH-2967) Message-ID: https://github.com/python/cpython/commit/330cdac5174e3dc6c1deb876bc12a39d7af9af84 commit: 330cdac5174e3dc6c1deb876bc12a39d7af9af84 branch: 3.6 author: Mariatta committer: GitHub date: 2017-07-31T19:59:50-07:00 summary: bpo-25910: Update LICENSE (GH-2873) (GH-2967) Use the copy provided in https://bugs.python.org/issue25910GH-msg295200 (cherry picked from commit 8474d87165593bac2bc231287f42c4cff3fd6aaf) files: M LICENSE diff --git a/LICENSE b/LICENSE index f5d0b39a0cd..529349e4b38 100644 --- a/LICENSE +++ b/LICENSE @@ -13,12 +13,11 @@ software. In May 2000, Guido and the Python core development team moved to BeOpen.com to form the BeOpen PythonLabs team. In October of the same -year, the PythonLabs team moved to Digital Creations (now Zope -Corporation, see http://www.zope.com). In 2001, the Python Software -Foundation (PSF, see http://www.python.org/psf/) was formed, a -non-profit organization created specifically to own Python-related -Intellectual Property. Zope Corporation is a sponsoring member of -the PSF. +year, the PythonLabs team moved to Digital Creations, which became +Zope Corporation. In 2001, the Python Software Foundation (PSF, see +https://www.python.org/psf/) was formed, a non-profit organization +created specifically to own Python-related Intellectual Property. +Zope Corporation was a sponsoring member of the PSF. All Python releases are Open Source (see http://www.opensource.org for the Open Source Definition). Historically, most, but not all, Python From webhook-mailer at python.org Mon Jul 31 23:56:14 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 01 Aug 2017 03:56:14 -0000 Subject: [Python-checkins] Create CODEOWNERS (GH-2924) Message-ID: https://github.com/python/cpython/commit/00fce69711c61d4fc9d40174b88d3d208567e2c4 commit: 00fce69711c61d4fc9d40174b88d3d208567e2c4 branch: master author: Mariatta committer: GitHub date: 2017-07-31T20:56:12-07:00 summary: Create CODEOWNERS (GH-2924) Copied over info from .mention-bot files: A .github/CODEOWNERS diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS new file mode 100644 index 00000000000..d1ebf2c2bac --- /dev/null +++ b/.github/CODEOWNERS @@ -0,0 +1,12 @@ +# See https://help.github.com/articles/about-codeowners/ +# for more info about CODEOWNERS file + +# It uses the same pattern rule for gitignore file +# https://git-scm.com/docs/gitignore#_pattern_format + +# Hashing +**/*hashlib* @tiran +**/*pyhash* @tiran + +# SSL +**/*ssl* @tiran From webhook-mailer at python.org Mon Jul 31 23:56:38 2017 From: webhook-mailer at python.org (Mariatta) Date: Tue, 01 Aug 2017 03:56:38 -0000 Subject: [Python-checkins] Remove .mention-bot (GH-2923) Message-ID: https://github.com/python/cpython/commit/e1e60bd95c376f9b18cbaf9481364281c6cc1bc7 commit: e1e60bd95c376f9b18cbaf9481364281c6cc1bc7 branch: master author: Mariatta committer: GitHub date: 2017-07-31T20:56:35-07:00 summary: Remove .mention-bot (GH-2923) files: D .mention-bot diff --git a/.mention-bot b/.mention-bot deleted file mode 100644 index 482e241c412..00000000000 --- a/.mention-bot +++ /dev/null @@ -1,20 +0,0 @@ -{ - "numFilesToCheck": 10, - "findPotentialReviewers": true, - "fileBlacklist": [ - "Misc/ACKS", - "Misc/NEWS", - "Doc/whatsnew/*.rst" - ], - "userBlacklist": ["gvanrossum", "skrah", "haypo"], - "userBlacklistForPR": ["benjaminp", "skrah", "berkerpeksag"], - "alwaysNotifyForPaths": [ - {"name": "tiran", - "files": [ - "Doc/library/hashlib.rst", "Doc/library/ssl.rst", "Lib/hashlib.py", - "Lib/ssl.py", "Lib/test/test_hashlib.py", "Lib/test/test_ssl.py", - "Modules/_hashopenssl.c", "Modules/_ssl*", "Modules/hashlib.h", - "Python/pyhash.c", "Include/pyhash.h"] - } - ] -}