mirror of
https://github.com/DCC-EX/CommandStation-EX.git
synced 2024-11-23 16:16:13 +01:00
commit
c8a4323a4f
|
@ -25,6 +25,7 @@
|
||||||
#include "Outputs.h"
|
#include "Outputs.h"
|
||||||
#include "Sensors.h"
|
#include "Sensors.h"
|
||||||
#include "freeMemory.h"
|
#include "freeMemory.h"
|
||||||
|
#include "GITHUB_SHA.h"
|
||||||
|
|
||||||
#include "EEStore.h"
|
#include "EEStore.h"
|
||||||
#include "DIAG.h"
|
#include "DIAG.h"
|
||||||
|
@ -222,11 +223,17 @@ void DCCEXParser::parse(Print * stream, byte *com, bool blocking) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case 'V': // VERIFY CV ON PROG <V CV VALUE> <V CV BIT 0|1>
|
case 'V': // VERIFY CV ON PROG <V CV VALUE> <V CV BIT 0|1>
|
||||||
if (!stashCallback(stream,p)) break;
|
if (params==2) { // <V CV VALUE>
|
||||||
if (params==2) DCC::verifyCVByte(p[0],p[1],callback_Vbyte,blocking);
|
if (!stashCallback(stream,p)) break;
|
||||||
else if (params==3) DCC::verifyCVBit(p[0],p[1],p[2],callback_Vbit,blocking);
|
DCC::verifyCVByte(p[0],p[1],callback_Vbyte,blocking);
|
||||||
else break;
|
return;
|
||||||
return;
|
}
|
||||||
|
if (params==3) {
|
||||||
|
if (!stashCallback(stream,p)) break;
|
||||||
|
DCC::verifyCVBit(p[0],p[1],p[2],callback_Vbit,blocking);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case 'B': // WRITE CV BIT ON PROG <B CV BIT VALUE CALLBACKNUM CALLBACKSUB>
|
case 'B': // WRITE CV BIT ON PROG <B CV BIT VALUE CALLBACKNUM CALLBACKSUB>
|
||||||
if (!stashCallback(stream,p)) break;
|
if (!stashCallback(stream,p)) break;
|
||||||
|
@ -234,10 +241,18 @@ void DCCEXParser::parse(Print * stream, byte *com, bool blocking) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
||||||
case 'R': // READ CV ON PROG <R CV CALLBACKNUM CALLBACKSUB>
|
case 'R': // READ CV ON PROG
|
||||||
if (!stashCallback(stream,p)) break;
|
if (params==3) { // <R CV CALLBACKNUM CALLBACKSUB>
|
||||||
DCC::readCV(p[0],callback_R,blocking);
|
if (!stashCallback(stream,p)) break;
|
||||||
return;
|
DCC::readCV(p[0],callback_R,blocking);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (params==0) { // <R> New read loco id
|
||||||
|
if (!stashCallback(stream,p)) break;
|
||||||
|
DCC::getLocoId(callback_Rloco,blocking);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case '1': // POWERON <1 [MAIN|PROG]>
|
case '1': // POWERON <1 [MAIN|PROG]>
|
||||||
case '0': // POWEROFF <0 [MAIN | PROG] >
|
case '0': // POWEROFF <0 [MAIN | PROG] >
|
||||||
|
@ -289,7 +304,7 @@ void DCCEXParser::parse(Print * stream, byte *com, bool blocking) {
|
||||||
|
|
||||||
case 's': // <s>
|
case 's': // <s>
|
||||||
StringFormatter::send(stream,F("<p%d>"),DCCWaveform::mainTrack.getPowerMode()==POWERMODE::ON );
|
StringFormatter::send(stream,F("<p%d>"),DCCWaveform::mainTrack.getPowerMode()==POWERMODE::ON );
|
||||||
StringFormatter::send(stream,F("<iDCC-EX-API / V-%S %s/%s>"), VERSION, __DATE__, __TIME__ );
|
StringFormatter::send(stream,F("<iDCC-EX-API / V-%S G-%S>"), VERSION, F(GITHUB_SHA));
|
||||||
// TODO Send stats of speed reminders table
|
// TODO Send stats of speed reminders table
|
||||||
// TODO send status of turnouts etc etc
|
// TODO send status of turnouts etc etc
|
||||||
return;
|
return;
|
||||||
|
@ -532,3 +547,8 @@ void DCCEXParser::callback_R(int result) {
|
||||||
stashBusy=false;
|
stashBusy=false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DCCEXParser::callback_Rloco(int result) {
|
||||||
|
StringFormatter::send(stashStream,F("<r %d>"),result);
|
||||||
|
stashBusy=false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -55,6 +55,7 @@ struct DCCEXParser
|
||||||
static void callback_W(int result);
|
static void callback_W(int result);
|
||||||
static void callback_B(int result);
|
static void callback_B(int result);
|
||||||
static void callback_R(int result);
|
static void callback_R(int result);
|
||||||
|
static void callback_Rloco(int result);
|
||||||
static void callback_Vbit(int result);
|
static void callback_Vbit(int result);
|
||||||
static void callback_Vbyte(int result);
|
static void callback_Vbyte(int result);
|
||||||
static FILTER_CALLBACK filterCallback;
|
static FILTER_CALLBACK filterCallback;
|
||||||
|
|
1
GITHUB_SHA.h
Normal file
1
GITHUB_SHA.h
Normal file
|
@ -0,0 +1 @@
|
||||||
|
#define GITHUB_SHA "9db6d36"
|
39
README.md
Normal file
39
README.md
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
# What's DCC++ EX
|
||||||
|
------------
|
||||||
|
|
||||||
|
DCC++ EX is an open-source hardware and software system for the operation of DCC-equipped model railroads. It expands on the work of Gregg E. Berman's original DCC++ (which can be found here in the BaseStation-Classic repository)
|
||||||
|
|
||||||
|
The system consists of two parts, the DCC++ EX Command Station and one of many front end controllers. These controllers can be hardware controllers (called CABs or Throttles), software applications like JMRI, phone apps like Engine Driver, or our exWebThrottle that is a simple application you run in a browser like a web page and control your model trains.
|
||||||
|
|
||||||
|
The DCC++ EX Command Station consists of an Arduino micro controller fitted with an Arduino Motor Shield (or other supported motor controllers) that can be connected directly to the tracks of a model railroad.
|
||||||
|
|
||||||
|
# What’s in this Repository
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
This repository, CommandStation-EX, contains a complete DCC++ EX Commmand Station sketch designed for compiling and uploading into an Arduino Uno, Mega, or Nano. All sketch files are in the folder named CommandStation-EX and its subforlders. More information about the sketch can be found in the included PDF file.
|
||||||
|
|
||||||
|
To utilize this sketch, you can use our automated installer, or download a zip file from this repository and open the file "CommandStation-EX.ino" after unzipping it to your Arduino IDE projects folder. Please do not rename the folder containing the sketch code, nor add any files in that folder. The Arduino IDE relies on the structure and name of the folder to properly display and compile the code.
|
||||||
|
|
||||||
|
The latest production release of the Master branch is 3.0.1:
|
||||||
|
|
||||||
|
* Supports the Arduino Uno, Arduino Mega, and Arduino Nano
|
||||||
|
* Built-in configuration for both the original Arduino Motor Shield, Pololu MC33926 Motor Shield, LMD18200, and BTS7960B
|
||||||
|
* Built-in configuration and support of Ethernet Shields and the ESP82266 WiFi module (networking for use with Mega only).
|
||||||
|
|
||||||
|
For more information on the overall DCC++ EX system, please follow the links in the PDF file.
|
||||||
|
|
||||||
|
Detailed diagrams showing pin mappings and required jumpers for the Motor Shields can be found in the Documentation Repository
|
||||||
|
|
||||||
|
The Master branch contains all of the Command Station functionality showed in the DCC-EX YouTube channel.
|
||||||
|
|
||||||
|
# How to find more information
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
[DCC++ EX WEB Page](https://dcc-ex.github.io "DCC++ EX WEB Page")
|
||||||
|
|
||||||
|
[The DCC++ EX Discord and live support](https://discord.gg/y2sB4Fp "The DCC++ EX Discord Server")
|
||||||
|
|
||||||
|
[TrainBoard DCC++ Forum](https://www.trainboard.com/highball/index.php?forums/dcc.177/ "TrainBoard DCC++ Forum")
|
||||||
|
|
||||||
|
-May 2020
|
||||||
|
!!
|
Loading…
Reference in New Issue
Block a user