Package edu.wpi.first.wpilibj2.command
Class ParallelRaceGroup
java.lang.Object
edu.wpi.first.wpilibj2.command.Command
edu.wpi.first.wpilibj2.command.ParallelRaceGroup
- All Implemented Interfaces:
Sendable
public class ParallelRaceGroup extends Command
A composition that runs a set of commands in parallel, ending when any one of the commands ends
and interrupting all the others.
The rules for command compositions apply: command instances that are passed to it cannot be added to any other composition or scheduled individually, and the composition requires all subsystems its components require.
This class is provided by the NewCommands VendorDep
-
Nested Class Summary
Nested classes/interfaces inherited from class edu.wpi.first.wpilibj2.command.Command
Command.InterruptionBehavior
-
Field Summary
-
Constructor Summary
Constructors Constructor Description ParallelRaceGroup(Command... commands)
Creates a new ParallelCommandRace. -
Method Summary
Modifier and Type Method Description void
addCommands(Command... commands)
Adds the given commands to the group.void
end(boolean interrupted)
The action to take when the command ends.void
execute()
The main body of a command.Command.InterruptionBehavior
getInterruptionBehavior()
How the command behaves when another command with a shared requirement is scheduled.void
initialize()
The initial subroutine of a command.boolean
isFinished()
Whether the command has finished.boolean
runsWhenDisabled()
Whether the given command should run when the robot is disabled.Methods inherited from class edu.wpi.first.wpilibj2.command.Command
addRequirements, alongWith, andThen, andThen, asProxy, beforeStarting, beforeStarting, cancel, deadlineWith, finallyDo, finallyDo, getName, getRequirements, getSubsystem, handleInterrupt, hasRequirement, ignoringDisable, initSendable, isScheduled, onlyIf, onlyWhile, raceWith, repeatedly, schedule, setName, setSubsystem, unless, until, withInterruptBehavior, withName, withTimeout
-
Constructor Details
-
ParallelRaceGroup
Creates a new ParallelCommandRace. The given commands will be executed simultaneously, and will "race to the finish" - the first command to finish ends the entire command, with all other commands being interrupted.- Parameters:
commands
- the commands to include in this composition.
-
-
Method Details
-
addCommands
Adds the given commands to the group.- Parameters:
commands
- Commands to add to the group.
-
initialize
Description copied from class:Command
The initial subroutine of a command. Called once when the command is initially scheduled.- Overrides:
initialize
in classCommand
-
execute
Description copied from class:Command
The main body of a command. Called repeatedly while the command is scheduled. -
end
Description copied from class:Command
The action to take when the command ends. Called when either the command finishes normally, or when it interrupted/canceled.Do not schedule commands here that share requirements with this command. Use
Command.andThen(Command...)
instead. -
isFinished
Description copied from class:Command
Whether the command has finished. Once a command finishes, the scheduler will call its end() method and un-schedule it.- Overrides:
isFinished
in classCommand
- Returns:
- whether the command has finished.
-
runsWhenDisabled
Description copied from class:Command
Whether the given command should run when the robot is disabled. Override to return true if the command should run when disabled.- Overrides:
runsWhenDisabled
in classCommand
- Returns:
- whether the command should run when the robot is disabled
-
getInterruptionBehavior
Description copied from class:Command
How the command behaves when another command with a shared requirement is scheduled.- Overrides:
getInterruptionBehavior
in classCommand
- Returns:
- a variant of
Command.InterruptionBehavior
, defaulting tokCancelSelf
.
-