-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMeSerial.h
299 lines (279 loc) · 7.47 KB
/
MeSerial.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
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
/**
* \par Copyright (C), 2012-2016, MakeBlock
* \class MeSerial
* \brief Driver for serial.
* @file MeSerial.h
* @author MakeBlock
* @version V1.0.1
* @date 2015/01/20
* @brief Header for for MeSerial.cpp module
*
* \par Copyright
* This software is Copyright (C), 2012-2016, MakeBlock. Use is subject to license \n
* conditions. The main licensing options available are GPL V2 or Commercial: \n
*
* \par Open Source Licensing GPL V2
* This is the appropriate option if you want to share the source code of your \n
* application with everyone you distribute it to, and you also want to give them \n
* the right to share who uses it. If you wish to use this software under Open \n
* Source Licensing, you must contribute all your source code to the open source \n
* community in accordance with the GPL Version 2 when your application is \n
* distributed. See http://www.gnu.org/copyleft/gpl.html
*
* \par Description
* This file is a drive for serial, It support hardware and software serial
*
* \par Method List:
*
* 1. void MeSerial::setHardware(bool mode)
* 2. void MeSerial::begin(long baudrate)
* 3. void MeSerial::end(void)
* 4. size_t MeSerial::write(uint8_t byte)
* 5. int16_t MeSerial::read(void)
* 6. int16_t MeSerial::available(void)
* 7. bool MeSerial::listen(void)
* 8. bool MeSerial::isListening(void)
* 9. int16_t MeSerial::poll(void)
*
* \par History:
* <pre>
* `<Author>` `<Time>` `<Version>` `<Descr>`
* Mark Yan 2015/09/08 1.0.0 Rebuild the old lib.
* Mark Yan 2016/01/20 1.0.1 support arduino pin-setting.
* </pre>
*/
#ifndef MeSerial_H
#define MeSerial_H
#include <stdint.h>
#include <stdbool.h>
#include <Arduino.h>
#include "MeConfig.h"
#ifdef ME_PORT_DEFINED
#include "MePort.h"
#endif // ME_PORT_DEFINED
/**
* Class: MeSerial
* \par Description
* Declaration of Class MeSerial.
*/
#ifndef ME_PORT_DEFINED
class MeSerial
#else // !ME_PORT_DEFINED
class MeSerial : public MePort, public SoftwareSerial
#endif // !ME_PORT_DEFINED
{
public:
/**
* Alternate Constructor which can call your own function to map the serial to arduino port,
* no pins are used or initialized here. hardware serial will be used by default.
* \param[in]
* None
*/
MeSerial(void);
/**
* Alternate Constructor which can call your own function to map the serial to arduino port,
* If the hardware serial was selected, we will used the hardware serial.
* \param[in]
* port - RJ25 port from PORT_1 to M2
*/
MeSerial(uint8_t port);
/**
* Alternate Constructor which can call your own function to map the serial to arduino port,
* If the hardware serial was selected, we will used the hardware serial.
* \param[in]
* receivePin - the rx pin of serial(arduino port)
* \param[in]
* transmitPin - the tx pin of serial(arduino port)
* \param[in]
* inverse_logic - Whether the Serial level need inv.
*/
MeSerial(uint8_t receivePin, uint8_t transmitPin, bool inverse_logic = false);
/**
* \par Function
* setHardware
* \par Description
* if need change the hardware and software serial, this function can be used.
* \param[in]
* mode - if need use hardware serial this value should set to true, or set it false.
* \par Output
* None
* \return
* None
* \par Others
* None
*/
void setHardware(bool mode);
/**
* \par Function
* begin
* \par Description
* Sets the speed (baud rate) for the serial communication. Supported baud
* rates are 300, 600, 1200, 2400, 4800, 9600, 14400, 19200, 28800, 31250,
* 38400, 57600, and 115200.
* \param[in]
* baudrate - he baud rate (long)
* \par Output
* None
* \return
* None
* \par Others
* None
*/
void begin(long baudrate);
/**
* \par Function
* write
* \par Description
* Writes binary data to the serial port. This data is sent as a byte or series of bytes;
* \param[in]
* byte - a value to send as a single byte
* \par Output
* None
* \return
* it will return the number of bytes written, though reading that number is optional
* \par Others
* None
*/
size_t write(uint8_t byte);
/**
* \par Function
* read
* \par Description
* Return a character that was received on the RX pin of the software serial port.
* Note that only one SoftwareSerial instance can receive incoming data at a time
* (select which one with the listen() function).
* \par Output
* None
* \return
* The character read, or -1 if none is available
* \par Others
* None
*/
int read();
/**
* \par Function
* available
* \par Description
* Get the number of bytes (characters) available for reading from a software
* serial port. This is data that's already arrived and stored in the serial
* receive buffer.
* \par Output
* None
* \return
* The number of bytes available to read
* \par Others
* None
*/
int available();
/**
* \par Function
* poll
* \par Description
* If we used the serial as software serial port, and set the _polling mask true.
* we beed use this function to read the serial data.
* \par Output
* None
* \return
* The character read, or -1 if none is available
* \par Others
* None
*/
int16_t poll(void);
/**
* \par Function
* end
* \par Description
* Stop listening and release the object
* \par Output
* None
* \return
* None
* \par Others
* None
*/
void end(void);
/**
* \par Function
* listen
* \par Description
* Enables the selected software serial port to listen, used for software serial.
* Only one software serial port can listen at a time; data that arrives for other
* ports will be discarded. Any data already received is discarded during the call
* to listen() (unless the given instance is already listening).
* \par Output
* None
* \return
* This function sets the current object as the "listening"
* one and returns true if it replaces another
* \par Others
* None
*/
bool listen(void);
/**
* \par Function
* isListening
* \par Description
* Tests to see if requested software serial port is actively listening.
* \par Output
* None
* \return
* Returns true if we were actually listening.
* \par Others
* None
*/
bool isListening(void);
/**
* \par Function
* sendString
* \par Description
* Send a string as a series of bytes, used for printf().
* \param[in]
* str - A string to send as a series of bytes
* \par Output
* None
* \return
* None
* \par Others
* None
*/
void sendString(char *str);
/**
* \par Function
* printf
* \par Description
* Printf format string (of which "printf" stands for "print formatted")
* refers to a control parameter used by a class of functions in the
* string-processing libraries of various programming languages.
* \param[in]
* fmt - A string that specifies the format of the output. The formatting
* string determines what additional arguments you need to provide.
* \par Output
* None
* \return
* None
* \par Others
* None
*/
void printf(char *fmt,...);
boolean dataLineAvailable(void);
String readDataLine(void);
String concatenateWith(String s1,String s2);
char letterOf(int i,String s);
int stringLength(String s);
boolean equalString(String s1,String s2);
float getValue(String key);
protected:
bool _hard;
bool _polling;
bool _scratch;
int16_t _bitPeriod;
int16_t _byte;
long _lastTime;
char buffer[64];
String lastLine;
int bufferIndex;
private:
volatile uint8_t _RxPin;
volatile uint8_t _TxPin;
};
#endif