X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=src%2Fserver%2Fhandler_coke.c;h=53cbd0fd7d3be7afecefdd8cd97f84125fdd5953;hb=dfa4eb21fc9e7cc2bfa912581d38aaee04f3b990;hp=13f25c0833726d97cdfd7013f70941b74739a520;hpb=4b597ccec76234944c19a9fb5d4f5d63e5671807;p=tpg%2Fopendispense2.git diff --git a/src/server/handler_coke.c b/src/server/handler_coke.c index 13f25c0..53cbd0f 100644 --- a/src/server/handler_coke.c +++ b/src/server/handler_coke.c @@ -36,8 +36,15 @@ regex_t gCoke_StatusRegex; // == CODE === int Coke_InitHandler() { - giCoke_SerialFD = open(gsCoke_SerialPort, O_RDWR); - regcomp(&gCoke_StatusRegex, "^slot\\s+(\\d)\\s+([^:]+):([a-zA-Z]+)\\s*", REG_EXTENDED); + printf("connecting to coke machine...\n"); + giCoke_SerialFD = open(gsCoke_SerialPort, O_RDWR | O_NOCTTY | O_NONBLOCK); + if( giCoke_SerialFD == -1 ) { + fprintf(stderr, "ERROR: Unable to open coke serial port ('%s')\n", gsCoke_SerialPort); + } + + InitSerial(giCoke_SerialFD, 9600); + + CompileRegex(&gCoke_StatusRegex, "^slot\\s+(\\d)\\s+([^:]+):([a-zA-Z]+)\\s*", REG_EXTENDED); return 0; } @@ -45,17 +52,27 @@ int Coke_CanDispense(int User, int Item) { char tmp[32], *status; regmatch_t matches[4]; + int ret; // Sanity please - if( Item < 0 || Item > 6 ) return -1; + if( Item < 0 || Item > 6 ) return -1; // -EYOURBAD // Ask the coke machine sprintf(tmp, "s%i\n", Item); write(giCoke_SerialFD, tmp, 2); // Read the response - read(giCoke_SerialFD, tmp, sizeof(tmp)-1); - regexec(&gCoke_StatusRegex, tmp, sizeof(matches)/sizeof(matches[0]), matches, 0); + tmp[0] = '\0'; + ret = read(giCoke_SerialFD, tmp, sizeof(tmp)-1); + //printf("ret = %i\n", ret); + if( ret <= 0 ) { + fprintf(stderr, "Coke machine is not being chatty (read = %i)\n", ret); + return -1; + } + ret = RunRegex(&gCoke_StatusRegex, tmp, sizeof(matches)/sizeof(matches[0]), matches, "Bad Response"); + if( ret ) { + return -1; + } tmp[ matches[3].rm_eo ] = '\0'; status = &tmp[ matches[3].rm_so ]; @@ -63,9 +80,9 @@ int Coke_CanDispense(int User, int Item) printf("Machine responded slot status '%s'\n", status); if( strcmp(status, "full") == 0 ) - return 1; + return 0; - return 0; + return 1; } /**