diff --git a/CMakeLists.txt b/CMakeLists.txt index 0edb47d8f..f0423dc52 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -31,8 +31,15 @@ set(CMAKE_CXX_STANDARD 14) option(NATRON_SYSTEM_LIBS "use system versions of dependencies instead of bundled ones" OFF) option(NATRON_BUILD_TESTS "build the Natron test suite" ON) +set(IS_DEBUG_BUILD OFF) if(CMAKE_BUILD_TYPE MATCHES "^(debug|Debug|DEBUG)$") + set(IS_DEBUG_BUILD ON) add_definitions(-DDEBUG) + + if(WIN32) + # Debug builds need minimal optimizations to avoid excessive link times and link errors related to Eigen. + add_compile_options(-O) + endif() else() add_definitions(-DQT_NO_DEBUG_OUTPUT) endif() @@ -49,7 +56,21 @@ if(WIN32) endif() find_package(Python3 COMPONENTS Interpreter Development) find_package(Qt5 5.15 CONFIG REQUIRED COMPONENTS Core Gui Network Widgets Concurrent) + +if(IS_DEBUG_BUILD AND WIN32) + # Explicitly setting SHIBOKEN_PYTHON_LIBRARIES variable to avoid PYTHON_DEBUG_LIBRARY-NOTFOUND + # link errors on Windows debug builds. + set(SHIBOKEN_PYTHON_LIBRARIES ${Python3_LIBRARIES}) +endif() find_package(Shiboken2 5.15 CONFIG REQUIRED COMPONENTS libshiboken2 shiboken2) + +if(IS_DEBUG_BUILD AND WIN32) + # Remove NDEBUG from Shiboken2 INTERFACE_COMPILE_DEFINITIONS so it is not inherited in debug builds. + get_property(ShibokenInterfaceDefs TARGET Shiboken2::libshiboken PROPERTY INTERFACE_COMPILE_DEFINITIONS) + list(REMOVE_ITEM ShibokenInterfaceDefs NDEBUG) + set_property(TARGET Shiboken2::libshiboken PROPERTY INTERFACE_COMPILE_DEFINITIONS ShibokenInterfaceDefs) +endif() + find_package(PySide2 5.15 CONFIG REQUIRED COMPONENTS pyside2) set(QT_VERSION_MAJOR 5) get_target_property(PYSIDE_INCLUDE_DIRS PySide2::pyside2 INTERFACE_INCLUDE_DIRECTORIES) diff --git a/Engine/OSGLContext_win.cpp b/Engine/OSGLContext_win.cpp index b9b78ff28..2e994c3eb 100644 --- a/Engine/OSGLContext_win.cpp +++ b/Engine/OSGLContext_win.cpp @@ -57,6 +57,18 @@ __declspec(dllexport) int AmdPowerXpressRequestHighPerformance = 1; NATRON_NAMESPACE_ENTER +namespace { + +bool makeDCAndContextCurrent(HDC dc, HGLRC context) +{ + const OSGLContext_wgl_data* wglInfo = appPTR->getWGLData(); + + assert(wglInfo); + return wglInfo->MakeCurrent(dc, context); +} + +} // namespace + bool OSGLContext_win::extensionSupported(const char* extension, OSGLContext_wgl_data* data) @@ -96,6 +108,7 @@ OSGLContext_win::initWGLData(OSGLContext_wgl_data* wglInfo) wglInfo->CreateContext = (WGLCREATECONTEXT_T)GetProcAddress(wglInfo->instance, "wglCreateContext"); wglInfo->DeleteContext = (WGLDELETECONTEXT_T)GetProcAddress(wglInfo->instance, "wglDeleteContext"); wglInfo->GetCurrentContext = (WGLGETCURRENTCONTEXT_T)GetProcAddress(wglInfo->instance, "wglGetCurrentContext"); + wglInfo->GetCurrentDC = (WGLGETCURRENTDC_T)GetProcAddress(wglInfo->instance, "wglGetCurrentDC"); wglInfo->GetProcAddress = (WGLGETPROCADDRESS_T)GetProcAddress(wglInfo->instance, "wglGetProcAddress"); wglInfo->MakeCurrent = (WGLMAKECURRENT_T)GetProcAddress(wglInfo->instance, "wglMakeCurrent"); wglInfo->ShareLists = (WGLSHARELISTS_T)GetProcAddress(wglInfo->instance, "wglShareLists"); @@ -606,18 +619,16 @@ OSGLContext_win::~OSGLContext_win() bool OSGLContext_win::makeContextCurrent(const OSGLContext_win* context) { - const OSGLContext_wgl_data* wglInfo = appPTR->getWGLData(); - - assert(wglInfo); if (context) { - return wglInfo->MakeCurrent(context->_dc, context->_handle); + return makeDCAndContextCurrent(context->_dc, context->_handle); } else { - return wglInfo->MakeCurrent(0, 0); + return makeDCAndContextCurrent(0, 0); } } bool -OSGLContext_win::threadHasACurrentContext() { +OSGLContext_win::threadHasACurrentContext() +{ const OSGLContext_wgl_data* wglInfo = appPTR->getWGLData(); assert(wglInfo); return wglInfo->GetCurrentContext() != nullptr; @@ -722,7 +733,11 @@ namespace { class ScopedGLContext { public: ScopedGLContext(const GLRendererID& gid) { - assert(!OSGLContext_win::threadHasACurrentContext()); + const OSGLContext_wgl_data* wglInfo = appPTR->getWGLData(); + assert(wglInfo); + _oldDc = wglInfo->GetCurrentDC(); + _oldContext = wglInfo->GetCurrentContext(); + try { _context = std::make_unique(FramebufferConfig(), GLVersion.major, GLVersion.minor, false, gid, nullptr); } catch (const std::exception& e) { @@ -737,7 +752,7 @@ class ScopedGLContext { ~ScopedGLContext() { if (_context) { - OSGLContext_win::makeContextCurrent(nullptr); + makeDCAndContextCurrent(_oldDc, _oldContext); } } @@ -745,6 +760,8 @@ class ScopedGLContext { private: std::unique_ptr _context; + HDC _oldDc = nullptr; + HGLRC _oldContext = nullptr; }; } // namespace diff --git a/Engine/OSGLContext_win.h b/Engine/OSGLContext_win.h index 862f8f65d..85906aa57 100644 --- a/Engine/OSGLContext_win.h +++ b/Engine/OSGLContext_win.h @@ -91,6 +91,7 @@ typedef PROC (WINAPI * WGLGETPROCADDRESS_T)(LPCSTR); typedef BOOL (WINAPI * WGLMAKECURRENT_T)(HDC, HGLRC); typedef BOOL (WINAPI * WGLSHARELISTS_T)(HGLRC, HGLRC); typedef HGLRC (WINAPI * WGLGETCURRENTCONTEXT_T)(); +typedef HDC (WINAPI * WGLGETCURRENTDC_T)(); ////////// https://www.opengl.org/registry/specs/NV/gpu_affinity.txt @@ -157,6 +158,7 @@ struct OSGLContext_wgl_data WGLCREATECONTEXT_T CreateContext; WGLDELETECONTEXT_T DeleteContext; WGLGETCURRENTCONTEXT_T GetCurrentContext; + WGLGETCURRENTDC_T GetCurrentDC; WGLGETPROCADDRESS_T GetProcAddress; WGLMAKECURRENT_T MakeCurrent; WGLSHARELISTS_T ShareLists;