diff --git a/m4/ax_lib_xml2.m4 b/m4/ax_lib_xml2.m4 new file mode 100644 index 00000000..d0cd2cb5 --- /dev/null +++ b/m4/ax_lib_xml2.m4 @@ -0,0 +1,150 @@ +# SYNOPSIS +# +# AX_LIB_XML2([MINIMUM-VERSION]) +# +# DESCRIPTION +# +# This macro provides tests of availability of xml2 'libxml2' library +# of particular version or newer. +# +# AX_LIB_LIBXML2 macro takes only one argument which is optional. If +# there is no required version passed, then macro does not run version +# test. +# +# The --with-libxml2 option takes one of three possible values: +# +# no - do not check for xml2 library +# +# yes - do check for xml2 library in standard locations (xml2-config +# should be in the PATH) +# +# path - complete path to xml2-config utility, use this option if xml2-config +# can't be found in the PATH +# +# This macro calls: +# +# AC_SUBST(XML2_CFLAGS) +# AC_SUBST(XML2_LDFLAGS) +# AC_SUBST(XML2_VERSION) +# +# And sets: +# +# HAVE_XML2 +# +# LICENSE +# +# Copyright (c) 2009 Hartmut Holzgraefe +# +# Copying and distribution of this file, with or without modification, are +# permitted in any medium without royalty provided the copyright notice +# and this notice are preserved. + +AC_DEFUN([AX_LIB_XML2], +[ + AC_ARG_WITH([libxml2], + AC_HELP_STRING([--with-libxml2=@<:@ARG@:>@], + [use libxml2 library @<:@default=yes@:>@, optionally specify path to xml2-config] + ), + [ + if test "$withval" = "no"; then + want_libxml2="no" + elif test "$withval" = "yes"; then + want_libxml2="yes" + else + want_libxml2="yes" + XML2_CONFIG="$withval" + fi + ], + [want_libxml2="yes"] + ) + + XML2_CFLAGS="" + XML2_LDFLAGS="" + XML2_VERSION="" + + dnl + dnl Check xml2 libraries (libxml2) + dnl + + if test "$want_libxml2" = "yes"; then + + if test -z "$XML2_CONFIG" -o test; then + AC_PATH_PROG([XML2_CONFIG], [xml2-config], []) + fi + + if test ! -x "$XML2_CONFIG"; then + AC_MSG_ERROR([$XML2_CONFIG does not exist or it is not an exectuable file]) + XML2_CONFIG="no" + found_libxml2="no" + fi + + if test "$XML2_CONFIG" != "no"; then + AC_MSG_CHECKING([for xml2 libraries]) + + XML2_CFLAGS="`$XML2_CONFIG --cflags`" + XML2_LDFLAGS="`$XML2_CONFIG --libs`" + + XML2_VERSION=`$XML2_CONFIG --version` + + AC_DEFINE([HAVE_XML2], [1], + [Define to 1 if xml2 libraries are available]) + + found_libxml2="yes" + AC_MSG_RESULT([yes]) + else + found_libxml2="no" + AC_MSG_RESULT([no]) + fi + fi + + dnl + dnl Check if required version of xml2 is available + dnl + + + libxml2_version_req=ifelse([$1], [], [], [$1]) + + + if test "$found_libxml2" = "yes" -a -n "$libxml2_version_req"; then + + AC_MSG_CHECKING([if libxml2 version is >= $libxml2_version_req]) + + dnl Decompose required version string of libxml2 + dnl and calculate its number representation + libxml2_version_req_major=`expr $libxml2_version_req : '\([[0-9]]*\)'` + libxml2_version_req_minor=`expr $libxml2_version_req : '[[0-9]]*\.\([[0-9]]*\)'` + libxml2_version_req_micro=`expr $libxml2_version_req : '[[0-9]]*\.[[0-9]]*\.\([[0-9]]*\)'` + if test "x$libxml2_version_req_micro" = "x"; then + libxml2_version_req_micro="0" + fi + + libxml2_version_req_number=`expr $libxml2_version_req_major \* 1000000 \ + \+ $libxml2_version_req_minor \* 1000 \ + \+ $libxml2_version_req_micro` + + dnl Decompose version string of installed PostgreSQL + dnl and calculate its number representation + libxml2_version_major=`expr $XML2_VERSION : '\([[0-9]]*\)'` + libxml2_version_minor=`expr $XML2_VERSION : '[[0-9]]*\.\([[0-9]]*\)'` + libxml2_version_micro=`expr $XML2_VERSION : '[[0-9]]*\.[[0-9]]*\.\([[0-9]]*\)'` + if test "x$libxml2_version_micro" = "x"; then + libxml2_version_micro="0" + fi + + libxml2_version_number=`expr $libxml2_version_major \* 1000000 \ + \+ $libxml2_version_minor \* 1000 \ + \+ $libxml2_version_micro` + + libxml2_version_check=`expr $libxml2_version_number \>\= $libxml2_version_req_number` + if test "$libxml2_version_check" = "1"; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + fi + fi + + AC_SUBST([XML2_VERSION]) + AC_SUBST([XML2_CFLAGS]) + AC_SUBST([XML2_LDFLAGS]) +]) +