X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=CMakeLists.txt;h=ec86073dcf956eb97fc03345f95e0b95abbcca70;hp=3ab0f72d7fb9a42891fe6e08e84605ce0344bd18;hb=HEAD;hpb=136995b831c50d3261143b1183c73af55c9ba3a5 diff --git a/CMakeLists.txt b/CMakeLists.txt index 3ab0f72d..ec86073d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -48,6 +48,7 @@ option(ENABLE_DECODE "Build with libsigrokdecode" TRUE) option(ENABLE_FLOW "Build with libsigrokflow" FALSE) option(ENABLE_TESTS "Enable unit tests" FALSE) option(STATIC_PKGDEPS_LIBS "Statically link to (pkg-config) libraries" FALSE) +option(ENABLE_TS_UPDATE "Update .ts source files (Qt l10n)" FALSE) if(WIN32) # On Windows/MinGW we need to statically link to libraries. @@ -82,30 +83,46 @@ include(memaccess) find_package(PkgConfig) -check_cxx_compiler_flag("-std=c++17" HAVE_STD_CXX_17) -check_cxx_compiler_flag("-std=c++14" HAVE_STD_CXX_14) -check_cxx_compiler_flag("-std=c++11" HAVE_STD_CXX_11) -if(HAVE_STD_CXX_17) - message(STATUS "Using C++17 for the application build") - set(CMAKE_CXX_STANDARD 17) - set(REQUIRED_STD_CXX_FLAGS "-std=c++17") -elseif(HAVE_STD_CXX_14) - message(STATUS "Using C++14 for the application build") - set(CMAKE_CXX_STANDARD 14) - set(REQUIRED_STD_CXX_FLAGS "-std=c++14") -elseif(HAVE_STD_CXX_11) - message(STATUS "Using C++11 for the application build") - set(CMAKE_CXX_STANDARD 11) - set(REQUIRED_STD_CXX_FLAGS "-std=c++11") +if(CMAKE_VERSION VERSION_EQUAL "3.8.0" OR CMAKE_VERSION VERSION_GREATER "3.8.0") + check_cxx_compiler_flag("-std=c++17" HAVE_STD_CXX_17) + check_cxx_compiler_flag("-std=c++14" HAVE_STD_CXX_14) + check_cxx_compiler_flag("-std=c++11" HAVE_STD_CXX_11) + if(HAVE_STD_CXX_17) + message(STATUS "Using C++17 for the application build") + set(CMAKE_CXX_STANDARD 17) + set(REQUIRED_STD_CXX_FLAGS "-std=c++17") + elseif(HAVE_STD_CXX_14) + message(STATUS "Using C++14 for the application build") + set(CMAKE_CXX_STANDARD 14) + set(REQUIRED_STD_CXX_FLAGS "-std=c++14") + elseif(HAVE_STD_CXX_11) + message(STATUS "Using C++11 for the application build") + set(CMAKE_CXX_STANDARD 11) + set(REQUIRED_STD_CXX_FLAGS "-std=c++11") + else() + message(FATAL_ERROR "Need modern C++, at least language standard 11") + endif() else() - message(FATAL_ERROR "Need modern C++, at least language standard 11") + check_cxx_compiler_flag("-std=c++14" HAVE_STD_CXX_14) + check_cxx_compiler_flag("-std=c++11" HAVE_STD_CXX_11) + if(HAVE_STD_CXX_14) + message(STATUS "Using C++14 for the application build") + set(CMAKE_CXX_STANDARD 14) + set(REQUIRED_STD_CXX_FLAGS "-std=c++14") + elseif(HAVE_STD_CXX_11) + message(STATUS "Using C++11 for the application build") + set(CMAKE_CXX_STANDARD 11) + set(REQUIRED_STD_CXX_FLAGS "-std=c++11") + else() + message(FATAL_ERROR "Need modern C++, at least language standard 11") + endif() endif() list(APPEND PKGDEPS glib-2.0>=2.28.0) # Try to find the prefered glibmm-2.4. If not found then add glibmm-2.68 # to the dependency list. -pkg_check_modules(GLIBMM_2_4 glibmm-2.4>2.28.0) +pkg_check_modules(GLIBMM_2_4 glibmm-2.4>=2.28.0) if(GLIBMM_2_4_FOUND) list(APPEND PKGDEPS glibmm-2.4>=2.28.0) else() @@ -528,14 +545,16 @@ endif () if(Qt5_FOUND) qt5_add_translation(QM_FILES ${TS_FILES}) - qt5_create_translation(QM_FILES ${pulseview_SOURCES} ${TS_FILES}) - qt5_add_resources(pulseview_RESOURCES_RCC ${CMAKE_BINARY_DIR}/translations.qrc) + if (ENABLE_TS_UPDATE) + qt5_create_translation(QM_FILES ${pulseview_SOURCES} ${TS_FILES}) + endif () else() qt6_add_translation(QM_FILES ${TS_FILES}) - qt6_create_translation(QM_FILES ${pulseview_SOURCES} ${TS_FILES}) - qt6_add_resources(pulseview_RESOURCES_RCC ${CMAKE_BINARY_DIR}/translations.qrc) + if (ENABLE_TS_UPDATE) + qt6_create_translation(QM_FILES ${pulseview_SOURCES} ${TS_FILES}) + endif () endif() #===============================================================================