cmake/Source/cmBreakCommand.cxx

75 lines
2.1 KiB
C++
Raw Normal View History

2016-10-30 18:24:19 +01:00
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
file Copyright.txt or https://cmake.org/licensing for details. */
#include "cmBreakCommand.h"
2017-04-14 19:02:05 +02:00
#include <sstream>
2016-10-30 18:24:19 +01:00
#include "cmExecutionStatus.h"
2017-04-14 19:02:05 +02:00
#include "cmMakefile.h"
2019-11-11 23:01:05 +01:00
#include "cmMessageType.h"
2017-04-14 19:02:05 +02:00
#include "cmPolicies.h"
2016-10-30 18:24:19 +01:00
// cmBreakCommand
2020-02-01 23:06:01 +01:00
bool cmBreakCommand(std::vector<std::string> const& args,
cmExecutionStatus& status)
{
2020-02-01 23:06:01 +01:00
if (!status.GetMakefile().IsLoopBlock()) {
2015-04-27 22:25:09 +02:00
bool issueMessage = true;
std::ostringstream e;
2019-11-11 23:01:05 +01:00
MessageType messageType = MessageType::AUTHOR_WARNING;
2020-02-01 23:06:01 +01:00
switch (status.GetMakefile().GetPolicyStatus(cmPolicies::CMP0055)) {
2015-04-27 22:25:09 +02:00
case cmPolicies::WARN:
2015-08-17 11:37:30 +02:00
e << cmPolicies::GetPolicyWarning(cmPolicies::CMP0055) << "\n";
2015-04-27 22:25:09 +02:00
break;
case cmPolicies::OLD:
issueMessage = false;
break;
case cmPolicies::REQUIRED_ALWAYS:
case cmPolicies::REQUIRED_IF_USED:
case cmPolicies::NEW:
2019-11-11 23:01:05 +01:00
messageType = MessageType::FATAL_ERROR;
2015-04-27 22:25:09 +02:00
break;
2016-07-09 11:21:54 +02:00
}
2015-04-27 22:25:09 +02:00
2016-07-09 11:21:54 +02:00
if (issueMessage) {
2015-04-27 22:25:09 +02:00
e << "A BREAK command was found outside of a proper "
"FOREACH or WHILE loop scope.";
2020-02-01 23:06:01 +01:00
status.GetMakefile().IssueMessage(messageType, e.str());
2019-11-11 23:01:05 +01:00
if (messageType == MessageType::FATAL_ERROR) {
2015-04-27 22:25:09 +02:00
return false;
}
}
2016-07-09 11:21:54 +02:00
}
2015-04-27 22:25:09 +02:00
2017-07-20 19:35:53 +02:00
status.SetBreakInvoked();
2015-04-27 22:25:09 +02:00
2016-07-09 11:21:54 +02:00
if (!args.empty()) {
2015-04-27 22:25:09 +02:00
bool issueMessage = true;
std::ostringstream e;
2019-11-11 23:01:05 +01:00
MessageType messageType = MessageType::AUTHOR_WARNING;
2020-02-01 23:06:01 +01:00
switch (status.GetMakefile().GetPolicyStatus(cmPolicies::CMP0055)) {
2015-04-27 22:25:09 +02:00
case cmPolicies::WARN:
2015-08-17 11:37:30 +02:00
e << cmPolicies::GetPolicyWarning(cmPolicies::CMP0055) << "\n";
2015-04-27 22:25:09 +02:00
break;
case cmPolicies::OLD:
issueMessage = false;
break;
case cmPolicies::REQUIRED_ALWAYS:
case cmPolicies::REQUIRED_IF_USED:
case cmPolicies::NEW:
2019-11-11 23:01:05 +01:00
messageType = MessageType::FATAL_ERROR;
2015-04-27 22:25:09 +02:00
break;
2016-07-09 11:21:54 +02:00
}
2015-04-27 22:25:09 +02:00
2016-07-09 11:21:54 +02:00
if (issueMessage) {
2015-04-27 22:25:09 +02:00
e << "The BREAK command does not accept any arguments.";
2020-02-01 23:06:01 +01:00
status.GetMakefile().IssueMessage(messageType, e.str());
2019-11-11 23:01:05 +01:00
if (messageType == MessageType::FATAL_ERROR) {
2015-04-27 22:25:09 +02:00
return false;
}
}
2016-07-09 11:21:54 +02:00
}
2015-04-27 22:25:09 +02:00
return true;
}