mirror of
https://github.com/ShaYmez/NXDNClients.git
synced 2025-08-02 21:12:27 -04:00
Merge pull request #206 from f1rmb/connection_status_to_static_at_startup
This commit is contained in:
commit
f9f1530dc9
@ -313,9 +313,11 @@ void CNXDNGateway::run()
|
|||||||
hangTimer.start();
|
hangTimer.start();
|
||||||
}
|
}
|
||||||
} else if (currentTG == 0U) {
|
} else if (currentTG == 0U) {
|
||||||
// Don't pass reflector control data through to the MMDVM
|
bool poll = false;
|
||||||
if (::memcmp(buffer, "NXDND", 5U) == 0) {
|
|
||||||
// Find the static TG that this audio data belongs to
|
// We weren't really connected yet, but we got a reply from a poll, or some data
|
||||||
|
if ((::memcmp(buffer, "NXDND", 5U) == 0) || (poll = (::memcmp(buffer, "NXDNP", 5U) == 0))) {
|
||||||
|
// Find the static TG that this audio data/poll belongs to
|
||||||
for (std::vector<CStaticTG>::const_iterator it = staticTGs.cbegin(); it != staticTGs.cend(); ++it) {
|
for (std::vector<CStaticTG>::const_iterator it = staticTGs.cbegin(); it != staticTGs.cend(); ++it) {
|
||||||
if (CUDPSocket::match(addr, (*it).m_addr)) {
|
if (CUDPSocket::match(addr, (*it).m_addr)) {
|
||||||
currentTG = (*it).m_tg;
|
currentTG = (*it).m_tg;
|
||||||
@ -334,7 +336,7 @@ void CNXDNGateway::run()
|
|||||||
|
|
||||||
bool grp = (buffer[9U] & 0x01U) == 0x01U;
|
bool grp = (buffer[9U] & 0x01U) == 0x01U;
|
||||||
|
|
||||||
if (grp && currentTG == dstTG)
|
if (grp && currentTG == dstTG && !poll)
|
||||||
localNetwork->write(buffer + 10U, len - 10U);
|
localNetwork->write(buffer + 10U, len - 10U);
|
||||||
|
|
||||||
LogMessage("Switched to reflector %u due to network activity", currentTG);
|
LogMessage("Switched to reflector %u due to network activity", currentTG);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user