Merge pull request #9663

978f1d7 Fix get_database_size on Windows (iamamyth)
This commit is contained in:
tobtoht 2025-01-14 14:32:20 +00:00
commit 8c08863d60
No known key found for this signature in database
GPG Key ID: E45B10DD027D2472
4 changed files with 8 additions and 44 deletions

View File

@ -38,7 +38,6 @@ namespace file_io_utils
bool is_file_exist(const std::string& path); bool is_file_exist(const std::string& path);
bool save_string_to_file(const std::string& path_to_file, const std::string& str); bool save_string_to_file(const std::string& path_to_file, const std::string& str);
bool load_file_to_string(const std::string& path_to_file, std::string& target_str, size_t max_size = 1000000000); bool load_file_to_string(const std::string& path_to_file, std::string& target_str, size_t max_size = 1000000000);
bool get_file_size(const std::string& path_to_file, uint64_t &size);
} }
} }

View File

@ -149,40 +149,5 @@ namespace file_io_utils
} }
#endif #endif
} }
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
}
} }
} }

View File

@ -34,7 +34,6 @@
#include <cstring> // memcpy #include <cstring> // memcpy
#include "string_tools.h" #include "string_tools.h"
#include "file_io_utils.h"
#include "common/util.h" #include "common/util.h"
#include "common/pruning.h" #include "common/pruning.h"
#include "cryptonote_basic/cryptonote_format_utils.h" #include "cryptonote_basic/cryptonote_format_utils.h"
@ -4536,12 +4535,11 @@ bool BlockchainLMDB::is_read_only() const
uint64_t BlockchainLMDB::get_database_size() const uint64_t BlockchainLMDB::get_database_size() const
{ {
uint64_t size = 0;
boost::filesystem::path datafile(m_folder); boost::filesystem::path datafile(m_folder);
datafile /= CRYPTONOTE_BLOCKCHAINDATA_FILENAME; datafile /= CRYPTONOTE_BLOCKCHAINDATA_FILENAME;
if (!epee::file_io_utils::get_file_size(datafile.string(), size)) boost::system::error_code ec{};
size = 0; const boost::uintmax_t size = boost::filesystem::file_size(datafile, ec);
return size; return (ec ? 0 : static_cast<uint64_t>(size));
} }
void BlockchainLMDB::fixup() void BlockchainLMDB::fixup()

View File

@ -30,7 +30,6 @@
#include <atomic> #include <atomic>
#include <boost/filesystem.hpp> #include <boost/filesystem.hpp>
#include <boost/thread/thread.hpp> #include <boost/thread/thread.hpp>
#include "file_io_utils.h"
#include "net/http_client.h" #include "net/http_client.h"
#include "download.h" #include "download.h"
@ -73,8 +72,11 @@ namespace tools
{ {
boost::unique_lock<boost::mutex> lock(control->mutex); boost::unique_lock<boost::mutex> lock(control->mutex);
std::ios_base::openmode mode = std::ios_base::out | std::ios_base::binary; std::ios_base::openmode mode = std::ios_base::out | std::ios_base::binary;
uint64_t existing_size = 0; boost::system::error_code ec{};
if (epee::file_io_utils::get_file_size(control->path, existing_size) && existing_size > 0) uint64_t existing_size = static_cast<uint64_t>(boost::filesystem::file_size(control->path, ec));
if (ec)
existing_size = 0;
if (existing_size > 0)
{ {
MINFO("Resuming downloading " << control->uri << " to " << control->path << " from " << existing_size); MINFO("Resuming downloading " << control->uri << " to " << control->path << " from " << existing_size);
mode |= std::ios_base::app; mode |= std::ios_base::app;