]> git.sur5r.net Git - c128-kasse/blobdiff - src/kasse.c
ziffer-handling: backspace-support, range check, nur ziffern
[c128-kasse] / src / kasse.c
index 977f8017b092a326a722c94c004f0ff6a608febc..7e652e0814c209072d90ac42102762e6e81a3622 100644 (file)
@@ -36,35 +36,62 @@ 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);
-               if ((i+16) < status.num_items) {
+               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+15) < 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);
+                       if (format_euro(profit, sizeof(profit), status.status[i+15].price) == NULL) {
+                               cprintf("Preis %ld konnte nicht umgerechnet werden\r\n", status.status[i+15].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+15);
+                       textcolor(TC_LIGHT_GRAY);
+                       cprintf(": %-" xstr(MAX_ITEM_NAME_LENGTH) "s \x7D%s, %3dx \x7D",
+                               status.status[i+15].item_name, profit, status.status[i+15].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");
 }
 
 /*
@@ -103,7 +130,7 @@ static signed int buy(char *name, unsigned int price) {
        int negative = 1;
        char entered[5] = {'1', 0, 0, 0, 0};
        BYTE i = 0, matches = 0;
-       BYTE c, nickname_len;
+       BYTE c, x, y, nickname_len;
        int einheiten;
        char *input;
        char nickname[11];
@@ -115,21 +142,48 @@ static signed int buy(char *name, unsigned int price) {
 
        clrscr();
        cprintf("Wieviel Einheiten \"%s\"? [1] \r\n", name);
+       x = wherex();
+       y = wherey();
        while (1) {
+               /* Buffer-Ende erreicht? */
+               if (i == 4)
+                       break;
+
                c = cgetc();
+               /* Enter */
                if (c == 13)
                        break;
-               cputc(c);
+               /* Backspace */
+               if (c == 20) {
+                       if (i == 0)
+                               continue;
+                       entered[--i] = '\0';
+                       cputcxy(x+i, y, ' ');
+                       gotoxy(x+i, y);
+                       continue;
+               }
                if (c == 27) {
                        cprintf("Kauf abgebrochen, druecke RETURN...\r\n");
                        get_input();
                        return 1;
-               } else if (c == '-' && i == 0)
+               }
+               if (c == '-' && i == 0) {
                        negative = -1;
-               else if (c > 47 && c < 58)
+                       cputc(c);
+               } else if (c > 47 && c < 58) {
                        entered[i++] = c;
+                       cputc(c);
+               }
+
+               /* Ungültige Eingabe (keine Ziffer), einfach ignorieren */
        }
        einheiten = atoi(entered) * negative;
+
+       if (einheiten > 100 || einheiten < -100 || einheiten == 0) {
+               cprintf("\r\nEinheit nicht in [-100, 100] oder 0, Abbruch, druecke RETURN...\r\n");
+               cgetc();
+               return 1;
+       }
        
        toggle_videomode();
        cprintf("\r\n             *** VERKAUF ***\r\n\r\n");
@@ -172,15 +226,19 @@ static signed int buy(char *name, unsigned int price) {
                                exit(1);
                        }
 
+                       textcolor(TC_LIGHT_GREEN);
                        cprintf("\r\nVerbleibendes Guthaben fuer %s: %s. Druecke RETURN...\r\n",
                                nickname, rest);
+                       textcolor(TC_LIGHT_GRAY);
                        toggle_videomode();
                        cprintf("\r\nDein Guthaben betraegt noch %s.\r\n", rest);
                        toggle_videomode();
                        get_input();
                        matches++;
                } else {
+                       textcolor(TC_LIGHT_RED);
                        cprintf("\r\nNickname nicht gefunden in der Guthabenverwaltung! Abbruch, druecke RETURN...\r\n");
+                       textcolor(TC_LIGHT_GRAY);
                        get_input();
                        return 0;
                }
@@ -272,6 +330,10 @@ int main() {
        if (VIDEOMODE == 40)
                toggle_videomode();
        clrscr();
+
+       /* Allocate logging buffer memory */
+       init_log();
+
        /* Set time initially, c128 doesn't know it */
        set_time_interactive();
 
@@ -291,7 +353,7 @@ int main() {
        sprintf(print_buffer, "%cC128-Kasse Version " GV "\r", 17);
        print_the_buffer();
 
-       sprintf(print_buffer, "%cKasse gestartet um %s. Nutze logfile log-%u, zeile %d.\r", 17, time, log_num, log_lines_written);
+       sprintf(print_buffer, "%cKasse gestartet um %s. Nutze logfile log-%u, offset %d.\r", 17, time, log_num, log_heap_offset);
        print_the_buffer();
 
        print_header();
@@ -315,13 +377,8 @@ int main() {
                } else if (*c == 's') {
                        save_items();
                        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"));
+                       log_flush();
+                       cprintf("\r\nStatefile/Creditfile/Log gesichert, druecke RETURN...\r\n");
                        get_input();
                } else if (*c == 'g') {
                        credit_manager();