mirror of
https://github.com/moparisthebest/curl
synced 2025-01-06 03:18:04 -05:00
b3b2ba31f7
Basically in loops like handle_errors(), 'query->next' was assigned a local variable and then query was referenced after the memory was freed by next_server(). I've changed that so next_server() and end_query() returns the next query. So callers should use this ret-value. The next problem was that 'server->tcp_buffer_pos' had a random value at entry to 1st recv() (luckily causing Winsock to return ENOBUFS). I've also added a ares_writev() for Windows to streamline the code a bit more.
90 lines
1.9 KiB
C
90 lines
1.9 KiB
C
#include "setup.h"
|
|
|
|
#ifdef WIN32 /* only do the following on windows */
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
#include <string.h>
|
|
#include <errno.h>
|
|
#include <malloc.h>
|
|
|
|
#include "nameser.h"
|
|
|
|
#ifndef __MINGW32__
|
|
int
|
|
ares_strncasecmp(const char *a, const char *b, size_t n)
|
|
{
|
|
size_t i;
|
|
|
|
for (i = 0; i < n; i++) {
|
|
int c1 = isupper(a[i]) ? tolower(a[i]) : a[i];
|
|
int c2 = isupper(b[i]) ? tolower(b[i]) : b[i];
|
|
if (c1 != c2) return c1-c2;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
ares_strcasecmp(const char *a, const char *b)
|
|
{
|
|
return strncasecmp(a, b, strlen(a)+1);
|
|
}
|
|
#endif
|
|
|
|
int
|
|
ares_gettimeofday(struct timeval *tv, struct timezone *tz)
|
|
{
|
|
FILETIME ft;
|
|
LARGE_INTEGER li;
|
|
__int64 t;
|
|
static int tzflag;
|
|
|
|
if (tv)
|
|
{
|
|
GetSystemTimeAsFileTime(&ft);
|
|
li.LowPart = ft.dwLowDateTime;
|
|
li.HighPart = ft.dwHighDateTime;
|
|
t = li.QuadPart; /* In 100-nanosecond intervals */
|
|
//t -= EPOCHFILETIME; /* Offset to the Epoch time */
|
|
t /= 10; /* In microseconds */
|
|
tv->tv_sec = (long)(t / 1000000);
|
|
tv->tv_usec = (long)(t % 1000000);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
ares_writev (SOCKET s, const struct iovec *vector, size_t count)
|
|
{
|
|
char *buffer, *bp;
|
|
size_t i, bytes = 0;
|
|
|
|
/* Find the total number of bytes to write
|
|
*/
|
|
for (i = 0; i < count; i++)
|
|
bytes += vector[i].iov_len;
|
|
|
|
if (bytes == 0) /* not an error */
|
|
return (0);
|
|
|
|
/* Allocate a temporary buffer to hold the data
|
|
*/
|
|
buffer = bp = (char*) alloca (bytes);
|
|
if (!buffer)
|
|
{
|
|
errno = ENOMEM;
|
|
return (-1);
|
|
}
|
|
|
|
/* Copy the data into buffer.
|
|
*/
|
|
for (i = 0; i < count; ++i)
|
|
{
|
|
memcpy (bp, vector[i].iov_base, vector[i].iov_len);
|
|
bp += vector[i].iov_len;
|
|
}
|
|
return send (s, (const void*)buffer, bytes, 0);
|
|
}
|
|
#endif /* WIN32 builds only */
|