Merge pull request #4744 from ligfx/cleanup-osx-cmake
CMake: Cleanup macOS-related logic
This commit is contained in:
commit
eed64bb0fe
|
@ -2,8 +2,14 @@
|
||||||
# General setup
|
# General setup
|
||||||
#
|
#
|
||||||
cmake_minimum_required(VERSION 3.5.0)
|
cmake_minimum_required(VERSION 3.5.0)
|
||||||
project(dolphin-emu)
|
set(CMAKE_OSX_ARCHITECTURES "x86_64")
|
||||||
|
# Minimum OS X version.
|
||||||
|
# This is inserted into the Info.plist as well.
|
||||||
|
# Note that the SDK determines the maximum version of which optional
|
||||||
|
# features can be used, not the minimum required version to run.
|
||||||
|
set(CMAKE_OSX_DEPLOYMENT_TARGET "10.9" CACHE string "")
|
||||||
|
|
||||||
|
project(dolphin-emu)
|
||||||
option(USE_EGL "Enables EGL OpenGL Interface" OFF)
|
option(USE_EGL "Enables EGL OpenGL Interface" OFF)
|
||||||
option(TRY_X11 "Enables X11 Support" ON)
|
option(TRY_X11 "Enables X11 Support" ON)
|
||||||
option(USE_SHARED_ENET "Use shared libenet if found rather than Dolphin's soon-to-compatibly-diverge version" OFF)
|
option(USE_SHARED_ENET "Use shared libenet if found rather than Dolphin's soon-to-compatibly-diverge version" OFF)
|
||||||
|
@ -66,25 +72,6 @@ endif()
|
||||||
# TODO: Add DSPSpy
|
# TODO: Add DSPSpy
|
||||||
option(DSPTOOL "Build dsptool" OFF)
|
option(DSPTOOL "Build dsptool" OFF)
|
||||||
|
|
||||||
# Update compiler before calling project()
|
|
||||||
if (APPLE)
|
|
||||||
# Use clang compiler
|
|
||||||
if (NOT DEFINED CMAKE_CXX_COMPILER)
|
|
||||||
set(CMAKE_CXX_COMPILER "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++")
|
|
||||||
if (NOT EXISTS "${CMAKE_CXX_COMPILER}")
|
|
||||||
set(CMAKE_CXX_COMPILER "clang++")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
if (NOT DEFINED CMAKE_C_COMPILER)
|
|
||||||
set(CMAKE_C_COMPILER "/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang")
|
|
||||||
if (NOT EXISTS "${CMAKE_C_COMPILER}")
|
|
||||||
set(CMAKE_C_COMPILER "clang")
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# This doesn't play with with the packaging script that doesn't understand @rpath
|
|
||||||
set(CMAKE_MACOSX_RPATH OFF)
|
|
||||||
endif()
|
|
||||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/CMakeTests)
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/CMakeTests)
|
||||||
# Libraries to link
|
# Libraries to link
|
||||||
set(LIBS)
|
set(LIBS)
|
||||||
|
@ -264,6 +251,9 @@ if(ENABLE_LTO)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
|
# This doesn't play well with the packaging script that doesn't understand @rpath
|
||||||
|
set(CMAKE_MACOSX_RPATH OFF)
|
||||||
|
|
||||||
if(NOT OSX_USE_DEFAULT_SEARCH_PATH)
|
if(NOT OSX_USE_DEFAULT_SEARCH_PATH)
|
||||||
# Hack up the path to prioritize the path to built-in OS libraries to
|
# Hack up the path to prioritize the path to built-in OS libraries to
|
||||||
# increase the chance of not depending on a bunch of copies of them
|
# increase the chance of not depending on a bunch of copies of them
|
||||||
|
@ -276,18 +266,6 @@ if(APPLE)
|
||||||
set(CMAKE_PREFIX_PATH "${CMAKE_PREFIX_PATH};/usr")
|
set(CMAKE_PREFIX_PATH "${CMAKE_PREFIX_PATH};/usr")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Identify the target system:
|
|
||||||
# Ask for 64-bit binary.
|
|
||||||
set(TARGET_FLAGS "-arch x86_64")
|
|
||||||
# Minimum OS X version.
|
|
||||||
# This is inserted into the Info.plist as well.
|
|
||||||
# Note that the SDK determines the maximum version of which optional
|
|
||||||
# features can be used, not the minimum required version to run.
|
|
||||||
set(OSX_MIN_VERSION "10.9")
|
|
||||||
set(TARGET_FLAGS "${TARGET_FLAGS} -mmacosx-version-min=${OSX_MIN_VERSION}")
|
|
||||||
# Do not warn about frameworks that are not available on all architectures.
|
|
||||||
# This avoids a warning when linking with QuickTime.
|
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,-no_arch_warnings")
|
|
||||||
# Specify target CPUs.
|
# Specify target CPUs.
|
||||||
set(TARGET_FLAGS "${TARGET_FLAGS} -mssse3")
|
set(TARGET_FLAGS "${TARGET_FLAGS} -mssse3")
|
||||||
set(TARGET_FLAGS "${TARGET_FLAGS} -march=core2")
|
set(TARGET_FLAGS "${TARGET_FLAGS} -march=core2")
|
||||||
|
@ -306,7 +284,6 @@ if(APPLE)
|
||||||
|
|
||||||
find_library(APPKIT_LIBRARY AppKit)
|
find_library(APPKIT_LIBRARY AppKit)
|
||||||
find_library(APPSERV_LIBRARY ApplicationServices)
|
find_library(APPSERV_LIBRARY ApplicationServices)
|
||||||
find_library(ATB_LIBRARY AudioToolbox)
|
|
||||||
find_library(AU_LIBRARY AudioUnit)
|
find_library(AU_LIBRARY AudioUnit)
|
||||||
find_library(CARBON_LIBRARY Carbon)
|
find_library(CARBON_LIBRARY Carbon)
|
||||||
find_library(COCOA_LIBRARY Cocoa)
|
find_library(COCOA_LIBRARY Cocoa)
|
||||||
|
@ -316,10 +293,19 @@ if(APPLE)
|
||||||
find_library(FOUNDATION_LIBRARY Foundation)
|
find_library(FOUNDATION_LIBRARY Foundation)
|
||||||
find_library(IOB_LIBRARY IOBluetooth)
|
find_library(IOB_LIBRARY IOBluetooth)
|
||||||
find_library(IOK_LIBRARY IOKit)
|
find_library(IOK_LIBRARY IOKit)
|
||||||
find_library(QUICKTIME_LIBRARY QuickTime)
|
|
||||||
find_library(WEBKIT_LIBRARY WebKit)
|
|
||||||
find_library(FORCEFEEDBACK ForceFeedback)
|
find_library(FORCEFEEDBACK ForceFeedback)
|
||||||
find_library(OPENGL_LIBRARY OpenGL)
|
find_library(OPENGL_LIBRARY OpenGL)
|
||||||
|
|
||||||
|
# Link against OS X system frameworks.
|
||||||
|
list(APPEND LIBS
|
||||||
|
${APPKIT_LIBRARY}
|
||||||
|
${AU_LIBRARY}
|
||||||
|
${COREAUDIO_LIBRARY}
|
||||||
|
${COREFUND_LIBRARY}
|
||||||
|
${CORESERV_LIBRARY}
|
||||||
|
${IOK_LIBRARY}
|
||||||
|
${FORCEFEEDBACK}
|
||||||
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
|
@ -349,12 +335,7 @@ if(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD|NetBSD")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Dolphin requires threads.
|
# Dolphin requires threads.
|
||||||
# The Apple build may not need an explicit flag because one of the
|
find_package(Threads)
|
||||||
# frameworks may already provide it.
|
|
||||||
# But for non-OSX systems, we will use the CMake Threads package.
|
|
||||||
IF(NOT APPLE)
|
|
||||||
FIND_PACKAGE(Threads)
|
|
||||||
ENDIF(NOT APPLE)
|
|
||||||
|
|
||||||
if(NOT CMAKE_BUILD_TYPE)
|
if(NOT CMAKE_BUILD_TYPE)
|
||||||
set(CMAKE_BUILD_TYPE "Release" CACHE STRING
|
set(CMAKE_BUILD_TYPE "Release" CACHE STRING
|
||||||
|
@ -983,19 +964,6 @@ if(${CMAKE_SYSTEM_NAME} MATCHES "FreeBSD|NetBSD")
|
||||||
set(LIBS ${LIBS} usbhid)
|
set(LIBS ${LIBS} usbhid)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
# Link against OS X system frameworks.
|
|
||||||
list(APPEND LIBS
|
|
||||||
${APPKIT_LIBRARY}
|
|
||||||
${AU_LIBRARY}
|
|
||||||
${COREAUDIO_LIBRARY}
|
|
||||||
${COREFUND_LIBRARY}
|
|
||||||
${CORESERV_LIBRARY}
|
|
||||||
${IOK_LIBRARY}
|
|
||||||
${FORCEFEEDBACK}
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
########################################
|
########################################
|
||||||
# Pre-build events: Define configuration variables and write SCM info header
|
# Pre-build events: Define configuration variables and write SCM info header
|
||||||
#
|
#
|
||||||
|
|
|
@ -839,14 +839,13 @@ if(APPLE)
|
||||||
iconv
|
iconv
|
||||||
${APPKIT_LIBRARY}
|
${APPKIT_LIBRARY}
|
||||||
${APPSERV_LIBRARY}
|
${APPSERV_LIBRARY}
|
||||||
${ATB_LIBRARY}
|
|
||||||
${CARBON_LIBRARY}
|
${CARBON_LIBRARY}
|
||||||
${COCOA_LIBRARY}
|
${COCOA_LIBRARY}
|
||||||
${COREFUND_LIBRARY}
|
${COREFUND_LIBRARY}
|
||||||
${CORESERV_LIBRARY}
|
${CORESERV_LIBRARY}
|
||||||
${IOK_LIBRARY}
|
${IOK_LIBRARY}
|
||||||
${OPENGL_LIBRARY}
|
${OPENGL_LIBRARY}
|
||||||
${QUICKTIME_LIBRARY})
|
)
|
||||||
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux|FreeBSD")
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux|FreeBSD")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++11")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++11")
|
||||||
if(${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
|
if(${CMAKE_SYSTEM_NAME} STREQUAL "Linux")
|
||||||
|
|
|
@ -48,7 +48,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define wxOSX_USE_QUICKTIME 0
|
#define wxOSX_USE_QUICKTIME 0
|
||||||
#define wxOSX_USE_AUDIOTOOLBOX 1
|
#define wxOSX_USE_AUDIOTOOLBOX 0
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Use the more efficient FSEvents API instead of kqueue
|
Use the more efficient FSEvents API instead of kqueue
|
||||||
|
|
|
@ -875,7 +875,7 @@
|
||||||
/*
|
/*
|
||||||
* wxWebKitCtrl
|
* wxWebKitCtrl
|
||||||
*/
|
*/
|
||||||
#define wxUSE_WEBKIT 1
|
#define wxUSE_WEBKIT 0
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Objective-C class name uniquifying
|
* Objective-C class name uniquifying
|
||||||
|
|
|
@ -75,7 +75,7 @@
|
||||||
<key>NSHumanReadableCopyright</key>
|
<key>NSHumanReadableCopyright</key>
|
||||||
<string>Licensed under GPL version 2 or later (GPLv2+)</string>
|
<string>Licensed under GPL version 2 or later (GPLv2+)</string>
|
||||||
<key>LSMinimumSystemVersion</key>
|
<key>LSMinimumSystemVersion</key>
|
||||||
<string>${OSX_MIN_VERSION}</string>
|
<string>${CMAKE_OSX_DEPLOYMENT_TARGET}</string>
|
||||||
<key>NSHighResolutionCapable</key>
|
<key>NSHighResolutionCapable</key>
|
||||||
<true/>
|
<true/>
|
||||||
<key>CSResourcesFileMapped</key>
|
<key>CSResourcesFileMapped</key>
|
||||||
|
|
|
@ -75,7 +75,7 @@
|
||||||
<key>NSHumanReadableCopyright</key>
|
<key>NSHumanReadableCopyright</key>
|
||||||
<string>Licensed under GPL version 2</string>
|
<string>Licensed under GPL version 2</string>
|
||||||
<key>LSMinimumSystemVersion</key>
|
<key>LSMinimumSystemVersion</key>
|
||||||
<string>${OSX_MIN_VERSION}</string>
|
<string>${CMAKE_OSX_DEPLOYMENT_TARGET}</string>
|
||||||
<key>LSRequiresCarbon</key>
|
<key>LSRequiresCarbon</key>
|
||||||
<true/>
|
<true/>
|
||||||
<key>NSHighResolutionCapable</key>
|
<key>NSHighResolutionCapable</key>
|
||||||
|
|
Loading…
Reference in New Issue