| 1 | /* | 
|---|
| 2 |  *   ORXONOX - the hottest 3D action shooter ever to exist | 
|---|
| 3 |  *                    > www.orxonox.net < | 
|---|
| 4 |  * | 
|---|
| 5 |  * | 
|---|
| 6 |  *   License notice: | 
|---|
| 7 |  * | 
|---|
| 8 |  *   This program is free software; you can redistribute it and/or | 
|---|
| 9 |  *   modify it under the terms of the GNU General Public License | 
|---|
| 10 |  *   as published by the Free Software Foundation; either version 2 | 
|---|
| 11 |  *   of the License, or (at your option) any later version. | 
|---|
| 12 |  * | 
|---|
| 13 |  *   This program is distributed in the hope that it will be useful, | 
|---|
| 14 |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 15 |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 16 |  *   GNU General Public License for more details. | 
|---|
| 17 |  * | 
|---|
| 18 |  *   You should have received a copy of the GNU General Public License | 
|---|
| 19 |  *   along with this program; if not, write to the Free Software | 
|---|
| 20 |  *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. | 
|---|
| 21 |  * | 
|---|
| 22 |  *   Author: | 
|---|
| 23 |  *      Nicolas Perrenoud <nicolape_at_ee.ethz.ch> | 
|---|
| 24 |  *   Co-authors: | 
|---|
| 25 |  *      ... | 
|---|
| 26 |  * | 
|---|
| 27 |  */ | 
|---|
| 28 |  | 
|---|
| 29 | #ifndef _Tokenizer_H__ | 
|---|
| 30 | #define _Tokenizer_H__ | 
|---|
| 31 |  | 
|---|
| 32 | #include <string> | 
|---|
| 33 | #include <iostream> | 
|---|
| 34 | #include <vector> | 
|---|
| 35 |  | 
|---|
| 36 | /** | 
|---|
| 37 |  * String tokenizer | 
|---|
| 38 |  * | 
|---|
| 39 |  * Splits a given string into several smaller strings | 
|---|
| 40 |  * using a delmiter (default is the comma). | 
|---|
| 41 |  * Returns the result as a vector<string> object | 
|---|
| 42 |  * | 
|---|
| 43 |  * @author Nicolas Perrenoud<nicolape_at_ee.ethz.ch> | 
|---|
| 44 |  */ | 
|---|
| 45 |  | 
|---|
| 46 | inline std::vector<std::string> tokenize(const std::string& str, const std::string& delimiters = ",") | 
|---|
| 47 | { | 
|---|
| 48 |   std::vector<std::string> tokens; | 
|---|
| 49 |  | 
|---|
| 50 |   // Skip delimiters at beginning. | 
|---|
| 51 |   std::string::size_type lastPos = str.find_first_not_of(delimiters, 0); | 
|---|
| 52 |   // Find first "non-delimiter". | 
|---|
| 53 |   std::string::size_type pos     = str.find_first_of(delimiters, lastPos); | 
|---|
| 54 |  | 
|---|
| 55 |   while (std::string::npos != pos || std::string::npos != lastPos) | 
|---|
| 56 |   { | 
|---|
| 57 |       // Found a token, add it to the vector. | 
|---|
| 58 |       tokens.push_back(str.substr(lastPos, pos - lastPos)); | 
|---|
| 59 |       // Skip delimiters.  Note the "not_of" | 
|---|
| 60 |       lastPos = str.find_first_not_of(delimiters, pos); | 
|---|
| 61 |       // Find next "non-delimiter" | 
|---|
| 62 |       pos = str.find_first_of(delimiters, lastPos); | 
|---|
| 63 |   } | 
|---|
| 64 |   return tokens; | 
|---|
| 65 | } | 
|---|
| 66 |  | 
|---|
| 67 |  | 
|---|
| 68 | #endif /* _Tokenizer_H__ */ | 
|---|