]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blobdiff - Server/src/httpmessage.cpp
Ya anda de nuevo el server. Compila y anda tan (in?)estable como antes, aunque tiene...
[z.facultad/75.42/plaqui.git] / Server / src / httpmessage.cpp
index 685fa69ad92b9e8912da6927f00cbbfc80c36ac5..cfdd89404fab55f58f07ed292250a912e0accee2 100644 (file)
@@ -25,6 +25,7 @@
 // $Id$
 //
 
+#include "plaqui/server/string.h"
 #include "plaqui/server/httpmessage.h"
 #include <sstream>
 #include <cstdlib>
@@ -82,27 +83,36 @@ istream& operator>>(istream& is, HTTPMessage& m) {
 #endif // DEBUG
        char buf[BUFSIZ];
        bool is_header = true;
-       stringstream body_ss;
+       // TODO body
+       // Para hacer que reciba bien el body hay que chequear la cabecera
+       // Content-length, si queda tiempo lo haré...
+       //stringstream body_ss;
        while (is.getline(buf, BUFSIZ)) {
-               string sbuf = buf;
+               String sbuf(buf);
+               sbuf.trim();
                if (sbuf.length()) {
                        if (is_header) {
                                stringstream ss;
-                               ss << buf;
+                               ss << sbuf;
                                ss >> m.headers;
-                       } else {
-                               body_ss << buf << endl;
-                       }
+                       }// else { TODO body
+                       //      body_ss << sbuf << endl;
+                       //}
                } else {
                        if (is_header) {
+                               // TODO body
+                               // Ver si tiene un Content-Length para saber si esperamos body.
+                               // Si no esperamos body, no hay que hacer otro is.getline()
+                               // porque se queda esperando forever.
                                is_header = false;
-                       } else {
-                               body_ss << buf << endl;
-                       }
+                               break;
+                       }// else { TODO body
+                       //      body_ss << sbuf << endl;
+                       //}
                }
        }
-       // TODO si el body es un serializable, deberia auto deserializarse.
-       m.body = body_ss.str();
+       // TODO body
+       //m.body = body_ss.str();
        return is;
 }