X-Git-Url: https://plomlompom.com/repos/todo?a=blobdiff_plain;f=src%2Fwincontrol.c;h=4ebf9ef666a308d9fb6c5c5c94b3be8f9cfd7eee;hb=f6aaf0667ee0f1ab62342ff7becca2beb6cabc9c;hp=acb6c566cf02ea055544535d6117a6dc6ad5a9a8;hpb=3b2c82991c9ab169b33248c7be840a9bcd351e6d;p=plomrogue diff --git a/src/wincontrol.c b/src/wincontrol.c index acb6c56..4ebf9ef 100644 --- a/src/wincontrol.c +++ b/src/wincontrol.c @@ -1,10 +1,11 @@ /* wincontrol.c */ #include "wincontrol.h" +#include /* for malloc(), free() */ #include /* for strlen() */ #include /* for uint8_t, uint16_t */ #include "windows.h" /* for suspend_win(), append_win(), reset_pad_offset(), - * resize_active_win(), struct Win, struct WinMeta + * resize_active_win(), init_win(), structs Win, WinMeta */ #include "yx_uint16.h" /* for yx_uint16 struct */ #include "main.h" /* for Wins struct */ @@ -14,6 +15,37 @@ +extern struct Win init_win_from_file(struct World * world, char * w_name, + void (* f) (struct Win *)) +{ + char * err = "Trouble in init_win_from_file() with malloc()."; + char * prefix = "config/Win_"; + uint8_t size = strlen(prefix) + strlen(w_name) + 1; + char * path = malloc(size); + exit_err(NULL == path, world, err); + sprintf(path, "%s%s", prefix, w_name); + + err = "Trouble in init_win_from_file() with fopen()."; + FILE * file = fopen(path, "r"); + free(path); + exit_err(NULL == file, world, err); + uint16_t linemax; + textfile_sizes(file, &linemax, NULL); + char * line = malloc(linemax); + err = "Trouble in init_win_from_file() with fgets()."; + exit_err(NULL == fgets(line, linemax, file), world, err); + int16_t height = atoi(line); + exit_err(NULL == fgets(line, linemax, file), world, err); + int16_t width = atoi(line); + free(line); + err = "Trouble in init_win_from_file() with fclose()."; + exit_err(fclose(file), world, err); + + struct WinMeta * wmeta = world->wins.meta; + return init_win(wmeta, w_name, height, width, world, f); +} + + extern void sorted_wintoggle(struct World * world) {