mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 02:08:27 +08:00
@@ -76,6 +76,9 @@
|
||||
native build system to choose a compiler or SDK. See the
|
||||
:variable:`CMAKE_GENERATOR_PLATFORM` variable for details.
|
||||
|
||||
``--install-prefix <directory>``
|
||||
Specify the installation prefix, :variable:`CMAKE_INSTALL_PREFIX`.
|
||||
|
||||
``-Wno-dev``
|
||||
Suppress developer warnings.
|
||||
|
||||
|
5
Help/release/dev/cmake-install-prefix-command.rst
Normal file
5
Help/release/dev/cmake-install-prefix-command.rst
Normal file
@@ -0,0 +1,5 @@
|
||||
cmake-install-prefix-command
|
||||
----------------------------
|
||||
|
||||
* The :manual:`cmake(1)` command gained the ``--install-prefix <dir>``
|
||||
command line option to specify the location of the install prefix.
|
@@ -493,6 +493,16 @@ bool cmake::SetCacheArgs(const std::vector<std::string>& args)
|
||||
return true;
|
||||
};
|
||||
|
||||
auto PrefixLambda = [&](std::string const& path, cmake* state) -> bool {
|
||||
const std::string var = "CMAKE_INSTALL_PREFIX";
|
||||
cmStateEnums::CacheEntryType type = cmStateEnums::PATH;
|
||||
#ifndef CMAKE_BOOTSTRAP
|
||||
state->UnprocessedPresetVariables.erase(var);
|
||||
#endif
|
||||
state->ProcessCacheArg(var, path, type);
|
||||
return true;
|
||||
};
|
||||
|
||||
std::vector<CommandArgument> arguments = {
|
||||
CommandArgument{ "-D", "-D must be followed with VAR=VALUE.",
|
||||
CommandArgument::Values::One, DefineLambda },
|
||||
@@ -511,8 +521,12 @@ bool cmake::SetCacheArgs(const std::vector<std::string>& args)
|
||||
state->ReadListFile(args, path);
|
||||
return true;
|
||||
} },
|
||||
|
||||
CommandArgument{ "-P", "-P must be followed by a file name.",
|
||||
CommandArgument::Values::One, ScriptLambda },
|
||||
CommandArgument{ "--install-prefix",
|
||||
"No install directory specified for --install-prefix",
|
||||
CommandArgument::Values::One, PrefixLambda },
|
||||
CommandArgument{ "--find-package", CommandArgument::Values::Zero,
|
||||
[&](std::string const&, cmake*) -> bool {
|
||||
findPackageMode = true;
|
||||
@@ -815,6 +829,9 @@ void cmake::SetArgs(const std::vector<std::string>& args)
|
||||
CommandArgument::Values::One, PlatformLambda },
|
||||
CommandArgument{ "-T", "No toolset specified for -T",
|
||||
CommandArgument::Values::One, ToolsetLamda },
|
||||
CommandArgument{ "--install-prefix",
|
||||
"No install directory specified for --install-prefix",
|
||||
CommandArgument::Values::One, IgnoreAndTrueLambda },
|
||||
|
||||
CommandArgument{ "--check-build-system", CommandArgument::Values::Two,
|
||||
[](std::string const& value, cmake* state) -> bool {
|
||||
|
@@ -712,6 +712,8 @@ private:
|
||||
"Specify toolset name if supported by generator." }, \
|
||||
{ "-A <platform-name>", \
|
||||
"Specify platform name if supported by generator." }, \
|
||||
{ "--install-prefix <directory>", \
|
||||
"Specify install directory [CMAKE_INSTALL_PREFIX]." }, \
|
||||
{ "-Wdev", "Enable developer warnings." }, \
|
||||
{ "-Wno-dev", "Suppress developer warnings." }, \
|
||||
{ "-Werror=dev", "Make developer warnings errors." }, \
|
||||
|
@@ -41,7 +41,7 @@ set(TutorialStep5_install_dir ${install_dir})
|
||||
set(proj TutorialStep5-Local-TestAfterInstall)
|
||||
ExternalProject_Add(${proj}
|
||||
URL "${CMAKE_CURRENT_SOURCE_DIR}/Step5"
|
||||
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_ARGS --install-prefix=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_CACHE_DEFAULT_ARGS -DUSE_MYMATH:BOOL=OFF
|
||||
TEST_AFTER_INSTALL 1
|
||||
LOG_TEST 1
|
||||
@@ -51,7 +51,7 @@ set_property(TARGET ${proj} PROPERTY FOLDER "Local")
|
||||
set(proj TutorialStep5-Local-TestExcludeFromMainBefore)
|
||||
ExternalProject_Add(${proj}
|
||||
URL "${CMAKE_CURRENT_SOURCE_DIR}/Step5"
|
||||
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_ARGS --install-prefix=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_CACHE_DEFAULT_ARGS -DUSE_MYMATH:BOOL=OFF
|
||||
TEST_BEFORE_INSTALL 1
|
||||
TEST_EXCLUDE_FROM_MAIN 1
|
||||
@@ -63,7 +63,7 @@ set_property(TARGET ${proj} PROPERTY FOLDER "Local")
|
||||
set(proj TutorialStep5-Local-TestExcludeFromMainAfter)
|
||||
ExternalProject_Add(${proj}
|
||||
URL "${CMAKE_CURRENT_SOURCE_DIR}/Step5"
|
||||
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_ARGS --install-prefix=<INSTALL_DIR> -G ${CMAKE_GENERATOR} <SOURCE_DIR>
|
||||
CMAKE_CACHE_DEFAULT_ARGS -DUSE_MYMATH:BOOL=OFF
|
||||
TEST_AFTER_INSTALL 1
|
||||
TEST_EXCLUDE_FROM_MAIN 1
|
||||
|
@@ -6,6 +6,10 @@ set(RunCMake_TEST_OPTIONS "-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/NotDefa
|
||||
run_cmake(CMP0041-OLD)
|
||||
run_cmake(CMP0041-NEW)
|
||||
run_cmake(CMP0041-WARN)
|
||||
|
||||
# Protect tests from running inside the default install prefix.
|
||||
set(RunCMake_TEST_OPTIONS "--install-prefix ${RunCMake_BINARY_DIR}/NotDefaultPrefix")
|
||||
|
||||
run_cmake(CMP0041-tid-OLD)
|
||||
run_cmake(CMP0041-tid-NEW)
|
||||
run_cmake(CMP0041-tid-WARN)
|
||||
|
@@ -61,6 +61,9 @@ run_cmake_command(build-bad-dir
|
||||
run_cmake_command(build-bad-generator
|
||||
${CMAKE_COMMAND} --build ${RunCMake_SOURCE_DIR}/cache-bad-generator)
|
||||
|
||||
|
||||
run_cmake_command(install-prefix-no-arg ${CMAKE_COMMAND} -B DummyBuildDir --install-prefix)
|
||||
|
||||
run_cmake_command(install-no-dir
|
||||
${CMAKE_COMMAND} --install)
|
||||
run_cmake_command(install-bad-dir
|
||||
|
@@ -18,6 +18,9 @@ run_cmake(BinaryDirectoryInInterface)
|
||||
set(RunCMake_TEST_OPTIONS "-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/DirInInstallPrefix/prefix")
|
||||
run_cmake(DirInInstallPrefix)
|
||||
|
||||
set(RunCMake_TEST_OPTIONS "--install-prefix=${RunCMake_BINARY_DIR}/DirInInstallPrefix/prefix")
|
||||
run_cmake(DirInInstallPrefix)
|
||||
|
||||
configure_file(
|
||||
"${RunCMake_SOURCE_DIR}/CMakeLists.txt"
|
||||
"${RunCMake_BINARY_DIR}/copy/CMakeLists.txt"
|
||||
@@ -34,14 +37,13 @@ configure_file(
|
||||
COPYONLY
|
||||
)
|
||||
set(RunCMake_TEST_OPTIONS
|
||||
"-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/copy/SourceDirectoryInInterface/prefix"
|
||||
"--install-prefix=${RunCMake_BINARY_DIR}/copy/SourceDirectoryInInterface/prefix"
|
||||
"-DTEST_FILE=${RunCMake_BINARY_DIR}/copy/SourceDirectoryInInterface.cmake"
|
||||
)
|
||||
set(RunCMake_TEST_SOURCE_DIR "${RunCMake_BINARY_DIR}/copy")
|
||||
run_cmake(InstallInSrcDir)
|
||||
unset(RunCMake_TEST_SOURCE_DIR)
|
||||
|
||||
set(RunCMake_TEST_OPTIONS "-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/InstallInBinDir-build/prefix")
|
||||
set(RunCMake_TEST_OPTIONS
|
||||
"-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/InstallInBinDir-build/prefix"
|
||||
"-DTEST_FILE=${RunCMake_SOURCE_DIR}/BinaryDirectoryInInterface.cmake"
|
||||
@@ -77,7 +79,7 @@ foreach(policyStatus NEW OLD "")
|
||||
set(policySuffix -CMP0052-${policyStatus})
|
||||
endif()
|
||||
set(RunCMake_TEST_OPTIONS
|
||||
"-DCMAKE_INSTALL_PREFIX=${RunCMake_BINARY_DIR}/prefix" ${policyOption}
|
||||
"--install-prefix=${RunCMake_BINARY_DIR}/prefix" ${policyOption}
|
||||
"-DTEST_FILE=${RunCMake_SOURCE_DIR}/BinaryDirectoryInInterface.cmake"
|
||||
)
|
||||
# Set the RunCMake_TEST_SOURCE_DIR here to the copy too. This is needed to run
|
||||
|
Reference in New Issue
Block a user