Merge branch 'develop' into refactor-scripts-stuff

This commit is contained in:
Edo 2022-03-01 20:34:25 +00:00 committed by GitHub
commit f07b2816df
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 74 additions and 44 deletions

View File

@ -6,9 +6,15 @@ namespace Components
bool Flags::HasFlag(const std::string& flag) bool Flags::HasFlag(const std::string& flag)
{ {
Flags::ParseFlags(); static auto parsed = false;
for (auto entry : Flags::EnabledFlags) if (!parsed)
{
Flags::ParseFlags();
parsed = true;
}
for (const auto& entry : Flags::EnabledFlags)
{ {
if (Utils::String::ToLower(entry) == Utils::String::ToLower(flag)) if (Utils::String::ToLower(entry) == Utils::String::ToLower(flag))
{ {
@ -21,21 +27,20 @@ namespace Components
void Flags::ParseFlags() void Flags::ParseFlags()
{ {
static bool flagsParsed = false;
if (flagsParsed) return;
flagsParsed = true;
int numArgs; int numArgs;
LPWSTR* argv = CommandLineToArgvW(GetCommandLineW(), &numArgs); auto* const argv = CommandLineToArgvW(GetCommandLineW(), &numArgs);
assert(Flags::EnabledFlags.empty());
if (argv) if (argv)
{ {
for (int i = 0; i < numArgs; ++i) for (auto i = 0; i < numArgs; ++i)
{ {
std::wstring wFlag(argv[i]); std::wstring wFlag(argv[i]);
if (wFlag[0] == L'-') if (wFlag[0] == L'-')
{ {
Flags::EnabledFlags.push_back(std::string(++wFlag.begin(), wFlag.end())); wFlag.erase(wFlag.begin());
Flags::EnabledFlags.push_back(Utils::String::Convert(wFlag));
} }
} }
@ -51,11 +56,5 @@ namespace Components
Flags::Flags() Flags::Flags()
{ {
Flags::ParseFlags();
}
Flags::~Flags()
{
Flags::EnabledFlags.clear();
} }
} }

View File

@ -6,7 +6,6 @@ namespace Components
{ {
public: public:
Flags(); Flags();
~Flags();
static bool HasFlag(const std::string& flag); static bool HasFlag(const std::string& flag);

View File

@ -103,30 +103,58 @@ namespace Utils
return _isspace_l(c, nullptr); return _isspace_l(c, nullptr);
} }
// trim from start // Trim from start
std::string& LTrim(std::string& s) std::string& LTrim(std::string& str)
{ {
s.erase(s.begin(), std::find_if(s.begin(), s.end(), [](int val) str.erase(str.begin(), std::find_if(str.begin(), str.end(), [](int val)
{ {
return !IsSpace(val); return !IsSpace(val);
})); }));
return s;
return str;
} }
// trim from end // Trim from end
std::string& RTrim(std::string& s) std::string& RTrim(std::string& str)
{ {
s.erase(std::find_if(s.rbegin(), s.rend(), [](int val) str.erase(std::find_if(str.rbegin(), str.rend(), [](int val)
{ {
return !IsSpace(val); return !IsSpace(val);
}).base(), s.end()); }).base(), str.end());
return s;
return str;
} }
// trim from both ends // Trim from both ends
std::string& Trim(std::string& s) std::string& Trim(std::string& str)
{ {
return LTrim(RTrim(s)); return LTrim(RTrim(str));
}
std::string Convert(const std::wstring& wstr)
{
std::string result;
result.reserve(wstr.size());
for (const auto& chr : wstr)
{
result.push_back(static_cast<char>(chr));
}
return result;
}
std::wstring Convert(const std::string& str)
{
std::wstring result;
result.reserve(str.size());
for (const auto& chr : str)
{
result.push_back(static_cast<wchar_t>(chr));
}
return result;
} }
std::string FormatTimeSpan(int milliseconds) std::string FormatTimeSpan(int milliseconds)

View File

@ -81,9 +81,13 @@ namespace Utils
std::vector<std::string> Split(const std::string& str, const char delim); std::vector<std::string> Split(const std::string& str, const char delim);
void Replace(std::string& string, const std::string& find, const std::string& replace); void Replace(std::string& string, const std::string& find, const std::string& replace);
bool StartsWith(const std::string& haystack, const std::string& needle); bool StartsWith(const std::string& haystack, const std::string& needle);
std::string& LTrim(std::string& s);
std::string& RTrim(std::string& s); std::string& LTrim(std::string& str);
std::string& Trim(std::string& s); std::string& RTrim(std::string& str);
std::string& Trim(std::string& str);
std::string Convert(const std::wstring& wstr);
std::wstring Convert(const std::string& str);
std::string FormatTimeSpan(int milliseconds); std::string FormatTimeSpan(int milliseconds);
std::string FormatBandwidth(size_t bytes, int milliseconds); std::string FormatBandwidth(size_t bytes, int milliseconds);

View File

@ -10,7 +10,7 @@ namespace Utils
if (mimeType) if (mimeType)
{ {
std::wstring wMimeType(mimeType); std::wstring wMimeType(mimeType);
return std::string(wMimeType.begin(), wMimeType.end()); return String::Convert(wMimeType);
} }
return "application/octet-stream"; return "application/octet-stream";

View File

@ -408,7 +408,7 @@ namespace Utils
replace = "\\"; replace = "\\";
} }
while ((nPos = path.find(find)) != std::wstring::npos) while ((nPos = path.find(find)) != std::string::npos)
{ {
path = path.replace(nPos, find.length(), replace); path = path.replace(nPos, find.length(), replace);
} }