From 02fce523a13c8e4cda0c95334b480bb87336ed1c Mon Sep 17 00:00:00 2001 From: Brad King Date: Tue, 29 Mar 2016 10:01:40 -0400 Subject: [PATCH 1/2] cmConditionEvaluator: Drop unnecessary path conversion In commit v3.4.0-rc2~1^2 (cmIfCommand: Issue CMP0054 warning with appropriate context, 2015-10-20) we added construction of a cmListFileContext with conversion of the calling file path. This code path runs on every condition (e.g. `if()`) and so the path conversion has a noticeable performance cost. Fortunately the only use of this context is for insertion into cmMakefile::CMP0054ReportedIds so we do not need to convert the path. Simply drop the conversion. --- Source/cmConditionEvaluator.cxx | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) diff --git a/Source/cmConditionEvaluator.cxx b/Source/cmConditionEvaluator.cxx index 6a0ebec2d..4bfe69748 100644 --- a/Source/cmConditionEvaluator.cxx +++ b/Source/cmConditionEvaluator.cxx @@ -105,7 +105,7 @@ bool cmConditionEvaluator::IsTrue( } cmListFileContext cmConditionEvaluator::GetConditionContext( - cmMakefile* mf, + cmMakefile*, const cmCommandContext& command, const std::string& filePath) { @@ -113,13 +113,6 @@ cmListFileContext cmConditionEvaluator::GetConditionContext( cmListFileContext::FromCommandContext( command, filePath); - - if(!mf->GetCMakeInstance()->GetIsInTryCompile()) - { - cmOutputConverter converter(mf->GetStateSnapshot()); - context.FilePath = converter.Convert(context.FilePath, - cmOutputConverter::HOME); - } return context; } From 2379b3ae3171db7277fd3cf126b5b0c298231b83 Mon Sep 17 00:00:00 2001 From: Brad King Date: Tue, 29 Mar 2016 10:01:55 -0400 Subject: [PATCH 2/2] cmConditionEvaluator: Remove GetConditionContext method All it does is call cmListFileContext::FromCommandContext, so move this to the call sites. --- Source/cmConditionEvaluator.cxx | 12 ------------ Source/cmConditionEvaluator.h | 3 --- Source/cmIfCommand.cxx | 8 ++++---- Source/cmWhileCommand.cxx | 4 ++-- 4 files changed, 6 insertions(+), 21 deletions(-) diff --git a/Source/cmConditionEvaluator.cxx b/Source/cmConditionEvaluator.cxx index 4bfe69748..5d06f40a4 100644 --- a/Source/cmConditionEvaluator.cxx +++ b/Source/cmConditionEvaluator.cxx @@ -104,18 +104,6 @@ bool cmConditionEvaluator::IsTrue( errorString, status, true); } -cmListFileContext cmConditionEvaluator::GetConditionContext( - cmMakefile*, - const cmCommandContext& command, - const std::string& filePath) -{ - cmListFileContext context = - cmListFileContext::FromCommandContext( - command, - filePath); - return context; -} - //========================================================================= const char* cmConditionEvaluator::GetDefinitionIfUnquoted( cmExpandedCommandArgument const& argument) const diff --git a/Source/cmConditionEvaluator.h b/Source/cmConditionEvaluator.h index 8600825d0..3ed512d12 100644 --- a/Source/cmConditionEvaluator.h +++ b/Source/cmConditionEvaluator.h @@ -33,9 +33,6 @@ public: std::string &errorString, cmake::MessageType &status); - static cmListFileContext GetConditionContext(cmMakefile* mf, - const cmCommandContext& command, std::string const& filePath); - private: // Filter the given variable definition based on policy CMP0054. const char* GetDefinitionIfUnquoted( diff --git a/Source/cmIfCommand.cxx b/Source/cmIfCommand.cxx index 5964ef1ee..9a07dded4 100644 --- a/Source/cmIfCommand.cxx +++ b/Source/cmIfCommand.cxx @@ -108,8 +108,8 @@ IsFunctionBlocked(const cmListFileFunction& lff, cmake::MessageType messType; cmListFileContext conditionContext = - cmConditionEvaluator::GetConditionContext( - &mf, this->Functions[c], + cmListFileContext::FromCommandContext( + this->Functions[c], this->GetStartingContext().FilePath); cmConditionEvaluator conditionEvaluator( @@ -210,8 +210,8 @@ bool cmIfCommand commandContext.Name = execContext.Name; cmConditionEvaluator conditionEvaluator( - *(this->Makefile), cmConditionEvaluator::GetConditionContext( - this->Makefile, commandContext, execContext.FilePath), + *(this->Makefile), cmListFileContext::FromCommandContext( + commandContext, execContext.FilePath), this->Makefile->GetBacktrace()); bool isTrue = conditionEvaluator.IsTrue( diff --git a/Source/cmWhileCommand.cxx b/Source/cmWhileCommand.cxx index 4b7afd87a..aabbe2715 100644 --- a/Source/cmWhileCommand.cxx +++ b/Source/cmWhileCommand.cxx @@ -56,8 +56,8 @@ IsFunctionBlocked(const cmListFileFunction& lff, cmMakefile &mf, commandContext.Name = execContext.Name; cmListFileContext conditionContext = - cmConditionEvaluator::GetConditionContext( - &mf, commandContext, + cmListFileContext::FromCommandContext( + commandContext, this->GetStartingContext().FilePath); cmConditionEvaluator conditionEvaluator(