// 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. #pragma once #ifdef _WIN32 #pragma warning(push) #pragma warning(disable : 4521) #endif #include #include #include #include "frc2/command/CommandGroupBase.h" #include "frc2/command/CommandHelper.h" namespace frc2 { /** * A CommandGroup that runs a set of commands in parallel, ending when the last * command ends. * *

As a rule, CommandGroups require the union of the requirements of their * component commands. * * This class is provided by the NewCommands VendorDep */ class ParallelCommandGroup : public CommandHelper { public: /** * Creates a new ParallelCommandGroup. The given commands will be executed * simultaneously. The command group will finish when the last command * finishes. If the CommandGroup is interrupted, only the commands that are * still running will be interrupted. * * @param commands the commands to include in this group. */ explicit ParallelCommandGroup( std::vector>&& commands); /** * Creates a new ParallelCommandGroup. The given commands will be executed * simultaneously. The command group will finish when the last command * finishes. If the CommandGroup is interrupted, only the commands that are * still running will be interrupted. * * @param commands the commands to include in this group. */ template >...>>> explicit ParallelCommandGroup(Types&&... commands) { AddCommands(std::forward(commands)...); } ParallelCommandGroup(ParallelCommandGroup&& other) = default; // No copy constructors for commandgroups ParallelCommandGroup(const ParallelCommandGroup&) = delete; // Prevent template expansion from emulating copy ctor ParallelCommandGroup(ParallelCommandGroup&) = delete; template >...>>> void AddCommands(Types&&... commands) { std::vector> foo; ((void)foo.emplace_back(std::make_unique>( std::forward(commands))), ...); AddCommands(std::move(foo)); } void Initialize() final; void Execute() final; void End(bool interrupted) final; bool IsFinished() final; bool RunsWhenDisabled() const override; Command::InterruptionBehavior GetInterruptionBehavior() const override; private: void AddCommands(std::vector>&& commands) final; std::vector, bool>> m_commands; bool m_runWhenDisabled{true}; Command::InterruptionBehavior m_interruptBehavior{ Command::InterruptionBehavior::kCancelIncoming}; bool isRunning = false; }; } // namespace frc2 #ifdef _WIN32 #pragma warning(pop) #endif