mirror of
				https://git.suyu.dev/suyu/suyu
				synced 2025-11-04 00:49:02 -06:00 
			
		
		
		
	Merge pull request #6397 from Morph1984/fs_util
common: fs: fs_util: Add more string conversion functions
This commit is contained in:
		@@ -2,6 +2,8 @@
 | 
			
		||||
// Licensed under GPLv2 or any later version
 | 
			
		||||
// Refer to the license.txt file included.
 | 
			
		||||
 | 
			
		||||
#include <algorithm>
 | 
			
		||||
 | 
			
		||||
#include "common/fs/fs_util.h"
 | 
			
		||||
 | 
			
		||||
namespace Common::FS {
 | 
			
		||||
@@ -10,4 +12,16 @@ std::u8string ToU8String(std::string_view utf8_string) {
 | 
			
		||||
    return std::u8string{utf8_string.begin(), utf8_string.end()};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
std::u8string BufferToU8String(std::span<const u8> buffer) {
 | 
			
		||||
    return std::u8string{buffer.begin(), std::ranges::find(buffer, u8{0})};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
std::string ToUTF8String(std::u8string_view u8_string) {
 | 
			
		||||
    return std::string{u8_string.begin(), u8_string.end()};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
std::string PathToUTF8String(const std::filesystem::path& path) {
 | 
			
		||||
    return ToUTF8String(path.u8string());
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
} // namespace Common::FS
 | 
			
		||||
 
 | 
			
		||||
@@ -5,9 +5,13 @@
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <concepts>
 | 
			
		||||
#include <filesystem>
 | 
			
		||||
#include <span>
 | 
			
		||||
#include <string>
 | 
			
		||||
#include <string_view>
 | 
			
		||||
 | 
			
		||||
#include "common/common_types.h"
 | 
			
		||||
 | 
			
		||||
namespace Common::FS {
 | 
			
		||||
 | 
			
		||||
template <typename T>
 | 
			
		||||
@@ -22,4 +26,33 @@ concept IsChar = std::same_as<T, char>;
 | 
			
		||||
 */
 | 
			
		||||
[[nodiscard]] std::u8string ToU8String(std::string_view utf8_string);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Converts a buffer of bytes to a UTF8-encoded std::u8string.
 | 
			
		||||
 * This converts from the start of the buffer until the first encountered null-terminator.
 | 
			
		||||
 * If no null-terminator is found, this converts the entire buffer instead.
 | 
			
		||||
 *
 | 
			
		||||
 * @param buffer Buffer of bytes
 | 
			
		||||
 *
 | 
			
		||||
 * @returns UTF-8 encoded std::u8string.
 | 
			
		||||
 */
 | 
			
		||||
[[nodiscard]] std::u8string BufferToU8String(std::span<const u8> buffer);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Converts a std::u8string or std::u8string_view to a UTF-8 encoded std::string.
 | 
			
		||||
 *
 | 
			
		||||
 * @param u8_string UTF-8 encoded u8string
 | 
			
		||||
 *
 | 
			
		||||
 * @returns UTF-8 encoded std::string.
 | 
			
		||||
 */
 | 
			
		||||
[[nodiscard]] std::string ToUTF8String(std::u8string_view u8_string);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Converts a filesystem path to a UTF-8 encoded std::string.
 | 
			
		||||
 *
 | 
			
		||||
 * @param path Filesystem path
 | 
			
		||||
 *
 | 
			
		||||
 * @returns UTF-8 encoded std::string.
 | 
			
		||||
 */
 | 
			
		||||
[[nodiscard]] std::string PathToUTF8String(const std::filesystem::path& path);
 | 
			
		||||
 | 
			
		||||
} // namespace Common::FS
 | 
			
		||||
 
 | 
			
		||||
@@ -129,12 +129,6 @@ private:
 | 
			
		||||
    std::unordered_map<YuzuPath, fs::path> yuzu_paths;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
std::string PathToUTF8String(const fs::path& path) {
 | 
			
		||||
    const auto utf8_string = path.u8string();
 | 
			
		||||
 | 
			
		||||
    return std::string{utf8_string.begin(), utf8_string.end()};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool ValidatePath(const fs::path& path) {
 | 
			
		||||
    if (path.empty()) {
 | 
			
		||||
        LOG_ERROR(Common_Filesystem, "Input path is empty, path={}", PathToUTF8String(path));
 | 
			
		||||
 
 | 
			
		||||
@@ -25,15 +25,6 @@ enum class YuzuPath {
 | 
			
		||||
    ShaderDir,      // Where shaders are stored.
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Converts a filesystem path to a UTF-8 encoded std::string.
 | 
			
		||||
 *
 | 
			
		||||
 * @param path Filesystem path
 | 
			
		||||
 *
 | 
			
		||||
 * @returns UTF-8 encoded std::string.
 | 
			
		||||
 */
 | 
			
		||||
[[nodiscard]] std::string PathToUTF8String(const std::filesystem::path& path);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Validates a given path.
 | 
			
		||||
 *
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user