Merge branch 'collectd-5.5' into collectd-5.6
authorFlorian Forster <octo@collectd.org>
Wed, 2 Nov 2016 08:20:57 +0000 (09:20 +0100)
committerFlorian Forster <octo@collectd.org>
Wed, 2 Nov 2016 08:20:57 +0000 (09:20 +0100)
1  2 
configure.ac
src/battery.c
src/powerdns.c
src/utils_format_graphite.c

diff --combined configure.ac
@@@ -1,7 -1,6 +1,7 @@@
  dnl Process this file with autoconf to produce a configure script.
 +AC_PREREQ([2.60])
  AC_INIT([collectd],[m4_esyscmd(./version-gen.sh)])
 -AC_CONFIG_SRCDIR(src/)
 +AC_CONFIG_SRCDIR(src/target_set.c)
  AC_CONFIG_HEADERS(src/config.h)
  AC_CONFIG_AUX_DIR([libltdl/config])
  
@@@ -32,7 -31,7 +32,7 @@@ m4_ifdef([LT_PACKAGE_VERSION]
  
  AM_CONDITIONAL([BUILD_INCLUDED_LTDL], [test "x$LTDLDEPS" != "x"])
  
 -AM_INIT_AUTOMAKE([tar-pax dist-bzip2 foreign])
 +AM_INIT_AUTOMAKE([subdir-objects tar-pax dist-bzip2 no-dist-gzip foreign])
  m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
  AC_LANG(C)
  
@@@ -43,10 -42,7 +43,10 @@@ AC_SYS_LARGEFIL
  #
  # Checks for programs.
  #
 -AC_PROG_CC
 +AC_PROG_CC_C99([],
 +  [AC_MSG_ERROR([No compiler found that supports C99])]
 +)
 +AC_PROG_CXX
  AC_PROG_CPP
  AC_PROG_EGREP
  AC_PROG_INSTALL
@@@ -60,8 -56,6 +60,8 @@@ AC_PROG_LIBTOO
  AC_PROG_LEX
  AC_PROG_YACC
  
 +AC_PATH_PROG([VALGRIND], [valgrind])
 +
  # Warn when pkg.m4 is missing
  m4_pattern_forbid([^_?PKG_[A-Z_]+$],[*** pkg.m4 missing, please install pkg-config])
  
@@@ -79,33 -73,26 +79,33 @@@ the
        AC_MSG_ERROR([bison is missing and you do not have ${srcdir}/src/liboconfig/parser.c. Please install bison])
  fi
  
 -AC_CHECK_PROG([have_protoc_c], [protoc-c], [yes], [no])
 -if test "x$have_protoc_c" = "xno"
 -then
 -      have_protoc_c="no (protoc-c compiler not found)"
 +AC_ARG_VAR([PROTOC], [path to the protoc binary])
 +AC_PATH_PROG([PROTOC], [protoc])
 +have_protoc3="no"
 +if test "x$PROTOC" != "x"; then
 +      AC_MSG_CHECKING([for protoc 3.0.0+])
 +      if $PROTOC --version | $EGREP libprotoc.3 >/dev/null; then
 +              protoc3="yes (`$PROTOC --version`)"
 +              have_protoc3="yes"
 +      else
 +              protoc3="no (`$PROTOC --version`)"
 +      fi
 +      AC_MSG_RESULT([$protoc3])
  fi
 +AM_CONDITIONAL(HAVE_PROTOC3, test "x$have_protoc3" = "xyes")
  
 -if test "x$have_protoc_c" = "xyes"
 -then
 -      AC_CHECK_HEADERS([protobuf-c/protobuf-c.h google/protobuf-c/protobuf-c.h],
 -                       [have_protoc_c="yes"; break],
 -                       [have_protoc_c="no (<google/protobuf-c/protobuf-c.h> not found)"])
 -fi
 -if test "x$have_protoc_c" = "xyes"
 -then
 -      AC_CHECK_LIB([protobuf-c], [protobuf_c_message_pack],
 -                   [have_protoc_c="yes"],
 -                   [have_protoc_c="no (libprotobuf-c not found)"])
 +AC_ARG_VAR([GRPC_CPP_PLUGIN], [path to the grpc_cpp_plugin binary])
 +AC_PATH_PROG([GRPC_CPP_PLUGIN], [grpc_cpp_plugin])
 +AM_CONDITIONAL(HAVE_GRPC_CPP, test "x$GRPC_CPP_PLUGIN" != "x")
  
 +AC_ARG_VAR([PROTOC_C], [path to the protoc-c binary])
 +AC_PATH_PROG([PROTOC_C], [protoc-c])
 +if test "x$PROTOC_C" = "x"
 +then
 +  have_protoc_c="no (protoc-c compiler not found)"
 +else
 +  have_protoc_c="yes"
  fi
 -AM_CONDITIONAL(HAVE_PROTOC_C, test "x$have_protoc_c" = "xyes")
  
  AC_MSG_CHECKING([for kernel type ($host_os)])
  case $host_os in
        AC_DEFINE([KERNEL_OPENBSD], 1, [True if program is to be compiled for an OpenBSD kernel])
        ac_system="OpenBSD"
        ;;
 +      *netbsd*)
 +      AC_DEFINE([KERNEL_NETBSD], 1, [True if program is to be compiled for a NetBSD kernel])
 +      ac_system="NetBSD"
 +      ;;
        *aix*)
        AC_DEFINE([KERNEL_AIX], 1, [True if program is to be compiled for a AIX kernel])
        ac_system="AIX"
  esac
  AC_MSG_RESULT([$ac_system])
  
 -AM_CONDITIONAL([BUILD_LINUX],[test "x$ac_system" = "xLinux"])
 -AM_CONDITIONAL([BUILD_SOLARIS],[test "x$ac_system" = "xSolaris"])
 -AM_CONDITIONAL([BUILD_DARWIN],[test "x$ac_system" = "xDarwin"])
 -AM_CONDITIONAL([BUILD_OPENBSD],[test "x$ac_system" = "xOpenBSD"])
 -AM_CONDITIONAL([BUILD_AIX],[test "x$ac_system" = "xAIX"])
 -AM_CONDITIONAL([BUILD_FREEBSD],[test "x$ac_system" = "xFreeBSD"])
 +AM_CONDITIONAL([BUILD_AIX], [test "x$ac_system" = "xAIX"])
 +AM_CONDITIONAL([BUILD_DARWIN], [test "x$ac_system" = "xDarwin"])
 +AM_CONDITIONAL([BUILD_FREEBSD], [test "x$ac_system" = "xFreeBSD"])
 +AM_CONDITIONAL([BUILD_LINUX], [test "x$ac_system" = "xLinux"])
 +AM_CONDITIONAL([BUILD_OPENBSD], [test "x$ac_system" = "xOpenBSD"])
 +AM_CONDITIONAL([BUILD_SOLARIS], [test "x$ac_system" = "xSolaris"])
  
  if test "x$ac_system" = "xLinux"
  then
@@@ -216,19 -199,6 +216,19 @@@ AC_HEADER_STDBOO
  
  AC_CHECK_HEADERS(stdio.h errno.h math.h stdarg.h syslog.h fcntl.h signal.h assert.h sys/types.h sys/socket.h sys/select.h poll.h netdb.h arpa/inet.h sys/resource.h sys/param.h kstat.h regex.h sys/ioctl.h endian.h sys/isa_defs.h fnmatch.h libgen.h)
  
 +# For entropy plugin on newer NetBSD
 +AC_CHECK_HEADERS(sys/rndio.h, [], [],
 +[#if HAVE_SYS_TYPES_H
 +# include <sys/types.h>
 +#endif
 +#if HAVE_SYS_IOCTL_H
 +# include <sys/ioctl.h>
 +#endif
 +#if HAVE_SYS_PARAM_H
 +# include <sys/param.h>
 +#endif
 +])
 +
  # For ping library
  AC_CHECK_HEADERS(netinet/in_systm.h, [], [],
  [#if HAVE_STDINT_H
@@@ -443,7 -413,7 +443,7 @@@ AC_CHECK_HEADERS(sys/sysctl.h, [], []
  AC_MSG_CHECKING([for sysctl kern.cp_times])
  if test -x /sbin/sysctl
  then
 -      /sbin/sysctl kern.cp_times 2>/dev/null
 +      /sbin/sysctl kern.cp_times >/dev/null 2>&1
        if test $? -eq 0
        then
                AC_MSG_RESULT([yes])
@@@ -456,22 -426,6 +456,22 @@@ els
        AC_MSG_RESULT([no])
  fi
  
 +AC_MSG_CHECKING([for sysctl kern.cp_time])
 +if test -x /sbin/sysctl
 +then
 +      /sbin/sysctl kern.cp_time >/dev/null 2>&1
 +      if test $? -eq 0
 +      then
 +              AC_MSG_RESULT([yes])
 +              AC_DEFINE(HAVE_SYSCTL_KERN_CP_TIME, 1,
 +                      [Define if sysctl supports kern.cp_time])
 +      else
 +              AC_MSG_RESULT([no])
 +      fi
 +else
 +      AC_MSG_RESULT([no])
 +fi
 +
  # For hddtemp module
  AC_CHECK_HEADERS(linux/major.h)
  
@@@ -491,7 -445,7 +491,7 @@@ els
        have_linux_raid_md_u_h="no"
  fi
  
 -# For the swap module
 +# For the wireless module
  have_linux_wireless_h="no"
  if test "x$ac_system" = "xLinux"
  then
@@@ -683,26 -637,10 +683,26 @@@ AC_CHECK_HEADERS([ 
    wordexp.h \
  ])
  
 -AC_CHECK_HEADERS([xfs/xqm.h], [], [],
 -[
 -#define _GNU_SOURCE
 -])
 +# --enable-xfs {{{
 +AC_ARG_ENABLE([xfs],
 +  [AS_HELP_STRING([--enable-xfs], [xfs support in df plugin @<:@default=yes@:>@])],
 +  [],
 +  [enable_xfs="auto"]
 +)
 +
 +if test "x$enable_xfs" != "xno"; then
 +  AC_CHECK_HEADERS([xfs/xqm.h],
 +    [],
 +    [
 +      if test "x$enable_xfs" = "xyes"; then
 +        AC_MSG_ERROR([xfs/xqm.h not found])
 +      fi
 +    ],
 +    [[#define _GNU_SOURCE]]
 +  )
 +fi
 +
 +# }}}
  
  # For the dns plugin
  AC_CHECK_HEADERS(arpa/nameser.h)
@@@ -742,6 -680,8 +742,6 @@@ AC_CHECK_HEADERS(netinet/if_ether.h, []
  #endif
  ])
  
 -AC_CHECK_HEADERS(netinet/ip_compat.h)
 -
  have_net_pfvar_h="no"
  AC_CHECK_HEADERS(net/pfvar.h,
                 [have_net_pfvar_h="yes"],
  have_termios_h="no"
  AC_CHECK_HEADERS(termios.h, [have_termios_h="yes"])
  
 +# For cpusleep plugin
 +AC_CACHE_CHECK([whether clock_boottime and clock_monotonic are supported],
 +                     [c_cv_have_clock_boottime_monotonic],
 +                     AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
 +[[
 +#include <time.h>
 +]],
 +[[
 + struct timespec b, m;
 + clock_gettime(CLOCK_BOOTTIME, &b );
 + clock_gettime(CLOCK_MONOTONIC, &m );
 +]]
 +                     )],
 +                     [c_cv_have_clock_boottime_monotonic="yes"],
 +                     [c_cv_have_clock_boottime_monotonic="no"]))
 +
 +
  # For the turbostat plugin
  have_asm_msrindex_h="no"
  AC_CHECK_HEADERS(asm/msr-index.h, [have_asm_msrindex_h="yes"])
  have_cpuid_h="no"
  AC_CHECK_HEADERS(cpuid.h, [have_cpuid_h="yes"])
  
 -AC_CHECK_HEADERS(sys/capability.h)
 +have_capability="yes"
 +AC_CHECK_HEADERS(sys/capability.h,
 +                 [have_capability="yes"],
 +                 [have_capability="no (<sys/capability.h> not found)"])
 +if test "x$have_capability" = "xyes"; then
 +AC_CHECK_LIB(cap, cap_get_bound,
 +                 [have_capability="yes"],
 +                 [have_capability="no (cap_get_bound() not found)"])
 +fi
 +if test "x$have_capability" = "xyes"; then
 +  AC_DEFINE(HAVE_CAPABILITY, 1, [Define to 1 if you have cap_get_bound() (-lcap).])
 +fi
 +AM_CONDITIONAL(BUILD_WITH_CAPABILITY, test "x$have_capability" = "xyes")
 +
  #
  # Checks for typedefs, structures, and compiler characteristics.
  #
  AC_C_CONST
 -AC_C_INLINE
 -AC_TYPE_OFF_T
  AC_TYPE_PID_T
  AC_TYPE_SIZE_T
 -AC_TYPE_SSIZE_T
  AC_TYPE_UID_T
 -AC_TYPE_UINT32_T
  AC_HEADER_TIME
  
  #
  # Checks for library functions.
  #
 -AC_PROG_GCC_TRADITIONAL
 -AC_CHECK_FUNCS(gettimeofday select strdup strtol getaddrinfo getnameinfo strchr memcpy strstr strcmp strncmp strncpy strlen strncasecmp strcasecmp openlog closelog sysconf setenv if_indextoname setlocale)
 +AC_CHECK_FUNCS(gettimeofday select strdup strtol getaddrinfo getnameinfo strchr memcpy strstr strcmp strncmp strncpy strlen strncasecmp strcasecmp openlog closelog sysconf setenv if_indextoname setlocale asprintf)
  
  AC_FUNC_STRERROR_R
  
 +test_cxx_flags() {
 +      AC_LANG_PUSH([C++])
 +      AC_LANG_CONFTEST([
 +              AC_LANG_SOURCE([[int main(void){}]])
 +      ])
 +      $CXX -c conftest.cpp $CXXFLAGS $@ > /dev/null 2> /dev/null
 +      ret=$?
 +      rm -f conftest.o
 +      AC_LANG_POP([C++])
 +      return $ret
 +}
 +
  SAVE_CFLAGS="$CFLAGS"
  # Emulate behavior of src/Makefile.am
  if test "x$GCC" = "xyes"
@@@ -949,6 -852,8 +949,6 @@@ f
  if test "x$have_clock_gettime" = "xyes"
  then
        AC_DEFINE(HAVE_CLOCK_GETTIME, 1, [Define if the clock_gettime(2) function is available.])
 -else
 -      AC_MSG_WARN(cannot find clock_gettime)
  fi
  
  nanosleep_needs_rt="no"
@@@ -1400,20 -1305,6 +1400,20 @@@ AC_ARG_WITH(useragent, [AS_HELP_STRING(
  
  # }}}
  
 +# --with-data-max-name-len {{{
 +AC_ARG_WITH(data-max-name-len, [AS_HELP_STRING([--with-data-max-name-len@<:@=VALUE@:>@], [Maximum length of data buffers])],
 +[
 +    if test "x$withval" != "x" && test $withval -gt 0
 +    then
 +        AC_DEFINE_UNQUOTED(DATA_MAX_NAME_LEN, [$withval], [Maximum length of data buffers])
 +    else
 +        AC_MSG_ERROR([DATA_MAX_NAME_LEN must be a positive integer -- $withval given])
 +    fi
 +],
 +[   AC_DEFINE(DATA_MAX_NAME_LEN, 128, [Maximum length of data buffers])]
 +)
 +# }}}
 +
  have_getfsstat="no"
  AC_CHECK_FUNCS(getfsstat, [have_getfsstat="yes"])
  have_getvfsstat="no"
@@@ -1491,15 -1382,15 +1491,15 @@@ if test "x$have_getmntent" = "xc"; the
  fi
  if test "x$have_getmntent" = "xsun"; then
        AC_DEFINE(HAVE_SUN_GETMNTENT, 1,
 -                [Define if the function getmntent exists. It's the version from libsun.])
 +                [Define if the function getmntent exists. It is the version from libsun.])
  fi
  if test "x$have_getmntent" = "xseq"; then
        AC_DEFINE(HAVE_SEQ_GETMNTENT, 1,
 -                [Define if the function getmntent exists. It's the version from libseq.])
 +                [Define if the function getmntent exists. It is the version from libseq.])
  fi
  if test "x$have_getmntent" = "xgen"; then
        AC_DEFINE(HAVE_GEN_GETMNTENT, 1,
 -                [Define if the function getmntent exists. It's the version from libgen.])
 +                [Define if the function getmntent exists. It is the version from libgen.])
  fi
  
  # Check for htonll
@@@ -1590,24 -1481,6 +1590,24 @@@ AC_CHECK_MEMBERS([struct kinfo_proc.p_p
  #include <kvm.h>
        ])
  
 +
 +AC_CHECK_MEMBERS([struct kinfo_proc2.p_pid, struct kinfo_proc2.p_uru_maxrss],
 +      [
 +              AC_DEFINE(HAVE_STRUCT_KINFO_PROC2_NETBSD, 1,
 +                      [Define if struct kinfo_proc2 exists in the NetBSD variant.])
 +              have_struct_kinfo_proc2_netbsd="yes"
 +      ],
 +      [
 +              have_struct_kinfo_proc2_netbsd="no"
 +      ],
 +      [
 +#include <sys/param.h>
 +#include <sys/sysctl.h>
 +#include <kvm.h>
 +      ])
 +
 +
 +
  AC_CHECK_MEMBERS([struct udphdr.uh_dport, struct udphdr.uh_sport], [], [],
  [#define _BSD_SOURCE
  #define _DEFAULT_SOURCE
@@@ -1675,48 -1548,18 +1675,48 @@@ AC_CHECK_LIB(resolv, res_search
  AM_CONDITIONAL(BUILD_WITH_LIBRESOLV, test "x$with_libresolv" = "xyes")
  
  dnl Check for HAL (hardware abstraction library)
 -with_libhal="yes"
 -AC_CHECK_LIB(hal,libhal_device_property_exists,
 -           [AC_DEFINE(HAVE_LIBHAL, 1, [Define to 1 if you have 'hal' library])],
 -           [with_libhal="no"])
 -if test "x$with_libhal" = "xyes"; then
 -      if test "x$PKG_CONFIG" != "x"; then
 -              BUILD_WITH_LIBHAL_CFLAGS="`$PKG_CONFIG --cflags hal`"
 -              BUILD_WITH_LIBHAL_LIBS="`$PKG_CONFIG --libs hal`"
 -              AC_SUBST(BUILD_WITH_LIBHAL_CFLAGS)
 -              AC_SUBST(BUILD_WITH_LIBHAL_LIBS)
 -      fi
 -fi
 +with_libhal="no"
 +PKG_CHECK_MODULES([HAL], [hal],
 +  [
 +    SAVE_LIBS="$LIBS"
 +    LIBS="$HAL_LIBS $LIBS"
 +    AC_CHECK_LIB([hal], [libhal_device_property_exists],
 +      [
 +        SAVE_CPPFLAGS="$CPPFLAGS"
 +        CPPFLAGS="$HAL_CFLAGS $CPPFLAGS"
 +        AC_CHECK_HEADERS([libhal.h],
 +        [
 +          with_libhal="yes"
 +          BUILD_WITH_LIBHAL_CFLAGS="$HAL_CFLAGS"
 +          BUILD_WITH_LIBHAL_LIBS="$HAL_LIBS"
 +        ])
 +        CPPFLAGS="$SAVE_CPPFLAGS"
 +      ],
 +      [ : ]
 +    )
 +    LIBS="$SAVE_LIBS"
 +  ],
 +  [ : ]
 +)
 +AC_SUBST(BUILD_WITH_LIBHAL_CFLAGS)
 +AC_SUBST(BUILD_WITH_LIBHAL_LIBS)
 +
 +
 +SAVE_LIBS="$LIBS"
 +AC_CHECK_LIB([pthread],
 +  [pthread_create],
 +  [],
 +  [AC_MSG_ERROR([Symbol 'pthread_create' not found in libpthread"])],
 +  []
 +)
 +PTHREAD_LIBS="$LIBS"
 +LIBS="$SAVE_LIBS"
 +
 +AC_CHECK_HEADERS([pthread.h],
 +  [],
 +  [AC_MSG_ERROR([pthread.h not found])]
 +)
 +AC_SUBST([PTHREAD_LIBS])
  
  m4_divert_once([HELP_WITH], [
  collectd additional packages:])
  fi
  if test "x$with_libcurl" = "xyes"
  then
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      SAVE_LDFLAGS="$LDFLAGS"
 +      CPPFLAGS="$CPPFLAGS $with_curl_cflags"
 +      LDFLAGS="$LDFLAGS $with_curl_libs"
 +      AC_CACHE_CHECK([for CURLINFO_APPCONNECT_TIME],
 +              [c_cv_have_curlinfo_appconnect_time],
 +              AC_LINK_IFELSE([AC_LANG_PROGRAM(
 +[[
 +#include <curl/curl.h>
 +]],
 +[[
 +int val = CURLINFO_APPCONNECT_TIME;
 +return val;
 +]]
 +                      )],
 +                      [c_cv_have_curlinfo_appconnect_time="yes"],
 +                      [c_cv_have_curlinfo_appconnect_time="no"]
 +              )
 +      )
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +      LDFLAGS="$SAVE_LDFLAGS"
 +fi
 +AM_CONDITIONAL(BUILD_WITH_LIBCURL, test "x$with_libcurl" = "xyes")
 +if test "x$c_cv_have_curlinfo_appconnect_time" = "xyes"
 +then
 +      AC_DEFINE(HAVE_CURLINFO_APPCONNECT_TIME, 1, [Define if curl.h defines CURLINFO_APPCONNECT_TIME.])
 +fi
 +
 +if test "x$with_libcurl" = "xyes"
 +then
        BUILD_WITH_LIBCURL_CFLAGS="$with_curl_cflags"
        BUILD_WITH_LIBCURL_LIBS="$with_curl_libs"
        AC_SUBST(BUILD_WITH_LIBCURL_CFLAGS)
                AC_DEFINE(HAVE_CURLOPT_TIMEOUT_MS, 1, [Define if libcurl supports CURLOPT_TIMEOUT_MS option.])
        fi
  fi
 -AM_CONDITIONAL(BUILD_WITH_LIBCURL, test "x$with_libcurl" = "xyes")
  # }}}
  
  # --with-libdbi {{{
@@@ -2297,6 -2111,12 +2297,6 @@@ the
        AC_CHECK_LIB(gcrypt, gcry_md_hash_buffer,
                [with_libgcrypt="yes"],
                [with_libgcrypt="no (symbol gcry_md_hash_buffer not found)"])
 -
 -      if test "$with_libgcrypt" != "no"; then
 -              m4_ifdef([AM_PATH_LIBGCRYPT],[AM_PATH_LIBGCRYPT(1:1.2.0,,with_libgcrypt="no (version 1.2.0+ required)")])
 -              GCRYPT_CPPFLAGS="$LIBGCRYPT_CPPFLAGS $LIBGCRYPT_CFLAGS"
 -              GCRYPT_LIBS="$LIBGCRYPT_LIBS"
 -      fi
  fi
  
  CPPFLAGS="$SAVE_CPPFLAGS"
@@@ -2314,146 -2134,6 +2314,146 @@@ AC_SUBST(GCRYPT_LIBS
  AM_CONDITIONAL(BUILD_WITH_LIBGCRYPT, test "x$with_libgcrypt" = "xyes")
  # }}}
  
 +# --with-libgps {{{
 +with_libgps_cflags=""
 +with_libgps_ldflags=""
 +AC_ARG_WITH(libgps, [AS_HELP_STRING([--with-libgps@<:@=PREFIX@:>@], [Path to libgps.])],
 +[
 +      if test "x$withval" != "xno" && test "x$withval" != "xyes"
 +      then
 +              with_libgps_cflags="-I$withval/include"
 +              with_libgps_ldflags="-L$withval/lib"
 +              with_libgps="yes"
 +      else
 +              with_libgps="$withval"
 +      fi
 +],
 +[
 +      with_libgps="yes"
 +])
 +if test "x$with_libgps" = "xyes"
 +then
 +      SAVE_CFLAGS="$CFLAGS"
 +      CFLAGS="$CFLAGS $with_libgps_cflags"
 +
 +      AC_CHECK_HEADERS(gps.h, [with_libgps="yes"], [with_libgps="no (gps.h not found)"])
 +
 +      CFLAGS="$SAVE_CFLAGS"
 +fi
 +if test "x$with_libgps" = "xyes"
 +then
 +      SAVE_CFLAGS="$CFLAGS"
 +      SAVE_LDFLAGS="$LDFLAGS"
 +      CFLAGS="$CFLAGS $with_libgps_cflags"
 +      LDFLAGS="$LDFLAGS $with_libgps_ldflags"
 +
 +      AC_CHECK_LIB(gps, gps_open, [with_libgps="yes"], [with_libgps="no (symbol gps_open not found)"])
 +
 +      CFLAGS="$SAVE_CFLAGS"
 +      LDFLAGS="$SAVE_LDFLAGS"
 +fi
 +if test "x$with_libgps" = "xyes"
 +then
 +      BUILD_WITH_LIBGPS_CFLAGS="$with_libgps_cflags"
 +      BUILD_WITH_LIBGPS_LDFLAGS="$with_libgps_ldflags"
 +      BUILD_WITH_LIBGPS_LIBS="-lgps"
 +      AC_SUBST(BUILD_WITH_LIBGPS_CFLAGS)
 +      AC_SUBST(BUILD_WITH_LIBGPS_LDFLAGS)
 +      AC_SUBST(BUILD_WITH_LIBGPS_LIBS)
 +fi
 +AM_CONDITIONAL(BUILD_WITH_LIBGPS, test "x$with_libgps" = "xyes")
 +# }}}
 +
 +# --with-libgrpc++ {{{
 +with_libgrpcpp_cppflags=""
 +with_libgrpcpp_ldflags=""
 +AC_ARG_WITH([libgrpc++], [AS_HELP_STRING([--with-libgrpc++@<:@=PREFIX@:>@], [Path to libgrpc++.])],
 +  [
 +    with_grpcpp="$withval"
 +    if test "x$withval" != "xno" && test "x$withval" != "xyes"
 +    then
 +      with_libgrpcpp_cppflags="-I$withval/include"
 +      with_libgrpcpp_ldflags="-L$withval/lib"
 +      with_libgrpcpp="yes"
 +    fi
 +    if test "x$withval" = "xno"
 +    then
 +      with_libgrpcpp="no (disabled on command line)"
 +    fi
 +  ],
 +  [withval="yes"]
 +)
 +if test "x$withval" = "xyes"
 +then
 +PKG_CHECK_MODULES([GRPCPP], [grpc++],
 +  [with_libgrpcpp="yes"],
 +  [with_libgrpcpp="no (pkg-config could not find libgrpc++)"]
 +)
 +fi
 +
 +if test "x$withval" != "xno"
 +then
 +  AC_MSG_CHECKING([whether $CXX accepts -std=c++11])
 +  if test_cxx_flags -std=c++11; then
 +    AC_MSG_RESULT([yes])
 +  else
 +    AC_MSG_RESULT([no])
 +    with_libgrpcpp="no (requires C++11 support)"
 +  fi
 +fi
 +
 +if test "x$with_libgrpcpp" = "xyes"
 +then
 +  AC_LANG_PUSH(C++)
 +  SAVE_CPPFLAGS="$CPPFLAGS"
 +  CPPFLAGS="-std=c++11 $with_libgrpcpp_cppflags $GRPCPP_CFLAGS $CPPFLAGS"
 +  AC_CHECK_HEADERS([grpc++/grpc++.h], [],
 +    [with_libgrpcpp="no (<grpc++/grpc++.h> not found)"]
 +  )
 +  CPPFLAGS="$SAVE_CPPFLAGS"
 +  AC_LANG_POP(C++)
 +fi
 +if test "x$with_libgrpcpp" = "xyes"
 +then
 +  AC_LANG_PUSH(C++)
 +  SAVE_CPPFLAGS="$CPPFLAGS"
 +  SAVE_LDFLAGS="$LDFLAGS"
 +  SAVE_LIBS="$LIBS"
 +  CPPFLAGS="-std=c++11 $with_libgrpcpp_cppflags $GRPCPP_CFLAGS $CPPFLAGS"
 +  LDFLAGS="$with_libgrpcpp_ldflags"
 +  if test "x$GRPCPP_LIBS" = "x"
 +  then
 +    LIBS="-lgrpc++"
 +  else
 +    LIBS="$GRPCPP_LIBS"
 +  fi
 +  AC_LINK_IFELSE(
 +    [AC_LANG_PROGRAM(
 +      [[#include <grpc++/grpc++.h>]],
 +      [[grpc::ServerBuilder sb;]]
 +    )],
 +    [
 +      with_libgrpcpp="yes"
 +      if test "x$GRPCPP_LIBS" = "x"
 +      then
 +        GRPCPP_LIBS="-lgrpc++"
 +      fi
 +    ],
 +    [with_libgrpcpp="no (libgrpc++ not found)"]
 +  )
 +  CPPFLAGS="$SAVE_CPPFLAGS"
 +  LDFLAGS="$SAVE_LDFLAGS"
 +  LIBS="$SAVE_LIBS"
 +  AC_LANG_POP(C++)
 +fi
 +BUILD_WITH_LIBGRPCPP_CPPFLAGS="-std=c++11 $with_libgrpcpp_cppflags $GRPCPP_CFLAGS"
 +BUILD_WITH_LIBGRPCPP_LDFLAGS="$with_libgrpcpp_ldflags"
 +BUILD_WITH_LIBGRPCPP_LIBS="$GRPCPP_LIBS"
 +AC_SUBST([BUILD_WITH_LIBGRPCPP_CPPFLAGS])
 +AC_SUBST([BUILD_WITH_LIBGRPCPP_LDFLAGS])
 +AC_SUBST([BUILD_WITH_LIBGRPCPP_LIBS])
 +# }}}
 +
  # --with-libiptc {{{
  AC_ARG_WITH(libiptc, [AS_HELP_STRING([--with-libiptc@<:@=PREFIX@:>@], [Path to libiptc.])],
  [
        fi
  ])
  
 -if test "x$with_libiptc" = "xpkgconfig" && test "x$PKG_CONFIG" = "x"
 -then
 -      with_libiptc="no (Don't have pkg-config)"
 -fi
 -
  if test "x$with_libiptc" = "xpkgconfig"
  then
        $PKG_CONFIG --exists 'libiptc' 2>/dev/null
@@@ -2550,6 -2235,9 +2550,6 @@@ if test "x$with_java_home" = "x
  then
        with_java_home="/usr/lib/jvm"
  fi
 -with_java_vmtype="client"
 -with_java_cflags=""
 -with_java_libs=""
  JAVAC="$JAVAC"
  JAR="$JAR"
  AC_ARG_WITH(java, [AS_HELP_STRING([--with-java@<:@=PREFIX@:>@], [Path to Java home.])],
@@@ -2571,7 -2259,7 +2571,7 @@@ the
        if test -d "$with_java_home"
        then
                AC_MSG_CHECKING([for jni.h])
-               TMPVAR=`find -L "$with_java_home" -name jni.h -type f -exec 'dirname' '{}' ';' 2>/dev/null | head -n 1`
+               TMPVAR=`find -L "$with_java_home" -name jni.h -type f -exec 'dirname' '{}' ';' 2>/dev/null | LC_ALL=C sort | head -n 1`
                if test "x$TMPVAR" != "x"
                then
                        AC_MSG_RESULT([found in $TMPVAR])
                fi
  
                AC_MSG_CHECKING([for jni_md.h])
-               TMPVAR=`find -L "$with_java_home" -name jni_md.h -type f -exec 'dirname' '{}' ';' 2>/dev/null | head -n 1`
+               TMPVAR=`find -L "$with_java_home" -name jni_md.h -type f -exec 'dirname' '{}' ';' 2>/dev/null | LC_ALL=C sort | head -n 1`
                if test "x$TMPVAR" != "x"
                then
                        AC_MSG_RESULT([found in $TMPVAR])
                fi
  
                AC_MSG_CHECKING([for libjvm.so])
-               TMPVAR=`find -L "$with_java_home" -type f \( -name libjvm.so -o -name libjvm.dylib \) -exec 'dirname' '{}' ';' 2>/dev/null | head -n 1`
+               TMPVAR=`find -L "$with_java_home" -type f \( -name libjvm.so -o -name libjvm.dylib \) -exec 'dirname' '{}' ';' 2>/dev/null | LC_ALL=C sort | head -n 1`
                if test "x$TMPVAR" != "x"
                then
                        AC_MSG_RESULT([found in $TMPVAR])
                if test "x$JAVAC" = "x"
                then
                        AC_MSG_CHECKING([for javac])
-                       TMPVAR=`find -L "$with_java_home" -name javac -type f 2>/dev/null | head -n 1`
+                       TMPVAR=`find -L "$with_java_home" -name javac -type f 2>/dev/null | LC_ALL=C sort | head -n 1`
                        if test "x$TMPVAR" != "x"
                        then
                                JAVAC="$TMPVAR"
                if test "x$JAR" = "x"
                then
                        AC_MSG_CHECKING([for jar])
-                       TMPVAR=`find -L "$with_java_home" -name jar -type f 2>/dev/null | head -n 1`
+                       TMPVAR=`find -L "$with_java_home" -name jar -type f 2>/dev/null | LC_ALL=C sort | head -n 1`
                        if test "x$TMPVAR" != "x"
                        then
                                JAR="$TMPVAR"
@@@ -2642,10 -2330,6 +2642,10 @@@ if test "x$JAVA_LDFLAGS" != "x
  then
        AC_MSG_NOTICE([Building with JAVA_LDFLAGS set to: $JAVA_LDFLAGS])
  fi
 +if test "x$JAVA_LIBS" != "x"
 +then
 +      AC_MSG_NOTICE([Building with JAVA_LIBS set to: $JAVA_LIBS])
 +fi
  if test "x$JAVAC" = "x"
  then
        with_javac_path="$PATH"
  SAVE_CPPFLAGS="$CPPFLAGS"
  SAVE_CFLAGS="$CFLAGS"
  SAVE_LDFLAGS="$LDFLAGS"
 +SAVE_LIBS="$LIBS"
  CPPFLAGS="$CPPFLAGS $JAVA_CPPFLAGS"
  CFLAGS="$CFLAGS $JAVA_CFLAGS"
  LDFLAGS="$LDFLAGS $JAVA_LDFLAGS"
 +LIBS="$LIBS $JAVA_LIBS"
  
  if test "x$with_java" = "xyes"
  then
@@@ -2700,8 -2382,8 +2700,8 @@@ if test "x$with_java" = "xyes
  then
        AC_CHECK_LIB(jvm, JNI_CreateJavaVM,
        [with_java="yes"],
 -      [with_java="no (libjvm not found)"],
 -      [$JAVA_LIBS])
 +      [with_java="no (Symbol 'JNI_CreateJavaVM' not found)"],
 +      [$JAVA_LIBS $PTHREAD_LIBS])
  fi
  if test "x$with_java" = "xyes"
  then
  CPPFLAGS="$SAVE_CPPFLAGS"
  CFLAGS="$SAVE_CFLAGS"
  LDFLAGS="$SAVE_LDFLAGS"
 +LIBS="$SAVE_LIBS"
  
  AC_SUBST(JAVA_CPPFLAGS)
  AC_SUBST(JAVA_CFLAGS)
  AM_CONDITIONAL(BUILD_WITH_LIBLDAP, test "x$with_libldap" = "xyes")
  # }}}
  
 +# --with-liblua {{{
 +AC_ARG_VAR([LIBLUA_PKG_CONFIG_NAME], [Name of liblua used by pkg-config])
 +if test "x$LIBLUA_PKG_CONFIG_NAME" != "x"
 +then
 +  PKG_CHECK_MODULES([LUA], [$LIBLUA_PKG_CONFIG_NAME],
 +    [with_liblua="yes"],
 +    [with_liblua="no"]
 +  )
 +else
 +  PKG_CHECK_MODULES([LUA], [lua],
 +    [with_liblua="yes"],
 +    [
 +      PKG_CHECK_MODULES([LUA], [lua-5.3],
 +        [with_liblua="yes"],
 +        [
 +        PKG_CHECK_MODULES([LUA], [lua5.3],
 +            [with_liblua="yes"],
 +            [
 +              PKG_CHECK_MODULES([LUA], [lua-5.2],
 +                [with_liblua="yes"],
 +                [
 +                  PKG_CHECK_MODULES([LUA], [lua5.2],
 +                    [with_liblua="yes"],
 +                    [
 +                      PKG_CHECK_MODULES([LUA], [lua-5.1],
 +                        [with_liblua="yes"],
 +                        [
 +                          PKG_CHECK_MODULES([LUA], [lua5.1],
 +                            [with_liblua="yes"],
 +                            [with_liblua="no (pkg-config cannot find liblua)"]
 +                          )
 +                        ]
 +                      )
 +                    ]
 +                  )
 +                ]
 +              )
 +            ]
 +          )
 +        ]
 +      )
 +    ]
 +  )
 +fi
 +
 +if test "x$with_liblua" = "xyes"
 +then
 +  SAVE_CFLAGS="$CFLAGS"
 +  CFLAGS="$CFLAGS $LUA_CFLAGS"
 +
 +  AC_CHECK_HEADERS([lua.h lauxlib.h lualib.h],
 +    [with_liblua="yes"],
 +    [with_liblua="no (header not found)"]
 +  )
 +
 +  CFLAGS="$SAVE_CFLAGS"
 +fi
 +
 +if test "x$with_liblua" = "xyes"
 +then
 +  SAVE_LIBS="$LIBS"
 +  LIBS="$LIBS $LUA_LIBS"
 +
 +  AC_CHECK_FUNC([lua_settop],
 +    [with_liblua="yes"],
 +    [with_liblua="no (symbol 'lua_settop' not found)"]
 +  )
 +
 +  LIBS="$SAVE_LIBS"
 +fi
 +
 +if test "x$with_liblua" = "xyes"
 +then
 +    BUILD_WITH_LIBLUA_CFLAGS="$LUA_CFLAGS"
 +    BUILD_WITH_LIBLUA_LIBS="$LUA_LIBS"
 +fi
 +AC_SUBST(BUILD_WITH_LIBLUA_CFLAGS)
 +AC_SUBST(BUILD_WITH_LIBLUA_LIBS)
 +# }}}
 +
  # --with-liblvm2app {{{
  with_liblvm2app_cppflags=""
  with_liblvm2app_ldflags=""
  AC_ARG_WITH(liblvm2app, [AS_HELP_STRING([--with-liblvm2app@<:@=PREFIX@:>@], [Path to liblvm2app.])],
  [
 -        if test "x$withval" != "xno" && test "x$withval" != "xyes"
 -        then
 -                with_liblvm2app_cppflags="-I$withval/include"
 -                with_liblvm2app_ldflags="-L$withval/lib"
 -                with_liblvm2app="yes"
 -        else
 -                with_liblvm2app="$withval"
 +      if test "x$withval" = "xno"
 +      then
 +              with_liblvm2app="no"
 +      else
 +              with_liblvm2app="yes"
 +              if test "x$withval" != "xyes"
 +              then
 +                      with_liblvm2app_cppflags="-I$withval/include"
 +                      with_liblvm2app_ldflags="-L$withval/lib"
 +              fi
          fi
  ],
  [
 -        with_liblvm2app="yes"
 +      if test "x$ac_system" = "xLinux"
 +      then
 +              with_liblvm2app="yes"
 +      else
 +              with_liblvm2app="no (Linux only library)"
 +      fi
  ])
  if test "x$with_liblvm2app" = "xyes"
  then
@@@ -2995,6 -2588,13 +2995,6 @@@ AC_ARG_WITH(libmodbus, [AS_HELP_STRING(
  # configure using pkg-config
  if test "x$with_libmodbus" = "xuse_pkgconfig"
  then
 -      if test "x$PKG_CONFIG" = "x"
 -      then
 -              with_libmodbus="no (Don't have pkg-config)"
 -      fi
 -fi
 -if test "x$with_libmodbus" = "xuse_pkgconfig"
 -then
        AC_MSG_NOTICE([Checking for libmodbus using $PKG_CONFIG])
        $PKG_CONFIG --exists 'libmodbus' 2>/dev/null
        if test $? -ne 0
  AM_CONDITIONAL(BUILD_WITH_LIBMONGOC, test "x$with_libmongoc" = "xyes")
  # }}}
  
 -# --with-libmysql {{{
 -with_mysql_config="mysql_config"
 -with_mysql_cflags=""
 -with_mysql_libs=""
 -AC_ARG_WITH(libmysql, [AS_HELP_STRING([--with-libmysql@<:@=PREFIX@:>@], [Path to libmysql.])],
 +# --with-libmosquitto {{{
 +with_libmosquitto_cppflags=""
 +with_libmosquitto_ldflags=""
 +AC_ARG_WITH(libmosquitto, [AS_HELP_STRING([--with-libmosquitto@<:@=PREFIX@:>@], [Path to libmosquitto.])],
  [
 -      if test "x$withval" = "xno"
 -      then
 -              with_libmysql="no"
 -      else if test "x$withval" = "xyes"
 +      if test "x$withval" != "xno" && test "x$withval" != "xyes"
        then
 -              with_libmysql="yes"
 +              with_libmosquitto_cppflags="-I$withval/include"
 +              with_libmosquitto_ldflags="-L$withval/lib"
 +              with_libmosquitto="yes"
        else
 -              if test -f "$withval" && test -x "$withval";
 -              then
 -                      with_mysql_config="$withval"
 -              else if test -x "$withval/bin/mysql_config"
 -              then
 -                      with_mysql_config="$withval/bin/mysql_config"
 -              fi; fi
 -              with_libmysql="yes"
 +              with_libmosquitto="$withval"
 +      fi
 +],
 +[
 +      with_libmosquitto="yes"
 +])
 +if test "x$with_libmosquitto" = "xyes"
 +then
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      CPPFLAGS="$CPPFLAGS $with_libmosquitto_cppflags"
 +
 +      AC_CHECK_HEADERS(mosquitto.h, [with_libmosquitto="yes"], [with_libmosquitto="no (mosquitto.h not found)"])
 +
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +fi
 +if test "x$with_libmosquitto" = "xyes"
 +then
 +      SAVE_LDFLAGS="$LDFLAGS"
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      LDFLAGS="$LDFLAGS $with_libmosquitto_ldflags"
 +      CPPFLAGS="$CPPFLAGS $with_libmosquitto_cppflags"
 +
 +      AC_CHECK_LIB(mosquitto, mosquitto_connect, [with_libmosquitto="yes"], [with_libmosquitto="no (libmosquitto not found)"])
 +
 +      LDFLAGS="$SAVE_LDFLAGS"
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +fi
 +if test "x$with_libmosquitto" = "xyes"
 +then
 +      BUILD_WITH_LIBMOSQUITTO_CPPFLAGS="$with_libmosquitto_cppflags"
 +      BUILD_WITH_LIBMOSQUITTO_LDFLAGS="$with_libmosquitto_ldflags"
 +      BUILD_WITH_LIBMOSQUITTO_LIBS="-lmosquitto"
 +      AC_SUBST(BUILD_WITH_LIBMOSQUITTO_CPPFLAGS)
 +      AC_SUBST(BUILD_WITH_LIBMOSQUITTO_LDFLAGS)
 +      AC_SUBST(BUILD_WITH_LIBMOSQUITTO_LIBS)
 +fi
 +# }}}
 +
 +# --with-libmysql {{{
 +with_mysql_config="mysql_config"
 +with_mysql_cflags=""
 +with_mysql_libs=""
 +AC_ARG_WITH(libmysql, [AS_HELP_STRING([--with-libmysql@<:@=PREFIX@:>@], [Path to libmysql.])],
 +[
 +      if test "x$withval" = "xno"
 +      then
 +              with_libmysql="no"
 +      else if test "x$withval" = "xyes"
 +      then
 +              with_libmysql="yes"
 +      else
 +              if test -f "$withval" && test -x "$withval";
 +              then
 +                      with_mysql_config="$withval"
 +              else if test -x "$withval/bin/mysql_config"
 +              then
 +                      with_mysql_config="$withval/bin/mysql_config"
 +              fi; fi
 +              with_libmysql="yes"
        fi; fi
  ],
  [
@@@ -3285,6 -2836,10 +3285,6 @@@ AC_ARG_WITH(libmnl, [AS_HELP_STRING([--
         with_libmnl="no (Linux only library)"
   fi
  ])
 -if test "x$PKG_CONFIG" = "x"
 -then
 -      with_libmnl="no (Don't have pkg-config)"
 -fi
  if test "x$with_libmnl" = "xyes"
  then
        if $PKG_CONFIG --exists libmnl 2>/dev/null; then
@@@ -3415,7 -2970,7 +3415,7 @@@ the
  
        if test "x$LIBNETAPP_LIBS" = "x"
        then
 -              LIBNETAPP_LIBS="-lpthread -lxml -ladt -lssl -lm -lcrypto -lz"
 +              LIBNETAPP_LIBS="$PTHREAD_LIBS -lxml -ladt -lssl -lm -lcrypto -lz"
        fi
        AC_MSG_NOTICE([netapp LIBS: $LIBNETAPP_LIBS])
  
@@@ -3441,6 -2996,9 +3441,6 @@@ AM_CONDITIONAL(BUILD_WITH_LIBNETAPP, te
  # }}}
  
  # --with-libnetsnmp {{{
 -with_snmp_config="net-snmp-config"
 -with_snmp_cflags=""
 -with_snmp_libs=""
  AC_ARG_WITH(libnetsnmp, [AS_HELP_STRING([--with-libnetsnmp@<:@=PREFIX@:>@], [Path to the Net-SNMPD library.])],
  [
        if test "x$withval" = "xno"
        then
                with_libnetsnmp="yes"
        else
 -              if test -x "$withval"
 -              then
 -                      with_snmp_config="$withval"
 -                      with_libnetsnmp="yes"
 -              else
 -                      with_snmp_config="$withval/bin/net-snmp-config"
 -                      with_libnetsnmp="yes"
 -              fi
 +              with_libnetsnmp_cppflags="-I$withval/include"
 +              with_libnetsnmp_ldflags="-I$withval/lib"
 +              with_libnetsnmp="yes"
        fi; fi
  ],
  [with_libnetsnmp="yes"])
  if test "x$with_libnetsnmp" = "xyes"
  then
 -      with_snmp_cflags=`$with_snmp_config --cflags 2>/dev/null`
 -      snmp_config_status=$?
 -
 -      if test $snmp_config_status -ne 0
 -      then
 -              with_libnetsnmp="no ($with_snmp_config failed)"
 -      else
 -              SAVE_CPPFLAGS="$CPPFLAGS"
 -              CPPFLAGS="$CPPFLAGS $with_snmp_cflags"
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      CPPFLAGS="$CPPFLAGS $with_libnetsnmp_cppflags"
  
 -              AC_CHECK_HEADERS(net-snmp/net-snmp-config.h, [], [with_libnetsnmp="no (net-snmp/net-snmp-config.h not found)"])
 +      AC_CHECK_HEADERS(net-snmp/net-snmp-config.h, [], [with_libnetsnmp="no (net-snmp/net-snmp-config.h not found)"])
  
 -              CPPFLAGS="$SAVE_CPPFLAGS"
 -      fi
 +      CPPFLAGS="$SAVE_CPPFLAGS"
  fi
  if test "x$with_libnetsnmp" = "xyes"
  then
 -      with_snmp_libs=`$with_snmp_config --libs 2>/dev/null`
 -      snmp_config_status=$?
 +      SAVE_LDFLAGS="$LDFLAGS"
 +      LDFLAGS="$LDFLAGS $with_libnetsnmp_ldflags"
  
 -      if test $snmp_config_status -ne 0
 -      then
 -              with_libnetsnmp="no ($with_snmp_config failed)"
 -      else
 -              AC_CHECK_LIB(netsnmp, init_snmp,
 +      AC_CHECK_LIB(netsnmp, init_snmp,
                [with_libnetsnmp="yes"],
                [with_libnetsnmp="no (libnetsnmp not found)"],
                [$with_snmp_libs])
 -      fi
 +
 +      LDFLAGS="$SAVE_LDFLAGS"
  fi
  if test "x$with_libnetsnmp" = "xyes"
  then
 -      BUILD_WITH_LIBSNMP_CFLAGS="$with_snmp_cflags"
 -      BUILD_WITH_LIBSNMP_LIBS="$with_snmp_libs"
 -      AC_SUBST(BUILD_WITH_LIBSNMP_CFLAGS)
 -      AC_SUBST(BUILD_WITH_LIBSNMP_LIBS)
 +      BUILD_WITH_LIBNETSNMP_CPPFLAGS="$with_libnetsnmp_cppflags"
 +      BUILD_WITH_LIBNETSNMP_LDFLAGS="$with_libnetsnmp_ldflags"
 +      BUILD_WITH_LIBNETSNMP_LIBS="-lnetsnmp"
  fi
 -AM_CONDITIONAL(BUILD_WITH_LIBNETSNMP, test "x$with_libnetsnmp" = "xyes")
 +AC_SUBST(BUILD_WITH_LIBNETSNMP_CPPFLAGS)
 +AC_SUBST(BUILD_WITH_LIBNETSNMP_LDFLAGS)
 +AC_SUBST(BUILD_WITH_LIBNETSNMP_LIBS)
  # }}}
  
  # --with-liboconfig {{{
@@@ -3518,7 -3091,7 +3518,7 @@@ save_LDFLAGS="$LDFLAGS
  save_CPPFLAGS="$CPPFLAGS"
  LDFLAGS="$liboconfig_LDFLAGS"
  CPPFLAGS="$liboconfig_CPPFLAGS"
 -AC_CHECK_LIB(oconfig, oconfig_parse_fh,
 +AC_CHECK_LIB(oconfig, oconfig_parse_file,
  [
        with_liboconfig="yes"
        with_own_liboconfig="no"
  fi
  if test "x$with_oracle" = "xyes"
  then
 -      BUILD_WITH_ORACLE_CFLAGS="$with_oracle_cppflags"
 +      BUILD_WITH_ORACLE_CPPFLAGS="$with_oracle_cppflags"
        BUILD_WITH_ORACLE_LIBS="$with_oracle_libs"
 -      AC_SUBST(BUILD_WITH_ORACLE_CFLAGS)
 +      AC_SUBST(BUILD_WITH_ORACLE_CPPFLAGS)
        AC_SUBST(BUILD_WITH_ORACLE_LIBS)
  fi
  # }}}
  
  # --with-libowcapi {{{
  with_libowcapi_cppflags=""
 -with_libowcapi_libs="-lowcapi"
 +with_libowcapi_ldflags=""
  AC_ARG_WITH(libowcapi, [AS_HELP_STRING([--with-libowcapi@<:@=PREFIX@:>@], [Path to libowcapi.])],
  [
        if test "x$withval" != "xno" && test "x$withval" != "xyes"
        then
                with_libowcapi_cppflags="-I$withval/include"
 -              with_libowcapi_libs="-L$withval/lib -lowcapi"
 +              with_libowcapi_ldflags="-L$withval/lib"
                with_libowcapi="yes"
        else
                with_libowcapi="$withval"
  if test "x$with_libowcapi" = "xyes"
  then
        SAVE_CPPFLAGS="$CPPFLAGS"
 -      CPPFLAGS="$with_libowcapi_cppflags"
 +      CPPFLAGS="$CPPFLAGS $with_libowcapi_cppflags"
  
        AC_CHECK_HEADERS(owcapi.h, [with_libowcapi="yes"], [with_libowcapi="no (owcapi.h not found)"])
  
@@@ -3693,7 -3266,7 +3693,7 @@@ if test "x$with_libowcapi" = "xyes
  then
        SAVE_LDFLAGS="$LDFLAGS"
        SAVE_CPPFLAGS="$CPPFLAGS"
 -      LDFLAGS="$with_libowcapi_libs"
 +      LDFLAGS="$LDFLAGS $with_libowcapi_ldflags"
        CPPFLAGS="$with_libowcapi_cppflags"
  
        AC_CHECK_LIB(owcapi, OW_get, [with_libowcapi="yes"], [with_libowcapi="no (libowcapi not found)"])
  if test "x$with_libowcapi" = "xyes"
  then
        BUILD_WITH_LIBOWCAPI_CPPFLAGS="$with_libowcapi_cppflags"
 -      BUILD_WITH_LIBOWCAPI_LIBS="$with_libowcapi_libs"
 +      BUILD_WITH_LIBOWCAPI_LDFLAGS="$with_libowcapi_ldflags"
 +      BUILD_WITH_LIBOWCAPI_LIBS="-lowcapi"
        AC_SUBST(BUILD_WITH_LIBOWCAPI_CPPFLAGS)
 +      AC_SUBST(BUILD_WITH_LIBOWCAPI_LDFLAGS)
        AC_SUBST(BUILD_WITH_LIBOWCAPI_LIBS)
  fi
  # }}}
@@@ -3802,7 -3373,7 +3802,7 @@@ the
    SAVE_CFLAGS="$CFLAGS"
    SAVE_LIBS="$LIBS"
  dnl ARCHFLAGS="" -> disable multi -arch on OSX (see Config_heavy.pl:fetch_string)
 -  PERL_CFLAGS=`ARCHFLAGS="" $perl_interpreter -MExtUtils::Embed -e ccopts`
 +  PERL_CFLAGS=`ARCHFLAGS="" $perl_interpreter -MExtUtils::Embed -e perl_inc`
    PERL_LIBS=`ARCHFLAGS="" $perl_interpreter -MExtUtils::Embed -e ldopts`
    CFLAGS="$CFLAGS $PERL_CFLAGS"
    LIBS="$LIBS $PERL_LIBS"
  AM_CONDITIONAL(BUILD_WITH_LIBPQ, test "x$with_libpq" = "xyes")
  # }}}
  
 -# --with-libpthread {{{
 -AC_ARG_WITH(libpthread, [AS_HELP_STRING([--with-libpthread=@<:@=PREFIX@:>@], [Path to libpthread.])],
 -[     if test "x$withval" != "xno" \
 -              && test "x$withval" != "xyes"
 -      then
 -              LDFLAGS="$LDFLAGS -L$withval/lib"
 -              CPPFLAGS="$CPPFLAGS -I$withval/include"
 -              with_libpthread="yes"
 -      else
 -              if test "x$withval" = "xno"
 -              then
 -                      with_libpthread="no (disabled)"
 -              fi
 -      fi
 -], [with_libpthread="yes"])
 -if test "x$with_libpthread" = "xyes"
 +# --with-libprotobuf {{{
 +with_libprotobuf_cppflags=""
 +with_libprotobuf_ldflags=""
 +AC_ARG_WITH([libprotobuf], [AS_HELP_STRING([--with-libprotobuf@<:@=PREFIX@:>@], [Path to libprotobuf.])],
 +  [
 +    if test "x$withval" != "xno" && test "x$withval" != "xyes"
 +    then
 +      with_libprotobuf_cppflags="-I$withval/include"
 +      with_libprotobuf_ldflags="-L$withval/lib"
 +      with_libprotobuf="yes"
 +    fi
 +    if test "x$withval" = "xno"
 +    then
 +      with_libprotobuf="no (disabled on command line)"
 +    fi
 +  ],
 +  [withval="yes"]
 +)
 +if test "x$withval" = "xyes"
  then
 -      AC_CHECK_LIB(pthread, pthread_create, [with_libpthread="yes"], [with_libpthread="no (libpthread not found)"], [])
 +PKG_CHECK_MODULES([PROTOBUF], [protobuf],
 +  [with_libprotobuf="yes"],
 +  [with_libprotobuf="no (pkg-config could not find libprotobuf)"]
 +)
  fi
  
 -if test "x$with_libpthread" = "xyes"
 -then
 -      AC_CHECK_HEADERS(pthread.h,, [with_libpthread="no (pthread.h not found)"])
 -fi
 -if test "x$with_libpthread" = "xyes"
 +if test "x$withval" != "xno"
  then
 -      collect_pthread=1
 -else
 -      collect_pthread=0
 +  SAVE_LDFLAGS="$LDFLAGS"
 +  SAVE_LIBS="$LIBS"
 +  LDFLAGS="$with_libprotobuf_ldflags"
 +  LIBS="$PROTOBUF_LIBS $LIBS"
 +  AC_LANG_PUSH([C++])
 +  AC_CHECK_LIB([protobuf], [main],
 +    [
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      CPPFLAGS="$with_libprotobuf_cppflags $PROTOBUF_CFLAGS"
 +      if test "x$PROTOBUF_LIBS" = "x"
 +      then
 +        PROTOBUF_LIBS="-lprotobuf"
 +      fi
 +      AC_CHECK_HEADERS([google/protobuf/util/time_util.h],
 +        [with_libprotobuf="yes"],
 +        [with_libprotobuf="no (<google/protobuf/util/time_util.h> not found)"]
 +      )
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +    ],
 +    [with_libprotobuf="no (libprotobuf not found)"]
 +  )
 +  AC_LANG_POP([C++])
 +  LDFLAGS="$SAVE_LDFLAGS"
 +  LIBS="$SAVE_LIBS"
  fi
 -AC_DEFINE_UNQUOTED(HAVE_LIBPTHREAD, [$collect_pthread],
 -      [Wether or not to use pthread (POSIX threads) library])
 -AM_CONDITIONAL(BUILD_WITH_LIBPTHREAD, test "x$with_libpthread" = "xyes")
 +BUILD_WITH_LIBPROTOBUF_CPPFLAGS="$with_libprotobuf_cppflags $PROTOBUF_CFLAGS"
 +BUILD_WITH_LIBPROTOBUF_LDFLAGS="$with_libprotobuf_ldflags"
 +BUILD_WITH_LIBPROTOBUF_LIBS="$PROTOBUF_LIBS"
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_CPPFLAGS])
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_LDFLAGS])
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_LIBS])
  # }}}
  
 -# --with-python {{{
 -with_python_prog=""
 -with_python_path="$PATH"
 -AC_ARG_WITH(python, [AS_HELP_STRING([--with-python@<:@=PREFIX@:>@], [Path to the python interpreter.])],
 -[
 - if test "x$withval" = "xyes" || test "x$withval" = "xno"
 - then
 -       with_python="$withval"
 - else if test -x "$withval"
 - then
 -       with_python_prog="$withval"
 -       with_python_path="`dirname \"$withval\"`$PATH_SEPARATOR$with_python_path"
 -       with_python="yes"
 - else if test -d "$withval"
 - then
 -       with_python_path="$withval$PATH_SEPARATOR$with_python_path"
 -       with_python="yes"
 - else
 -       AC_MSG_WARN([Argument not recognized: $withval])
 - fi; fi; fi
 -], [with_python="yes"])
 -
 -SAVE_PATH="$PATH"
 -SAVE_CPPFLAGS="$CPPFLAGS"
 -SAVE_LDFLAGS="$LDFLAGS"
 -SAVE_LIBS="$LIBS"
 -
 -PATH="$with_python_path"
 -
 -if test "x$with_python" = "xyes" && test "x$with_python_prog" = "x"
 -then
 -      AC_MSG_CHECKING([for python])
 -      with_python_prog="`which python 2>/dev/null`"
 -      if test "x$with_python_prog" = "x"
 -      then
 -              AC_MSG_RESULT([not found])
 -              with_python="no (interpreter not found)"
 -      else
 -              AC_MSG_RESULT([$with_python_prog])
 -      fi
 -fi
 -
 -if test "x$with_python" = "xyes"
 -then
 -      AC_MSG_CHECKING([for Python CPPFLAGS])
 -      python_include_path=`echo "import distutils.sysconfig;import sys;sys.stdout.write(distutils.sysconfig.get_python_inc())" | "$with_python_prog" 2>&1`
 -      python_config_status=$?
 -
 -      if test "$python_config_status" -ne 0 || test "x$python_include_path" = "x"
 -      then
 -              AC_MSG_RESULT([failed with status $python_config_status (output: $python_include_path)])
 -              with_python="no"
 -      else
 -              AC_MSG_RESULT([$python_include_path])
 -      fi
 -fi
 -
 -if test "x$with_python" = "xyes"
 +# --with-libprotobuf-c {{{
 +with_libprotobuf_c_cppflags=""
 +with_libprotobuf_c_ldflags=""
 +AC_ARG_WITH([libprotobuf-c], [AS_HELP_STRING([--with-libprotobuf-c@<:@=PREFIX@:>@], [Path to libprotobuf-c.])],
 +  [
 +    if test "x$withval" != "xno" && test "x$withval" != "xyes"
 +    then
 +      with_libprotobuf_c_cppflags="-I$withval/include"
 +      with_libprotobuf_c_ldflags="-L$withval/lib"
 +      with_libprotobuf_c="yes"
 +    fi
 +    if test "x$withval" = "xno"
 +    then
 +      with_libprotobuf_c="no (disabled on command line)"
 +    fi
 +  ],
 +  [withval="yes"]
 +)
 +if test "x$withval" = "xyes"
  then
 -      CPPFLAGS="-I$python_include_path $CPPFLAGS"
 -      AC_CHECK_HEADERS(Python.h,
 -                       [with_python="yes"],
 -                       [with_python="no ('Python.h' not found)"])
 +PKG_CHECK_MODULES([PROTOBUF_C], [libprotobuf-c],
 +  [with_libprotobuf_c="yes"],
 +  [with_libprotobuf_c="no (pkg-config could not find libprotobuf-c)"]
 +)
  fi
  
 -if test "x$with_python" = "xyes"
 +if test "x$withval" != "xno"
  then
 -      AC_MSG_CHECKING([for Python LDFLAGS])
 -      python_library_path=`echo "import distutils.sysconfig;import sys;sys.stdout.write(distutils.sysconfig.get_config_vars(\"LIBDIR\").__getitem__(0))" | "$with_python_prog" 2>&1`
 -      python_config_status=$?
 -
 -      if test "$python_config_status" -ne 0 || test "x$python_library_path" = "x"
 -      then
 -              AC_MSG_RESULT([failed with status $python_config_status (output: $python_library_path)])
 -              with_python="no"
 -      else
 -              AC_MSG_RESULT([$python_library_path])
 -      fi
 +  SAVE_LDFLAGS="$LDFLAGS"
 +  SAVE_LIBS="$LIBS"
 +  LDFLAGS="$with_libprotobuf_c_ldflags"
 +  LIBS="$PROTOBUF_C_LIBS $LIBS"
 +  AC_CHECK_LIB([protobuf-c], [protobuf_c_message_pack],
 +    [
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      CPPFLAGS="$with_libprotobuf_c_cppflags $PROTOBUF_C_CFLAGS"
 +      if test "x$PROTOBUF_C_LIBS" = "x"
 +      then
 +        PROTOBUF_C_LIBS="-lprotobuf-c"
 +      fi
 +      AC_CHECK_HEADERS([protobuf-c/protobuf-c.h google/protobuf-c/protobuf-c.h],
 +        [
 +          with_libprotobuf_c="yes"
 +          break
 +        ],
 +        [with_libprotobuf_c="no (<protobuf-c.h> not found)"]
 +      )
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +    ],
 +    [with_libprotobuf_c="no (libprotobuf-c not found)"]
 +  )
 +  LDFLAGS="$SAVE_LDFLAGS"
 +  LIBS="$SAVE_LIBS"
  fi
 +BUILD_WITH_LIBPROTOBUF_C_CPPFLAGS="$with_libprotobuf_c_cppflags $PROTOBUF_C_CFLAGS"
 +BUILD_WITH_LIBPROTOBUF_C_LDFLAGS="$with_libprotobuf_c_ldflags"
 +BUILD_WITH_LIBPROTOBUF_C_LIBS="$PROTOBUF_C_LIBS"
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_C_CPPFLAGS])
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_C_LDFLAGS])
 +AC_SUBST([BUILD_WITH_LIBPROTOBUF_C_LIBS])
 +# }}}
  
 -if test "x$with_python" = "xyes"
 -then
 -      AC_MSG_CHECKING([for Python LIBS])
 -      python_library_flags=`echo "import distutils.sysconfig;import sys;sys.stdout.write(distutils.sysconfig.get_config_vars(\"BLDLIBRARY\").__getitem__(0))" | "$with_python_prog" 2>&1`
 -      python_config_status=$?
 +# --with-libpython {{{
 +AC_ARG_VAR([LIBPYTHON_CPPFLAGS], [Preprocessor flags for libpython])
 +AC_ARG_VAR([LIBPYTHON_LDFLAGS], [Linker flags for libpython])
 +AC_ARG_VAR([LIBPYTHON_LIBS], [Libraries for libpython])
  
 -      if test "$python_config_status" -ne 0 || test "x$python_library_flags" = "x"
 -      then
 -              AC_MSG_RESULT([failed with status $python_config_status (output: $python_library_flags)])
 -              with_python="no"
 -      else
 -              AC_MSG_RESULT([$python_library_flags])
 -      fi
 +AC_ARG_WITH([libpython],
 +  [AS_HELP_STRING([--with-libpython],
 +    [if we should build with libpython @<:@default=yes@:>@])
 +  ],
 +  [with_libpython="$withval"],
 +  [with_libpython="check"]
 +)
 +if test "$with_libpython" != "no"; then
 +  if test "$LIBPYTHON_CPPFLAGS" = "" && test "$LIBPYTHON_LDFLAGS" = ""; then
 +    AC_ARG_VAR([PYTHON_CONFIG], [path to python-config])
 +    AC_PATH_PROGS([PYTHON_CONFIG],
 +      [python3-config python2-config python-config]
 +    )
 +    if test "$PYTHON_CONFIG" = ""; then
 +      if test "$with_libpython" = "yes"; then
 +        AC_MSG_ERROR([Unable to find python-config])
 +      fi
 +      with_libpython="no"
 +    fi
 +  fi
  fi
  
 -if test "x$with_python" = "xyes"
 -then
 -      LDFLAGS="-L$python_library_path $LDFLAGS"
 -      LIBS="$python_library_flags $LIBS"
 -
 -      AC_CHECK_FUNC(PyObject_CallFunction,
 -                    [with_python="yes"],
 -                    [with_python="no (Symbol 'PyObject_CallFunction' not found)"])
 +if test "$PYTHON_CONFIG" != ""; then
 +  LIBPYTHON_CPPFLAGS="`${PYTHON_CONFIG} --includes`"
 +  if test $? -ne 0; then
 +    with_libpython="no"
 +  fi
 +  LIBPYTHON_LDFLAGS="`${PYTHON_CONFIG} --ldflags`"
 +  if test $? -ne 0; then
 +    with_libpython="no"
 +  fi
 +  LIBPYTHON_LIBS="`${PYTHON_CONFIG} --libs`"
 +  if test $? -ne 0; then
 +    with_libpython="no"
 +  fi
  fi
  
 -PATH="$SAVE_PATH"
 -CPPFLAGS="$SAVE_CPPFLAGS"
 -LDFLAGS="$SAVE_LDFLAGS"
 -LIBS="$SAVE_LIBS"
 -
 -if test "x$with_python" = "xyes"
 -then
 -      BUILD_WITH_PYTHON_CPPFLAGS="-I$python_include_path"
 -      BUILD_WITH_PYTHON_LDFLAGS="-L$python_library_path"
 -      BUILD_WITH_PYTHON_LIBS="$python_library_flags"
 -      AC_SUBST(BUILD_WITH_PYTHON_CPPFLAGS)
 -      AC_SUBST(BUILD_WITH_PYTHON_LDFLAGS)
 -      AC_SUBST(BUILD_WITH_PYTHON_LIBS)
 +if test "$with_libpython" != "xno"; then
 +  SAVE_CPPFLAGS="$CPPFLAGS"
 +  SAVE_LDFLAGS="$LDFLAGS"
 +  SAVE_LIBS="$LIBS"
 +  CPPFLAGS="$LIBPYTHON_CPPFLAGS $CPPFLAGS"
 +  LDFLAGS="$LIBPYTHON_LDFLAGS $LDFLAGS"
 +  LIBS="$LIBPYTHON_LIBS $LIBS"
 +  AC_CHECK_HEADERS([Python.h],
 +    [
 +      AC_MSG_CHECKING([for libpython])
 +      AC_LINK_IFELSE([AC_LANG_PROGRAM(
 +          [[#include <Python.h>]],
 +          [[Py_Initialize();]])
 +        ],
 +        [with_libpython="yes"],
 +        [with_libpython="no"]
 +      )
 +      AC_MSG_RESULT([$with_libpython])
 +    ],
 +    [with_libpython="no"]
 +  )
 +  CPPFLAGS="$SAVE_CPPFLAGS"
 +  LDFLAGS="$SAVE_LDFLAGS"
 +  LIBS="$SAVE_LIBS"
  fi
 -# }}} --with-python
 +# }}} --with-libpython
  
  # --with-librabbitmq {{{
  with_librabbitmq_cppflags=""
@@@ -4579,6 -4114,11 +4579,6 @@@ the
        SAVE_CPPFLAGS="$CPPFLAGS"
        CPPFLAGS="$CPPFLAGS $with_sensors_cflags"
  
 -#     AC_CHECK_HEADERS(sensors/sensors.h,
 -#     [
 -#             AC_DEFINE(HAVE_SENSORS_SENSORS_H, 1, [Define to 1 if you have the <sensors/sensors.h> header file.])
 -#     ],
 -#     [with_libsensors="no (sensors/sensors.h not found)"])
        AC_CHECK_HEADERS(sensors/sensors.h, [], [with_libsensors="no (sensors/sensors.h not found)"])
  
        CPPFLAGS="$SAVE_CPPFLAGS"
  AM_CONDITIONAL(BUILD_WITH_LM_SENSORS, test "x$with_libsensors" = "xyes")
  # }}}
  
 -# --with-libsigrok {{{
 -with_libsigrok_cflags=""
 -with_libsigrok_ldflags=""
 -AC_ARG_WITH(libsigrok, [AS_HELP_STRING([--with-libsigrok@<:@=PREFIX@:>@], [Path to libsigrok.])],
 -[
 -      if test "x$withval" = "xno"
 -      then
 -              with_libsigrok="no"
 -      else
 -              with_libsigrok="yes"
 -              if test "x$withval" != "xyes"
 -              then
 -                      with_libsigrok_cflags="-I$withval/include"
 -                      with_libsigrok_ldflags="-L$withval/lib"
 -              fi
 -      fi
 -],[with_libsigrok="yes"])
 -
 -# libsigrok has a glib dependency
 -if test "x$with_libsigrok" = "xyes"
 -then
 -m4_ifdef([AM_PATH_GLIB_2_0],
 -      [
 -       AM_PATH_GLIB_2_0([2.28.0],
 -              [with_libsigrok_cflags="$with_libsigrok_cflags $GLIB_CFLAGS"; with_libsigrok_ldflags="$with_libsigrok_ldflags $GLIB_LIBS"])
 -      ],
 -      [
 -       with_libsigrok="no (glib not available)"
 -      ]
 +# libsigrok {{{
 +AC_SUBST([LIBSIGROK_CFLAGS])
 +AC_SUBST([LIBSIGROK_LIBS])
 +PKG_CHECK_MODULES([LIBSIGROK], [libsigrok < 0.4],
 +  [with_libsigrok="yes"],
 +  [with_libsigrok="no (pkg-config could not find libsigrok)"]
  )
 -fi
 -
 -# libsigrok headers
 -if test "x$with_libsigrok" = "xyes"
 -then
 -      SAVE_CPPFLAGS="$CPPFLAGS"
 -      CPPFLAGS="$CPPFLAGS $with_libsigrok_cflags"
 -
 -      AC_CHECK_HEADERS(libsigrok/libsigrok.h, [], [with_libsigrok="no (libsigrok/libsigrok.h not found)"])
 -
 -      CPPFLAGS="$SAVE_CPPFLAGS"
 -fi
 -
 -# libsigrok library
 -if test "x$with_libsigrok" = "xyes"
 -then
 -      SAVE_CPPFLAGS="$CPPFLAGS"
 -      SAVE_LDFLAGS="$LDFLAGS"
 -      CPPFLAGS="$CPPFLAGS $with_libsigrok_cflags"
 -      LDFLAGS="$LDFLAGS $with_libsigrok_ldflags"
 -
 -      AC_CHECK_LIB(sigrok, sr_init,
 -      [
 -              AC_DEFINE(HAVE_LIBSIGROK, 1, [Define to 1 if you have the sigrok library (-lsigrok).])
 -      ],
 -      [with_libsigrok="no (libsigrok not found)"])
 -
 -      CPPFLAGS="$SAVE_CPPFLAGS"
 -      LDFLAGS="$SAVE_LDFLAGS"
 -fi
 -if test "x$with_libsigrok" = "xyes"
 -then
 -      BUILD_WITH_LIBSIGROK_CFLAGS="$with_libsigrok_cflags"
 -      BUILD_WITH_LIBSIGROK_LDFLAGS="$with_libsigrok_ldflags"
 -      AC_SUBST(BUILD_WITH_LIBSIGROK_CFLAGS)
 -      AC_SUBST(BUILD_WITH_LIBSIGROK_LDFLAGS)
 -fi
 -AM_CONDITIONAL(BUILD_WITH_LIBSIGROK, test "x$with_libsigrok" = "xyes")
  # }}}
  
  # --with-libstatgrab {{{
@@@ -4643,16 -4244,23 +4643,16 @@@ AC_ARG_WITH(libstatgrab, [AS_HELP_STRIN
  if test "x$with_libstatgrab" = "xyes" \
    && test "x$with_libstatgrab_pkg_config" = "xyes"
  then
 -  if test "x$PKG_CONFIG" != "x"
 +  AC_MSG_CHECKING([pkg-config for libstatgrab])
 +  temp_result="found"
 +  $PKG_CONFIG --exists libstatgrab 2>/dev/null
 +  if test "$?" != "0"
    then
 -    AC_MSG_CHECKING([pkg-config for libstatgrab])
 -    temp_result="found"
 -    $PKG_CONFIG --exists libstatgrab 2>/dev/null
 -    if test "$?" != "0"
 -    then
 -      with_libstatgrab_pkg_config="no"
 -      with_libstatgrab="no (pkg-config doesn't know libstatgrab)"
 -      temp_result="not found"
 -    fi
 -    AC_MSG_RESULT([$temp_result])
 -  else
 -    AC_MSG_NOTICE([pkg-config not available, trying to guess flags for the statgrab library.])
      with_libstatgrab_pkg_config="no"
 -    with_libstatgrab_ldflags="$with_libstatgrab_ldflags -lstatgrab"
 +    with_libstatgrab="no (pkg-config doesn't know libstatgrab)"
 +    temp_result="not found"
    fi
 +  AC_MSG_RESULT([$temp_result])
  fi
  
  if test "x$with_libstatgrab" = "xyes" \
  if test "x$with_libstatgrab" = "xyes"
  then
    SAVE_CFLAGS="$CFLAGS"
 +  SAVE_LDFLAGS="$LDFLAGS"
    SAVE_LIBS="$LIBS"
  
    CFLAGS="$CFLAGS $with_libstatgrab_cflags"
  # configure using pkg-config
  if test "x$with_libupsclient" = "xuse_pkgconfig"
  then
 -      if test "x$PKG_CONFIG" = "x"
 -      then
 -              with_libupsclient="no (Don't have pkg-config)"
 -      fi
 -fi
 -if test "x$with_libupsclient" = "xuse_pkgconfig"
 -then
        AC_MSG_NOTICE([Checking for libupsclient using $PKG_CONFIG])
        $PKG_CONFIG --exists 'libupsclient' 2>/dev/null
        if test $? -ne 0
  fi
  # }}}
  
 +# --with-libxenctrl {{{
 +with_libxenctrl_cppflags=""
 +with_libxenctrl_ldflags=""
 +AC_ARG_WITH(libxenctrl, [AS_HELP_STRING([--with-libxenctrl@<:@=PREFIX@:>@], [Path to libxenctrl.])],
 +[
 +      if test "x$withval" != "xno" && test "x$withval" != "xyes"
 +      then
 +              with_libxenctrl_cppflags="-I$withval/include"
 +              with_libxenctrl_ldflags="-L$withval/lib"
 +              with_libxenctrl="yes"
 +      else
 +              with_libxenctrl="$withval"
 +      fi
 +],
 +[
 +      with_libxenctrl="yes"
 +])
 +if test "x$with_libxenctrl" = "xyes"
 +then
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      CPPFLAGS="$CPPFLAGS $with_libxenctrl_cppflags"
 +
 +      AC_CHECK_HEADERS(xenctrl.h, [with_libxenctrl="yes"], [with_libxenctrl="no (xenctrl.h not found)"])
 +
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +fi
 +if test "x$with_libxenctrl" = "xyes"
 +then
 +      SAVE_CPPFLAGS="$CPPFLAGS"
 +      SAVE_LDFLAGS="$LDFLAGS"
 +      CPPFLAGS="$CPPFLAGS $with_libxenctrl_cppflags"
 +      LDFLAGS="$LDFLAGS $with_libxenctrl_ldflags"
 +
 +      #Xen versions older than 3.4 has no xc_getcpuinfo()
 +      AC_CHECK_LIB(xenctrl, xc_getcpuinfo, [with_libxenctrl="yes"], [with_libxenctrl="no (symbol 'xc_getcpuinfo' not found)"], [])
 +
 +      CPPFLAGS="$SAVE_CPPFLAGS"
 +      LDFLAGS="$SAVE_LDFLAGS"
 +      LIBXENCTL_CPPFLAGS="$with_libxenctl_cppflags"
 +      LIBXENCTL_LDFLAGS="$with_libxenctl_ldflags"
 +      AC_SUBST(LIBXENCTL_CPPFLAGS)
 +      AC_SUBST(LIBXENCTL_LDFLAGS)
 +fi
 +# }}}
 +
  # --with-libxmms {{{
  with_xmms_config="xmms-config"
  with_xmms_cflags=""
@@@ -5207,7 -4776,7 +5207,7 @@@ AC_ARG_WITH(mic,[AS_HELP_STRING([--with
                AC_MSG_NOTICE([Not checking for Intel Mic: Manually configured])
                with_mic_cflags="-I$withval/include"
                with_mic_ldpath="-L$withval/lib/Linux"
 -              with_mic_libs="-lMicAccessSDK -lscif -lpthread"
 +              with_mic_libs="$PTHREAD_LIBS -lMicAccessSDK -lscif"
                with_mic="yes"
        fi; fi; fi
  ],
@@@ -5229,8 -4798,8 +5229,8 @@@ the
  
        AC_CHECK_LIB(MicAccessSDK, MicInitAPI,
                        [with_mic_ldpath="$with_mic_ldpath"
 -                      with_mic_libs="-lMicAccessSDK -lscif -lpthread"],
 -                      [with_mic="no (symbol MicInitAPI not found)"],[-lscif -lpthread])
 +                      with_mic_libs="$PTHREAD_LIBS -lMicAccessSDK -lscif"],
 +                      [with_mic="no (symbol MicInitAPI not found)"],[$PTHREAD_LIBS -lscif])
  
        CPPFLAGS="$SAVE_CPPFLAGS"
        LDFLAGS="$SAVE_LDFLAGS"
@@@ -5272,6 -4841,13 +5272,6 @@@ AC_ARG_WITH(libvarnish, [AS_HELP_STRING
  # configure using pkg-config
  if test "x$with_libvarnish" = "xuse_pkgconfig"
  then
 -      if test "x$PKG_CONFIG" = "x"
 -      then
 -              with_libvarnish="no (Don't have pkg-config)"
 -      fi
 -fi
 -if test "x$with_libvarnish" = "xuse_pkgconfig"
 -then
        AC_MSG_NOTICE([Checking for varnishapi using $PKG_CONFIG])
        $PKG_CONFIG --exists 'varnishapi' 2>/dev/null
        if test $? -ne 0
@@@ -5331,20 -4907,23 +5331,20 @@@ with_libxml2_ldflags="
  with_libvirt="no (pkg-config isn't available)"
  with_libvirt_cflags=""
  with_libvirt_ldflags=""
 -if test "x$PKG_CONFIG" != "x"
 +$PKG_CONFIG --exists 'libxml-2.0' 2>/dev/null
 +if test "$?" = "0"
  then
 -      $PKG_CONFIG --exists 'libxml-2.0' 2>/dev/null
 -      if test "$?" = "0"
 -      then
 -              with_libxml2="yes"
 -      else
 -              with_libxml2="no (pkg-config doesn't know libxml-2.0)"
 -      fi
 +      with_libxml2="yes"
 +else
 +      with_libxml2="no (pkg-config doesn't know libxml-2.0)"
 +fi
  
 -      $PKG_CONFIG --exists libvirt 2>/dev/null
 -      if test "$?" = "0"
 -      then
 -              with_libvirt="yes"
 -      else
 -              with_libvirt="no (pkg-config doesn't know libvirt)"
 -      fi
 +$PKG_CONFIG --exists libvirt 2>/dev/null
 +if test "$?" = "0"
 +then
 +      with_libvirt="yes"
 +else
 +      with_libvirt="no (pkg-config doesn't know libvirt)"
  fi
  if test "x$with_libxml2" = "xyes"
  then
@@@ -5443,6 -5022,17 +5443,6 @@@ with_libopenipmipthread="yes
  with_libopenipmipthread_cflags=""
  with_libopenipmipthread_libs=""
  
 -AC_MSG_CHECKING([for pkg-config])
 -temp_result="no"
 -if test "x$PKG_CONFIG" = "x"
 -then
 -      with_libopenipmipthread="no"
 -      temp_result="no"
 -else
 -      temp_result="$PKG_CONFIG"
 -fi
 -AC_MSG_RESULT([$temp_result])
 -
  if test "x$with_libopenipmipthread" = "xyes"
  then
        AC_MSG_CHECKING([for libOpenIPMIpthread])
@@@ -5566,12 -5156,11 +5566,12 @@@ AM_CONDITIONAL(BUILD_WITH_LIBATASMART, 
  
  PKG_CHECK_MODULES([LIBNOTIFY], [libnotify],
                [with_libnotify="yes"],
 -              [if test "x$LIBNOTIFY_PKG_ERRORS" = "x"; then
 -                       with_libnotify="no"
 -               else
 -                       with_libnotify="no ($LIBNOTIFY_PKG_ERRORS)"
 -               fi])
 +              [with_libnotify="no (pkg-config doesn't know libnotify)"]
 +)
 +
 +PKG_CHECK_MODULES([LIBRIEMANN_CLIENT], [riemann-client >= 1.6.0],
 + [with_libriemann_client="yes"],
 + [with_libriemann_client="no (pkg-config doesn't know libriemann-client)"])
  
  # Check for enabled/disabled features
  #
@@@ -5664,7 -5253,7 +5664,7 @@@ AC_DEFUN
             then
                     enable_plugin="yes"
             else
 -                   enable_plugin="no"
 +                   enable_plugin="$2"
             fi
         else
             enable_plugin="$enable_all_plugins"
                    fi
            else # User passed "yes" but dependency checking yielded "no" => Dependency problem.
                    dependency_error="yes"
 -                  enable_plugin="no (dependency error)"
 +                  enable_plugin="$2 (dependency error)"
            fi
      fi
      AM_CONDITIONAL([BUILD_PLUGIN_]my_toupper([$1]), test "x$enable_plugin" = "xyes")
@@@ -5695,7 -5284,6 +5695,7 @@@ collectd features:]
  AC_COLLECTD([debug],     [enable],  [feature], [debugging])
  AC_COLLECTD([daemon],    [disable], [feature], [daemon mode])
  AC_COLLECTD([getifaddrs],[enable],  [feature], [getifaddrs under Linux])
 +AC_COLLECTD([werror],    [disable], [feature], [building with -Werror])
  
  dependency_warning="no"
  dependency_error="no"
@@@ -5710,7 -5298,6 +5710,7 @@@ plugin_conntrack="no
  plugin_contextswitch="no"
  plugin_cpu="no"
  plugin_cpufreq="no"
 +plugin_cpusleep="no"
  plugin_curl_json="no"
  plugin_curl_xml="no"
  plugin_df="no"
@@@ -5720,8 -5307,6 +5720,8 @@@ plugin_entropy="no
  plugin_ethstat="no"
  plugin_fhcount="no"
  plugin_fscache="no"
 +plugin_gps="no"
 +plugin_grpc="no"
  plugin_interface="no"
  plugin_ipmi="no"
  plugin_ipvs="no"
@@@ -5733,10 -5318,8 +5733,10 @@@ plugin_multimeter="no
  plugin_nfs="no"
  plugin_numa="no"
  plugin_perl="no"
 +plugin_pinba="no"
  plugin_processes="no"
  plugin_protocols="no"
 +plugin_python="no"
  plugin_serial="no"
  plugin_smart="no"
  plugin_swap="no"
@@@ -5751,18 -5334,16 +5751,18 @@@ plugin_virt="no
  plugin_vmem="no"
  plugin_vserver="no"
  plugin_wireless="no"
 +plugin_xencpu="no"
  plugin_zfs_arc="no"
 +plugin_zone="no"
  plugin_zookeeper="no"
  
  # Linux
  if test "x$ac_system" = "xLinux"
  then
        plugin_battery="yes"
 +      plugin_cgroups="yes"
        plugin_conntrack="yes"
        plugin_contextswitch="yes"
 -      plugin_cgroups="yes"
        plugin_cpu="yes"
        plugin_cpufreq="yes"
        plugin_disk="yes"
        then
                plugin_turbostat="yes"
        fi
 +      
 +      if test "x$c_cv_have_clock_boottime_monotonic" = "xyes"
 +      then
 +              plugin_cpusleep="yes"
 +      fi
  fi
  
  if test "x$ac_system" = "xOpenBSD"
        plugin_tcpconns="yes"
  fi
  
 +if test "x$ac_system" = "xNetBSD"
 +then
 +      plugin_disk="yes"
 +      plugin_entropy="yes"
 +      plugin_irq="yes"
 +      plugin_processes="yes"
 +fi
 +
  # Mac OS X devices
  if test "x$with_libiokit" = "xyes"
  then
  
  if test "x$ac_system" = "xAIX"
  then
 -      plugin_tcpconns="yes"
        plugin_ipc="yes"
 +      plugin_tcpconns="yes"
  fi
  
  # FreeBSD
  
  if test "x$ac_system" = "xFreeBSD"
  then
 +      plugin_disk="yes"
        plugin_zfs_arc="yes"
  fi
  
  
  if test "x$with_perfstat" = "xyes"
  then
 -      plugin_cpu="yes"
        plugin_contextswitch="yes"
 +      plugin_cpu="yes"
        plugin_disk="yes"
 -      plugin_memory="yes"
 -      plugin_swap="yes"
        plugin_interface="yes"
        plugin_load="yes"
 +      plugin_memory="yes"
 +      plugin_swap="yes"
        plugin_uptime="yes"
  fi
  
@@@ -5866,7 -5433,6 +5866,7 @@@ the
        plugin_processes="yes"
        plugin_uptime="yes"
        plugin_zfs_arc="yes"
 +      plugin_zone="yes"
  fi
  
  if test "x$with_devinfo$with_kstat" = "xyesyes"
@@@ -5879,6 -5445,7 +5879,6 @@@ the
  fi
  
  # libi2c-dev
 -with_libi2c="no"
  if test "x$ac_system" = "xLinux"
  then
  AC_CHECK_DECL(i2c_smbus_read_i2c_block_data,
        [with_libi2c="no (symbol i2c_smbus_read_i2c_block_data not found - have you installed libi2c-dev ?)"],
        [[#include <stdlib.h>
        #include <linux/i2c-dev.h>]])
 +else
 +      with_libi2c="no (Linux only)"
  fi
  
  if test "x$with_libi2c" = "xyes"
        plugin_ethstat="yes"
  fi
  
 +if test "x$with_libgrpcpp" = "xyes" && test "x$with_libprotobuf" = "xyes" && test "x$have_protoc3" = "xyes" && test "x$GRPC_CPP_PLUGIN" != "x"
 +then
 +      plugin_grpc="yes"
 +fi
 +
  if test "x$have_getifaddrs" = "xyes"
  then
        plugin_interface="yes"
  fi
  
 +if test "x$with_libgps" = "xyes"
 +then
 +      plugin_gps="yes"
 +fi
 +
  if test "x$have_getloadavg" = "xyes"
  then
        plugin_load="yes"
        plugin_perl="yes"
  fi
  
 +if test "x$have_protoc_c" = "xyes" && test "x$with_libprotobuf_c" = "xyes"
 +then
 +      plugin_pinba="yes"
 +fi
 +
  # Mac OS X memory interface
  if test "x$have_host_statistics" = "xyes"
  then
        plugin_processes="yes"
  fi
  
 +if test "x$with_libpython" != "xno"
 +then
 +      plugin_python="yes"
 +fi
 +
  if test "x$with_libatasmart" = "xyes" && test "x$with_libudev" = "xyes"
  then
        plugin_smart="yes"
        plugin_swap="yes"
  fi
  
 +if test "x$have_swapctl" = "xyes" && test "x$c_cv_have_swapctl_three_args" = "xyes"
 +then
 +      plugin_swap="yes"
 +fi
 +
  if test "x$with_kvm_openfiles$with_kvm_nlist" = "xyesyes"
  then
        plugin_tcpconns="yes"
        plugin_virt="yes"
  fi
  
 +if test "x$with_libxenctrl" = "xyes"
 +then
 +  plugin_xencpu="yes"
 +fi
  
  m4_divert_once([HELP_ENABLE], [
  collectd plugins:])
@@@ -6138,150 -5674,141 +6138,150 @@@ AC_ARG_ENABLE([all-plugins]
  
  m4_divert_once([HELP_ENABLE], [])
  
 -AC_PLUGIN([aggregation], [yes],                [Aggregation plugin])
 -AC_PLUGIN([amqp],        [$with_librabbitmq],  [AMQP output plugin])
 -AC_PLUGIN([apache],      [$with_libcurl],      [Apache httpd statistics])
 -AC_PLUGIN([apcups],      [yes],                [Statistics of UPSes by APC])
 -AC_PLUGIN([apple_sensors], [$with_libiokit],   [Apple's hardware sensors])
 -AC_PLUGIN([aquaero],     [$with_libaquaero5],  [Aquaero's hardware sensors])
 -AC_PLUGIN([ascent],      [$plugin_ascent],     [AscentEmu player statistics])
 -AC_PLUGIN([barometer],   [$plugin_barometer],  [Barometer sensor on I2C])
 -AC_PLUGIN([battery],     [$plugin_battery],    [Battery statistics])
 -AC_PLUGIN([bind],        [$plugin_bind],       [ISC Bind nameserver statistics])
 -AC_PLUGIN([ceph],        [$plugin_ceph],       [Ceph daemon statistics])
 -AC_PLUGIN([conntrack],   [$plugin_conntrack],  [nf_conntrack statistics])
 -AC_PLUGIN([contextswitch], [$plugin_contextswitch], [context switch statistics])
 -AC_PLUGIN([cpufreq],     [$plugin_cpufreq],    [CPU frequency statistics])
 -AC_PLUGIN([cpu],         [$plugin_cpu],        [CPU usage statistics])
 -AC_PLUGIN([csv],         [yes],                [CSV output plugin])
 -AC_PLUGIN([curl],        [$with_libcurl],      [CURL generic web statistics])
 -AC_PLUGIN([curl_json],   [$plugin_curl_json],    [CouchDB statistics])
 -AC_PLUGIN([curl_xml],   [$plugin_curl_xml],    [CURL generic xml statistics])
 -AC_PLUGIN([cgroups],     [$plugin_cgroups],    [CGroups CPU usage accounting])
 -AC_PLUGIN([dbi],         [$with_libdbi],       [General database statistics])
 -AC_PLUGIN([df],          [$plugin_df],         [Filesystem usage statistics])
 -AC_PLUGIN([disk],        [$plugin_disk],       [Disk usage statistics])
 -AC_PLUGIN([drbd],        [$plugin_drbd],       [DRBD statistics])
 -AC_PLUGIN([dns],         [$with_libpcap],      [DNS traffic analysis])
 -AC_PLUGIN([email],       [yes],                [EMail statistics])
 -AC_PLUGIN([entropy],     [$plugin_entropy],    [Entropy statistics])
 -AC_PLUGIN([ethstat],     [$plugin_ethstat],    [Stats from NIC driver])
 -AC_PLUGIN([exec],        [yes],                [Execution of external programs])
 -AC_PLUGIN([fhcount],     [$plugin_fhcount],    [File handles statistics])
 -AC_PLUGIN([filecount],   [yes],                [Count files in directories])
 -AC_PLUGIN([fscache],     [$plugin_fscache],    [fscache statistics])
 -AC_PLUGIN([gmond],       [$with_libganglia],   [Ganglia plugin])
 -AC_PLUGIN([hddtemp],     [yes],                [Query hddtempd])
 -AC_PLUGIN([interface],   [$plugin_interface],  [Interface traffic statistics])
 -AC_PLUGIN([ipc],         [$plugin_ipc],        [IPC statistics])
 -AC_PLUGIN([ipmi],        [$plugin_ipmi],       [IPMI sensor statistics])
 -AC_PLUGIN([iptables],    [$with_libiptc],      [IPTables rule counters])
 -AC_PLUGIN([ipvs],        [$plugin_ipvs],       [IPVS connection statistics])
 -AC_PLUGIN([irq],         [$plugin_irq],        [IRQ statistics])
 -AC_PLUGIN([java],        [$with_java],         [Embed the Java Virtual Machine])
 -AC_PLUGIN([load],        [$plugin_load],       [System load])
 -AC_PLUGIN([logfile],     [yes],                [File logging plugin])
 -AC_PLUGIN([log_logstash], [$plugin_log_logstash], [Logstash json_event compatible logging])
 -AC_PLUGIN([lpar],        [$with_perfstat],     [AIX logical partitions statistics])
 -AC_PLUGIN([lvm],         [$with_liblvm2app],   [LVM statistics])
 -AC_PLUGIN([madwifi],     [$have_linux_wireless_h], [Madwifi wireless statistics])
 -AC_PLUGIN([match_empty_counter], [yes],        [The empty counter match])
 -AC_PLUGIN([match_hashed], [yes],               [The hashed match])
 -AC_PLUGIN([match_regex], [yes],                [The regex match])
 -AC_PLUGIN([match_timediff], [yes],             [The timediff match])
 -AC_PLUGIN([match_value], [yes],                [The value match])
 -AC_PLUGIN([mbmon],       [yes],                [Query mbmond])
 -AC_PLUGIN([md],          [$have_linux_raid_md_u_h], [md (Linux software RAID) devices])
 -AC_PLUGIN([memcachec],   [$with_libmemcached], [memcachec statistics])
 -AC_PLUGIN([memcached],   [yes],                [memcached statistics])
 -AC_PLUGIN([memory],      [$plugin_memory],     [Memory usage])
 -AC_PLUGIN([mic],         [$with_mic],          [Intel Many Integrated Core stats])
 -AC_PLUGIN([modbus],      [$with_libmodbus],    [Modbus plugin])
 -AC_PLUGIN([multimeter],  [$plugin_multimeter], [Read multimeter values])
 -AC_PLUGIN([mysql],       [$with_libmysql],     [MySQL statistics])
 -AC_PLUGIN([netapp],      [$with_libnetapp],    [NetApp plugin])
 -AC_PLUGIN([netlink],     [$with_libmnl],       [Enhanced Linux network statistics])
 -AC_PLUGIN([network],     [yes],                [Network communication plugin])
 -AC_PLUGIN([nfs],         [$plugin_nfs],        [NFS statistics])
 -AC_PLUGIN([nginx],       [$with_libcurl],      [nginx statistics])
 -AC_PLUGIN([notify_desktop], [$with_libnotify], [Desktop notifications])
 -AC_PLUGIN([notify_email], [$with_libesmtp],    [Email notifier])
 -AC_PLUGIN([ntpd],        [yes],                [NTPd statistics])
 -AC_PLUGIN([numa],        [$plugin_numa],       [NUMA virtual memory statistics])
 -AC_PLUGIN([nut],         [$with_libupsclient], [Network UPS tools statistics])
 -AC_PLUGIN([olsrd],       [yes],                [olsrd statistics])
 -AC_PLUGIN([onewire],     [$with_libowcapi],    [OneWire sensor statistics])
 -AC_PLUGIN([openldap],    [$with_libldap],      [OpenLDAP statistics])
 -AC_PLUGIN([openvpn],     [yes],                [OpenVPN client statistics])
 -AC_PLUGIN([oracle],      [$with_oracle],       [Oracle plugin])
 -AC_PLUGIN([perl],        [$plugin_perl],       [Embed a Perl interpreter])
 -AC_PLUGIN([pf],          [$have_net_pfvar_h],  [BSD packet filter (PF) statistics])
 +AC_PLUGIN([aggregation],         [yes],                     [Aggregation plugin])
 +AC_PLUGIN([amqp],                [$with_librabbitmq],       [AMQP output plugin])
 +AC_PLUGIN([apache],              [$with_libcurl],           [Apache httpd statistics])
 +AC_PLUGIN([apcups],              [yes],                     [Statistics of UPSes by APC])
 +AC_PLUGIN([apple_sensors],       [$with_libiokit],          [Apple hardware sensors])
 +AC_PLUGIN([aquaero],             [$with_libaquaero5],       [Aquaero hardware sensors])
 +AC_PLUGIN([ascent],              [$plugin_ascent],          [AscentEmu player statistics])
 +AC_PLUGIN([barometer],           [$plugin_barometer],       [Barometer sensor on I2C])
 +AC_PLUGIN([battery],             [$plugin_battery],         [Battery statistics])
 +AC_PLUGIN([bind],                [$plugin_bind],            [ISC Bind nameserver statistics])
 +AC_PLUGIN([ceph],                [$plugin_ceph],            [Ceph daemon statistics])
 +AC_PLUGIN([cgroups],             [$plugin_cgroups],         [CGroups CPU usage accounting])
 +AC_PLUGIN([chrony],              [yes],                     [Chrony statistics])
 +AC_PLUGIN([conntrack],           [$plugin_conntrack],       [nf_conntrack statistics])
 +AC_PLUGIN([contextswitch],       [$plugin_contextswitch],   [context switch statistics])
 +AC_PLUGIN([cpu],                 [$plugin_cpu],             [CPU usage statistics])
 +AC_PLUGIN([cpufreq],             [$plugin_cpufreq],         [CPU frequency statistics])
 +AC_PLUGIN([cpusleep],            [$plugin_cpusleep],        [CPU sleep statistics])
 +AC_PLUGIN([csv],                 [yes],                     [CSV output plugin])
 +AC_PLUGIN([curl],                [$with_libcurl],           [CURL generic web statistics])
 +AC_PLUGIN([curl_json],           [$plugin_curl_json],       [CouchDB statistics])
 +AC_PLUGIN([curl_xml],            [$plugin_curl_xml],        [CURL generic xml statistics])
 +AC_PLUGIN([dbi],                 [$with_libdbi],            [General database statistics])
 +AC_PLUGIN([df],                  [$plugin_df],              [Filesystem usage statistics])
 +AC_PLUGIN([disk],                [$plugin_disk],            [Disk usage statistics])
 +AC_PLUGIN([dns],                 [$with_libpcap],           [DNS traffic analysis])
 +AC_PLUGIN([drbd],                [$plugin_drbd],            [DRBD statistics])
 +AC_PLUGIN([email],               [yes],                     [EMail statistics])
 +AC_PLUGIN([entropy],             [$plugin_entropy],         [Entropy statistics])
 +AC_PLUGIN([ethstat],             [$plugin_ethstat],         [Stats from NIC driver])
 +AC_PLUGIN([exec],                [yes],                     [Execution of external programs])
 +AC_PLUGIN([fhcount],             [$plugin_fhcount],         [File handles statistics])
 +AC_PLUGIN([filecount],           [yes],                     [Count files in directories])
 +AC_PLUGIN([fscache],             [$plugin_fscache],         [fscache statistics])
 +AC_PLUGIN([gmond],               [$with_libganglia],        [Ganglia plugin])
 +AC_PLUGIN([gps],                 [$plugin_gps],             [GPS plugin])
 +AC_PLUGIN([grpc],                [$plugin_grpc],            [gRPC plugin])
 +AC_PLUGIN([hddtemp],             [yes],                     [Query hddtempd])
 +AC_PLUGIN([interface],           [$plugin_interface],       [Interface traffic statistics])
 +AC_PLUGIN([ipc],                 [$plugin_ipc],             [IPC statistics])
 +AC_PLUGIN([ipmi],                [$plugin_ipmi],            [IPMI sensor statistics])
 +AC_PLUGIN([iptables],            [$with_libiptc],           [IPTables rule counters])
 +AC_PLUGIN([ipvs],                [$plugin_ipvs],            [IPVS connection statistics])
 +AC_PLUGIN([irq],                 [$plugin_irq],             [IRQ statistics])
 +AC_PLUGIN([java],                [$with_java],              [Embed the Java Virtual Machine])
 +AC_PLUGIN([load],                [$plugin_load],            [System load])
 +AC_PLUGIN([log_logstash],        [$plugin_log_logstash],    [Logstash json_event compatible logging])
 +AC_PLUGIN([logfile],             [yes],                     [File logging plugin])
 +AC_PLUGIN([lpar],                [$with_perfstat],          [AIX logical partitions statistics])
 +AC_PLUGIN([lua],                 [$with_liblua],            [Lua plugin])
 +AC_PLUGIN([lvm],                 [$with_liblvm2app],        [LVM statistics])
 +AC_PLUGIN([madwifi],             [$have_linux_wireless_h],  [Madwifi wireless statistics])
 +AC_PLUGIN([match_empty_counter], [yes],                     [The empty counter match])
 +AC_PLUGIN([match_hashed],        [yes],                     [The hashed match])
 +AC_PLUGIN([match_regex],         [yes],                     [The regex match])
 +AC_PLUGIN([match_timediff],      [yes],                     [The timediff match])
 +AC_PLUGIN([match_value],         [yes],                     [The value match])
 +AC_PLUGIN([mbmon],               [yes],                     [Query mbmond])
 +AC_PLUGIN([md],                  [$have_linux_raid_md_u_h], [md (Linux software RAID) devices])
 +AC_PLUGIN([memcachec],           [$with_libmemcached],      [memcachec statistics])
 +AC_PLUGIN([memcached],           [yes],                     [memcached statistics])
 +AC_PLUGIN([memory],              [$plugin_memory],          [Memory usage])
 +AC_PLUGIN([mic],                 [$with_mic],               [Intel Many Integrated Core stats])
 +AC_PLUGIN([modbus],              [$with_libmodbus],         [Modbus plugin])
 +AC_PLUGIN([mqtt],                [$with_libmosquitto],      [MQTT output plugin])
 +AC_PLUGIN([multimeter],          [$plugin_multimeter],      [Read multimeter values])
 +AC_PLUGIN([mysql],               [$with_libmysql],          [MySQL statistics])
 +AC_PLUGIN([netapp],              [$with_libnetapp],         [NetApp plugin])
 +AC_PLUGIN([netlink],             [$with_libmnl],            [Enhanced Linux network statistics])
 +AC_PLUGIN([network],             [yes],                     [Network communication plugin])
 +AC_PLUGIN([nfs],                 [$plugin_nfs],             [NFS statistics])
 +AC_PLUGIN([nginx],               [$with_libcurl],           [nginx statistics])
 +AC_PLUGIN([notify_desktop],      [$with_libnotify],         [Desktop notifications])
 +AC_PLUGIN([notify_email],        [$with_libesmtp],          [Email notifier])
 +AC_PLUGIN([notify_nagios],       [yes],                     [Nagios notification plugin])
 +AC_PLUGIN([ntpd],                [yes],                     [NTPd statistics])
 +AC_PLUGIN([numa],                [$plugin_numa],            [NUMA virtual memory statistics])
 +AC_PLUGIN([nut],                 [$with_libupsclient],      [Network UPS tools statistics])
 +AC_PLUGIN([olsrd],               [yes],                     [olsrd statistics])
 +AC_PLUGIN([onewire],             [$with_libowcapi],         [OneWire sensor statistics])
 +AC_PLUGIN([openldap],            [$with_libldap],           [OpenLDAP statistics])
 +AC_PLUGIN([openvpn],             [yes],                     [OpenVPN client statistics])
 +AC_PLUGIN([oracle],              [$with_oracle],            [Oracle plugin])
 +AC_PLUGIN([perl],                [$plugin_perl],            [Embed a Perl interpreter])
 +AC_PLUGIN([pf],                  [$have_net_pfvar_h],       [BSD packet filter (PF) statistics])
  # FIXME: Check for libevent, too.
 -AC_PLUGIN([pinba],       [$have_protoc_c],     [Pinba statistics])
 -AC_PLUGIN([ping],        [$with_liboping],     [Network latency statistics])
 -AC_PLUGIN([postgresql],  [$with_libpq],        [PostgreSQL database statistics])
 -AC_PLUGIN([powerdns],    [yes],                [PowerDNS statistics])
 -AC_PLUGIN([processes],   [$plugin_processes],  [Process statistics])
 -AC_PLUGIN([protocols],   [$plugin_protocols],  [Protocol (IP, TCP, ...) statistics])
 -AC_PLUGIN([python],      [$with_python],       [Embed a Python interpreter])
 -AC_PLUGIN([redis],       [$with_libhiredis],    [Redis plugin])
 -AC_PLUGIN([routeros],    [$with_librouteros],  [RouterOS plugin])
 -AC_PLUGIN([rrdcached],   [$librrd_rrdc_update], [RRDTool output plugin])
 -AC_PLUGIN([rrdtool],     [$with_librrd],       [RRDTool output plugin])
 -AC_PLUGIN([sensors],     [$with_libsensors],   [lm_sensors statistics])
 -AC_PLUGIN([serial],      [$plugin_serial],     [serial port traffic])
 -AC_PLUGIN([sigrok],      [$with_libsigrok],    [sigrok acquisition sources])
 -AC_PLUGIN([smart],       [$plugin_smart],      [SMART statistics])
 -AC_PLUGIN([snmp],        [$with_libnetsnmp],   [SNMP querying plugin])
 -AC_PLUGIN([statsd],      [yes],                [StatsD plugin])
 -AC_PLUGIN([swap],        [$plugin_swap],       [Swap usage statistics])
 -AC_PLUGIN([syslog],      [$have_syslog],       [Syslog logging plugin])
 -AC_PLUGIN([table],       [yes],                [Parsing of tabular data])
 -AC_PLUGIN([tail],        [yes],                [Parsing of logfiles])
 -AC_PLUGIN([tail_csv],    [yes],                [Parsing of CSV files])
 -AC_PLUGIN([tape],        [$plugin_tape],       [Tape drive statistics])
 -AC_PLUGIN([target_notification], [yes],        [The notification target])
 -AC_PLUGIN([target_replace], [yes],             [The replace target])
 -AC_PLUGIN([target_scale],[yes],                [The scale target])
 -AC_PLUGIN([target_set],  [yes],                [The set target])
 -AC_PLUGIN([target_v5upgrade], [yes],           [The v5upgrade target])
 -AC_PLUGIN([tcpconns],    [$plugin_tcpconns],   [TCP connection statistics])
 -AC_PLUGIN([teamspeak2],  [yes],                [TeamSpeak2 server statistics])
 -AC_PLUGIN([ted],         [$plugin_ted],        [Read The Energy Detective values])
 -AC_PLUGIN([thermal],     [$plugin_thermal],    [Linux ACPI thermal zone statistics])
 -AC_PLUGIN([threshold],   [yes],                [Threshold checking plugin])
 -AC_PLUGIN([tokyotyrant], [$with_libtokyotyrant],  [TokyoTyrant database statistics])
 -AC_PLUGIN([turbostat],   [$plugin_turbostat],  [Advanced statistic on Intel cpu states])
 -AC_PLUGIN([unixsock],    [yes],                [Unixsock communication plugin])
 -AC_PLUGIN([uptime],      [$plugin_uptime],     [Uptime statistics])
 -AC_PLUGIN([users],       [$plugin_users],      [User statistics])
 -AC_PLUGIN([uuid],        [yes],                [UUID as hostname plugin])
 -AC_PLUGIN([varnish],     [$with_libvarnish],   [Varnish cache statistics])
 -AC_PLUGIN([virt],        [$plugin_virt],       [Virtual machine statistics])
 -AC_PLUGIN([vmem],        [$plugin_vmem],       [Virtual memory statistics])
 -AC_PLUGIN([vserver],     [$plugin_vserver],    [Linux VServer statistics])
 -AC_PLUGIN([wireless],    [$plugin_wireless],   [Wireless statistics])
 -AC_PLUGIN([write_graphite], [yes],             [Graphite / Carbon output plugin])
 -AC_PLUGIN([write_http],  [$with_libcurl],      [HTTP output plugin])
 -AC_PLUGIN([write_kafka],  [$with_librdkafka],  [Kafka output plugin])
 -AC_PLUGIN([write_log], [yes],                  [Log output plugin])
 -AC_PLUGIN([write_mongodb], [$with_libmongoc],  [MongoDB output plugin])
 -AC_PLUGIN([write_redis], [$with_libhiredis],    [Redis output plugin])
 -AC_PLUGIN([write_riemann], [$have_protoc_c],   [Riemann output plugin])
 -AC_PLUGIN([write_sensu], [yes],                [Sensu output plugin])
 -AC_PLUGIN([write_tsdb],  [yes],                [TSDB output plugin])
 -AC_PLUGIN([xmms],        [$with_libxmms],      [XMMS statistics])
 -AC_PLUGIN([zfs_arc],     [$plugin_zfs_arc],    [ZFS ARC statistics])
 -AC_PLUGIN([zookeeper],   [yes],              [Zookeeper statistics])
 +AC_PLUGIN([pinba],               [$plugin_pinba],           [Pinba statistics])
 +AC_PLUGIN([ping],                [$with_liboping],          [Network latency statistics])
 +AC_PLUGIN([postgresql],          [$with_libpq],             [PostgreSQL database statistics])
 +AC_PLUGIN([powerdns],            [yes],                     [PowerDNS statistics])
 +AC_PLUGIN([processes],           [$plugin_processes],       [Process statistics])
 +AC_PLUGIN([protocols],           [$plugin_protocols],       [Protocol (IP, TCP, ...) statistics])
 +AC_PLUGIN([python],              [$plugin_python],          [Embed a Python interpreter])
 +AC_PLUGIN([redis],               [$with_libhiredis],        [Redis plugin])
 +AC_PLUGIN([routeros],            [$with_librouteros],       [RouterOS plugin])
 +AC_PLUGIN([rrdcached],           [$librrd_rrdc_update],     [RRDTool output plugin])
 +AC_PLUGIN([rrdtool],             [$with_librrd],            [RRDTool output plugin])
 +AC_PLUGIN([sensors],             [$with_libsensors],        [lm_sensors statistics])
 +AC_PLUGIN([serial],              [$plugin_serial],          [serial port traffic])
 +AC_PLUGIN([sigrok],              [$with_libsigrok],         [sigrok acquisition sources])
 +AC_PLUGIN([smart],               [$plugin_smart],           [SMART statistics])
 +AC_PLUGIN([snmp],                [$with_libnetsnmp],        [SNMP querying plugin])
 +AC_PLUGIN([statsd],              [yes],                     [StatsD plugin])
 +AC_PLUGIN([swap],                [$plugin_swap],            [Swap usage statistics])
 +AC_PLUGIN([syslog],              [$have_syslog],            [Syslog logging plugin])
 +AC_PLUGIN([table],               [yes],                     [Parsing of tabular data])
 +AC_PLUGIN([tail],                [yes],                     [Parsing of logfiles])
 +AC_PLUGIN([tail_csv],            [yes],                     [Parsing of CSV files])
 +AC_PLUGIN([tape],                [$plugin_tape],            [Tape drive statistics])
 +AC_PLUGIN([target_notification], [yes],                     [The notification target])
 +AC_PLUGIN([target_replace],      [yes],                     [The replace target])
 +AC_PLUGIN([target_scale],        [yes],                     [The scale target])
 +AC_PLUGIN([target_set],          [yes],                     [The set target])
 +AC_PLUGIN([target_v5upgrade],    [yes],                     [The v5upgrade target])
 +AC_PLUGIN([tcpconns],            [$plugin_tcpconns],        [TCP connection statistics])
 +AC_PLUGIN([teamspeak2],          [yes],                     [TeamSpeak2 server statistics])
 +AC_PLUGIN([ted],                 [$plugin_ted],             [Read The Energy Detective values])
 +AC_PLUGIN([thermal],             [$plugin_thermal],         [Linux ACPI thermal zone statistics])
 +AC_PLUGIN([threshold],           [yes],                     [Threshold checking plugin])
 +AC_PLUGIN([tokyotyrant],         [$with_libtokyotyrant],    [TokyoTyrant database statistics])
 +AC_PLUGIN([turbostat],           [$plugin_turbostat],       [Advanced statistic on Intel cpu states])
 +AC_PLUGIN([unixsock],            [yes],                     [Unixsock communication plugin])
 +AC_PLUGIN([uptime],              [$plugin_uptime],          [Uptime statistics])
 +AC_PLUGIN([users],               [$plugin_users],           [User statistics])
 +AC_PLUGIN([uuid],                [yes],                     [UUID as hostname plugin])
 +AC_PLUGIN([varnish],             [$with_libvarnish],        [Varnish cache statistics])
 +AC_PLUGIN([virt],                [$plugin_virt],            [Virtual machine statistics])
 +AC_PLUGIN([vmem],                [$plugin_vmem],            [Virtual memory statistics])
 +AC_PLUGIN([vserver],             [$plugin_vserver],         [Linux VServer statistics])
 +AC_PLUGIN([wireless],            [$plugin_wireless],        [Wireless statistics])
 +AC_PLUGIN([write_graphite],      [yes],                     [Graphite / Carbon output plugin])
 +AC_PLUGIN([write_http],          [$with_libcurl],           [HTTP output plugin])
 +AC_PLUGIN([write_kafka],         [$with_librdkafka],        [Kafka output plugin])
 +AC_PLUGIN([write_log],           [yes],                     [Log output plugin])
 +AC_PLUGIN([write_mongodb],       [$with_libmongoc],         [MongoDB output plugin])
 +AC_PLUGIN([write_redis],         [$with_libhiredis],        [Redis output plugin])
 +AC_PLUGIN([write_riemann],       [$with_libriemann_client], [Riemann output plugin])
 +AC_PLUGIN([write_sensu],         [yes],                     [Sensu output plugin])
 +AC_PLUGIN([write_tsdb],          [yes],                     [TSDB output plugin])
 +AC_PLUGIN([xencpu],              [$plugin_xencpu],          [Xen Host CPU usage])
 +AC_PLUGIN([xmms],                [$with_libxmms],           [XMMS statistics])
 +AC_PLUGIN([zfs_arc],             [$plugin_zfs_arc],         [ZFS ARC statistics])
 +AC_PLUGIN([zone],                [$plugin_zone],            [Solaris container statistics])
 +AC_PLUGIN([zookeeper],           [yes],                     [Zookeeper statistics])
  
  dnl Default configuration file
  # Load either syslog or logfile
@@@ -6406,18 -5933,6 +6406,18 @@@ AC_ARG_WITH(perl-bindings, [AS_HELP_STR
                with_perl_bindings="no (no perl interpreter found)"
        fi
  ])
 +
 +if test "x$with_perl_bindings" = "xyes"
 +then
 +      AC_MSG_CHECKING([for the ExtUtils::MakeMaker module])
 +      if $PERL -MExtUtils::MakeMaker -e '' 2>/dev/null; then
 +              AC_MSG_RESULT([yes])
 +      else
 +              AC_MSG_RESULT([no])
 +              with_perl_bindings="no (ExtUtils::MakeMaker not found)"
 +      fi
 +fi
 +
  if test "x$with_perl_bindings" = "xyes"
  then
        PERL_BINDINGS="perl"
@@@ -6444,17 -5959,7 +6444,17 @@@ AC_SUBST(LCC_VERSION_STRING
  
  AC_CONFIG_FILES(src/libcollectdclient/collectd/lcc_features.h)
  
 -AC_CONFIG_FILES([Makefile src/Makefile src/daemon/Makefile src/collectd.conf src/libcollectdclient/Makefile src/libcollectdclient/libcollectdclient.pc src/liboconfig/Makefile bindings/Makefile bindings/java/Makefile])
 +AM_CFLAGS="-Wall"
 +AM_CXXFLAGS="-Wall"
 +if test "x$enable_werror" != "xno"
 +then
 +        AM_CFLAGS="$AM_CFLAGS -Werror"
 +        AM_CXXFLAGS="$AM_CXXFLAGS -Werror"
 +fi
 +AC_SUBST([AM_CFLAGS])
 +AC_SUBST([AM_CXXFLAGS])
 +
 +AC_CONFIG_FILES([Makefile proto/Makefile src/Makefile src/daemon/Makefile src/collectd.conf src/libcollectdclient/Makefile src/libcollectdclient/libcollectdclient.pc src/liboconfig/Makefile bindings/Makefile bindings/java/Makefile])
  AC_OUTPUT
  
  if test "x$with_librrd" = "xyes" \
        with_perl_bindings="yes ($PERL_BINDINGS_OPTIONS)"
  fi
  
 -cat <<EOF;
 -
 -Configuration:
 -  Libraries:
 -    intel mic . . . . . . $with_mic
 -    libaquaero5 . . . . . $with_libaquaero5
 -    libatasmart . . . . . $with_libatasmart
 -    libcurl . . . . . . . $with_libcurl
 -    libdbi  . . . . . . . $with_libdbi
 -    libesmtp  . . . . . . $with_libesmtp
 -    libganglia  . . . . . $with_libganglia
 -    libgcrypt . . . . . . $with_libgcrypt
 -    libhal  . . . . . . . $with_libhal
 -    libhiredis  . . . . . $with_libhiredis
 -    libi2c-dev  . . . . . $with_libi2c
 -    libiokit  . . . . . . $with_libiokit
 -    libiptc . . . . . . . $with_libiptc
 -    libjvm  . . . . . . . $with_java
 -    libkstat  . . . . . . $with_kstat
 -    libkvm  . . . . . . . $with_libkvm
 -    libldap . . . . . . . $with_libldap
 -    liblvm2app  . . . . . $with_liblvm2app
 -    libmemcached  . . . . $with_libmemcached
 -    libmnl  . . . . . . . $with_libmnl
 -    libmodbus . . . . . . $with_libmodbus
 -    libmongoc . . . . . . $with_libmongoc
 -    libmysql  . . . . . . $with_libmysql
 -    libnetapp . . . . . . $with_libnetapp
 -    libnetsnmp  . . . . . $with_libnetsnmp
 -    libnotify . . . . . . $with_libnotify
 -    liboconfig  . . . . . $with_liboconfig
 -    libopenipmi . . . . . $with_libopenipmipthread
 -    liboping  . . . . . . $with_liboping
 -    libowcapi . . . . . . $with_libowcapi
 -    libpcap . . . . . . . $with_libpcap
 -    libperfstat . . . . . $with_perfstat
 -    libperl . . . . . . . $with_libperl
 -    libpq . . . . . . . . $with_libpq
 -    libpthread  . . . . . $with_libpthread
 -    librabbitmq . . . . . $with_librabbitmq
 -    librdkafka  . . . . . $with_librdkafka
 -    librouteros . . . . . $with_librouteros
 -    librrd  . . . . . . . $with_librrd
 -    libsensors  . . . . . $with_libsensors
 -    libsigrok   . . . . . $with_libsigrok
 -    libstatgrab . . . . . $with_libstatgrab
 -    libtokyotyrant  . . . $with_libtokyotyrant
 -    libudev . . . . . . . $with_libudev
 -    libupsclient  . . . . $with_libupsclient
 -    libvarnish  . . . . . $with_libvarnish
 -    libvirt . . . . . . . $with_libvirt
 -    libxml2 . . . . . . . $with_libxml2
 -    libxmms . . . . . . . $with_libxmms
 -    libyajl . . . . . . . $with_libyajl
 -    oracle  . . . . . . . $with_oracle
 -    protobuf-c  . . . . . $have_protoc_c
 -    python  . . . . . . . $with_python
 -
 -  Features:
 -    daemon mode . . . . . $enable_daemon
 -    debug . . . . . . . . $enable_debug
 -
 -  Bindings:
 -    perl  . . . . . . . . $with_perl_bindings
 -
 -  Modules:
 -    aggregation . . . . . $enable_aggregation
 -    amqp    . . . . . . . $enable_amqp
 -    apache  . . . . . . . $enable_apache
 -    apcups  . . . . . . . $enable_apcups
 -    apple_sensors . . . . $enable_apple_sensors
 -    aquaero . . . . . . . $enable_aquaero
 -    ascent  . . . . . . . $enable_ascent
 -    barometer . . . . . . $enable_barometer
 -    battery . . . . . . . $enable_battery
 -    bind  . . . . . . . . $enable_bind
 -    ceph  . . . . . . . . $enable_ceph
 -    cgroups . . . . . . . $enable_cgroups
 -    conntrack . . . . . . $enable_conntrack
 -    contextswitch . . . . $enable_contextswitch
 -    cpu . . . . . . . . . $enable_cpu
 -    cpufreq . . . . . . . $enable_cpufreq
 -    csv . . . . . . . . . $enable_csv
 -    curl  . . . . . . . . $enable_curl
 -    curl_json . . . . . . $enable_curl_json
 -    curl_xml  . . . . . . $enable_curl_xml
 -    dbi . . . . . . . . . $enable_dbi
 -    df  . . . . . . . . . $enable_df
 -    disk  . . . . . . . . $enable_disk
 -    dns . . . . . . . . . $enable_dns
 -    drbd  . . . . . . . . $enable_drbd
 -    email . . . . . . . . $enable_email
 -    entropy . . . . . . . $enable_entropy
 -    ethstat . . . . . . . $enable_ethstat
 -    exec  . . . . . . . . $enable_exec
 -    fhcount . . . . . . . $enable_fhcount
 -    filecount . . . . . . $enable_filecount
 -    fscache . . . . . . . $enable_fscache
 -    gmond . . . . . . . . $enable_gmond
 -    hddtemp . . . . . . . $enable_hddtemp
 -    interface . . . . . . $enable_interface
 -    ipc . . . . . . . . . $enable_ipc
 -    ipmi  . . . . . . . . $enable_ipmi
 -    iptables  . . . . . . $enable_iptables
 -    ipvs  . . . . . . . . $enable_ipvs
 -    irq . . . . . . . . . $enable_irq
 -    java  . . . . . . . . $enable_java
 -    load  . . . . . . . . $enable_load
 -    logfile . . . . . . . $enable_logfile
 -    log_logstash  . . . . $enable_log_logstash
 -    lpar  . . . . . . . . $enable_lpar
 -    lvm . . . . . . . . . $enable_lvm
 -    madwifi . . . . . . . $enable_madwifi
 -    match_empty_counter . $enable_match_empty_counter
 -    match_hashed  . . . . $enable_match_hashed
 -    match_regex . . . . . $enable_match_regex
 -    match_timediff  . . . $enable_match_timediff
 -    match_value . . . . . $enable_match_value
 -    mbmon . . . . . . . . $enable_mbmon
 -    md  . . . . . . . . . $enable_md
 -    memcachec . . . . . . $enable_memcachec
 -    memcached . . . . . . $enable_memcached
 -    memory  . . . . . . . $enable_memory
 -    mic . . . . . . . . . $enable_mic
 -    modbus  . . . . . . . $enable_modbus
 -    multimeter  . . . . . $enable_multimeter
 -    mysql . . . . . . . . $enable_mysql
 -    netapp  . . . . . . . $enable_netapp
 -    netlink . . . . . . . $enable_netlink
 -    network . . . . . . . $enable_network
 -    nfs . . . . . . . . . $enable_nfs
 -    nginx . . . . . . . . $enable_nginx
 -    notify_desktop  . . . $enable_notify_desktop
 -    notify_email  . . . . $enable_notify_email
 -    ntpd  . . . . . . . . $enable_ntpd
 -    numa  . . . . . . . . $enable_numa
 -    nut . . . . . . . . . $enable_nut
 -    olsrd . . . . . . . . $enable_olsrd
 -    onewire . . . . . . . $enable_onewire
 -    openldap  . . . . . . $enable_openldap
 -    openvpn . . . . . . . $enable_openvpn
 -    oracle  . . . . . . . $enable_oracle
 -    perl  . . . . . . . . $enable_perl
 -    pf  . . . . . . . . . $enable_pf
 -    pinba . . . . . . . . $enable_pinba
 -    ping  . . . . . . . . $enable_ping
 -    postgresql  . . . . . $enable_postgresql
 -    powerdns  . . . . . . $enable_powerdns
 -    processes . . . . . . $enable_processes
 -    protocols . . . . . . $enable_protocols
 -    python  . . . . . . . $enable_python
 -    redis . . . . . . . . $enable_redis
 -    routeros  . . . . . . $enable_routeros
 -    rrdcached . . . . . . $enable_rrdcached
 -    rrdtool . . . . . . . $enable_rrdtool
 -    sensors . . . . . . . $enable_sensors
 -    serial  . . . . . . . $enable_serial
 -    sigrok  . . . . . . . $enable_sigrok
 -    smart . . . . . . . . $enable_smart
 -    snmp  . . . . . . . . $enable_snmp
 -    statsd  . . . . . . . $enable_statsd
 -    swap  . . . . . . . . $enable_swap
 -    syslog  . . . . . . . $enable_syslog
 -    table . . . . . . . . $enable_table
 -    tail_csv  . . . . . . $enable_tail_csv
 -    tail  . . . . . . . . $enable_tail
 -    tape  . . . . . . . . $enable_tape
 -    target_notification . $enable_target_notification
 -    target_replace  . . . $enable_target_replace
 -    target_scale  . . . . $enable_target_scale
 -    target_set  . . . . . $enable_target_set
 -    target_v5upgrade  . . $enable_target_v5upgrade
 -    tcpconns  . . . . . . $enable_tcpconns
 -    teamspeak2  . . . . . $enable_teamspeak2
 -    ted . . . . . . . . . $enable_ted
 -    thermal . . . . . . . $enable_thermal
 -    threshold . . . . . . $enable_threshold
 -    tokyotyrant . . . . . $enable_tokyotyrant
 -    turbostat . . . . . . $enable_turbostat
 -    unixsock  . . . . . . $enable_unixsock
 -    uptime  . . . . . . . $enable_uptime
 -    users . . . . . . . . $enable_users
 -    uuid  . . . . . . . . $enable_uuid
 -    varnish . . . . . . . $enable_varnish
 -    virt  . . . . . . . . $enable_virt
 -    vmem  . . . . . . . . $enable_vmem
 -    vserver . . . . . . . $enable_vserver
 -    wireless  . . . . . . $enable_wireless
 -    write_graphite  . . . $enable_write_graphite
 -    write_http  . . . . . $enable_write_http
 -    write_kafka . . . . . $enable_write_kafka
 -    write_log . . . . . . $enable_write_log
 -    write_mongodb . . . . $enable_write_mongodb
 -    write_redis . . . . . $enable_write_redis
 -    write_riemann . . . . $enable_write_riemann
 -    write_sensu . . . . . $enable_write_sensu
 -    write_tsdb  . . . . . $enable_write_tsdb
 -    xmms  . . . . . . . . $enable_xmms
 -    zfs_arc . . . . . . . $enable_zfs_arc
 -    zookeeper . . . . . . $enable_zookeeper
 -
 -EOF
 +AC_MSG_RESULT()
 +AC_MSG_RESULT([Configuration:])
 +AC_MSG_RESULT([  Build:])
 +AC_MSG_RESULT([    Platform  . . . . . . $ac_system])
 +AC_MSG_RESULT([    CC  . . . . . . . . . $CC])
 +AC_MSG_RESULT([    CFLAGS  . . . . . . . $AM_CFLAGS $CFLAGS])
 +AC_MSG_RESULT([    CXXFLAGS  . . . . . . $AM_CXXFLAGS $CXXFLAGS])
 +AC_MSG_RESULT([    CPP . . . . . . . . . $CPP])
 +AC_MSG_RESULT([    CPPFLAGS  . . . . . . $CPPFLAGS])
 +AC_MSG_RESULT([    GRPC_CPP_PLUGIN . . . $GRPC_CPP_PLUGIN])
 +AC_MSG_RESULT([    LD  . . . . . . . . . $LD])
 +AC_MSG_RESULT([    LDFLAGS . . . . . . . $LDFLAGS])
 +AC_MSG_RESULT([    PROTOC  . . . . . . . $PROTOC])
 +AC_MSG_RESULT([    YACC  . . . . . . . . $YACC])
 +AC_MSG_RESULT([    YFLAGS  . . . . . . . $YFLAGS])
 +AC_MSG_RESULT()
 +AC_MSG_RESULT([  Libraries:])
 +AC_MSG_RESULT([    intel mic . . . . . . $with_mic])
 +AC_MSG_RESULT([    libaquaero5 . . . . . $with_libaquaero5])
 +AC_MSG_RESULT([    libatasmart . . . . . $with_libatasmart])
 +AC_MSG_RESULT([    libcurl . . . . . . . $with_libcurl])
 +AC_MSG_RESULT([    libdbi  . . . . . . . $with_libdbi])
 +AC_MSG_RESULT([    libesmtp  . . . . . . $with_libesmtp])
 +AC_MSG_RESULT([    libganglia  . . . . . $with_libganglia])
 +AC_MSG_RESULT([    libgcrypt . . . . . . $with_libgcrypt])
 +AC_MSG_RESULT([    libgps  . . . . . . . $with_libgps])
 +AC_MSG_RESULT([    libgrpc++ . . . . . . $with_libgrpcpp])
 +AC_MSG_RESULT([    libhal  . . . . . . . $with_libhal])
 +AC_MSG_RESULT([    libhiredis  . . . . . $with_libhiredis])
 +AC_MSG_RESULT([    libi2c-dev  . . . . . $with_libi2c])
 +AC_MSG_RESULT([    libiokit  . . . . . . $with_libiokit])
 +AC_MSG_RESULT([    libiptc . . . . . . . $with_libiptc])
 +AC_MSG_RESULT([    libjvm  . . . . . . . $with_java])
 +AC_MSG_RESULT([    libkstat  . . . . . . $with_kstat])
 +AC_MSG_RESULT([    libkvm  . . . . . . . $with_libkvm])
 +AC_MSG_RESULT([    libldap . . . . . . . $with_libldap])
 +AC_MSG_RESULT([    liblua  . . . . . . . $with_liblua])
 +AC_MSG_RESULT([    liblvm2app  . . . . . $with_liblvm2app])
 +AC_MSG_RESULT([    libmemcached  . . . . $with_libmemcached])
 +AC_MSG_RESULT([    libmnl  . . . . . . . $with_libmnl])
 +AC_MSG_RESULT([    libmodbus . . . . . . $with_libmodbus])
 +AC_MSG_RESULT([    libmongoc . . . . . . $with_libmongoc])
 +AC_MSG_RESULT([    libmosquitto  . . . . $with_libmosquitto])
 +AC_MSG_RESULT([    libmysql  . . . . . . $with_libmysql])
 +AC_MSG_RESULT([    libnetapp . . . . . . $with_libnetapp])
 +AC_MSG_RESULT([    libnetsnmp  . . . . . $with_libnetsnmp])
 +AC_MSG_RESULT([    libnotify . . . . . . $with_libnotify])
 +AC_MSG_RESULT([    liboconfig  . . . . . $with_liboconfig])
 +AC_MSG_RESULT([    libopenipmi . . . . . $with_libopenipmipthread])
 +AC_MSG_RESULT([    liboping  . . . . . . $with_liboping])
 +AC_MSG_RESULT([    libowcapi . . . . . . $with_libowcapi])
 +AC_MSG_RESULT([    libpcap . . . . . . . $with_libpcap])
 +AC_MSG_RESULT([    libperfstat . . . . . $with_perfstat])
 +AC_MSG_RESULT([    libperl . . . . . . . $with_libperl])
 +AC_MSG_RESULT([    libpq . . . . . . . . $with_libpq])
 +AC_MSG_RESULT([    libprotobuf . . . . . $with_libprotobuf])
 +AC_MSG_RESULT([    libprotobuf-c . . . . $with_libprotobuf_c])
 +AC_MSG_RESULT([    libpython . . . . . . $with_libpython])
 +AC_MSG_RESULT([    librabbitmq . . . . . $with_librabbitmq])
 +AC_MSG_RESULT([    libriemann-client . . $with_libriemann_client])
 +AC_MSG_RESULT([    librdkafka  . . . . . $with_librdkafka])
 +AC_MSG_RESULT([    librouteros . . . . . $with_librouteros])
 +AC_MSG_RESULT([    librrd  . . . . . . . $with_librrd])
 +AC_MSG_RESULT([    libsensors  . . . . . $with_libsensors])
 +AC_MSG_RESULT([    libsigrok   . . . . . $with_libsigrok])
 +AC_MSG_RESULT([    libstatgrab . . . . . $with_libstatgrab])
 +AC_MSG_RESULT([    libtokyotyrant  . . . $with_libtokyotyrant])
 +AC_MSG_RESULT([    libudev . . . . . . . $with_libudev])
 +AC_MSG_RESULT([    libupsclient  . . . . $with_libupsclient])
 +AC_MSG_RESULT([    libvarnish  . . . . . $with_libvarnish])
 +AC_MSG_RESULT([    libvirt . . . . . . . $with_libvirt])
 +AC_MSG_RESULT([    libxenctrl  . . . . . $with_libxenctrl])
 +AC_MSG_RESULT([    libxml2 . . . . . . . $with_libxml2])
 +AC_MSG_RESULT([    libxmms . . . . . . . $with_libxmms])
 +AC_MSG_RESULT([    libyajl . . . . . . . $with_libyajl])
 +AC_MSG_RESULT([    oracle  . . . . . . . $with_oracle])
 +AC_MSG_RESULT([    protobuf-c  . . . . . $have_protoc_c])
 +AC_MSG_RESULT([    protoc 3  . . . . . . $have_protoc3])
 +AC_MSG_RESULT()
 +AC_MSG_RESULT([  Features:])
 +AC_MSG_RESULT([    daemon mode . . . . . $enable_daemon])
 +AC_MSG_RESULT([    debug . . . . . . . . $enable_debug])
 +AC_MSG_RESULT()
 +AC_MSG_RESULT([  Bindings:])
 +AC_MSG_RESULT([    perl  . . . . . . . . $with_perl_bindings])
 +AC_MSG_RESULT()
 +AC_MSG_RESULT([  Modules:])
 +AC_MSG_RESULT([    aggregation . . . . . $enable_aggregation])
 +AC_MSG_RESULT([    amqp    . . . . . . . $enable_amqp])
 +AC_MSG_RESULT([    apache  . . . . . . . $enable_apache])
 +AC_MSG_RESULT([    apcups  . . . . . . . $enable_apcups])
 +AC_MSG_RESULT([    apple_sensors . . . . $enable_apple_sensors])
 +AC_MSG_RESULT([    aquaero . . . . . . . $enable_aquaero])
 +AC_MSG_RESULT([    ascent  . . . . . . . $enable_ascent])
 +AC_MSG_RESULT([    barometer . . . . . . $enable_barometer])
 +AC_MSG_RESULT([    battery . . . . . . . $enable_battery])
 +AC_MSG_RESULT([    bind  . . . . . . . . $enable_bind])
 +AC_MSG_RESULT([    ceph  . . . . . . . . $enable_ceph])
 +AC_MSG_RESULT([    cgroups . . . . . . . $enable_cgroups])
 +AC_MSG_RESULT([    chrony. . . . . . . . $enable_chrony])
 +AC_MSG_RESULT([    conntrack . . . . . . $enable_conntrack])
 +AC_MSG_RESULT([    contextswitch . . . . $enable_contextswitch])
 +AC_MSG_RESULT([    cpu . . . . . . . . . $enable_cpu])
 +AC_MSG_RESULT([    cpufreq . . . . . . . $enable_cpufreq])
 +AC_MSG_RESULT([    cpusleep  . . . . . . $enable_cpusleep])
 +AC_MSG_RESULT([    csv . . . . . . . . . $enable_csv])
 +AC_MSG_RESULT([    curl  . . . . . . . . $enable_curl])
 +AC_MSG_RESULT([    curl_json . . . . . . $enable_curl_json])
 +AC_MSG_RESULT([    curl_xml  . . . . . . $enable_curl_xml])
 +AC_MSG_RESULT([    dbi . . . . . . . . . $enable_dbi])
 +AC_MSG_RESULT([    df  . . . . . . . . . $enable_df])
 +AC_MSG_RESULT([    disk  . . . . . . . . $enable_disk])
 +AC_MSG_RESULT([    dns . . . . . . . . . $enable_dns])
 +AC_MSG_RESULT([    drbd  . . . . . . . . $enable_drbd])
 +AC_MSG_RESULT([    email . . . . . . . . $enable_email])
 +AC_MSG_RESULT([    entropy . . . . . . . $enable_entropy])
 +AC_MSG_RESULT([    ethstat . . . . . . . $enable_ethstat])
 +AC_MSG_RESULT([    exec  . . . . . . . . $enable_exec])
 +AC_MSG_RESULT([    fhcount . . . . . . . $enable_fhcount])
 +AC_MSG_RESULT([    filecount . . . . . . $enable_filecount])
 +AC_MSG_RESULT([    fscache . . . . . . . $enable_fscache])
 +AC_MSG_RESULT([    gmond . . . . . . . . $enable_gmond])
 +AC_MSG_RESULT([    gps . . . . . . . . . $enable_gps])
 +AC_MSG_RESULT([    grpc  . . . . . . . . $enable_grpc])
 +AC_MSG_RESULT([    hddtemp . . . . . . . $enable_hddtemp])
 +AC_MSG_RESULT([    interface . . . . . . $enable_interface])
 +AC_MSG_RESULT([    ipc . . . . . . . . . $enable_ipc])
 +AC_MSG_RESULT([    ipmi  . . . . . . . . $enable_ipmi])
 +AC_MSG_RESULT([    iptables  . . . . . . $enable_iptables])
 +AC_MSG_RESULT([    ipvs  . . . . . . . . $enable_ipvs])
 +AC_MSG_RESULT([    irq . . . . . . . . . $enable_irq])
 +AC_MSG_RESULT([    java  . . . . . . . . $enable_java])
 +AC_MSG_RESULT([    load  . . . . . . . . $enable_load])
 +AC_MSG_RESULT([    logfile . . . . . . . $enable_logfile])
 +AC_MSG_RESULT([    log_logstash  . . . . $enable_log_logstash])
 +AC_MSG_RESULT([    lpar  . . . . . . . . $enable_lpar])
 +AC_MSG_RESULT([    lua . . . . . . . . . $enable_lua])
 +AC_MSG_RESULT([    lvm . . . . . . . . . $enable_lvm])
 +AC_MSG_RESULT([    madwifi . . . . . . . $enable_madwifi])
 +AC_MSG_RESULT([    match_empty_counter . $enable_match_empty_counter])
 +AC_MSG_RESULT([    match_hashed  . . . . $enable_match_hashed])
 +AC_MSG_RESULT([    match_regex . . . . . $enable_match_regex])
 +AC_MSG_RESULT([    match_timediff  . . . $enable_match_timediff])
 +AC_MSG_RESULT([    match_value . . . . . $enable_match_value])
 +AC_MSG_RESULT([    mbmon . . . . . . . . $enable_mbmon])
 +AC_MSG_RESULT([    md  . . . . . . . . . $enable_md])
 +AC_MSG_RESULT([    memcachec . . . . . . $enable_memcachec])
 +AC_MSG_RESULT([    memcached . . . . . . $enable_memcached])
 +AC_MSG_RESULT([    memory  . . . . . . . $enable_memory])
 +AC_MSG_RESULT([    mic . . . . . . . . . $enable_mic])
 +AC_MSG_RESULT([    modbus  . . . . . . . $enable_modbus])
 +AC_MSG_RESULT([    mqtt  . . . . . . . . $enable_mqtt])
 +AC_MSG_RESULT([    multimeter  . . . . . $enable_multimeter])
 +AC_MSG_RESULT([    mysql . . . . . . . . $enable_mysql])
 +AC_MSG_RESULT([    netapp  . . . . . . . $enable_netapp])
 +AC_MSG_RESULT([    netlink . . . . . . . $enable_netlink])
 +AC_MSG_RESULT([    network . . . . . . . $enable_network])
 +AC_MSG_RESULT([    nfs . . . . . . . . . $enable_nfs])
 +AC_MSG_RESULT([    nginx . . . . . . . . $enable_nginx])
 +AC_MSG_RESULT([    notify_desktop  . . . $enable_notify_desktop])
 +AC_MSG_RESULT([    notify_email  . . . . $enable_notify_email])
 +AC_MSG_RESULT([    notify_nagios . . . . $enable_notify_nagios])
 +AC_MSG_RESULT([    ntpd  . . . . . . . . $enable_ntpd])
 +AC_MSG_RESULT([    numa  . . . . . . . . $enable_numa])
 +AC_MSG_RESULT([    nut . . . . . . . . . $enable_nut])
 +AC_MSG_RESULT([    olsrd . . . . . . . . $enable_olsrd])
 +AC_MSG_RESULT([    onewire . . . . . . . $enable_onewire])
 +AC_MSG_RESULT([    openldap  . . . . . . $enable_openldap])
 +AC_MSG_RESULT([    openvpn . . . . . . . $enable_openvpn])
 +AC_MSG_RESULT([    oracle  . . . . . . . $enable_oracle])
 +AC_MSG_RESULT([    perl  . . . . . . . . $enable_perl])
 +AC_MSG_RESULT([    pf  . . . . . . . . . $enable_pf])
 +AC_MSG_RESULT([    pinba . . . . . . . . $enable_pinba])
 +AC_MSG_RESULT([    ping  . . . . . . . . $enable_ping])
 +AC_MSG_RESULT([    postgresql  . . . . . $enable_postgresql])
 +AC_MSG_RESULT([    powerdns  . . . . . . $enable_powerdns])
 +AC_MSG_RESULT([    processes . . . . . . $enable_processes])
 +AC_MSG_RESULT([    protocols . . . . . . $enable_protocols])
 +AC_MSG_RESULT([    python  . . . . . . . $enable_python])
 +AC_MSG_RESULT([    redis . . . . . . . . $enable_redis])
 +AC_MSG_RESULT([    routeros  . . . . . . $enable_routeros])
 +AC_MSG_RESULT([    rrdcached . . . . . . $enable_rrdcached])
 +AC_MSG_RESULT([    rrdtool . . . . . . . $enable_rrdtool])
 +AC_MSG_RESULT([    sensors . . . . . . . $enable_sensors])
 +AC_MSG_RESULT([    serial  . . . . . . . $enable_serial])
 +AC_MSG_RESULT([    sigrok  . . . . . . . $enable_sigrok])
 +AC_MSG_RESULT([    smart . . . . . . . . $enable_smart])
 +AC_MSG_RESULT([    snmp  . . . . . . . . $enable_snmp])
 +AC_MSG_RESULT([    statsd  . . . . . . . $enable_statsd])
 +AC_MSG_RESULT([    swap  . . . . . . . . $enable_swap])
 +AC_MSG_RESULT([    syslog  . . . . . . . $enable_syslog])
 +AC_MSG_RESULT([    table . . . . . . . . $enable_table])
 +AC_MSG_RESULT([    tail_csv  . . . . . . $enable_tail_csv])
 +AC_MSG_RESULT([    tail  . . . . . . . . $enable_tail])
 +AC_MSG_RESULT([    tape  . . . . . . . . $enable_tape])
 +AC_MSG_RESULT([    target_notification . $enable_target_notification])
 +AC_MSG_RESULT([    target_replace  . . . $enable_target_replace])
 +AC_MSG_RESULT([    target_scale  . . . . $enable_target_scale])
 +AC_MSG_RESULT([    target_set  . . . . . $enable_target_set])
 +AC_MSG_RESULT([    target_v5upgrade  . . $enable_target_v5upgrade])
 +AC_MSG_RESULT([    tcpconns  . . . . . . $enable_tcpconns])
 +AC_MSG_RESULT([    teamspeak2  . . . . . $enable_teamspeak2])
 +AC_MSG_RESULT([    ted . . . . . . . . . $enable_ted])
 +AC_MSG_RESULT([    thermal . . . . . . . $enable_thermal])
 +AC_MSG_RESULT([    threshold . . . . . . $enable_threshold])
 +AC_MSG_RESULT([    tokyotyrant . . . . . $enable_tokyotyrant])
 +AC_MSG_RESULT([    turbostat . . . . . . $enable_turbostat])
 +AC_MSG_RESULT([    unixsock  . . . . . . $enable_unixsock])
 +AC_MSG_RESULT([    uptime  . . . . . . . $enable_uptime])
 +AC_MSG_RESULT([    users . . . . . . . . $enable_users])
 +AC_MSG_RESULT([    uuid  . . . . . . . . $enable_uuid])
 +AC_MSG_RESULT([    varnish . . . . . . . $enable_varnish])
 +AC_MSG_RESULT([    virt  . . . . . . . . $enable_virt])
 +AC_MSG_RESULT([    vmem  . . . . . . . . $enable_vmem])
 +AC_MSG_RESULT([    vserver . . . . . . . $enable_vserver])
 +AC_MSG_RESULT([    wireless  . . . . . . $enable_wireless])
 +AC_MSG_RESULT([    write_graphite  . . . $enable_write_graphite])
 +AC_MSG_RESULT([    write_http  . . . . . $enable_write_http])
 +AC_MSG_RESULT([    write_kafka . . . . . $enable_write_kafka])
 +AC_MSG_RESULT([    write_log . . . . . . $enable_write_log])
 +AC_MSG_RESULT([    write_mongodb . . . . $enable_write_mongodb])
 +AC_MSG_RESULT([    write_redis . . . . . $enable_write_redis])
 +AC_MSG_RESULT([    write_riemann . . . . $enable_write_riemann])
 +AC_MSG_RESULT([    write_sensu . . . . . $enable_write_sensu])
 +AC_MSG_RESULT([    write_tsdb  . . . . . $enable_write_tsdb])
 +AC_MSG_RESULT([    xencpu  . . . . . . . $enable_xencpu])
 +AC_MSG_RESULT([    xmms  . . . . . . . . $enable_xmms])
 +AC_MSG_RESULT([    zfs_arc . . . . . . . $enable_zfs_arc])
 +AC_MSG_RESULT([    zone  . . . . . . . . $enable_zone])
 +AC_MSG_RESULT([    zookeeper . . . . . . $enable_zookeeper])
 +AC_MSG_RESULT()
  
  if test "x$dependency_error" = "xyes"; then
        AC_MSG_ERROR("Some plugins are missing dependencies - see the summary above for details")
diff --combined src/battery.c
   **/
  
  #include "collectd.h"
 +
  #include "common.h"
  #include "plugin.h"
  
 -#include "utils_complain.h"
 -
  #if HAVE_MACH_MACH_TYPES_H
  #  include <mach/mach_types.h>
  #endif
@@@ -142,7 -143,7 +142,7 @@@ static void submit_capacity (char cons
  } /* }}} void submit_capacity */
  
  #if HAVE_IOKIT_PS_IOPOWERSOURCES_H || HAVE_IOKIT_IOKITLIB_H
 -static double dict_get_double (CFDictionaryRef dict, char *key_string) /* {{{ */
 +static double dict_get_double (CFDictionaryRef dict, const char *key_string) /* {{{ */
  {
        double      val_double;
        long long   val_int;
@@@ -202,6 -203,7 +202,6 @@@ static void get_via_io_power_sources (d
        CFTypeRef       ps_obj;
  
        double temp_double;
 -      int i;
  
        ps_raw       = IOPSCopyPowerSourcesInfo ();
        ps_array     = IOPSCopyPowerSourcesList (ps_raw);
  
        DEBUG ("ps_array_len == %i", ps_array_len);
  
 -      for (i = 0; i < ps_array_len; i++)
 +      for (int i = 0; i < ps_array_len; i++)
        {
                ps_obj  = CFArrayGetValueAtIndex (ps_array, i);
                ps_dict = IOPSGetPowerSourceDescription (ps_raw, ps_obj);
@@@ -274,6 -276,7 +274,6 @@@ static void get_via_generic_iokit (doub
        CFDictionaryRef bat_root_dict;
        CFArrayRef      bat_info_arry;
        CFIndex         bat_info_arry_len;
 -      CFIndex         bat_info_arry_pos;
        CFDictionaryRef bat_info_dict;
  
        double temp_double;
                }
                bat_info_arry_len = CFArrayGetCount (bat_info_arry);
  
 -              for (bat_info_arry_pos = 0;
 +              for (CFIndex bat_info_arry_pos = 0;
                                bat_info_arry_pos < bat_info_arry_len;
                                bat_info_arry_pos++)
                {
                                *ret_voltage = temp_double / 1000.0;
                        }
                }
 -              
 +
                CFRelease (bat_root_dict);
        }
  
@@@ -355,7 -358,7 +355,7 @@@ static int battery_read (void) /* {{{ *
         * IOPowerSources. IOKit, on the other hand, only reports the full
         * capacity. We use the two to calculate the current charged capacity. */
        gauge_t charge_rel = NAN; /* Current charge in percent */
 -      gauge_t capacity_charged = NAN; /* Charged capacity */
 +      gauge_t capacity_charged; /* Charged capacity */
        gauge_t capacity_full = NAN; /* Total capacity */
        gauge_t capacity_design = NAN; /* Full design capacity */
  
@@@ -712,10 -715,11 +712,10 @@@ static int read_acpi (void) /* {{{ *
  
  static int read_pmu (void) /* {{{ */
  {
 -      int i;
 -
 +      int i = 0;
        /* The upper limit here is just a safeguard. If there is a system with
         * more than 100 batteries, this can easily be increased. */
 -      for (i = 0; i < 100; i++)
 +      for (; i < 100; i++)
        {
                FILE *fh;
  
@@@ -793,14 -797,16 +793,14 @@@ static int battery_read (void) /* {{{ *
        if (status == 0)
                return (0);
  
-       ERROR ("battery plugin: Add available input methods failed.");
+       ERROR ("battery plugin: All available input methods failed.");
        return (-1);
  } /* }}} int battery_read */
  #endif /* KERNEL_LINUX */
  
  static int battery_config (oconfig_item_t *ci)
  {
 -      int i;
 -
 -      for (i = 0; i < ci->children_num; i++)
 +      for (int i = 0; i < ci->children_num; i++)
        {
                oconfig_item_t *child = ci->children + i;
  
diff --combined src/powerdns.c
@@@ -25,9 -25,9 +25,9 @@@
   **/
  
  #include "collectd.h"
 +
  #include "common.h"
  #include "plugin.h"
 -#include "configfile.h"
  #include "utils_llist.h"
  
  #include <sys/stat.h>
@@@ -37,6 -37,7 +37,6 @@@
  #include <string.h>
  #include <errno.h>
  #include <sys/types.h>
 -#include <sys/socket.h>
  #include <sys/un.h>
  
  #ifndef UNIX_PATH_MAX
@@@ -50,7 -51,7 +50,7 @@@
  #define RECURSOR_SOCKET  LOCALSTATEDIR"/run/pdns_recursor.controlsocket"
  #define RECURSOR_COMMAND "get noerror-answers nxdomain-answers " \
    "servfail-answers sys-msec user-msec qa-latency cache-entries cache-hits " \
-   "cache-misses questions\n"
+   "cache-misses questions \n"
  
  struct list_item_s;
  typedef struct list_item_s list_item_t;
@@@ -75,75 -76,52 +75,75 @@@ struct list_item_
  
  struct statname_lookup_s
  {
 -  char *name;
 -  char *type;
 -  char *type_instance;
 +  const char *name;
 +  const char *type;
 +  const char *type_instance;
  };
  typedef struct statname_lookup_s statname_lookup_t;
  
  /* Description of statistics returned by the recursor: {{{
 -all-outqueries      counts the number of outgoing UDP queries since starting
 -answers0-1          counts the number of queries answered within 1 millisecond
 -answers100-1000     counts the number of queries answered within 1 second
 -answers10-100       counts the number of queries answered within 100 milliseconds
 -answers1-10         counts the number of queries answered within 10 milliseconds
 -answers-slow        counts the number of queries answered after 1 second
 -cache-entries       shows the number of entries in the cache
 -cache-hits          counts the number of cache hits since starting
 -cache-misses        counts the number of cache misses since starting
 -chain-resends       number of queries chained to existing outstanding query
 -client-parse-errors counts number of client packets that could not be parsed
 -concurrent-queries  shows the number of MThreads currently running
 -dlg-only-drops      number of records dropped because of delegation only setting
 -negcache-entries    shows the number of entries in the Negative answer cache
 -noerror-answers     counts the number of times it answered NOERROR since starting
 -nsspeeds-entries    shows the number of entries in the NS speeds map
 -nsset-invalidations number of times an nsset was dropped because it no longer worked
 -nxdomain-answers    counts the number of times it answered NXDOMAIN since starting
 -outgoing-timeouts   counts the number of timeouts on outgoing UDP queries since starting
 -qa-latency          shows the current latency average
 -questions           counts all End-user initiated queries with the RD bit set
 -resource-limits     counts number of queries that could not be performed because of resource limits
 -server-parse-errors counts number of server replied packets that could not be parsed
 -servfail-answers    counts the number of times it answered SERVFAIL since starting
 -spoof-prevents      number of times PowerDNS considered itself spoofed, and dropped the data
 -sys-msec            number of CPU milliseconds spent in 'system' mode
 -tcp-client-overflow number of times an IP address was denied TCP access because it already had too many connections
 -tcp-outqueries      counts the number of outgoing TCP queries since starting
 -tcp-questions       counts all incoming TCP queries (since starting)
 -throttled-out       counts the number of throttled outgoing UDP queries since starting
 -throttle-entries    shows the number of entries in the throttle map
 -unauthorized-tcp    number of TCP questions denied because of allow-from restrictions
 -unauthorized-udp    number of UDP questions denied because of allow-from restrictions
 -unexpected-packets  number of answers from remote servers that were unexpected (might point to spoofing)
 -uptime              number of seconds process has been running (since 3.1.5)
 -user-msec           number of CPU milliseconds spent in 'user' mode
 +all-outqueries        counts the number of outgoing UDP queries since starting
 +answers-slow          counts the number of queries answered after 1 second
 +answers0-1            counts the number of queries answered within 1 millisecond
 +answers1-10           counts the number of queries answered within 10 milliseconds
 +answers10-100         counts the number of queries answered within 100 milliseconds
 +answers100-1000       counts the number of queries answered within 1 second
 +cache-bytes           size of the cache in bytes (since 3.3.1)
 +cache-entries         shows the number of entries in the cache
 +cache-hits            counts the number of cache hits since starting, this does not include hits that got answered from the packet-cache
 +cache-misses          counts the number of cache misses since starting
 +case-mismatches       counts the number of mismatches in character case since starting
 +chain-resends         number of queries chained to existing outstanding query
 +client-parse-errors   counts number of client packets that could not be parsed
 +concurrent-queries    shows the number of MThreads currently running
 +dlg-only-drops        number of records dropped because of delegation only setting
 +dont-outqueries       number of outgoing queries dropped because of 'dont-query' setting (since 3.3)
 +edns-ping-matches     number of servers that sent a valid EDNS PING respons
 +edns-ping-mismatches  number of servers that sent an invalid EDNS PING response
 +failed-host-entries   number of servers that failed to resolve
 +ipv6-outqueries       number of outgoing queries over IPv6
 +ipv6-questions        counts all End-user initiated queries with the RD bit set, received over IPv6 UDP
 +malloc-bytes          returns the number of bytes allocated by the process (broken, always returns 0)
 +max-mthread-stack     maximum amount of thread stack ever used
 +negcache-entries      shows the number of entries in the Negative answer cache
 +no-packet-error       number of errorneous received packets
 +noedns-outqueries     number of queries sent out without EDNS
 +noerror-answers       counts the number of times it answered NOERROR since starting
 +noping-outqueries     number of queries sent out without ENDS PING
 +nsset-invalidations   number of times an nsset was dropped because it no longer worked
 +nsspeeds-entries      shows the number of entries in the NS speeds map
 +nxdomain-answers      counts the number of times it answered NXDOMAIN since starting
 +outgoing-timeouts     counts the number of timeouts on outgoing UDP queries since starting
 +over-capacity-drops   questions dropped because over maximum concurrent query limit (since 3.2)
 +packetcache-bytes     size of the packet cache in bytes (since 3.3.1)
 +packetcache-entries   size of packet cache (since 3.2)
 +packetcache-hits      packet cache hits (since 3.2)
 +packetcache-misses    packet cache misses (since 3.2)
 +policy-drops          packets dropped because of (Lua) policy decision
 +qa-latency            shows the current latency average
 +questions             counts all end-user initiated queries with the RD bit set
 +resource-limits       counts number of queries that could not be performed because of resource limits
 +security-status       security status based on security polling
 +server-parse-errors   counts number of server replied packets that could not be parsed
 +servfail-answers      counts the number of times it answered SERVFAIL since starting
 +spoof-prevents        number of times PowerDNS considered itself spoofed, and dropped the data
 +sys-msec              number of CPU milliseconds spent in 'system' mode
 +tcp-client-overflow   number of times an IP address was denied TCP access because it already had too many connections
 +tcp-clients           counts the number of currently active TCP/IP clients
 +tcp-outqueries        counts the number of outgoing TCP queries since starting
 +tcp-questions         counts all incoming TCP queries (since starting)
 +throttle-entries      shows the number of entries in the throttle map
 +throttled-out         counts the number of throttled outgoing UDP queries since starting
 +throttled-outqueries  idem to throttled-out
 +unauthorized-tcp      number of TCP questions denied because of allow-from restrictions
 +unauthorized-udp      number of UDP questions denied because of allow-from restrictions
 +unexpected-packets    number of answers from remote servers that were unexpected (might point to spoofing)
 +unreachables          number of times nameservers were unreachable since starting
 +uptime                number of seconds process has been running (since 3.1.5)
 +user-msec             number of CPU milliseconds spent in 'user' mode
  }}} */
  
 -const char* const default_server_fields[] = /* {{{ */
 +static const char* const default_server_fields[] = /* {{{ */
  {
    "latency",
    "packetcache-hit",
    "udp-answers",
    "udp-queries",
  }; /* }}} */
 -int default_server_fields_num = STATIC_ARRAY_SIZE (default_server_fields);
 +static int default_server_fields_num = STATIC_ARRAY_SIZE (default_server_fields);
  
 -statname_lookup_t lookup_table[] = /* {{{ */
 +static statname_lookup_t lookup_table[] = /* {{{ */
  {
    /*********************
     * Server statistics *
    {"udp-answers-bytes",      "total_bytes",  "udp-answers-bytes"},
  
    /* Cache stuff */
 +  {"cache-bytes",            "cache_size",   "cache-bytes"},
 +  {"packetcache-bytes",      "cache_size",   "packet-bytes"},
 +  {"packetcache-entries",    "cache_size",   "packet-entries"},
    {"packetcache-hit",        "cache_result", "packet-hit"},
 +  {"packetcache-hits",       "cache_result", "packet-hit"},
    {"packetcache-miss",       "cache_result", "packet-miss"},
 +  {"packetcache-misses",     "cache_result", "packet-miss"},
    {"packetcache-size",       "cache_size",   "packet"},
    {"key-cache-size",         "cache_size",   "key"},
    {"meta-cache-size",        "cache_size",   "meta"},
    {"corrupt-packets",        "ipt_packets",  "corrupt"},
    {"deferred-cache-inserts", "counter",      "cache-deferred_insert"},
    {"deferred-cache-lookup",  "counter",      "cache-deferred_lookup"},
 +  {"dont-outqueries",        "dns_question", "dont-outqueries"},
    {"qsize-a",                "cache_size",   "answers"},
    {"qsize-q",                "cache_size",   "questions"},
    {"servfail-packets",       "ipt_packets",  "servfail"},
     * Recursor statistics *
     ***********************/
    /* Answers by return code */
 -  {"noerror-answers",     "dns_rcode",    "NOERROR"},
 -  {"nxdomain-answers",    "dns_rcode",    "NXDOMAIN"},
 -  {"servfail-answers",    "dns_rcode",    "SERVFAIL"},
 +  {"noerror-answers",      "dns_rcode",    "NOERROR"},
 +  {"nxdomain-answers",     "dns_rcode",    "NXDOMAIN"},
 +  {"servfail-answers",     "dns_rcode",    "SERVFAIL"},
  
    /* CPU utilization */
 -  {"sys-msec",            "cpu",          "system"},
 -  {"user-msec",           "cpu",          "user"},
 +  {"sys-msec",             "cpu",          "system"},
 +  {"user-msec",            "cpu",          "user"},
  
    /* Question-to-answer latency */
 -  {"qa-latency",          "latency",      NULL},
 +  {"qa-latency",           "latency",      NULL},
  
    /* Cache */
 -  {"cache-entries",       "cache_size",   NULL},
 -  {"cache-hits",          "cache_result", "hit"},
 -  {"cache-misses",        "cache_result", "miss"},
 +  {"cache-entries",        "cache_size",   NULL},
 +  {"cache-hits",           "cache_result", "hit"},
 +  {"cache-misses",         "cache_result", "miss"},
  
    /* Total number of questions.. */
 -  {"questions",           "dns_qtype",    "total"},
 +  {"questions",            "dns_qtype",    "total"},
  
    /* All the other stuff.. */
 -  {"all-outqueries",      "dns_question", "outgoing"},
 -  {"answers0-1",          "dns_answer",   "0_1"},
 -  {"answers1-10",         "dns_answer",   "1_10"},
 -  {"answers10-100",       "dns_answer",   "10_100"},
 -  {"answers100-1000",     "dns_answer",   "100_1000"},
 -  {"answers-slow",        "dns_answer",   "slow"},
 -  {"chain-resends",       "dns_question", "chained"},
 -  {"client-parse-errors", "counter",      "drops-client_parse_error"},
 -  {"concurrent-queries",  "dns_question", "concurrent"},
 -  {"dlg-only-drops",      "counter",      "drops-delegation_only"},
 -  {"negcache-entries",    "cache_size",   "negative"},
 -  {"nsspeeds-entries",    "gauge",        "entries-ns_speeds"},
 -  {"nsset-invalidations", "counter",      "ns_set_invalidation"},
 -  {"outgoing-timeouts",   "counter",      "drops-timeout_outgoing"},
 -  {"resource-limits",     "counter",      "drops-resource_limit"},
 -  {"server-parse-errors", "counter",      "drops-server_parse_error"},
 -  {"spoof-prevents",      "counter",      "drops-spoofed"},
 -  {"tcp-client-overflow", "counter",      "denied-client_overflow_tcp"},
 -  {"tcp-outqueries",      "dns_question", "outgoing-tcp"},
 -  {"tcp-questions",       "dns_question", "incoming-tcp"},
 -  {"throttled-out",       "dns_question", "outgoing-throttled"},
 -  {"throttle-entries",    "gauge",        "entries-throttle"},
 -  {"unauthorized-tcp",    "counter",      "denied-unauthorized_tcp"},
 -  {"unauthorized-udp",    "counter",      "denied-unauthorized_udp"},
 -  {"unexpected-packets",  "dns_answer",   "unexpected"},
 -  {"uptime",              "uptime",       NULL}
 +  {"all-outqueries",       "dns_question", "outgoing"},
 +  {"answers0-1",           "dns_answer",   "0_1"},
 +  {"answers1-10",          "dns_answer",   "1_10"},
 +  {"answers10-100",        "dns_answer",   "10_100"},
 +  {"answers100-1000",      "dns_answer",   "100_1000"},
 +  {"answers-slow",         "dns_answer",   "slow"},
 +  {"case-mismatches",      "counter",      "case_mismatches"},
 +  {"chain-resends",        "dns_question", "chained"},
 +  {"client-parse-errors",  "counter",      "drops-client_parse_error"},
 +  {"concurrent-queries",   "dns_question", "concurrent"},
 +  {"dlg-only-drops",       "counter",      "drops-delegation_only"},
 +  {"edns-ping-matches",    "counter",      "edns-ping_matches"},
 +  {"edns-ping-mismatches", "counter",      "edns-ping_mismatches"},
 +  {"failed-host-entries",  "counter",      "entries-failed_host"},
 +  {"ipv6-outqueries",      "dns_question", "outgoing-ipv6"},
 +  {"ipv6-questions",       "dns_question", "incoming-ipv6"},
 +  {"malloc-bytes",         "gauge",        "malloc_bytes"},
 +  {"max-mthread-stack",    "gauge",        "max_mthread_stack"},
 +  {"no-packet-error",      "gauge",        "no_packet_error"},
 +  {"noedns-outqueries",    "dns_question", "outgoing-noedns"},
 +  {"noping-outqueries",    "dns_question", "outgoing-noping"},
 +  {"over-capacity-drops",  "dns_question", "incoming-over_capacity"},
 +  {"negcache-entries",     "cache_size",   "negative"},
 +  {"nsspeeds-entries",     "gauge",        "entries-ns_speeds"},
 +  {"nsset-invalidations",  "counter",      "ns_set_invalidation"},
 +  {"outgoing-timeouts",    "counter",      "drops-timeout_outgoing"},
 +  {"policy-drops",         "counter",      "drops-policy"},
 +  {"resource-limits",      "counter",      "drops-resource_limit"},
 +  {"server-parse-errors",  "counter",      "drops-server_parse_error"},
 +  {"spoof-prevents",       "counter",      "drops-spoofed"},
 +  {"tcp-client-overflow",  "counter",      "denied-client_overflow_tcp"},
 +  {"tcp-clients",          "gauge",        "clients-tcp"},
 +  {"tcp-outqueries",       "dns_question", "outgoing-tcp"},
 +  {"tcp-questions",        "dns_question", "incoming-tcp"},
 +  {"throttled-out",        "dns_question", "outgoing-throttled"},
 +  {"throttle-entries",     "gauge",        "entries-throttle"},
 +  {"throttled-outqueries", "dns_question", "outgoing-throttle"},
 +  {"unauthorized-tcp",     "counter",      "denied-unauthorized_tcp"},
 +  {"unauthorized-udp",     "counter",      "denied-unauthorized_udp"},
 +  {"unexpected-packets",   "dns_answer",   "unexpected"},
 +  {"uptime",               "uptime",       NULL}
  }; /* }}} */
 -int lookup_table_length = STATIC_ARRAY_SIZE (lookup_table);
 +static int lookup_table_length = STATIC_ARRAY_SIZE (lookup_table);
  
  static llist_t *list = NULL;
  
  static char *local_sockpath = NULL;
  
  /* TODO: Do this before 4.4:
 - * - Recursor:
 - *   - Complete list of known pdns -> collectd mappings.
   * - Update the collectd.conf(5) manpage.
   *
   * -octo
   */
  
 -/* <http://doc.powerdns.com/recursor-stats.html> */
 +/* <https://doc.powerdns.com/md/recursor/stats/> */
  static void submit (const char *plugin_instance, /* {{{ */
      const char *pdns_type, const char *value)
  {
  
    if (ds->ds_num != 1)
    {
 -    ERROR ("powerdns plugin: type `%s' has %i data sources, "
 +    ERROR ("powerdns plugin: type `%s' has %zu data sources, "
          "but I can only handle one.",
          type, ds->ds_num);
      return;
@@@ -375,7 -334,7 +375,7 @@@ static int powerdns_get_data_dgram (lis
    char *buffer = NULL;
    size_t buffer_size = 0;
  
 -  struct sockaddr_un sa_unix;
 +  struct sockaddr_un sa_unix = { 0 };
  
    struct timeval stv_timeout;
    cdtime_t cdt_timeout;
      return (-1);
    }
  
 -  memset (&sa_unix, 0, sizeof (sa_unix));
    sa_unix.sun_family = AF_UNIX;
    sstrncpy (sa_unix.sun_path,
        (local_sockpath != NULL) ? local_sockpath : PDNS_LOCAL_SOCKPATH,
      return (-1);
  
    assert (buffer_size > 0);
 -  buffer = (char *) malloc (buffer_size);
 +  buffer = malloc (buffer_size);
    if (buffer == NULL)
    {
      FUNC_ERROR ("malloc");
@@@ -541,7 -501,7 +541,7 @@@ static int powerdns_get_data_stream (li
      else if (status == 0)
        break;
  
 -    buffer_new = (char *) realloc (buffer, buffer_size + status + 1);
 +    buffer_new = realloc (buffer, buffer_size + status + 1);
      if (buffer_new == NULL)
      {
        FUNC_ERROR ("realloc");
@@@ -630,6 -590,8 +630,6 @@@ static int powerdns_read_server (list_i
    saveptr = NULL;
    while ((key = strtok_r (dummy, ",", &saveptr)) != NULL)
    {
 -    int i;
 -
      dummy = NULL;
  
      value = strchr (key, '=');
        continue;
  
      /* Check if this item was requested. */
 +    int i;
      for (i = 0; i < fields_num; i++)
        if (strcasecmp (key, fields[i]) == 0)
        break;
@@@ -689,12 -650,12 +689,12 @@@ static int powerdns_update_recursor_com
        return (-1);
      }
      buffer[sizeof (buffer) - 1] = 0;
 -    int i = strlen (buffer);
 -    if (i < sizeof (buffer) - 2)
 +    size_t len = strlen (buffer);
 +    if (len < sizeof (buffer) - 2)
      {
 -      buffer[i++] = ' ';
 -      buffer[i++] = '\n';
 -      buffer[i++] = '\0';
 +      buffer[len++] = ' ';
 +      buffer[len++] = '\n';
 +      buffer[len++] = '\0';
      }
    }
  
@@@ -779,6 -740,7 +779,6 @@@ static int powerdns_read_recursor (list
  static int powerdns_config_add_collect (list_item_t *li, /* {{{ */
      oconfig_item_t *ci)
  {
 -  int i;
    char **temp;
  
    if (ci->values_num < 1)
      return (-1);
    }
  
 -  for (i = 0; i < ci->values_num; i++)
 +  for (int i = 0; i < ci->values_num; i++)
      if (ci->values[i].type != OCONFIG_TYPE_STRING)
      {
        WARNING ("powerdns plugin: Only string arguments are allowed to "
        return (-1);
      }
  
 -  temp = (char **) realloc (li->fields,
 +  temp = realloc (li->fields,
        sizeof (char *) * (li->fields_num + ci->values_num));
    if (temp == NULL)
    {
    }
    li->fields = temp;
  
 -  for (i = 0; i < ci->values_num; i++)
 +  for (int i = 0; i < ci->values_num; i++)
    {
      li->fields[li->fields_num] = strdup (ci->values[i].value.string);
      if (li->fields[li->fields_num] == NULL)
@@@ -828,6 -790,7 +828,6 @@@ static int powerdns_config_add_server (
  
    list_item_t *item;
    int status;
 -  int i;
  
    if ((ci->values_num != 1) || (ci->values[0].type != OCONFIG_TYPE_STRING))
    {
      return (-1);
    }
  
 -  item = (list_item_t *) malloc (sizeof (list_item_t));
 +  item = calloc (1, sizeof (*item));
    if (item == NULL)
    {
 -    ERROR ("powerdns plugin: malloc failed.");
 +    ERROR ("powerdns plugin: calloc failed.");
      return (-1);
    }
 -  memset (item, '\0', sizeof (list_item_t));
  
    item->instance = strdup (ci->values[0].value.string);
    if (item->instance == NULL)
    }
  
    status = 0;
 -  for (i = 0; i < ci->children_num; i++)
 +  for (int i = 0; i < ci->children_num; i++)
    {
      oconfig_item_t *option = ci->children + i;
  
  
  static int powerdns_config (oconfig_item_t *ci) /* {{{ */
  {
 -  int i;
 -
    DEBUG ("powerdns plugin: powerdns_config (ci = %p);", (void *) ci);
  
    if (list == NULL)
      }
    }
  
 -  for (i = 0; i < ci->children_num; i++)
 +  for (int i = 0; i < ci->children_num; i++)
    {
      oconfig_item_t *option = ci->children + i;
  
  
  static int powerdns_read (void)
  {
 -  llentry_t *e;
 -
 -  for (e = llist_head (list); e != NULL; e = e->next)
 +  for (llentry_t *e = llist_head (list); e != NULL; e = e->next)
    {
      list_item_t *item = e->value;
      item->func (item);
  
  static int powerdns_shutdown (void)
  {
 -  llentry_t *e;
 -
    if (list == NULL)
      return (0);
  
 -  for (e = llist_head (list); e != NULL; e = e->next)
 +  for (llentry_t *e = llist_head (list); e != NULL; e = e->next)
    {
      list_item_t *item = (list_item_t *) e->value;
      e->value = NULL;
@@@ -22,7 -22,6 +22,7 @@@
   **/
  
  #include "collectd.h"
 +
  #include "plugin.h"
  #include "common.h"
  
@@@ -85,12 -84,14 +85,12 @@@ static int gr_format_values (char *ret
  static void gr_copy_escape_part (char *dst, const char *src, size_t dst_len,
      char escape_char)
  {
 -    size_t i;
 -
      memset (dst, 0, dst_len);
  
      if (src == NULL)
          return;
  
 -    for (i = 0; i < dst_len; i++)
 +    for (size_t i = 0; i < dst_len; i++)
      {
          if (src[i] == 0)
          {
@@@ -171,9 -172,11 +171,9 @@@ static int gr_format_name (char *ret, i
  
  static void escape_graphite_string (char *buffer, char escape_char)
  {
 -      char *head;
 -
        assert (strchr(GRAPHITE_FORBIDDEN, escape_char) == NULL);
  
 -      for (head = buffer + strcspn(buffer, GRAPHITE_FORBIDDEN);
 +      for (char *head = buffer + strcspn(buffer, GRAPHITE_FORBIDDEN);
             *head != '\0';
             head += strcspn(head, GRAPHITE_FORBIDDEN))
                *head = escape_char;
@@@ -185,13 -188,14 +185,13 @@@ int format_graphite (char *buffer, size
      unsigned int flags)
  {
      int status = 0;
 -    int i;
      int buffer_pos = 0;
  
      gauge_t *rates = NULL;
      if (flags & GRAPHITE_STORE_RATES)
        rates = uc_get_rate (ds, vl);
  
 -    for (i = 0; i < ds->ds_num; i++)
 +    for (size_t i = 0; i < ds->ds_num; i++)
      {
          char const *ds_name = NULL;
          char        key[10*DATA_MAX_NAME_LEN];
          }
          memcpy((void *) (buffer + buffer_pos), message, message_len);
          buffer_pos += message_len;
+         buffer[buffer_pos] = '\0';
      }
      sfree (rates);
      return (status);