]> git.sur5r.net Git - c128-kasse/blobdiff - kasse.c
fix printing, nice formatting used
[c128-kasse] / kasse.c
diff --git a/kasse.c b/kasse.c
index 7eb8df9542de8f44ecead7414a2e1f7adf1112d0..8bf25c56a51a78a27966c4b43f28f722096fb624 100644 (file)
--- a/kasse.c
+++ b/kasse.c
@@ -18,47 +18,67 @@ char print_buffer[81];
 void print_screen() {
        BYTE i = 0;
        char *time = get_time();
+       char profit[10];
        clrscr();
-       cprintf("C128-Kassenprogramm\r\n\r\nUhrzeit: %s (wird nicht aktualisiert\r\nEingenommen: %ld Cents, Verkauft: %ld Flaschen, Drucken: %s\r\n\r\n", time, money, items_sold, (printing == 1 ? "ein" : "aus"));
-       free(time);
-       for (; i < num_items; ++i)
-               cprintf("Eintrag %x: %s (%d Cents, %d mal verkauft)\r\n", i, status[i].item_name, status[i].price, status[i].times_sold);
-       cprintf("\r\nBefehle: s) Daten sichern d) Drucken umschalten\r\ng) Guthabenverwaltung z) Zeit setzen\r\n");
+       if (format_euro(profit, 10, money) == NULL) {
+               cprintf("Einname %ld konnte nicht umgerechnet werden\r\n", money);
+               exit(1);
+       }
+       cprintf("C128-Kassenprogramm (phil_fry, sECuRE, sur5r)\r\
+\r\nUhrzeit: %s (wird nicht aktualisiert)\r\
+Eingenommen: %s, Verkauft: %ld Flaschen, Drucken: %s\r\n\r\n", 
+       time, profit, items_sold, (printing == 1 ? "ein" : "aus"));
+       for (; i < status.num_items; ++i)
+               cprintf("Eintrag %x: %s (%d Cents, %d mal verkauft)\r\n",
+                       i, status.status[i].item_name, status.status[i].price, status.status[i].times_sold);
+       cprintf("\r\nBefehle: s) Daten sichern d) Drucken umschalten\r\
+g) Guthabenverwaltung     z) Zeit setzen\r\
+n) Neues Getraenk\r\n");
 }
 
-void log_file(char * s) {
-       FILE * f;
-       if (s==NULL)
+void log_file(char *s) {
+       /*FILE *f;
+       if (s == NULL)
                return;
-       f = fopen("log", "a");
-       if (f==NULL)
+       if ((f = fopen("log", "a")) == NULL)
                c128_perror(23, "kann logfile nicht oeffnen");
        fputs(s, f);
-       fclose(f);
+       fclose(f);*/
 }
 
 /* Druckt eine entsprechende Zeile aus */
 void print_log(BYTE n, int einheiten, char *nickname) {
        BYTE c;
+       char *time = get_time();
+       char price[10];
        /* Format: 
           Transaction-ID (Anzahl verkaufter Einträge, inklusive des zu druckenden!)
-          Uhrzeit (TODO)
+          Uhrzeit
           Eintragname (= Getränk)
           Preis (in Cents)
           Anzahl
           Nickname (falls es vom Guthaben abgezogen wird)
           */
-//     sprintf(print_buffer, "[%d] UHRZEIT - %s - %d - %d - an %s\r\n", items_sold, status[n].item_name, status[n].price, einheiten, (nickname != NULL ? nickname : "Unbekannt"));
+       if (format_euro(price, 10, status.status[n].price) == NULL) {
+               cprintf("Preis %d konnte nicht umgerechnet werden\r\n", status.status[n].price);
+               exit(1);
+       }
+               
+       sprintf(print_buffer, "[%lu] %s - %s - %s - %d - an %s\r\n",
+               items_sold, time, status.status[n].item_name, price, 
+               einheiten, (nickname != NULL ? nickname : "Unbekannt"));
        c = cbm_open((BYTE)4, (BYTE)4, (BYTE)0, NULL);
        if (c != 0) {
                c128_perror(c, "cbm_open(printer)");
-               save_state();
+               save_items();
+               save_credits();
                exit(1);
        }
        c = cbm_write((BYTE)4, print_buffer, strlen(print_buffer));
        if (c != strlen(print_buffer)) {
                c128_perror(c, "write(printer)");
-               save_state();
+               save_items();
+               save_credits();
                exit(1);
        }
        cbm_close((BYTE)4);
@@ -70,64 +90,62 @@ void buy(BYTE n) {
        int negative = 1;
        char entered[5] = {'1', 0, 0, 0, 0};
        BYTE i = 0, matches = 0;
-       BYTE c, nickname_len, single_match;
+       BYTE c, nickname_len;
        int einheiten;
        char *nickname;
-       if (status[n].item_name == NULL)
+
+       if (status.status[n].item_name == NULL) {
                cprintf("FEHLER: Diese Einheit existiert nicht.\r\n");
-       else {
-               cprintf("Wieviel Einheiten \"%s\"?\r\n", status[n].item_name);
-               while (1) {
-                       c = getchar();
-                       if (c == 13)
-                               break;
-                       else if (c == '-'&& i == 0)
-                               negative = -1;
-                       else if (c > 47 && c < 58)
-                               entered[i++] = c;
-               }
-               einheiten = atoi(entered) * negative;
-               cprintf("\r\nAuf ein Guthaben kaufen? Wenn ja, Nickname eingeben:\r\n");
-               nickname = get_input();
-               if (nickname[0] == '\0') {
-                       free(nickname);
-                       nickname = NULL;
-               } else {
-                       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 */
-                       for (c = 0; c < num_credit_items; ++c)
-                               if (strncmp(nickname, credits[c].nickname, nickname_len) == 0) {
-                                       if (++matches == 2)
-                                               break;
-                                       else single_match = c;
-                               }
-                       if (matches == 1) {
-                               if (credits[single_match].credit < (status[n].price * einheiten)) {
+               return;
+       }
+       cprintf("Wieviel Einheiten \"%s\"? [1] \r\n", status.status[n].item_name);
+       while (1) {
+               c = getchar();
+               if (c == 13)
+                       break;
+               else if (c == 27) {
+                       cprintf("Kauf abgebrochen, druecke RETURN...\r\n");
+                       get_input();
+                       return;
+               } else if (c == '-' && i == 0)
+                       negative = -1;
+               else if (c > 47 && c < 58)
+                       entered[i++] = c;
+       }
+       einheiten = atoi(entered) * negative;
+       cprintf("\r\nAuf ein Guthaben kaufen? Wenn ja, Nickname eingeben:\r\n");
+       nickname = get_input();
+       if (nickname != NULL && *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 */
+               for (c = 0; c < credits.num_items; ++c)
+                       if (strncmp(nickname, credits.credits[c].nickname, nickname_len) == 0) {
+                               if (credits.credits[c].credit < (status.status[n].price * einheiten)) {
                                        cprintf("Sorry, %s hat nicht genug Geld :-(\r\n", nickname);
-                                       free(nickname);
                                        return;
-                               } else {
-                                       /* Geld abziehen */
-                                       credits[single_match].credit -= (status[n].price * einheiten);
-                                       cprintf("\r\nVerbleibendes Guthaben fuer %s: %d Cents. Druecke ANYKEY...\r\n", nickname, credits[single_match].credit);
-                                       getchar();
                                }
-                       } else if (matches == 0) {
-                               // TODO
-                       } else {
-                               free(nickname);
-                               nickname = NULL;
+                               /* Geld abziehen */
+                               credits.credits[c].credit -= (status.status[n].price * einheiten);
+                               cprintf("\r\nVerbleibendes Guthaben fuer %s: %d Cents. Druecke RETURN...\r\n",
+                                       nickname, credits.credits[c].credit);
+                               get_input();
+                               matches++;
+                               break;
                        }
+               if (matches == 0) {
+                       cprintf("\r\nNickname nicht gefunden in der Guthabenverwaltung! Abbruch, druecke RETURN...\r\n");
+                       get_input();
                }
-               status[n].times_sold += einheiten;
-               money += status[n].price * einheiten;
-               items_sold += einheiten;
-               if (printing == 1)
-                       print_log(n, einheiten, nickname);
-               if (nickname != NULL)
-                       free(nickname);
+       } else {
+               /* Ensure that nickname is NULL if it's empty because it's used in print_log */
+               nickname = NULL;
        }
+       status.status[n].times_sold += einheiten;
+       money += status.status[n].price * einheiten;
+       items_sold += einheiten;
+       if (printing == 1)
+               print_log(n, einheiten, nickname);
 }
 
 void set_time_interactive() {
@@ -149,48 +167,55 @@ void set_time_interactive() {
 
        time = get_time();
        cprintf("Zeit gesetzt: %s\r\n", time);
-       free(time);
 }
 
 int main() {
-       BYTE c;
+       char *c;
+       toggle_videomode();
        /* Zeit erstmalig setzen */
        set_time_interactive();
        POKE(216, 255);
+       /* Variablen zurechtbiegen */
+       credits.num_items = 0;
+       status.num_items = 0;
        /* Konfigurationsdatei laden */
        load_config();
-       /* Einträge (=Getränke) laden */
+       /* Einträge (=Getränke) und Zustand laden */
        load_items();
-       /* Zustand laden */
-       load_state();
        /* Guthaben laden */
-//     load_credits();
+       load_credits();
        while (1) {
                /* Bildschirm anzeigen */
                print_screen();
                /* Tastatureingaben abfragen */
-               c = getchar();
+               c = get_input();
                /* und eventuell weitere Dialoge anzeigen */
-               if (c > 47 && c < 58)
-                       buy(c - 48);
-               else if (c == 's') {
+               if (*c > 47 && *c < 58)
+                       buy((*c) - 48);
+               else if (*c == 's') {
                        /* Zustandsdatei schreiben */
-                       save_state();
-//                     save_credits();
-                       cprintf("Statefile/Creditfile gesichert, druecke ANYKEY...\r\n");
-                       getchar();
-               } else if (c == 'd') {
+                       save_items();
+                       save_credits();
+                       cprintf("Statefile/Creditfile gesichert, druecke RETURN...\r\n");
+                       get_input();
+               } else if (*c == 'd') {
                        /* Drucken an- oder ausschalten */
                        printing = (printing == 1 ? 0 : 1);
-                       cprintf("Drucken ist nun %s, druecke ANYKEY...\r\n", (printing == 1 ? "eingeschaltet" : "ausgeschaltet"));
-                       getchar();
-               } else if (c == 'g') {
+                       cprintf("Drucken ist nun %s, druecke RETURN...\r\n", 
+                               (printing == 1 ? "eingeschaltet" : "ausgeschaltet"));
+                       get_input();
+               } else if (*c == 'g') {
                        /* Guthabenverwalter aufrufen */
                        credit_manager();
-               } else if (c == 'z') {
+               } else if (*c == 'z') {
                        /* Zeit setzen */
                        set_time_interactive();
-               } else if (c == 'q')
+               } else if (*c == 'n') {
+                       strcpy(status.status[status.num_items].item_name, "mate");
+                       status.status[status.num_items].price = 23;
+                       status.status[status.num_items].times_sold = 5;
+                       status.num_items++;
+               } else if (*c == 'q')
                        break;
        }
        cprintf("BYEBYE\r\n");