3 Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation; either version 2.1 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
25 std::string trim(const std::string &str);
31 void start(std::string niinq){
38 void to(unsigned int i){
44 std::string next(std::string plop){
45 //std::cout<<"tek=\""<<tek<<"\" plop=\""<<plop<<"\""<<std::endl;
50 //std::cout<<"\tp<tek.size()"<<std::endl;
51 if ((n = tek.find(plop, p)) == std::string::npos || plop == "")
53 //std::cout<<"\t\tn == string::npos || plop == \"\""<<std::endl;
58 //std::cout<<"\t\tn != string::npos"<<std::endl;
60 palautus = tek.substr(p, n-p);
61 p = n + plop.length();
64 //std::cout<<"\tp>=tek.size()"<<std::endl;
65 //std::cout<<"palautus=\""<<palautus<<"\""<<std::endl;
68 void skip_over(std::string chars){
69 while(p < tek.size()){
71 for(unsigned int i=0; i<chars.size(); i++){
72 if(chars[i] == tek[p]){
82 if(p>=tek.size()) return true;
85 Strfnd(std::string s){
94 void start(std::wstring niinq){
101 void to(unsigned int i){
107 std::wstring next(std::wstring plop){
108 //std::cout<<"tek=\""<<tek<<"\" plop=\""<<plop<<"\""<<std::endl;
110 std::wstring palautus;
113 //std::cout<<"\tp<tek.size()"<<std::endl;
114 if ((n = tek.find(plop, p)) == std::wstring::npos || plop == L"")
116 //std::cout<<"\t\tn == string::npos || plop == \"\""<<std::endl;
121 //std::cout<<"\t\tn != string::npos"<<std::endl;
123 palautus = tek.substr(p, n-p);
124 p = n + plop.length();
127 //std::cout<<"\tp>=tek.size()"<<std::endl;
128 //std::cout<<"palautus=\""<<palautus<<"\""<<std::endl;
132 if(p>=tek.size()) return true;
135 WStrfnd(std::wstring s){
140 inline std::string trim(const std::string &s)
147 str.substr(0, 1)==" " ||
148 str.substr(0, 1)=="\t" ||
149 str.substr(0, 1)=="\r" ||
150 str.substr(0, 1)=="\n" ||
151 str.substr(str.length()-1, 1)==" " ||
152 str.substr(str.length()-1, 1)=="\t" ||
153 str.substr(str.length()-1, 1)=="\r" ||
154 str.substr(str.length()-1, 1)=="\n"
158 if (str.substr(0, 1)==" ")
159 str = str.substr(1,str.length()-1);
160 else if (str.substr(0, 1)=="\t")
161 str = str.substr(1,str.length()-1);
162 else if (str.substr(0, 1)=="\r")
163 str = str.substr(1,str.length()-1);
164 else if (str.substr(0, 1)=="\n")
165 str = str.substr(1,str.length()-1);
166 else if (str.substr(str.length()-1, 1)==" ")
167 str = str.substr(0,str.length()-1);
168 else if (str.substr(str.length()-1, 1)=="\t")
169 str = str.substr(0,str.length()-1);
170 else if (str.substr(str.length()-1, 1)=="\r")
171 str = str.substr(0,str.length()-1);
172 else if (str.substr(str.length()-1, 1)=="\n")
173 str = str.substr(0,str.length()-1);