+ }
+ winconf_ids[i] = '\0';
+ exit_err(errno, world, err_r);
+ exit_err(closedir(dp), world, err_c);
+ world->winconf_ids = try_malloc(strlen(winconf_ids + 1), world, f_name);
+ memcpy(world->winconf_ids, winconf_ids, strlen(winconf_ids) + 1);
+ free(winconf_ids);
+
+ struct WinConf * winconfs;
+ winconfs = try_malloc(strlen(world->winconf_ids) * sizeof(struct WinConf),
+ world, f_name);
+ i = 0;
+ while (0 != (id = get_next_winconf_id(world)))
+ {
+ create_winconf(id, &winconfs[i]);
+ i++;
+ }
+ world->winconfs = winconfs;
+ while (0 != (id = get_next_winconf_id(world)))
+ {
+ init_winconf_from_file(world, id);
+ i++;
+ }
+}
+
+
+
+extern void free_winconf(struct World * world, char id)
+{
+ struct WinConf * wc = get_winconf_by_id(world, id);
+ free(wc->title);
+}
+
+
+
+extern void free_winconfs(struct World * world)
+{
+ char id;
+ while (0 != (id = get_next_winconf_id(world)))
+ {
+ free_winconf(world, id);
+ }
+ free(world->winconf_ids);
+ free(world->winconfs);
+}
+
+
+
+extern void init_wins(struct World * world)
+{
+ char id;
+ while (0 != (id = get_next_winconf_id(world)))
+ {
+ init_win_from_winconf(world, id);
+ }
+}
+
+
+
+extern void free_wins(struct World * world)
+{
+ char id;
+ while (0 != (id = get_next_winconf_id(world)))
+ {
+ free_win(get_win_by_id(world, id));
+ }
+}
+
+
+
+extern void sorted_wintoggle(struct World * world)
+{
+ char * f_name = "sorted_wintoggle()";
+ char * path = "config/windows/toggle_order";
+ FILE * file = try_fopen(path, "r", world, f_name);
+ uint16_t linemax = get_linemax(file, world, f_name);
+ char win_order[linemax + 1];
+ try_fgets(win_order, linemax + 1, file, world, f_name);
+ try_fclose(file, world, f_name);
+ uint8_t i = 0;
+ for (; i < linemax - 1; i++)
+ {
+ if (NULL == strchr(world->winconf_ids, win_order[i]))