1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
#include <stdint.h>
#include "dbhandling.h"
#include "enum.h"
const uint8_t PATH_MAX = 64;
const char *filepath = ".local/share/sqlite";
const char *filename = "library.db";
void print_help(void)
{
printf("\n");
printf("usage: myal MODE TARGET NAME [EPISODE|CHAPTER] \n");
printf("possible modes are: get|set|add \n");
printf("possible targets are: anime|manga|book \n");
printf("EXAMPLES: myal get anime %% | Prints all anime \n");
printf(" myal set manga Murcielago 10 | Set chapter of " \
"Murcielago to 10\n");
printf("mode get is fuzzy; set and add have to match exactly \n");
printf("See more examples in the readme. \n");
printf("\n");
}
int main(int argc, char **argv)
{
if (argc < 3) {
fprintf(stderr, "missing argument...\n");
print_help();
exit(69);
}
args_e mode;
mode = str2enum(argv[1]);
args_e target;
target = str2enum(argv[2]);
entry_t *entry = malloc(sizeof(entry_t));
entry->name = malloc(128 * sizeof(char));
entry->author = malloc(64 * sizeof(char));
entry->value = malloc(16 * sizeof(char));
entry->status = malloc(16 * sizeof(char));
char fullpath[PATH_MAX];
snprintf(fullpath, PATH_MAX, "%s/%s/%s", getenv("HOME"), filepath, filename);
sqlite3 *db;
int rc;
rc = sqlite3_open(fullpath, &db);
if (rc) {
exit_with_error(db, "Can't open database: ");
}
switch (mode) {
case GET:
select_from_table(db, target, entry);
break;
case SET:
update_entry(db, target, entry);
break;
case ADD:
add_entry(db, target, entry);
break;
default:
fprintf(stderr, "unknown option...\n");
print_help();
sqlite3_close(db);
exit(69);
}
sqlite3_close(db);
free(entry);
return 0;
}
|