summaryrefslogtreecommitdiffstats
path: root/Source/cmFunctionCommand.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2009-01-21 14:49:31 (GMT)
committerBrad King <brad.king@kitware.com>2009-01-21 14:49:31 (GMT)
commit919fdb7f2759d6001db475635b47a6911f700c0d (patch)
tree9d23be4a4723cdc25d117e03149903465ee54295 /Source/cmFunctionCommand.cxx
parent1dcc5b455829db89f0d931cd57c12e0e247c0f44 (diff)
downloadCMake-919fdb7f2759d6001db475635b47a6911f700c0d.zip
CMake-919fdb7f2759d6001db475635b47a6911f700c0d.tar.gz
CMake-919fdb7f2759d6001db475635b47a6911f700c0d.tar.bz2
ENH: Enforce logical blocks in functions/macros
This teaches function() and macro() to enforce matching logical blocks inside the recorded bodies. This makes the error message more specific.
Diffstat (limited to 'Source/cmFunctionCommand.cxx')
-rw-r--r--Source/cmFunctionCommand.cxx2
1 files changed, 2 insertions, 0 deletions
diff --git a/Source/cmFunctionCommand.cxx b/Source/cmFunctionCommand.cxx
index 04d8428..2b5223b 100644
--- a/Source/cmFunctionCommand.cxx
+++ b/Source/cmFunctionCommand.cxx
@@ -104,6 +104,7 @@ bool cmFunctionHelperCommand::InvokeInitialPass
}
// we push a scope on the makefile
+ cmMakefile::LexicalPushPop lexScope(this->Makefile);
cmMakefile::ScopePushPop varScope(this->Makefile);
static_cast<void>(varScope);
@@ -163,6 +164,7 @@ bool cmFunctionHelperCommand::InvokeInitialPass
{
// The error message should have already included the call stack
// so we do not need to report an error here.
+ lexScope.Quiet();
inStatus.SetNestedError(true);
return false;
}