X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Flibgame%2Fmisc.c;h=81ec00e7a1cc2245f1dd573d100a3c6e38296f48;hp=9d6e0cc9c9e461cd3e55d33f9ffb8e88a8e04e4f;hb=a8816d6e5319f9ec26a45346b08250f61e95c011;hpb=297ee9b33dab3bca9433befc81d7c7ce91450dd0 diff --git a/src/libgame/misc.c b/src/libgame/misc.c index 9d6e0cc9..81ec00e7 100644 --- a/src/libgame/misc.c +++ b/src/libgame/misc.c @@ -835,9 +835,13 @@ void GetOptions(char *argv[], void (*print_usage_function)(void)) options.debug = FALSE; options.debug_x11_sync = FALSE; +#if 1 + options.verbose = TRUE; +#else #if !defined(PLATFORM_UNIX) if (*options_left == NULL) /* no options given -- enable verbose mode */ options.verbose = TRUE; +#endif #endif while (*options_left) @@ -1043,8 +1047,11 @@ void Error(int mode, char *format, ...) char *process_name = ""; #if defined(PLATFORM_ANDROID) - android_log_prio = (mode & ERR_WARN ? ANDROID_LOG_WARN : - mode & ERR_EXIT ? ANDROID_LOG_FATAL : ANDROID_LOG_INFO); + android_log_prio = (mode & ERR_DEBUG ? ANDROID_LOG_DEBUG : + mode & ERR_INFO ? ANDROID_LOG_INFO : + mode & ERR_WARN ? ANDROID_LOG_WARN : + mode & ERR_EXIT ? ANDROID_LOG_FATAL : + ANDROID_LOG_UNKNOWN); #endif #if 1 @@ -1894,12 +1901,110 @@ void dumpList(ListNode *node_first) /* ------------------------------------------------------------------------- */ -/* functions for reading directories */ +/* functions for file handling */ +/* ------------------------------------------------------------------------- */ + +File *openFile(char *filename, char *mode) +{ + File *file = checked_calloc(sizeof(File)); + + file->file = fopen(filename, mode); + + if (file->file != NULL) + { + file->filename = getStringCopy(filename); + + return file; + } + +#if defined(PLATFORM_ANDROID) + file->asset_file = SDL_RWFromFile(filename, mode); + + if (file->asset_file != NULL) + { + file->file_is_asset = TRUE; + file->filename = getStringCopy(filename); + + return file; + } +#endif + + checked_free(file); + + return NULL; +} + +int closeFile(File *file) +{ + if (file == NULL) + return -1; + + int result; + +#if defined(PLATFORM_ANDROID) + if (file->asset_file) + result = SDL_RWclose(file->asset_file); +#endif + + if (file->file) + result = fclose(file->file); + + checked_free(file->filename); + checked_free(file); + + return result; +} + +int checkEndOfFile(File *file) +{ +#if defined(PLATFORM_ANDROID) + if (file->file_is_asset) + return file->end_of_file; +#endif + + return feof(file->file); +} + +char *getStringFromFile(File *file, char *line, int size) +{ +#if defined(PLATFORM_ANDROID) + if (file->file_is_asset) + { + if (file->end_of_file) + return NULL; + + char *line_ptr = line; + int num_bytes_read = 0; + + while (num_bytes_read < size - 1 && + SDL_RWread(file->asset_file, line_ptr, 1, 1) == 1 && + *line_ptr++ != '\n') + num_bytes_read++; + + *line_ptr = '\0'; + + if (strlen(line) == 0) + { + file->end_of_file = TRUE; + + return NULL; + } + + return line; + } +#endif + + return fgets(line, size, file->file); +} + + +/* ------------------------------------------------------------------------- */ +/* functions for directory handling */ /* ------------------------------------------------------------------------- */ -struct Directory *openDirectory(char *dir_name) +Directory *openDirectory(char *dir_name) { - struct Directory *dir = checked_calloc(sizeof(struct Directory)); + Directory *dir = checked_calloc(sizeof(Directory)); dir->dir = opendir(dir_name); @@ -1931,7 +2036,7 @@ struct Directory *openDirectory(char *dir_name) return NULL; } -int closeDirectory(struct Directory *dir) +int closeDirectory(Directory *dir) { if (dir == NULL) return -1; @@ -1955,7 +2060,7 @@ int closeDirectory(struct Directory *dir) return result; } -struct DirectoryEntry *readDirectory(struct Directory *dir) +DirectoryEntry *readDirectory(Directory *dir) { if (dir->dir_entry) freeDirectoryEntry(dir->dir_entry); @@ -1967,14 +2072,12 @@ struct DirectoryEntry *readDirectory(struct Directory *dir) { char line[MAX_LINE_LEN]; char *line_ptr = line; - char *last_line_ptr = line_ptr; int num_bytes_read = 0; - while (num_bytes_read < MAX_LINE_LEN && + while (num_bytes_read < MAX_LINE_LEN - 1 && SDL_RWread(dir->asset_toc_file, line_ptr, 1, 1) == 1 && *line_ptr != '\n') { - last_line_ptr = line_ptr; line_ptr++; num_bytes_read++; } @@ -1984,7 +2087,7 @@ struct DirectoryEntry *readDirectory(struct Directory *dir) if (strlen(line) == 0) return NULL; - dir->dir_entry = checked_calloc(sizeof(struct DirectoryEntry)); + dir->dir_entry = checked_calloc(sizeof(DirectoryEntry)); dir->dir_entry->is_directory = FALSE; if (line[strlen(line) - 1] = '/') @@ -2006,7 +2109,7 @@ struct DirectoryEntry *readDirectory(struct Directory *dir) if (dir_entry == NULL) return NULL; - dir->dir_entry = checked_calloc(sizeof(struct DirectoryEntry)); + dir->dir_entry = checked_calloc(sizeof(DirectoryEntry)); dir->dir_entry->basename = getStringCopy(dir_entry->d_name); dir->dir_entry->filename = getPath2(dir->filename, dir_entry->d_name); @@ -2015,12 +2118,18 @@ struct DirectoryEntry *readDirectory(struct Directory *dir) dir->dir_entry->is_directory = (stat(dir->dir_entry->filename, &file_status) == 0 && - (file_status.st_mode & S_IFMT) != S_IFDIR); + (file_status.st_mode & S_IFMT) == S_IFDIR); + +#if 0 + Error(ERR_INFO, "::: '%s' is directory: %d", + dir->dir_entry->basename, + dir->dir_entry->is_directory); +#endif return dir->dir_entry; } -void freeDirectoryEntry(struct DirectoryEntry *dir_entry) +void freeDirectoryEntry(DirectoryEntry *dir_entry) { if (dir_entry == NULL) return; @@ -2100,20 +2209,31 @@ boolean fileHasSuffix(char *basename, char *suffix) boolean FileIsGraphic(char *filename) { +#if 1 + return TRUE; +#else char *basename = getBaseNamePtr(filename); return fileHasSuffix(basename, "pcx"); +#endif } boolean FileIsSound(char *filename) { +#if 1 + return TRUE; +#else char *basename = getBaseNamePtr(filename); return fileHasSuffix(basename, "wav"); +#endif } boolean FileIsMusic(char *filename) { +#if 1 + return TRUE; +#else char *basename = getBaseNamePtr(filename); if (FileIsSound(basename)) @@ -2133,6 +2253,7 @@ boolean FileIsMusic(char *filename) #endif return FALSE; +#endif } boolean FileIsArtworkType(char *basename, int type) @@ -2390,10 +2511,13 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, } list_pos = 0; + for (i = 0; config_list[i].token != NULL; i++) { int len_config_token = strlen(config_list[i].token); +#if 0 int len_config_value = strlen(config_list[i].value); +#endif boolean is_file_entry = TRUE; for (j = 0; suffix_list[j].token != NULL; j++) @@ -2408,6 +2532,7 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, config_list[i].value); is_file_entry = FALSE; + break; } } @@ -2425,6 +2550,7 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, if (list_pos >= num_file_list_entries) break; +#if 0 /* simple sanity check if this is really a file definition */ if (!strEqual(&config_list[i].value[len_config_value - 4], ".pcx") && !strEqual(&config_list[i].value[len_config_value - 4], ".wav") && @@ -2434,6 +2560,7 @@ struct FileInfo *getFileListFromConfigList(struct ConfigInfo *config_list, config_list[i].token, config_list[i].value); Error(ERR_EXIT, "This seems to be no valid definition -- please fix"); } +#endif file_list[list_pos].token = config_list[i].token; file_list[list_pos].default_filename = config_list[i].value; @@ -3224,6 +3351,7 @@ static void LoadCustomArtwork(struct ArtworkListInfo *artwork_info, if (strEqual(file_list_entry->filename, UNDEFINED_FILENAME)) { deleteArtworkListEntry(artwork_info, listnode); + return; } @@ -3239,6 +3367,8 @@ void ReloadCustomArtworkList(struct ArtworkListInfo *artwork_info) artwork_info->num_dynamic_file_list_entries; int i; + print_timestamp_init("ReloadCustomArtworkList"); + for (i = 0; i < num_file_list_entries; i++) LoadCustomArtwork(artwork_info, &artwork_info->artwork_list[i], &file_list[i]); @@ -3247,6 +3377,8 @@ void ReloadCustomArtworkList(struct ArtworkListInfo *artwork_info) LoadCustomArtwork(artwork_info, &artwork_info->dynamic_artwork_list[i], &dynamic_file_list[i]); + print_timestamp_done("ReloadCustomArtworkList"); + #if 0 dumpList(artwork_info->content_list); #endif @@ -3344,8 +3476,11 @@ void NotifyUserAboutErrorFile() #if DEBUG -#define DEBUG_NUM_TIMESTAMPS 5 -#define DEBUG_TIME_IN_MICROSECONDS 0 +#define DEBUG_PRINT_INIT_TIMESTAMPS TRUE +#define DEBUG_PRINT_INIT_TIMESTAMPS_DEPTH 10 + +#define DEBUG_NUM_TIMESTAMPS 10 +#define DEBUG_TIME_IN_MICROSECONDS 0 #if DEBUG_TIME_IN_MICROSECONDS static double Counter_Microseconds() @@ -3409,7 +3544,11 @@ void debug_print_timestamp(int counter_nr, char *message) counter[counter_nr][1] = counter[counter_nr][0]; if (message) +#if 1 + Error(ERR_DEBUG, "%s%s%s %.3f %s", +#else printf("%s%s%s %.3f %s\n", +#endif debug_print_timestamp_get_padding(counter_nr * indent_size), message, debug_print_timestamp_get_padding(padding_size - strlen(message)), @@ -3433,4 +3572,69 @@ void debug_print_parent_only(char *format, ...) printf("\n"); } } + +void print_timestamp_ext(char *message, char *mode) +{ +#if DEBUG_PRINT_INIT_TIMESTAMPS + static char *debug_message = NULL; + static char *last_message = NULL; + static int counter_nr = 0; + int max_depth = DEBUG_PRINT_INIT_TIMESTAMPS_DEPTH; + + checked_free(debug_message); + debug_message = getStringCat3(mode, " ", message); + + if (strEqual(mode, "INIT")) + { + debug_print_timestamp(counter_nr, NULL); + + if (counter_nr + 1 < max_depth) + debug_print_timestamp(counter_nr, debug_message); + + counter_nr++; + + debug_print_timestamp(counter_nr, NULL); + } + else if (strEqual(mode, "DONE")) + { + counter_nr--; + + if (counter_nr + 1 < max_depth || + (counter_nr == 0 && max_depth == 1)) + { + last_message = message; + + if (counter_nr == 0 && max_depth == 1) + { + checked_free(debug_message); + debug_message = getStringCat3("TIME", " ", message); + } + + debug_print_timestamp(counter_nr, debug_message); + } + } + else if (!strEqual(mode, "TIME") || + !strEqual(message, last_message)) + { + if (counter_nr < max_depth) + debug_print_timestamp(counter_nr, debug_message); + } #endif +} + +void print_timestamp_init(char *message) +{ + print_timestamp_ext(message, "INIT"); +} + +void print_timestamp_time(char *message) +{ + print_timestamp_ext(message, "TIME"); +} + +void print_timestamp_done(char *message) +{ + print_timestamp_ext(message, "DONE"); +} + +#endif /* DEBUG */