mirror of
https://github.com/matrix-construct/construct
synced 2025-01-01 02:14:13 +01:00
156 lines
5.3 KiB
C++
156 lines
5.3 KiB
C++
/*
|
|
* charybdis: an advanced ircd.
|
|
* inline/stringops.h: inlined string operations used in a few places
|
|
*
|
|
* Copyright (C) 2005-2016 Charybdis Development Team
|
|
*
|
|
* This program 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 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program 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 this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
* USA
|
|
*/
|
|
|
|
#pragma once
|
|
#define HAVE_IRCD_STRINGOPS_H
|
|
|
|
#ifdef __cplusplus
|
|
namespace ircd {
|
|
|
|
using token_closure_cstr = std::function<void (char *const &)>;
|
|
void tokens(char *const &str, const char *const &sep, const token_closure_cstr &);
|
|
void tokens(const char *const &str, const char *const &sep, char *const &buf, const size_t &max, const token_closure_cstr &);
|
|
void tokens(const char *const &str, const char *const &sep, const token_closure_cstr &);
|
|
void tokensa(const char *const &str, const char *const &sep, const token_closure_cstr &);
|
|
std::vector<char *> tokens(const char *const &str, const char *const &sep, char *const &buf, const size_t &max, const size_t &reserve = 16);
|
|
|
|
using token_closure_string = std::function<void (const std::string &)>;
|
|
void tokens(const std::string &str, const char *const &sep, const token_closure_string &);
|
|
std::vector<std::string> tokens(const std::string &str, const char *const &sep, const size_t &reserve = 16);
|
|
size_t token_count(const std::string &str, const char *const &sep);
|
|
std::string token(const std::string &str, const char *const &sep, const size_t &at);
|
|
std::string token_last(const std::string &str, const char *const &sep);
|
|
|
|
std::string chomp(const std::string &str, const std::string &c = " "s);
|
|
std::pair<std::string, std::string> split(const std::string &str, const std::string &delim = " "s);
|
|
std::pair<std::string, std::string> rsplit(const std::string &str, const std::string &delim = " "s);
|
|
std::string between(const std::string &str, const std::string &a = "("s, const std::string &b = ")"s);
|
|
bool endswith(const std::string &str, const char *const &val);
|
|
bool endswith(const std::string &str, const std::string &val);
|
|
bool endswith(const std::string &str, const char &val);
|
|
template<class It> bool endswith_any(const std::string &str, const It &begin, const It &end);
|
|
bool startswith(const std::string &str, const char *const &val);
|
|
bool startswith(const std::string &str, const std::string &val);
|
|
bool startswith(const std::string &str, const char &val);
|
|
|
|
char *strip_colour(char *string);
|
|
char *strip_unprintable(char *string);
|
|
char *reconstruct_parv(int parc, const char **parv);
|
|
|
|
} // namespace ircd
|
|
|
|
inline bool
|
|
ircd::startswith(const std::string &str,
|
|
const char &val)
|
|
{
|
|
return !str.empty() && str[0] == val;
|
|
}
|
|
|
|
inline bool
|
|
ircd::startswith(const std::string &str,
|
|
const std::string &val)
|
|
{
|
|
const auto pos(str.find(val, 0));
|
|
return pos == 0;
|
|
}
|
|
|
|
inline bool
|
|
ircd::startswith(const std::string &str,
|
|
const char *const &val)
|
|
{
|
|
const auto pos(str.find(val, 0, strlen(val)));
|
|
return pos == 0;
|
|
}
|
|
|
|
template<class It>
|
|
bool
|
|
ircd::endswith_any(const std::string &str,
|
|
const It &begin,
|
|
const It &end)
|
|
{
|
|
return std::any_of(begin, end, [&str](const auto &val)
|
|
{
|
|
return endswith(str, val);
|
|
});
|
|
}
|
|
|
|
inline bool
|
|
ircd::endswith(const std::string &str,
|
|
const char &val)
|
|
{
|
|
return !str.empty() && str[str.size()-1] == val;
|
|
}
|
|
|
|
inline bool
|
|
ircd::endswith(const std::string &str,
|
|
const std::string &val)
|
|
{
|
|
const auto vlen(std::min(str.size(), val.size()));
|
|
const auto pos(str.find(val, vlen));
|
|
return pos == str.size() - vlen;
|
|
}
|
|
|
|
inline bool
|
|
ircd::endswith(const std::string &str,
|
|
const char *const &val)
|
|
{
|
|
const auto vlen(std::min(str.size(), strlen(val)));
|
|
const auto pos(str.find(val, str.size() - vlen));
|
|
return pos == str.size() - vlen;
|
|
}
|
|
|
|
inline std::string
|
|
ircd::between(const std::string &str,
|
|
const std::string &a,
|
|
const std::string &b)
|
|
{
|
|
return split(split(str, a).second, b).first;
|
|
}
|
|
|
|
|
|
inline std::pair<std::string, std::string>
|
|
ircd::rsplit(const std::string &str,
|
|
const std::string &delim)
|
|
{
|
|
const auto pos(str.find_last_of(delim));
|
|
return pos == std::string::npos? std::make_pair(std::string{}, str):
|
|
std::make_pair(str.substr(0, pos), str.substr(pos+delim.size()));
|
|
}
|
|
|
|
inline std::pair<std::string, std::string>
|
|
ircd::split(const std::string &str,
|
|
const std::string &delim)
|
|
{
|
|
const auto pos(str.find(delim));
|
|
return pos == std::string::npos? std::make_pair(str, std::string{}):
|
|
std::make_pair(str.substr(0, pos), str.substr(pos+delim.size()));
|
|
}
|
|
|
|
inline std::string
|
|
ircd::chomp(const std::string &str,
|
|
const std::string &c)
|
|
{
|
|
const auto pos(str.find_last_not_of(c));
|
|
return pos == std::string::npos? str : str.substr(0, pos+1);
|
|
}
|
|
|
|
#endif // __cplusplus
|