mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-20 00:51:42 +00:00
This is a clearer description for the functionality. Will deprecate withInterrupt next year.
56 lines
1.6 KiB
C++
56 lines
1.6 KiB
C++
// 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
|
|
|
|
#include <functional>
|
|
#include <initializer_list>
|
|
|
|
#include <wpi/span.h>
|
|
|
|
#include "frc2/command/CommandBase.h"
|
|
#include "frc2/command/CommandHelper.h"
|
|
|
|
namespace frc2 {
|
|
/**
|
|
* A command that runs a Runnable continuously. Has no end condition as-is;
|
|
* either subclass it or use Command.WithTimeout() or
|
|
* Command.Until() to give it one. If you only wish
|
|
* to execute a Runnable once, use InstantCommand.
|
|
*
|
|
* This class is provided by the NewCommands VendorDep
|
|
*/
|
|
class RunCommand : public CommandHelper<CommandBase, RunCommand> {
|
|
public:
|
|
/**
|
|
* Creates a new RunCommand. The Runnable will be run continuously until the
|
|
* command ends. Does not run when disabled.
|
|
*
|
|
* @param toRun the Runnable to run
|
|
* @param requirements the subsystems to require
|
|
*/
|
|
RunCommand(std::function<void()> toRun,
|
|
std::initializer_list<Subsystem*> requirements);
|
|
|
|
/**
|
|
* Creates a new RunCommand. The Runnable will be run continuously until the
|
|
* command ends. Does not run when disabled.
|
|
*
|
|
* @param toRun the Runnable to run
|
|
* @param requirements the subsystems to require
|
|
*/
|
|
explicit RunCommand(std::function<void()> toRun,
|
|
wpi::span<Subsystem* const> requirements = {});
|
|
|
|
RunCommand(RunCommand&& other) = default;
|
|
|
|
RunCommand(const RunCommand& other) = default;
|
|
|
|
void Execute() override;
|
|
|
|
protected:
|
|
std::function<void()> m_toRun;
|
|
};
|
|
} // namespace frc2
|