2010-11-29 19:13:04 +01:00
|
|
|
/*
|
2013-02-24 18:40:43 +01:00
|
|
|
Minetest
|
2013-02-24 19:38:45 +01:00
|
|
|
Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
|
2010-11-29 19:13:04 +01:00
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
2012-06-05 16:56:56 +02:00
|
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2.1 of the License, or
|
2010-11-29 19:13:04 +01:00
|
|
|
(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
|
2012-06-05 16:56:56 +02:00
|
|
|
GNU Lesser General Public License for more details.
|
2010-11-29 19:13:04 +01:00
|
|
|
|
2012-06-05 16:56:56 +02:00
|
|
|
You should have received a copy of the GNU Lesser General Public License along
|
2010-11-29 19:13:04 +01:00
|
|
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
2010-11-27 00:02:21 +01:00
|
|
|
#ifndef STRFND_HEADER
|
|
|
|
#define STRFND_HEADER
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2010-12-22 15:30:23 +01:00
|
|
|
std::string trim(const std::string &str);
|
2010-11-27 00:02:21 +01:00
|
|
|
|
|
|
|
class Strfnd{
|
|
|
|
std::string tek;
|
|
|
|
unsigned int p;
|
|
|
|
public:
|
|
|
|
void start(std::string niinq){
|
|
|
|
tek = niinq;
|
|
|
|
p=0;
|
|
|
|
}
|
|
|
|
unsigned int where(){
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
void to(unsigned int i){
|
|
|
|
p = i;
|
|
|
|
}
|
|
|
|
std::string what(){
|
|
|
|
return tek;
|
|
|
|
}
|
|
|
|
std::string next(std::string plop){
|
|
|
|
//std::cout<<"tek=\""<<tek<<"\" plop=\""<<plop<<"\""<<std::endl;
|
|
|
|
size_t n;
|
|
|
|
std::string palautus;
|
|
|
|
if (p < tek.size())
|
|
|
|
{
|
|
|
|
//std::cout<<"\tp<tek.size()"<<std::endl;
|
|
|
|
if ((n = tek.find(plop, p)) == std::string::npos || plop == "")
|
|
|
|
{
|
|
|
|
//std::cout<<"\t\tn == string::npos || plop == \"\""<<std::endl;
|
|
|
|
n = tek.size();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//std::cout<<"\t\tn != string::npos"<<std::endl;
|
|
|
|
}
|
|
|
|
palautus = tek.substr(p, n-p);
|
|
|
|
p = n + plop.length();
|
|
|
|
}
|
|
|
|
//else
|
|
|
|
//std::cout<<"\tp>=tek.size()"<<std::endl;
|
|
|
|
//std::cout<<"palautus=\""<<palautus<<"\""<<std::endl;
|
|
|
|
return palautus;
|
|
|
|
}
|
2013-02-24 22:00:35 +01:00
|
|
|
|
|
|
|
// Returns substr of tek up to the next occurence of plop that isn't escaped with '\'
|
|
|
|
std::string next_esc(std::string plop) {
|
|
|
|
size_t n, realp;
|
|
|
|
|
|
|
|
if (p >= tek.size())
|
|
|
|
return "";
|
|
|
|
|
|
|
|
realp = p;
|
|
|
|
do {
|
|
|
|
n = tek.find(plop, p);
|
|
|
|
if (n == std::string::npos || plop == "")
|
|
|
|
n = tek.length();
|
|
|
|
p = n + plop.length();
|
|
|
|
} while (n > 0 && tek[n - 1] == '\\');
|
|
|
|
|
|
|
|
return tek.substr(realp, n - realp);
|
|
|
|
}
|
|
|
|
|
2011-11-16 21:47:37 +01:00
|
|
|
void skip_over(std::string chars){
|
|
|
|
while(p < tek.size()){
|
|
|
|
bool is = false;
|
|
|
|
for(unsigned int i=0; i<chars.size(); i++){
|
|
|
|
if(chars[i] == tek[p]){
|
|
|
|
is = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(!is) break;
|
|
|
|
p++;
|
|
|
|
}
|
|
|
|
}
|
2010-11-27 00:02:21 +01:00
|
|
|
bool atend(){
|
|
|
|
if(p>=tek.size()) return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
Strfnd(std::string s){
|
|
|
|
start(s);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2011-07-30 18:31:33 +02:00
|
|
|
class WStrfnd{
|
|
|
|
std::wstring tek;
|
|
|
|
unsigned int p;
|
|
|
|
public:
|
|
|
|
void start(std::wstring niinq){
|
|
|
|
tek = niinq;
|
|
|
|
p=0;
|
|
|
|
}
|
|
|
|
unsigned int where(){
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
void to(unsigned int i){
|
|
|
|
p = i;
|
|
|
|
}
|
|
|
|
std::wstring what(){
|
|
|
|
return tek;
|
|
|
|
}
|
|
|
|
std::wstring next(std::wstring plop){
|
|
|
|
//std::cout<<"tek=\""<<tek<<"\" plop=\""<<plop<<"\""<<std::endl;
|
|
|
|
size_t n;
|
|
|
|
std::wstring palautus;
|
|
|
|
if (p < tek.size())
|
|
|
|
{
|
|
|
|
//std::cout<<"\tp<tek.size()"<<std::endl;
|
|
|
|
if ((n = tek.find(plop, p)) == std::wstring::npos || plop == L"")
|
|
|
|
{
|
|
|
|
//std::cout<<"\t\tn == string::npos || plop == \"\""<<std::endl;
|
|
|
|
n = tek.size();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//std::cout<<"\t\tn != string::npos"<<std::endl;
|
|
|
|
}
|
|
|
|
palautus = tek.substr(p, n-p);
|
|
|
|
p = n + plop.length();
|
|
|
|
}
|
|
|
|
//else
|
|
|
|
//std::cout<<"\tp>=tek.size()"<<std::endl;
|
|
|
|
//std::cout<<"palautus=\""<<palautus<<"\""<<std::endl;
|
|
|
|
return palautus;
|
|
|
|
}
|
2013-02-24 22:00:35 +01:00
|
|
|
|
|
|
|
std::wstring next_esc(std::wstring plop) {
|
|
|
|
size_t n, realp;
|
|
|
|
|
|
|
|
if (p >= tek.size())
|
|
|
|
return L"";
|
|
|
|
|
|
|
|
realp = p;
|
|
|
|
do {
|
|
|
|
n = tek.find(plop, p);
|
|
|
|
if (n == std::wstring::npos || plop == L"")
|
|
|
|
n = tek.length();
|
|
|
|
p = n + plop.length();
|
|
|
|
} while (n > 0 && tek[n - 1] == '\\');
|
|
|
|
|
|
|
|
return tek.substr(realp, n - realp);
|
|
|
|
}
|
|
|
|
|
2011-07-30 18:31:33 +02:00
|
|
|
bool atend(){
|
|
|
|
if(p>=tek.size()) return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
WStrfnd(std::wstring s){
|
|
|
|
start(s);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-12-22 15:30:23 +01:00
|
|
|
inline std::string trim(const std::string &s)
|
2010-11-27 00:02:21 +01:00
|
|
|
{
|
2010-12-22 15:30:23 +01:00
|
|
|
std::string str = s;
|
2010-11-27 00:02:21 +01:00
|
|
|
while(
|
|
|
|
str.length()>0
|
|
|
|
&&
|
|
|
|
(
|
|
|
|
str.substr(0, 1)==" " ||
|
|
|
|
str.substr(0, 1)=="\t" ||
|
|
|
|
str.substr(0, 1)=="\r" ||
|
|
|
|
str.substr(0, 1)=="\n" ||
|
|
|
|
str.substr(str.length()-1, 1)==" " ||
|
|
|
|
str.substr(str.length()-1, 1)=="\t" ||
|
|
|
|
str.substr(str.length()-1, 1)=="\r" ||
|
|
|
|
str.substr(str.length()-1, 1)=="\n"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (str.substr(0, 1)==" ")
|
|
|
|
str = str.substr(1,str.length()-1);
|
|
|
|
else if (str.substr(0, 1)=="\t")
|
|
|
|
str = str.substr(1,str.length()-1);
|
|
|
|
else if (str.substr(0, 1)=="\r")
|
|
|
|
str = str.substr(1,str.length()-1);
|
|
|
|
else if (str.substr(0, 1)=="\n")
|
|
|
|
str = str.substr(1,str.length()-1);
|
|
|
|
else if (str.substr(str.length()-1, 1)==" ")
|
|
|
|
str = str.substr(0,str.length()-1);
|
|
|
|
else if (str.substr(str.length()-1, 1)=="\t")
|
|
|
|
str = str.substr(0,str.length()-1);
|
|
|
|
else if (str.substr(str.length()-1, 1)=="\r")
|
|
|
|
str = str.substr(0,str.length()-1);
|
|
|
|
else if (str.substr(str.length()-1, 1)=="\n")
|
|
|
|
str = str.substr(0,str.length()-1);
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|