X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fkasse.c;h=d5426c2cdae47b15db30141f5fd15cae3d191c2e;hb=3a0ee7dce566ac289c19d31bd3837ee1535dcf2b;hp=d6ffb486c3ed5931eb46dd3956cb9d9b102b514f;hpb=750dbde18501efb6f9520d378475e3b58aea9ea4;p=c128-kasse diff --git a/src/kasse.c b/src/kasse.c index d6ffb48..d5426c2 100644 --- a/src/kasse.c +++ b/src/kasse.c @@ -25,7 +25,7 @@ // graphic 4,0,10 void print_item(BYTE i) { - char profit[10]; + char profit[EUR_FORMAT_MINLEN + 1]; if (format_euro(profit, sizeof(profit), status.status[i].price) == NULL) { cprintf("Preis %ld konnte nicht umgerechnet werden\r\n", status.status[i].price); @@ -42,11 +42,11 @@ void print_item(BYTE i) { static void print_screen(void) { BYTE i = 0; char *time = get_time(); - char profit[10]; + char profit[EUR_FORMAT_MINLEN + 1]; clrscr(); if (format_euro(profit, sizeof(profit), money) == NULL) { cprintf("Einnahme %ld konnte nicht umgerechnet werden\r\n", money); - exit(1); + profit[0]='\0'; } textcolor(TC_CYAN); cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r, mxf) " GV "\r\n"); @@ -112,29 +112,47 @@ static void print_screen(void) { static void print_log(char *name, int item_price, int einheiten, char *nickname, char *rest) { char *time = get_time(); - char price[10]; - /* Format: - Transaction-ID (Anzahl verkaufter Einträge, inklusive des zu druckenden!) - -- 6-stellig - Uhrzeit -- 8-stellig - Eintragname (= Getränk) -- 9-stellig - Preis (in Cents) -- 9-stellig - Anzahl -- 2-stellig - Nickname (falls es vom Guthaben abgezogen wird) -- 10-stellig - restguthaben (9-stellig) - - + 7 leerzeichen - --> 48 zeichen - */ + uint8_t n; + char price[EUR_FORMAT_MINLEN + 1]; if (format_euro(price, sizeof(price), item_price) == NULL) { cprintf("Preis %d konnte nicht umgerechnet werden\r\n", item_price); exit(1); } - sprintf(print_buffer, "%c[%3u] %s - %-" xstr( - MAX_ITEM_NAME_LENGTH) "s - %s - %s - %d - an %s\r", - 17, status.transaction_id, time, name, price, rest, einheiten, - (*nickname != '\0' ? nickname : "Unbekannt")); + /* TODO: teach the EUR sign to the printer. + * Until then, we just overwrite it with "E" */ + price[EUR_FORMAT_MINLEN - 1] = 'E'; + rest[EUR_FORMAT_MINLEN - 1] = 'E'; + + /* clang-format off */ + n = snprintf(print_buffer, sizeof(print_buffer), + /* enable lower case letters -- 1 */ + "%c" + /* Transaction-ID (Anzahl verkaufter Einträge, inklusive des zu druckenden!) + -- 6-stellig */ + "[%3u] " + /* Uhrzeit -- 8-stellig + 3 */ + "%8s - " + /* Eintragname (= Getränk) -- 9-stellig + 3 */ + "%-" xstr(MAX_ITEM_NAME_LENGTH) "s - " + /* Preis (in Cents) -- 7-stellig + 3 */ + "%" xstr(EUR_FORMAT_MINLEN) "s - " + /* restguthaben (7-stellig) + 3 */ + "%" xstr(EUR_FORMAT_MINLEN) "s - " + /* Anzahl -- 2-stellig + 3 */ + "%2d - " + /* Nickname (falls es vom Guthaben abgezogen wird) -- 10-stellig + 4 */ + "an %" xstr(NICKNAME_MAX_LEN)"s\r", + 17, status.transaction_id, time, name, price, rest, einheiten, + (*nickname != '\0' ? nickname : "Unbekannt")); + /* clang-format on */ + if (n > sizeof(print_buffer)) { + cprintf("\r\nprint_log(): print_buffer overflowed!\r\n" + "Wanted to write %d bytes\r\n%s\r\n", + n, print_buffer); + exit(1); + } + status.transaction_id++; print_the_buffer(); } @@ -145,12 +163,9 @@ static signed int buy(char *name, unsigned int price) { BYTE c, nickname_len; int einheiten; char nickname[NICKNAME_MAX_LEN + 1]; - char rest[10]; + char rest[EUR_FORMAT_MINLEN + 1]; struct credits_t *credit; - memset(nickname, '\0', sizeof(nickname)); - memset(rest, '\0', sizeof(rest)); - clrscr(); cprintf("Wieviel Einheiten \"%s\"? [1] \r\n", name); @@ -159,87 +174,14 @@ static signed int buy(char *name, unsigned int price) { if (einheiten > 100 || einheiten < -100 || einheiten == 0) { cprintf("\r\nEinheit nicht in [-100, 100] oder 0, Abbruch, dr" uUML "cke " "RETURN...\r\n"); - cgetc(); + cget_return(); return 1; } cprintf("\r\nAuf ein Guthaben kaufen? Wenn ja, Nickname eingeben:\r\n"); - { - BYTE i; - BYTE x; - BYTE y; - BYTE matches; - char *uniquematch; - input_terminator_t terminator; - while (1) { - terminator = get_input_terminated_by(INPUT_TERMINATOR_RETURN | - INPUT_TERMINATOR_SPACE, - nickname, sizeof(nickname)); - - /* Clear the screen from any previous completions */ - x = wherex(); - y = wherey(); - for (i = 1; i < 7; i++) { - /* "Completion:" is longer than NICKNAME_MAX_LEN */ - cclearxy(0, y + i, strlen("Completion:")); - } - gotoxy(x, y); - - if (terminator != INPUT_TERMINATOR_SPACE) { - break; - } - - matches = 0; - uniquematch = NULL; - for (i = 0; i < credits.num_items; i++) { - if (strncmp(nickname, credits.credits[i].nickname, strlen(nickname)) != - 0) { - continue; - } - matches++; - if (matches > 1) { - break; - } - uniquematch = credits.credits[i].nickname; - } - if (matches == 1) { - /* Display the rest of the nickname */ - textcolor(TC_LIGHT_GREEN); - cprintf("%s", uniquematch + strlen(nickname)); - textcolor(TC_LIGHT_GRAY); - strcat(nickname, uniquematch + strlen(nickname)); - } else { - /* Multiple nicknames match what was entered so far. Abort and - * display all matches, then prompt the user again. */ - char completion[NICKNAME_MAX_LEN + 1]; - BYTE len = strlen(nickname); - x = wherex(); - y = wherey(); - cprintf("\r\nCompletion:\r\n"); - matches = 0; - for (i = 0; i < credits.num_items; i++) { - if (strncmp(nickname, credits.credits[i].nickname, len) != 0) { - continue; - } - if (++matches == 5) { - cprintf("...\r\n"); - break; - } - strcpy(completion, credits.credits[i].nickname); - *(completion + len) = '\0'; - cprintf("%s", completion); - textcolor(TC_LIGHT_GREEN); - cprintf("%c", *(credits.credits[i].nickname + len)); - textcolor(TC_LIGHT_GRAY); - cprintf("%s\r\n", completion + len + 1); - } - gotoxy(x, y); - } - } - } + nickname_len = cget_nickname(nickname, sizeof(nickname)); - if (*nickname != '\0' && *nickname != PETSCII_SP) { - nickname_len = strlen(nickname); + if (nickname_len && *nickname != '\0' && *nickname != PETSCII_SP) { /* go through credits and remove the amount of money or set nickname * to NULL if no such credit could be found */ credit = find_credit(nickname); @@ -283,10 +225,6 @@ static signed int buy(char *name, unsigned int price) { cget_return(); return 0; } - } else { - /* Ensure that nickname is NULL if it's empty because it's used in print_log - */ - *nickname = '\0'; } money += price * einheiten;