check both main dir and parent dir (temp fix)

This commit is contained in:
biglyderv 2025-03-25 13:43:02 -04:00
parent f4be64fe19
commit 4bef1a220c
Signed by: biglyderv
GPG key ID: 0E2EB0B4CD7397B5
3 changed files with 29 additions and 10 deletions

View file

@ -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
}

View file

@ -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);

View file

@ -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);