It’s not a good idea. You end up with two different C runtimes in memory that cannot communicate, and many things will not work properly.
If you compile your debug build extension with the non-debug CRT (/MD rather than /MDd) you will lose asserts, but otherwise it will work fine and the quoted code picks the release lib.
Or if you like, when you install Python 3.5 or later there are advanced options to install debug symbols and binaries. You can use a proper debug build against the debug binaries (python_d.exe).
Cheers,
Steve
Top-posted from my Windows phone
From: Ivan Pozdeev via Python-ideas
Sent: Saturday, December 30, 2017 13:01
To: python-ideas@python.org
Subject: [Python-ideas] Allow to compile debug extension against releasePython in Windows
The Windows version of pyconfig.h has the following construct:
if defined(_DEBUG)
pragma comment(lib,"python37_d.lib")
elif defined(Py_LIMITED_API)
pragma comment(lib,"python3.lib")
else
pragma comment(lib,"python37.lib")
endif /* _DEBUG */
which fails the compilation of a debug version of an extension. Making
debugging it... difficult.
Perhaps we could define some other constant?
I'm not sure whether such compilation is a good idea in general, so
asking here at first.
--
Regards,
Ivan
_______________________________________________
Python-ideas mailing list
Python-ideas@python.org
https://mail.python.org/mailman/listinfo/python-ideas
Code of Conduct: http://python.org/psf/codeofconduct/