Class ProtobufTopic<T>
- Type Parameters:
T
- value class
-
Field Summary
-
Method Summary
Modifier and TypeMethodDescriptionboolean
getEntry
(T defaultValue, PubSubOption... options) Create a new entry for the topic.getProto()
Returns the protobuf.int
hashCode()
publish
(PubSubOption... options) Create a new publisher to the topic.publishEx
(String properties, PubSubOption... options) Create a new publisher to the topic, with type string and initial properties.subscribe
(T defaultValue, PubSubOption... options) Create a new subscriber to the topic.static <T> ProtobufTopic<T>
wrap
(NetworkTableInstance inst, int handle, Protobuf<T, ?> proto) Create a ProtobufTopic from a native handle; generally NetworkTableInstance.getProtobufTopic() should be used instead.static <T> ProtobufTopic<T>
Create a ProtobufTopic from a generic topic.Methods inherited from class edu.wpi.first.networktables.Topic
deleteProperty, exists, genericPublish, genericPublishEx, genericSubscribe, genericSubscribe, getGenericEntry, getGenericEntry, getHandle, getInfo, getInstance, getName, getProperties, getProperty, getType, getTypeString, isCached, isPersistent, isRetained, isValid, setCached, setPersistent, setProperties, setProperty, setRetained
-
Method Details
-
wrap
Create a ProtobufTopic from a generic topic.- Type Parameters:
T
- value class (inferred from proto)- Parameters:
topic
- generic topicproto
- protobuf serialization implementation- Returns:
- ProtobufTopic for value class
-
wrap
Create a ProtobufTopic from a native handle; generally NetworkTableInstance.getProtobufTopic() should be used instead.- Type Parameters:
T
- value class (inferred from proto)- Parameters:
inst
- Instancehandle
- Native handleproto
- protobuf serialization implementation- Returns:
- ProtobufTopic for value class
-
subscribe
Create a new subscriber to the topic.The subscriber is only active as long as the returned object is not closed.
Subscribers that do not match the published data type do not return any values. To determine if the data type matches, use the appropriate Topic functions.
- Parameters:
defaultValue
- default value used when a default is not provided to a getter functionoptions
- subscribe options- Returns:
- subscriber
-
publish
Create a new publisher to the topic.The publisher is only active as long as the returned object is not closed.
It is not possible to publish two different data types to the same topic. Conflicts between publishers are typically resolved by the server on a first-come, first-served basis. Any published values that do not match the topic's data type are dropped (ignored). To determine if the data type matches, use the appropriate Topic functions.
- Parameters:
options
- publish options- Returns:
- publisher
-
publishEx
Create a new publisher to the topic, with type string and initial properties.The publisher is only active as long as the returned object is not closed.
It is not possible to publish two different data types to the same topic. Conflicts between publishers are typically resolved by the server on a first-come, first-served basis. Any published values that do not match the topic's data type are dropped (ignored). To determine if the data type matches, use the appropriate Topic functions.
- Parameters:
properties
- JSON propertiesoptions
- publish options- Returns:
- publisher
- Throws:
IllegalArgumentException
- if properties is not a JSON object
-
getEntry
Create a new entry for the topic.Entries act as a combination of a subscriber and a weak publisher. The subscriber is active as long as the entry is not closed. The publisher is created when the entry is first written to, and remains active until either unpublish() is called or the entry is closed.
It is not possible to use two different data types with the same topic. Conflicts between publishers are typically resolved by the server on a first-come, first-served basis. Any published values that do not match the topic's data type are dropped (ignored), and the entry will show no new values if the data type does not match. To determine if the data type matches, use the appropriate Topic functions.
- Parameters:
defaultValue
- default value used when a default is not provided to a getter functionoptions
- publish and/or subscribe options- Returns:
- entry
-
getProto
Returns the protobuf.- Returns:
- The protobuf.
-
equals
-
hashCode
-