-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcoolASSM_config.h
270 lines (243 loc) · 9.58 KB
/
coolASSM_config.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
/**
* coolASSM - cool arduino serial state machine
*
* Christian
* created 20190511
* version 20200404
*
* MIT License
*
* Copyright (c) 2019-2020 coolASSM Christian ([email protected])
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
#ifndef __ARDUINO_COOLASSM_HELPER_H__
#define __ARDUINO_COOLASSM_HELPER_H__
#include <Arduino.h>
// simple STATE and some load indicator that flashes differently in each state;
// if true, the defined PIN (default 13, where all small arduino boards have a
// built in LED) will will light up and flash differently in each STATE. For the
// ERROR STATE it will light permanently, for IDLE STATE it will flash like a
// hearbeat with 60 bpms, and for _all_ run MODE STATEs it will flash for 10
// milliseonds; last let arduino take a general delay of 20 ms in total.
#define ASSM_LED_ACTV true // false; PIN can be used for electronics
#define ASSM_LED_PIN 13 // define you PIN if you soldered differently
// define the baud rate the arduino should run its serial ..
// #define SERIAL_BAUD 2400 // Baudrate
// #define SERIAL_BAUD 4800 // Baudrate
#define SERIAL_BAUD 9600 // Baudrate
// #define SERIAL_BAUD 19200 // Baudrate
// #define SERIAL_BAUD 38400 // Baudrate
// #define SERIAL_BAUD 57600 // Baudrate
// #define SERIAL_BAUD 115200 // Baudrate
/**
* \brief the cool ASSM COMMANDs as IDs and STRINGs
*/
#define ASSM_CMD_NULL 0 // NULL or NO COMMAND; is handled as a CMD
#define ASSM_CMD_NULL_STR "NULL"
#define ASSM_CMD_SNA 1 // service not available (SNA); go error state
#define ASSM_CMD_SNA_STR "SNA"
#define ASSM_CMD_PING 2 // send a PING and try get a PONG response
#define ASSM_CMD_PING_STR "PING"
#define ASSM_CMD_PONG 3 // send a PONG for a PING receive
#define ASSM_CMD_PONG_STR "PONG"
#define ASSM_CMD_AKNW 4 // ACKNOWLEDGE a received command
#define ASSM_CMD_AKNW_STR "AKNW"
#define ASSM_CMD_RUN 5 // signal to WAIT to CLIENT or SERVER
#define ASSM_CMD_RUN_STR "RUN"
#define ASSM_CMD_WAIT 6 // signal to WAIT to CLIENT or SERVER
#define ASSM_CMD_WAIT_STR "WAIT"
#define ASSM_CMD_EVNT 7 // signal an EVENT to CLIENT or SERVER
#define ASSM_CMD_EVNT_STR "EVNT"
#define ASSM_CMD_DONE 8 // send a STOP to CLIENT or SERVER
#define ASSM_CMD_DONE_STR "DONE"
#define ASSM_CMD_STOP 9 // send a STOP to CLIENT or SERVER
#define ASSM_CMD_STOP_STR "STOP"
#define ASSM_CMD_STAT 10 // request the STATUS of CLIENT or SERVER
#define ASSM_CMD_STAT_STR "STAT"
// define different RUN MODEs ..
#define ASSM_CMD_RMD1 11 // let arduino do something while in run MODE 1
#define ASSM_CMD_RMD1_STR "RMD1"
#define ASSM_CMD_RMD2 12 // let arduino do something while in run MODE 2
#define ASSM_CMD_RMD2_STR "RMD2"
#define ASSM_CMD_RMD3 13 // let arduino do something while in run MODE 3
#define ASSM_CMD_RMD3_STR "RMD3"
#define ASSM_CMD_RMD4 14 // let arduino do something while in run MODE 4
#define ASSM_CMD_RMD4_STR "RMD4"
#define ASSM_CMD_RMD5 15 // let arduino do something while in run MODE 5
#define ASSM_CMD_RMD5_STR "RMD5"
#define ASSM_CMD_RMD6 16 // let arduino do something while in run MODE 6
#define ASSM_CMD_RMD6_STR "RMD6"
#define ASSM_CMD_RMD7 17 // let arduino do something while in run MODE 7
#define ASSM_CMD_RMD7_STR "RMD7"
// CONNECT and DISCONNECT COMMANDs; not really necessary
#define ASSM_CMD_CNCT 18 // CONNECT and ready for COMMANDs
#define ASSM_CMD_CNCT_STR "CNCT"
#define ASSM_CMD_DCNT 19 // DISCONNECT from SERVER
#define ASSM_CMD_DCNT_STR "DCNT"
// ALL other COMMAND values are application specific and should be defined in
// by extending the this class. In parallel one should overload the methods
// of error, idle, and run_MODE1, run_MODE2, .. ,run_MODE7.
/*!
* \brief The cool ASSM STATEs
*/
#define ASSM_STATE_ERROR 0
#define ASSM_STATE_ERROR_STR "ERROR"
#define ASSM_STATE_IDLNG 1
#define ASSM_STATE_IDLNG_STR "IDLNG"
// the defined run MODES of arduino to do different jobs
#define ASSM_STATE_MODE1 11
#define ASSM_STATE_MODE1_STR "MODE1"
#define ASSM_STATE_MODE2 12
#define ASSM_STATE_MODE2_STR "MODE1"
#define ASSM_STATE_MODE3 13
#define ASSM_STATE_MODE3_STR "MODE1"
#define ASSM_STATE_MODE4 14
#define ASSM_STATE_MODE4_STR "MODE1"
#define ASSM_STATE_MODE5 15
#define ASSM_STATE_MODE5_STR "MODE1"
#define ASSM_STATE_MODE6 16
#define ASSM_STATE_MODE6_STR "MODE1"
#define ASSM_STATE_MODE7 17
#define ASSM_STATE_MODE7_STR "MODE7"
/*!
* \brief The cool ASSM HARDWARE; doing leetspeak ..
*/
#define ASSM_HARD_ANLG0 40
#define ASSM_HARD_ANLG0_STR "A0"
#define ASSM_HARD_ANLG1 41
#define ASSM_HARD_ANLG1_STR "A1"
#define ASSM_HARD_ANLG2 42
#define ASSM_HARD_ANLG2_STR "A2"
#define ASSM_HARD_ANLG3 43
#define ASSM_HARD_ANLG3_STR "A3"
#define ASSM_HARD_ANLG4 44
#define ASSM_HARD_ANLG4_STR "A4"
#define ASSM_HARD_ANLG5 45
#define ASSM_HARD_ANLG5_STR "A5"
#define ASSM_HARD_GPIO0 60
#define ASSM_HARD_GPIO0_STR "GPIO0"
#define ASSM_HARD_GPIO1 61
#define ASSM_HARD_GPIO1_STR "GPIO1"
#define ASSM_HARD_GPIO2 62
#define ASSM_HARD_GPIO2_STR "GPIO2"
#define ASSM_HARD_GPIO3 63
#define ASSM_HARD_GPIO3_STR "GPIO3"
#define ASSM_HARD_GPIO4 64
#define ASSM_HARD_GPIO4_STR "GPIO4"
#define ASSM_HARD_GPIO5 65
#define ASSM_HARD_GPIO5_STR "GPIO5"
#define ASSM_HARD_GPIO6 66
#define ASSM_HARD_GPIO6_STR "GPIO6"
#define ASSM_HARD_GPIO7 67
#define ASSM_HARD_GPIO7_STR "GPIO7"
#define ASSM_HARD_GPIO8 68
#define ASSM_HARD_GPIO8_STR "GPIO8"
#define ASSM_HARD_GPIO9 69
#define ASSM_HARD_GPIO9_STR "GPIO9"
#define ASSM_HARD_GPIO10 70
#define ASSM_HARD_GPIO10_STR "GPIO10"
#define ASSM_HARD_GPIO11 71
#define ASSM_HARD_GPIO11_STR "GPIO11"
#define ASSM_HARD_GPIO12 72
#define ASSM_HARD_GPIO12_STR "GPIO12"
#define ASSM_HARD_GPIO13 73
#define ASSM_HARD_GPIO13_STR "GPIO13"
/*!
* a Helper for converting COMMANDs and STATEs from ID to String & vice versa
*/
class ASSM_HELPER {
public:
/*!
* \brief Constructor
*/
ASSM_HELPER( void );
/*!
* \brief Destructor
*/
virtual ~ASSM_HELPER( void );
/*!
* \brief read a COMMAND as integer and hand back the matching string
* \return the COMMAND as string
*/
String command_to_String( uint8_t Command );
/*!
* \brief read a COMMAND as string and hand back the matching integer
* \return the COMMAND as unsigned integer
*/
uint8_t command_to_Integer( String Command );
/*!
* \brief read a STATE as integer and hand back the matching string
* \return the STATE as string
*/
String state_to_String( uint8_t state );
/*!
* \brief read a STATE as string and hand back the matching integer
* \return the STATE as unsigned integer
*/
uint8_t state_to_Integer( String state );
/*!
* \brief read a HARDWARE as integer and hand back the matching string
* \return the HARDWARE as string
*/
String hardware_to_String( uint8_t hardware );
/*!
* \brief receives a string and adds some marking to be a state or command:
* pattern: <STATE/> or <COMMAND/>
* \return the string as marked state or command
*/
String mark_as_State_or_Command( String state_or_command );
/*!
* \brief receives a string and adds some marking to be an individual
* starting data command; pattern: <DATA_COMMAND>
* \return the string as marked individual starting data command
*/
String mark_as_Data_starting( String individual_data_command );
/*!
* \brief receives a string and adds some marking to be an individual
* stopping data command; pattern: </DATA_COMMAND>
* \return the string as marked individual stopping data command
*/
String mark_as_Data_stopping( String individual_data_command );
/*!
* \brief converts a float to a String
* \param the double value
* \return the correspoding string; e.g. "16.84"
*/
String toStr( float f, int digits, int precision );
/*!
* \brief converts a double to a String
* \param the double value
* \return the correspoding string; e.g. "16.84"
*/
String toStr( double d, int digits, int precision );
private: // some stuff that's not so interesting
const char _markerHead = '<';
const char _markerPref = '/';
const char _markerFoot = '>';
// const String _markerCommand = "CMD_"; // deprecated
/*!
* \brief converts a char array into an integer
* \param the char array keeping a one or more digit number
* \return the correspoding integer
*/
int a2i( const char* s );
}; // class
#endif