]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
resolv: Move ns_samename into its own file, and into libc
authorFlorian Weimer <fweimer@redhat.com>
Mon, 19 Jul 2021 05:55:27 +0000 (07:55 +0200)
committerFlorian Weimer <fweimer@redhat.com>
Mon, 19 Jul 2021 05:56:21 +0000 (07:56 +0200)
But only as an internal symbol, __libc_ns_samename.  The libresolv
ABI is preserved.  This is because the function is deprecated, and
it does not make sense to add new symbol versions for deprecated
functions.

Also reformat the implementation to GNU style.

Reviewed-by: Carlos O'Donell <carlos@redhat.com>
Tested-by: Carlos O'Donell <carlos@redhat.com>
include/arpa/nameser.h
resolv/Makefile
resolv/Versions
resolv/ns_print.c
resolv/ns_samedomain.c
resolv/ns_samename.c [new file with mode: 0644]
resolv/res_query.c
resolv/res_send.c
resolv/resolv-deprecated.c

index a529cc86d369265fe47eb690e7dc83322bb0199f..53f1dbc7c3f659e930fee72f5fd36595f7104e84 100644 (file)
@@ -68,7 +68,6 @@ libresolv_hidden_proto (ns_parserr)
 libresolv_hidden_proto (ns_sprintrr)
 libresolv_hidden_proto (ns_sprintrrf)
 libresolv_hidden_proto (ns_samedomain)
-libresolv_hidden_proto (ns_samename)
 libresolv_hidden_proto (ns_format_ttl)
 
 extern __typeof (ns_makecanon) __libc_ns_makecanon;
@@ -87,6 +86,8 @@ extern __typeof (ns_name_uncompress) __ns_name_uncompress;
 libc_hidden_proto (__ns_name_uncompress)
 extern __typeof (ns_name_unpack) __ns_name_unpack;
 libc_hidden_proto (__ns_name_unpack)
+extern __typeof (ns_samename) __libc_ns_samename;
+libc_hidden_proto (__libc_ns_samename)
 
 # endif /* !_ISOMAC */
 #endif
index d1ad5e4cba340f403e1401a9a7fe5483288cc243..744da951aed1b13a8f08894b29e5f6287999a01a 100644 (file)
@@ -43,6 +43,7 @@ routines := \
   ns_name_skip \
   ns_name_uncompress \
   ns_name_unpack \
+  ns_samename \
   nsap_addr \
   res-close \
   res-name-checking \
index 93078de25c418315a31a7e208ef7aa3925142c1e..2201d4224ca21bce7c86021e4207169ad80588bf 100644 (file)
@@ -73,6 +73,7 @@ libc {
     __libc_dn_expand;
     __libc_dn_skipname;
     __libc_ns_makecanon;
+    __libc_ns_samename;
     __libc_res_dnok;
     __libc_res_hnok;
     __ns_name_compress;
index 9a9602d74cb4a3db7ce36270d866af8196a86953..43f39edf61c838b91e90d939f0d197fe544bd1c5 100644 (file)
@@ -103,9 +103,9 @@ ns_sprintrrf(const u_char *msg, size_t msglen,
        /*
         * Owner.
         */
-       if (name_ctx != NULL && ns_samename(name_ctx, name) == 1) {
+       if (name_ctx != NULL && __libc_ns_samename (name_ctx, name) == 1)
                T(addstr("\t\t\t", 3, &buf, &buflen));
-       else {
+       else {
                len = prune_origin(name, origin);
                if (*name == '\0') {
                        goto root;
@@ -621,7 +621,7 @@ prune_origin(const char *name, const char *origin) {
        const char *oname = name;
 
        while (*name != '\0') {
-               if (origin != NULL && ns_samename(name, origin) == 1)
+               if (origin != NULL && __libc_ns_samename (name, origin) == 1)
                        return (name - oname - (name > oname));
                while (*name != '\0') {
                        if (*name == '\\') {
index cfff2516b075c4e71ff3ac9d711faa423154d09c..46cb8f5fb25d492e1b6e70fdbc3f3998b7fd1d3b 100644 (file)
@@ -139,31 +139,9 @@ libresolv_hidden_def (ns_samedomain)
  *     is "a" a subdomain of "b"?
  */
 int
-ns_subdomain(const char *a, const char *b) {
-       return (ns_samename(a, b) != 1 && ns_samedomain(a, b));
+ns_subdomain (const char *a, const char *b)
+{
+  return __libc_ns_samename (a, b) != 1 && ns_samedomain (a, b);
 }
 
-/*%
- *     determine whether domain name "a" is the same as domain name "b"
- *
- * return:
- *\li  -1 on error
- *\li  0 if names differ
- *\li  1 if names are the same
- */
-
-int
-ns_samename(const char *a, const char *b) {
-       char ta[NS_MAXDNAME], tb[NS_MAXDNAME];
-
-       if (__libc_ns_makecanon(a, ta, sizeof ta) < 0 ||
-           __libc_ns_makecanon(b, tb, sizeof tb) < 0)
-               return (-1);
-       if (strcasecmp(ta, tb) == 0)
-               return (1);
-       else
-               return (0);
-}
-libresolv_hidden_def (ns_samename)
-
 /*! \file */
diff --git a/resolv/ns_samename.c b/resolv/ns_samename.c
new file mode 100644 (file)
index 0000000..61fe3ca
--- /dev/null
@@ -0,0 +1,38 @@
+/* Check if two domain names are equal after trailing dot normalization.
+ * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (c) 1995,1999 by Internet Software Consortium.
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM DISCLAIMS
+ * ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL INTERNET SOFTWARE
+ * CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
+ * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
+ * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
+ * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
+ * SOFTWARE.
+ */
+
+#include <arpa/nameser.h>
+#include <string.h>
+
+/* Determines whether domain name A is the same as domain name B.
+   Returns -1 on error, 0 if names differ, 1 if names are the
+   same.  */
+int
+__libc_ns_samename (const char *a, const char *b)
+{
+  char ta[NS_MAXDNAME], tb[NS_MAXDNAME];
+
+  if (__libc_ns_makecanon (a, ta, sizeof ta) < 0 ||
+      __libc_ns_makecanon (b, tb, sizeof tb) < 0)
+    return -1;
+  if (__strcasecmp (ta, tb) == 0)
+    return 1;
+  else
+    return 0;
+}
+libc_hidden_def (__libc_ns_samename)
index ebbe5a6a4ed86abe3fccd4a134bfcf6f613c9bbb..5b51af8451acdc47acad352a91514fa10b8d72c5 100644 (file)
@@ -656,7 +656,7 @@ __res_context_hostalias (struct resolv_context *ctx,
                if (!*cp1)
                        break;
                *cp1 = '\0';
-               if (ns_samename(buf, name) == 1) {
+               if (__libc_ns_samename(buf, name) == 1) {
                        while (isspace(*++cp1))
                                ;
                        if (!*cp1)
index 915fc6d2c67b8615be60fd81f136acd58566728b..dfea9fc7fa307fb3d019aff6d8992e506cab9208 100644 (file)
@@ -224,8 +224,8 @@ res_nameinquery(const char *name, int type, int class,
                        return (-1);
                NS_GET16(ttype, cp);
                NS_GET16(tclass, cp);
-               if (ttype == type && tclass == class &&
-                   ns_samename(tname, name) == 1)
+               if (ttype == type && tclass == class
+                   && __libc_ns_samename (tname, name) == 1)
                        return (1);
        }
        return (0);
index cbd1078dc2f25e8a9fbdbe3352cadf79dacb53ce..d8344f8f39743beb8cf17a98a16870ce4a8f7046 100644 (file)
@@ -33,3 +33,9 @@ ns_makecanon (const char *src, char *dst, size_t dstsize)
 {
   return __libc_ns_makecanon (src, dst, dstsize);
 }
+
+int
+ns_samename (const char *a, const char *b)
+{
+  return __libc_ns_samename (a, b);
+}