[project @ 2005-06-28 09:54:46 by unknown_lamer]
[clinton/bobotpp.git] / source / Socket.C
index 3e83568..aa85976 100644 (file)
 
 // You should have received a copy of the GNU General Public License
 // along with this program; if not, write to the Free Software
-// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307, USA.
+// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 
 #include "Socket.H"
+#include "Bot.H"
+#include <string>
 
 #include <sys/types.h>
 #include <sys/socket.h>
@@ -190,7 +192,11 @@ Socket::connect()
   addr.sin_addr.s_addr = htonl(remoteAddress);
   addr.sin_port = htons(remotePort);
   if (::connect(fd->fd, (struct sockaddr *)&addr, sizeof(addr)) < 0)
-    return false;
+    {
+      //      Bot::logLine (String("Socket Error: ") 
+      //                   + strerror (errno) + String("\n"));
+      return false;
+    }
   
   return true;
 }
@@ -243,9 +249,24 @@ Socket::write(String s, bool m)
 String
 Socket::readLine()
 {
-  static char buf[512];
-  int pos = 0, nb;
-  char r;
+  // fixme: this could probably be sped up (use some faster way of
+  // reading from the socket than reading a char at a time)
+
+  // We allocate the buffer statically to keep from having to overhead
+  // of reallocating a new buffer every time we call this (which is
+  // every time anything happens on IRC so the overhead of
+  // re-allocating a buffer every time is potentially too large). 
+  //
+  // Since it is static, and the length of lines will differ for each
+  // read, an embedded \0 is inserted after the last character of the
+  // line and then a copy of the the c_str is returned as a String so
+  // that only the line that was just read is returned.
+  static std::string buf (512, ' ');
+
+  std::string::size_type pos = 0; // pos in buffer
+  int nb; // number of bytes read by ::read
+  char r; // temp var for storing output of read into
+  std::string::size_type length = buf.length ();
   
   do 
     {
@@ -260,15 +281,25 @@ Socket::readLine()
       }
       
       if (nb != -1)
-       buf[pos++] = r;
+       if (pos < length)
+         buf[pos++] = r;
+       else
+         {
+           buf.resize (length * 2);
+           length = buf.length ();
+           buf[pos++] = r;
+         }
     } while (r != '\n');
   
-if (pos > 1 && buf[pos-2] == '\r')
+  if (pos > 1 && buf[pos-2] == '\r')
     buf[pos-2] = '\0';
   else
-  buf[pos-1] = '\0';
-
-  return String(buf);
+    buf[pos-1] = '\0';
+  
+  // c_str () is used because the String constructor for std::string
+  // will copy the entire std::string into it when we only want it to
+  // copy up to the first null.
+  return String (buf.c_str ());
 }
 
 String