From 638d265b339435c7f7af530f84a3e242500f75ce Mon Sep 17 00:00:00 2001 From: Jade Date: Fri, 10 Jan 2025 15:31:40 +0800 Subject: [PATCH] [commands] Add a warning to `schedule` docs (NFC) (#7073) Signed-off-by: Jade Turner --- .../first/wpilibj2/command/CommandScheduler.java | 6 ++++++ .../include/frc2/command/CommandScheduler.h | 16 ++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/wpilibNewCommands/src/main/java/edu/wpi/first/wpilibj2/command/CommandScheduler.java b/wpilibNewCommands/src/main/java/edu/wpi/first/wpilibj2/command/CommandScheduler.java index 0e80a74c613..15babf85bbf 100644 --- a/wpilibNewCommands/src/main/java/edu/wpi/first/wpilibj2/command/CommandScheduler.java +++ b/wpilibNewCommands/src/main/java/edu/wpi/first/wpilibj2/command/CommandScheduler.java @@ -180,6 +180,9 @@ private void initCommand(Command command, Set requirements) { * using those requirements have been scheduled as interruptible. If this is the case, they will * be interrupted and the command will be scheduled. * + *

WARNING: using this function directly can often lead to unexpected behavior and should be + * avoided. Instead Triggers should be used to schedule Commands. + * * @param command the command to schedule. If null, no-op. */ private void schedule(Command command) { @@ -230,6 +233,9 @@ private void schedule(Command command) { /** * Schedules multiple commands for execution. Does nothing for commands already scheduled. * + *

WARNING: using this function directly can often lead to unexpected behavior and should be + * avoided. Instead Triggers should be used to schedule Commands. + * * @param commands the commands to schedule. No-op on null. */ public void schedule(Command... commands) { diff --git a/wpilibNewCommands/src/main/native/include/frc2/command/CommandScheduler.h b/wpilibNewCommands/src/main/native/include/frc2/command/CommandScheduler.h index 2f43ff7bc2e..c45d3811555 100644 --- a/wpilibNewCommands/src/main/native/include/frc2/command/CommandScheduler.h +++ b/wpilibNewCommands/src/main/native/include/frc2/command/CommandScheduler.h @@ -88,6 +88,10 @@ class CommandScheduler final : public wpi::Sendable, * interruptible. If this is the case, they will be interrupted and the * command will be scheduled. * + * @warning Using this function directly can often lead to unexpected behavior + * and should be avoided. Instead Triggers should be used to schedule + * Commands. + * * @param command the command to schedule */ void Schedule(const CommandPtr& command); @@ -112,6 +116,10 @@ class CommandScheduler final : public wpi::Sendable, * * The pointer must remain valid through the entire lifecycle of the command. * + * @warning Using this function directly can often lead to unexpected behavior + * and should be avoided. Instead Triggers should be used to schedule + * Commands. + * * @param command the command to schedule */ void Schedule(Command* command); @@ -120,6 +128,10 @@ class CommandScheduler final : public wpi::Sendable, * Schedules multiple commands for execution. Does nothing for commands * already scheduled. * + * @warning Using this function directly can often lead to unexpected behavior + * and should be avoided. Instead Triggers should be used to schedule + * Commands. + * * @param commands the commands to schedule */ void Schedule(std::span commands); @@ -128,6 +140,10 @@ class CommandScheduler final : public wpi::Sendable, * Schedules multiple commands for execution. Does nothing for commands * already scheduled. * + * @warning Using this function directly can often lead to unexpected behavior + * and should be avoided. Instead Triggers should be used to schedule + * Commands. + * * @param commands the commands to schedule */ void Schedule(std::initializer_list commands);