From de203f736cab8d8f9666e56520ca1e53447d8837 Mon Sep 17 00:00:00 2001 From: Ken Martin Date: Tue, 1 May 2001 16:27:51 -0400 Subject: slight bug in If command I think --- Source/cmIfCommand.cxx | 27 +++++++++------------------ 1 file changed, 9 insertions(+), 18 deletions(-) diff --git a/Source/cmIfCommand.cxx b/Source/cmIfCommand.cxx index 37daba6..1425cbb 100644 --- a/Source/cmIfCommand.cxx +++ b/Source/cmIfCommand.cxx @@ -45,29 +45,20 @@ bool cmIfFunctionBlocker:: IsFunctionBlocked(const char *name, const std::vector &args, const cmMakefile &mf) const { - if (strcmp(name,"ELSE") && strcmp(name,"ENDIF")) + if (!strcmp(name,"ELSE") || !strcmp(name,"ENDIF")) { - return true; - } - if (m_Not && args.size() == 2) - { - if (strcmp(args[0].c_str(),"NOT")) - { - return true; - } - if (strcmp(args[1].c_str(),m_Define.c_str())) + if (m_Not && (args.size() == 2) && !strcmp(args[0].c_str(),"NOT") && + !strcmp(args[1].c_str(),m_Define.c_str())) { - return true; + return false; } - } - else - { - if (strcmp(args[0].c_str(),m_Define.c_str())) + if (!m_Not && (args.size() == 1) && + !strcmp(args[0].c_str(),m_Define.c_str())) { - return true; + return false; } } - return false; + return true; } bool cmIfFunctionBlocker:: @@ -85,7 +76,7 @@ bool cmIfCommand::Invoke(std::vector& args) return false; } - // check for the NOT vale + // check for the NOT value const char *def; if (args.size() == 2 && (args[0] == "NOT")) { -- cgit v0.12