ndb - bug#24011

parent 4037a8d6
...@@ -53,10 +53,6 @@ readln_socket(NDB_SOCKET_TYPE socket, int timeout_millis, ...@@ -53,10 +53,6 @@ readln_socket(NDB_SOCKET_TYPE socket, int timeout_millis,
if(buflen <= 1) if(buflen <= 1)
return 0; return 0;
int sock_flags= fcntl(socket, F_GETFL);
if(fcntl(socket, F_SETFL, sock_flags | O_NONBLOCK) == -1)
return -1;
fd_set readset; fd_set readset;
FD_ZERO(&readset); FD_ZERO(&readset);
FD_SET(socket, &readset); FD_SET(socket, &readset);
...@@ -71,43 +67,65 @@ readln_socket(NDB_SOCKET_TYPE socket, int timeout_millis, ...@@ -71,43 +67,65 @@ readln_socket(NDB_SOCKET_TYPE socket, int timeout_millis,
} }
if(selectRes == -1){ if(selectRes == -1){
fcntl(socket, F_SETFL, sock_flags);
return -1;
}
buf[0] = 0;
const int t = recv(socket, buf, buflen, MSG_PEEK);
if(t < 1)
{
fcntl(socket, F_SETFL, sock_flags);
return -1; return -1;
} }
for(int i=0; i< t;i++) char* ptr = buf;
int len = buflen;
do
{ {
if(buf[i] == '\n'){ int t;
recv(socket, buf, i+1, 0); while((t = recv(socket, ptr, len, MSG_PEEK)) == -1 && errno == EINTR);
buf[i] = 0;
if(t < 1)
{
return -1;
}
if(i > 0 && buf[i-1] == '\r'){
i--; for(int i = 0; i<t; i++)
buf[i] = 0; {
if(ptr[i] == '\n')
{
/**
* Now consume
*/
for (len = 1 + i; len; )
{
while ((t = recv(socket, ptr, len, 0)) == -1 && errno == EINTR);
if (t < 1)
return -1;
ptr += t;
len -= t;
}
ptr[0]= 0;
return ptr - buf;
} }
fcntl(socket, F_SETFL, sock_flags);
return t;
} }
}
for (int tmp = t; tmp; )
if(t == (buflen - 1)){ {
recv(socket, buf, t, 0); while ((t = recv(socket, ptr, tmp, 0)) == -1 && errno == EINTR);
buf[t] = 0; if (t < 1)
fcntl(socket, F_SETFL, sock_flags); {
return buflen; return -1;
} }
ptr += t;
len -= t;
tmp -= t;
}
return 0; FD_ZERO(&readset);
FD_SET(socket, &readset);
timeout.tv_sec = (timeout_millis / 1000);
timeout.tv_usec = (timeout_millis % 1000) * 1000;
const int selectRes = select(socket + 1, &readset, 0, 0, &timeout);
if(selectRes != 1){
return -1;
}
} while (len > 0);
return -1;
} }
extern "C" extern "C"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment