1 diff --git a/mkspecs/common/mac.conf b/mkspecs/common/mac.conf
2 index b77494ec..470c38e7 100644
3 --- a/mkspecs/common/mac.conf
4 +++ b/mkspecs/common/mac.conf
5 @@ -24,7 +24,7 @@ QMAKE_INCDIR_OPENGL = \
7 QMAKE_FIX_RPATH = install_name_tool -id
9 -QMAKE_LFLAGS_RPATH = -Wl,-rpath,
11 QMAKE_LFLAGS_GCSECTIONS = -Wl,-dead_strip
13 QMAKE_LFLAGS_REL_RPATH =
14 diff --git a/mkspecs/features/mac/default_post.prf b/mkspecs/features/mac/default_post.prf
15 index d052808c..b80ec1e8 100644
16 --- a/mkspecs/features/mac/default_post.prf
17 +++ b/mkspecs/features/mac/default_post.prf
18 @@ -68,208 +68,6 @@ qt {
22 -# Add the same default rpaths as Xcode does for new projects.
23 -# This is especially important for iOS/tvOS/watchOS where no other option is possible.
25 - QMAKE_RPATHDIR += @executable_path/../Frameworks
26 - equals(TEMPLATE, lib):!plugin:lib_bundle: QMAKE_RPATHDIR += @loader_path/Frameworks
29 -# Don't pass -headerpad_max_install_names when using Bitcode.
30 -# In that case the linker emits a warning stating that the flag is ignored when
31 -# used with bitcode, for reasons that cannot be determined (rdar://problem/20748962).
32 -# Using this flag is also unnecessary in practice on UIKit platforms since they
33 -# are sandboxed, and only UIKit platforms support bitcode to begin with.
34 -!bitcode: QMAKE_LFLAGS += $$QMAKE_LFLAGS_HEADERPAD
36 -app_extension_api_only {
37 - QMAKE_CFLAGS += $$QMAKE_CFLAGS_APPLICATION_EXTENSION
38 - QMAKE_CXXFLAGS += $$QMAKE_CFLAGS_APPLICATION_EXTENSION
39 - QMAKE_CXXFLAGS_PRECOMPILE += $$QMAKE_CFLAGS_APPLICATION_EXTENSION
40 - QMAKE_LFLAGS += $$QMAKE_CFLAGS_APPLICATION_EXTENSION
44 - qmake_pkginfo_typeinfo.name = QMAKE_PKGINFO_TYPEINFO
45 - !isEmpty(QMAKE_PKGINFO_TYPEINFO): \
46 - qmake_pkginfo_typeinfo.value = $$QMAKE_PKGINFO_TYPEINFO
48 - qmake_pkginfo_typeinfo.value = "????"
49 - QMAKE_MAC_XCODE_SETTINGS += qmake_pkginfo_typeinfo
51 - bundle_version = $$VERSION
52 - isEmpty(bundle_version): bundle_version = 1.0.0
54 - l = $$split(bundle_version, '.') 0 0 # make sure there are at least three
55 - VER_MAJ = $$member(l, 0, 0)
56 - VER_MIN = $$member(l, 1, 1)
57 - VER_PAT = $$member(l, 2, 2)
60 - qmake_full_version.name = QMAKE_FULL_VERSION
61 - qmake_full_version.value = $${VER_MAJ}.$${VER_MIN}.$${VER_PAT}
62 - QMAKE_MAC_XCODE_SETTINGS += qmake_full_version
64 - qmake_short_version.name = QMAKE_SHORT_VERSION
65 - qmake_short_version.value = $${VER_MAJ}.$${VER_MIN}
66 - QMAKE_MAC_XCODE_SETTINGS += qmake_short_version
68 - !isEmpty(QMAKE_XCODE_DEBUG_INFORMATION_FORMAT) {
69 - debug_information_format.name = DEBUG_INFORMATION_FORMAT
70 - debug_information_format.value = $$QMAKE_XCODE_DEBUG_INFORMATION_FORMAT
71 - debug_information_format.build = debug
72 - QMAKE_MAC_XCODE_SETTINGS += debug_information_format
77 - arch_device.name = "ARCHS[sdk=$${device.sdk}*]"
78 - arch_device.value = $$QMAKE_APPLE_DEVICE_ARCHS
79 - QMAKE_XCODE_ARCHS += $$QMAKE_APPLE_DEVICE_ARCHS
80 - QMAKE_MAC_XCODE_SETTINGS += arch_device
83 - arch_simulator.name = "ARCHS[sdk=$${simulator.sdk}*]"
84 - arch_simulator.value = $$QMAKE_APPLE_SIMULATOR_ARCHS
85 - QMAKE_XCODE_ARCHS += $$QMAKE_APPLE_SIMULATOR_ARCHS
86 - QMAKE_MAC_XCODE_SETTINGS += arch_simulator
89 - only_active_arch.name = ONLY_ACTIVE_ARCH
90 - only_active_arch.value = YES
91 - only_active_arch.build = debug
92 - QMAKE_MAC_XCODE_SETTINGS += only_active_arch
94 - device|!simulator: VALID_DEVICE_ARCHS = $$QMAKE_APPLE_DEVICE_ARCHS
95 - simulator: VALID_SIMULATOR_ARCHS = $$QMAKE_APPLE_SIMULATOR_ARCHS
96 - VALID_ARCHS = $$VALID_DEVICE_ARCHS $$VALID_SIMULATOR_ARCHS
98 - isEmpty(VALID_ARCHS): \
99 - error("QMAKE_APPLE_DEVICE_ARCHS or QMAKE_APPLE_SIMULATOR_ARCHS must contain at least one architecture")
101 - single_arch: VALID_ARCHS = $$first(VALID_ARCHS)
103 - ACTIVE_ARCHS = $(filter $(EXPORT_VALID_ARCHS), $(ARCHS))
104 - ARCH_ARGS = $(foreach arch, $(if $(EXPORT_ACTIVE_ARCHS), $(EXPORT_ACTIVE_ARCHS), $(EXPORT_VALID_ARCHS)), -arch $(arch))
106 - QMAKE_EXTRA_VARIABLES += VALID_ARCHS ACTIVE_ARCHS ARCH_ARGS
108 - arch_flags = $(EXPORT_ARCH_ARGS)
110 - QMAKE_CFLAGS += $$arch_flags
111 - QMAKE_CXXFLAGS += $$arch_flags
112 - QMAKE_LFLAGS += $$arch_flags
114 - QMAKE_PCH_ARCHS = $$VALID_ARCHS
116 - macos: deployment_target = $$QMAKE_MACOSX_DEPLOYMENT_TARGET
117 - ios: deployment_target = $$QMAKE_IOS_DEPLOYMENT_TARGET
118 - tvos: deployment_target = $$QMAKE_TVOS_DEPLOYMENT_TARGET
119 - watchos: deployment_target = $$QMAKE_WATCHOS_DEPLOYMENT_TARGET
121 - # If we're doing a simulator and device build, device and simulator
122 - # architectures use different paths and flags for the sysroot and
123 - # deployment target switch, so we must multiplex them across multiple
124 - # architectures using -Xarch. Otherwise we fall back to the simple path.
125 - # This is not strictly necessary, but results in cleaner command lines
126 - # and makes it easier for people to override EXPORT_VALID_ARCHS to limit
127 - # individual rules to a different set of architecture(s) from the overall
128 - # build (such as machtest in QtCore).
130 - QMAKE_XARCH_CFLAGS =
131 - QMAKE_XARCH_LFLAGS =
132 - QMAKE_EXTRA_VARIABLES += QMAKE_XARCH_CFLAGS QMAKE_XARCH_LFLAGS
134 - for (arch, VALID_ARCHS) {
135 - contains(VALID_SIMULATOR_ARCHS, $$arch) {
136 - sdk = $$simulator.sdk
137 - version_identifier = $$simulator.deployment_identifier
140 - version_identifier = $$device.deployment_identifier
143 - version_min_flags = \
145 - -m$${version_identifier}-version-min=$$deployment_target
146 - QMAKE_XARCH_CFLAGS_$${arch} = $$version_min_flags \
148 - -isysroot$$xcodeSDKInfo(Path, $$sdk)
149 - QMAKE_XARCH_LFLAGS_$${arch} = $$version_min_flags \
151 - -isysroot$$xcodeSDKInfo(Path, $$sdk)
153 - QMAKE_XARCH_CFLAGS += $(EXPORT_QMAKE_XARCH_CFLAGS_$${arch})
154 - QMAKE_XARCH_LFLAGS += $(EXPORT_QMAKE_XARCH_LFLAGS_$${arch})
156 - QMAKE_EXTRA_VARIABLES += \
157 - QMAKE_XARCH_CFLAGS_$${arch} \
158 - QMAKE_XARCH_LFLAGS_$${arch}
161 - QMAKE_CFLAGS += $(EXPORT_QMAKE_XARCH_CFLAGS)
162 - QMAKE_CXXFLAGS += $(EXPORT_QMAKE_XARCH_CFLAGS)
163 - QMAKE_LFLAGS += $(EXPORT_QMAKE_XARCH_LFLAGS)
166 - version_identifier = $$simulator.deployment_identifier
168 - version_identifier = $$device.deployment_identifier
169 - version_min_flag = -m$${version_identifier}-version-min=$$deployment_target
170 - QMAKE_CFLAGS += -isysroot $$QMAKE_MAC_SDK_PATH $$version_min_flag
171 - QMAKE_CXXFLAGS += -isysroot $$QMAKE_MAC_SDK_PATH $$version_min_flag
172 - QMAKE_LFLAGS += -isysroot $$QMAKE_MAC_SDK_PATH $$version_min_flag
175 - # Enable precompiled headers for multiple architectures
176 - QMAKE_CFLAGS_USE_PRECOMPILE =
177 - for (arch, VALID_ARCHS) {
179 - use_flag = "-pch-use "
181 - use_flag = -include
183 - # Only use Xarch with multi-arch, as the option confuses ccache
184 - count(VALID_ARCHS, 1, greaterThan): \
185 - QMAKE_CFLAGS_USE_PRECOMPILE += \
188 - QMAKE_CFLAGS_USE_PRECOMPILE += \
189 - $${use_flag}${QMAKE_PCH_OUTPUT_$${arch}}
192 - QMAKE_CXXFLAGS_USE_PRECOMPILE = $$QMAKE_CFLAGS_USE_PRECOMPILE -include ${QMAKE_PCH_INPUT}
193 - QMAKE_CFLAGS_USE_PRECOMPILE =
195 - QMAKE_CXXFLAGS_USE_PRECOMPILE = $$QMAKE_CFLAGS_USE_PRECOMPILE
196 - QMAKE_OBJCFLAGS_USE_PRECOMPILE = $$QMAKE_CFLAGS_USE_PRECOMPILE
197 - QMAKE_OBJCXXFLAGS_USE_PRECOMPILE = $$QMAKE_CFLAGS_USE_PRECOMPILE
200 - QMAKE_PCH_OUTPUT_EXT = _${QMAKE_PCH_ARCH}$${QMAKE_PCH_OUTPUT_EXT}
203 -!equals(sdk_version, $$QMAKE_MAC_SDK_VERSION) {
204 - # Explicit SDK version has been set, respect that
205 - QMAKE_LFLAGS += -Wl,-sdk_version -Wl,$$sdk_version
208 -cache(QMAKE_XCODE_DEVELOPER_PATH, stash)
209 -!isEmpty(QMAKE_XCODE_VERSION): \
210 - cache(QMAKE_XCODE_VERSION, stash)
212 -QMAKE_XCODE_LIBRARY_SUFFIX = $$qtPlatformTargetSuffix()
214 -xcode_product_bundle_identifier_setting.name = PRODUCT_BUNDLE_IDENTIFIER
215 -xcode_product_bundle_identifier_setting.value = $$QMAKE_TARGET_BUNDLE_PREFIX
216 -isEmpty(xcode_product_bundle_identifier_setting.value): \
217 - xcode_product_bundle_identifier_setting.value = "com.yourcompany"
218 -xcode_product_bundle_target = $$QMAKE_BUNDLE
219 -isEmpty(xcode_product_bundle_target): \
220 - xcode_product_bundle_target = ${PRODUCT_NAME:rfc1034identifier}
221 -xcode_product_bundle_identifier_setting.value = "$${xcode_product_bundle_identifier_setting.value}.$${xcode_product_bundle_target}"
222 -QMAKE_MAC_XCODE_SETTINGS += xcode_product_bundle_identifier_setting
225 generate_xcode_project.commands = @$(QMAKE) -spec macx-xcode \"$(EXPORT__PRO_FILE_)\" $$QMAKE_ARGS
226 generate_xcode_project.target = xcodeproj
227 diff --git a/mkspecs/features/mac/default_pre.prf b/mkspecs/features/mac/default_pre.prf
228 index e3534561..3b01424e 100644
229 --- a/mkspecs/features/mac/default_pre.prf
230 +++ b/mkspecs/features/mac/default_pre.prf
232 CONFIG = asset_catalogs rez $$CONFIG
235 -isEmpty(QMAKE_XCODE_DEVELOPER_PATH) {
236 - # Get path of Xcode's Developer directory
237 - QMAKE_XCODE_DEVELOPER_PATH = $$system("/usr/bin/xcode-select --print-path 2>/dev/null")
238 - isEmpty(QMAKE_XCODE_DEVELOPER_PATH): \
239 - error("Xcode path is not set. Please use xcode-select to choose Xcode installation path.")
241 - # Make sure Xcode path is valid
242 - !exists($$QMAKE_XCODE_DEVELOPER_PATH): \
243 - error("Xcode is not installed in $${QMAKE_XCODE_DEVELOPER_PATH}. Please use xcode-select to choose Xcode installation path.")
246 -isEmpty(QMAKE_XCODEBUILD_PATH): \
247 - QMAKE_XCODEBUILD_PATH = $$system("/usr/bin/xcrun -find xcodebuild 2>/dev/null")
249 -!isEmpty(QMAKE_XCODEBUILD_PATH) {
250 - # Make sure Xcode is set up properly
251 - !system("/usr/bin/xcrun xcodebuild -license check 2>/dev/null"): \
252 - error("Xcode not set up properly. You need to confirm the license agreement by running 'sudo xcrun xcodebuild -license accept'.")
254 - isEmpty(QMAKE_XCODE_VERSION) {
255 - # Extract Xcode version using xcodebuild
256 - xcode_version = $$system("/usr/bin/xcrun xcodebuild -version")
257 - QMAKE_XCODE_VERSION = $$member(xcode_version, 1)
258 - isEmpty(QMAKE_XCODE_VERSION): error("Could not resolve Xcode version.")
259 - unset(xcode_version)
263 -isEmpty(QMAKE_TARGET_BUNDLE_PREFIX) {
264 - QMAKE_XCODE_PREFERENCES_FILE = $$(HOME)/Library/Preferences/com.apple.dt.Xcode.plist
265 - exists($$QMAKE_XCODE_PREFERENCES_FILE): \
266 - QMAKE_TARGET_BUNDLE_PREFIX = $$system("/usr/libexec/PlistBuddy -c 'print IDETemplateOptions:bundleIdentifierPrefix' $$QMAKE_XCODE_PREFERENCES_FILE 2>/dev/null")
268 - !isEmpty(_QMAKE_CACHE_):!isEmpty(QMAKE_TARGET_BUNDLE_PREFIX): \
269 - cache(QMAKE_TARGET_BUNDLE_PREFIX)
272 -QMAKE_ASSET_CATALOGS_APP_ICON = AppIcon
274 -# Make the default debug info format for static debug builds
275 -# DWARF instead of DWARF with dSYM. This cuts down build times
276 -# for application debug builds significantly, as Xcode doesn't
277 -# have to pull out all the DWARF info from the Qt static libs
278 -# and put it into a dSYM file. We don't need that dSYM file in
279 -# the first place, since the information is available in the
280 -# object files inside the archives (static libraries).
281 -macx-xcode:qtConfig(static): \
282 - QMAKE_XCODE_DEBUG_INFORMATION_FORMAT = dwarf
284 -# This variable is used by the xcode_dynamic_library_suffix
285 -# feature, which allows Xcode to choose the Qt libraries to link to
286 -# at build time, depending on the current Xcode SDK and configuration.
287 -QMAKE_XCODE_LIBRARY_SUFFIX_SETTING = QT_LIBRARY_SUFFIX
289 -xcode_copy_phase_strip_setting.name = COPY_PHASE_STRIP
290 -xcode_copy_phase_strip_setting.value = NO
291 -QMAKE_MAC_XCODE_SETTINGS += xcode_copy_phase_strip_setting
292 diff --git a/mkspecs/features/mac/sdk.mk b/mkspecs/features/mac/sdk.mk
293 index c40f58c9..e69de29b 100644
294 --- a/mkspecs/features/mac/sdk.mk
295 +++ b/mkspecs/features/mac/sdk.mk
298 -ifeq ($(QT_MAC_SDK_NO_VERSION_CHECK),)
299 - CHECK_SDK_COMMAND = /usr/bin/xcrun --sdk $(EXPORT_QMAKE_MAC_SDK) -show-sdk-version 2>&1
300 - CURRENT_MAC_SDK_VERSION := $(shell DEVELOPER_DIR=$(EXPORT_QMAKE_XCODE_DEVELOPER_PATH) $(CHECK_SDK_COMMAND))
301 - ifneq ($(CURRENT_MAC_SDK_VERSION),$(EXPORT_QMAKE_MAC_SDK_VERSION))
302 - # We don't want to complain about out of date SDK unless the target needs to be remade.
303 - # This covers use-cases such as running 'make check' after moving the build to a
304 - # computer without Xcode or with a different Xcode version.
305 - TARGET_UP_TO_DATE := $(shell QT_MAC_SDK_NO_VERSION_CHECK=1 $(MAKE) --question $(QMAKE_TARGET) && echo 1 || echo 0)
306 - ifeq ($(TARGET_UP_TO_DATE),0)
307 - ifneq ($(findstring missing DEVELOPER_DIR path,$(CURRENT_MAC_SDK_VERSION)),)
308 - $(info The developer dir $(EXPORT_QMAKE_XCODE_DEVELOPER_PATH) is no longer valid.)
309 - else ifneq ($(findstring SDK "$(EXPORT_QMAKE_MAC_SDK)" cannot be located,$(CURRENT_MAC_SDK_VERSION)),)
310 - $(info The developer dir $(EXPORT_QMAKE_XCODE_DEVELOPER_PATH) no longer contains the $(EXPORT_QMAKE_MAC_SDK_VERSION) platform SDK.)
311 - else ifneq ($(CURRENT_MAC_SDK_VERSION),)
312 - $(info The platform SDK has been changed from version $(EXPORT_QMAKE_MAC_SDK_VERSION) to version $(CURRENT_MAC_SDK_VERSION).)
314 - $(info Unknown error resolving current platform SDK version.)
316 - $(info This requires a fresh build. Please wipe the build directory completely,)
317 - $(info including any .qmake.stash and .qmake.cache files generated by qmake.)
322 diff --git a/mkspecs/features/mac/sdk.prf b/mkspecs/features/mac/sdk.prf
323 index 3a9c2778..e69de29b 100644
324 --- a/mkspecs/features/mac/sdk.prf
325 +++ b/mkspecs/features/mac/sdk.prf
328 -isEmpty(QMAKE_MAC_SDK): \
329 - error("QMAKE_MAC_SDK must be set when using CONFIG += sdk.")
331 -contains(QMAKE_MAC_SDK, .*/.*): \
332 - error("QMAKE_MAC_SDK can only contain short-form SDK names (eg. macosx, iphoneos)")
334 -defineReplace(xcodeSDKInfo) {
336 - equals(info, "Path"): \
337 - infoarg = --show-sdk-path
338 - equals(info, "PlatformPath"): \
339 - infoarg = --show-sdk-platform-path
340 - equals(info, "SDKVersion"): \
341 - infoarg = --show-sdk-version
344 - sdk = $$QMAKE_MAC_SDK
346 - isEmpty(QMAKE_MAC_SDK.$${sdk}.$${info}) {
347 - QMAKE_MAC_SDK.$${sdk}.$${info} = $$system("/usr/bin/xcrun --sdk $$sdk $$infoarg 2>/dev/null")
348 - # --show-sdk-platform-path won't work for Command Line Tools; this is fine
349 - # only used by the XCTest backend to testlib
350 - isEmpty(QMAKE_MAC_SDK.$${sdk}.$${info}):if(!isEmpty(QMAKE_XCODEBUILD_PATH)|!equals(infoarg, "--show-sdk-platform-path")): \
351 - error("Could not resolve SDK $$info for \'$$sdk\' using $$infoarg")
352 - cache(QMAKE_MAC_SDK.$${sdk}.$${info}, set stash, QMAKE_MAC_SDK.$${sdk}.$${info})
355 - return($$eval(QMAKE_MAC_SDK.$${sdk}.$${info}))
358 -QMAKE_MAC_SDK_PATH = $$xcodeSDKInfo(Path)
359 -QMAKE_MAC_SDK_PLATFORM_PATH = $$xcodeSDKInfo(PlatformPath)
360 -QMAKE_MAC_SDK_VERSION = $$xcodeSDKInfo(SDKVersion)
362 -isEmpty(QMAKE_EXPORT_INCDIR_OPENGL) {
363 - QMAKE_EXPORT_INCDIR_OPENGL = $$QMAKE_INCDIR_OPENGL
365 - for(val, QMAKE_INCDIR_OPENGL): sysrootified += $${QMAKE_MAC_SDK_PATH}$$val
366 - QMAKE_INCDIR_OPENGL = $$sysrootified
369 -QMAKESPEC_NAME = $$basename(QMAKESPEC)
371 -# Resolve SDK version of various tools
372 -for(tool, $$list(QMAKE_CC QMAKE_CXX QMAKE_FIX_RPATH QMAKE_AR QMAKE_RANLIB QMAKE_LINK QMAKE_LINK_SHLIB QMAKE_ACTOOL QMAKE_LINK_C QMAKE_LINK_C_SHLIB)) {
373 - tool_variable = QMAKE_MAC_SDK.$${QMAKESPEC_NAME}.$${QMAKE_MAC_SDK}.$${tool}
374 - !isEmpty($$tool_variable) {
375 - $$tool = $$eval($$tool_variable)
379 - value = $$eval($$tool)
380 - isEmpty(value): next()
382 - sysrooted = $$system("/usr/bin/xcrun -sdk $$QMAKE_MAC_SDK -find $$first(value) 2>/dev/null")
383 - isEmpty(sysrooted): next()
385 - $$tool = $$sysrooted $$member(value, 1, -1)
386 - cache($$tool_variable, set stash, $$tool)