check both main dir and parent dir (temp fix)
This commit is contained in:
parent
f4be64fe19
commit
4bef1a220c
3 changed files with 29 additions and 10 deletions
22
src/loader.c
22
src/loader.c
|
@ -6,21 +6,28 @@
|
|||
|
||||
#define MAX_FILE_SIZE 1024 * 16
|
||||
|
||||
void load_elements(hashmap *m, char *table, int use_inv) {
|
||||
int load_elements(hashmap *m, char *table, int use_inv) {
|
||||
FILE *fptr;
|
||||
|
||||
fptr = fopen(table, "r");
|
||||
|
||||
if (fptr == NULL)
|
||||
return 0;
|
||||
|
||||
char *str;
|
||||
|
||||
int did_something = 0;
|
||||
|
||||
while (1) {
|
||||
str = calloc(MAX_FILE_SIZE, sizeof(char));
|
||||
if (!fgets(str, MAX_FILE_SIZE, fptr))
|
||||
break;
|
||||
|
||||
did_something = 1;
|
||||
|
||||
if (use_inv) {
|
||||
hashmap_set(m, str, strlen(str) - 2, (uintptr_t)1);
|
||||
continue;
|
||||
hashmap_set(m, str, strlen(str) - 2, (uintptr_t)1);
|
||||
continue;
|
||||
}
|
||||
|
||||
char *combo = strstr(str, ";");
|
||||
|
@ -30,5 +37,14 @@ void load_elements(hashmap *m, char *table, int use_inv) {
|
|||
hashmap_set(m, combo, strlen(combo) - 1, (uintptr_t)str);
|
||||
}
|
||||
|
||||
|
||||
printf("%i\n",did_something);
|
||||
|
||||
if (!did_something) {
|
||||
free(str);
|
||||
}
|
||||
|
||||
return did_something;
|
||||
|
||||
// todo: properly free this
|
||||
}
|
|
@ -1,2 +1,2 @@
|
|||
#include "map.h"
|
||||
void load_elements(hashmap *m, char *table, int use_inv);
|
||||
int load_elements(hashmap *m, char *table, int use_inv);
|
15
src/main.c
15
src/main.c
|
@ -16,8 +16,9 @@ int main(int argc, char *argv[]) {
|
|||
char *command_re = calloc(MAX_BUF_LENGTH, sizeof(char));
|
||||
char **sort_tmp = calloc(MAX_COMBO_LENGTH, sizeof(char **));
|
||||
|
||||
load_elements(elements, "bin/combos.txt", 0);
|
||||
load_elements(inv, "bin/inv.txt", 1);
|
||||
load_elements(elements, "combos.txt", 0) ||
|
||||
load_elements(elements, "bin/combos.txt", 0);
|
||||
load_elements(inv, "inv.txt", 1) || load_elements(inv, "bin/inv.txt", 1);
|
||||
|
||||
printf("Welcome to Elemental on Command Line!\n");
|
||||
while (1) {
|
||||
|
@ -25,15 +26,16 @@ int main(int argc, char *argv[]) {
|
|||
|
||||
printf("\n");
|
||||
fgets(command, MAX_BUF_LENGTH - 1, stdin);
|
||||
int slashRan = slash_command(command,inv);
|
||||
if (slashRan) continue;
|
||||
int slashRan = slash_command(command, inv);
|
||||
if (slashRan)
|
||||
continue;
|
||||
|
||||
int combos = get_command(command, command_re, sort_tmp);
|
||||
|
||||
int failed = 0;
|
||||
for (int i = 0; i < combos; i++) {
|
||||
uintptr_t result;
|
||||
hashmap_get(inv, sort_tmp[i], strlen(sort_tmp[i]) - 1, &result);
|
||||
hashmap_get(inv, sort_tmp[i], strlen(sort_tmp[i]) - 1, &result);
|
||||
if (result != 1) {
|
||||
printf("You don't have %s.\n", sort_tmp[i]);
|
||||
failed = 1;
|
||||
|
@ -41,7 +43,8 @@ int main(int argc, char *argv[]) {
|
|||
}
|
||||
}
|
||||
|
||||
if (failed) continue;
|
||||
if (failed)
|
||||
continue;
|
||||
|
||||
uintptr_t result;
|
||||
hashmap_get(elements, command_re, strlen(command_re), &result);
|
||||
|
|
Loading…
Reference in a new issue