15 // Para no exportar los símbolos (uso interno de este módulo)
18 /// Saca espacios de una palabra
19 std::string strip(std::string s) {
20 std::string ws = " \t\n";
21 int first = s.find_first_not_of(ws);
22 int last = s.find_last_not_of(ws);
25 int pos_first = s.find_first_of(ws);
26 if (pos_first == -1) {
29 return std::string("");
32 return s.substr(first,last-first+1).c_str();
35 /// Devuelve palabra hasta el caracter indicado
36 std::string get_hasta(std::istream& is, char hasta)
39 std::getline(is, s, hasta);
46 input(const std::string& filename)
48 std::ifstream f(filename.c_str());
51 Persona::sexo_type sexo = Persona::M;
52 Persona::sexo_type opuesto = Persona::F;
54 while (std::getline(f, l))
57 // la linea vacia alterna de sexo
65 // obtenemos el nombre y la lista
66 std::istringstream ss(l);
67 std::string nombre = get_hasta(ss, ':');
68 Persona* pp = susanita.get_persona(nombre);
71 pp = new Persona(nombre, sexo);
72 susanita.add_persona(pp);
75 Persona::prefs_type prefs;
78 std::string nombre = get_hasta(ss, ',');
79 nombre = strip(nombre);
83 Persona* ppp = susanita.get_persona(nombre);
86 ppp = new Persona(nombre, opuesto);
87 susanita.add_persona(ppp);
89 pp->prefs.push_back(ppp);
99 for (Susanita::personas_type::const_iterator ih
100 = susanita.hombres.begin();
101 ih != susanita.hombres.end(); ++ih)
104 assert(h.estado == Persona::COMPROMETIDO);
105 std::cout << h.nombre << ", " << h.pareja->nombre << "\n";
108 for (Susanita::personas_type::const_iterator im
109 = susanita.mujeres.begin();
110 im != susanita.mujeres.end(); ++im)
113 assert(m.estado == Persona::COMPROMETIDO);
114 std::cout << m.nombre << ", " << m.pareja->nombre << "\n";