mirror of https://github.com/python/cpython
Check for compiler warnings in test_cext on Windows (#121088)
On Windows, test_cext and test_cppext now pass /WX flag to the MSC compiler to treat all compiler warnings as errors. In verbose mode, these tests now log the compiler commands to help debugging. Change Py_BUILD_ASSERT_EXPR implementation on Windows to avoid a compiler warning about an unnamed structure.
This commit is contained in:
parent
ef3c400434
commit
43709d5d54
|
@ -46,7 +46,8 @@
|
|||
/* Argument must be a char or an int in [-128, 127] or [0, 255]. */
|
||||
#define Py_CHARMASK(c) ((unsigned char)((c) & 0xff))
|
||||
|
||||
#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L
|
||||
#if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L \
|
||||
&& !defined(_MSC_VER))
|
||||
# define Py_BUILD_ASSERT_EXPR(cond) \
|
||||
((void)sizeof(struct { int dummy; _Static_assert(cond, #cond); }), \
|
||||
0)
|
||||
|
|
|
@ -86,6 +86,8 @@ class TestExt(unittest.TestCase):
|
|||
cmd = [python_exe, '-X', 'dev',
|
||||
'-m', 'pip', 'install', '--no-build-isolation',
|
||||
os.path.abspath(pkg_dir)]
|
||||
if support.verbose:
|
||||
cmd.append('-v')
|
||||
run_cmd('Install', cmd)
|
||||
|
||||
# Do a reference run. Until we test that running python
|
||||
|
|
|
@ -11,6 +11,7 @@ from setuptools import setup, Extension
|
|||
|
||||
|
||||
SOURCE = 'extension.c'
|
||||
|
||||
if not support.MS_WINDOWS:
|
||||
# C compiler flags for GCC and clang
|
||||
CFLAGS = [
|
||||
|
@ -28,8 +29,11 @@ if not support.MS_WINDOWS:
|
|||
'-Werror=declaration-after-statement',
|
||||
)
|
||||
else:
|
||||
# Don't pass any compiler flag to MSVC
|
||||
CFLAGS = []
|
||||
# MSVC compiler flags
|
||||
CFLAGS = [
|
||||
# Treat all compiler warnings as compiler errors
|
||||
'/WX',
|
||||
]
|
||||
|
||||
|
||||
def main():
|
||||
|
|
|
@ -76,6 +76,8 @@ class TestCPPExt(unittest.TestCase):
|
|||
cmd = [python_exe, '-X', 'dev',
|
||||
'-m', 'pip', 'install', '--no-build-isolation',
|
||||
os.path.abspath(pkg_dir)]
|
||||
if support.verbose:
|
||||
cmd.append('-v')
|
||||
run_cmd('Install', cmd)
|
||||
|
||||
# Do a reference run. Until we test that running python
|
||||
|
|
|
@ -10,6 +10,7 @@ from setuptools import setup, Extension
|
|||
|
||||
|
||||
SOURCE = 'extension.cpp'
|
||||
|
||||
if not support.MS_WINDOWS:
|
||||
# C++ compiler flags for GCC and clang
|
||||
CPPFLAGS = [
|
||||
|
@ -19,8 +20,11 @@ if not support.MS_WINDOWS:
|
|||
'-Werror',
|
||||
]
|
||||
else:
|
||||
# Don't pass any compiler flag to MSVC
|
||||
CPPFLAGS = []
|
||||
# MSVC compiler flags
|
||||
CPPFLAGS = [
|
||||
# Treat all compiler warnings as compiler errors
|
||||
'/WX',
|
||||
]
|
||||
|
||||
|
||||
def main():
|
||||
|
|
Loading…
Reference in New Issue