Add policy CMP0029 to disallow subdir_depends
This commit is contained in:
parent
882c0f0b69
commit
9f64fbf5b5
|
@ -1,7 +1,9 @@
|
||||||
subdir_depends
|
subdir_depends
|
||||||
--------------
|
--------------
|
||||||
|
|
||||||
Deprecated. Does nothing.
|
Disallowed. See CMake Policy :policy:`CMP0029`.
|
||||||
|
|
||||||
|
Does nothing.
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
|
|
|
@ -58,3 +58,4 @@ All Policies
|
||||||
/policy/CMP0026
|
/policy/CMP0026
|
||||||
/policy/CMP0027
|
/policy/CMP0027
|
||||||
/policy/CMP0028
|
/policy/CMP0028
|
||||||
|
/policy/CMP0029
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
CMP0029
|
||||||
|
-------
|
||||||
|
|
||||||
|
The :command:`subdir_depends` command should not be called.
|
||||||
|
|
||||||
|
The implementation of this command has been empty since December 2001
|
||||||
|
but was kept in CMake for compatibility for a long time.
|
||||||
|
|
||||||
|
.. |disallowed_version| replace:: 3.0.0
|
||||||
|
.. include:: DISALLOWED_COMMAND.txt
|
|
@ -246,6 +246,11 @@ cmPolicies::cmPolicies()
|
||||||
CMP0028, "CMP0028",
|
CMP0028, "CMP0028",
|
||||||
"Double colon in target name means ALIAS or IMPORTED target.",
|
"Double colon in target name means ALIAS or IMPORTED target.",
|
||||||
3,0,0,0, cmPolicies::WARN);
|
3,0,0,0, cmPolicies::WARN);
|
||||||
|
|
||||||
|
this->DefinePolicy(
|
||||||
|
CMP0029, "CMP0029",
|
||||||
|
"The subdir_depends command should not be called.",
|
||||||
|
3,0,0,0, cmPolicies::WARN);
|
||||||
}
|
}
|
||||||
|
|
||||||
cmPolicies::~cmPolicies()
|
cmPolicies::~cmPolicies()
|
||||||
|
|
|
@ -80,6 +80,7 @@ public:
|
||||||
CMP0027, ///< Conditionally linked imported targets with missing include
|
CMP0027, ///< Conditionally linked imported targets with missing include
|
||||||
/// directories.
|
/// directories.
|
||||||
CMP0028, ///< Double colon in target name means ALIAS or IMPORTED target.
|
CMP0028, ///< Double colon in target name means ALIAS or IMPORTED target.
|
||||||
|
CMP0029, ///< Disallow command: subdir_depends
|
||||||
|
|
||||||
/** \brief Always the last entry.
|
/** \brief Always the last entry.
|
||||||
*
|
*
|
||||||
|
|
|
@ -11,10 +11,10 @@
|
||||||
============================================================================*/
|
============================================================================*/
|
||||||
#include "cmSubdirDependsCommand.h"
|
#include "cmSubdirDependsCommand.h"
|
||||||
|
|
||||||
// cmSubdirDependsCommand
|
|
||||||
bool cmSubdirDependsCommand::InitialPass(std::vector<std::string> const& ,
|
bool cmSubdirDependsCommand::InitialPass(std::vector<std::string> const& ,
|
||||||
cmExecutionStatus &)
|
cmExecutionStatus &)
|
||||||
{
|
{
|
||||||
|
this->Disallowed(cmPolicies::CMP0029,
|
||||||
|
"The subdir_depends command should not be called; see CMP0029.");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,45 +14,15 @@
|
||||||
|
|
||||||
#include "cmCommand.h"
|
#include "cmCommand.h"
|
||||||
|
|
||||||
/** \class cmSubdirDependsCommand
|
|
||||||
* \brief Legacy command. Do not use.
|
|
||||||
*
|
|
||||||
* cmSubdirDependsCommand has been left in CMake for compatability with
|
|
||||||
* projects already using it. Its functionality in supporting parallel
|
|
||||||
* builds is now automatic. The command does not do anything.
|
|
||||||
*/
|
|
||||||
class cmSubdirDependsCommand : public cmCommand
|
class cmSubdirDependsCommand : public cmCommand
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
virtual cmCommand* Clone() { return new cmSubdirDependsCommand; }
|
||||||
* This is a virtual constructor for the command.
|
|
||||||
*/
|
|
||||||
virtual cmCommand* Clone()
|
|
||||||
{
|
|
||||||
return new cmSubdirDependsCommand;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This is called when the command is first encountered in
|
|
||||||
* the CMakeLists.txt file.
|
|
||||||
*/
|
|
||||||
virtual bool InitialPass(std::vector<std::string> const& args,
|
virtual bool InitialPass(std::vector<std::string> const& args,
|
||||||
cmExecutionStatus &status);
|
cmExecutionStatus &status);
|
||||||
|
|
||||||
/**
|
|
||||||
* The name of the command as specified in CMakeList.txt.
|
|
||||||
*/
|
|
||||||
virtual const char* GetName() const { return "subdir_depends";}
|
virtual const char* GetName() const { return "subdir_depends";}
|
||||||
|
virtual bool IsDiscouraged() const { return true; }
|
||||||
/** This command is kept for compatibility with older CMake versions. */
|
|
||||||
virtual bool IsDiscouraged() const
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
cmTypeMacro(cmSubdirDependsCommand, cmCommand);
|
cmTypeMacro(cmSubdirDependsCommand, cmCommand);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
1
|
|
@ -0,0 +1,4 @@
|
||||||
|
CMake Error at CMP0029-NEW.cmake:2 \(subdir_depends\):
|
||||||
|
The subdir_depends command should not be called; see CMP0029.
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
CMakeLists.txt:3 \(include\)
|
|
@ -0,0 +1,2 @@
|
||||||
|
cmake_policy(SET CMP0029 NEW)
|
||||||
|
subdir_depends()
|
|
@ -0,0 +1 @@
|
||||||
|
^$
|
|
@ -0,0 +1,2 @@
|
||||||
|
cmake_policy(SET CMP0029 OLD)
|
||||||
|
subdir_depends()
|
|
@ -0,0 +1,7 @@
|
||||||
|
CMake Warning \(dev\) at CMP0029-WARN.cmake:1 \(subdir_depends\):
|
||||||
|
Policy CMP0029 is not set: The subdir_depends command should not be called.
|
||||||
|
Run "cmake --help-policy CMP0029" for policy details. Use the cmake_policy
|
||||||
|
command to set the policy and suppress this warning.
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
CMakeLists.txt:3 \(include\)
|
||||||
|
This warning is for project developers. Use -Wno-dev to suppress it.
|
|
@ -0,0 +1 @@
|
||||||
|
subdir_depends()
|
|
@ -1,6 +1,7 @@
|
||||||
include(RunCMake)
|
include(RunCMake)
|
||||||
|
|
||||||
foreach(p
|
foreach(p
|
||||||
|
CMP0029
|
||||||
)
|
)
|
||||||
run_cmake(${p}-WARN)
|
run_cmake(${p}-WARN)
|
||||||
run_cmake(${p}-OLD)
|
run_cmake(${p}-OLD)
|
||||||
|
|
Loading…
Reference in New Issue