1
0
mirror of https://github.com/DCC-EX/CommandStation-EX.git synced 2025-01-12 05:41:02 +01:00
CommandStation-EX/CVReader.ino

40 lines
1.3 KiB
Arduino
Raw Normal View History

2020-05-24 17:07:16 +02:00
#include "DCC.h"
2020-05-24 00:02:54 +02:00
#include "DIAG.h"
2020-06-04 21:55:18 +02:00
#include "DCCEXParser.h"
2020-06-11 14:35:16 +02:00
#include "WifiInterface.h"
2020-05-24 00:22:12 +02:00
/* this code is here to test the waveform generator and reveal the issues involved in programming track operations.
2020-05-24 00:22:12 +02:00
It tests the Waveform genartor and demonstrates how a DCC API function can be simply written
to transmit and receive DCC data on the programming track.
2020-05-24 00:22:12 +02:00
Once started, it continues to operate as a DCC++ compaitible command parser
Important... Config.h contains hardware specific confioguration settings
that you will need to check.
2020-05-24 17:07:16 +02:00
*/
void myCallback(int result) {
2020-06-08 14:04:47 +02:00
DIAG(F("\n getting Loco Id callback result=%d"),result);
}
2020-05-24 00:02:54 +02:00
2020-06-11 14:35:16 +02:00
DCCEXParser serialParser;
2020-05-24 00:02:54 +02:00
void setup() {
Serial.begin(SERIAL_BAUD_RATE);
2020-06-11 14:35:16 +02:00
DCC::begin();
if (WIFI_PORT>0) WifiInterface::setup();
2020-06-08 14:04:47 +02:00
DIAG(F("\n===== CVReader demonstrating DCC::getLocoId() call ==========\n"));
DCC::getLocoId(myCallback); // myCallback will be called with the result
DIAG(F("\n===== DCC::getLocoId has returned, but wont be executed until we are in loop() ======\n"));
DIAG(F("\nReady for JMRI commands\n"));
2020-05-24 00:02:54 +02:00
}
2020-06-11 14:35:16 +02:00
void loop() {
DCC::loop(); // required to keep locos running and check powwer
2020-06-04 21:55:18 +02:00
// This line passes input on Serial to the DCCEXParser
2020-06-11 14:35:16 +02:00
serialParser.loop(Serial);
if (WIFI_PORT>0) WifiInterface::loop();
2020-05-26 00:03:11 +02:00
}