WPILibC++  2020.3.2
frc::ConditionalCommand Class Referenceabstract

A ConditionalCommand is a Command that starts one of two commands. More...

#include <ConditionalCommand.h>

Inheritance diagram for frc::ConditionalCommand:
frc::Command frc::ErrorBase frc::Sendable frc::SendableHelper< Command >

Public Member Functions

 ConditionalCommand (Command *onTrue, Command *onFalse=nullptr)
 Creates a new ConditionalCommand with given onTrue and onFalse Commands. More...
 
 ConditionalCommand (const wpi::Twine &name, Command *onTrue, Command *onFalse=nullptr)
 Creates a new ConditionalCommand with given onTrue and onFalse Commands. More...
 
 ConditionalCommand (ConditionalCommand &&)=default
 
ConditionalCommandoperator= (ConditionalCommand &&)=default
 
- Public Member Functions inherited from frc::Command
 Command ()
 Creates a new command. More...
 
 Command (const wpi::Twine &name)
 Creates a new command with the given name and no timeout. More...
 
 Command (double timeout)
 Creates a new command with the given timeout and a default name. More...
 
 Command (Subsystem &subsystem)
 Creates a new command with the given timeout and a default name. More...
 
 Command (const wpi::Twine &name, double timeout)
 Creates a new command with the given name and timeout. More...
 
 Command (const wpi::Twine &name, Subsystem &subsystem)
 Creates a new command with the given name and timeout. More...
 
 Command (double timeout, Subsystem &subsystem)
 Creates a new command with the given name and timeout. More...
 
 Command (const wpi::Twine &name, double timeout, Subsystem &subsystem)
 Creates a new command with the given name and timeout. More...
 
 Command (Command &&)=default
 
Commandoperator= (Command &&)=default
 
double TimeSinceInitialized () const
 Returns the time since this command was initialized (in seconds). More...
 
void Requires (Subsystem *s)
 This method specifies that the given Subsystem is used by this command. More...
 
void Start ()
 Starts up the command. More...
 
bool Run ()
 The run method is used internally to actually run the commands. More...
 
void Cancel ()
 This will cancel the current command. More...
 
bool IsRunning () const
 Returns whether or not the command is running. More...
 
bool IsInitialized () const
 Returns whether or not the command has been initialized. More...
 
bool IsCompleted () const
 Returns whether or not the command has completed running. More...
 
bool IsCanceled () const
 Returns whether or not this has been canceled. More...
 
bool IsInterruptible () const
 Returns whether or not this command can be interrupted. More...
 
void SetInterruptible (bool interruptible)
 Sets whether or not this command can be interrupted. More...
 
bool DoesRequire (Subsystem *subsystem) const
 Checks if the command requires the given Subsystem. More...
 
const SubsystemSetGetRequirements () const
 Returns the requirements (as an std::set of Subsystem pointers) of this command. More...
 
CommandGroupGetGroup () const
 Returns the CommandGroup that this command is a part of. More...
 
void SetRunWhenDisabled (bool run)
 Sets whether or not this Command should run when the robot is disabled. More...
 
bool WillRunWhenDisabled () const
 Returns whether or not this Command will run when the robot is disabled, or if it will cancel itself. More...
 
int GetID () const
 Get the ID (sequence number) for this command. More...
 
std::string GetName () const
 Gets the name of this Command. More...
 
void SetName (const wpi::Twine &name)
 Sets the name of this Command. More...
 
std::string GetSubsystem () const
 Gets the subsystem name of this Command. More...
 
void SetSubsystem (const wpi::Twine &subsystem)
 Sets the subsystem name of this Command. More...
 
void InitSendable (SendableBuilder &builder) override
 Initializes this Sendable object. More...
 
- Public Member Functions inherited from frc::ErrorBase
 ErrorBase (const ErrorBase &)=default
 
ErrorBaseoperator= (const ErrorBase &)=default
 
 ErrorBase (ErrorBase &&)=default
 
ErrorBaseoperator= (ErrorBase &&)=default
 
virtual ErrorGetError ()
 Retrieve the current error. More...
 
virtual const ErrorGetError () const
 Retrieve the current error. More...
 
virtual void ClearError () const
 Clear the current error information associated with this sensor.
 
virtual void SetErrnoError (const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber) const
 Set error information associated with a C library call that set an error to the "errno" global variable. More...
 
virtual void SetImaqError (int success, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber) const
 Set the current error information associated from the nivision Imaq API. More...
 
virtual void SetError (Error::Code code, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber) const
 Set the current error information associated with this sensor. More...
 
virtual void SetErrorRange (Error::Code code, int32_t minRange, int32_t maxRange, int32_t requestedValue, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber) const
 Set the current error information associated with this sensor. More...
 
virtual void SetWPIError (const wpi::Twine &errorMessage, Error::Code code, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber) const
 Set the current error information associated with this sensor. More...
 
virtual void CloneError (const ErrorBase &rhs) const
 
virtual bool StatusIsFatal () const
 Check if the current error code represents a fatal error. More...
 
void ClearGlobalErrors ()
 Clear global errors.
 
- Public Member Functions inherited from frc::SendableHelper< Command >
 SendableHelper (const SendableHelper &rhs)=default
 
 SendableHelper (SendableHelper &&rhs)
 
SendableHelperoperator= (const SendableHelper &rhs)=default
 
SendableHelperoperator= (SendableHelper &&rhs)
 
std::string GetName () const
 Gets the name of this Sendable object. More...
 
void SetName (const wpi::Twine &name)
 Sets the name of this Sendable object. More...
 
void SetName (const wpi::Twine &subsystem, const wpi::Twine &name)
 Sets both the subsystem name and device name of this Sendable object. More...
 
std::string GetSubsystem () const
 Gets the subsystem name of this Sendable object. More...
 
void SetSubsystem (const wpi::Twine &subsystem)
 Sets the subsystem name of this Sendable object. More...
 

Protected Member Functions

virtual bool Condition ()=0
 The Condition to test to determine which Command to run. More...
 
void _Initialize () override
 
void _Cancel () override
 This works like Cancel(), except that it doesn't throw an exception if it is a part of a command group. More...
 
bool IsFinished () override
 Returns whether this command is finished. More...
 
void _Interrupted () override
 
- Protected Member Functions inherited from frc::Command
void SetTimeout (double timeout)
 Sets the timeout of this command. More...
 
bool IsTimedOut () const
 Returns whether or not the TimeSinceInitialized() method returns a number which is greater than or equal to the timeout for the command. More...
 
bool AssertUnlocked (const std::string &message)
 If changes are locked, then this will generate a CommandIllegalUse error. More...
 
void SetParent (CommandGroup *parent)
 Sets the parent of this command. More...
 
bool IsParented () const
 Returns whether the command has a parent. More...
 
void ClearRequirements ()
 Clears list of subsystem requirements. More...
 
virtual void Initialize ()
 The initialize method is called the first time this Command is run after being started.
 
virtual void Execute ()
 The execute method is called repeatedly until this Command either finishes or is canceled.
 
virtual void End ()
 Called when the command ended peacefully. More...
 
virtual void Interrupted ()
 Called when the command ends because somebody called Cancel() or another command shared the same requirements as this one, and booted it out. More...
 
virtual void _Execute ()
 
virtual void _End ()
 
- Protected Member Functions inherited from frc::SendableHelper< Command >
void SetName (const wpi::Twine &moduleType, int channel)
 Sets the name of the sensor with a channel number. More...
 
void SetName (const wpi::Twine &moduleType, int moduleNumber, int channel)
 Sets the name of the sensor with a module and channel number. More...
 
void AddChild (std::shared_ptr< Sendable > child)
 Add a child component. More...
 
void AddChild (void *child)
 Add a child component. More...
 

Additional Inherited Members

- Public Types inherited from frc::Command
using SubsystemSet = wpi::SmallPtrSetImpl< Subsystem * >
 
- Static Public Member Functions inherited from frc::ErrorBase
static void SetGlobalError (Error::Code code, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber)
 
static void SetGlobalWPIError (const wpi::Twine &errorMessage, const wpi::Twine &contextMessage, wpi::StringRef filename, wpi::StringRef function, int lineNumber)
 
static Error GetGlobalError ()
 Retrieve the last global error.
 
static std::vector< ErrorGetGlobalErrors ()
 Retrieve all global errors.
 
- Protected Attributes inherited from frc::ErrorBase
Error m_error
 

Detailed Description

A ConditionalCommand is a Command that starts one of two commands.

A ConditionalCommand uses the Condition method to determine whether it should run onTrue or onFalse.

A ConditionalCommand adds the proper Command to the Scheduler during Initialize() and then IsFinished() will return true once that Command has finished executing.

If no Command is specified for onFalse, the occurrence of that condition will be a no-op.

A ConditionalCommand will require the superset of subsystems of the onTrue and onFalse commands.

See also
Command
Scheduler

Constructor & Destructor Documentation

◆ ConditionalCommand() [1/2]

frc::ConditionalCommand::ConditionalCommand ( Command onTrue,
Command onFalse = nullptr 
)
explicit

Creates a new ConditionalCommand with given onTrue and onFalse Commands.

Parameters
onTrueThe Command to execute if Condition() returns true
onFalseThe Command to execute if Condition() returns false

◆ ConditionalCommand() [2/2]

frc::ConditionalCommand::ConditionalCommand ( const wpi::Twine name,
Command onTrue,
Command onFalse = nullptr 
)

Creates a new ConditionalCommand with given onTrue and onFalse Commands.

Parameters
nameThe name for this command group
onTrueThe Command to execute if Condition() returns true
onFalseThe Command to execute if Condition() returns false

Member Function Documentation

◆ _Cancel()

void frc::ConditionalCommand::_Cancel ( )
overrideprotectedvirtual

This works like Cancel(), except that it doesn't throw an exception if it is a part of a command group.

Should only be called by the parent command group.

Reimplemented from frc::Command.

◆ Condition()

virtual bool frc::ConditionalCommand::Condition ( )
protectedpure virtual

The Condition to test to determine which Command to run.

Returns
true if m_onTrue should be run or false if m_onFalse should be run.

◆ IsFinished()

bool frc::ConditionalCommand::IsFinished ( )
overrideprotectedvirtual

Returns whether this command is finished.

If it is, then the command will be removed and End() will be called.

It may be useful for a team to reference the IsTimedOut() method for time-sensitive commands.

Returning false will result in the command never ending automatically. It may still be cancelled manually or interrupted by another command. Returning true will result in the command executing once and finishing immediately. We recommend using InstantCommand for this.

Returns
Whether this command is finished.
See also
IsTimedOut()

Implements frc::Command.


The documentation for this class was generated from the following file: