summaryrefslogtreecommitdiffstats
path: root/Source/cmMacroCommand.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/cmMacroCommand.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/cmMacroCommand.cxx')
-rw-r--r--Source/cmMacroCommand.cxx4
1 files changed, 4 insertions, 0 deletions
diff --git a/Source/cmMacroCommand.cxx b/Source/cmMacroCommand.cxx
index 0a7d0dc..9cc2653 100644
--- a/Source/cmMacroCommand.cxx
+++ b/Source/cmMacroCommand.cxx
@@ -107,6 +107,9 @@ bool cmMacroHelperCommand::InvokeInitialPass
return false;
}
+ // Enforce matching logical blocks inside the macro.
+ cmMakefile::LexicalPushPop lexScope(this->Makefile);
+
// set the value of argc
cmOStringStream argcDefStream;
argcDefStream << expandedArgs.size();
@@ -215,6 +218,7 @@ bool cmMacroHelperCommand::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;
}