2020-12-26 14:12:05 -08:00
|
|
|
// Copyright (c) FIRST and other WPILib contributors.
|
|
|
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
|
|
|
// the WPILib BSD license file in the root directory of this project.
|
2019-08-25 23:55:59 -04:00
|
|
|
|
|
|
|
|
#include "frc2/command/SequentialCommandGroup.h"
|
|
|
|
|
|
2022-12-16 04:28:52 +02:00
|
|
|
#include <wpi/sendable/SendableBuilder.h>
|
|
|
|
|
|
2019-08-25 23:55:59 -04:00
|
|
|
using namespace frc2;
|
|
|
|
|
|
|
|
|
|
SequentialCommandGroup::SequentialCommandGroup(
|
|
|
|
|
std::vector<std::unique_ptr<Command>>&& commands) {
|
|
|
|
|
AddCommands(std::move(commands));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SequentialCommandGroup::Initialize() {
|
|
|
|
|
m_currentCommandIndex = 0;
|
|
|
|
|
|
|
|
|
|
if (!m_commands.empty()) {
|
|
|
|
|
m_commands[0]->Initialize();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SequentialCommandGroup::Execute() {
|
2020-12-28 12:58:06 -08:00
|
|
|
if (m_commands.empty()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2019-08-25 23:55:59 -04:00
|
|
|
|
|
|
|
|
auto& currentCommand = m_commands[m_currentCommandIndex];
|
|
|
|
|
|
|
|
|
|
currentCommand->Execute();
|
|
|
|
|
if (currentCommand->IsFinished()) {
|
|
|
|
|
currentCommand->End(false);
|
|
|
|
|
m_currentCommandIndex++;
|
|
|
|
|
if (m_currentCommandIndex < m_commands.size()) {
|
|
|
|
|
m_commands[m_currentCommandIndex]->Initialize();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void SequentialCommandGroup::End(bool interrupted) {
|
2019-10-18 07:55:14 -07:00
|
|
|
if (interrupted && !m_commands.empty() &&
|
|
|
|
|
m_currentCommandIndex != invalid_index &&
|
|
|
|
|
m_currentCommandIndex < m_commands.size()) {
|
2019-08-25 23:55:59 -04:00
|
|
|
m_commands[m_currentCommandIndex]->End(interrupted);
|
|
|
|
|
}
|
|
|
|
|
m_currentCommandIndex = invalid_index;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool SequentialCommandGroup::IsFinished() {
|
|
|
|
|
return m_currentCommandIndex == m_commands.size();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool SequentialCommandGroup::RunsWhenDisabled() const {
|
|
|
|
|
return m_runWhenDisabled;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-28 02:23:56 +02:00
|
|
|
Command::InterruptionBehavior SequentialCommandGroup::GetInterruptionBehavior()
|
|
|
|
|
const {
|
|
|
|
|
return m_interruptBehavior;
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-25 23:55:59 -04:00
|
|
|
void SequentialCommandGroup::AddCommands(
|
|
|
|
|
std::vector<std::unique_ptr<Command>>&& commands) {
|
2022-12-07 07:13:31 +02:00
|
|
|
CommandScheduler::GetInstance().RequireUngrouped(commands);
|
2019-08-25 23:55:59 -04:00
|
|
|
|
|
|
|
|
if (m_currentCommandIndex != invalid_index) {
|
2022-10-19 10:49:27 -07:00
|
|
|
throw FRC_MakeError(frc::err::CommandIllegalUse,
|
2021-04-18 20:35:29 -07:00
|
|
|
"Commands cannot be added to a CommandGroup "
|
|
|
|
|
"while the group is running");
|
2019-08-25 23:55:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (auto&& command : commands) {
|
2022-12-07 07:13:31 +02:00
|
|
|
command->SetComposed(true);
|
2019-08-25 23:55:59 -04:00
|
|
|
AddRequirements(command->GetRequirements());
|
|
|
|
|
m_runWhenDisabled &= command->RunsWhenDisabled();
|
2022-11-28 02:23:56 +02:00
|
|
|
if (command->GetInterruptionBehavior() ==
|
|
|
|
|
Command::InterruptionBehavior::kCancelSelf) {
|
|
|
|
|
m_interruptBehavior = Command::InterruptionBehavior::kCancelSelf;
|
|
|
|
|
}
|
2019-08-25 23:55:59 -04:00
|
|
|
m_commands.emplace_back(std::move(command));
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-12-16 04:28:52 +02:00
|
|
|
|
|
|
|
|
void SequentialCommandGroup::InitSendable(wpi::SendableBuilder& builder) {
|
2023-07-14 01:12:01 -04:00
|
|
|
Command::InitSendable(builder);
|
2022-12-16 04:28:52 +02:00
|
|
|
builder.AddIntegerProperty(
|
|
|
|
|
"index", [this] { return m_currentCommandIndex; }, nullptr);
|
|
|
|
|
}
|