git.ucc.asn.au
/
tpg
/
opendispense2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Client - Fix to possible infinite loop in ReadLine
[tpg/opendispense2.git]
/
src
/
client
/
main.c
diff --git
a/src/client/main.c
b/src/client/main.c
index
5601c08
..
bf22fab
100644
(file)
--- a/
src/client/main.c
+++ b/
src/client/main.c
@@
-23,7
+23,7
@@
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
-
#include <openssl/sha.h>
// SHA1
+
//#include <openssl/sha.h>
// SHA1
#define USE_NCURSES_INTERFACE 0
#define DEBUG_TRACE_SERVER 0
#define USE_NCURSES_INTERFACE 0
#define DEBUG_TRACE_SERVER 0
@@
-97,7
+97,7
@@
char *trim(char *string);
void CompileRegex(regex_t *regex, const char *pattern, int flags);
// === GLOBALS ===
void CompileRegex(regex_t *regex, const char *pattern, int flags);
// === GLOBALS ===
-char *gsDispenseServer = "
heathred
";
+char *gsDispenseServer = "
merlo.ucc.gu.uwa.edu.au
";
int giDispensePort = 11020;
tItem *gaItems;
int giDispensePort = 11020;
tItem *gaItems;
@@
-146,6
+146,11
@@
void ShowUsage(void)
" dispense iteminfo <itemid>\n"
" Get the name and price for an item\n"
);
" dispense iteminfo <itemid>\n"
" Get the name and price for an item\n"
);
+// if( giTextArgc == 0 || strcmp(gsTextArgs[0], "enumitems") == 0 )
+// printf(
+// " dispense enumitems\n"
+// " List avaliable items\n"
+// );
if( giTextArgc == 0 )
printf(" == Coke members == \n");
if( giTextArgc == 0 || strcmp(gsTextArgs[0], "acct") == 0 )
if( giTextArgc == 0 )
printf(" == Coke members == \n");
if( giTextArgc == 0 || strcmp(gsTextArgs[0], "acct") == 0 )
@@
-161,6
+166,8
@@
void ShowUsage(void)
printf(
" dispense refund <user> <itemid> [<price>]\n"
" Refund an item to a user (with optional price override)\n"
printf(
" dispense refund <user> <itemid> [<price>]\n"
" Refund an item to a user (with optional price override)\n"
+ " Item IDs can be seen in the cokelog (in the brackets after the item name)\n"
+ " e.g. coke:6 for a coke, snack:33 for slot 33 of the snack machine\n"
);
if( giTextArgc == 0 || strcmp(gsTextArgs[0], "slot") == 0 )
printf(
);
if( giTextArgc == 0 || strcmp(gsTextArgs[0], "slot") == 0 )
printf(
@@
-814,10
+821,10
@@
int main(int argc, char *argv[])
if( j > 1 ) {
printf("%i items dispensed\n", j);
}
if( j > 1 ) {
printf("%i items dispensed\n", j);
}
+ Dispense_ShowUser(sock, gsUserName);
close(sock);
close(sock);
- }
- Dispense_ShowUser(sock, gsUserName);
+ }
return ret;
}
return ret;
}
@@
-1125,7
+1132,7
@@
int ShowItemAt(int Row, int Col, int Width, int Index, int bHilighted)
}
// If the item isn't availiable for sale, return -1 (so it's skipped)
}
// If the item isn't availiable for sale, return -1 (so it's skipped)
- if( status || price >
=
giUserBalance )
+ if( status || price > giUserBalance )
Index = -1;
return Index;
Index = -1;
return Index;
@@
-2212,9
+2219,9
@@
char *ReadLine(int Socket)
}
else {
len = recv(Socket, buf+bufPos, BUFSIZ-1-bufPos, 0);
}
else {
len = recv(Socket, buf+bufPos, BUFSIZ-1-bufPos, 0);
- if( len < 0 ) {
+ if( len <
=
0 ) {
free(ret);
free(ret);
- return strdup("
4
99 Client Connection Error\n");
+ return strdup("
5
99 Client Connection Error\n");
}
}
buf[bufPos+len] = '\0';
}
}
buf[bufPos+len] = '\0';
UCC
git Repository :: git.ucc.asn.au