From d47ee877be5d1175bdc36f2d87881ddaf875a8e9 Mon Sep 17 00:00:00 2001 From: Oleg Morozenkov Date: Mon, 23 Jul 2018 01:56:42 +0300 Subject: Refactor http clients, fix webhook server, add more samples, change tabs to 4 spaces --- src/tools/FileTools.cpp | 30 +++++----- src/tools/StringTools.cpp | 139 +++++++++++++++++++++++----------------------- 2 files changed, 84 insertions(+), 85 deletions(-) (limited to 'src/tools') diff --git a/src/tools/FileTools.cpp b/src/tools/FileTools.cpp index 105d80f..279f152 100644 --- a/src/tools/FileTools.cpp +++ b/src/tools/FileTools.cpp @@ -12,24 +12,24 @@ using namespace std; namespace FileTools { string read(const string& filePath) { - ifstream in(filePath, ios::in | ios::binary); - if (!in) { - throw system_error(errno, system_category()); - } - ostringstream contents; - contents << in.rdbuf(); - in.close(); - return contents.str(); + ifstream in(filePath, ios::in | ios::binary); + if (!in) { + throw system_error(errno, system_category()); + } + ostringstream contents; + contents << in.rdbuf(); + in.close(); + return contents.str(); } bool write(const string& content, const string& filePath) { - ofstream out(filePath, ios::out | ios::binary); - if (!out) { - return false; - } - out << content; - out.close(); - return true; + ofstream out(filePath, ios::out | ios::binary); + if (!out) { + return false; + } + out << content; + out.close(); + return true; } }; diff --git a/src/tools/StringTools.cpp b/src/tools/StringTools.cpp index 0e68dcc..5055d8e 100644 --- a/src/tools/StringTools.cpp +++ b/src/tools/StringTools.cpp @@ -22,100 +22,99 @@ #include "tgbot/tools/StringTools.h" -#include +#include #include -#include +#include using namespace std; namespace StringTools { bool startsWith(const string& str1, const string& str2) { - if (str1.length() < str2.length()) { - return false; - } - string::const_iterator it1(str1.begin()); - string::const_iterator end1(str1.end()); - string::const_iterator it2(str2.begin()); - string::const_iterator end2(str2.end()); - while (it1 != end1 && it2 != end2) { - if (*it1 != *it2) { - return false; - } - ++it1; - ++it2; - } - return true; + if (str1.length() < str2.length()) { + return false; + } + string::const_iterator it1(str1.begin()); + string::const_iterator end1(str1.end()); + string::const_iterator it2(str2.begin()); + string::const_iterator end2(str2.end()); + while (it1 != end1 && it2 != end2) { + if (*it1 != *it2) { + return false; + } + ++it1; + ++it2; + } + return true; } bool endsWith(const string& str1, const string& str2) { - if (str1.length() < str2.length()) { - return false; - } - string::const_iterator it1(str1.end()); - string::const_iterator begin1(str1.begin()); - string::const_iterator it2(str2.end()); - string::const_iterator begin2(str2.begin()); - --begin1; - --begin2; - while (it1 != begin1 && it2 != begin2) { - if (*it1 != *it2) { - return false; - } - --it1; - --it2; - } - return true; + if (str1.length() < str2.length()) { + return false; + } + string::const_iterator it1(str1.end()); + string::const_iterator begin1(str1.begin()); + string::const_iterator it2(str2.end()); + string::const_iterator begin2(str2.begin()); + --begin1; + --begin2; + while (it1 != begin1 && it2 != begin2) { + if (*it1 != *it2) { + return false; + } + --it1; + --it2; + } + return true; } void split(const string& str, char delimiter, vector& dest) { - istringstream stream(str); - string s; - while (getline(stream, s, delimiter)) { - dest.push_back(s); - } + istringstream stream(str); + string s; + while (getline(stream, s, delimiter)) { + dest.push_back(s); + } } string generateRandomString(size_t length) { - static const string chars("qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890-=[]\\;',./!@#$%^&*()_+{}|:\"<>?`~"); - static const size_t charsLen = chars.length(); - string result; - for (size_t i = 0; i < length; ++i) { - result += chars[rand() % charsLen]; - } - return result; + static const string chars("qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890-=[]\\;',./!@#$%^&*()_+{}|:\"<>?`~"); + static const size_t charsLen = chars.length(); + string result; + for (size_t i = 0; i < length; ++i) { + result += chars[rand() % charsLen]; + } + return result; } string urlEncode(const string& value, const std::string& additionalLegitChars) { - static const string legitPunctuation = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.-~:"; - std::stringstream ss; - for (auto const &c : value) { - if ((legitPunctuation.find(c) == std::string::npos) - && (additionalLegitChars.find(c)==std::string::npos)) { - ss << '%' << std::uppercase << std::setfill('0') << std::setw(2) << std::hex << (unsigned int)(unsigned char)c; - } else { - ss << c; - } - } + static const string legitPunctuation = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.-~:"; + std::stringstream ss; + for (auto const &c : value) { + if ((legitPunctuation.find(c) == std::string::npos) && (additionalLegitChars.find(c) == std::string::npos)) { + ss << '%' << std::uppercase << std::setfill('0') << std::setw(2) << std::hex << (unsigned int)(unsigned char)c; + } else { + ss << c; + } + } - return ss.str(); + return ss.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; + 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; } } -- cgit v1.2.3