X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Flibgame%2Fmisc.c;h=7637dc2d8473efc6ac661c9bd93a12c49d131b7c;hb=09e22b6b1f060be3ac1aca3937ff29c9d53e5866;hp=757872e8647a8c11d35b36238e3579c74fdc99a0;hpb=2e9b81c595b0150da80f8bf5ee56a74240fda6c1;p=rocksndiamonds.git diff --git a/src/libgame/misc.c b/src/libgame/misc.c index 757872e8..7637dc2d 100644 --- a/src/libgame/misc.c +++ b/src/libgame/misc.c @@ -1397,6 +1397,7 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, for (i=0; config_list[i].token != NULL; i++) { int len_config_token = strlen(config_list[i].token); + int len_config_value = strlen(config_list[i].value); boolean is_file_entry = TRUE; for (j=0; suffix_list[j].token != NULL; j++) @@ -1419,8 +1420,18 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, if (i > 0) list_pos++; - if (list_pos >= num_file_list_entries) - Error(ERR_EXIT, "inconsistant config list information -- please fix"); + if (list_pos > num_file_list_entries - 1) + break; + + /* simple sanity check if this is really a file definition */ + if (strcmp(&config_list[i].value[len_config_value - 4], ".pcx") != 0 && + strcmp(&config_list[i].value[len_config_value - 4], ".wav") != 0 && + strcmp(config_list[i].value, UNDEFINED_FILENAME) != 0) + { + Error(ERR_RETURN, "Configuration directive '%s' -> '%s':", + config_list[i].token, config_list[i].value); + Error(ERR_EXIT, "This seems to be no valid definition -- please fix"); + } file_list[list_pos].token = config_list[i].token; file_list[list_pos].default_filename = config_list[i].value; @@ -1558,6 +1569,10 @@ static void replaceArtworkListEntry(struct ArtworkListInfo *artwork_info, } else if ((*listnode = artwork_info->load_artwork(filename)) != NULL) { +#if 0 + printf("[adding new artwork '%s']\n", filename); +#endif + (*listnode)->num_references = 1; addNodeToList(&artwork_info->content_list, (*listnode)->source_filename, *listnode); @@ -1644,6 +1659,10 @@ void ReloadCustomArtworkList(struct ArtworkListInfo *artwork_info) DrawInitText(file_list[i].token, 150, FC_YELLOW); LoadArtworkToList(artwork_info, file_list[i].filename, i); + +#if 0 + printf("DEBUG: loading artwork file '%s'...\n", file_list[i].filename); +#endif } draw_init[artwork_info->type].do_it = FALSE;