removed dependency on inet_pton on Solaris; custom implementation if inet_pton for...
authorVictor Kirhenshtein <victor@netxms.org>
Fri, 16 Jan 2015 10:22:57 +0000 (12:22 +0200)
committerVictor Kirhenshtein <victor@netxms.org>
Fri, 16 Jan 2015 10:22:57 +0000 (12:22 +0200)
ChangeLog
android/src/agent/res/values/build_number.xml
android/src/console/res/values/build_number.xml
build/build_number
configure.ac
include/build.h
include/nms_util.h
src/java/build/set_build_number.cmd
src/java/client/netxms-base/src/main/java/org/netxms/base/BuildNumber.java
src/libnetxms/Makefile.am
src/libnetxms/inet_pton.c [new file with mode: 0644]

index 5c17ff7..1bf56b3 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -5,7 +5,7 @@
 - Fixed server hang issue on some Windows versions
 - Fixed SNMPv3 communication issue with HP A series switches
 - Fixed LDAP sync problems on Windows
-- Fixed issues: #699, #716, #721, #736, #737
+- Fixed issues: #699, #716, #721, #735, #736, #737
 
 
 *
index c286745..b0e8189 100644 (file)
@@ -1,4 +1,4 @@
 <?xml version="1.0" encoding="utf-8"?>
 <resources>
-       <string name="build_number">8006</string>
+       <string name="build_number">8007</string>
 </resources>
index c286745..b0e8189 100644 (file)
@@ -1,4 +1,4 @@
 <?xml version="1.0" encoding="utf-8"?>
 <resources>
-       <string name="build_number">8006</string>
+       <string name="build_number">8007</string>
 </resources>
index 2401f08..0ceb18b 100644 (file)
@@ -1 +1 @@
-8006
+8007
index 3e45a87..5371013 100644 (file)
@@ -4,7 +4,7 @@
 # Configure script
 #
 
-AC_INIT([NetXMS], [2.0-M1], [bugs@netxms.org])
+AC_INIT([NetXMS], [2.0-M2], [bugs@netxms.org])
 AC_CONFIG_AUX_DIR(config)
 AC_CONFIG_HEADERS(config.h)
 AM_INIT_AUTOMAKE
@@ -1573,6 +1573,11 @@ AC_CHECK_FUNCS([fopen64 strptime timegm gethostbyname2_r])
 
 AC_CHECK_DECLS([nanosleep])
 
+# Do not use inet_pton on Solaris as it has binary compatibility problems
+if test "$PLATFORM" != "SunOS"; then
+       AC_CHECK_FUNCS([inet_pton])
+fi
+
 # Check if strerror_r is POSIX-compliant
 if test "$ac_cv_func_strerror_r" = "yes"; then
        AC_MSG_CHECKING(if strerror_r is POSIX compliant)
index 1a2f214..d592206 100644 (file)
@@ -1,5 +1,5 @@
 #ifndef __build_h
 #define __build_h
-#define NETXMS_VERSION_BUILD 8006
-#define NETXMS_VERSION_BUILD_STRING _T("8006")
+#define NETXMS_VERSION_BUILD 8007
+#define NETXMS_VERSION_BUILD_STRING _T("8007")
 #endif
index 5b25468..a721bf4 100644 (file)
@@ -1,6 +1,6 @@
 /*
 ** NetXMS - Network Management System
-** Copyright (C) 2003-2013 Victor Kirhenshtein
+** Copyright (C) 2003-2015 Victor Kirhenshtein
 **
 ** This program is free software; you can redistribute it and/or modify
 ** it under the terms of the GNU Lesser General Public License as published
@@ -1518,6 +1518,11 @@ char LIBNETXMS_EXPORTABLE *strptime(const char *buf, const char *fmt, struct tm
 time_t LIBNETXMS_EXPORTABLE timegm(struct tm *_tm);
 #endif
 
+#if !HAVE_INET_PTON
+int LIBNETXMS_EXPORTABLE nx_inet_pton(int af, const char *src, void *dst);
+#define inet_pton nx_inet_pton
+#endif
+
 #ifdef __cplusplus
 }
 #endif
index 12c31df..953b5ff 100644 (file)
@@ -1,5 +1,5 @@
 package org.netxms.base;
 public final class BuildNumber {
-   public static final String TEXT = "8006";
-   public static final int NUMBER = 8006;
+   public static final String TEXT = "8007";
+   public static final int NUMBER = 8007;
 }
index 681eafd..3d34ccf 100644 (file)
@@ -1,12 +1,12 @@
 SOURCES = agent.cpp array.cpp base64.cpp config.cpp crypto.cpp dirw_unix.c \
          gen_uuid.c geolocation.cpp getopt.c dload.cpp hash.cpp ice.c \
-         icmp.cpp iconv.cpp inetaddr.cpp log.cpp main.cpp md5.cpp message.cpp \
-         msgrecv.cpp msgwq.cpp net.cpp nxcp.cpp pa.cpp parisc_atomic.cpp \
-         qsort.c queue.cpp rwlock.cpp scandir.c serial.cpp sha1.cpp \
-         solaris9_atomic.c string.cpp stringlist.cpp strmap.cpp strmapbase.cpp \
-         strptime.c strset.cpp strtoll.c strtoull.c table.cpp threads.cpp \
-         timegm.c tools.cpp unicode.cpp uuid.c wcstoll.c wcstoull.c xml.cpp \
-         wcscasecmp.cpp wcsncasecmp.cpp
+         icmp.cpp iconv.cpp inet_pton.c inetaddr.cpp log.cpp main.cpp \
+         md5.cpp message.cpp msgrecv.cpp msgwq.cpp net.cpp nxcp.cpp pa.cpp \
+         parisc_atomic.cpp qsort.c queue.cpp rwlock.cpp scandir.c \
+         serial.cpp sha1.cpp solaris9_atomic.c string.cpp stringlist.cpp \
+         strmap.cpp strmapbase.cpp strptime.c strset.cpp strtoll.c \
+         strtoull.c table.cpp threads.cpp timegm.c tools.cpp unicode.cpp \
+         uuid.c wcstoll.c wcstoull.c xml.cpp wcscasecmp.cpp wcsncasecmp.cpp
 
 lib_LTLIBRARIES = libnetxms.la
 
diff --git a/src/libnetxms/inet_pton.c b/src/libnetxms/inet_pton.c
new file mode 100644 (file)
index 0000000..96954f5
--- /dev/null
@@ -0,0 +1,232 @@
+/* This is from the BIND 4.9.4 release, modified to compile by itself */
+
+/* Copyright (c) 1996 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 <config.h>
+
+#if !HAVE_INET_PTON
+
+#if HAVE_SYS_PARAM_H
+#include <sys/param.h>
+#endif
+#if HAVE_SYS_SOCKET_H
+#include <sys/socket.h>
+#endif
+#if HAVE_NETINET_IN_H
+#include <netinet/in.h>
+#endif
+#if HAVE_ARPA_INET_H
+#include <arpa/inet.h>
+#endif
+#include <string.h>
+#include <errno.h>
+
+#define IN6ADDRSZ       16
+#define INADDRSZ         4
+#define INT16SZ          2
+
+/*
+ * WARNING: Don't even consider trying to compile this on a system where
+ * sizeof(int) < 4.  sizeof(int) > 4 is fine; all the world's not a VAX.
+ */
+
+static int      inet_pton4(const char *src, unsigned char *dst);
+static int      inet_pton6(const char *src, unsigned char *dst);
+
+/* int
+ * inet_pton(af, src, dst)
+ *      convert from presentation format (which usually means ASCII printable)
+ *      to network format (which is usually some kind of binary format).
+ * return:
+ *      1 if the address was valid for the specified address family
+ *      0 if the address wasn't valid (`dst' is untouched in this case)
+ *      -1 if some other error occurred (`dst' is untouched in this case, too)
+ * notice:
+ *      On Windows we store the error in the thread errno, not
+ *      in the winsock error code. This is to avoid loosing the
+ *      actual last winsock error. So use macro ERRNO to fetch the
+ *      errno this funtion sets when returning (-1), not SOCKERRNO.
+ * author:
+ *      Paul Vixie, 1996.
+ */
+int nx_inet_pton(int af, const char *src, void *dst)
+{
+  switch (af) {
+  case AF_INET:
+    return (inet_pton4(src, (unsigned char *)dst));
+  case AF_INET6:
+    return (inet_pton6(src, (unsigned char *)dst));
+  default:
+#ifdef SET_ERRNO
+    SET_ERRNO(EAFNOSUPPORT);
+#endif
+    return (-1);
+  }
+  /* NOTREACHED */
+}
+
+/* int
+ * inet_pton4(src, dst)
+ *      like inet_aton() but without all the hexadecimal and shorthand.
+ * return:
+ *      1 if `src' is a valid dotted quad, else 0.
+ * notice:
+ *      does not touch `dst' unless it's returning 1.
+ * author:
+ *      Paul Vixie, 1996.
+ */
+static int
+inet_pton4(const char *src, unsigned char *dst)
+{
+  static const char digits[] = "0123456789";
+  int saw_digit, octets, ch;
+  unsigned char tmp[INADDRSZ], *tp;
+
+  saw_digit = 0;
+  octets = 0;
+  tp = tmp;
+  *tp = 0;
+  while((ch = *src++) != '\0') {
+    const char *pch;
+
+    if((pch = strchr(digits, ch)) != NULL) {
+      unsigned int val = *tp * 10 + (unsigned int)(pch - digits);
+
+      if(saw_digit && *tp == 0)
+        return (0);
+      if(val > 255)
+        return (0);
+      *tp = (unsigned char)val;
+      if(! saw_digit) {
+        if(++octets > 4)
+          return (0);
+        saw_digit = 1;
+      }
+    }
+    else if(ch == '.' && saw_digit) {
+      if(octets == 4)
+        return (0);
+      *++tp = 0;
+      saw_digit = 0;
+    }
+    else
+      return (0);
+  }
+  if(octets < 4)
+    return (0);
+  memcpy(dst, tmp, INADDRSZ);
+  return (1);
+}
+
+/* int
+ * inet_pton6(src, dst)
+ *      convert presentation level address to network order binary form.
+ * return:
+ *      1 if `src' is a valid [RFC1884 2.2] address, else 0.
+ * notice:
+ *      (1) does not touch `dst' unless it's returning 1.
+ *      (2) :: in a full address is silently ignored.
+ * credit:
+ *      inspired by Mark Andrews.
+ * author:
+ *      Paul Vixie, 1996.
+ */
+static int
+inet_pton6(const char *src, unsigned char *dst)
+{
+  static const char xdigits_l[] = "0123456789abcdef",
+    xdigits_u[] = "0123456789ABCDEF";
+  unsigned char tmp[IN6ADDRSZ], *tp, *endp, *colonp;
+  const char *xdigits, *curtok;
+  int ch, saw_xdigit;
+  unsigned int val;
+
+  memset((tp = tmp), 0, IN6ADDRSZ);
+  endp = tp + IN6ADDRSZ;
+  colonp = NULL;
+  /* Leading :: requires some special handling. */
+  if(*src == ':')
+    if(*++src != ':')
+      return (0);
+  curtok = src;
+  saw_xdigit = 0;
+  val = 0;
+  while((ch = *src++) != '\0') {
+    const char *pch;
+
+    if((pch = strchr((xdigits = xdigits_l), ch)) == NULL)
+      pch = strchr((xdigits = xdigits_u), ch);
+    if(pch != NULL) {
+      val <<= 4;
+      val |= (pch - xdigits);
+      if(++saw_xdigit > 4)
+        return (0);
+      continue;
+    }
+    if(ch == ':') {
+      curtok = src;
+      if(!saw_xdigit) {
+        if(colonp)
+          return (0);
+        colonp = tp;
+        continue;
+      }
+      if(tp + INT16SZ > endp)
+        return (0);
+      *tp++ = (unsigned char) (val >> 8) & 0xff;
+      *tp++ = (unsigned char) val & 0xff;
+      saw_xdigit = 0;
+      val = 0;
+      continue;
+    }
+    if(ch == '.' && ((tp + INADDRSZ) <= endp) &&
+        inet_pton4(curtok, tp) > 0) {
+      tp += INADDRSZ;
+      saw_xdigit = 0;
+      break;    /* '\0' was seen by inet_pton4(). */
+    }
+    return (0);
+  }
+  if(saw_xdigit) {
+    if(tp + INT16SZ > endp)
+      return (0);
+    *tp++ = (unsigned char) (val >> 8) & 0xff;
+    *tp++ = (unsigned char) val & 0xff;
+  }
+  if(colonp != NULL) {
+    /*
+     * Since some memmove()'s erroneously fail to handle
+     * overlapping regions, we'll do the shift by hand.
+     */
+    const long n = tp - colonp;
+    long i;
+
+    if(tp == endp)
+      return (0);
+    for (i = 1; i <= n; i++) {
+      endp[- i] = colonp[n - i];
+      colonp[n - i] = 0;
+    }
+    tp = endp;
+  }
+  if(tp != endp)
+    return (0);
+  memcpy(dst, tmp, IN6ADDRSZ);
+  return (1);
+}
+
+#endif /* HAVE_INET_PTON */