1
0
mirror of https://github.com/DCC-EX/CommandStation-EX.git synced 2024-12-24 13:21:23 +01:00

Reformat reply to <=>

This commit is contained in:
Harald Barth 2023-11-11 09:45:28 +01:00
parent befcfebec7
commit e8b9f80c8c
3 changed files with 18 additions and 23 deletions

View File

@ -269,8 +269,8 @@ void CommandDistributor::broadcastRaw(clientType type, char * msg) {
broadcastReply(type, F("%s"),msg);
}
void CommandDistributor::broadcastTrackState(const FSH* format,byte trackLetter, int16_t dcAddr) {
broadcastReply(COMMAND_TYPE, format,trackLetter, dcAddr);
void CommandDistributor::broadcastTrackState(const FSH* format,byte trackLetter, byte pstate, int16_t dcAddr) {
broadcastReply(COMMAND_TYPE, format,trackLetter, pstate, dcAddr);
}
void CommandDistributor::broadcastRouteState(uint16_t routeId, byte state ) {

View File

@ -55,7 +55,7 @@ public :
static int16_t retClockTime();
static void broadcastPower();
static void broadcastRaw(clientType type,char * msg);
static void broadcastTrackState(const FSH* format,byte trackLetter, int16_t dcAddr);
static void broadcastTrackState(const FSH* format,byte trackLetter, byte pstate, int16_t dcAddr);
template<typename... Targs> static void broadcastReply(clientType type, Targs... msg);
static void forget(byte clientId);
static void broadcastRouteState(uint16_t routeId,byte state);

View File

@ -401,50 +401,45 @@ void TrackManager::streamTrackState(Print* stream, byte t) {
// null stream means send to commandDistributor for broadcast
if (track[t]==NULL) return;
auto format=F("");
// bool pstate = TrackManager::isPowerOn(t);
// char *statestr;
// if (pstate)
// statestr = (char *)"ON";
// else
// statestr = (char *)"OFF";
byte pstate = TrackManager::isPowerOn(t) ? 1 : 0;
TRACK_MODE tm = track[t]->getMode();
if (tm & TRACK_MODE_MAIN) {
if(tm & TRACK_MODE_AUTOINV)
format=F("<= %c MAIN AUTOINV>\n");
format=F("<= %c %d MAIN AUTOINV>\n");
else if (tm & TRACK_MODE_INV)
format=F("<= %c MAIN INV>\n");
format=F("<= %c %d MAIN INV>\n");
else
format=F("<= %c MAIN>\n");
format=F("<= %c %d MAIN>\n");
}
#ifndef DISABLE_PROG
else if (tm & TRACK_MODE_PROG)
format=F("<= %c PROG>\n");
format=F("<= %c %d PROG>\n");
#endif
else if (tm & TRACK_MODE_NONE)
format=F("<= %c NONE>\n");
format=F("<= %c %d NONE>\n");
else if(tm & TRACK_MODE_EXT)
format=F("<= %c EXT>\n");
format=F("<= %c %d EXT>\n");
else if(tm & TRACK_MODE_BOOST) {
if(tm & TRACK_MODE_AUTOINV)
format=F("<= %c BOOST AUTOINV>\n");
format=F("<= %c %d BOOST AUTOINV>\n");
else if (tm & TRACK_MODE_INV)
format=F("<= %c BOOST INV>\n");
format=F("<= %c %d BOOST INV>\n");
else
format=F("<= %c BOOST>\n");
format=F("<= %c %d BOOST>\n");
}
else if (tm & TRACK_MODE_DC) {
if (tm & TRACK_MODE_INV)
format=F("<= %c DCX %d>\n");
format=F("<= %c %d DCX %d>\n");
else
format=F("<= %c DC %d>\n");
format=F("<= %c %d DC %d>\n");
}
else
format=F("<= %c XXX>\n");
format=F("<= %c %d XXX>\n");
if (stream)
StringFormatter::send(stream,format,'A'+t, trackDCAddr[t]);
StringFormatter::send(stream,format,'A'+t, pstate, trackDCAddr[t]);
else
CommandDistributor::broadcastTrackState(format,'A'+t, trackDCAddr[t]);
CommandDistributor::broadcastTrackState(format,'A'+t, pstate, trackDCAddr[t]);
}