aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/base/songloading/songloading_strategy_txt.cpp56
-rw-r--r--src/base/songloading/songloading_strategy_txt.hpp25
2 files changed, 7 insertions, 74 deletions
diff --git a/src/base/songloading/songloading_strategy_txt.cpp b/src/base/songloading/songloading_strategy_txt.cpp
index c65e9347..efcc3740 100644
--- a/src/base/songloading/songloading_strategy_txt.cpp
+++ b/src/base/songloading/songloading_strategy_txt.cpp
@@ -29,6 +29,8 @@
#include <sstream>
#include <string>
+#include <boost/algorithm/string.hpp>
+
#include "songloading_strategy_txt.hpp"
#include "utils/file.hpp"
#include "utils/locale_independent_float.hpp"
@@ -65,63 +67,18 @@ namespace usdx
result.first.begin(), toupper);
// line is already ltrimmed
- rtrim(result.first);
+ boost::trim_right(result.first);
result.second = line.substr(pos + 1);
// line is already rtrimmed
- ltrim(result.second);
+ boost::trim_left(result.second);
LOG4CXX_DEBUG(log, L"Found header: '" << result.first << L"' with value '" << result.second << L"'");
return result;
}
- std::wstring& SongloadingStrategyTxt::ltrim(std::wstring& line)
- {
- std::size_t found = line.find_first_not_of(L" \t\n\r");
- if (found != std::wstring::npos && found >= 1) {
- line.erase(0, found - 1);
- }
-
- return line;
- }
-
- std::wstring& SongloadingStrategyTxt::ltrim_newlines(std::wstring& line)
- {
- std::size_t found = line.find_first_not_of(L"\n\r");
- if (found != std::wstring::npos) {
- line.erase(0, found - 1);
- }
-
- return line;
- }
-
- std::wstring& SongloadingStrategyTxt::rtrim(std::wstring& line)
- {
- std::size_t found = line.find_last_not_of(L" \t\n\r");
- if (found != std::wstring::npos) {
- line.erase(found + 1);
- }
-
- return line;
- }
-
- std::wstring& SongloadingStrategyTxt::rtrim_newlines(std::wstring& line)
- {
- std::size_t found = line.find_last_not_of(L"\n\r");
- if (found != std::wstring::npos) {
- line.erase(found + 1);
- }
-
- return line;
- }
-
- std::wstring& SongloadingStrategyTxt::trim(std::wstring& line)
- {
- return ltrim(rtrim(line));
- }
-
Song* SongloadingStrategyTxt::load_song(Song *song)
{
LOG4CXX_DEBUG(log, "Starting loading song from file: " << song->get_filename());
@@ -225,7 +182,7 @@ namespace usdx
linestream >> beat >> length >> height >> std::noskipws;
linestream.ignore();
getline(linestream, lyric);
- rtrim_newlines(lyric);
+ boost::trim_right_if(lyric, boost::is_cntrl());
LOG4CXX_DEBUG(log, L"Found lyric: '" << lyric << L"' at line: " << line_number <<
L" at beat: " << beat << L" with length: " << length <<
@@ -243,7 +200,8 @@ namespace usdx
while (file.stream().good()) {
std::getline(file.stream(), line);
- trim(line);
+ boost::trim(line);
+ boost::trim_if(line, boost::is_cntrl());
LOG4CXX_DEBUG(log, L"Line: " << line);
if (header && line[0] == L'#') {
diff --git a/src/base/songloading/songloading_strategy_txt.hpp b/src/base/songloading/songloading_strategy_txt.hpp
index 097f35cf..a285042f 100644
--- a/src/base/songloading/songloading_strategy_txt.hpp
+++ b/src/base/songloading/songloading_strategy_txt.hpp
@@ -44,31 +44,6 @@ namespace usdx
*/
std::pair<std::wstring, std::wstring> split_header_field(std::wstring &line);
- /**
- * Removes whitespaces in front of the string.
- */
- std::wstring& ltrim(std::wstring& line);
-
- /**
- * Removes whitespaces behind the string.
- */
- std::wstring& rtrim(std::wstring& line);
-
- /**
- * Removes ''\r'' and ''\n'' in front of the string.
- */
- std::wstring& ltrim_newlines(std::wstring& line);
-
- /**
- * Removes ''\r'' and ''\n'' behind the string.
- */
- std::wstring& rtrim_newlines(std::wstring& line);
-
- /**
- * Removes whitespaces in front of the string and behind it.
- */
- std::wstring& trim(std::wstring& line);
-
bool parse_line(Song* song, File& file, const int line_number);
void parse_newline(Song* song, std::wistringstream& linestream, const int line_number);
void parse_bpm(Song* song, std::wistringstream& linestream, const int line_number);