mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
StripSpaces: only strip spaces
StripWhitespace maintains old behavior
This commit is contained in:
parent
e4ff49769c
commit
f92541fbd9
@ -30,7 +30,7 @@ static void LogCallback(const char* format, ...)
|
|||||||
va_start(args, format);
|
va_start(args, format);
|
||||||
const char* filename = va_arg(args, const char*) + s_path_cutoff_point;
|
const char* filename = va_arg(args, const char*) + s_path_cutoff_point;
|
||||||
const int lineno = va_arg(args, int);
|
const int lineno = va_arg(args, int);
|
||||||
const std::string adapted_format(StripSpaces(format + strlen("%s:%d:")));
|
const std::string adapted_format(StripWhitespace(format + strlen("%s:%d:")));
|
||||||
const std::string message = StringFromFormatV(adapted_format.c_str(), args);
|
const std::string message = StringFromFormatV(adapted_format.c_str(), args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
|
||||||
|
@ -25,11 +25,11 @@ void IniFile::ParseLine(std::string_view line, std::string* keyOut, std::string*
|
|||||||
if (firstEquals != std::string::npos)
|
if (firstEquals != std::string::npos)
|
||||||
{
|
{
|
||||||
// Yes, a valid line!
|
// Yes, a valid line!
|
||||||
*keyOut = StripSpaces(line.substr(0, firstEquals));
|
*keyOut = StripWhitespace(line.substr(0, firstEquals));
|
||||||
|
|
||||||
if (valueOut)
|
if (valueOut)
|
||||||
{
|
{
|
||||||
*valueOut = StripQuotes(StripSpaces(line.substr(firstEquals + 1, std::string::npos)));
|
*valueOut = StripQuotes(StripWhitespace(line.substr(firstEquals + 1, std::string::npos)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -96,7 +96,7 @@ bool IniFile::Section::GetLines(std::vector<std::string>* lines, const bool remo
|
|||||||
{
|
{
|
||||||
for (const std::string& line : m_lines)
|
for (const std::string& line : m_lines)
|
||||||
{
|
{
|
||||||
std::string_view stripped_line = StripSpaces(line);
|
std::string_view stripped_line = StripWhitespace(line);
|
||||||
|
|
||||||
if (remove_comments)
|
if (remove_comments)
|
||||||
{
|
{
|
||||||
@ -108,7 +108,7 @@ bool IniFile::Section::GetLines(std::vector<std::string>* lines, const bool remo
|
|||||||
|
|
||||||
if (commentPos != std::string::npos)
|
if (commentPos != std::string::npos)
|
||||||
{
|
{
|
||||||
stripped_line = StripSpaces(stripped_line.substr(0, commentPos));
|
stripped_line = StripWhitespace(stripped_line.substr(0, commentPos));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -219,20 +219,31 @@ std::string ArrayToString(const u8* data, u32 size, int line_len, bool spaces)
|
|||||||
return oss.str();
|
return oss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Turns "\n\r\t hello " into "hello" (trims at the start and end but not inside).
|
template <typename T>
|
||||||
std::string_view StripSpaces(std::string_view str)
|
static std::string_view StripEnclosingChars(std::string_view str, T chars)
|
||||||
{
|
{
|
||||||
const size_t s = str.find_first_not_of(" \t\r\n");
|
const size_t s = str.find_first_not_of(chars);
|
||||||
|
|
||||||
if (str.npos != s)
|
if (str.npos != s)
|
||||||
return str.substr(s, str.find_last_not_of(" \t\r\n") - s + 1);
|
return str.substr(s, str.find_last_not_of(chars) - s + 1);
|
||||||
else
|
else
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Turns "\n\r\t hello " into "hello" (trims at the start and end but not inside).
|
||||||
|
std::string_view StripWhitespace(std::string_view str)
|
||||||
|
{
|
||||||
|
return StripEnclosingChars(str, " \t\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string_view StripSpaces(std::string_view str)
|
||||||
|
{
|
||||||
|
return StripEnclosingChars(str, ' ');
|
||||||
|
}
|
||||||
|
|
||||||
// "\"hello\"" is turned to "hello"
|
// "\"hello\"" is turned to "hello"
|
||||||
// This one assumes that the string has already been space stripped in both
|
// This one assumes that the string has already been space stripped in both
|
||||||
// ends, as done by StripSpaces above, for example.
|
// ends, as done by StripWhitespace above, for example.
|
||||||
std::string_view StripQuotes(std::string_view s)
|
std::string_view StripQuotes(std::string_view s)
|
||||||
{
|
{
|
||||||
if (!s.empty() && '\"' == s[0] && '\"' == *s.rbegin())
|
if (!s.empty() && '\"' == s[0] && '\"' == *s.rbegin())
|
||||||
|
@ -46,6 +46,7 @@ inline void CharArrayFromFormat(char (&out)[Count], const char* format, ...)
|
|||||||
// Good
|
// Good
|
||||||
std::string ArrayToString(const u8* data, u32 size, int line_len = 20, bool spaces = true);
|
std::string ArrayToString(const u8* data, u32 size, int line_len = 20, bool spaces = true);
|
||||||
|
|
||||||
|
std::string_view StripWhitespace(std::string_view s);
|
||||||
std::string_view StripSpaces(std::string_view s);
|
std::string_view StripSpaces(std::string_view s);
|
||||||
std::string_view StripQuotes(std::string_view s);
|
std::string_view StripQuotes(std::string_view s);
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ std::vector<GeckoCode> DownloadCodes(std::string gametdb_id, bool* succeeded, bo
|
|||||||
{
|
{
|
||||||
// Remove \r at the end of the line for files using windows line endings, std::getline only
|
// Remove \r at the end of the line for files using windows line endings, std::getline only
|
||||||
// removes \n
|
// removes \n
|
||||||
line = StripSpaces(line);
|
line = StripWhitespace(line);
|
||||||
|
|
||||||
if (line.empty())
|
if (line.empty())
|
||||||
{
|
{
|
||||||
@ -74,7 +74,7 @@ std::vector<GeckoCode> DownloadCodes(std::string gametdb_id, bool* succeeded, bo
|
|||||||
std::istringstream ssline(line);
|
std::istringstream ssline(line);
|
||||||
// stop at [ character (beginning of contributor name)
|
// stop at [ character (beginning of contributor name)
|
||||||
std::getline(ssline, gcode.name, '[');
|
std::getline(ssline, gcode.name, '[');
|
||||||
gcode.name = StripSpaces(gcode.name);
|
gcode.name = StripWhitespace(gcode.name);
|
||||||
gcode.user_defined = true;
|
gcode.user_defined = true;
|
||||||
// read the code creator name
|
// read the code creator name
|
||||||
std::getline(ssline, gcode.creator, ']');
|
std::getline(ssline, gcode.creator, ']');
|
||||||
@ -165,7 +165,7 @@ std::vector<GeckoCode> LoadCodes(const IniFile& globalIni, const IniFile& localI
|
|||||||
ss.seekg(1, std::ios_base::cur);
|
ss.seekg(1, std::ios_base::cur);
|
||||||
// read the code name
|
// read the code name
|
||||||
std::getline(ss, gcode.name, '['); // stop at [ character (beginning of contributor name)
|
std::getline(ss, gcode.name, '['); // stop at [ character (beginning of contributor name)
|
||||||
gcode.name = StripSpaces(gcode.name);
|
gcode.name = StripWhitespace(gcode.name);
|
||||||
// read the code creator name
|
// read the code creator name
|
||||||
std::getline(ss, gcode.creator, ']');
|
std::getline(ss, gcode.creator, ']');
|
||||||
break;
|
break;
|
||||||
|
@ -298,7 +298,7 @@ bool PPCSymbolDB::LoadMap(const std::string& filename, bool bad)
|
|||||||
constexpr auto is_hex_str = [](const std::string& s) {
|
constexpr auto is_hex_str = [](const std::string& s) {
|
||||||
return !s.empty() && s.find_first_not_of("0123456789abcdefABCDEF") == std::string::npos;
|
return !s.empty() && s.find_first_not_of("0123456789abcdefABCDEF") == std::string::npos;
|
||||||
};
|
};
|
||||||
const std::string stripped_line(StripSpaces(line));
|
const std::string stripped_line(StripWhitespace(line));
|
||||||
std::istringstream iss(stripped_line);
|
std::istringstream iss(stripped_line);
|
||||||
iss.imbue(std::locale::classic());
|
iss.imbue(std::locale::classic());
|
||||||
std::string word;
|
std::string word;
|
||||||
|
@ -52,7 +52,7 @@ bool GetFunctionName(std::istringstream* iss, std::string* name)
|
|||||||
|
|
||||||
std::getline(*iss, buffer);
|
std::getline(*iss, buffer);
|
||||||
size_t next = buffer.find(" ^");
|
size_t next = buffer.find(" ^");
|
||||||
*name = StripSpaces(buffer.substr(0, next));
|
*name = StripWhitespace(buffer.substr(0, next));
|
||||||
|
|
||||||
if (name->empty())
|
if (name->empty())
|
||||||
return false;
|
return false;
|
||||||
|
@ -43,9 +43,9 @@ static Map LoadMap(const std::string& file_path)
|
|||||||
if (equals_index != std::string::npos)
|
if (equals_index != std::string::npos)
|
||||||
{
|
{
|
||||||
const std::string_view line_view(line);
|
const std::string_view line_view(line);
|
||||||
const std::string_view game_id = StripSpaces(line_view.substr(0, equals_index));
|
const std::string_view game_id = StripWhitespace(line_view.substr(0, equals_index));
|
||||||
if (game_id.length() >= 4)
|
if (game_id.length() >= 4)
|
||||||
map.emplace(game_id, StripSpaces(line_view.substr(equals_index + 1)));
|
map.emplace(game_id, StripWhitespace(line_view.substr(equals_index + 1)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return map;
|
return map;
|
||||||
|
@ -261,7 +261,7 @@ std::vector<RedumpVerifier::PotentialMatch> RedumpVerifier::ScanDatfile(const st
|
|||||||
// disc with the game ID "G96P" and the serial "DL-DOL-D96P-EUR, DL-DOL-G96P-EUR".
|
// disc with the game ID "G96P" and the serial "DL-DOL-D96P-EUR, DL-DOL-G96P-EUR".
|
||||||
for (const std::string& serial_str : SplitString(serials, ','))
|
for (const std::string& serial_str : SplitString(serials, ','))
|
||||||
{
|
{
|
||||||
const std::string_view serial = StripSpaces(serial_str);
|
const std::string_view serial = StripWhitespace(serial_str);
|
||||||
|
|
||||||
// Skip the prefix, normally either "DL-DOL-" or "RVL-" (depending on the console),
|
// Skip the prefix, normally either "DL-DOL-" or "RVL-" (depending on the console),
|
||||||
// but there are some exceptions like the "RVLE-SBSE-USA-B0" serial.
|
// but there are some exceptions like the "RVLE-SBSE-USA-B0" serial.
|
||||||
|
@ -1150,7 +1150,7 @@ void MenuBar::CheckNAND()
|
|||||||
{
|
{
|
||||||
title_listings += " - " + banner.GetName();
|
title_listings += " - " + banner.GetName();
|
||||||
const std::string description = banner.GetDescription();
|
const std::string description = banner.GetDescription();
|
||||||
if (!StripSpaces(description).empty())
|
if (!StripWhitespace(description).empty())
|
||||||
title_listings += " - " + description;
|
title_listings += " - " + description;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -95,7 +95,7 @@ void BroadbandAdapterSettingsDialog::InitControls()
|
|||||||
|
|
||||||
void BroadbandAdapterSettingsDialog::SaveAddress()
|
void BroadbandAdapterSettingsDialog::SaveAddress()
|
||||||
{
|
{
|
||||||
const std::string bba_new_address(StripSpaces(m_address_input->text().toStdString()));
|
const std::string bba_new_address(StripWhitespace(m_address_input->text().toStdString()));
|
||||||
|
|
||||||
switch (m_bba_type)
|
switch (m_bba_type)
|
||||||
{
|
{
|
||||||
|
@ -124,8 +124,8 @@ void USBDeviceAddToWhitelistDialog::RefreshDeviceList()
|
|||||||
|
|
||||||
void USBDeviceAddToWhitelistDialog::AddUSBDeviceToWhitelist()
|
void USBDeviceAddToWhitelistDialog::AddUSBDeviceToWhitelist()
|
||||||
{
|
{
|
||||||
const std::string vid_string(StripSpaces(device_vid_textbox->text().toStdString()));
|
const std::string vid_string(StripWhitespace(device_vid_textbox->text().toStdString()));
|
||||||
const std::string pid_string(StripSpaces(device_pid_textbox->text().toStdString()));
|
const std::string pid_string(StripWhitespace(device_pid_textbox->text().toStdString()));
|
||||||
if (!IsValidUSBIDString(vid_string))
|
if (!IsValidUSBIDString(vid_string))
|
||||||
{
|
{
|
||||||
// i18n: Here, VID means Vendor ID (for a USB device).
|
// i18n: Here, VID means Vendor ID (for a USB device).
|
||||||
|
@ -980,7 +980,7 @@ static std::unique_ptr<Expression> ParseBarewordExpression(const std::string& st
|
|||||||
|
|
||||||
ParseResult ParseExpression(const std::string& str)
|
ParseResult ParseExpression(const std::string& str)
|
||||||
{
|
{
|
||||||
if (StripSpaces(str).empty())
|
if (StripWhitespace(str).empty())
|
||||||
return ParseResult::MakeEmptyResult();
|
return ParseResult::MakeEmptyResult();
|
||||||
|
|
||||||
auto bareword_expr = ParseBarewordExpression(str);
|
auto bareword_expr = ParseBarewordExpression(str);
|
||||||
|
@ -41,7 +41,7 @@ std::string GetDeviceName(const LPDIRECTINPUTDEVICE8 device)
|
|||||||
HRESULT hr = device->GetProperty(DIPROP_PRODUCTNAME, &str.diph);
|
HRESULT hr = device->GetProperty(DIPROP_PRODUCTNAME, &str.diph);
|
||||||
if (SUCCEEDED(hr))
|
if (SUCCEEDED(hr))
|
||||||
{
|
{
|
||||||
result = StripSpaces(WStringToUTF8(str.wsz));
|
result = StripWhitespace(WStringToUTF8(str.wsz));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -139,7 +139,7 @@ static std::string GetDeviceRefName(IOHIDDeviceRef inIOHIDDeviceRef)
|
|||||||
{
|
{
|
||||||
const NSString* name = reinterpret_cast<const NSString*>(
|
const NSString* name = reinterpret_cast<const NSString*>(
|
||||||
IOHIDDeviceGetProperty(inIOHIDDeviceRef, CFSTR(kIOHIDProductKey)));
|
IOHIDDeviceGetProperty(inIOHIDDeviceRef, CFSTR(kIOHIDProductKey)));
|
||||||
return (name != nullptr) ? std::string(StripSpaces([name UTF8String])) : "Unknown device";
|
return (name != nullptr) ? std::string(StripWhitespace([name UTF8String])) : "Unknown device";
|
||||||
}
|
}
|
||||||
|
|
||||||
static void DeviceRemovalCallback(void* inContext, IOReturn inResult, void* inSender,
|
static void DeviceRemovalCallback(void* inContext, IOReturn inResult, void* inSender,
|
||||||
|
@ -164,7 +164,7 @@ std::string Joystick::Button::GetName() const
|
|||||||
{
|
{
|
||||||
std::ostringstream s;
|
std::ostringstream s;
|
||||||
s << IOHIDElementGetUsage(m_element);
|
s << IOHIDElementGetUsage(m_element);
|
||||||
return std::string("Button ").append(StripSpaces(s.str()));
|
return std::string("Button ").append(StripWhitespace(s.str()));
|
||||||
}
|
}
|
||||||
|
|
||||||
Joystick::Axis::Axis(IOHIDElementRef element, IOHIDDeviceRef device, direction dir)
|
Joystick::Axis::Axis(IOHIDElementRef element, IOHIDDeviceRef device, direction dir)
|
||||||
@ -210,7 +210,7 @@ Joystick::Axis::Axis(IOHIDElementRef element, IOHIDDeviceRef device, direction d
|
|||||||
std::ostringstream s;
|
std::ostringstream s;
|
||||||
s << "CK-";
|
s << "CK-";
|
||||||
s << elementCookie;
|
s << elementCookie;
|
||||||
description = StripSpaces(s.str());
|
description = StripWhitespace(s.str());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -272,7 +272,7 @@ void PopulateDevices()
|
|||||||
}
|
}
|
||||||
|
|
||||||
Joystick::Joystick(SDL_Joystick* const joystick, const int sdl_index)
|
Joystick::Joystick(SDL_Joystick* const joystick, const int sdl_index)
|
||||||
: m_joystick(joystick), m_name(StripSpaces(GetJoystickName(sdl_index)))
|
: m_joystick(joystick), m_name(StripWhitespace(GetJoystickName(sdl_index)))
|
||||||
{
|
{
|
||||||
// really bad HACKS:
|
// really bad HACKS:
|
||||||
// to not use SDL for an XInput device
|
// to not use SDL for an XInput device
|
||||||
|
@ -784,7 +784,7 @@ void PopulateDevices()
|
|||||||
if (SUCCEEDED(hr = rgc2->get_DisplayName(&hstr)) && hstr)
|
if (SUCCEEDED(hr = rgc2->get_DisplayName(&hstr)) && hstr)
|
||||||
{
|
{
|
||||||
device_name =
|
device_name =
|
||||||
StripSpaces(WStringToUTF8(g_WindowsGetStringRawBuffer_address(hstr, nullptr)));
|
StripWhitespace(WStringToUTF8(g_WindowsGetStringRawBuffer_address(hstr, nullptr)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ protected:
|
|||||||
{
|
{
|
||||||
if (const char* code_name = libevdev_event_code_get_name(EV_KEY, m_code))
|
if (const char* code_name = libevdev_event_code_get_name(EV_KEY, m_code))
|
||||||
{
|
{
|
||||||
const auto name = StripSpaces(code_name);
|
const auto name = StripWhitespace(code_name);
|
||||||
|
|
||||||
for (auto remove_prefix : {"BTN_", "KEY_"})
|
for (auto remove_prefix : {"BTN_", "KEY_"})
|
||||||
{
|
{
|
||||||
@ -441,7 +441,7 @@ bool evdevDevice::AddNode(std::string devnode, int fd, libevdev* dev)
|
|||||||
m_nodes.emplace_back(Node{std::move(devnode), fd, dev});
|
m_nodes.emplace_back(Node{std::move(devnode), fd, dev});
|
||||||
|
|
||||||
// Take on the alphabetically first name.
|
// Take on the alphabetically first name.
|
||||||
const auto potential_new_name = StripSpaces(libevdev_get_name(dev));
|
const auto potential_new_name = StripWhitespace(libevdev_get_name(dev));
|
||||||
if (m_name.empty() || potential_new_name < m_name)
|
if (m_name.empty() || potential_new_name < m_name)
|
||||||
m_name = potential_new_name;
|
m_name = potential_new_name;
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ std::vector<std::string> GetProfilesFromSetting(const std::string& setting, cons
|
|||||||
std::vector<std::string> result;
|
std::vector<std::string> result;
|
||||||
for (const std::string& setting_choice : setting_choices)
|
for (const std::string& setting_choice : setting_choices)
|
||||||
{
|
{
|
||||||
const std::string path = root + std::string(StripSpaces(setting_choice));
|
const std::string path = root + std::string(StripWhitespace(setting_choice));
|
||||||
if (File::IsDirectory(path))
|
if (File::IsDirectory(path))
|
||||||
{
|
{
|
||||||
const auto files_under_directory = Common::DoFileSearch({path}, {".ini"}, true);
|
const auto files_under_directory = Common::DoFileSearch({path}, {".ini"}, true);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user