2004-07-22 22:18:45 +00:00
|
|
|
#include "setup.h"
|
|
|
|
|
2004-08-20 13:45:26 +00:00
|
|
|
/* only do the following on windows
|
|
|
|
*/
|
|
|
|
#if (defined(WIN32) || defined(WATT32)) && !defined(MSDOS)
|
2003-10-07 21:54:04 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <string.h>
|
2004-07-24 21:47:49 +00:00
|
|
|
#include <errno.h>
|
|
|
|
#include <malloc.h>
|
2003-10-07 21:54:04 +00:00
|
|
|
|
2004-08-20 13:45:26 +00:00
|
|
|
#ifdef WATT32
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#else
|
2003-10-07 21:54:04 +00:00
|
|
|
#include "nameser.h"
|
2004-08-20 13:45:26 +00:00
|
|
|
#endif
|
|
|
|
#include "ares.h"
|
|
|
|
#include "ares_private.h"
|
2003-10-07 21:54:04 +00:00
|
|
|
|
2004-03-09 10:18:09 +00:00
|
|
|
#ifndef __MINGW32__
|
2003-10-07 21:54:04 +00:00
|
|
|
int
|
2004-08-20 13:45:26 +00:00
|
|
|
ares_strncasecmp(const char *a, const char *b, int n)
|
2003-10-07 21:54:04 +00:00
|
|
|
{
|
2004-08-20 13:45:26 +00:00
|
|
|
int i;
|
2003-10-07 21:54:04 +00:00
|
|
|
|
|
|
|
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
|
2004-02-04 08:00:25 +00:00
|
|
|
ares_strcasecmp(const char *a, const char *b)
|
2003-10-07 21:54:04 +00:00
|
|
|
{
|
|
|
|
return strncasecmp(a, b, strlen(a)+1);
|
|
|
|
}
|
2004-03-09 10:18:09 +00:00
|
|
|
#endif
|
2003-10-07 21:54:04 +00:00
|
|
|
|
2004-11-10 14:23:20 +00:00
|
|
|
/*
|
|
|
|
* Number of micro-seconds between the beginning of the Windows epoch
|
|
|
|
* (Jan. 1, 1601) and the Unix epoch (Jan. 1, 1970).
|
|
|
|
*/
|
|
|
|
#if defined(_MSC_VER) || defined(__WATCOMC__)
|
|
|
|
#define EPOCH_FILETIME 11644473600000000Ui64
|
|
|
|
#else
|
|
|
|
#define EPOCH_FILETIME 11644473600000000ULL
|
|
|
|
#endif
|
|
|
|
|
2004-07-22 22:18:45 +00:00
|
|
|
int
|
|
|
|
ares_gettimeofday(struct timeval *tv, struct timezone *tz)
|
2003-10-07 21:54:04 +00:00
|
|
|
{
|
|
|
|
FILETIME ft;
|
|
|
|
LARGE_INTEGER li;
|
|
|
|
__int64 t;
|
|
|
|
|
|
|
|
if (tv)
|
|
|
|
{
|
|
|
|
GetSystemTimeAsFileTime(&ft);
|
|
|
|
li.LowPart = ft.dwLowDateTime;
|
|
|
|
li.HighPart = ft.dwHighDateTime;
|
2004-11-10 14:23:20 +00:00
|
|
|
t = li.QuadPart / 10; /* In micro-second intervals */
|
|
|
|
t -= EPOCH_FILETIME; /* Offset to the Epoch time */
|
2003-10-07 21:54:04 +00:00
|
|
|
tv->tv_sec = (long)(t / 1000000);
|
|
|
|
tv->tv_usec = (long)(t % 1000000);
|
|
|
|
}
|
2004-11-10 14:23:20 +00:00
|
|
|
(void) tz;
|
2003-10-07 21:54:04 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2004-07-22 22:18:45 +00:00
|
|
|
|
2004-07-24 21:47:49 +00:00
|
|
|
int
|
2004-08-20 13:45:26 +00:00
|
|
|
ares_writev (ares_socket_t s, const struct iovec *vector, size_t count)
|
2004-07-24 21:47:49 +00:00
|
|
|
{
|
|
|
|
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);
|
|
|
|
}
|
2004-07-22 22:18:45 +00:00
|
|
|
#endif /* WIN32 builds only */
|