diff options
author | Sergei Golubchik <sergii@pisem.net> | 2011-11-14 00:32:21 +0100 |
---|---|---|
committer | Sergei Golubchik <sergii@pisem.net> | 2011-11-14 00:32:21 +0100 |
commit | c25f47259926fcc10d3a4e072fd44aeeba71f108 (patch) | |
tree | 513bc1db6ce5ae596516680e9df9d605bf6f34b4 /plugin/feedback | |
parent | f76bfc40ea697473e7f1bea211a68a22210e7b53 (diff) | |
parent | b5d41c1c11ab4f34913f6a104638f860bcd74907 (diff) | |
download | mariadb-git-c25f47259926fcc10d3a4e072fd44aeeba71f108.tar.gz |
5.2->5.3 merge
Diffstat (limited to 'plugin/feedback')
-rw-r--r-- | plugin/feedback/url_http.cc | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/plugin/feedback/url_http.cc b/plugin/feedback/url_http.cc index e1f60d60de7..71b67a52807 100644 --- a/plugin/feedback/url_http.cc +++ b/plugin/feedback/url_http.cc @@ -155,7 +155,7 @@ int Url_http::send(const char* data, size_t data_length) { my_socket fd= INVALID_SOCKET; char buf[1024]; - uint len; + uint len= 0; addrinfo *addrs, *addr, filter= {0, AF_UNSPEC, SOCK_STREAM, 6, 0, 0, 0, 0}; int res= getaddrinfo(host.str, port.str, &filter, &addrs); @@ -258,7 +258,13 @@ int Url_http::send(const char* data, size_t data_length) Extract the first string between <h1>...</h1> tags and put it as a server reply into the error log. */ - len= vio_read(vio, (uchar*)buf, sizeof(buf)-1); + for (;;) + { + size_t i= vio_read(vio, (uchar*)buf + len, sizeof(buf) - len - 1); + if ((int)i <= 0) + break; + len+= i; + } if (len && len < sizeof(buf)) { char *from; |