Skip to content

Commit

Permalink
Merge pull request #4 from ThadHouse/requestversions
Browse files Browse the repository at this point in the history
Send versions when requested by the DS
  • Loading branch information
ThadHouse authored Jan 12, 2025
2 parents 2ed1914 + d97aeac commit 5cd6b4d
Showing 1 changed file with 39 additions and 11 deletions.
50 changes: 39 additions & 11 deletions kitcan/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ constexpr uint32_t revPhAnyPacketMask = 0x09050000;
constexpr uint32_t revPdhVersionPacketMask = 0x08052600;

struct CanState {
wpi::mutex sendVersionsMutex;
int socketHandle{-1};
nt::IntegerPublisher deviceIdPublisher;
std::array<nt::RawPublisher, 4> framePublishers;
Expand All @@ -49,6 +50,7 @@ struct CanState {
void maybeSendVersionRequest(uint32_t canId);

void handleRevVersionFrame(const canfd_frame& frame);
void sendVersions();

void handleCanFrame(const canfd_frame& frame);
void handlePowerFrame(const canfd_frame& frame);
Expand All @@ -57,6 +59,29 @@ struct CanState {
wpi::uv::Loop& loop);
};

void CanState::sendVersions() {
std::scoped_lock lock{sendVersionsMutex};

for (auto&& versions : sentVersions) {
if (versions.first == 0 || versions.second.empty()) {
continue;
}

uint32_t frameId = versions.first;

std::array<std::string, 3> sendData;
sendData[0] = std::to_string(frameId);
sendData[1] = ((frameId & deviceTypeMask) == pneumaticsFilter)
? "Rev PH"
: "Rev PDH";
sendData[2] = versions.second;

fmt::print("Setting {:x} {} {}\n", frameId, sendData[1], sendData[2]);

versionPublisher.Set(sendData);
}
}

void CanState::maybeSendVersionRequest(uint32_t canId) {
auto& sent = sentVersions[canId];
if (!sent.empty()) {
Expand Down Expand Up @@ -87,17 +112,7 @@ void CanState::handleRevVersionFrame(const canfd_frame& frame) {
char buf[32];
snprintf(buf, sizeof(buf), "%u.%u.%u", year, minor, fix);

std::array<std::string, 3> sendData;
sendData[0] = std::to_string(frameId);
sendData[1] = ((frame.can_id & deviceTypeMask) == pneumaticsFilter)
? "Rev PH"
: "Rev PDH";
sendData[2] = buf;

fmt::print("Setting {:x} {} {}\n", frameId, sendData[1], sendData[2]);

versionPublisher.Set(sendData);

std::scoped_lock lock{sendVersionsMutex};
sentVersions[frameId] = buf;
}

Expand Down Expand Up @@ -297,6 +312,10 @@ int main() {
ntInst.SetServer({"localhost"}, 6810);
ntInst.StartClient("KitCanDaemon");

nt::IntegerSubscriber requestSubscriber =
ntInst.GetIntegerTopic("/Netcomm/Reporting/RequestVersions")
.Subscribe(0);

wpi::EventLoopRunner loopRunner;

bool success = false;
Expand All @@ -309,6 +328,14 @@ int main() {
}
});

NT_Listener requestListener =
ntInst.AddListener(requestSubscriber, NT_EVENT_VALUE_REMOTE,
[&states, &loopRunner](const nt::Event& event) {
for (size_t i = 0; i < states.size(); i++) {
states[i].sendVersions();
}
});

if (!success) {
loopRunner.Stop();
return -1;
Expand All @@ -322,6 +349,7 @@ int main() {
(void)getchar();
#endif
}
ntInst.RemoveListener(requestListener);
ntInst.StopClient();
nt::NetworkTableInstance::Destroy(ntInst);

Expand Down

0 comments on commit 5cd6b4d

Please sign in to comment.