2014-12-17 05:38:14 +00:00
|
|
|
// Copyright 2013 Dolphin Emulator Project / 2014 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
2013-09-05 00:17:46 +00:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2014-08-17 17:45:50 +00:00
|
|
|
#pragma once
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2014-08-17 17:45:50 +00:00
|
|
|
#include <cstdarg>
|
2015-06-20 21:33:54 +00:00
|
|
|
#include <cstddef>
|
2014-08-17 17:45:50 +00:00
|
|
|
#include <iomanip>
|
2013-09-05 00:17:46 +00:00
|
|
|
#include <sstream>
|
2015-06-20 21:33:54 +00:00
|
|
|
#include <string>
|
2014-08-17 17:45:50 +00:00
|
|
|
#include <vector>
|
2015-05-06 07:06:12 +00:00
|
|
|
#include "common/common_types.h"
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2014-09-07 18:50:43 +00:00
|
|
|
namespace Common {
|
2014-09-07 07:49:52 +00:00
|
|
|
|
2014-09-07 18:50:43 +00:00
|
|
|
/// Make a string lowercase
|
|
|
|
std::string ToLower(std::string str);
|
2014-04-15 01:25:46 +00:00
|
|
|
|
|
|
|
/// Make a string uppercase
|
2014-09-07 18:50:43 +00:00
|
|
|
std::string ToUpper(std::string str);
|
2014-04-15 01:25:46 +00:00
|
|
|
|
2013-09-05 00:17:46 +00:00
|
|
|
std::string StringFromFormat(const char* format, ...);
|
|
|
|
// Cheap!
|
|
|
|
bool CharArrayFromFormatV(char* out, int outsize, const char* format, va_list args);
|
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
template <size_t Count>
|
|
|
|
inline void CharArrayFromFormat(char (&out)[Count], const char* format, ...) {
|
2014-04-01 22:20:08 +00:00
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
CharArrayFromFormatV(out, Count, format, args);
|
|
|
|
va_end(args);
|
2013-09-05 00:17:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Good
|
2017-09-26 23:26:09 +00:00
|
|
|
std::string ArrayToString(const u8* data, size_t size, int line_len = 20, bool spaces = true);
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
std::string StripSpaces(const std::string& s);
|
|
|
|
std::string StripQuotes(const std::string& s);
|
2013-09-05 00:17:46 +00:00
|
|
|
|
|
|
|
// Thousand separator. Turns 12345678 into 12,345,678
|
|
|
|
template <typename I>
|
2016-09-18 00:38:01 +00:00
|
|
|
std::string ThousandSeparate(I value, int spaces = 0) {
|
2014-04-01 22:20:08 +00:00
|
|
|
std::ostringstream oss;
|
2013-09-05 00:17:46 +00:00
|
|
|
|
|
|
|
// std::locale("") seems to be broken on many platforms
|
|
|
|
#if defined _WIN32 || (defined __linux__ && !defined __clang__)
|
2014-04-01 22:20:08 +00:00
|
|
|
oss.imbue(std::locale(""));
|
2013-09-05 00:17:46 +00:00
|
|
|
#endif
|
2014-04-01 22:20:08 +00:00
|
|
|
oss << std::setw(spaces) << value;
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2014-04-01 22:20:08 +00:00
|
|
|
return oss.str();
|
2013-09-05 00:17:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
std::string StringFromBool(bool value);
|
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
bool TryParse(const std::string& str, bool* output);
|
|
|
|
bool TryParse(const std::string& str, u32* output);
|
2013-09-05 00:17:46 +00:00
|
|
|
|
|
|
|
template <typename N>
|
2016-09-18 00:38:01 +00:00
|
|
|
static bool TryParse(const std::string& str, N* const output) {
|
2014-04-01 22:20:08 +00:00
|
|
|
std::istringstream iss(str);
|
2014-11-19 08:49:13 +00:00
|
|
|
|
2014-04-01 22:20:08 +00:00
|
|
|
N tmp = 0;
|
2016-09-18 00:38:01 +00:00
|
|
|
if (iss >> tmp) {
|
2014-04-01 22:20:08 +00:00
|
|
|
*output = tmp;
|
|
|
|
return true;
|
2016-09-18 00:38:01 +00:00
|
|
|
} else
|
2014-04-01 22:20:08 +00:00
|
|
|
return false;
|
2013-09-05 00:17:46 +00:00
|
|
|
}
|
|
|
|
|
2018-07-22 19:33:07 +00:00
|
|
|
std::string TabsToSpaces(int tab_size, std::string in);
|
2013-09-05 00:17:46 +00: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 00:38:01 +00:00
|
|
|
bool SplitPath(const std::string& full_path, std::string* _pPath, std::string* _pFilename,
|
|
|
|
std::string* _pExtension);
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
void BuildCompleteFilename(std::string& _CompleteFilename, const std::string& _Path,
|
|
|
|
const std::string& _Filename);
|
2013-09-05 00:17:46 +00:00
|
|
|
std::string ReplaceAll(std::string result, const std::string& src, const std::string& dest);
|
|
|
|
|
2014-11-10 22:36:32 +00:00
|
|
|
std::string UTF16ToUTF8(const std::u16string& input);
|
|
|
|
std::u16string UTF8ToUTF16(const std::string& input);
|
|
|
|
|
2013-09-05 00:17:46 +00:00
|
|
|
std::string CP1252ToUTF8(const std::string& str);
|
|
|
|
std::string SHIFTJISToUTF8(const std::string& str);
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
2016-03-31 10:58:37 +00:00
|
|
|
std::string UTF16ToUTF8(const std::wstring& input);
|
2014-11-10 22:36:32 +00:00
|
|
|
std::wstring UTF8ToUTF16W(const std::string& str);
|
2013-09-05 00:17:46 +00:00
|
|
|
|
|
|
|
#ifdef _UNICODE
|
2016-09-18 00:38:01 +00:00
|
|
|
inline std::string TStrToUTF8(const std::wstring& str) {
|
|
|
|
return UTF16ToUTF8(str);
|
|
|
|
}
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
inline std::wstring UTF8ToTStr(const std::string& str) {
|
|
|
|
return UTF8ToUTF16W(str);
|
|
|
|
}
|
2013-09-05 00:17:46 +00:00
|
|
|
#else
|
2016-09-18 00:38:01 +00:00
|
|
|
inline std::string TStrToUTF8(const std::string& str) {
|
|
|
|
return str;
|
|
|
|
}
|
2013-09-05 00:17:46 +00:00
|
|
|
|
2016-09-18 00:38:01 +00:00
|
|
|
inline std::string UTF8ToTStr(const std::string& str) {
|
|
|
|
return str;
|
|
|
|
}
|
2013-09-05 00:17:46 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|
2014-09-07 18:50:43 +00:00
|
|
|
|
2014-11-04 05:03:19 +00:00
|
|
|
/**
|
|
|
|
* Compares the string defined by the range [`begin`, `end`) to the null-terminated C-string
|
|
|
|
* `other` for equality.
|
|
|
|
*/
|
|
|
|
template <typename InIt>
|
|
|
|
bool ComparePartialString(InIt begin, InIt end, const char* other) {
|
|
|
|
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');
|
|
|
|
}
|
|
|
|
|
2015-05-07 00:32:52 +00: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.
|
|
|
|
*/
|
|
|
|
std::string StringFromFixedZeroTerminatedBuffer(const char* buffer, size_t max_len);
|
2018-02-20 00:51:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Attempts to trim an arbitrary prefix from `path`, leaving only the part starting at `root`. It's
|
|
|
|
* intended to be used to strip a system-specific build directory from the `__FILE__` macro,
|
|
|
|
* leaving only the path relative to the sources root.
|
|
|
|
*
|
|
|
|
* @param path The input file path as a null-terminated string
|
|
|
|
* @param root The name of the root source directory as a null-terminated string. Path up to and
|
|
|
|
* including the last occurrence of this name will be stripped
|
|
|
|
* @return A pointer to the same string passed as `path`, but starting at the trimmed portion
|
|
|
|
*/
|
|
|
|
const char* TrimSourcePath(const char* path, const char* root = "src");
|
|
|
|
|
|
|
|
} // namespace Common
|