X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Flibgame%2Fmisc.c;h=3c61d46dd77a1dd033383856ec5371fce1ca61bb;hp=5d4a4acc4b2474792327e10fdf44dde90f3fb0c2;hb=b13dc8e30a0c07bea53bf168ae6d1017394d3c22;hpb=fffaec4e69e54c74cf5eea689191e81b8c19b85a diff --git a/src/libgame/misc.c b/src/libgame/misc.c index 5d4a4acc..3c61d46d 100644 --- a/src/libgame/misc.c +++ b/src/libgame/misc.c @@ -1350,13 +1350,35 @@ boolean FileIsArtworkType(char *basename, int type) struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, char *suffix_list[], - int num_list_entries) + int num_file_list_entries) { - struct FileInfo *file_list = - checked_calloc(num_list_entries * sizeof(struct FileInfo)); - int list_pos = 0; + struct FileInfo *file_list; + int num_suffix_list_entries = 0; + int list_pos = -1; int i, j; + file_list = checked_calloc(num_file_list_entries * sizeof(struct FileInfo)); + + for (i=0; suffix_list[i] != NULL; i++) + num_suffix_list_entries++; + + if (num_suffix_list_entries > 0) + { + for (i=0; i= num_list_entries) + list_pos++; + + if (list_pos >= num_file_list_entries) Error(ERR_EXIT, "inconsistant config list information -- please fix"); file_list[list_pos].token = config_list[i].token; file_list[list_pos].default_filename = config_list[i].value; - - list_pos++; } } - if (list_pos != num_list_entries) + if (list_pos != num_file_list_entries - 1) Error(ERR_EXIT, "inconsistant config list information -- please fix"); return file_list; @@ -1395,33 +1419,41 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, static void LoadArtworkConfig(struct ArtworkListInfo *artwork_info) { - int num_list_entries = artwork_info->num_list_entries; + int num_file_list_entries = artwork_info->num_file_list_entries; + int num_suffix_list_entries = artwork_info->num_suffix_list_entries; struct FileInfo *file_list = artwork_info->file_list; char *filename = getCustomArtworkConfigFilename(artwork_info->type); struct SetupFileList *setup_file_list; - int i; + int i, j; #if 0 printf("GOT CUSTOM ARTWORK CONFIG FILE '%s'\n", filename); #endif /* always start with reliable default values */ - for (i=0; iartwork_list == NULL || - list_pos >= artwork_info->num_list_entries) + list_pos >= artwork_info->num_file_list_entries) return; #if 0 @@ -1560,7 +1592,7 @@ void ReloadCustomArtworkList(struct ArtworkListInfo *artwork_info) { "Loading music:", TRUE } }; - int num_list_entries = artwork_info->num_list_entries; + int num_file_list_entries = artwork_info->num_file_list_entries; struct FileInfo *file_list = artwork_info->file_list; int i; @@ -1570,10 +1602,10 @@ void ReloadCustomArtworkList(struct ArtworkListInfo *artwork_info) DrawInitText(draw_init[artwork_info->type].text, 120, FC_GREEN); #if 0 - printf("DEBUG: reloading %d sounds ...\n", num_list_entries); + printf("DEBUG: reloading %d sounds ...\n", num_file_list_entries); #endif - for(i=0; itype].do_it) DrawInitText(file_list[i].token, 150, FC_YELLOW); @@ -1607,7 +1639,7 @@ void FreeCustomArtworkList(struct ArtworkListInfo *artwork_info) IS_CHILD_PROCESS(audio.mixer_pid) ? "CHILD" : "PARENT"); #endif - for(i=0; inum_list_entries; i++) + for(i=0; inum_file_list_entries; i++) deleteArtworkListEntry(artwork_info, &artwork_info->artwork_list[i]); #if 0 @@ -1618,7 +1650,7 @@ void FreeCustomArtworkList(struct ArtworkListInfo *artwork_info) free(artwork_info->artwork_list); artwork_info->artwork_list = NULL; - artwork_info->num_list_entries = 0; + artwork_info->num_file_list_entries = 0; }