Staging
v0.8.1
v0.8.1
Revision 38f11cc3f62db11a4a24354bd06273322ac91afa authored by Gregory P. Smith on 16 February 2019, 20:57:40 UTC, committed by GitHub on 16 February 2019, 20:57:40 UTC
* bpo-1054041: Exit properly by a signal after a ^C. An uncaught KeyboardInterrupt exception means the user pressed ^C and our code did not handle it. Programs that install SIGINT handlers are supposed to reraise the SIGINT signal to the SIG_DFL handler in order to exit in a manner that their calling process can detect that they died due to a Ctrl-C. https://www.cons.org/cracauer/sigint.html After this change on POSIX systems while true; do python -c 'import time; time.sleep(23)'; done can be stopped via a simple Ctrl-C instead of the shell infinitely restarting a new python process. What to do on Windows, or if anything needs to be done there has not yet been determined. That belongs in its own PR. TODO(gpshead): A unittest for this behavior is still needed. * Do the unhandled ^C check after pymain_free. * Return STATUS_CONTROL_C_EXIT on Windows. * Fix ifdef around unistd.h include. * 📜🤖 Added by blurb_it. * Add STATUS_CTRL_C_EXIT to the os module on Windows * Add unittests. * Don't send CTRL_C_EVENT in the Windows test. It was causing CI systems to bail out of the entire test suite. See https://dev.azure.com/Python/cpython/_build/results?buildId=37980 for example. * Correct posix test (fail on macOS?) check. * STATUS_CONTROL_C_EXIT must be unsigned. * Improve the error message. * test typo :) * Skip if the bash version is too old. ...and rename the windows test to reflect what it does. * min bash version is 4.4, detect no bash. * restore a blank line i didn't mean to delete. * PyErr_Occurred() before the Py_DECREF(co); * Don't add os.STATUS_CONTROL_C_EXIT as a constant. * Update the Windows test comment. * Refactor common logic into a run_eval_code_obj fn.
1 parent 43766f8
File | Mode | Size |
---|---|---|
bdist_wininst | ||
clinic | ||
icons | ||
layout | ||
WinMain.c | -rw-r--r-- | 449 bytes |
_msi.c | -rw-r--r-- | 32.5 KB |
_testconsole.c | -rw-r--r-- | 3.3 KB |
classicAppCompat.can.xml | -rw-r--r-- | 3.9 KB |
classicAppCompat.cat | -rw-r--r-- | 10.7 KB |
classicAppCompat.sccd | -rw-r--r-- | 18.1 KB |
config.c | -rw-r--r-- | 5.4 KB |
dl_nt.c | -rw-r--r-- | 4.6 KB |
empty.c | -rw-r--r-- | 137 bytes |
errmap.h | -rw-r--r-- | 2.1 KB |
errmap.mak | -rw-r--r-- | 95 bytes |
frozen_dllmain.c | -rw-r--r-- | 3.9 KB |
generrmap.c | -rw-r--r-- | 849 bytes |
getpathp.c | -rw-r--r-- | 32.1 KB |
invalid_parameter_handler.c | -rw-r--r-- | 549 bytes |
launcher.c | -rw-r--r-- | 59.6 KB |
msvcrtmodule.c | -rw-r--r-- | 15.3 KB |
pyconfig.h | -rw-r--r-- | 19.9 KB |
pylauncher.rc | -rw-r--r-- | 1.5 KB |
pyshellext.cpp | -rw-r--r-- | 18.3 KB |
pyshellext.def | -rw-r--r-- | 141 bytes |
pyshellext.idl | -rw-r--r-- | 277 bytes |
pyshellext.rc | -rw-r--r-- | 1.1 KB |
pyshellext_d.def | -rw-r--r-- | 143 bytes |
python.manifest | -rw-r--r-- | 1.3 KB |
python3.def | -rw-r--r-- | 40.7 KB |
python3dll.c | -rw-r--r-- | 134 bytes |
python_exe.rc | -rw-r--r-- | 1.2 KB |
python_nt.rc | -rw-r--r-- | 1.2 KB |
python_uwp.cpp | -rw-r--r-- | 5.5 KB |
python_ver_rc.h | -rw-r--r-- | 970 bytes |
pythonw_exe.rc | -rw-r--r-- | 1.2 KB |
readme.txt | -rw-r--r-- | 3.5 KB |
sqlite3.rc | -rw-r--r-- | 1.3 KB |
store_info.txt | -rw-r--r-- | 5.6 KB |
testpy.py | -rw-r--r-- | 831 bytes |
validate_ucrtbase.py | -rw-r--r-- | 2.7 KB |
winreg.c | -rw-r--r-- | 60.3 KB |
winsound.c | -rw-r--r-- | 6.5 KB |
Computing file changes ...