mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-24 01:31:46 +00:00
WPILib Reorganization
This is a major restructuring of the WPILib repository to simply build procedures and remove the remnants of Maven from everything except the eclipse plugins. Gradle files have been largely simplified or rewritten, taking advantage of splitting up parts of the build into separate build files for ease of reading. The eclipse plugins are now in a separate project, as is ntcore. All dependencies are resolved via Maven dependencies, with the Jenkins-maintained WPILib repo. Project structures have also been simplified: we no longer have separate subprojects inside wpilibc and wpilibj. Where possible, these changes hav been done with git renames, to make sure we still have full history for all repositories. Other unrelated subprojects have also been broken out: OutlineViewer is now a separate project. Change-Id: Ib4e2a6e1a2f66427a14f16612b0e0d69ed661878
This commit is contained in:
99
wpilibc/simulation/src/RobotBase.cpp
Normal file
99
wpilibc/simulation/src/RobotBase.cpp
Normal file
@@ -0,0 +1,99 @@
|
||||
/*----------------------------------------------------------------------------*/
|
||||
/* Copyright (c) FIRST 2008. All Rights Reserved. */
|
||||
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||||
/* must be accompanied by the FIRST BSD license file in $(WIND_BASE)/WPILib. */
|
||||
/*----------------------------------------------------------------------------*/
|
||||
|
||||
#include "RobotBase.h"
|
||||
#include "RobotState.h"
|
||||
#include "Utility.h"
|
||||
|
||||
#include <cstring>
|
||||
|
||||
RobotBase* RobotBase::m_instance = nullptr;
|
||||
|
||||
void RobotBase::setInstance(RobotBase* robot)
|
||||
{
|
||||
wpi_assert(m_instance == nullptr);
|
||||
m_instance = robot;
|
||||
}
|
||||
|
||||
RobotBase &RobotBase::getInstance()
|
||||
{
|
||||
return *m_instance;
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructor for a generic robot program.
|
||||
* User code should be placed in the constuctor that runs before the Autonomous or Operator
|
||||
* Control period starts. The constructor will run to completion before Autonomous is entered.
|
||||
*
|
||||
* This must be used to ensure that the communications code starts. In the future it would be
|
||||
* nice to put this code into it's own task that loads on boot so ensure that it runs.
|
||||
*/
|
||||
RobotBase::RobotBase() : m_ds(DriverStation::GetInstance())
|
||||
{
|
||||
RobotState::SetImplementation(DriverStation::GetInstance());
|
||||
transport::SubscriberPtr time_pub = MainNode::Subscribe("time", &wpilib::internal::time_callback);
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the Robot is currently enabled.
|
||||
* @return True if the Robot is currently enabled by the field controls.
|
||||
*/
|
||||
bool RobotBase::IsEnabled() const
|
||||
{
|
||||
return m_ds.IsEnabled();
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the Robot is currently disabled.
|
||||
* @return True if the Robot is currently disabled by the field controls.
|
||||
*/
|
||||
bool RobotBase::IsDisabled() const
|
||||
{
|
||||
return m_ds.IsDisabled();
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the robot is currently in Autnomous mode.
|
||||
* @return True if the robot is currently operating Autonomously as determined by the field controls.
|
||||
*/
|
||||
bool RobotBase::IsAutonomous() const
|
||||
{
|
||||
return m_ds.IsAutonomous();
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the robot is currently in Operator Control mode.
|
||||
* @return True if the robot is currently operating in Tele-Op mode as determined by the field controls.
|
||||
*/
|
||||
bool RobotBase::IsOperatorControl() const
|
||||
{
|
||||
return m_ds.IsOperatorControl();
|
||||
}
|
||||
|
||||
/**
|
||||
* Determine if the robot is currently in Test mode.
|
||||
* @return True if the robot is currently running tests as determined by the field controls.
|
||||
*/
|
||||
bool RobotBase::IsTest() const
|
||||
{
|
||||
return m_ds.IsTest();
|
||||
}
|
||||
|
||||
/**
|
||||
* This class exists for the sole purpose of getting its destructor called when the module unloads.
|
||||
* Before the module is done unloading, we need to delete the RobotBase derived singleton. This should delete
|
||||
* the other remaining singletons that were registered. This should also stop all tasks that are using
|
||||
* the Task class.
|
||||
*/
|
||||
class RobotDeleter
|
||||
{
|
||||
public:
|
||||
~RobotDeleter()
|
||||
{
|
||||
delete &RobotBase::getInstance();
|
||||
}
|
||||
};
|
||||
static RobotDeleter g_robotDeleter;
|
||||
Reference in New Issue
Block a user