c85bf83e88
check for ssize_t to make it possible to use that when receiving the send() error code. This is necessary to prevent compiler warnings on some systems. - Made configure create config.h, and all source files now include setup.h that might include the proper config.h (or a handicrafted alternative). - Switched to 'ares_socket_t' type for sockets in ares, since Windows don't use 'int' for that. - automake-ified and libool-ified c-ares. Now it builds libcares as a shared lib on most platforms if wanted. (This bloated the size of the release archive with another 200K!) - Makefile.am now uses Makefile.inc for the c sources, h headers and man pages, to make it easier for other makefiles to use the exact same set of files. - Adjusted 'maketgz' to use the new automake magic when building distribution archives. |
||
---|---|---|
.. | ||
vc | ||
.cvsignore | ||
acinclude.m4 | ||
adig.c | ||
ahost.c | ||
ares__close_sockets.c | ||
ares__get_hostent.c | ||
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 | ||
ares_init_options.3 | ||
ares_init.3 | ||
ares_init.c | ||
ares_mkquery.3 | ||
ares_mkquery.c | ||
ares_parse_a_reply.3 | ||
ares_parse_a_reply.c | ||
ares_parse_ptr_reply.3 | ||
ares_parse_ptr_reply.c | ||
ares_private.h | ||
ares_process.3 | ||
ares_process.c | ||
ares_query.3 | ||
ares_query.c | ||
ares_search.3 | ||
ares_search.c | ||
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 | ||
ares.h | ||
buildconf | ||
CHANGES | ||
configure.ac | ||
FILES | ||
install-sh | ||
Makefile.am | ||
Makefile.dj | ||
Makefile.in | ||
Makefile.inc | ||
Makefile.m32 | ||
Makefile.netware | ||
maketgz | ||
mkinstalldirs | ||
nameser.h | ||
NEWS | ||
README | ||
README.cares | ||
setup.h | ||
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.