summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2011-01-10 15:46:15 (GMT)
committerBrad King <brad.king@kitware.com>2011-01-10 15:46:15 (GMT)
commit7ffe6d77da01674b1a67e518a83dab3b744d09b4 (patch)
tree91006806ca19006755f920f3a8fc97a3f9f87f8b
parent6754b26bf0bb69ad6d65249bf4122dbbda446922 (diff)
downloadCMake-7ffe6d77da01674b1a67e518a83dab3b744d09b4.zip
CMake-7ffe6d77da01674b1a67e518a83dab3b744d09b4.tar.gz
CMake-7ffe6d77da01674b1a67e518a83dab3b744d09b4.tar.bz2
Document reading LOCATION early as undefined (#11671)
Reading the LOCATION target property currently locks down the result and ignores any later changes to properties that affect it. This may or may not be expected and may or may not be the behavior in earlier versions of CMake. The property is documented as provided only for compatibility with CMake 2.4 and alternative interfaces are now available for all originally envisioned use cases. We want to discourage its use without outright deprecating it. Add documentation to explicitly state that reading the property before other properties are set is undefined.
-rw-r--r--Source/cmTarget.cxx12
1 files changed, 11 insertions, 1 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx
index 9a698c0..7617cca 100644
--- a/Source/cmTarget.cxx
+++ b/Source/cmTarget.cxx
@@ -517,7 +517,17 @@ void cmTarget::DefineProperties(cmake *cm)
"In CMake 2.6 and above add_custom_command automatically recognizes a "
"target name in its COMMAND and DEPENDS options and computes the "
"target location. "
- "Therefore this property is not needed for creating custom commands.");
+ "In CMake 2.8.4 and above add_custom_command recognizes generator "
+ "expressions to refer to target locations anywhere in the command. "
+ "Therefore this property is not needed for creating custom commands."
+ "\n"
+ "Do not read this property until after all other properties that can "
+ "affect the location of the target have been set. "
+ "These include properties whose names match "
+ "\"(IMPLIB_)?(PREFIX|SUFFIX)\" or "
+ "\"(RUNTIME|LIBRARY|ARCHIVE)_OUTPUT_(NAME|DIRECTORY)(_<CONFIG>)?\". "
+ "Failure to follow this rule is not diagnosed and leaves the location "
+ "of the target undefined.");
cm->DefineProperty
("LOCATION_<CONFIG>", cmProperty::TARGET,