From 5fe16708d63a0d1d4328b7ed1a639c1996bb3c78 Mon Sep 17 00:00:00 2001 From: jeffro256 Date: Thu, 10 Oct 2024 12:43:57 -0500 Subject: [PATCH] epee: use `std::filesystem::file_size` to implement `epee::file_io_utils::get_file_size` Fixes #9513 --- contrib/epee/src/file_io_utils.cpp | 33 ++++-------------------------- 1 file changed, 4 insertions(+), 29 deletions(-) diff --git a/contrib/epee/src/file_io_utils.cpp b/contrib/epee/src/file_io_utils.cpp index c0798a510..41e320675 100644 --- a/contrib/epee/src/file_io_utils.cpp +++ b/contrib/epee/src/file_io_utils.cpp @@ -26,6 +26,7 @@ #include "file_io_utils.h" +#include #include #include #include @@ -153,35 +154,9 @@ namespace file_io_utils bool get_file_size(const std::string& path_to_file, uint64_t &size) { -#ifdef _WIN32 - std::wstring wide_path; - try { wide_path = string_tools::utf8_to_utf16(path_to_file); } catch (...) { return false; } - HANDLE file_handle = CreateFileW(wide_path.c_str(), GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); - if (file_handle == INVALID_HANDLE_VALUE) - return false; - LARGE_INTEGER file_size; - BOOL result = GetFileSizeEx(file_handle, &file_size); - CloseHandle(file_handle); - if (result) { - size = file_size.QuadPart; - } - return size; -#else - try - { - std::ifstream fstream; - fstream.exceptions(std::ifstream::failbit | std::ifstream::badbit); - fstream.open(path_to_file, std::ios_base::binary | std::ios_base::in | std::ios::ate); - size = fstream.tellg(); - fstream.close(); - return true; - } - - catch(...) - { - return false; - } -#endif + std::error_code ec; + size = static_cast(std::filesystem::file_size(path_to_file, ec)); + return !ec; } }