Skip to content

Commit

Permalink
[wpilib] Make HID classes implement Sendable
Browse files Browse the repository at this point in the history
Resolves #5191
  • Loading branch information
spacey-sooty committed Jun 29, 2024
1 parent 5e745bc commit 1fb3568
Show file tree
Hide file tree
Showing 15 changed files with 282 additions and 11 deletions.
15 changes: 15 additions & 0 deletions wpilibc/src/generate/main/native/cpp/hid.cpp.jinja
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@

#include <hal/FRCUsageReporting.h>

#include <wpi/sendable/SendableBuilder.h>

#include "frc/event/BooleanEvent.h"

using namespace frc;
Expand Down Expand Up @@ -90,3 +92,16 @@ bool {{ ConsoleName }}Controller::GetTouchpadReleased() {
return GetRawButtonReleased(Button::kTouchpad);
}
{% endif %}

void {{ ConsoleName }}Controller::InitSendable(wpi::SendableBuilder& builder) {
builder.SetSmartDashboardType("HID");
{%- for trigger in triggers %}
builder.AddDoubleProperty("{{ capitalize_first(trigger.name) }}", [=, this] { return Get{{ capitalize_first(trigger.name) }}Axis(); }, nullptr);
{%- endfor -%}
{% for stick in sticks %}
builder.AddDoubleProperty("{{ stick.NameParts|map("capitalize")|join }}", [=, this] { return Get{{ stick.NameParts|map("capitalize")|join }}(); }, nullptr);
{%- endfor -%}
{% for button in buttons %}
builder.AddBooleanProperty("{{ capitalize_first(button.name) }}", [=, this] { return Get{{ capitalize_first(button.name) }}Button(); }, nullptr);
{%- endfor %}
}
8 changes: 7 additions & 1 deletion wpilibc/src/generate/main/native/include/frc/hid.h.jinja
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@

#include "frc/GenericHID.h"

#include <wpi/sendable/Sendable.h>
#include <wpi/sendable/SendableHelper.h>

namespace frc {

/**
Expand All @@ -24,7 +27,8 @@ namespace frc {
* correct mapping, and only through the official NI DS. Sim is not guaranteed
* to have the same mapping, as well as any 3rd party controllers.
*/
class {{ ConsoleName }}Controller : public GenericHID {
class {{ ConsoleName }}Controller : public GenericHID, public wpi::Sendable,
public wpi::SendableHelper<{{ ConsoleName }}Controller> {
public:
/**
* Construct an instance of a controller.
Expand Down Expand Up @@ -203,6 +207,8 @@ class {{ ConsoleName }}Controller : public GenericHID {
static constexpr int k{{ capitalize_first(trigger.name) }} = {{ trigger.value }};
{%- endfor %}
};

void InitSendable(wpi::SendableBuilder& builder) override;
};

} // namespace frc
27 changes: 27 additions & 0 deletions wpilibc/src/generated/main/native/cpp/PS4Controller.cpp

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

27 changes: 27 additions & 0 deletions wpilibc/src/generated/main/native/cpp/PS5Controller.cpp

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

26 changes: 26 additions & 0 deletions wpilibc/src/generated/main/native/cpp/StadiaController.cpp

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

23 changes: 23 additions & 0 deletions wpilibc/src/generated/main/native/cpp/XboxController.cpp

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

20 changes: 18 additions & 2 deletions wpilibj/src/generate/hid.java.jinja
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ package edu.wpi.first.wpilibj;

{{ "// " if SkipReporting }}import edu.wpi.first.hal.FRCNetComm.tResourceType;
{{ "// " if SkipReporting }}import edu.wpi.first.hal.HAL;
import edu.wpi.first.util.sendable.Sendable;
import edu.wpi.first.util.sendable.SendableBuilder;
import edu.wpi.first.wpilibj.event.BooleanEvent;
import edu.wpi.first.wpilibj.event.EventLoop;

Expand All @@ -24,7 +26,7 @@ import edu.wpi.first.wpilibj.event.EventLoop;
* only through the official NI DS. Sim is not guaranteed to have the same mapping, as well as any
* 3rd party controllers.
*/
public class {{ ConsoleName }}Controller extends GenericHID {
public class {{ ConsoleName }}Controller extends GenericHID implements Sendable {
/** Represents a digital button on a {{ ConsoleName }}Controller. */
public enum Button {
{%- for button in buttons %}
Expand Down Expand Up @@ -285,5 +287,19 @@ public class {{ ConsoleName }}Controller extends GenericHID {
public boolean getTouchpadReleased() {
return getRawButtonReleased(Button.kTouchpad.value);
}
{% endif -%}
{% endif %}

@Override
public void initSendable(SendableBuilder builder) {
builder.setSmartDashboardType("HID");
{%- for trigger in triggers %}
builder.addDoubleProperty("{{ capitalize_first(trigger.name) }}", this::get{{ capitalize_first(trigger.name) }}Axis, null);
{%- endfor -%}
{% for stick in sticks %}
builder.addDoubleProperty("{{ stick.NameParts|map("capitalize")|join }}", this::get{{ stick.NameParts|map("capitalize")|join }}, null);
{%- endfor -%}
{% for button in buttons %}
builder.addBooleanProperty("{{ capitalize_first(button.name) }}", this::get{{ capitalize_first(button.name) }}Button, null);
{%- endfor %}
}
}
Loading

0 comments on commit 1fb3568

Please sign in to comment.