summaryrefslogtreecommitdiff
path: root/plugin/feedback
diff options
context:
space:
mode:
authorSergei Golubchik <sergii@pisem.net>2011-11-14 00:32:21 +0100
committerSergei Golubchik <sergii@pisem.net>2011-11-14 00:32:21 +0100
commitc25f47259926fcc10d3a4e072fd44aeeba71f108 (patch)
tree513bc1db6ce5ae596516680e9df9d605bf6f34b4 /plugin/feedback
parentf76bfc40ea697473e7f1bea211a68a22210e7b53 (diff)
parentb5d41c1c11ab4f34913f6a104638f860bcd74907 (diff)
downloadmariadb-git-c25f47259926fcc10d3a4e072fd44aeeba71f108.tar.gz
5.2->5.3 merge
Diffstat (limited to 'plugin/feedback')
-rw-r--r--plugin/feedback/url_http.cc10
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;