diff options
author | Oleg Morozenkov <omorozenkov@gmail.com> | 2015-07-09 15:03:59 +0300 |
---|---|---|
committer | Oleg Morozenkov <omorozenkov@gmail.com> | 2015-07-09 15:03:59 +0300 |
commit | 51d2176d1535c8c8176426909e1c7b70633d794b (patch) | |
tree | 4301e0bb6f93913c53d4f41bdd96ddf1fcff9221 /src/tgbot/tools | |
parent | 28ef71aa3c6d9473d4127dd648161a0afa109895 (diff) |
Refactoring
Diffstat (limited to 'src/tgbot/tools')
-rw-r--r-- | src/tgbot/tools/StringTools.cpp | 31 | ||||
-rw-r--r-- | src/tgbot/tools/StringTools.h | 1 |
2 files changed, 24 insertions, 8 deletions
diff --git a/src/tgbot/tools/StringTools.cpp b/src/tgbot/tools/StringTools.cpp index 7a8b740..de3bbb8 100644 --- a/src/tgbot/tools/StringTools.cpp +++ b/src/tgbot/tools/StringTools.cpp @@ -24,6 +24,7 @@ #include <stdlib.h> #include <iomanip> +#include <stdio.h> using namespace std; @@ -46,15 +47,15 @@ bool startsWith(const string& str1, const string& str2) { bool endsWith(const string& str1, const string& str2) { string::const_iterator it1(str1.end()); - string::const_iterator start1(str1.begin()); - string::const_iterator it2(str2.begin()); - string::const_iterator end2(str2.end()); - while (it1 != start1 && it2 != end2) { + string::const_iterator begin1(str1.begin()); + string::const_iterator it2(str2.end()); + string::const_iterator begin2(str2.begin()); + while (it1 != begin1 && it2 != begin2) { if (*it1 != *it2) { return false; } --it1; - ++it2; + --it2; } return true; } @@ -78,15 +79,13 @@ string generateRandomString(size_t length) { } string urlEncode(const string& value) { - static const string legitPunctuation = "-_.~!*()'"; + static const string legitPunctuation = "-_.~"; ostringstream result; result.fill('0'); result << hex; for (const char& c : value) { if (isalnum(c) || legitPunctuation.find(c) != legitPunctuation.npos) { result << c; - } else if (c == ' ') { - result << '+'; } else { result << '%' << setw(2) << int((unsigned char) c); } @@ -95,4 +94,20 @@ string urlEncode(const string& value) { return result.str(); } +string urlDecode(const string& value) { + string result; + for (size_t i = 0, count = value.length(); i < count; ++i) { + const char c = value[i]; + if (c == '%') { + int t = 0; + sscanf(value.substr(i + 1, 2).c_str(), "%x", &t); + result += (char) t; + i += 2; + } else { + result += c; + } + } + return result; +} + } diff --git a/src/tgbot/tools/StringTools.h b/src/tgbot/tools/StringTools.h index 0c94338..37ab858 100644 --- a/src/tgbot/tools/StringTools.h +++ b/src/tgbot/tools/StringTools.h @@ -34,6 +34,7 @@ bool endsWith(const std::string& str1, const std::string& str2); void split(const std::string& str, char delimiter, std::vector<std::string>& dest); std::string generateRandomString(size_t length); std::string urlEncode(const std::string& value); +std::string urlDecode(const std::string& value); inline std::vector<std::string> split(const std::string& str, char delimiter) { std::vector<std::string> result; |