WPILibC++ 2023.4.3
SendableBuilderImpl.h
Go to the documentation of this file.
1// Copyright (c) FIRST and other WPILib contributors.
2// Open Source Software; you can modify and/or share it under the terms of
3// the WPILib BSD license file in the root directory of this project.
4
5#pragma once
6
7#include <functional>
8#include <memory>
9#include <span>
10#include <string>
11#include <string_view>
12#include <utility>
13#include <vector>
14
19#include <wpi/FunctionExtras.h>
20#include <wpi/SmallVector.h>
21
22namespace frc {
23
25 public:
27 ~SendableBuilderImpl() override = default;
28
31
32 /**
33 * Set the network table. Must be called prior to any Add* functions being
34 * called.
35 * @param table Network table
36 */
37 void SetTable(std::shared_ptr<nt::NetworkTable> table);
38
39 /**
40 * Get the network table.
41 * @return The network table
42 */
43 std::shared_ptr<nt::NetworkTable> GetTable() override;
44
45 /**
46 * Return whether this sendable has an associated table.
47 * @return True if it has a table, false if not.
48 */
49 bool IsPublished() const override;
50
51 /**
52 * Return whether this sendable should be treated as an actuator.
53 * @return True if actuator, false if not.
54 */
55 bool IsActuator() const;
56
57 /**
58 * Synchronize with network table values by calling the getters for all
59 * properties and setters when the network table value has changed.
60 */
61 void Update() override;
62
63 /**
64 * Hook setters for all properties.
65 */
67
68 /**
69 * Unhook setters for all properties.
70 */
72
73 /**
74 * Start LiveWindow mode by hooking the setters for all properties. Also
75 * calls the SafeState function if one was provided.
76 */
78
79 /**
80 * Stop LiveWindow mode by unhooking the setters for all properties. Also
81 * calls the SafeState function if one was provided.
82 */
84
85 /**
86 * Clear properties.
87 */
88 void ClearProperties() override;
89
91 void SetActuator(bool value) override;
92 void SetSafeState(std::function<void()> func) override;
93 void SetUpdateTable(wpi::unique_function<void()> func) override;
95
96 void AddBooleanProperty(std::string_view key, std::function<bool()> getter,
97 std::function<void(bool)> setter) override;
98
99 void AddIntegerProperty(std::string_view key, std::function<int64_t()> getter,
100 std::function<void(int64_t)> setter) override;
101
102 void AddFloatProperty(std::string_view key, std::function<float()> getter,
103 std::function<void(float)> setter) override;
104
105 void AddDoubleProperty(std::string_view key, std::function<double()> getter,
106 std::function<void(double)> setter) override;
107
109 std::function<std::string()> getter,
110 std::function<void(std::string_view)> setter) override;
111
113 std::string_view key, std::function<std::vector<int>()> getter,
114 std::function<void(std::span<const int>)> setter) override;
115
117 std::string_view key, std::function<std::vector<int64_t>()> getter,
118 std::function<void(std::span<const int64_t>)> setter) override;
119
121 std::string_view key, std::function<std::vector<float>()> getter,
122 std::function<void(std::span<const float>)> setter) override;
123
125 std::string_view key, std::function<std::vector<double>()> getter,
126 std::function<void(std::span<const double>)> setter) override;
127
129 std::string_view key, std::function<std::vector<std::string>()> getter,
130 std::function<void(std::span<const std::string>)> setter) override;
131
133 std::string_view key, std::string_view typeString,
134 std::function<std::vector<uint8_t>()> getter,
135 std::function<void(std::span<const uint8_t>)> setter) override;
136
139 std::function<std::string_view(wpi::SmallVectorImpl<char>& buf)> getter,
140 std::function<void(std::string_view)> setter) override;
141
144 std::function<std::span<const int>(wpi::SmallVectorImpl<int>& buf)>
145 getter,
146 std::function<void(std::span<const int>)> setter) override;
147
150 std::function<
151 std::span<const int64_t>(wpi::SmallVectorImpl<int64_t>& buf)>
152 getter,
153 std::function<void(std::span<const int64_t>)> setter) override;
154
157 std::function<std::span<const float>(wpi::SmallVectorImpl<float>& buf)>
158 getter,
159 std::function<void(std::span<const float>)> setter) override;
160
163 std::function<std::span<const double>(wpi::SmallVectorImpl<double>& buf)>
164 getter,
165 std::function<void(std::span<const double>)> setter) override;
166
169 std::function<
170 std::span<const std::string>(wpi::SmallVectorImpl<std::string>& buf)>
171 getter,
172 std::function<void(std::span<const std::string>)> setter) override;
173
175 std::string_view key, std::string_view typeString,
176 std::function<std::span<uint8_t>(wpi::SmallVectorImpl<uint8_t>& buf)>
177 getter,
178 std::function<void(std::span<const uint8_t>)> setter) override;
179
180 private:
181 struct Property {
182 virtual ~Property() = default;
183 virtual void Update(bool controllable, int64_t time) = 0;
184 };
185
186 template <typename Topic>
187 struct PropertyImpl : public Property {
188 void Update(bool controllable, int64_t time) override;
189
190 using Publisher = typename Topic::PublisherType;
191 using Subscriber = typename Topic::SubscriberType;
192 Publisher pub;
193 Subscriber sub;
194 std::function<void(Publisher& pub, int64_t time)> updateNetwork;
195 std::function<void(Subscriber& sub)> updateLocal;
196 };
197
198 template <typename Topic, typename Getter, typename Setter>
199 void AddPropertyImpl(Topic topic, Getter getter, Setter setter);
200
201 template <typename T, size_t Size, typename Topic, typename Getter,
202 typename Setter>
203 void AddSmallPropertyImpl(Topic topic, Getter getter, Setter setter);
204
205 std::vector<std::unique_ptr<Property>> m_properties;
206 std::function<void()> m_safeState;
207 std::vector<wpi::unique_function<void()>> m_updateTables;
208 std::shared_ptr<nt::NetworkTable> m_table;
209 bool m_controllable = false;
210 bool m_actuator = false;
211
212 nt::BooleanPublisher m_controllablePublisher;
213 nt::StringPublisher m_typePublisher;
214 nt::BooleanPublisher m_actuatorPublisher;
215};
216
217} // namespace frc
This file provides a collection of function (or more generally, callable) type erasure utilities supp...
Definition: SendableBuilderImpl.h:24
void AddSmallRawProperty(std::string_view key, std::string_view typeString, std::function< std::span< uint8_t >(wpi::SmallVectorImpl< uint8_t > &buf)> getter, std::function< void(std::span< const uint8_t >)> setter) override
void AddDoubleProperty(std::string_view key, std::function< double()> getter, std::function< void(double)> setter) override
Add a double property.
void AddIntegerProperty(std::string_view key, std::function< int64_t()> getter, std::function< void(int64_t)> setter) override
Add an integer property.
void SetSmartDashboardType(std::string_view type) override
Set the string representation of the named data type that will be used by the smart dashboard for thi...
void SetSafeState(std::function< void()> func) override
Set the function that should be called to set the Sendable into a safe state.
void AddDoubleArrayProperty(std::string_view key, std::function< std::vector< double >()> getter, std::function< void(std::span< const double >)> setter) override
Add a double array property.
void AddSmallFloatArrayProperty(std::string_view key, std::function< std::span< const float >(wpi::SmallVectorImpl< float > &buf)> getter, std::function< void(std::span< const float >)> setter) override
bool IsActuator() const
Return whether this sendable should be treated as an actuator.
void StartListeners()
Hook setters for all properties.
void AddSmallDoubleArrayProperty(std::string_view key, std::function< std::span< const double >(wpi::SmallVectorImpl< double > &buf)> getter, std::function< void(std::span< const double >)> setter) override
void AddBooleanProperty(std::string_view key, std::function< bool()> getter, std::function< void(bool)> setter) override
Add a boolean property.
void AddRawProperty(std::string_view key, std::string_view typeString, std::function< std::vector< uint8_t >()> getter, std::function< void(std::span< const uint8_t >)> setter) override
Add a raw property.
void AddStringProperty(std::string_view key, std::function< std::string()> getter, std::function< void(std::string_view)> setter) override
Add a string property.
void StopLiveWindowMode()
Stop LiveWindow mode by unhooking the setters for all properties.
void AddSmallStringArrayProperty(std::string_view key, std::function< std::span< const std::string >(wpi::SmallVectorImpl< std::string > &buf)> getter, std::function< void(std::span< const std::string >)> setter) override
void AddSmallStringProperty(std::string_view key, std::function< std::string_view(wpi::SmallVectorImpl< char > &buf)> getter, std::function< void(std::string_view)> setter) override
nt::Topic GetTopic(std::string_view key) override
Add a property without getters or setters.
void SetTable(std::shared_ptr< nt::NetworkTable > table)
Set the network table.
std::shared_ptr< nt::NetworkTable > GetTable() override
Get the network table.
SendableBuilderImpl & operator=(SendableBuilderImpl &&)=default
void AddSmallBooleanArrayProperty(std::string_view key, std::function< std::span< const int >(wpi::SmallVectorImpl< int > &buf)> getter, std::function< void(std::span< const int >)> setter) override
void SetActuator(bool value) override
Set a flag indicating if this sendable should be treated as an actuator.
void AddSmallIntegerArrayProperty(std::string_view key, std::function< std::span< const int64_t >(wpi::SmallVectorImpl< int64_t > &buf)> getter, std::function< void(std::span< const int64_t >)> setter) override
~SendableBuilderImpl() override=default
void AddBooleanArrayProperty(std::string_view key, std::function< std::vector< int >()> getter, std::function< void(std::span< const int >)> setter) override
Add a boolean array property.
void Update() override
Synchronize with network table values by calling the getters for all properties and setters when the ...
void AddStringArrayProperty(std::string_view key, std::function< std::vector< std::string >()> getter, std::function< void(std::span< const std::string >)> setter) override
Add a string array property.
void StartLiveWindowMode()
Start LiveWindow mode by hooking the setters for all properties.
void AddFloatProperty(std::string_view key, std::function< float()> getter, std::function< void(float)> setter) override
Add a float property.
SendableBuilderImpl(SendableBuilderImpl &&)=default
void AddIntegerArrayProperty(std::string_view key, std::function< std::vector< int64_t >()> getter, std::function< void(std::span< const int64_t >)> setter) override
Add an integer array property.
bool IsPublished() const override
Return whether this sendable has an associated table.
void SetUpdateTable(wpi::unique_function< void()> func) override
Set the function that should be called to update the network table for things other than properties.
void AddFloatArrayProperty(std::string_view key, std::function< std::vector< float >()> getter, std::function< void(std::span< const float >)> setter) override
Add a float array property.
void StopListeners()
Unhook setters for all properties.
void ClearProperties() override
Clear properties.
NetworkTables Boolean publisher.
Definition: BooleanTopic.h:110
Definition: NTSendableBuilder.h:18
NetworkTables String publisher.
Definition: StringTopic.h:159
NetworkTables Topic.
Definition: Topic.h:30
Definition: core.h:1240
unique_function is a type-erasing functor similar to std::function.
Definition: FunctionExtras.h:56
basic_string_view< char > string_view
Definition: core.h:520
type
Definition: core.h:575
::int64_t int64_t
Definition: Meta.h:59
Definition: AprilTagFieldLayout.h:22