summaryrefslogtreecommitdiff
path: root/src/tgbot/tools
diff options
context:
space:
mode:
authorOleg Morozenkov <omorozenkov@gmail.com>2015-07-09 15:03:59 +0300
committerOleg Morozenkov <omorozenkov@gmail.com>2015-07-09 15:03:59 +0300
commit51d2176d1535c8c8176426909e1c7b70633d794b (patch)
tree4301e0bb6f93913c53d4f41bdd96ddf1fcff9221 /src/tgbot/tools
parent28ef71aa3c6d9473d4127dd648161a0afa109895 (diff)
Refactoring
Diffstat (limited to 'src/tgbot/tools')
-rw-r--r--src/tgbot/tools/StringTools.cpp31
-rw-r--r--src/tgbot/tools/StringTools.h1
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;