1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
/* -----------------------------------------------------------------------------
*
* Monocasual Utils
*
* -----------------------------------------------------------------------------
*
* Copyright (C) 2021-2025 Giovanni A. Zuliani | Monocasual
*
* This file is part of Monocasual Utils.
*
* Monocasual Utils is free software: you can
* redistribute it and/or modify it under the terms of the GNU General
* Public License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* Monocasual Utils is distributed in the hope that it
* will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Giada - Monocasual Utils. If not, see
* <http://www.gnu.org/licenses/>.
*
* -------------------------------------------------------------------------- */
#include "string.hpp"
#include <climits>
#include <cstdarg>
#include <iomanip>
#include <vector>
namespace mcl::utils::string
{
std::string trim(const std::string& s)
{
std::size_t first = s.find_first_not_of(" \n\t");
std::size_t last = s.find_last_not_of(" \n\t");
return s.substr(first, last - first + 1);
}
/* -------------------------------------------------------------------------- */
std::string replace(std::string in, const std::string& search, const std::string& replace)
{
std::size_t pos = 0;
while ((pos = in.find(search, pos)) != std::string::npos)
{
in.replace(pos, search.length(), replace);
pos += replace.length();
}
return in;
}
/* -------------------------------------------------------------------------- */
bool contains(const std::string& s, char c)
{
return s.find(c) != std::string::npos;
}
/* -------------------------------------------------------------------------- */
std::vector<std::string> split(const std::string& in, const std::string& sep)
{
std::vector<std::string> out;
std::string full = in;
std::string token = "";
std::size_t curr = 0;
std::size_t next = -1;
do
{
curr = next + 1;
next = full.find_first_of(sep, curr);
token = full.substr(curr, next - curr);
if (token != "")
out.push_back(token);
} while (next != std::string::npos);
return out;
}
/* -------------------------------------------------------------------------- */
float toFloat(const std::string& s)
{
try
{
return std::stof(s);
}
catch (const std::exception&)
{
return 0.0f;
}
}
/* -------------------------------------------------------------------------- */
int toInt(const std::string& s)
{
try
{
return std::stoi(s);
}
catch (const std::exception&)
{
return 0;
}
}
} // namespace mcl::utils::string
|