Updated the copy commands to run on post_build and use generator expressions to simplify the code as well
This commit is contained in:
		
							parent
							
								
									2d7008f03c
								
							
						
					
					
						commit
						5b9a5493c5
					
				@ -12,29 +12,29 @@ else()
 | 
				
			|||||||
    add_definitions(/D_CRT_SECURE_NO_WARNINGS)
 | 
					    add_definitions(/D_CRT_SECURE_NO_WARNINGS)
 | 
				
			||||||
    # set up output paths for executable binaries (.exe-files, and .dll-files on DLL-capable platforms)
 | 
					    # set up output paths for executable binaries (.exe-files, and .dll-files on DLL-capable platforms)
 | 
				
			||||||
    set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
 | 
					    set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
 | 
				
			||||||
    set(CMAKE_CONFIGURATION_TYPES Debug Release RelWithDebInfo CACHE TYPE INTERNAL)
 | 
					    set(CMAKE_CONFIGURATION_TYPES Debug Release RelWithDebInfo CACHE STRING "" FORCE)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Tweak optimization settings
 | 
					    # Tweak optimization settings
 | 
				
			||||||
    # As far as I can tell, there's no way to override the CMake defaults while leaving user
 | 
					    # As far as I can tell, there's no way to override the CMake defaults while leaving user
 | 
				
			||||||
    # changes intact, so we'll just clobber everything and say sorry.
 | 
					    # changes intact, so we'll just clobber everything and say sorry.
 | 
				
			||||||
    message(STATUS "Cache compiler flags ignored, please edit CMakeLists.txt to change the flags.")
 | 
					    message(STATUS "Cache compiler flags ignored, please edit CMakeLists.txt to change the flags.")
 | 
				
			||||||
    # /MP - Multi-threaded compilation
 | 
					    # /O2 - Optimization level 2
 | 
				
			||||||
    # /Ox - Full optimization
 | 
					 | 
				
			||||||
    # /Oy- - Don't omit frame pointer
 | 
					    # /Oy- - Don't omit frame pointer
 | 
				
			||||||
    # /GR- - Disable RTTI
 | 
					    # /GR- - Disable RTTI
 | 
				
			||||||
    # /GS- - No stack buffer overflow checks
 | 
					    # /GS- - No stack buffer overflow checks
 | 
				
			||||||
    # /EHsc - C++-only exception handling semantics
 | 
					    # /EHsc - C++-only exception handling semantics
 | 
				
			||||||
    set(optimization_flags "/MP /Ox /Oy- /GR- /GS- /EHsc")
 | 
					    set(optimization_flags "/O2 /Oy- /GR- /GS- /EHsc")
 | 
				
			||||||
 | 
					    # /MP - Multi-threaded compilation
 | 
				
			||||||
    # /Zi - Output debugging information
 | 
					    # /Zi - Output debugging information
 | 
				
			||||||
    # /Zo - enahnced debug info for optimized builds
 | 
					    # /Zo - enahnced debug info for optimized builds
 | 
				
			||||||
    # /MDd - Multi-threaded Debug Runtime DLL
 | 
					    # /MDd - Multi-threaded Debug Runtime DLL
 | 
				
			||||||
    set(CMAKE_C_FLAGS_DEBUG   "/MP /MDd /Zi" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_C_FLAGS_DEBUG   "/MP /MDd /Zi" CACHE STRING "" FORCE)
 | 
				
			||||||
    set(CMAKE_CXX_FLAGS_DEBUG "/MP /MDd /Zi" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_CXX_FLAGS_DEBUG "/MP /MDd /Zi" CACHE STRING "" FORCE)
 | 
				
			||||||
    # /MD - Multi-threaded runtime DLL
 | 
					    # /MD - Multi-threaded runtime DLL
 | 
				
			||||||
    set(CMAKE_C_FLAGS_RELEASE   "${optimization_flags} /MD" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_C_FLAGS_RELEASE   "${optimization_flags} /MP /MD" CACHE STRING "" FORCE)
 | 
				
			||||||
    set(CMAKE_CXX_FLAGS_RELEASE "${optimization_flags} /MD" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_CXX_FLAGS_RELEASE "${optimization_flags} /MP /MD" CACHE STRING "" FORCE)
 | 
				
			||||||
    set(CMAKE_C_FLAGS_RELWITHDEBINFO   "${optimization_flags} /MD /Zi /Zo" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_C_FLAGS_RELWITHDEBINFO   "${optimization_flags} /MP /MD /Zi /Zo" CACHE STRING "" FORCE)
 | 
				
			||||||
    set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${optimization_flags} /MD /Zi /Zo" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${optimization_flags} /MP /MD /Zi /Zo" CACHE STRING "" FORCE)
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    set(CMAKE_EXE_LINKER_FLAGS_DEBUG "/DEBUG" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_EXE_LINKER_FLAGS_DEBUG "/DEBUG" CACHE STRING "" FORCE)
 | 
				
			||||||
    set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "/DEBUG" CACHE STRING "" FORCE)
 | 
					    set(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "/DEBUG" CACHE STRING "" FORCE)
 | 
				
			||||||
 | 
				
			|||||||
@ -77,34 +77,33 @@ target_link_libraries(citra-qt ${PLATFORM_LIBRARIES})
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
if (Qt5_FOUND AND MSVC)
 | 
					if (Qt5_FOUND AND MSVC)
 | 
				
			||||||
    set(Qt5_DLL_DIR "${Qt5_DIR}/../../../bin")
 | 
					    set(Qt5_DLL_DIR "${Qt5_DIR}/../../../bin")
 | 
				
			||||||
    file(GLOB Qt5_DEBUG_DLLS
 | 
					    set(Qt5_PLATFORMS_DIR "${Qt5_DIR}/../../../plugins/platforms/")
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icudt*.dll"
 | 
					    set(Qt5_DLLS
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icuin*.dll"
 | 
					        icudt*.dll
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icuuc*.dll"
 | 
					        icuin*.dll
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Cored.*"
 | 
					        icuuc*.dll
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Guid.*"
 | 
					        Qt5Core$<$<CONFIG:Debug>:d>.*
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5OpenGLd.*"
 | 
					        Qt5Gui$<$<CONFIG:Debug>:d>.*
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Widgetsd.*"
 | 
					        Qt5OpenGL$<$<CONFIG:Debug>:d>.*
 | 
				
			||||||
 | 
					        Qt5Widgets$<$<CONFIG:Debug>:d>.*
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
    file(GLOB Qt5_RELEASE_DLLS
 | 
					    set(DLL_DEST "${CMAKE_BINARY_DIR}/bin/$<CONFIG>/")
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icudt*.dll"
 | 
					    set(PLATFORMS ${DLL_DEST}platforms/)
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icuin*.dll"
 | 
					    
 | 
				
			||||||
        "${Qt5_DLL_DIR}/icuuc*.dll"
 | 
					    # windows commandline expects the / to be \ so switch them
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Core.*"
 | 
					    string(REPLACE "/" "\\" Qt5_DLL_DIR ${Qt5_DLL_DIR})
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Gui.*"
 | 
					    string(REPLACE "/" "\\" Qt5_PLATFORMS_DIR ${Qt5_PLATFORMS_DIR})
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5OpenGL.*"
 | 
					    string(REPLACE "/" "\\" DLL_DEST ${DLL_DEST})
 | 
				
			||||||
        "${Qt5_DLL_DIR}/Qt5Widgets.*"
 | 
					    string(REPLACE "/" "\\" PLATFORMS ${PLATFORMS})
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    # /NJH /NJS /NDL /NFL /NC /NS /NP - Silence any output
 | 
				
			||||||
 | 
					    # cmake adds an extra check for command success which doesn't work too well with robocopy 
 | 
				
			||||||
 | 
					    # so trick it into thinking the command was successful with the || cmd /c "exit /b 0"
 | 
				
			||||||
 | 
					    add_custom_command(TARGET citra-qt POST_BUILD
 | 
				
			||||||
 | 
					        COMMAND robocopy ${Qt5_DLL_DIR} ${DLL_DEST} ${Qt5_DLLS} /NJH /NJS /NDL /NFL /NC /NS /NP || cmd /c "exit /b 0"
 | 
				
			||||||
 | 
					        COMMAND if not exist ${PLATFORMS} mkdir ${PLATFORMS} 2> nul
 | 
				
			||||||
 | 
					        COMMAND robocopy ${Qt5_PLATFORMS_DIR} ${PLATFORMS} qwindows$<$<CONFIG:Debug>:d>.* /NJH /NJS /NDL /NFL /NC /NS /NP || cmd /c "exit /b 0"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
    # make the output directories ahead of the time and copy in the needed Dlls now
 | 
					    unset(Qt5_DLLS)
 | 
				
			||||||
    file(MAKE_DIRECTORY
 | 
					 | 
				
			||||||
        ${CMAKE_BINARY_DIR}/bin/Debug/
 | 
					 | 
				
			||||||
        ${CMAKE_BINARY_DIR}/bin/Release/
 | 
					 | 
				
			||||||
        ${CMAKE_BINARY_DIR}/bin/RelWithDebInfo/
 | 
					 | 
				
			||||||
    )
 | 
					 | 
				
			||||||
    file(COPY ${Qt5_DEBUG_DLLS} DESTINATION ${CMAKE_BINARY_DIR}/bin/Debug/)
 | 
					 | 
				
			||||||
    file(COPY ${Qt5_RELEASE_DLLS} DESTINATION ${CMAKE_BINARY_DIR}/bin/Release/)
 | 
					 | 
				
			||||||
    file(COPY ${Qt5_RELEASE_DLLS} DESTINATION ${CMAKE_BINARY_DIR}/bin/RelWithDebInfo/)
 | 
					 | 
				
			||||||
    unset(Qt5_RELEASE_DLLS)
 | 
					 | 
				
			||||||
    unset(Qt5_DEBUG_DLLS)
 | 
					 | 
				
			||||||
    unset(Qt5_DLL_DIR)
 | 
					    unset(Qt5_DLL_DIR)
 | 
				
			||||||
endif()
 | 
					endif()
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user