-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcommand.h
More file actions
81 lines (61 loc) · 2.18 KB
/
command.h
File metadata and controls
81 lines (61 loc) · 2.18 KB
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
/*
* Part of Strimer Plus Arduino
* Version: 2021.10.27
* Author: Murat TAMCI
* Web Site: www.themt.co
* License: Read LICENSE.txt
*/
String read_string;
char* cmd_cursor; // cursor
String cmd_key; // key
String cmd_value; // value
bool cmd_fail;
void cmdWork (String cmd_key, String cmd_value);
void cmdProc () {
if (Serial.available()) {
char c = Serial.read();
if (c == '\n' || c == '\0' || c == '\r') {
Serial.read();
//Serial.println(read_string);
cmd_cursor = read_string.c_str();
while (*cmd_cursor != '\0') {
while (*cmd_cursor == '\t' || *cmd_cursor == ' ' && *cmd_cursor != '\0') { cmd_cursor++; } // skip all whitespace
cmd_key = "";
cmd_value = "";
// i found key
if (*(cmd_cursor-1) != '\\' && *cmd_cursor == '-') {
cmd_fail = false;
if (*cmd_cursor != '\0') cmd_cursor++; // skip "-" character
while (*cmd_cursor != '\t' && *cmd_cursor != ' ' && *cmd_cursor != '\0') {
cmd_key += *cmd_cursor; cmd_cursor++;
}
if (cmd_key.length() == 0) {
cmd_fail = true;
Serial.println("FAIL key is empty");
}
if (*cmd_cursor != '\0') cmd_cursor++; // skip whitespace character
// i found value
while (*cmd_cursor != '\0') {
if (*cmd_cursor == '\\') {
cmd_cursor++;
} else if (*(cmd_cursor+1) == '-') break;
cmd_value += *cmd_cursor; cmd_cursor++;
}
if (cmd_value.length() == 0) {
cmd_fail = true;
Serial.println("FAIL value is empty");
}
if (!cmd_fail) cmdWork (cmd_key, cmd_value);
//Serial.print ("key: "); Serial.println (cmd_key);
//Serial.print ("val: "); Serial.println (cmd_value);
} else {
if (*cmd_cursor != '\0') cmd_cursor++;
}
}
read_string=""; //clears variable for new input
}
else {
read_string += c; //makes the string read_string
}
}
}