blob: 236cc0f99cd1067a60824ac2d96da3da4d5bb00d [file] [log] [blame]
Brian Silvermanda45b6c2014-12-28 11:36:50 -08001#include "frc971/wpilib/joystick_sender.h"
2
3#include "aos/common/messages/robot_state.q.h"
4#include "aos/linux_code/init.h"
5#include "aos/common/network/team_number.h"
6#include "aos/common/logging/queue_logging.h"
7
8#include "DriverStation.h"
Brian Silverman6f7d5fe2015-01-01 15:45:41 -08009#include "HAL/HAL.hpp"
Brian Silvermanda45b6c2014-12-28 11:36:50 -080010
11namespace frc971 {
12namespace wpilib {
13
14void JoystickSender::operator()() {
15 DriverStation *ds = DriverStation::GetInstance();
Brian Silvermanbd925f92014-12-31 14:28:06 -080016 ::aos::SetCurrentThreadName("DSReader");
Brian Silvermanda45b6c2014-12-28 11:36:50 -080017 uint16_t team_id = ::aos::network::GetTeamNumber();
18
Brian Silvermanbd925f92014-12-31 14:28:06 -080019 ::aos::SetCurrentThreadRealtimePriority(29);
20
Brian Silvermanda45b6c2014-12-28 11:36:50 -080021 while (run_) {
22 ds->WaitForData();
Brian Silverman699f0cb2015-02-05 19:45:01 -050023 auto new_state = ::aos::joystick_state.MakeMessage();
Brian Silvermanda45b6c2014-12-28 11:36:50 -080024
Brian Silverman6f7d5fe2015-01-01 15:45:41 -080025 HALControlWord control_word;
26 HALGetControlWord(&control_word);
27 new_state->test_mode = control_word.test;
28 new_state->fms_attached = control_word.fmsAttached;
29 new_state->enabled = control_word.enabled;
30 new_state->autonomous = control_word.autonomous;
Brian Silvermanda45b6c2014-12-28 11:36:50 -080031 new_state->team_id = team_id;
32 new_state->fake = false;
33
34 for (int i = 0; i < 4; ++i) {
Brian Silverman5e233772015-01-01 13:25:44 -080035 new_state->joysticks[i].buttons = ds->GetStickButtons(i);
Brian Silvermanda45b6c2014-12-28 11:36:50 -080036 for (int j = 0; j < 4; ++j) {
37 new_state->joysticks[i].axis[j] = ds->GetStickAxis(i, j);
38 }
Austin Schuhfee2e602015-03-08 18:26:05 -070039 new_state->joysticks[i].pov = ds->GetStickPOV(i, 0);
Brian Silvermanda45b6c2014-12-28 11:36:50 -080040 }
Brian Silverman699f0cb2015-02-05 19:45:01 -050041 LOG_STRUCT(DEBUG, "joystick_state", *new_state);
Brian Silvermanda45b6c2014-12-28 11:36:50 -080042
43 if (!new_state.Send()) {
Brian Silverman699f0cb2015-02-05 19:45:01 -050044 LOG(WARNING, "sending joystick_state failed\n");
Brian Silvermanda45b6c2014-12-28 11:36:50 -080045 }
46 }
47}
48
49} // namespace wpilib
50} // namespace frc971