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.
 
 
 
 
 
Daniel Stenberg e7fe2744db RELEASE-NOTES: final edits for 1.11.0 9 years ago
m4 test: namespaces unavailable when cross-compiling 9 years ago
test test: prefer ON_CALL to EXPECT_CALL to reduce flakes 9 years ago
vc
.gitignore build: Add a code coverage option 9 years ago
.travis.yml test: skip repeated build steps 9 years ago
AUTHORS doc: Update in preparation for next release 9 years ago
CHANGES
CHANGES.0
CONTRIBUTING.md doc: Update docs on contributing 9 years ago
GIT-INFO
INSTALL
Makefile.Watcom
Makefile.am dist: Distribute README.md 9 years ago
Makefile.dj
Makefile.inc Add ares_set_socket_configure_callback() 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
NEWS
README.cares README.cares: s/I/Daniel 9 years ago
README.md doc: Update missed repo references 9 years ago
README.msvc
RELEASE-NOTES RELEASE-NOTES: final edits for 1.11.0 9 years ago
TODO
acinclude.m4 nowarn: use <limits.h> instead of configure for size of long 12 years ago
acountry.1
acountry.c acountry: drop inert test 9 years ago
adig.1
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: Get test code building under Windows 9 years ago
ares.h Add ares_set_socket_configure_callback() 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
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.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_data.c txt: introduce `ares_parse_txt_reply_ext` 9 years ago
ares_data.h txt: introduce `ares_parse_txt_reply_ext` 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
ares_dns.h
ares_dup.3 ares_dup.3: remove mention of nonexistent function 9 years ago
ares_expand_name.3
ares_expand_name.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_expand_string.3
ares_expand_string.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_fds.3
ares_fds.c
ares_free_data.3
ares_free_hostent.3
ares_free_hostent.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_free_string.3
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
ares_getenv.h
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
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
ares_getopt.h
ares_getsock.3
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 Use "resolve" as synonym of "dns" in nsswitch.conf 9 years ago
ares_init_options.3
ares_iphlpapi.h
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 ares_win32_init: make LoadLibrary work when using UNICODE too 9 years ago
ares_library_init.h
ares_llist.c
ares_llist.h
ares_mkquery.3
ares_mkquery.c
ares_nowarn.c nowarn: use <limits.h> instead of configure for size of long 12 years ago
ares_nowarn.h
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
ares_parse_mx_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_naptr_reply.3
ares_parse_naptr_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_ns_reply.3
ares_parse_ns_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_ptr_reply.3
ares_parse_ptr_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_soa_reply.3
ares_parse_soa_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_srv_reply.3
ares_parse_srv_reply.c api: Allow injection of user-specified malloc/free functions 9 years ago
ares_parse_txt_reply.3 txt: introduce `ares_parse_txt_reply_ext` 9 years ago
ares_parse_txt_reply.c txt: introduce `ares_parse_txt_reply_ext` 9 years ago
ares_platform.c
ares_platform.h
ares_private.h Add ares_set_socket_configure_callback() 9 years ago
ares_process.3
ares_process.c Add ares_set_socket_configure_callback() 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
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_ip6.3
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 ares_set_socket_callback: make manpage match code 9 years ago
ares_set_socket_configure_callback.3 Add ares_set_socket_configure_callback() 9 years ago
ares_set_sortlist.3 api: Add ares_set_sortlist(3) entrypoint 9 years ago
ares_setup.h
ares_strcasecmp.c
ares_strcasecmp.h
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
ares_strerror.c
ares_timeout.3
ares_timeout.c timeoffset: made static and private 12 years ago
ares_version.3
ares_version.c
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
bitncmp.c bitncmp: update comment to match code behaviour 9 years ago
bitncmp.h
buildconf buildconf: run test/buildconf too if present 9 years ago
buildconf.bat
cares.rc
config-dos.h
config-win32.h build: Allow header compilation by Windows C++ compiler 9 years ago
configure.ac configure: only run configure in test when NOT cross-compiling 9 years ago
get_ver.awk
git2changes.pl
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
maketgz
mkinstalldirs refresh: updated now with automake 1.14 11 years ago
nameser.h
setup_once.h
windows_port.c

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 */

  • Try to keep line lengths below 80 columns.