X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=src%2Fkasse.c;h=3c59486bd46c4f2067f65cbad365b42be6caeedd;hb=142d3092a0455bf0404c7629cd07b92040ff2b9c;hp=70863885b2972845f6ee5f551b08a5bc28b75e30;hpb=aa0e1bb3a4ebf8d8b9a1b9f943d24e12275568a9;p=c128-kasse diff --git a/src/kasse.c b/src/kasse.c index 7086388..3c59486 100644 --- a/src/kasse.c +++ b/src/kasse.c @@ -36,38 +36,68 @@ static void print_screen() { cprintf("Einnahme %ld konnte nicht umgerechnet werden\r\n", money); exit(1); } - cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r) " GV "\r\ + textcolor(TC_CYAN); + cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r) " GV "\r"); + textcolor(TC_LIGHT_GRAY); + cprintf("\ \r\nUhrzeit: %s (wird nicht aktualisiert)\r\ Eingenommen: %s, Verkauft: %ld Dinge, Drucken: %s\r\n", time, profit, items_sold, (printing == 1 ? "ein" : "aus")); - cprintf("\xB0\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xAE\r\n"); + textcolor(TC_LIGHT_GRAY); + cprintf(" \xB0\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB2\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xAE\r\n"); for (; i < min(status.num_items, 15); ++i) { if (format_euro(profit, sizeof(profit), status.status[i].price) == NULL) { cprintf("Preis %ld konnte nicht umgerechnet werden\r\n", status.status[i].price); exit(1); } - cprintf("\x7D%2d: %-" xstr(MAX_ITEM_NAME_LENGTH) "s \x7D%s, %3dx \x7D", - i, status.status[i].item_name, profit, status.status[i].times_sold); + cprintf(" \x7D"); + textcolor(TC_YELLOW); + cprintf("%2d", i); + textcolor(TC_LIGHT_GRAY); + cprintf(": %-" xstr(MAX_ITEM_NAME_LENGTH) "s \x7D%s, %3dx \x7D", + status.status[i].item_name, profit, status.status[i].times_sold); if ((i+16) < status.num_items) { if (format_euro(profit, sizeof(profit), status.status[i+16].price) == NULL) { cprintf("Preis %ld konnte nicht umgerechnet werden\r\n", status.status[i+16].price); exit(1); } - cprintf("%2d: %-" xstr(MAX_ITEM_NAME_LENGTH) "s \x7D%s, %3dx \x7D", - i+16, status.status[i+16].item_name, profit, status.status[i+16].times_sold); + textcolor(TC_YELLOW); + cprintf("%2d", i+16); + textcolor(TC_LIGHT_GRAY); + cprintf(": %-" xstr(MAX_ITEM_NAME_LENGTH) "s \x7D%s, %3dx \x7D", + status.status[i+16].item_name, profit, status.status[i+16].times_sold); } else cprintf(" \x7D \x7D"); cprintf("\r\n"); } - cprintf("\xAD\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xBD\r\n"); - cprintf( -" s) Daten sichern d) Drucken umschalten\r\ - g) Guthabenverwaltung z) Zeit setzen\r\ - f) Freitext verkaufen q) Beenden\r\n"); + cprintf(" \xAD\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xB1\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\x60\xBD\r\n"); + textcolor(TC_YELLOW); + cprintf(" s"); + textcolor(TC_LIGHT_GRAY); + cprintf(") Daten sichern "); + textcolor(TC_YELLOW); + cprintf("g"); + textcolor(TC_LIGHT_GRAY); + cprintf(") Guthabenverwaltung\r\n"); + textcolor(TC_YELLOW); + cprintf(" z"); + textcolor(TC_LIGHT_GRAY); + cprintf(") Zeit setzen "); + textcolor(TC_YELLOW); + cprintf("f"); + textcolor(TC_LIGHT_GRAY); + cprintf(") Freitext verkaufen "); + textcolor(TC_YELLOW); + cprintf("q"); + textcolor(TC_LIGHT_GRAY); + cprintf(") Beenden\r\n"); } -/* Prints a line and logs it to file */ +/* + * Prints a line and logs it to file. Every line can be at max 80 characters. + * + */ static void print_log(char *name, int item_price, int einheiten, char *nickname, char *rest) { char *time = get_time(); char price[10]; @@ -75,7 +105,7 @@ static void print_log(char *name, int item_price, int einheiten, char *nickname, Transaction-ID (Anzahl verkaufter Einträge, inklusive des zu druckenden!) -- 6-stellig Uhrzeit -- 8-stellig Eintragname (= Getränk) -- 9-stellig - Preis (in Cents) -- 7-stellig + Preis (in Cents) -- 9-stellig Anzahl -- 2-stellig Nickname (falls es vom Guthaben abgezogen wird) -- 10-stellig restguthaben (9-stellig) @@ -88,9 +118,10 @@ static void print_log(char *name, int item_price, int einheiten, char *nickname, exit(1); } - sprintf(print_buffer, "%c[%3lu] %s - %-" xstr(MAX_ITEM_NAME_LENGTH) "s - %s - r %s - %d - an %s\r", 17, - items_sold, time, name, price, rest, + 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")); + status.transaction_id++; print_the_buffer(); } @@ -103,18 +134,20 @@ static signed int buy(char *name, unsigned int price) { int einheiten; char *input; char nickname[11]; - char rest[9]; + char rest[11]; struct credits_t *credit; memset(rest, ' ', sizeof(rest)); rest[8] = '\0'; + clrscr(); cprintf("Wieviel Einheiten \"%s\"? [1] \r\n", name); while (1) { - c = getchar(); + c = cgetc(); if (c == 13) break; - else if (c == 27) { + cputc(c); + if (c == 27) { cprintf("Kauf abgebrochen, druecke RETURN...\r\n"); get_input(); return 1; @@ -126,7 +159,8 @@ static signed int buy(char *name, unsigned int price) { einheiten = atoi(entered) * negative; toggle_videomode(); - cprintf("%dx %s fuer ", einheiten, name); + cprintf("\r\n *** VERKAUF ***\r\n\r\n"); + cprintf("%dx %s", einheiten, name); toggle_videomode(); cprintf("\r\nAuf ein Guthaben kaufen? Wenn ja, Nickname eingeben:\r\n"); @@ -134,20 +168,28 @@ static signed int buy(char *name, unsigned int price) { strncpy(nickname, input, 11); if (*nickname != '\0') { toggle_videomode(); - cprintf("%s\r\n", nickname); + cprintf(" fuer %s\r\n", nickname); toggle_videomode(); } - if (nickname != NULL && *nickname != '\0' && *nickname != 32) { + if (*nickname != '\0' && *nickname != 32) { nickname_len = strlen(nickname); /* 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); if (credit != NULL) { - if ((signed int)credit->credit < ((signed int)price * einheiten)) { - cprintf("Sorry, %s hat nicht genug Geld :-(\r\n", nickname); - get_input(); - return 0; + while ((signed int)credit->credit < ((signed int)price * einheiten)) { + if (format_euro(rest, 10, credit->credit) == NULL) { + cprintf("Preis %d konnte nicht umgerechnet werden\r\n", credit->credit); + exit(1); + } + cprintf("\r\n%s hat nicht genug Geld (%s). e) einzahlen a) abbruch \r\n", nickname, rest); + c = cgetc(); + if (c == 'e') { + deposit_credit(nickname); + } else { + return 0; + } } /* substract money */ credit->credit -= (price * einheiten); @@ -160,7 +202,7 @@ static signed int buy(char *name, unsigned int price) { cprintf("\r\nVerbleibendes Guthaben fuer %s: %s. Druecke RETURN...\r\n", nickname, rest); toggle_videomode(); - cprintf("\r\nDein verbleibendes Guthaben betraegt %s.\r\n", rest); + cprintf("\r\nDein Guthaben betraegt noch %s.\r\n", rest); toggle_videomode(); get_input(); matches++; @@ -209,10 +251,11 @@ void buy_custom() { cprintf("\r\nWie teuer ist \"%s\" (in cents)?\r\n", name); while (1) { - c = getchar(); + c = cgetc(); if (c == 13) break; - else if (c == 27) { + cputc(c); + if (c == 27) { cprintf("Kauf abgebrochen, druecke RETURN...\r\n"); get_input(); return; @@ -270,7 +313,7 @@ int main() { load_credits(); time = get_time(); - sprintf(print_buffer, "%c-----------------------------------------------------------------\r", 17); + sprintf(print_buffer, "%c--------------------------------------------------------------------------------\r", 17); print_the_buffer(); sprintf(print_buffer, "%cC128-Kasse Version " GV "\r", 17); print_the_buffer(); @@ -301,12 +344,6 @@ int main() { save_credits(); cprintf("Statefile/Creditfile gesichert, druecke RETURN...\r\n"); get_input(); - } else if (*c == 'd') { - /* enable/disable printing */ - printing = (printing == 1 ? 0 : 1); - cprintf("Drucken ist nun %s, druecke RETURN...\r\n", - (printing == 1 ? "eingeschaltet" : "ausgeschaltet")); - get_input(); } else if (*c == 'g') { credit_manager(); } else if (*c == 'z') {