Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

gh-131942: Use the Python-specific Py_DEBUG macro rather than _DEBUG in Windows-related C code #131944

Open
wants to merge 12 commits into
base: main
Choose a base branch
from
7 changes: 7 additions & 0 deletions Doc/c-api/intro.rst
Original file line number Diff line number Diff line change
Expand Up @@ -832,6 +832,13 @@ It is also implied by the presence of the
not-Python-specific :c:macro:`!_DEBUG` macro. When :c:macro:`!Py_DEBUG` is enabled
in the Unix build, compiler optimization is disabled.

.. note::
On Windows, the :c:macro:`!Py_DEBUG` macro is not defined by default.

The :option:`--with-pydebug` option is not available on Windows. Instead, the
not-Python-specific :c:macro:`!_DEBUG` macro can be defined by the compiler
options and that will enable the :c:macro:`!Py_DEBUG` macro.

In addition to the reference count debugging described below, extra checks are
performed, see :ref:`Python Debug Build <debug-build>`.

Expand Down
2 changes: 1 addition & 1 deletion Include/internal/pycore_importdl.h
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ extern int _PyImport_RunModInitFunc(
#include <windows.h>
typedef FARPROC dl_funcptr;

#ifdef _DEBUG
#ifdef Py_DEBUG
# define PYD_DEBUG_SUFFIX "_d"
#else
# define PYD_DEBUG_SUFFIX ""
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Use the Python-specific :c:macro:`Py_DEBUG` macro rather than :c:macro:`!_DEBUG` in Windows-related C code. Patch by Xuehai Pan.
2 changes: 1 addition & 1 deletion Modules/_ctypes/callproc.c
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ module _ctypes
#include <sanitizer/msan_interface.h>
#endif

#if defined(_DEBUG) || defined(__MINGW32__)
#if defined(Py_DEBUG) || defined(__MINGW32__)
/* Don't use structured exception handling on Windows if this is defined.
MingW, AFAIK, doesn't support it.
*/
Expand Down
2 changes: 1 addition & 1 deletion Modules/_ssl.c
Original file line number Diff line number Diff line change
Expand Up @@ -4427,7 +4427,7 @@ _ssl__SSLContext_load_dh_params_impl(PySSLContext *self, PyObject *filepath)
FILE *f;
DH *dh;

#if defined(MS_WINDOWS) && defined(_DEBUG)
#if defined(MS_WINDOWS) && defined(Py_DEBUG)
PyErr_SetString(PyExc_NotImplementedError,
"load_dh_params: unavailable on Windows debug build");
return NULL;
Expand Down
2 changes: 1 addition & 1 deletion Modules/_ssl/debughelpers.c
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ _PySSLContext_set_keylog_filename(PyObject *op, PyObject *arg,
PySSLContext *self = PySSLContext_CAST(op);
FILE *fp;

#if defined(MS_WINDOWS) && defined(_DEBUG)
#if defined(MS_WINDOWS) && defined(Py_DEBUG)
PyErr_SetString(PyExc_NotImplementedError,
"set_keylog_filename: unavailable on Windows debug build");
return -1;
Expand Down
14 changes: 7 additions & 7 deletions PC/clinic/msvcrtmodule.c.h

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion PC/launcher.c
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ static wchar_t * get_env(wchar_t * key)
return buf;
}

#if defined(_DEBUG)
#if defined(Py_DEBUG)
/* Do not define EXECUTABLEPATH_VALUE in debug builds as it'll
never point to the debug build. */
#if defined(_WINDOWS)
Expand Down
6 changes: 3 additions & 3 deletions PC/msvcrtmodule.c
Original file line number Diff line number Diff line change
Expand Up @@ -415,7 +415,7 @@ msvcrt_ungetwch_impl(PyObject *module, int unicode_char)

#endif /* MS_WINDOWS_DESKTOP */

#ifdef _DEBUG
#ifdef Py_DEBUG
/*[clinic input]
msvcrt.CrtSetReportFile -> HANDLE

Expand Down Expand Up @@ -490,7 +490,7 @@ msvcrt_set_error_mode_impl(PyObject *module, int mode)

return res;
}
#endif /* _DEBUG */
#endif /* Py_DEBUG */

#if defined(MS_WINDOWS_DESKTOP) || defined(MS_WINDOWS_APP) || defined(MS_WINDOWS_SYSTEM)

Expand Down Expand Up @@ -604,7 +604,7 @@ exec_module(PyObject* m)
INSERTINT(m, "SEM_NOGPFAULTERRORBOX", SEM_NOGPFAULTERRORBOX);
INSERTINT(m, "SEM_NOOPENFILEERRORBOX", SEM_NOOPENFILEERRORBOX);
#endif
#ifdef _DEBUG
#ifdef Py_DEBUG
INSERTINT(m, "CRT_WARN", _CRT_WARN);
INSERTINT(m, "CRT_ERROR", _CRT_ERROR);
INSERTINT(m, "CRT_ASSERT", _CRT_ASSERT);
Expand Down
18 changes: 9 additions & 9 deletions PC/pyconfig.h.in
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,11 @@ WIN32 is still required for the locale module.
#endif
#endif /* Py_BUILD_CORE || Py_BUILD_CORE_BUILTIN || Py_BUILD_CORE_MODULE */

/* _DEBUG implies Py_DEBUG */
#ifdef _DEBUG
# define Py_DEBUG 1
#endif

/* Define to 1 if you want to disable the GIL */
/* Uncomment the definition for free-threaded builds, or define it manually
* when compiling extension modules. Note that we test with #ifdef, so
Expand Down Expand Up @@ -319,21 +324,21 @@ Py_NO_ENABLE_SHARED to find out. Also support MS_NO_COREDLL for b/w compat */
This is relevant when using build-system generator (e.g CMake) where
the linking is explicitly handled */
# if defined(Py_GIL_DISABLED)
# if defined(_DEBUG)
# if defined(Py_DEBUG)
# pragma comment(lib,"python314t_d.lib")
# elif defined(Py_LIMITED_API)
# pragma comment(lib,"python3t.lib")
# else
# pragma comment(lib,"python314t.lib")
# endif /* _DEBUG */
# endif /* Py_DEBUG */
# else /* Py_GIL_DISABLED */
# if defined(_DEBUG)
# if defined(Py_DEBUG)
# pragma comment(lib,"python314_d.lib")
# elif defined(Py_LIMITED_API)
# pragma comment(lib,"python3.lib")
# else
# pragma comment(lib,"python314.lib")
# endif /* _DEBUG */
# endif /* Py_DEBUG */
# endif /* Py_GIL_DISABLED */
# endif /* _MSC_VER && !Py_NO_LINK_LIB */
# endif /* Py_BUILD_CORE */
Expand Down Expand Up @@ -376,11 +381,6 @@ Py_NO_ENABLE_SHARED to find out. Also support MS_NO_COREDLL for b/w compat */
# define ALIGNOF_MAX_ALIGN_T 8
#endif

#ifdef _DEBUG
# define Py_DEBUG
#endif


#ifdef MS_WIN32

#define SIZEOF_SHORT 2
Expand Down
4 changes: 2 additions & 2 deletions PC/python_uwp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,13 @@
#include <winrt\Windows.Storage.h>

#ifdef PYTHONW
#ifdef _DEBUG
#ifdef Py_DEBUG
const wchar_t *PROGNAME = L"pythonw_d.exe";
#else
const wchar_t *PROGNAME = L"pythonw.exe";
#endif
#else
#ifdef _DEBUG
#ifdef Py_DEBUG
const wchar_t *PROGNAME = L"python_d.exe";
#else
const wchar_t *PROGNAME = L"python.exe";
Expand Down
2 changes: 1 addition & 1 deletion PC/python_ver_rc.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
#define MS_WINDOWS
#include "modsupport.h"
#include "patchlevel.h"
#ifdef _DEBUG
#ifdef Py_DEBUG
# define PYTHON_DEBUG_EXT "_d"
#else
# define PYTHON_DEBUG_EXT
Expand Down
6 changes: 3 additions & 3 deletions Python/dynload_win.c
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ static char *GetPythonImport (HINSTANCE hModule)
char *pch;

/* Don't claim that python3.dll is a Python DLL. */
#ifdef _DEBUG
#ifdef Py_DEBUG
if (strcmp(import_name, "python3_d.dll") == 0) {
#else
if (strcmp(import_name, "python3.dll") == 0) {
Expand All @@ -120,7 +120,7 @@ static char *GetPythonImport (HINSTANCE hModule)
/* Ensure python prefix is followed only
by numbers to the end of the basename */
pch = import_name + 6;
#ifdef _DEBUG
#ifdef Py_DEBUG
while (*pch && pch[0] != '_' && pch[1] != 'd' && pch[2] != '.') {
#else
while (*pch && *pch != '.') {
Expand Down Expand Up @@ -300,7 +300,7 @@ dl_funcptr _PyImport_FindSharedFuncptrWindows(const char *prefix,
char buffer[256];

PyOS_snprintf(buffer, sizeof(buffer),
#ifdef _DEBUG
#ifdef Py_DEBUG
"python%d%d_d.dll",
#else
"python%d%d.dll",
Expand Down
2 changes: 1 addition & 1 deletion Python/marshal.c
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ module marshal
* On Windows PGO builds, the r_object function overallocates its stack and
* can cause a stack overflow. We reduce the maximum depth for all Windows
* releases to protect against this.
* #if defined(MS_WINDOWS) && defined(_DEBUG)
* #if defined(MS_WINDOWS) && defined(Py_DEBUG)
*/
#if defined(MS_WINDOWS)
# define MAX_MARSHAL_STACK_DEPTH 1000
Expand Down
2 changes: 1 addition & 1 deletion Python/pylifecycle.c
Original file line number Diff line number Diff line change
Expand Up @@ -3134,7 +3134,7 @@ static inline void _Py_NO_RETURN
fatal_error_exit(int status)
{
if (status < 0) {
#if defined(MS_WINDOWS) && defined(_DEBUG)
#if defined(MS_WINDOWS) && defined(Py_DEBUG)
DebugBreak();
#endif
abort();
Expand Down
Loading