From bd62246033bcaa79c7be1ccddf9ebdc4678a879f Mon Sep 17 00:00:00 2001 From: Anthony Minessale Date: Fri, 23 Feb 2007 16:44:04 +0000 Subject: [PATCH] handle fragmented reads on the socket git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@4358 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- scripts/socket/FreeSWITCH/Client.pm | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/scripts/socket/FreeSWITCH/Client.pm b/scripts/socket/FreeSWITCH/Client.pm index 91282caee8..96daddd325 100644 --- a/scripts/socket/FreeSWITCH/Client.pm +++ b/scripts/socket/FreeSWITCH/Client.pm @@ -42,7 +42,6 @@ sub readhash($;$) { if ($i eq "") { $h->{socketerror} = "yes"; return $h; - last; } elsif ($i eq "\n") { $crc++; last; @@ -51,6 +50,7 @@ sub readhash($;$) { } $line .= $i; } + if (!$line) { last; } @@ -67,7 +67,15 @@ sub readhash($;$) { } if ($h->{'content-length'}) { - recv $s, $h->{body}, $h->{'content-length'}, 0; + while(length($h->{body}) < $h->{'content-length'}) { + my $buf; + recv $s, $buf, $h->{'content-length'}, 0; + if (!$buf) { + $h->{socketerror} = "yes"; + return $h; + } + $h->{body} .= $buf; + } } if ($h->{'content-type'} eq "text/event-plain") {