summaryrefslogtreecommitdiffstats
path: root/bin
diff options
context:
space:
mode:
authorJoerg Bornemann <joerg.bornemann@qt.io>2020-10-29 11:34:32 +0100
committerJoerg Bornemann <joerg.bornemann@qt.io>2020-10-30 08:22:30 +0100
commit2a29426e3915ecc7fa5b4cbb06c7565c40ca2ec6 (patch)
tree95ca992725cbea7f42592992b486e53b119c3c02 /bin
parentde3bd644259b134d68414dcb8479f66f2f39fe70 (diff)
CMake: Fix argument passing for configure.bat / qt-configure-module.bat
Passing arguments with equal signs was broken for configure.bat and qt-configure-module.bat. An argument FOO=BAR was split at = and written as FOO BAR to config.opt, breaking every attempt of assigning CMake variables. We must not iterate over %* in batch files to avoid splitting arguments at equal signs. Instead, pass %* unmodified to a CMake script that writes config.opt. Fixes: QTBUG-88019 Change-Id: I7c743a206961d1ed168f2313f864905f6b345b49 Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Diffstat (limited to 'bin')
-rw-r--r--bin/qt-configure-module.bat.in13
1 files changed, 2 insertions, 11 deletions
diff --git a/bin/qt-configure-module.bat.in b/bin/qt-configure-module.bat.in
index a4858d412c..9d9243f5b8 100644
--- a/bin/qt-configure-module.bat.in
+++ b/bin/qt-configure-module.bat.in
@@ -17,18 +17,9 @@ if not exist "%module_root%\CMakeLists.txt" (
exit /b 1
)
-echo. > "config.opt"
-set first_iteration=indeed
-for %%a in (%*) do (
- if defined first_iteration (
- :: Drop the first argument, which is the module root.
- set first_iteration=
- ) else (
- echo %%a >> "config.opt"
- )
-)
-
set cmake_scripts_dir=%script_dir_path%\@__relative_path_to_cmake_scripts_dir@
+call "%script_dir_path%"\qt-cmake.bat -DSKIP_ARGS=1 -DOUT_FILE=config.opt ^
+ -P "%cmake_scripts_dir%\QtWriteArgsFile.cmake" %*
call "%script_dir_path%"\qt-cmake-private.bat -DOPTFILE=config.opt -DMODULE_ROOT="%module_root%" ^
-DCMAKE_COMMAND="%script_dir_path%\qt-cmake-private.bat" ^
-P "%cmake_scripts_dir%\QtProcessConfigureArgs.cmake"