| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248 | 
							- /// @file
 
- #include "mmu2_protocol.h"
 
- // protocol definition
 
- // command: Q0
 
- // meaning: query operation status
 
- // Query/command: query
 
- // Expected reply from the MMU:
 
- //  any of the running operation statuses: OID: [T|L|U|E|C|W|K][0-4]
 
- //  <OID> P[0-9]      : command being processed i.e. operation running, may contain a state number
 
- //  <OID> E[0-9][0-9] : error 1-9 while doing a tool change
 
- //  <OID> F           : operation finished - will be repeated to "Q" messages until a new command is issued
 
- namespace modules {
 
- namespace protocol {
 
- // decoding automaton
 
- // states:  input -> transition into state
 
- // Code      QTLMUXPSBEWK -> msgcode
 
- //           \n ->start
 
- //           * ->error
 
- // error     \n ->start
 
- //           * ->error
 
- // msgcode   0-9 ->msgvalue
 
- //           * ->error
 
- // msgvalue  0-9 ->msgvalue
 
- //           \n ->start successfully accepted command
 
- DecodeStatus Protocol::DecodeRequest(uint8_t c) {
 
-     switch (rqState) {
 
-     case RequestStates::Code:
 
-         switch (c) {
 
-         case 'Q':
 
-         case 'T':
 
-         case 'L':
 
-         case 'M':
 
-         case 'U':
 
-         case 'X':
 
-         case 'P':
 
-         case 'S':
 
-         case 'B':
 
-         case 'E':
 
-         case 'W':
 
-         case 'K':
 
-         case 'F':
 
-         case 'f':
 
-         case 'H':
 
-             requestMsg.code = (RequestMsgCodes)c;
 
-             requestMsg.value = 0;
 
-             rqState = RequestStates::Value;
 
-             return DecodeStatus::NeedMoreData;
 
-         default:
 
-             requestMsg.code = RequestMsgCodes::unknown;
 
-             rqState = RequestStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     case RequestStates::Value:
 
-         if (IsDigit(c)) {
 
-             requestMsg.value *= 10;
 
-             requestMsg.value += c - '0';
 
-             return DecodeStatus::NeedMoreData;
 
-         } else if (IsNewLine(c)) {
 
-             rqState = RequestStates::Code;
 
-             return DecodeStatus::MessageCompleted;
 
-         } else {
 
-             requestMsg.code = RequestMsgCodes::unknown;
 
-             rqState = RequestStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     default: //case error:
 
-         if (IsNewLine(c)) {
 
-             rqState = RequestStates::Code;
 
-             return DecodeStatus::MessageCompleted;
 
-         } else {
 
-             requestMsg.code = RequestMsgCodes::unknown;
 
-             rqState = RequestStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     }
 
- }
 
- uint8_t Protocol::EncodeRequest(const RequestMsg &msg, uint8_t *txbuff) {
 
-     constexpr uint8_t reqSize = 3;
 
-     txbuff[0] = (uint8_t)msg.code;
 
-     txbuff[1] = msg.value + '0';
 
-     txbuff[2] = '\n';
 
-     return reqSize;
 
-     static_assert(reqSize <= MaxRequestSize(), "Request message length exceeded the maximum size, increase the magic constant in MaxRequestSize()");
 
- }
 
- DecodeStatus Protocol::DecodeResponse(uint8_t c) {
 
-     switch (rspState) {
 
-     case ResponseStates::RequestCode:
 
-         switch (c) {
 
-         case 'Q':
 
-         case 'T':
 
-         case 'L':
 
-         case 'M':
 
-         case 'U':
 
-         case 'X':
 
-         case 'P':
 
-         case 'S':
 
-         case 'B':
 
-         case 'E':
 
-         case 'W':
 
-         case 'K':
 
-         case 'F':
 
-         case 'f':
 
-         case 'H':
 
-             responseMsg.request.code = (RequestMsgCodes)c;
 
-             responseMsg.request.value = 0;
 
-             rspState = ResponseStates::RequestValue;
 
-             return DecodeStatus::NeedMoreData;
 
-         case 0x0a:
 
-         case 0x0d:
 
-             // skip leading whitespace if any (makes integration with other SW easier/tolerant)
 
-             return DecodeStatus::NeedMoreData;
 
-         default:
 
-             rspState = ResponseStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     case ResponseStates::RequestValue:
 
-         if (IsDigit(c)) {
 
-             responseMsg.request.value *= 10;
 
-             responseMsg.request.value += c - '0';
 
-             return DecodeStatus::NeedMoreData;
 
-         } else if (c == ' ') {
 
-             rspState = ResponseStates::ParamCode;
 
-             return DecodeStatus::NeedMoreData;
 
-         } else {
 
-             rspState = ResponseStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     case ResponseStates::ParamCode:
 
-         switch (c) {
 
-         case 'P':
 
-         case 'E':
 
-         case 'F':
 
-         case 'A':
 
-         case 'R':
 
-         case 'B':
 
-             rspState = ResponseStates::ParamValue;
 
-             responseMsg.paramCode = (ResponseMsgParamCodes)c;
 
-             responseMsg.paramValue = 0;
 
-             return DecodeStatus::NeedMoreData;
 
-         default:
 
-             responseMsg.paramCode = ResponseMsgParamCodes::unknown;
 
-             rspState = ResponseStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     case ResponseStates::ParamValue:
 
-         if (IsDigit(c)) {
 
-             responseMsg.paramValue *= 10;
 
-             responseMsg.paramValue += c - '0';
 
-             return DecodeStatus::NeedMoreData;
 
-         } else if (IsNewLine(c)) {
 
-             rspState = ResponseStates::RequestCode;
 
-             return DecodeStatus::MessageCompleted;
 
-         } else {
 
-             responseMsg.paramCode = ResponseMsgParamCodes::unknown;
 
-             rspState = ResponseStates::Error;
 
-             return DecodeStatus::Error;
 
-         }
 
-     default: //case error:
 
-         if (IsNewLine(c)) {
 
-             rspState = ResponseStates::RequestCode;
 
-             return DecodeStatus::MessageCompleted;
 
-         } else {
 
-             responseMsg.paramCode = ResponseMsgParamCodes::unknown;
 
-             return DecodeStatus::Error;
 
-         }
 
-     }
 
- }
 
- uint8_t Protocol::EncodeResponseCmdAR(const RequestMsg &msg, ResponseMsgParamCodes ar, uint8_t *txbuff) {
 
-     txbuff[0] = (uint8_t)msg.code;
 
-     txbuff[1] = msg.value + '0';
 
-     txbuff[2] = ' ';
 
-     txbuff[3] = (uint8_t)ar;
 
-     txbuff[4] = '\n';
 
-     return 5;
 
- }
 
- uint8_t Protocol::EncodeResponseReadFINDA(const RequestMsg &msg, uint8_t findaValue, uint8_t *txbuff) {
 
-     txbuff[0] = (uint8_t)msg.code;
 
-     txbuff[1] = msg.value + '0';
 
-     txbuff[2] = ' ';
 
-     txbuff[3] = (uint8_t)ResponseMsgParamCodes::Accepted;
 
-     txbuff[4] = findaValue + '0';
 
-     txbuff[5] = '\n';
 
-     return 6;
 
- }
 
- uint8_t Protocol::EncodeResponseVersion(const RequestMsg &msg, uint8_t value, uint8_t *txbuff) {
 
-     txbuff[0] = (uint8_t)msg.code;
 
-     txbuff[1] = msg.value + '0';
 
-     txbuff[2] = ' ';
 
-     txbuff[3] = (uint8_t)ResponseMsgParamCodes::Accepted;
 
-     uint8_t *dst = txbuff + 4;
 
-     if (value < 10) {
 
-         *dst++ = value + '0';
 
-     } else if (value < 100) {
 
-         *dst++ = value / 10 + '0';
 
-         *dst++ = value % 10 + '0';
 
-     } else {
 
-         *dst++ = value / 100 + '0';
 
-         *dst++ = (value / 10) % 10 + '0';
 
-         *dst++ = value % 10 + '0';
 
-     }
 
-     *dst = '\n';
 
-     return dst - txbuff + 1;
 
- }
 
- uint8_t Protocol::EncodeResponseQueryOperation(const RequestMsg &msg, ResponseMsgParamCodes code, uint16_t value, uint8_t *txbuff) {
 
-     txbuff[0] = (uint8_t)msg.code;
 
-     txbuff[1] = msg.value + '0';
 
-     txbuff[2] = ' ';
 
-     txbuff[3] = (uint8_t)code;
 
-     uint8_t *dst = txbuff + 4;
 
-     if (code != ResponseMsgParamCodes::Finished) {
 
-         if (value < 10) {
 
-             *dst++ = value + '0';
 
-         } else if (value < 100) {
 
-             *dst++ = value / 10 + '0';
 
-             *dst++ = value % 10 + '0';
 
-         } else if (value < 1000) {
 
-             *dst++ = value / 100 + '0';
 
-             *dst++ = (value / 10) % 10 + '0';
 
-             *dst++ = value % 10 + '0';
 
-         } else if (value < 10000) {
 
-             *dst++ = value / 1000 + '0';
 
-             *dst++ = (value / 100) % 10 + '0';
 
-             *dst++ = (value / 10) % 10 + '0';
 
-             *dst++ = value % 10 + '0';
 
-         } else {
 
-             *dst++ = value / 10000 + '0';
 
-             *dst++ = (value / 1000) % 10 + '0';
 
-             *dst++ = (value / 100) % 10 + '0';
 
-             *dst++ = (value / 10) % 10 + '0';
 
-             *dst++ = value % 10 + '0';
 
-         }
 
-     }
 
-     *dst = '\n';
 
-     return dst - txbuff + 1;
 
- }
 
- } // namespace protocol
 
- } // namespace modules
 
 
  |