X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=firmware%2Ftuer.pde;h=6c966a25b5d35390b440966b3dfe8485ce11a8e5;hb=612479558c6a9be836c331c46e04b8f0b28fbabc;hp=ddf8ba3f3d68f9f9e338419de2344aa0b17fcf15;hpb=138139e389ccc8acd4a9b26df3ef073fd9d3d2bf;p=svn42.git diff --git a/firmware/tuer.pde b/firmware/tuer.pde index ddf8ba3..6c966a2 100644 --- a/firmware/tuer.pde +++ b/firmware/tuer.pde @@ -38,6 +38,7 @@ int debounce_cnt = 0; #define CMD_OPEN 'o' #define CMD_CLOSE 'c' +#define CMD_TOGGLE 't' #define CMD_STATUS 's' #define CMD_RESET 'r' @@ -554,16 +555,27 @@ void loop() else Serial.println("Error: Operation in progress"); } + else if (command == CMD_TOGGLE) { + if(current_state == IDLE) { + if(is_closed()) + start_open(); + else + start_close(); + Serial.println("Ok"); + } + else + Serial.println("Error: Operation in progress"); + } else if (command == CMD_STATUS) print_status(); else Serial.println("Error: unknown command"); } - if(manual_open() && !is_opened() && current_state == IDLE) { + if(manual_open() && !is_opened() && (current_state == IDLE || current_state == ERROR)) { Serial.println("open forced manually"); start_open(); } - if(manual_close() && !is_closed() && current_state == IDLE) { + if(manual_close() && !is_closed() && (current_state == IDLE || current_state == ERROR)) { Serial.println("close forced manually"); start_close(); }