1 // vim: set noexpandtab tabstop=4 shiftwidth=4:
2 //----------------------------------------------------------------------------
4 //----------------------------------------------------------------------------
5 // This file is part of PlaQui.
7 // PlaQui is free software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the Free Software
9 // Foundation; either version 2 of the License, or (at your option) any later
12 // PlaQui is distributed in the hope that it will be useful, but WITHOUT ANY
13 // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 // FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 // You should have received a copy of the GNU General Public License along
18 // with PlaQui; if not, write to the Free Software Foundation, Inc., 59 Temple
19 // Place, Suite 330, Boston, MA 02111-1307 USA
20 //----------------------------------------------------------------------------
21 // Creado: dom oct 19 16:46:00 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
28 #ifndef PLAQUI_STRING_H
29 #define PLAQUI_STRING_H
40 * Convierte de un tipo a otro (de p1 a p2) a través de un stringstream.
42 * \param p1 Parámetro origen.
43 * \param p1 Parámetro destino, al que se quiere convertir.
45 * \return Referencia a p2.
47 template < class T1, class T2 > static T2& to(const T1& p1, T2& p2) {
48 std::stringstream ss(p1);
55 class String: public std::string {
59 /// Caracteres que son considerados espacios a la hora de parsear.
60 static const std::string SPACE_CHARS;
65 virtual ~String(void);
75 * \param str String a copiar.
77 String(const std::string& str);
80 * Constructor a partir de un vector.
81 * Convierte el vector en string uniendo sus componentes a traves
85 * \param sep Separador.
87 String(const std::vector<std::string>& v,
88 const std::string& sep);
91 * Elmina caracteres al inicio y fin de un string.
93 * \param c Lista de caracteres a eliminar.
95 String& trim(const String& clist = SPACE_CHARS);
98 * Convierte a mayúsculas.
100 String& to_upper(void);
103 * Convierte a mayúsculas.
105 String& to_lower(void);
108 * Fracciona una cadena convirtiendola en un vector.
110 * \param sep Caracter usado como separador.
112 std::vector<std::string> split(char sep) const;
115 * Concatena los elementos de un vector.
118 * \param sep Separador.
120 static String join(const std::vector<std::string>& v,
121 const std::string& sep);
124 * Convierte un string a otro tipo.
126 * \param p Parametro del tipo al que se quiere convertir.
128 template < class T > T& to(T& p) const {
129 std::stringstream ss(*this);
135 * Convierte un tipo a string.
137 * \param p Parametro del tipo que se quiere convertir a string.
139 template < class T > String& from(const T& p) {
140 std::stringstream ss;
152 #endif // PLAQUI_STRING_H