curl/ares
2006-10-27 15:37:26 +00:00
..
vc
.cvsignore
acinclude.m4 Check for struct timeval at configuration time 2006-10-13 01:35:14 +00:00
adig.c Added '-d' option for Watt32 targets. Added cvs id. 2006-10-25 14:13:35 +00:00
ahost.c Check for USE_WINSOCK instead of WIN32 where the check was done 2006-10-18 21:05:40 +00:00
ares__close_sockets.c
ares__get_hostent.c Replace is*() macros with our own IS*() ones. 2006-10-18 03:42:06 +00:00
ares__read_line.c
ares_cancel.3
ares_cancel.c
ares_destroy.3
ares_destroy.c
ares_dns.h
ares_expand_name.3
ares_expand_name.c
ares_expand_string.3
ares_expand_string.c
ares_fds.3
ares_fds.c
ares_free_hostent.3
ares_free_hostent.c
ares_free_string.3
ares_free_string.c
ares_gethostbyaddr.3
ares_gethostbyaddr.c
ares_gethostbyname.3
ares_gethostbyname.c Fixed comment. 2006-08-04 15:41:56 +00:00
ares_getnameinfo.3
ares_getnameinfo.c Fixed "'x' might be used uninitialized in this function" warning. 2006-10-25 14:16:01 +00:00
ares_getsock.3
ares_getsock.c avoid an overflow if an excessive amount of servers are used 2006-10-12 16:47:50 +00:00
ares_init_options.3
ares_init.3
ares_init.c Replace is*() macros with our own IS*() ones. 2006-10-18 03:42:06 +00:00
ares_ipv6.h
ares_mkquery.3
ares_mkquery.c
ares_parse_a_reply.3
ares_parse_a_reply.c
ares_parse_aaaa_reply.3
ares_parse_aaaa_reply.c
ares_parse_ptr_reply.3
ares_parse_ptr_reply.c
ares_private.h
ares_process.3
ares_process.c Compiler warning fix 2006-10-25 10:25:43 +00:00
ares_query.3
ares_query.c
ares_search.3
ares_search.c Replace is*() macros with our own IS*() ones. 2006-10-18 03:42:06 +00:00
ares_send.3
ares_send.c
ares_strerror.3
ares_strerror.c
ares_timeout.3
ares_timeout.c
ares_version.3
ares_version.c
ares_version.h Brad Spencer did 2006-08-29 15:17:47 +00:00
ares.h Remove redundant __CYGWIN__ symbol check 2006-10-11 16:01:16 +00:00
AUTHORS
bitncmp.c
bitncmp.h
buildconf
CHANGES Prevent ares_getsock() to overflow if more than 16 sockets are used. 2006-10-13 21:25:11 +00:00
config-win32.h Define HAVE_STRUCT_TIMEVAL as appropriate for platforms that lack autotools support 2006-10-14 12:01:44 +00:00
configure.ac Check for struct timeval at configuration time 2006-10-13 01:35:14 +00:00
FILES
inet_net_pton.c Replace is*() macros with our own IS*() ones. 2006-10-18 03:42:06 +00:00
inet_net_pton.h
inet_ntop.c Minor compatibility fix 2006-08-04 17:35:05 +00:00
inet_ntop.h
install-sh
Makefile.am
Makefile.dj Define HAVE_STRUCT_TIMEVAL as appropriate for platforms that lack autotools support 2006-10-14 12:01:44 +00:00
Makefile.inc add missing man page 2006-08-14 07:21:33 +00:00
Makefile.m32
Makefile.netware Define HAVE_STRUCT_TIMEVAL as appropriate for platforms that lack autotools support 2006-10-14 12:01:44 +00:00
Makefile.vc6
maketgz
mkinstalldirs
nameser.h
NEWS
README
README.cares
setup_once.h Sync with lib/setup_once.h 2006-10-27 15:37:26 +00:00
setup.h Check for USE_WINSOCK instead of WIN32 where the check was done 2006-10-18 21:05:40 +00:00
windows_port.c

This is c-ares, a forked version of the original ares. The original ares
README follows below, the c-ares specific details are in README.cares

====================================================================

This is ares, an asynchronous resolver library.  It is intended for
applications which need to perform DNS queries without blocking, or
need to perform multiple DNS queries in parallel.  The primary
examples of such applications are servers which communicate with
multiple clients and programs with graphical user interfaces.

This library implementation is not especially portable to crufty old
systems like SunOS 4.  It assumes a compiler which can handle ANSI C
syntax, a system malloc which properly handles realloc(NULL, foo) and
free(NULL), and a reasonably up-to-date <arpa/nameser.h>.

I have attempted to preserve the externally visible behavior of the
BIND resolver in nearly all respects.  The API of the library is, of
course, very different from the synchronous BIND API; instead of
invoking a function like res_send() and getting a return value back
indicating the number of bytes in the response, you invoke a function
like ares_send() and give it a callback function to invoke when the
response arrives.  You then have to select() on the file descriptors
indicated by ares_fds(), with a timeout given by ares_timeout().  You
call ares_process() when select() returns.

Some features are missing from the current version of ares, relative
to the BIND resolver:

	* There is no IPV6 support.
	* There is no hostname verification.
	* There is no logging of unexpected events.
	* There is no debugging-oriented logging.
	* There is no YP support.

libares requires an ANSI compiler to compile and use.  To build the
library, just run "./configure" and "make".  To install it, run "make
install".  Run "./configure --help" to see a list of options you can
provide to configure to change how the library builds.  libares has no
data files, so you can move the include file and library around freely
without leaving behind any dependencies on old paths.  Building the
library will also build the "adig" program, a little toy for trying
out the library.  It doesn't get installed.

libares is distributed at athena-dist.mit.edu:pub/ATHENA/ares.  Please
send bug reports and comments to ghudson@mit.edu.