Files
CMake/Source/cmMessageCommand.cxx
Stephen Kelly 23f87e8157 cmake: Remove force from IssueMessage API
The force parameter is ugly and makes the method harder to reason about
(issues the message ... but maybe it doesn't ... but then again you can
force it).  It is a violation of

 https://en.wikipedia.org/wiki/Interface_segregation_principle

and is the kind of thing described in a recent blog here:

 http://code.joejag.com/2016/anti-if-the-missing-patterns.html

 "Any time you see this you actually have two methods bundled into one.
  That boolean represents an opportunity to name a concept in your code."
2016-06-12 22:09:27 +02:00

81 lines
2.4 KiB
C++

/*============================================================================
CMake - Cross Platform Makefile Generator
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
Distributed under the OSI-approved BSD License (the "License");
see accompanying file Copyright.txt for details.
This software is distributed WITHOUT ANY WARRANTY; without even the
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the License for more information.
============================================================================*/
#include "cmMessageCommand.h"
// cmLibraryCommand
bool cmMessageCommand::InitialPass(std::vector<std::string> const& args,
cmExecutionStatus&)
{
if (args.size() < 1) {
this->SetError("called with incorrect number of arguments");
return false;
}
std::vector<std::string>::const_iterator i = args.begin();
cmake::MessageType type = cmake::MESSAGE;
bool status = false;
bool fatal = false;
cmake* cm = this->Makefile->GetCMakeInstance();
if (*i == "SEND_ERROR") {
type = cmake::FATAL_ERROR;
++i;
} else if (*i == "FATAL_ERROR") {
fatal = true;
type = cmake::FATAL_ERROR;
++i;
} else if (*i == "WARNING") {
type = cmake::WARNING;
++i;
} else if (*i == "AUTHOR_WARNING") {
if (cm->GetDevWarningsAsErrors(this->Makefile)) {
fatal = true;
type = cmake::AUTHOR_ERROR;
} else if (!cm->GetSuppressDevWarnings(this->Makefile)) {
type = cmake::AUTHOR_WARNING;
} else {
return true;
}
++i;
} else if (*i == "STATUS") {
status = true;
++i;
} else if (*i == "DEPRECATION") {
if (cm->GetDeprecatedWarningsAsErrors(this->Makefile)) {
fatal = true;
type = cmake::DEPRECATION_ERROR;
} else if (!cm->GetSuppressDeprecatedWarnings(this->Makefile)) {
type = cmake::DEPRECATION_WARNING;
} else {
return true;
}
++i;
}
std::string message = cmJoin(cmMakeRange(i, args.end()), std::string());
if (type != cmake::MESSAGE) {
// we've overriden the message type, above, so display it directly
cmake* cm = this->Makefile->GetCMakeInstance();
cm->DisplayMessage(type, message, this->Makefile->GetBacktrace());
} else {
if (status) {
this->Makefile->DisplayStatus(message.c_str(), -1);
} else {
cmSystemTools::Message(message.c_str());
}
}
if (fatal) {
cmSystemTools::SetFatalErrorOccured();
}
return true;
}