]> git.sur5r.net Git - c128-kasse/blob - src/credit_manager.c
4cd9bb5dd1f07ee214d095c4bd3a44be70c1c358
[c128-kasse] / src / credit_manager.c
1 /*
2  * RGB2R-C128-Kassenprogramm
3  * © 2007-2009 phil_fry, sECuRE, sur5r
4  * See LICENSE for license information
5  *
6  */
7 #include <conio.h>
8 #include <stdio.h>
9 #include <stdlib.h>
10 #include <string.h>
11
12 #include "config.h"
13 #include "general.h"
14 #include "kasse.h"
15 #include "c128time.h"
16 #include "print.h"
17 #include "version.h"
18 #include "vdc_patch_charset.h"
19
20 static char *filter = NULL;
21 static BYTE filter_len;
22
23 static BYTE current_credits_page = 0;
24
25 static void credit_print_screen(void) {
26   BYTE i, pages;
27   char buffer[EUR_FORMAT_MINLEN + 1];
28
29   clrscr();
30   cprintf("credit_manager (phil_fry, sECuRE, sur5r) v:" GV "\r\n\r\n");
31   pages = (credits.num_items / CREDITS_PER_PAGE);
32   if (current_credits_page > pages)
33     current_credits_page = pages;
34   cprintf("Datei: CREDITS (Seite %d von %d)\r\n\r\n", current_credits_page,
35           pages);
36   for (i = (current_credits_page * CREDITS_PER_PAGE);
37        i < credits.num_items &&
38        i < ((current_credits_page + 1) * CREDITS_PER_PAGE);
39        i++) {
40     if (filter == NULL ||
41         strncmp(credits.credits[i].nickname, filter, filter_len) == 0) {
42       if (format_euro(buffer, sizeof(buffer), credits.credits[i].credit) !=
43           buffer) {
44         cprintf("Error: Could not format credit %d\r\n",
45                 credits.credits[i].credit);
46         exit(1);
47       }
48
49       cprintf("%d: %s: %s\r\n", i, credits.credits[i].nickname, buffer);
50     }
51   }
52   cprintf("\r\nn) Neu d) L" oUML "schen p) Einzahlen b) Seite hoch "
53           "f) Seite runter\r\ng) Filtern e) " AUML "ndern s) Speichern "
54           "z) Zur" uUML "ck\r\n");
55 }
56
57 static int8_t find_credit_idx(char *name) {
58   int8_t i;
59   for (i = 0; i < credits.num_items; ++i) {
60     if (strncmp(name, credits.credits[i].nickname, NICKNAME_MAX_LEN + 1) == 0) {
61       return i;
62     }
63   }
64   return -1;
65 }
66
67 struct credits_t *find_credit(char *name) {
68   int i;
69   if ((i = find_credit_idx(name)) >= 0) {
70     return &credits.credits[i];
71   }
72   return NULL;
73 }
74
75 void deposit_credit(char *nickname) {
76   char *time = get_time();
77   struct credits_t *credit;
78   unsigned int deposit;
79
80   if ((credit = find_credit(nickname)) == NULL)
81     return; // cannot find named credit
82
83   cprintf("\r\nEinzahlung in Cent:\r\n");
84   if ((deposit = cget_number(0)) == 0)
85     return;
86
87   credit->credit += deposit;
88
89   print_the_buffer();
90   cprintf("\r\nEinzahlung durchgef" uUML "hrt, dr" uUML "cke RETURN...\r\n");
91   cget_return();
92 }
93
94 static void new_credit(void) {
95   char name[NICKNAME_MAX_LEN + 1];
96   char *time;
97   int credit;
98
99   if (credits.num_items == MAX_CREDIT_ITEMS) {
100     cprintf("\rEs ist bereits die maximale Anzahl an Eintr" aUML
101             "gen erreicht, dr" uUML "cke RETURN...\r\n");
102     cget_return();
103     return;
104   }
105
106   clrscr();
107   cprintf("\rNickname (max. 10 Zeichen):\r\n");
108   if (cgetn_input(name, sizeof(name)) == 0)
109     return;
110
111   if (find_credit_idx(name) >= 0) {
112     cprintf("\rNickname existiert bereits, dr" uUML "cke RETURN...\r\n");
113     cget_return();
114     return;
115   }
116
117   cprintf("\r\nGuthaben in Cents:\r\n");
118   if ((credit = cget_number(0)) == 0)
119     return;
120   strncpy(credits.credits[credits.num_items].nickname, name, NICKNAME_MAX_LEN);
121   credits.credits[credits.num_items].credit = credit;
122
123   time = get_time();
124   sprintf(print_buffer, "%c%s - Guthaben mit %d Cent f" uUML "r %s angelegt\r",
125           17, time, credit, name);
126   print_the_buffer();
127
128   credits.num_items++;
129 }
130
131 static void delete_credit(char *nickname) {
132   char *input;
133   int8_t i;
134   if ((i = find_credit_idx(nickname)) < 0) {
135     cprintf("\r Nick existiert nicht\r\n");
136     return;
137   }
138   --credits.num_items;
139   if (i != credits.num_items) {
140     credits.credits[i] = credits.credits[credits.num_items];
141   }
142   memset(credits.credits[credits.num_items].nickname, '\0',
143          NICKNAME_MAX_LEN + 1);
144   credits.credits[credits.num_items].credit = 0;
145   return;
146 }
147
148 void credit_manager() {
149   char nickname[NICKNAME_MAX_LEN + 1];
150   char *c;
151   while (1) {
152     credit_print_screen();
153     c = get_input();
154     switch (*c) {
155     case 'n':
156       new_credit();
157       break;
158     case 'd':
159       cputs("\rName?\r\n");
160       if (cget_nickname(nickname, sizeof(nickname))) {
161         delete_credit(nickname);
162       }
163       break;
164     case 's':
165       save_credits();
166       break;
167     case 'f':
168       if (current_credits_page < (credits.num_items / CREDITS_PER_PAGE))
169         current_credits_page++;
170       break;
171     case 'b':
172       if (current_credits_page > 0)
173         current_credits_page--;
174       break;
175     case 'p':
176       cputs("\rName?\r\n");
177       if (cget_nickname(nickname, sizeof(nickname))) {
178         deposit_credit(nickname);
179       }
180       break;
181     case 'g':
182       cprintf("Filter eingeben:\r\n");
183       filter = get_input();
184       if (filter == NULL || *filter == PETSCII_SP ||
185           (filter_len = strlen(filter)) == 0)
186         filter = NULL;
187       break;
188     case 'z':
189       save_credits();
190       return;
191     default:
192       cprintf("Unbekannter Befehl, dr" uUML "cke RETURN...\r\n");
193       cget_return();
194     }
195   }
196 }