From f8aa7d2a399ba7427e22c474191b1bd3331b647c Mon Sep 17 00:00:00 2001 From: Aldrik Ramaekers Date: Sat, 16 Mar 2024 11:49:21 +0100 Subject: retrieve file size during dir iteration instead of after opening file --- src/unix/main_unix.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'src/unix') diff --git a/src/unix/main_unix.cpp b/src/unix/main_unix.cpp index 755b617..0c58d02 100644 --- a/src/unix/main_unix.cpp +++ b/src/unix/main_unix.cpp @@ -303,10 +303,14 @@ void ts_platform_list_files_block(ts_search_result* result, wchar_t* start_dir) ts_found_file* f = (ts_found_file*)ts_memory_bucket_reserve(&result->memory, sizeof(ts_found_file)); f->path = (utf8_int8_t*)ts_memory_bucket_reserve(&result->memory, MAX_INPUT_LENGTH); + strcpy(f->path, complete_file_path); f->match_count = 0; f->error = 0; f->collapsed = false; - strcpy(f->path, complete_file_path); + + struct stat file_stat; + stat(f->path, &file_stat); + f->file_size = file_stat.st_size; ts_mutex_lock(&result->files.mutex); ts_array_push_size(&result->files, &f, sizeof(ts_found_file*)); -- cgit v1.2.3-70-g09d2