X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=development%2Fcmake%2FConfigureChecks.cmake;h=f09ba8bd921c460d69d83f1d3d10f9664558009e;hb=6461d6aa1b01a97814020020e260c34c117a2631;hp=2de915f7e701558212f0859f1de970144188b952;hpb=7a86fe3e0b70f944a2c99381ebf217609bf993e9;p=lyx.git diff --git a/development/cmake/ConfigureChecks.cmake b/development/cmake/ConfigureChecks.cmake index 2de915f7e7..f09ba8bd92 100644 --- a/development/cmake/ConfigureChecks.cmake +++ b/development/cmake/ConfigureChecks.cmake @@ -12,6 +12,7 @@ include(CheckFunctionExists) include(CheckLibraryExists) include(CheckTypeSize) include(CheckCXXSourceCompiles) +include(CheckCXXSourceRuns) include(MacroBoolTo01) include(TestBigEndian) @@ -61,6 +62,7 @@ check_symbol_exists(pid_t "sys/types.h" HAVE_PID_T) check_symbol_exists(intmax_t "inttypes.h" HAVE_INTTYPES_H_WITH_UINTMAX) check_symbol_exists(uintmax_t "stdint.h" HAVE_STDINT_H_WITH_UINTMAX) check_symbol_exists(LC_MESSAGES "locale.h" HAVE_LC_MESSAGES) +check_symbol_exists(PATH_MAX "limits.h" HAVE_DEF_PATH_MAX) check_type_size(intmax_t HAVE_INTMAX_T) macro_bool_to_01(HAVE_UINTMAX_T HAVE_STDINT_H_WITH_UINTMAX) @@ -172,6 +174,27 @@ check_cxx_source_compiles( " lyx_cv_prog_clang) +check_cxx_source_compiles( + " + #include + using std::make_unique; + int main() { + return(0); + } + " +HAVE_DEF_MAKE_UNIQUE) + +check_cxx_source_compiles( + " + #include + static std::once_flag flag; + int main() { + std::call_once(flag, [](){ return; }); + return(0); + } + " +LYX_USE_STD_CALL_ONCE) + set(USE_LLVM_LIBCPP) set(STD_STRING_USES_COW) set(USE_GLIBCXX_CXX11_ABI) @@ -186,7 +209,36 @@ else() endif() endif() +set(QPA_XCB) +set(HAVE_QT5_X11_EXTRAS) if(LYX_USE_QT MATCHES "QT5") + + set(CMAKE_REQUIRED_INCLUDES ${Qt5Core_INCLUDE_DIRS}) + set(CMAKE_REQUIRED_FLAGS) + #message(STATUS "Qt5Core_INCLUDE_DIRS = ${Qt5Core_INCLUDE_DIRS}") + check_include_file_cxx(QtGui/qtgui-config.h HAVE_QTGUI_CONFIG_H) + if (HAVE_QTGUI_CONFIG_H) + set(lyx_qt5_config "QtGui/qtgui-config.h") + else() + set(lyx_qt5_config "QtCore/qconfig.h") + endif() + check_cxx_source_runs( + " + #include <${lyx_qt5_config}> + #include + using namespace std; + string a(QT_QPA_DEFAULT_PLATFORM_NAME); + int main(int argc, char **argv) + { + if (a.compare(\"xcb\") == 0) + return(0); + else + return 1; + } + " + QT_USES_X11) + set(QPA_XCB ${QT_USES_X11}) + if (Qt5X11Extras_FOUND) get_target_property(_x11extra_prop Qt5::X11Extras IMPORTED_CONFIGURATIONS) get_target_property(_x11extra_link_libraries Qt5::X11Extras IMPORTED_LOCATION_${_x11extra_prop}) @@ -204,7 +256,9 @@ if(LYX_USE_QT MATCHES "QT5") bool isX11 = QX11Info::isPlatformX11(); } " - QT_USES_X11) + QT_HAS_X11_EXTRAS) + set(HAVE_QT5_X11_EXTRAS ${QT_HAS_X11_EXTRAS}) + set(LYX_QT5_X11_EXTRAS_LIBRARY ${_x11extra_link_libraries}) endif() if (Qt5WinExtras_FOUND) get_target_property(_winextra_prop Qt5::WinExtras IMPORTED_CONFIGURATIONS) @@ -230,4 +284,3 @@ elseif(LYX_USE_QT MATCHES "QT4") else() message(FATAL_ERROR "Check for QT_USES_X11: Not handled LYX_USE_QT (= ${LYX_USE_QT})") endif() -