mirror of
				https://github.com/encounter/SDL.git
				synced 2025-10-26 03:30:23 +00:00 
			
		
		
		
	Fix MSVC ARM32 builds
This commit is contained in:
		
							parent
							
								
									b352b78345
								
							
						
					
					
						commit
						9ef6885743
					
				
							
								
								
									
										1
									
								
								.github/workflows/msvc.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/msvc.yml
									
									
									
									
										vendored
									
									
								
							| @ -17,6 +17,7 @@ jobs: | |||||||
|         - { name: Windows static VCRT (x86), flags: -A Win32 -DSDL_FORCE_STATIC_VCRT=ON } |         - { name: Windows static VCRT (x86), flags: -A Win32 -DSDL_FORCE_STATIC_VCRT=ON } | ||||||
|         - { name: Windows (clang-cl x64), flags: -T ClangCL -A x64 } |         - { name: Windows (clang-cl x64), flags: -T ClangCL -A x64 } | ||||||
|         - { name: Windows (clang-cl x86), flags: -T ClangCL -A Win32 } |         - { name: Windows (clang-cl x86), flags: -T ClangCL -A Win32 } | ||||||
|  |         - { name: Windows (ARM),          flags: -A ARM } | ||||||
|         - { name: Windows (ARM64),        flags: -A ARM64 } |         - { name: Windows (ARM64),        flags: -A ARM64 } | ||||||
|         - { name: UWP (x64),              flags: -A x64 -DCMAKE_SYSTEM_NAME=WindowsStore -DCMAKE_SYSTEM_VERSION="10.0" -DSDL_TEST=OFF, project: VisualC-WinRT/SDL-UWP.sln, projectflags: '/p:Platform=x64 /p:WindowsTargetPlatformVersion=10.0.17763.0' } |         - { name: UWP (x64),              flags: -A x64 -DCMAKE_SYSTEM_NAME=WindowsStore -DCMAKE_SYSTEM_VERSION="10.0" -DSDL_TEST=OFF, project: VisualC-WinRT/SDL-UWP.sln, projectflags: '/p:Platform=x64 /p:WindowsTargetPlatformVersion=10.0.17763.0' } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1550,7 +1550,7 @@ elseif(WINDOWS) | |||||||
|   if(MSVC AND NOT SDL_LIBC) |   if(MSVC AND NOT SDL_LIBC) | ||||||
|     # Prevent codegen that would use the VC runtime libraries. |     # Prevent codegen that would use the VC runtime libraries. | ||||||
|     set_property(DIRECTORY . APPEND PROPERTY COMPILE_OPTIONS "/GS-") |     set_property(DIRECTORY . APPEND PROPERTY COMPILE_OPTIONS "/GS-") | ||||||
|     if(NOT ARCH_64) |     if(NOT ARCH_64 AND NOT CMAKE_GENERATOR_PLATFORM STREQUAL "ARM") | ||||||
|       set_property(DIRECTORY . APPEND PROPERTY COMPILE_OPTIONS "/arch:SSE") |       set_property(DIRECTORY . APPEND PROPERTY COMPILE_OPTIONS "/arch:SSE") | ||||||
|     endif() |     endif() | ||||||
|   endif() |   endif() | ||||||
| @ -1582,7 +1582,7 @@ elseif(WINDOWS) | |||||||
|     check_include_file(ddraw.h HAVE_DDRAW_H) |     check_include_file(ddraw.h HAVE_DDRAW_H) | ||||||
|     check_include_file(dsound.h HAVE_DSOUND_H) |     check_include_file(dsound.h HAVE_DSOUND_H) | ||||||
|     check_include_file(dinput.h HAVE_DINPUT_H) |     check_include_file(dinput.h HAVE_DINPUT_H) | ||||||
|     if(WINDOWS_STORE OR VCPKG_TARGET_TRIPLET MATCHES "arm-windows") |     if(WINDOWS_STORE OR CMAKE_GENERATOR_PLATFORM STREQUAL "ARM") | ||||||
|       set(HAVE_DINPUT_H 0) |       set(HAVE_DINPUT_H 0) | ||||||
|     endif() |     endif() | ||||||
|     check_include_file(dxgi.h HAVE_DXGI_H) |     check_include_file(dxgi.h HAVE_DXGI_H) | ||||||
| @ -2890,6 +2890,9 @@ if(NOT WINDOWS_STORE AND NOT SDL2_DISABLE_SDL2MAIN) | |||||||
|   add_library(SDL2::SDL2main ALIAS SDL2main) |   add_library(SDL2::SDL2main ALIAS SDL2main) | ||||||
|   target_include_directories(SDL2main BEFORE PRIVATE "${SDL2_BINARY_DIR}/include") |   target_include_directories(SDL2main BEFORE PRIVATE "${SDL2_BINARY_DIR}/include") | ||||||
|   target_include_directories(SDL2main PUBLIC "$<BUILD_INTERFACE:${SDL2_SOURCE_DIR}/include>" $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}> $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>) |   target_include_directories(SDL2main PUBLIC "$<BUILD_INTERFACE:${SDL2_SOURCE_DIR}/include>" $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}> $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/SDL2>) | ||||||
|  |   if (WIN32) | ||||||
|  |     target_link_libraries(SDL2main PRIVATE shell32) | ||||||
|  |   endif() | ||||||
|   if (NOT ANDROID) |   if (NOT ANDROID) | ||||||
|     set_target_properties(SDL2main PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}") |     set_target_properties(SDL2main PROPERTIES DEBUG_POSTFIX "${SDL_CMAKE_DEBUG_POSTFIX}") | ||||||
|   endif() |   endif() | ||||||
| @ -2930,7 +2933,7 @@ if(SDL_SHARED) | |||||||
|       OUTPUT_NAME "SDL2") |       OUTPUT_NAME "SDL2") | ||||||
|   endif() |   endif() | ||||||
|   # Note: The clang toolset for Visual Studio does not support /NODEFAULTLIB. |   # Note: The clang toolset for Visual Studio does not support /NODEFAULTLIB. | ||||||
|   if(MSVC AND NOT SDL_LIBC AND NOT MSVC_CLANG) |   if(MSVC AND NOT SDL_LIBC AND NOT MSVC_CLANG AND NOT CMAKE_GENERATOR_PLATFORM STREQUAL "ARM") | ||||||
|     # Don't try to link with the default set of libraries. |     # Don't try to link with the default set of libraries. | ||||||
|     if(NOT WINDOWS_STORE) |     if(NOT WINDOWS_STORE) | ||||||
|       set_target_properties(SDL2 PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB") |       set_target_properties(SDL2 PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB") | ||||||
| @ -2962,7 +2965,7 @@ if(SDL_STATIC) | |||||||
|   endif() |   endif() | ||||||
|   set_target_properties(SDL2-static PROPERTIES POSITION_INDEPENDENT_CODE ${SDL_STATIC_PIC}) |   set_target_properties(SDL2-static PROPERTIES POSITION_INDEPENDENT_CODE ${SDL_STATIC_PIC}) | ||||||
|   # Note: The clang toolset for Visual Studio does not support /NODEFAULTLIB. |   # Note: The clang toolset for Visual Studio does not support /NODEFAULTLIB. | ||||||
|   if(MSVC AND NOT SDL_LIBC AND NOT MSVC_CLANG) |   if(MSVC AND NOT SDL_LIBC AND NOT MSVC_CLANG AND NOT CMAKE_GENERATOR_PLATFORM STREQUAL "ARM") | ||||||
|     set_target_properties(SDL2-static PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB") |     set_target_properties(SDL2-static PROPERTIES LINK_FLAGS_RELEASE "/NODEFAULTLIB") | ||||||
|     set_target_properties(SDL2-static PROPERTIES LINK_FLAGS_DEBUG "/NODEFAULTLIB") |     set_target_properties(SDL2-static PROPERTIES LINK_FLAGS_DEBUG "/NODEFAULTLIB") | ||||||
|     set_target_properties(SDL2-static PROPERTIES STATIC_LIBRARY_FLAGS "/NODEFAULTLIB") |     set_target_properties(SDL2-static PROPERTIES STATIC_LIBRARY_FLAGS "/NODEFAULTLIB") | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user