CMake: Define QT_STATIC for static builds

QT_STATIC must be defined for static builds to have the right
import/export symbol macros defined. Originally, this macro is wrapped
in a condition. That's why we extend qt_feature_definition to be able
to write a prerequisite to qconfig.h.

Change-Id: I610e60acc7f5bdc031eff6d53a76e0b229a5c8c2
Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
This commit is contained in:
Joerg Bornemann 2020-03-31 14:12:01 +02:00
parent c20f23e03b
commit 7909de1beb
3 changed files with 29 additions and 5 deletions

View File

@ -343,7 +343,7 @@ endfunction()
function(qt_feature_definition feature name) function(qt_feature_definition feature name)
qt_feature_normalize_name("${feature}" feature) qt_feature_normalize_name("${feature}" feature)
qt_parse_all_arguments(arg "qt_feature_definition" "NEGATE" "VALUE" "" ${ARGN}) qt_parse_all_arguments(arg "qt_feature_definition" "NEGATE" "VALUE;PREREQUISITE" "" ${ARGN})
# Store all the define related info in a unique variable key. # Store all the define related info in a unique variable key.
set(key_name "_QT_FEATURE_DEFINE_DEFINITION_${feature}_${name}") set(key_name "_QT_FEATURE_DEFINE_DEFINITION_${feature}_${name}")
@ -363,7 +363,7 @@ function(qt_evaluate_feature_definition key)
cmake_parse_arguments(arg cmake_parse_arguments(arg
"NEGATE;" "NEGATE;"
"FEATURE;NAME;VALUE;" "" ${${key}}) "FEATURE;NAME;VALUE;PREREQUISITE" "" ${${key}})
set(expected ON) set(expected ON)
if (arg_NEGATE) if (arg_NEGATE)
@ -373,10 +373,18 @@ function(qt_evaluate_feature_definition key)
set(msg "") set(msg "")
if(QT_FEATURE_${arg_FEATURE} STREQUAL expected) if(QT_FEATURE_${arg_FEATURE} STREQUAL expected)
set(indent "")
if(arg_PREREQUISITE)
string(APPEND msg "#if ${arg_PREREQUISITE}\n")
set(indent " ")
endif()
if (arg_VALUE) if (arg_VALUE)
string(APPEND msg "#define ${arg_NAME} ${arg_VALUE}\n") string(APPEND msg "${indent}#define ${arg_NAME} ${arg_VALUE}\n")
else() else()
string(APPEND msg "#define ${arg_NAME}\n") string(APPEND msg "${indent}#define ${arg_NAME}\n")
endif()
if(arg_PREREQUISITE)
string(APPEND msg "#endif\n")
endif() endif()
string(APPEND __QtFeature_public_extra "${msg}") string(APPEND __QtFeature_public_extra "${msg}")

View File

@ -321,6 +321,7 @@ qt_feature("shared" PUBLIC
AUTODETECT NOT UIKIT AUTODETECT NOT UIKIT
CONDITION BUILD_SHARED_LIBS CONDITION BUILD_SHARED_LIBS
) )
qt_feature_definition("shared" "QT_STATIC" NEGATE PREREQUISITE "!defined(QT_SHARED) && !defined(QT_STATIC)")
qt_feature_config("shared" QMAKE_PUBLIC_QT_CONFIG) qt_feature_config("shared" QMAKE_PUBLIC_QT_CONFIG)
qt_feature_config("shared" QMAKE_PUBLIC_CONFIG) qt_feature_config("shared" QMAKE_PUBLIC_CONFIG)
qt_feature("use_bfd_linker" qt_feature("use_bfd_linker"

View File

@ -827,7 +827,20 @@ def get_feature_mapping():
"sanitizer": None, "sanitizer": None,
"sanitize_thread": None, "sanitize_thread": None,
"sanitize_undefined": None, "sanitize_undefined": None,
"shared": {"condition": "BUILD_SHARED_LIBS"}, "shared": {
"condition": "BUILD_SHARED_LIBS",
"output": [
"publicFeature",
"publicQtConfig",
"publicConfig",
{
"type": "define",
"name": "QT_STATIC",
"prerequisite": "!defined(QT_SHARED) && !defined(QT_STATIC)",
"negative": True
}
]
},
"silent": None, "silent": None,
"sql-sqlite": {"condition": "QT_FEATURE_datestring"}, "sql-sqlite": {"condition": "QT_FEATURE_datestring"},
"static": None, "static": None,
@ -1050,6 +1063,8 @@ def parseFeature(ctx, feature, data, cm_fh):
cm_fh.write(" NEGATE") cm_fh.write(" NEGATE")
if outputArgs.get("value") is not None: if outputArgs.get("value") is not None:
cm_fh.write(f' VALUE "{outputArgs.get("value")}"') cm_fh.write(f' VALUE "{outputArgs.get("value")}"')
if outputArgs.get("prerequisite") is not None:
cm_fh.write(f' PREREQUISITE "{outputArgs.get("prerequisite")}"')
cm_fh.write(")\n") cm_fh.write(")\n")
# Write qt_feature_config() calls # Write qt_feature_config() calls