mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-24 01:31:46 +00:00
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
82 lines
2.4 KiB
C++
82 lines
2.4 KiB
C++
/*----------------------------------------------------------------------------*/
|
|
/* 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 "SafePWM.h"
|
|
|
|
/**
|
|
* Constructor for a SafePWM object taking a channel number.
|
|
* @param channel The PWM channel number 0-9 are on-board, 10-19 are on the MXP
|
|
* port
|
|
*/
|
|
SafePWM::SafePWM(uint32_t channel) : PWM(channel) {
|
|
m_safetyHelper = std::make_unique<MotorSafetyHelper>(this);
|
|
m_safetyHelper->SetSafetyEnabled(false);
|
|
}
|
|
|
|
/**
|
|
* Set the expiration time for the PWM object
|
|
* @param timeout The timeout (in seconds) for this motor object
|
|
*/
|
|
void SafePWM::SetExpiration(float timeout) {
|
|
m_safetyHelper->SetExpiration(timeout);
|
|
}
|
|
|
|
/**
|
|
* Return the expiration time for the PWM object.
|
|
* @returns The expiration time value.
|
|
*/
|
|
float SafePWM::GetExpiration() const { return m_safetyHelper->GetExpiration(); }
|
|
|
|
/**
|
|
* Check if the PWM object is currently alive or stopped due to a timeout.
|
|
* @returns a bool value that is true if the motor has NOT timed out and should
|
|
* still
|
|
* be running.
|
|
*/
|
|
bool SafePWM::IsAlive() const { return m_safetyHelper->IsAlive(); }
|
|
|
|
/**
|
|
* Stop the motor associated with this PWM object.
|
|
* This is called by the MotorSafetyHelper object when it has a timeout for this
|
|
* PWM and needs to
|
|
* stop it from running.
|
|
*/
|
|
void SafePWM::StopMotor() { SetRaw(kPwmDisabled); }
|
|
|
|
/**
|
|
* Enable/disable motor safety for this device
|
|
* Turn on and off the motor safety option for this PWM object.
|
|
* @param enabled True if motor safety is enforced for this object
|
|
*/
|
|
void SafePWM::SetSafetyEnabled(bool enabled) {
|
|
m_safetyHelper->SetSafetyEnabled(enabled);
|
|
}
|
|
|
|
/**
|
|
* Check if motor safety is enabled for this object
|
|
* @returns True if motor safety is enforced for this object
|
|
*/
|
|
bool SafePWM::IsSafetyEnabled() const {
|
|
return m_safetyHelper->IsSafetyEnabled();
|
|
}
|
|
|
|
void SafePWM::GetDescription(std::ostringstream& desc) const {
|
|
desc << "PWM " << GetChannel();
|
|
}
|
|
|
|
/**
|
|
* Feed the MotorSafety timer when setting the speed.
|
|
* This method is called by the subclass motor whenever it updates its speed,
|
|
* thereby reseting
|
|
* the timeout value.
|
|
* @param speed Value to pass to the PWM class
|
|
*/
|
|
void SafePWM::SetSpeed(float speed) {
|
|
PWM::SetSpeed(speed);
|
|
m_safetyHelper->Feed();
|
|
}
|