2025-08-27 22:21:04 +02:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2025 Eden Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2022-04-28 18:24:11 +02:00
|
|
|
// SPDX-FileCopyrightText: 2013 Dolphin Emulator Project
|
|
|
|
// SPDX-FileCopyrightText: 2014 Citra Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2014-08-17 13:45:50 -04:00
|
|
|
#pragma once
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2025-08-31 08:40:46 +02:00
|
|
|
#include <algorithm>
|
2015-06-20 22:33:54 +01:00
|
|
|
#include <cstddef>
|
2023-02-03 00:08:45 -05:00
|
|
|
#include <span>
|
2015-06-20 22:33:54 +01:00
|
|
|
#include <string>
|
2014-08-17 13:45:50 -04:00
|
|
|
#include <vector>
|
2015-05-06 04:06:12 -03:00
|
|
|
#include "common/common_types.h"
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2014-09-07 11:50:43 -07:00
|
|
|
namespace Common {
|
2014-09-07 00:49:52 -07:00
|
|
|
|
2014-09-07 11:50:43 -07:00
|
|
|
/// Make a string lowercase
|
2025-08-27 22:21:04 +02:00
|
|
|
[[nodiscard]] std::string ToLower(const std::string_view sv);
|
2014-04-14 21:25:46 -04:00
|
|
|
|
|
|
|
/// Make a string uppercase
|
2025-08-27 22:21:04 +02:00
|
|
|
[[nodiscard]] std::string ToUpper(const std::string_view sv);
|
2014-04-14 21:25:46 -04:00
|
|
|
|
2025-08-27 22:21:04 +02:00
|
|
|
[[nodiscard]] inline std::string StringFromBuffer(std::span<const u8> data) noexcept {
|
|
|
|
return std::string(data.begin(), std::find(data.begin(), data.end(), '\0'));
|
|
|
|
}
|
|
|
|
[[nodiscard]] inline std::string StringFromBuffer(std::span<const char> data) noexcept {
|
|
|
|
return std::string(data.begin(), std::find(data.begin(), data.end(), '\0'));
|
|
|
|
}
|
2018-06-06 16:38:54 +03:00
|
|
|
|
2025-08-27 22:21:04 +02:00
|
|
|
/// Turns " hej " into "hej". Also handles tabs.
|
|
|
|
[[nodiscard]] inline std::string StripSpaces(const std::string_view str) noexcept {
|
|
|
|
const std::size_t s = str.find_first_not_of(" \t\r\n");
|
|
|
|
if (str.npos != s)
|
|
|
|
return std::string{str.substr(s, str.find_last_not_of(" \t\r\n") - s + 1)};
|
|
|
|
return {};
|
|
|
|
}
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2025-08-27 22:21:04 +02:00
|
|
|
/// "\"hello\"" is turned to "hello"
|
|
|
|
/// This one assumes that the string has already been space stripped in both
|
|
|
|
/// ends, as done by StripSpaces above, for example.
|
|
|
|
[[nodiscard]] inline std::string StripQuotes(const std::string_view s) noexcept {
|
|
|
|
if (s.size() && '\"' == s[0] && '\"' == *s.rbegin())
|
|
|
|
return std::string{s.substr(1, s.size() - 2)};
|
|
|
|
return std::string{s};
|
|
|
|
}
|
|
|
|
|
|
|
|
[[nodiscard]] inline std::string StringFromBool(bool value) noexcept {
|
|
|
|
return value ? "True" : "False";
|
|
|
|
}
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2020-08-14 09:38:45 -04:00
|
|
|
[[nodiscard]] std::string TabsToSpaces(int tab_size, std::string in);
|
2013-09-04 20:17:46 -04:00
|
|
|
|
|
|
|
void SplitString(const std::string& str, char delim, std::vector<std::string>& output);
|
|
|
|
|
|
|
|
// "C:/Windows/winhelp.exe" to "C:/Windows/", "winhelp", ".exe"
|
2016-09-18 09:38:01 +09:00
|
|
|
bool SplitPath(const std::string& full_path, std::string* _pPath, std::string* _pFilename,
|
|
|
|
std::string* _pExtension);
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2020-08-14 09:38:45 -04:00
|
|
|
[[nodiscard]] std::string ReplaceAll(std::string result, const std::string& src,
|
|
|
|
const std::string& dest);
|
2013-09-04 20:17:46 -04:00
|
|
|
|
2023-03-18 22:42:25 -07:00
|
|
|
[[nodiscard]] std::string UTF16ToUTF8(std::u16string_view input);
|
|
|
|
[[nodiscard]] std::u16string UTF8ToUTF16(std::string_view input);
|
2023-10-01 16:21:23 -04:00
|
|
|
[[nodiscard]] std::u32string UTF8ToUTF32(std::string_view input);
|
2014-11-10 14:36:32 -08:00
|
|
|
|
2013-09-04 20:17:46 -04:00
|
|
|
#ifdef _WIN32
|
2023-03-18 22:42:25 -07:00
|
|
|
[[nodiscard]] std::string UTF16ToUTF8(std::wstring_view input);
|
|
|
|
[[nodiscard]] std::wstring UTF8ToUTF16W(std::string_view str);
|
2013-09-04 20:17:46 -04:00
|
|
|
|
|
|
|
#endif
|
2014-09-07 11:50:43 -07:00
|
|
|
|
2022-05-15 18:06:33 -04:00
|
|
|
[[nodiscard]] std::u16string U16StringFromBuffer(const u16* input, std::size_t length);
|
|
|
|
|
2014-11-04 03:03:19 -02:00
|
|
|
/**
|
|
|
|
* Compares the string defined by the range [`begin`, `end`) to the null-terminated C-string
|
|
|
|
* `other` for equality.
|
|
|
|
*/
|
|
|
|
template <typename InIt>
|
2025-08-27 22:21:04 +02:00
|
|
|
[[nodiscard]] inline bool ComparePartialString(InIt begin, InIt end, const char* other) noexcept {
|
2014-11-04 03:03:19 -02:00
|
|
|
for (; begin != end && *other != '\0'; ++begin, ++other) {
|
|
|
|
if (*begin != *other) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Only return true if both strings finished at the same point
|
|
|
|
return (begin == end) == (*other == '\0');
|
|
|
|
}
|
|
|
|
|
2025-08-27 22:21:04 +02:00
|
|
|
/// Creates a std::string from a fixed-size NUL-terminated char buffer. If the buffer isn't
|
|
|
|
/// NUL-terminated then the string ends at max_len characters.
|
2021-10-14 13:11:08 -04:00
|
|
|
[[nodiscard]] std::string StringFromFixedZeroTerminatedBuffer(std::string_view buffer,
|
2020-08-14 09:38:45 -04:00
|
|
|
std::size_t max_len);
|
2018-03-22 18:21:29 +08:00
|
|
|
|
2025-08-27 22:21:04 +02:00
|
|
|
/// Creates a UTF-16 std::u16string from a fixed-size NUL-terminated char buffer. If the buffer isn't
|
|
|
|
/// null-terminated, then the string ends at the greatest multiple of two less then or equal to
|
|
|
|
/// max_len_bytes.
|
2020-08-14 09:38:45 -04:00
|
|
|
[[nodiscard]] std::u16string UTF16StringFromFixedZeroTerminatedBuffer(std::u16string_view buffer,
|
|
|
|
std::size_t max_len);
|
2018-11-09 17:03:54 -05:00
|
|
|
|
2018-01-20 00:48:02 -07:00
|
|
|
} // namespace Common
|