summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBill Hoffman <bill.hoffman@kitware.com>2010-04-13 13:21:31 (GMT)
committerBen Boeckel <ben.boeckel@kitware.com>2010-09-01 17:08:13 (GMT)
commit48b5b855934be341c02139c0bed88c35c1b40d8f (patch)
tree932548a1470f02f2949e3c26ff3e95f5c12f2284 /Source
parentcd626ea66ed114736ddf5d6a4c989ef6c9b8d248 (diff)
downloadCMake-48b5b855934be341c02139c0bed88c35c1b40d8f.zip
CMake-48b5b855934be341c02139c0bed88c35c1b40d8f.tar.gz
CMake-48b5b855934be341c02139c0bed88c35c1b40d8f.tar.bz2
Add a warning when variables are used uninitialized.
Diffstat (limited to 'Source')
-rw-r--r--Source/cmCommandArgumentParserHelper.cxx7
-rw-r--r--Source/cmMakefile.cxx11
-rw-r--r--Source/cmMakefile.h4
3 files changed, 21 insertions, 1 deletions
diff --git a/Source/cmCommandArgumentParserHelper.cxx b/Source/cmCommandArgumentParserHelper.cxx
index 234c37e..027a2ba 100644
--- a/Source/cmCommandArgumentParserHelper.cxx
+++ b/Source/cmCommandArgumentParserHelper.cxx
@@ -119,10 +119,15 @@ char* cmCommandArgumentParserHelper::ExpandVariable(const char* var)
cmOStringStream ostr;
ostr << this->FileLine;
return this->AddString(ostr.str().c_str());
- }
+ }
const char* value = this->Makefile->GetDefinition(var);
if(!value && !this->RemoveEmpty)
{
+ if(!this->Makefile->VariableCleared(var))
+ {
+ std::cerr << this->FileName << ":" << this->FileLine << ":" <<
+ " warning: uninitialized variable \'" << var << "\'\n";
+ }
return 0;
}
if (this->EscapeQuotes && value)
diff --git a/Source/cmMakefile.cxx b/Source/cmMakefile.cxx
index 8eece6b..c56641c 100644
--- a/Source/cmMakefile.cxx
+++ b/Source/cmMakefile.cxx
@@ -43,6 +43,7 @@ class cmMakefile::Internals
{
public:
std::stack<cmDefinitions, std::list<cmDefinitions> > VarStack;
+ std::set<cmStdString> VarRemoved;
};
// default is not to be building executables
@@ -1694,9 +1695,19 @@ void cmMakefile::AddDefinition(const char* name, bool value)
#endif
}
+bool cmMakefile::VariableCleared(const char* var) const
+{
+ if(this->Internal->VarRemoved.find(var) != this->Internal->VarRemoved.end())
+ {
+ return true;
+ }
+ return false;
+}
+
void cmMakefile::RemoveDefinition(const char* name)
{
this->Internal->VarStack.top().Set(name, 0);
+ this->Internal->VarRemoved.insert(name);
#ifdef CMAKE_BUILD_WITH_CMAKE
cmVariableWatch* vv = this->GetVariableWatch();
if ( vv )
diff --git a/Source/cmMakefile.h b/Source/cmMakefile.h
index 4fae7ee..daeab83 100644
--- a/Source/cmMakefile.h
+++ b/Source/cmMakefile.h
@@ -61,6 +61,10 @@ public:
unsigned int GetCacheMajorVersion();
unsigned int GetCacheMinorVersion();
+ /* return true if a variable has been set with
+ set(foo )
+ */
+ bool VariableCleared(const char* ) const;
/** Return whether compatibility features needed for a version of
the cache or lower should be enabled. */
bool NeedCacheCompatibility(int major, int minor);