summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
Diffstat (limited to 'src/common')
-rw-r--r--src/common/file_util.cpp37
-rw-r--r--src/common/file_util.h14
2 files changed, 41 insertions, 10 deletions
diff --git a/src/common/file_util.cpp b/src/common/file_util.cpp
index 35eee0096..45b750e1e 100644
--- a/src/common/file_util.cpp
+++ b/src/common/file_util.cpp
@@ -888,7 +888,14 @@ std::string SanitizePath(std::string_view path_, DirectorySeparator directory_se
888 } 888 }
889 889
890 std::replace(path.begin(), path.end(), type1, type2); 890 std::replace(path.begin(), path.end(), type1, type2);
891 path.erase(std::unique(path.begin(), path.end(), 891
892 auto start = path.begin();
893#ifdef _WIN32
894 // allow network paths which start with a double backslash (e.g. \\server\share)
895 if (start != path.end())
896 ++start;
897#endif
898 path.erase(std::unique(start, path.end(),
892 [type2](char c1, char c2) { return c1 == type2 && c2 == type2; }), 899 [type2](char c1, char c2) { return c1 == type2 && c2 == type2; }),
893 path.end()); 900 path.end());
894 return std::string(RemoveTrailingSlash(path)); 901 return std::string(RemoveTrailingSlash(path));
@@ -967,6 +974,34 @@ bool IOFile::Flush() {
967 return IsOpen() && 0 == std::fflush(m_file); 974 return IsOpen() && 0 == std::fflush(m_file);
968} 975}
969 976
977std::size_t IOFile::ReadImpl(void* data, std::size_t length, std::size_t data_size) const {
978 if (!IsOpen()) {
979 return std::numeric_limits<std::size_t>::max();
980 }
981
982 if (length == 0) {
983 return 0;
984 }
985
986 DEBUG_ASSERT(data != nullptr);
987
988 return std::fread(data, data_size, length, m_file);
989}
990
991std::size_t IOFile::WriteImpl(const void* data, std::size_t length, std::size_t data_size) {
992 if (!IsOpen()) {
993 return std::numeric_limits<std::size_t>::max();
994 }
995
996 if (length == 0) {
997 return 0;
998 }
999
1000 DEBUG_ASSERT(data != nullptr);
1001
1002 return std::fwrite(data, data_size, length, m_file);
1003}
1004
970bool IOFile::Resize(u64 size) { 1005bool IOFile::Resize(u64 size) {
971 return IsOpen() && 0 == 1006 return IsOpen() && 0 ==
972#ifdef _WIN32 1007#ifdef _WIN32
diff --git a/src/common/file_util.h b/src/common/file_util.h
index cde7ddf2d..f7a0c33fa 100644
--- a/src/common/file_util.h
+++ b/src/common/file_util.h
@@ -222,22 +222,15 @@ public:
222 static_assert(std::is_trivially_copyable_v<T>, 222 static_assert(std::is_trivially_copyable_v<T>,
223 "Given array does not consist of trivially copyable objects"); 223 "Given array does not consist of trivially copyable objects");
224 224
225 if (!IsOpen()) { 225 return ReadImpl(data, length, sizeof(T));
226 return std::numeric_limits<std::size_t>::max();
227 }
228
229 return std::fread(data, sizeof(T), length, m_file);
230 } 226 }
231 227
232 template <typename T> 228 template <typename T>
233 std::size_t WriteArray(const T* data, std::size_t length) { 229 std::size_t WriteArray(const T* data, std::size_t length) {
234 static_assert(std::is_trivially_copyable_v<T>, 230 static_assert(std::is_trivially_copyable_v<T>,
235 "Given array does not consist of trivially copyable objects"); 231 "Given array does not consist of trivially copyable objects");
236 if (!IsOpen()) {
237 return std::numeric_limits<std::size_t>::max();
238 }
239 232
240 return std::fwrite(data, sizeof(T), length, m_file); 233 return WriteImpl(data, length, sizeof(T));
241 } 234 }
242 235
243 template <typename T> 236 template <typename T>
@@ -278,6 +271,9 @@ public:
278 } 271 }
279 272
280private: 273private:
274 std::size_t ReadImpl(void* data, std::size_t length, std::size_t data_size) const;
275 std::size_t WriteImpl(const void* data, std::size_t length, std::size_t data_size);
276
281 std::FILE* m_file = nullptr; 277 std::FILE* m_file = nullptr;
282}; 278};
283 279