From 82cdc707398b36a92b94c4513db4f63b084a69a1 Mon Sep 17 00:00:00 2001 From: Andrew Pamment Date: Fri, 19 Aug 2016 20:07:59 +1000 Subject: [PATCH] Attempt to fix file listing --- files.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) diff --git a/files.c b/files.c index 5f6f657..ec3c36f 100644 --- a/files.c +++ b/files.c @@ -569,6 +569,53 @@ void list_files(struct user_record *user) { s_putchar(files_e[i]->description[j]); } } + if (lines >= 18) { + lines = 0; + while (1) { + s_printf(get_string(70)); + s_readstring(buffer, 5); + if (strlen(buffer) == 0) { + s_printf("\r\n"); + break; + } else if (tolower(buffer[0]) == 'q') { + for (z=0;zfilename); + free(files_e[z]->description); + free(files_e[z]); + } + free(files_e); + s_printf("\r\n"); + return; + } else { + z = atoi(buffer); + if (z >= 0 && z < files_c) { + if (conf.file_directories[user->cur_file_dir]->file_subs[user->cur_file_sub]->download_sec_level <= user->sec_level) { + match = 0; + for (k=0;kfilename) == 0) { + match = 1; + break; + } + } + if (match == 0) { + if (tagged_count == 0) { + tagged_files = (char **)malloc(sizeof(char *)); + } else { + tagged_files = (char **)realloc(tagged_files, sizeof(char *) * (tagged_count + 1)); + } + tagged_files[tagged_count] = strdup(files_e[z]->filename); + tagged_count++; + s_printf(get_string(71), basename(files_e[z]->filename)); + } else { + s_printf(get_string(72)); + } + } else { + s_printf(get_string(73)); + } + } + } + } + } } while (1) { s_printf(get_string(75));