Skip to content

Commit

Permalink
Provide ares_nameser.h as a public interface (#417)
Browse files Browse the repository at this point in the history
NodeJS needs ares_nameser.h as a pubic header.

Fixes: #415
Fix By: Felix Yan (@felixonmars)
  • Loading branch information
felixonmars committed Aug 17, 2021
1 parent 9c4c483 commit 7712fcd
Show file tree
Hide file tree
Showing 8 changed files with 33 additions and 7 deletions.
6 changes: 6 additions & 0 deletions CMakeLists.txt
Expand Up @@ -557,6 +557,12 @@ ENDIF()
IF (HAVE_WINDOWS_H)
SET (CARES_HAVE_WINDOWS_H 1)
ENDIF()
IF (HAVE_ARPA_NAMESER_H)
SET (CARES_HAVE_ARPA_NAMESER_H 1)
ENDIF()
IF (HAVE_ARPA_NAMESER_COMPAT_H)
SET (CARES_HAVE_ARPA_NAMESER_COMPAT_H 1)
ENDIF()

# Record toplevel CMakeLists.txt path
set(CARES_TOPLEVEL_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
Expand Down
14 changes: 14 additions & 0 deletions configure.ac
Expand Up @@ -547,6 +547,20 @@ dnl *Sigh* these are needed in order for net/if.h to get properly detected.
]
)

dnl Test and set CARES_HAVE_ARPA_NAMESER_H / CARES_HAVE_ARPA_NAMESER_COMPAT_H
AC_CHECK_DECL([HAVE_ARPA_NAMESER_H],
[
CARES_DEFINE_UNQUOTED([CARES_HAVE_ARPA_NAMESER_H])
],
[]
)
AC_CHECK_DECL([HAVE_ARPA_NAMESER_COMPAT_H],
[
CARES_DEFINE_UNQUOTED([CARES_HAVE_ARPA_NAMESER_COMPAT_H])
],
[]
)

dnl Checks for typedefs, structures, and compiler characteristics.
AC_C_CONST
AC_TYPE_SIZE_T
Expand Down
2 changes: 1 addition & 1 deletion include/CMakeLists.txt
Expand Up @@ -3,6 +3,6 @@ CONFIGURE_FILE (ares_build.h.cmake ${PROJECT_BINARY_DIR}/ares_build.h)

# Headers installation target
IF (CARES_INSTALL)
SET (CARES_HEADERS ares.h ares_version.h "${PROJECT_BINARY_DIR}/ares_build.h" ares_rules.h ares_dns.h)
SET (CARES_HEADERS ares.h ares_version.h "${PROJECT_BINARY_DIR}/ares_build.h" ares_rules.h ares_dns.h ares_nameser.h)
INSTALL (FILES ${CARES_HEADERS} COMPONENT Devel DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
ENDIF ()
2 changes: 1 addition & 1 deletion include/Makefile.am
Expand Up @@ -2,6 +2,6 @@ AUTOMAKE_OPTIONS = foreign nostdinc 1.9.6
ACLOCAL_AMFLAGS = -I m4 --install

# what headers to install on 'make install':
include_HEADERS = ares.h ares_version.h ares_build.h ares_rules.h ares_dns.h
include_HEADERS = ares.h ares_version.h ares_build.h ares_rules.h ares_dns.h ares_nameser.h

EXTRA_DIST = ares_build.h.cmake ares_build.h.in ares_build.h.dist CMakeLists.txt
2 changes: 2 additions & 0 deletions include/ares_build.h.cmake
Expand Up @@ -13,6 +13,8 @@
#cmakedefine CARES_HAVE_WS2TCPIP_H
#cmakedefine CARES_HAVE_WINSOCK2_H
#cmakedefine CARES_HAVE_WINDOWS_H
#cmakedefine CARES_HAVE_ARPA_NAMESER_H
#cmakedefine CARES_HAVE_ARPA_NAMESER_COMPAT_H

#ifdef CARES_HAVE_SYS_TYPES_H
# include <sys/types.h>
Expand Down
3 changes: 3 additions & 0 deletions include/ares_build.h.in
Expand Up @@ -55,6 +55,9 @@
Error Compilation_aborted_CARES_TYPEOF_ARES_SOCKLEN_T_already_defined
#endif

#undef CARES_HAVE_ARPA_NAMESER_H
#undef CARES_HAVE_ARPA_NAMESER_COMPAT_H

/* ================================================================ */
/* EXTERNAL INTERFACE SETTINGS FOR CONFIGURE CAPABLE SYSTEMS ONLY */
/* ================================================================ */
Expand Down
10 changes: 6 additions & 4 deletions src/lib/ares_nameser.h → include/ares_nameser.h
Expand Up @@ -2,10 +2,12 @@
#ifndef ARES_NAMESER_H
#define ARES_NAMESER_H

#ifdef HAVE_ARPA_NAMESER_H
#include "ares_build.h"

#ifdef CARES_HAVE_ARPA_NAMESER_H
# include <arpa/nameser.h>
#endif
#ifdef HAVE_ARPA_NAMESER_COMPAT_H
#ifdef CARES_HAVE_ARPA_NAMESER_COMPAT_H
# include <arpa/nameser_compat.h>
#endif

Expand Down Expand Up @@ -68,7 +70,7 @@
* provide them
* ============================================================================
*/
#ifndef HAVE_ARPA_NAMESER_H
#ifndef CARES_HAVE_ARPA_NAMESER_H

typedef enum __ns_class {
ns_c_invalid = 0, /* Cookie. */
Expand Down Expand Up @@ -173,7 +175,7 @@ typedef enum __ns_rcode {
ns_r_badtime = 18
} ns_rcode;

#endif /* HAVE_ARPA_NAMESER_H */
#endif /* CARES_HAVE_ARPA_NAMESER_H */


/* ============================================================================
Expand Down
1 change: 0 additions & 1 deletion src/lib/Makefile.inc
Expand Up @@ -73,7 +73,6 @@ HHEADERS = ares_android.h \
ares_strsplit.h \
ares_writev.h \
bitncmp.h \
ares_nameser.h \
ares_setup.h \
setup_once.h

Expand Down

0 comments on commit 7712fcd

Please sign in to comment.