diff options
| author | 2021-06-02 00:28:34 -0400 | |
|---|---|---|
| committer | 2021-06-02 00:28:34 -0400 | |
| commit | 50866199a4f76db501f692112ddfe142679ad3bb (patch) | |
| tree | 24a040c1117135d965e9f17aefa37a6cdd9d3bc7 | |
| parent | Merge pull request #6361 from lat9nq/per-hb-cfg (diff) | |
| parent | common: fs: fs_util: Move PathToUTF8String to fs_util (diff) | |
| download | yuzu-50866199a4f76db501f692112ddfe142679ad3bb.tar.gz yuzu-50866199a4f76db501f692112ddfe142679ad3bb.tar.xz yuzu-50866199a4f76db501f692112ddfe142679ad3bb.zip | |
Merge pull request #6397 from Morph1984/fs_util
common: fs: fs_util: Add more string conversion functions
Diffstat (limited to '')
| -rw-r--r-- | src/common/fs/fs_util.cpp | 14 | ||||
| -rw-r--r-- | src/common/fs/fs_util.h | 33 | ||||
| -rw-r--r-- | src/common/fs/path_util.cpp | 6 | ||||
| -rw-r--r-- | src/common/fs/path_util.h | 9 |
4 files changed, 47 insertions, 15 deletions
diff --git a/src/common/fs/fs_util.cpp b/src/common/fs/fs_util.cpp index 0ddfc3131..357cf5855 100644 --- a/src/common/fs/fs_util.cpp +++ b/src/common/fs/fs_util.cpp | |||
| @@ -2,6 +2,8 @@ | |||
| 2 | // Licensed under GPLv2 or any later version | 2 | // Licensed under GPLv2 or any later version |
| 3 | // Refer to the license.txt file included. | 3 | // Refer to the license.txt file included. |
| 4 | 4 | ||
| 5 | #include <algorithm> | ||
| 6 | |||
| 5 | #include "common/fs/fs_util.h" | 7 | #include "common/fs/fs_util.h" |
| 6 | 8 | ||
| 7 | namespace Common::FS { | 9 | namespace Common::FS { |
| @@ -10,4 +12,16 @@ std::u8string ToU8String(std::string_view utf8_string) { | |||
| 10 | return std::u8string{utf8_string.begin(), utf8_string.end()}; | 12 | return std::u8string{utf8_string.begin(), utf8_string.end()}; |
| 11 | } | 13 | } |
| 12 | 14 | ||
| 15 | std::u8string BufferToU8String(std::span<const u8> buffer) { | ||
| 16 | return std::u8string{buffer.begin(), std::ranges::find(buffer, u8{0})}; | ||
| 17 | } | ||
| 18 | |||
| 19 | std::string ToUTF8String(std::u8string_view u8_string) { | ||
| 20 | return std::string{u8_string.begin(), u8_string.end()}; | ||
| 21 | } | ||
| 22 | |||
| 23 | std::string PathToUTF8String(const std::filesystem::path& path) { | ||
| 24 | return ToUTF8String(path.u8string()); | ||
| 25 | } | ||
| 26 | |||
| 13 | } // namespace Common::FS | 27 | } // namespace Common::FS |
diff --git a/src/common/fs/fs_util.h b/src/common/fs/fs_util.h index 951df53b6..ec9950ee7 100644 --- a/src/common/fs/fs_util.h +++ b/src/common/fs/fs_util.h | |||
| @@ -5,9 +5,13 @@ | |||
| 5 | #pragma once | 5 | #pragma once |
| 6 | 6 | ||
| 7 | #include <concepts> | 7 | #include <concepts> |
| 8 | #include <filesystem> | ||
| 9 | #include <span> | ||
| 8 | #include <string> | 10 | #include <string> |
| 9 | #include <string_view> | 11 | #include <string_view> |
| 10 | 12 | ||
| 13 | #include "common/common_types.h" | ||
| 14 | |||
| 11 | namespace Common::FS { | 15 | namespace Common::FS { |
| 12 | 16 | ||
| 13 | template <typename T> | 17 | template <typename T> |
| @@ -22,4 +26,33 @@ concept IsChar = std::same_as<T, char>; | |||
| 22 | */ | 26 | */ |
| 23 | [[nodiscard]] std::u8string ToU8String(std::string_view utf8_string); | 27 | [[nodiscard]] std::u8string ToU8String(std::string_view utf8_string); |
| 24 | 28 | ||
| 29 | /** | ||
| 30 | * Converts a buffer of bytes to a UTF8-encoded std::u8string. | ||
| 31 | * This converts from the start of the buffer until the first encountered null-terminator. | ||
| 32 | * If no null-terminator is found, this converts the entire buffer instead. | ||
| 33 | * | ||
| 34 | * @param buffer Buffer of bytes | ||
| 35 | * | ||
| 36 | * @returns UTF-8 encoded std::u8string. | ||
| 37 | */ | ||
| 38 | [[nodiscard]] std::u8string BufferToU8String(std::span<const u8> buffer); | ||
| 39 | |||
| 40 | /** | ||
| 41 | * Converts a std::u8string or std::u8string_view to a UTF-8 encoded std::string. | ||
| 42 | * | ||
| 43 | * @param u8_string UTF-8 encoded u8string | ||
| 44 | * | ||
| 45 | * @returns UTF-8 encoded std::string. | ||
| 46 | */ | ||
| 47 | [[nodiscard]] std::string ToUTF8String(std::u8string_view u8_string); | ||
| 48 | |||
| 49 | /** | ||
| 50 | * Converts a filesystem path to a UTF-8 encoded std::string. | ||
| 51 | * | ||
| 52 | * @param path Filesystem path | ||
| 53 | * | ||
| 54 | * @returns UTF-8 encoded std::string. | ||
| 55 | */ | ||
| 56 | [[nodiscard]] std::string PathToUTF8String(const std::filesystem::path& path); | ||
| 57 | |||
| 25 | } // namespace Common::FS | 58 | } // namespace Common::FS |
diff --git a/src/common/fs/path_util.cpp b/src/common/fs/path_util.cpp index 8b732a21c..6cdd14f13 100644 --- a/src/common/fs/path_util.cpp +++ b/src/common/fs/path_util.cpp | |||
| @@ -129,12 +129,6 @@ private: | |||
| 129 | std::unordered_map<YuzuPath, fs::path> yuzu_paths; | 129 | std::unordered_map<YuzuPath, fs::path> yuzu_paths; |
| 130 | }; | 130 | }; |
| 131 | 131 | ||
| 132 | std::string PathToUTF8String(const fs::path& path) { | ||
| 133 | const auto utf8_string = path.u8string(); | ||
| 134 | |||
| 135 | return std::string{utf8_string.begin(), utf8_string.end()}; | ||
| 136 | } | ||
| 137 | |||
| 138 | bool ValidatePath(const fs::path& path) { | 132 | bool ValidatePath(const fs::path& path) { |
| 139 | if (path.empty()) { | 133 | if (path.empty()) { |
| 140 | LOG_ERROR(Common_Filesystem, "Input path is empty, path={}", PathToUTF8String(path)); | 134 | LOG_ERROR(Common_Filesystem, "Input path is empty, path={}", PathToUTF8String(path)); |
diff --git a/src/common/fs/path_util.h b/src/common/fs/path_util.h index a9fadbceb..14e8c35d7 100644 --- a/src/common/fs/path_util.h +++ b/src/common/fs/path_util.h | |||
| @@ -26,15 +26,6 @@ enum class YuzuPath { | |||
| 26 | }; | 26 | }; |
| 27 | 27 | ||
| 28 | /** | 28 | /** |
| 29 | * Converts a filesystem path to a UTF-8 encoded std::string. | ||
| 30 | * | ||
| 31 | * @param path Filesystem path | ||
| 32 | * | ||
| 33 | * @returns UTF-8 encoded std::string. | ||
| 34 | */ | ||
| 35 | [[nodiscard]] std::string PathToUTF8String(const std::filesystem::path& path); | ||
| 36 | |||
| 37 | /** | ||
| 38 | * Validates a given path. | 29 | * Validates a given path. |
| 39 | * | 30 | * |
| 40 | * A given path is valid if it meets these conditions: | 31 | * A given path is valid if it meets these conditions: |