mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-07-05 03:21:42 +00:00
[hal, wpilib] Add OpMode support (#7744)
User code: - OpModeRobot used as the robot base class - LinearOpMode and PeriodicOpMode are provided opmode base classes - In Java, annotations can be used to automatically register opmode classes Additional user code functionality: - OpMode (string) is available in addition to the overall auto/teleop/test robot mode - OpMode does not indicate enable (enable/disable is still separate) - The HAL API uses integer UIDs; these are exposed at the user API level as well for faster checks - User code creates opmodes on startup (these have name, category, description, etc). DS: - DS will present opmode selection lists for auto and teleop for match/practice. During a match, the DS will automatically activate the selected opmode in the corresponding match period. - For testing, an overall mode is selected (e.g. teleop/auto/test) and a single opmode is selected Future work: - Command framework support/integration - Python annotation support - Unit tests (needs race-free DS sim updates) - Porting of examples Co-authored-by: Joseph Eng <91924258+KangarooKoala@users.noreply.github.com>
This commit is contained in:
@@ -7,6 +7,9 @@
|
||||
#include <atomic>
|
||||
#include <thread>
|
||||
|
||||
#include "wpi/hal/DriverStationTypes.h"
|
||||
#include "wpi/util/Synchronization.h"
|
||||
|
||||
namespace wpi::internal {
|
||||
/**
|
||||
* For internal use only.
|
||||
@@ -15,8 +18,10 @@ class DriverStationModeThread {
|
||||
public:
|
||||
/**
|
||||
* For internal use only.
|
||||
*
|
||||
* @param word initial control word
|
||||
*/
|
||||
DriverStationModeThread();
|
||||
explicit DriverStationModeThread(wpi::hal::ControlWord word);
|
||||
|
||||
~DriverStationModeThread();
|
||||
|
||||
@@ -30,44 +35,17 @@ class DriverStationModeThread {
|
||||
* Only to be used to tell the Driver Station what code you claim to be
|
||||
* executing for diagnostic purposes only.
|
||||
*
|
||||
* @param entering If true, starting disabled code; if false, leaving disabled
|
||||
* code
|
||||
* @param word control word
|
||||
*/
|
||||
void InDisabled(bool entering);
|
||||
|
||||
/**
|
||||
* Only to be used to tell the Driver Station what code you claim to be
|
||||
* executing for diagnostic purposes only.
|
||||
*
|
||||
* @param entering If true, starting autonomous code; if false, leaving
|
||||
* autonomous code
|
||||
*/
|
||||
void InAutonomous(bool entering);
|
||||
|
||||
/**
|
||||
* Only to be used to tell the Driver Station what code you claim to be
|
||||
* executing for diagnostic purposes only.
|
||||
*
|
||||
* @param entering If true, starting teleop code; if false, leaving teleop
|
||||
* code
|
||||
*/
|
||||
void InTeleop(bool entering);
|
||||
|
||||
/**
|
||||
* Only to be used to tell the Driver Station what code you claim to be
|
||||
* executing for diagnostic purposes only.
|
||||
*
|
||||
* @param entering If true, starting test code; if false, leaving test code
|
||||
*/
|
||||
void InTest(bool entering);
|
||||
void InControl(wpi::hal::ControlWord word) {
|
||||
m_userControlWord = word.GetValue().value;
|
||||
}
|
||||
|
||||
private:
|
||||
std::atomic_bool m_keepAlive{false};
|
||||
wpi::util::Event m_event{false, false};
|
||||
std::thread m_thread;
|
||||
void Run();
|
||||
bool m_userInDisabled{false};
|
||||
bool m_userInAutonomous{false};
|
||||
bool m_userInTeleop{false};
|
||||
bool m_userInTest{false};
|
||||
std::atomic<int64_t> m_userControlWord;
|
||||
};
|
||||
} // namespace wpi::internal
|
||||
|
||||
Reference in New Issue
Block a user