webserv/webserv/utils/utils.cpp

156 lines
3.4 KiB
C++

#include "webserv/socket/ASocket.hpp"
#include <webserv/utils/utils.hpp>
#include <cstdint>
#include <sstream>
#include <stdexcept>
#include <string>
#include <type_traits>
#include <vector>
#include <sys/epoll.h>
namespace utils
{
size_t stoul(const std::string &str, int base)
{
if (str.find_first_not_of("0123456789abcdefABCDEF") != std::string::npos)
{
throw std::invalid_argument("Invalid number: " + str);
}
size_t idx = 0;
unsigned long value = std::stoul(str, &idx, base);
if (idx != str.length())
{
throw std::invalid_argument("Invalid number with extra characters: " + str);
}
return value;
}
std::string trim(const std::string &str, const std::string &charset)
{
size_t first = str.find_first_not_of(charset);
size_t last = str.find_last_not_of(charset);
if (first == std::string::npos || last == std::string::npos)
{
return "";
}
return str.substr(first, last - first + 1);
}
std::string trimSemi(const std::string &str)
{
size_t semi = str.find(';');
if (semi == str.length() - 1)
{
return str.substr(0, semi);
}
return str;
}
size_t findCorrespondingClosingBrace(const std::string &str, size_t openPos)
{
int braceCount = 1;
if (str[openPos] != '{')
{
return std::string::npos; // Not an opening brace at the given position
}
for (size_t i = openPos + 1; i < str.size(); ++i)
{
if (str[i] == '{')
{
++braceCount;
}
else if (str[i] == '}')
{
--braceCount;
}
if (braceCount == 0)
{
return i;
}
}
return std::string::npos;
}
void removeEmptyLines(std::string &str)
{
std::istringstream stream(str);
std::string line;
std::string result;
while (std::getline(stream, line))
{
if (!utils::trim(line).empty())
{
result += utils::trim(line, " \t\n\r;") + '\n';
}
}
str = result;
}
void removeComments(std::string &str)
{
size_t pos = 0;
while ((pos = str.find('#', pos)) != std::string::npos)
{
size_t end = str.find('\n', pos);
if (end == std::string::npos)
{
str.erase(pos);
}
else
{
str.erase(pos, end - pos);
}
}
removeEmptyLines(str);
}
std::vector<std::string> split(const std::string &str, char delimiter)
{
std::vector<std::string> parts;
std::string part;
std::istringstream stream(str);
while (std::getline(stream, part, delimiter))
{
parts.push_back(part);
}
return parts;
}
std::string implode(const std::vector<std::string> &elements, const std::string &delimiter)
{
std::ostringstream stream;
for (size_t i = 0; i < elements.size(); ++i)
{
stream << elements[i];
if (i < elements.size() - 1)
{
stream << delimiter;
}
}
return stream.str();
}
uint32_t stateToEpoll(const ASocket::IOState &event)
{
uint32_t epollEvents = 0;
using EventType = std::underlying_type_t<ASocket::IOState>;
if ((static_cast<EventType>(event) & static_cast<EventType>(ASocket::IOState::READ)) != 0U)
{
epollEvents |= EPOLLIN;
}
if ((static_cast<EventType>(event) & static_cast<EventType>(ASocket::IOState::WRITE)) != 0U)
{
epollEvents |= EPOLLOUT;
}
return epollEvents;
}
} // namespace utils