From 6ad79cbd562d04ebbcb61c774fb3389e70fedb7c Mon Sep 17 00:00:00 2001 From: Chun Kuan Lee Date: Sat, 23 Feb 2019 22:25:24 +0800 Subject: [PATCH] wallet: Use fsbridge::ifstream to fix Windows path issue --- src/fs.cpp | 2 ++ src/wallet/walletutil.cpp | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/src/fs.cpp b/src/fs.cpp index 3c8f4c02472..f937f64e04d 100644 --- a/src/fs.cpp +++ b/src/fs.cpp @@ -160,6 +160,7 @@ static std::string openmodeToStr(std::ios_base::openmode mode) void ifstream::open(const fs::path& p, std::ios_base::openmode mode) { close(); + mode |= std::ios_base::in; m_file = fsbridge::fopen(p, openmodeToStr(mode).c_str()); if (m_file == nullptr) { return; @@ -183,6 +184,7 @@ void ifstream::close() void ofstream::open(const fs::path& p, std::ios_base::openmode mode) { close(); + mode |= std::ios_base::out; m_file = fsbridge::fopen(p, openmodeToStr(mode).c_str()); if (m_file == nullptr) { return; diff --git a/src/wallet/walletutil.cpp b/src/wallet/walletutil.cpp index 6db4c63acbe..d779251d566 100644 --- a/src/wallet/walletutil.cpp +++ b/src/wallet/walletutil.cpp @@ -35,7 +35,7 @@ static bool IsBerkeleyBtree(const fs::path& path) boost::system::error_code ec; if (fs::file_size(path, ec) < 4096) return false; - fs::ifstream file(path.string(), std::ios::binary); + fsbridge::ifstream file(path, std::ios::binary); if (!file.is_open()) return false; file.seekg(12, std::ios::beg); // Magic bytes start at offset 12