]> git.sur5r.net Git - c128-kasse/blobdiff - src/kasse.c
Change drawing chars (#9)
[c128-kasse] / src / kasse.c
index c225d8783233d8045bc6a5cdd43fc288e746dc16..aab97fec2a99d08ca8b3ce839524fe32c31064f5 100644 (file)
 // drucker 4 oder 5
 // graphic 4,0,10
 
+void print_item(BYTE i) {
+    char profit[10];
+    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);
+    }
+    textcolor(TC_YELLOW);
+    cprintf("%2d", i);
+    textcolor(TC_LIGHT_GRAY);
+    cprintf(": %-" xstr(MAX_ITEM_NAME_LENGTH) "s \xDD%s, %3dx ",
+        status.status[i].item_name, profit, status.status[i].times_sold);
+}
+
 /* Hauptbildschirm ausgeben */
 static void print_screen(void) {
        BYTE i = 0;
@@ -32,41 +45,38 @@ static void print_screen(void) {
                exit(1);
        }
        textcolor(TC_CYAN);
-       cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r) " GV "\r");
+       cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r) " GV "\r\n");
        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("\r\nUhrzeit:     %s (wird nicht aktualisiert)\r\n"
+            "Eingenommen: %s, Verkauft: %ld Dinge, Drucken: %s\r\n",
+            time, profit, items_sold, (printing == 1 ? "ein" : "aus"));
        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");
+       cprintf("      \xB0"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB2"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB2"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB2"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\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");
-               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);
+        cprintf("      \xDD");
+        print_item(i);
+        cprintf("\xDD");
+
+        /* if we have more than 15 items, use the second column */
                if ((i+15) < status.num_items) {
+            print_item(i+15);
+            cprintf("\xDD");
+               } else {
+            cprintf("              \xDD                \xDD");
+        }
 
-                       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);
-                       }
-                       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("      \xAD"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB1"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB1"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xB1"
+            "\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xC0\xBD\r\n");
        textcolor(TC_YELLOW);
        cprintf("   s");
        textcolor(TC_LIGHT_GRAY);
@@ -128,10 +138,11 @@ static signed int buy(char *name, unsigned int price) {
        BYTE c, x, y, nickname_len;
        int einheiten;
        char *input;
-       char nickname[11];
+       char nickname[NICKNAME_MAX_LEN+1];
        char rest[11];
        struct credits_t *credit;
 
+       memset(nickname, '\0', sizeof(nickname));
        memset(rest, ' ', sizeof(rest));
        rest[8] = '\0';
 
@@ -146,10 +157,10 @@ static signed int buy(char *name, unsigned int price) {
 
                c = cgetc();
                /* Enter */
-               if (c == 13)
+               if (c == PETSCII_CR)
                        break;
                /* Backspace */
-               if (c == 20) {
+               if (c == PETSCII_DEL) {
                        if (i == 0)
                                continue;
                        entered[--i] = '\0';
@@ -165,7 +176,7 @@ static signed int buy(char *name, unsigned int price) {
                if (c == '-' && i == 0) {
                        negative = -1;
                        cputc(c);
-               } else if (c > 47 && c < 58) {
+               } else if (c >= PETSCII_0 && c <= PETSCII_9) {
                        entered[i++] = c;
                        cputc(c);
                }
@@ -184,10 +195,82 @@ static signed int buy(char *name, unsigned int price) {
        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");
-       input = get_input();
-       strncpy(nickname, input, 11);
+       {
+               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);
+                       }
+               }
+       }
        if (*nickname != '\0') {
                toggle_videomode();
                cprintf(" fuer %s\r\n", nickname);