X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/e68f34816f462dea879082b69eb1df7cfb1b0c0f..f0359dd00d60d72c4b3dec85de8e490692f6015c:/lib/compat.c diff --git a/lib/compat.c b/lib/compat.c index 9b411cda..a6d7d708 100644 --- a/lib/compat.c +++ b/lib/compat.c @@ -72,7 +72,7 @@ #ifndef HAVE_MEMMOVE void *memmove(void *dest, const void *src, size_t n) { - memcpy(dest, src, n); + bcopy((char *) src, (char *) dest, n); return dest; } #endif @@ -145,3 +145,40 @@ return ret; } #endif + +#ifndef HAVE_INET_ATON + int inet_aton(const char *cp, struct in_addr *inp) +{ + unsigned int a1, a2, a3, a4; + unsigned long ret; + + if (strcmp(cp, "255.255.255.255") == 0) { + inp->s_addr = (unsigned) -1; + return 1; + } + + if (sscanf(cp, "%u.%u.%u.%u", &a1, &a2, &a3, &a4) != 4 || + a1 > 255 || a2 > 255 || a3 > 255 || a4 > 255) { + return 1; + } + + ret = (a1 << 24) | (a2 << 16) | (a3 << 8) | a4; + + inp->s_addr = htonl(ret); + + if (inp->s_addr == (unsigned) -1) { + return 0; + } + return 1; +} +#endif + +/* some systems don't take the 2nd argument */ +int sys_gettimeofday(struct timeval *tv) +{ +#if HAVE_GETTIMEOFDAY_TZ + return gettimeofday(tv, NULL); +#else + return gettimeofday(tv); +#endif +}