]> git.sur5r.net Git - c128-kasse/blob - src/credit_manager.c
Fix incorrect free()
[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 struct credits_t *find_credit(char *name) {
58   int 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 &credits.credits[i];
62   return NULL;
63 }
64
65 void deposit_credit(char *nickname) {
66   char *time = get_time();
67   struct credits_t *credit;
68   unsigned int deposit;
69
70   if ((credit = find_credit(nickname)) == NULL)
71     return; // cannot find named credit
72
73   cprintf("\r\nEinzahlung in Cent:\r\n");
74   if (cget_number(0) == 0)
75     return;
76
77   credit->credit += deposit;
78
79   print_the_buffer();
80   cprintf("\r\nEinzahlung durchgef" uUML "hrt, dr" uUML "cke RETURN...\r\n");
81   cget_return();
82 }
83
84 static void new_credit(void) {
85   char name[NICKNAME_MAX_LEN + 1];
86   char *time;
87   int credit;
88
89   if (credits.num_items == MAX_CREDIT_ITEMS) {
90     cprintf("\rEs ist bereits die maximale Anzahl an Eintr" aUML
91             "gen erreicht, dr" uUML "cke RETURN...\r\n");
92     cget_return();
93     return;
94   }
95
96   clrscr();
97   cprintf("\rNickname (max. 10 Zeichen):\r\n");
98   if (cgetn_input(name, sizeof(name)) == 0)
99     return;
100
101   cprintf("\r\nGuthaben in Cents:\r\n");
102   if ((credit = cget_number(0)) == 0)
103     return;
104   strncpy(credits.credits[credits.num_items].nickname, name, NICKNAME_MAX_LEN);
105   credits.credits[credits.num_items].credit = credit;
106
107   time = get_time();
108   sprintf(print_buffer, "%c%s - Guthaben mit %d Cent f" uUML "r %s angelegt\r",
109           17, time, credit, name);
110   print_the_buffer();
111
112   credits.num_items++;
113 }
114
115 static void _delete_credit(BYTE num) {
116   memset(credits.credits[num].nickname, '\0', NICKNAME_MAX_LEN + 1);
117   credits.credits[num].credit = 0;
118 }
119
120 static void delete_credit(void) {
121   char *input;
122   BYTE num, last;
123
124   cprintf("\r Welcher Eintrag soll gel" oUML "scht werden?\r\n");
125   if ((input = get_input()) == NULL || *input == '\0')
126     return;
127   num = atoi(input);
128   if (credits.num_items > 1) {
129     /* Swap last item with this one and delete the last one to avoid holes */
130     last = (credits.num_items - 1);
131     strncpy(credits.credits[num].nickname, credits.credits[last].nickname,
132             NICKNAME_MAX_LEN);
133     credits.credits[num].credit = credits.credits[last].credit;
134     _delete_credit(last);
135   } else {
136     /* Just delete it */
137     _delete_credit(num);
138   }
139   credits.num_items--;
140 }
141
142 void credit_manager() {
143   char nickname[NICKNAME_MAX_LEN + 1];
144   char *c;
145   while (1) {
146     credit_print_screen();
147     c = get_input();
148     switch (*c) {
149     case 'n':
150       new_credit();
151       break;
152     case 'd':
153       delete_credit();
154       break;
155     case 's':
156       save_credits();
157       break;
158     case 'f':
159       if (current_credits_page < (credits.num_items / CREDITS_PER_PAGE))
160         current_credits_page++;
161       break;
162     case 'b':
163       if (current_credits_page > 0)
164         current_credits_page--;
165       break;
166     case 'p':
167       cputs("\rName?\r\n");
168       if (cgetn_input(nickname, sizeof(nickname)))
169         deposit_credit(nickname);
170       break;
171     case 'g':
172       cprintf("Filter eingeben:\r\n");
173       filter = get_input();
174       if (filter == NULL || *filter == PETSCII_SP ||
175           (filter_len = strlen(filter)) == 0)
176         filter = NULL;
177       break;
178     case 'z':
179       save_credits();
180       return;
181     default:
182       cprintf("Unbekannter Befehl, dr" uUML "cke RETURN...\r\n");
183       cget_return();
184     }
185   }
186 }