From b8d46d5e505d1942dadab63ad31e7be4147382f5 Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Wed, 10 Jun 2020 12:07:28 -0400 Subject: ci: add a script to download Qt --- .gitlab/ci/download_qt.cmake | 136 ++++++++++++++++++++++++++++++++++++ .gitlab/ci/download_qt_hashes.cmake | 9 +++ 2 files changed, 145 insertions(+) create mode 100644 .gitlab/ci/download_qt.cmake create mode 100644 .gitlab/ci/download_qt_hashes.cmake diff --git a/.gitlab/ci/download_qt.cmake b/.gitlab/ci/download_qt.cmake new file mode 100644 index 0000000..2c5854d --- /dev/null +++ b/.gitlab/ci/download_qt.cmake @@ -0,0 +1,136 @@ +cmake_minimum_required(VERSION 3.12) + +# Input variables. +set(qt_version_major "5") +set(qt_version_minor "15") +set(qt_version_patch "0") +# This URL is only visible inside of Kitware's network. Please use your own Qt +# Account to obtain these files. +set(qt_url_root "https://paraview.org/files/dependencies/internal/qt") + +# Determine the ABI to fetch for Qt. +if ("$ENV{CMAKE_CONFIGURATION}" MATCHES "vs2015") + set(qt_platform "windows_x86") + set(msvc_year "2015") + set(qt_abi "win64_msvc${msvc_year}_64") +elseif ("$ENV{CMAKE_CONFIGURATION}" MATCHES "vs2017" OR + "$ENV{CMAKE_CONFIGURATION}" MATCHES "vs2019") + set(qt_platform "windows_x86") + set(msvc_year "2017") + set(qt_abi "win64_msvc${msvc_year}_64") +elseif ("$ENV{CMAKE_CONFIGURATION}" MATCHES "macos") + set(qt_platform "mac_x64") + set(qt_abi "clang_64") +else () + message(FATAL_ERROR + "Unknown ABI to use for Qt") +endif () + +# Combined version variables. +set(qt_version "${qt_version_major}.${qt_version_minor}.${qt_version_patch}") +set(qt_version_nodot "${qt_version_major}${qt_version_minor}${qt_version_patch}") + +# Files needed to download. +set(qt_files) +if (qt_platform STREQUAL "windows_x86") + if (msvc_year STREQUAL "2017") + set(qt_build_stamp "202002260536") + elseif (msvc_year STREQUAL "2015") + set(qt_build_stamp "202005150700") + else () + message(FATAL_ERROR + "Build stamp for MSVC ${msvc_year} is unknown") + endif () + + set(qt_file_name_prefix "${qt_version}-0-${qt_build_stamp}") + + foreach (qt_component IN ITEMS qtbase qtwinextras) + list(APPEND qt_files + "${qt_file_name_prefix}${qt_component}-Windows-Windows_10-MSVC${msvc_year}-Windows-Windows_10-X86_64.7z") + endforeach () + + set(qt_subdir "${qt_version}/msvc${msvc_year}_64") +else () + message(FATAL_ERROR + "Unknown files for ${qt_platform}") +endif () + +# Verify that we know what directory will be extracted. +if (NOT qt_subdir) + message(FATAL_ERROR + "The extracted subdirectory is not set") +endif () + +# Build up the path to the file to download. +set(qt_url_path "${qt_platform}/desktop/qt5_${qt_version_nodot}/qt.qt5.${qt_version_nodot}.${qt_abi}") +set(qt_url_prefix "${qt_url_root}/${qt_url_path}") + +# Include the file containing the hashes of the files that matter. +include("${CMAKE_CURRENT_LIST_DIR}/download_qt_hashes.cmake") + +# Download and extract each file. +foreach (qt_file IN LISTS qt_files) + # Ensure we have a hash to verify. + if (NOT DEFINED "${qt_file}_hash") + message(FATAL_ERROR + "Unknown hash for ${qt_file}") + endif () + + # Download the file. + file(DOWNLOAD + "${qt_url_prefix}/${qt_file}" + ".gitlab/${qt_file}" + STATUS download_status + EXPECTED_HASH "SHA256=${${qt_file}_hash}") + + # Check the download status. + list(GET download_status 0 res) + if (res) + list(GET download_status 1 err) + message(FATAL_ERROR + "Failed to download ${qt_file}: ${err}") + endif () + + # Extract the file. + execute_process( + COMMAND + "${CMAKE_COMMAND}" + -E tar + xf "${qt_file}" + WORKING_DIRECTORY ".gitlab" + RESULT_VARIABLE res + ERROR_VARIABLE err + ERROR_STRIP_TRAILING_WHITESPACE) + if (res) + message(FATAL_ERROR + "Failed to extract ${qt_file}: ${err}") + endif () +endforeach () + +# The Windows tarballs have some unfortunate permissions in them that prevent +# deletion when `git clean -ffdx` tries to clean up the directory. +if (qt_platform STREQUAL "windows_x86") + # Fix permissions. + file(TO_NATIVE_PATH ".gitlab/${qt_subdir}/*.*" native_qt_dir) + execute_process( + # Remove any read-only flags that aren't affected by `icacls`. + COMMAND + attrib + -r # Remove readonly flag + "${native_qt_dir}" + /d # Treat as a directory + /s # Recursive + /l # Don't dereference symlinks + RESULT_VARIABLE res + ERROR_VARIABLE err + ERROR_STRIP_TRAILING_WHITESPACE) + if (res) + message(FATAL_ERROR + "Failed to fix remove read-only flags in ${qt_file}: ${err}") + endif () +endif () + +# Move to a predictable prefix. +file(RENAME + ".gitlab/${qt_subdir}" + ".gitlab/qt") diff --git a/.gitlab/ci/download_qt_hashes.cmake b/.gitlab/ci/download_qt_hashes.cmake new file mode 100644 index 0000000..32536ed --- /dev/null +++ b/.gitlab/ci/download_qt_hashes.cmake @@ -0,0 +1,9 @@ +# Lines can be generated by doing: +# +# sha256sum $files | awk '{ print "set(\"" $2 "_hash\" " $1 ")" }' >> $thisfile + +set("5.15.0-0-202002260536qtbase-Windows-Windows_10-MSVC2017-Windows-Windows_10-X86_64.7z_hash" c041596be8f7a16c7be9ea6757c14766ff3200ab6d56f7db8f865dbfe039fe20) +set("5.15.0-0-202002260536qtwinextras-Windows-Windows_10-MSVC2017-Windows-Windows_10-X86_64.7z_hash" 10796128fac54f146767e33f6872975ba238858547de7a9650ec4cd9581fe71a) + +set("5.15.0-0-202005150700qtbase-Windows-Windows_10-MSVC2015-Windows-Windows_10-X86_64.7z_hash" 0c2653c5eca256f59c0b48b537cd633b05560e4241c0226856d2ae22ab066df4) +set("5.15.0-0-202005150700qtwinextras-Windows-Windows_10-MSVC2015-Windows-Windows_10-X86_64.7z_hash" 4bca3a8d8c7611e211a82d86b3396f8a622abe7859d5052452414642ec191844) -- cgit v0.12 From 881c0b86ddeac5e9aaa5b4e438821f5e33398f0b Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Wed, 10 Jun 2020 12:09:41 -0400 Subject: gitlab-ci: test QtDialog on Windows --- .gitlab-ci.yml | 2 ++ .gitlab/ci/configure_windows_common.cmake | 4 ++++ .gitlab/ci/configure_windows_vs2019_x64_ninja.cmake | 2 +- 3 files changed, 7 insertions(+), 1 deletion(-) create mode 100644 .gitlab/ci/configure_windows_common.cmake diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 3447964..697ffb0 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -217,6 +217,8 @@ - Set-Item -Force -Path "env:PATH" -Value "$pwdpath\.gitlab;$pwdpath\.gitlab\cmake\bin;$env:PATH" - cmake --version - ninja --version + - cmake -P .gitlab/ci/download_qt.cmake + - Set-Item -Force -Path "env:PATH" -Value "$pwdpath\.gitlab\qt\bin;$env:PATH" .cmake_build_unix: &cmake_build_unix stage: build diff --git a/.gitlab/ci/configure_windows_common.cmake b/.gitlab/ci/configure_windows_common.cmake new file mode 100644 index 0000000..45250ac --- /dev/null +++ b/.gitlab/ci/configure_windows_common.cmake @@ -0,0 +1,4 @@ +set(BUILD_QtDialog ON CACHE BOOL "") +set(CMAKE_PREFIX_PATH "$ENV{CI_PROJECT_DIR}/.gitlab/qt" CACHE STRING "") + +include("${CMAKE_CURRENT_LIST_DIR}/configure_common.cmake") diff --git a/.gitlab/ci/configure_windows_vs2019_x64_ninja.cmake b/.gitlab/ci/configure_windows_vs2019_x64_ninja.cmake index e2f00dd..719c93c 100644 --- a/.gitlab/ci/configure_windows_vs2019_x64_ninja.cmake +++ b/.gitlab/ci/configure_windows_vs2019_x64_ninja.cmake @@ -1,3 +1,3 @@ set(CMake_TEST_WIX_NO_VERIFY "ON" CACHE BOOL "") -include("${CMAKE_CURRENT_LIST_DIR}/configure_common.cmake") +include("${CMAKE_CURRENT_LIST_DIR}/configure_windows_common.cmake") -- cgit v0.12 From 1a995439e56445b22a2f8d71ab15b67891e74f10 Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Wed, 10 Jun 2020 12:15:57 -0400 Subject: ci: add download information for Qt on macOS --- .gitlab/ci/download_qt.cmake | 10 ++++++++++ .gitlab/ci/download_qt_hashes.cmake | 2 ++ 2 files changed, 12 insertions(+) diff --git a/.gitlab/ci/download_qt.cmake b/.gitlab/ci/download_qt.cmake index 2c5854d..c392b1c 100644 --- a/.gitlab/ci/download_qt.cmake +++ b/.gitlab/ci/download_qt.cmake @@ -50,6 +50,16 @@ if (qt_platform STREQUAL "windows_x86") endforeach () set(qt_subdir "${qt_version}/msvc${msvc_year}_64") +elseif (qt_platform STREQUAL "mac_x64") + set(qt_build_stamp "202005140805") + set(qt_file_name_prefix "${qt_version}-0-${qt_build_stamp}") + + foreach (qt_component IN ITEMS qtbase) + list(APPEND qt_files + "${qt_file_name_prefix}${qt_component}-MacOS-MacOS_10_13-Clang-MacOS-MacOS_10_13-X86_64.7z") + endforeach () + + set(qt_subdir "${qt_version}/clang_64") else () message(FATAL_ERROR "Unknown files for ${qt_platform}") diff --git a/.gitlab/ci/download_qt_hashes.cmake b/.gitlab/ci/download_qt_hashes.cmake index 32536ed..59cb597 100644 --- a/.gitlab/ci/download_qt_hashes.cmake +++ b/.gitlab/ci/download_qt_hashes.cmake @@ -7,3 +7,5 @@ set("5.15.0-0-202002260536qtwinextras-Windows-Windows_10-MSVC2017-Windows-Window set("5.15.0-0-202005150700qtbase-Windows-Windows_10-MSVC2015-Windows-Windows_10-X86_64.7z_hash" 0c2653c5eca256f59c0b48b537cd633b05560e4241c0226856d2ae22ab066df4) set("5.15.0-0-202005150700qtwinextras-Windows-Windows_10-MSVC2015-Windows-Windows_10-X86_64.7z_hash" 4bca3a8d8c7611e211a82d86b3396f8a622abe7859d5052452414642ec191844) + +set("5.15.0-0-202005140805qtbase-MacOS-MacOS_10_13-Clang-MacOS-MacOS_10_13-X86_64.7z_hash" 04d867c81d2431f288c42c9752642759460b9468477de349368dcc8de0c8ddc4) -- cgit v0.12 From 973fc5602066ba6e57a282581f3137dd9bfdd7a8 Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Wed, 10 Jun 2020 12:16:14 -0400 Subject: gitlab-ci: test QtDialog on macOS --- .gitlab-ci.yml | 3 +++ .gitlab/ci/configure_macos_common.cmake | 2 ++ 2 files changed, 5 insertions(+) diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 697ffb0..c9f94f0 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -209,6 +209,9 @@ - export PATH=$PWD/.gitlab:$PWD/.gitlab/cmake/bin:$PATH - cmake --version - ninja --version + # Download Qt on macOS + - "[ \"$( uname -s )\" = \"Darwin\" ] && cmake -P .gitlab/ci/download_qt.cmake" + - "[ \"$( uname -s )\" = \"Darwin\" ] && export CMAKE_PREFIX_PATH=$PWD/.gitlab/qt" .before_script_windows: &before_script_windows - Invoke-Expression -Command .gitlab/ci/cmake.ps1 diff --git a/.gitlab/ci/configure_macos_common.cmake b/.gitlab/ci/configure_macos_common.cmake index 4b86d21..3589475 100644 --- a/.gitlab/ci/configure_macos_common.cmake +++ b/.gitlab/ci/configure_macos_common.cmake @@ -6,4 +6,6 @@ set(Java_JAVA_EXECUTABLE "" CACHE FILEPATH "") set(Java_JAVAC_EXECUTABLE "" CACHE FILEPATH "") set(Java_JAR_EXECUTABLE "" CACHE FILEPATH "") +set(BUILD_QtDialog ON CACHE BOOL "") + include("${CMAKE_CURRENT_LIST_DIR}/configure_common.cmake") -- cgit v0.12 From d7679f642762c4ea5a8e0839bbf990eb179a648a Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Wed, 10 Jun 2020 16:14:46 -0400 Subject: QCMakeCacheView: use non-deprecated List and Set constructions --- Source/QtDialog/QCMakeCacheView.cxx | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/Source/QtDialog/QCMakeCacheView.cxx b/Source/QtDialog/QCMakeCacheView.cxx index 40cc89c..541d3e9 100644 --- a/Source/QtDialog/QCMakeCacheView.cxx +++ b/Source/QtDialog/QCMakeCacheView.cxx @@ -217,14 +217,27 @@ void QCMakeCacheModel::setProperties(const QCMakePropertyList& props) QSet newProps2; if (this->ShowNewProperties) { +#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) newProps = props.toSet(); +#else + newProps = QSet(props.begin(), props.end()); +#endif newProps2 = newProps; +#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) QSet oldProps = this->properties().toSet(); +#else + QSet oldProps = + QSet(this->properties().begin(), this->properties().end()); +#endif oldProps.intersect(newProps); newProps.subtract(oldProps); newProps2.subtract(newProps); } else { +#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) newProps2 = props.toSet(); +#else + newProps2 = QSet(props.begin(), props.end()); +#endif } bool b = this->blockSignals(true); @@ -233,8 +246,8 @@ void QCMakeCacheModel::setProperties(const QCMakePropertyList& props) this->NewPropertyCount = newProps.size(); if (View == FlatView) { - QCMakePropertyList newP = newProps.toList(); - QCMakePropertyList newP2 = newProps2.toList(); + QCMakePropertyList newP = newProps.values(); + QCMakePropertyList newP2 = newProps2.values(); #if QT_VERSION >= QT_VERSION_CHECK(5, 9, 0) std::sort(newP.begin(), newP.end()); std::sort(newP2.begin(), newP2.end()); -- cgit v0.12