A C library for asynchronous DNS requests (grpc依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
David Drysdale 2aa07c7d02 test: Add README.md documentation 9 years ago
m4 build: Expose whether symbol hiding is on 9 years ago
test test: Add README.md documentation 9 years ago
vc vc6cares.dsp: add ares_create_query.c and ares_parse_soa_reply.c 12 years ago
.gitignore build: Add a code coverage option 9 years ago
.travis.yml test: Temporarily avoid latest Python requests package 9 years ago
AUTHORS doc: Update in preparation for next release 9 years ago
CHANGES CHANGES: generate from script 14 years ago
CHANGES.0 CHANGES: generate from script 14 years ago
CONTRIBUTING CONTRIBUTING: add file to indicate mailing list is preferred 11 years ago
GIT-INFO GIT-INFO: mention buildconf 13 years ago
INSTALL INSTALL: some adjustments 13 years ago
Makefile.Watcom Makefile.Watcom: 14 years ago
Makefile.am build: Add a code coverage option 9 years ago
Makefile.dj build: config.dos renamed to config-dos.h 14 years ago
Makefile.inc api: Add entrypoints to allow use of per-server ports 9 years ago
Makefile.m32 Create ares_build.h when buidling from Git. 12 years ago
Makefile.msvc Support Visual Studio 2015 9 years ago
Makefile.netware Makefile.netware: SIZEOF_SHORT definition 14 years ago
NEWS - Fixed a few variable return types for some system calls. Made configure 21 years ago
README.cares README.cares: s/I/Daniel 9 years ago
README.md doc: Show build badges in README.md 9 years ago
README.msvc build: add install target to Makefile.msvc 14 years ago
RELEASE-NOTES doc: Update in preparation for next release 9 years ago
TODO ares_reinit() 15 years ago
acinclude.m4 nowarn: use <limits.h> instead of configure for size of long 12 years ago
acountry.1 man pages: docs for the c-ares utility programs 14 years ago
acountry.c Re-start loop if select fails 10 years ago
adig.1 man pages: docs for the c-ares utility programs 14 years ago
adig.c ares_inet_pton/ntop: cleanup 12 years ago
ahost.1 Add -t u option to ahost 11 years ago
ahost.c ahost: Allow repeated -s <domain> options 9 years ago
appveyor.yml test: Add AppVeyor config file for Windows build 9 years ago
ares.h api: Add entrypoints to allow use of per-server ports 9 years ago
ares__close_sockets.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares__get_hostent.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares__read_line.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares__timeval.c Mark unhittable lines 9 years ago
ares_build.h.dist ares_build.h: fix building on 64-bit powerpc 11 years ago
ares_build.h.in Revert "Do not use sized constants in public headers" 14 years ago
ares_cancel.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_cancel.c ares_cancel(): cancel requests safely 12 years ago
ares_create_query.3 ares_create_query.3: mention when this is added 13 years ago
ares_create_query.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_data.c api: Add entrypoints to allow use of per-server ports 9 years ago
ares_data.h api: Add entrypoints to allow use of per-server ports 9 years ago
ares_destroy.3 ares_destroy() documentation: no new requests 12 years ago
ares_destroy.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_destroy_options.3 remove all $Id$ lines 15 years ago
ares_dns.h Added new feature (rfc2671) 13 years ago
ares_dup.3 remove all $Id$ lines 15 years ago
ares_expand_name.3 ares_expand_name.3: clarify how to free the data 12 years ago
ares_expand_name.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_expand_string.3 remove all $Id$ lines 15 years ago
ares_expand_string.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_fds.3 remove all $Id$ lines 15 years ago
ares_fds.c Header inclusion clean-up 12 years ago
ares_free_data.3 SOA parser added 13 years ago
ares_free_hostent.3 remove all $Id$ lines 15 years ago
ares_free_hostent.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_free_string.3 remove all $Id$ lines 15 years ago
ares_free_string.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_get_servers.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_get_servers_ports.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_getenv.c build: use getenv() replacement function for systems which lack it 14 years ago
ares_getenv.h build: use getenv() replacement function for systems which lack it 14 years ago
ares_gethostbyaddr.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_gethostbyaddr.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_gethostbyname.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_gethostbyname.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_gethostbyname_file.3 remove all $Id$ lines 15 years ago
ares_getnameinfo.3 ares_getnameinfo.3: there is no ares_getaddrinfo 10 years ago
ares_getnameinfo.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_getopt.c remove all $Id$ lines 15 years ago
ares_getopt.h Fix macro redefinition. 15 years ago
ares_getsock.3 remove all $Id$ lines 15 years ago
ares_getsock.c Fix integer shift overflow if both tcp_socket and udp_socket are set 10 years ago
ares_inet_net_pton.h ares_inet_pton/ntop: cleanup 12 years ago
ares_inet_ntop.3 ares_inet_ntop.3: s/socklen_t/ares_socklen_t 12 years ago
ares_inet_pton.3 spell inet correctly! 12 years ago
ares_init.3 Fix typos detected by lintian 9 years ago
ares_init.c api: Add entrypoints to allow use of per-server ports 9 years ago
ares_init_options.3 remove all $Id$ lines 15 years ago
ares_iphlpapi.h ares_iphlpapi.h: Watcom C fix 14 years ago
ares_ipv6.h Comment in ares_ipv6.h 11 years ago
ares_library_cleanup.3 library init: documentation update 12 years ago
ares_library_init.3 api: Allow injection of user-specified malloc/free functions 9 years ago
ares_library_init.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_library_init.h winsock: compilation fixes 14 years ago
ares_llist.c ares__swap_lists: make private and static 12 years ago
ares_llist.h ares__swap_lists: make private and static 12 years ago
ares_mkquery.3 Added new feature (rfc2671) 13 years ago
ares_mkquery.c Added new feature (rfc2671) 13 years ago
ares_nowarn.c nowarn: use <limits.h> instead of configure for size of long 12 years ago
ares_nowarn.h Kill compiler warning 13 years ago
ares_options.c api: Add entrypoints to allow use of per-server ports 9 years ago
ares_parse_a_reply.3 nroff: fix two syntax mistakes 12 years ago
ares_parse_a_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_aaaa_reply.3 nroff: fix two syntax mistakes 12 years ago
ares_parse_aaaa_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_mx_reply.3 added ares_parse_mx_reply 15 years ago
ares_parse_mx_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_naptr_reply.3 Added support for parsing NAPTR records 13 years ago
ares_parse_naptr_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_ns_reply.3 Vlad Dinulescu added ares_parse_ns_reply() 18 years ago
ares_parse_ns_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_ptr_reply.3 remove all $Id$ lines 15 years ago
ares_parse_ptr_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_soa_reply.3 SOA parser added 13 years ago
ares_parse_soa_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_srv_reply.3 Daniel wants upcoming release to be 1.7.0 15 years ago
ares_parse_srv_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_txt_reply.3 ares_parse_txt_reply: return a ares_txt_reply node for each sub-string 12 years ago
ares_parse_txt_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_platform.c compiler warning: fix 14 years ago
ares_platform.h getservbyport replacement for Win CE 14 years ago
ares_private.h api: Add entrypoints to allow use of per-server ports 9 years ago
ares_process.3 remove all $Id$ lines 15 years ago
ares_process.c api: Add entrypoints to allow use of per-server ports 9 years ago
ares_query.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_query.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_rules.h ares_rules.h: CARES_SIZEOF_LONG doesn't exist anymore, don't test for it 12 years ago
ares_save_options.3 remove all $Id$ lines 15 years ago
ares_search.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_search.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_send.3 Documentation: properly document ARES_ECANCELLED 12 years ago
ares_send.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_set_local_dev.3 Fix typos detected by lintian 9 years ago
ares_set_local_ip4.3 ares_set_local_*: added in 1.7.4, not before 14 years ago
ares_set_local_ip6.3 ares_set_local_*: added in 1.7.4, not before 14 years ago
ares_set_servers.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_set_servers_csv.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_set_servers_ports.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_set_servers_ports_csv.3 api: Add entrypoints to allow use of per-server ports 9 years ago
ares_set_socket_callback.3 remove all $Id$ lines 15 years ago
ares_set_sortlist.3 api: Add ares_set_sortlist(3) entrypoint 9 years ago
ares_setup.h Check for __ANDROID__ in addition to ANDROID macro. 13 years ago
ares_strcasecmp.c remove all $Id$ lines 15 years ago
ares_strcasecmp.h remove all $Id$ lines 15 years ago
ares_strdup.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_strdup.h api: Allow injection of user-specified malloc/free functions 9 years ago
ares_strerror.3 remove all $Id$ lines 15 years ago
ares_strerror.c remove all $Id$ lines 15 years ago
ares_timeout.3 ares_timeout.3: fix the NAME section 13 years ago
ares_timeout.c timeoffset: made static and private 12 years ago
ares_version.3 remove all $Id$ lines 15 years ago
ares_version.c remove all $Id$ lines 15 years ago
ares_version.h bump: start working towards 1.10.1 12 years ago
ares_writev.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_writev.h remove all $Id$ lines 15 years ago
bitncmp.c bitncmp: update comment to match code behaviour 9 years ago
bitncmp.h ares__bitncmp: use two underscores for private functions 12 years ago
buildconf Fix buildconf on platforms using glibtoolize 9 years ago
buildconf.bat remove all $Id$ lines 15 years ago
cares.rc Added copyright string to ares_version.h and make use of it in other files. 15 years ago
config-dos.h config-dos.h: define HAVE_CLOSE_S for MSDOS/Watt-32 12 years ago
config-win32.h build: Allow header compilation by Windows C++ compiler 9 years ago
configure.ac build: Add a code coverage option 9 years ago
get_ver.awk Cleaned up version awk script. 13 years ago
git2changes.pl CHANGES: generate from script 14 years ago
inet_net_pton.c Mark unhittable lines 9 years ago
inet_ntop.c inet_ntop.c: s/socklen_t/ares_socklen_t 12 years ago
install-sh refresh: updated now with automake 1.14 11 years ago
libcares.pc.in Fix libcares.pc generation for static MingW* cross builds 13 years ago
maketgz CHANGES: generate from script 14 years ago
mkinstalldirs refresh: updated now with automake 1.14 11 years ago
nameser.h c-ares/nameser.h: add some T_* defines for ns_t_* values 12 years ago
setup_once.h curl_setup_once.h: definition of HAVE_CLOSE_S defines sclose() to close_s() 12 years ago
windows_port.c build: move platform stuff to ares_platform.c and ares_platform.h 14 years ago

README.md

c-ares

Build Status Windows Build Status Coverage Status

This is c-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.

The full source code is available in the 'c-ares' release archives, and in a git repository: http://github.com/c-ares/c-ares

If you find bugs, correct flaws, have questions or have comments in general in regard to c-ares (or by all means the original ares too), get in touch with us on the c-ares mailing list: http://cool.haxx.se/mailman/listinfo/c-ares

c-ares is of course distributed under the same MIT-style license as the original ares.

You'll find all c-ares details and news here: http://c-ares.haxx.se/

Notes for c-ares hackers

  • The distributed ares_build.h file is only intended to be used on systems which can not run the also distributed configure script.

  • The distributed ares_build.h file is generated as a copy of ares_build.h.dist when the c-ares source code distribution archive file is originally created.

  • If you check out from git on a non-configure platform, you must run the appropriate buildconf* script to set up ares_build.h and other local files before being able to compile the library.

  • On systems capable of running the configure script, the configure process will overwrite the distributed ares_build.h file with one that is suitable and specific to the library being configured and built, this new file is generated from the ares_build.h.in template file.

  • If you intend to distribute an already compiled c-ares library you MUST also distribute along with it the generated ares_build.h which has been used to compile it. Otherwise the library will be of no use for the users of the library that you have built. It is your responsibility to provide this file. No one at the c-ares project can know how you have built the library.

  • File ares_build.h includes platform and configuration dependent info, and must not be modified by anyone. Configure script generates it for you.

  • We cannot assume anything else but very basic compiler features being present. While c-ares requires an ANSI C compiler to build, some of the earlier ANSI compilers clearly can't deal with some preprocessor operators.

  • Newlines must remain unix-style for older compilers' sake.

  • Comments must be written in the old-style /* unnested C-fashion */