Mercurial > repos > ktnyt > gembassy
comparison GEMBASSY-1.0.3/m4/postgresql.m4 @ 0:8300eb051bea draft
Initial upload
| author | ktnyt | 
|---|---|
| date | Fri, 26 Jun 2015 05:19:29 -0400 | 
| parents | |
| children | 
   comparison
  equal
  deleted
  inserted
  replaced
| -1:000000000000 | 0:8300eb051bea | 
|---|---|
| 1 dnl -*- Autoconf -*- | |
| 2 ##### http://autoconf-archive.cryp.to/ax_lib_postgresql.html | |
| 3 # | |
| 4 # SYNOPSIS | |
| 5 # | |
| 6 # AX_LIB_POSTGRESQL([MINIMUM-VERSION]) | |
| 7 # | |
| 8 # DESCRIPTION | |
| 9 # | |
| 10 # This macro provides tests of availability of PostgreSQL 'libpq' | |
| 11 # library of particular version or newer. | |
| 12 # | |
| 13 # AX_LIB_POSTGRESQL macro takes only one argument which is optional. | |
| 14 # If there is no required version passed, then macro does not run | |
| 15 # version test. | |
| 16 # | |
| 17 # The --with-postgresql option takes one of three possible values: | |
| 18 # | |
| 19 # no - do not check for PostgreSQL client library | |
| 20 # | |
| 21 # yes - do check for PostgreSQL library in standard locations | |
| 22 # (pg_config should be in the PATH) | |
| 23 # | |
| 24 # path - complete path to pg_config utility, use this option if | |
| 25 # pg_config can't be found in the PATH | |
| 26 # | |
| 27 # This macro calls: | |
| 28 # | |
| 29 # AC_SUBST([POSTGRESQL_CFLAGS]) | |
| 30 # AC_SUBST([POSTGRESQL_CPPFLAGS]) | |
| 31 # AC_SUBST([POSTGRESQL_LDFLAGS]) | |
| 32 # AC_SUBST([POSTGRESQL_VERSION]) | |
| 33 # | |
| 34 # And sets: | |
| 35 # | |
| 36 # HAVE_POSTGRESQL | |
| 37 # | |
| 38 # LAST MODIFICATION | |
| 39 # | |
| 40 # 2006-07-16 | |
| 41 # 2010-05-14 MKS: Added POSTGRESQL_CPPFLAGS | |
| 42 # 2011-06-21 AJB: Added workaround for Fedora pg_config oddity | |
| 43 # 2011-08-01 MKS: Changed PG_CONFIG to POSTGRESQL_CONFIG | |
| 44 # Made test constructs more portable | |
| 45 # | |
| 46 # COPYLEFT | |
| 47 # | |
| 48 # Copyright (c) 2006 Mateusz Loskot <mateusz@loskot.net> | |
| 49 # | |
| 50 # Copying and distribution of this file, with or without | |
| 51 # modification, are permitted in any medium without royalty provided | |
| 52 # the copyright notice and this notice are preserved. | |
| 53 | |
| 54 AC_DEFUN([AX_LIB_POSTGRESQL], | |
| 55 [ | |
| 56 POSTGRESQL_CFLAGS="" | |
| 57 POSTGRESQL_CPPFLAGS="" | |
| 58 POSTGRESQL_LDFLAGS="" | |
| 59 POSTGRESQL_CONFIG="" | |
| 60 POSTGRESQL_VERSION="" | |
| 61 | |
| 62 AC_ARG_WITH([postgresql], | |
| 63 [AS_HELP_STRING([--with-postgresql@<:=@ARG@:>@], | |
| 64 [use PostgreSQL library @<:@default=yes@:>@, optionally specify path to pg_config])], | |
| 65 [ | |
| 66 AS_IF([test "x${withval}" = "xno"], | |
| 67 [want_postgresql="no"], | |
| 68 [test "x${withval}" = "xyes"], | |
| 69 [want_postgresql="yes"], | |
| 70 [ | |
| 71 want_postgresql="yes" | |
| 72 POSTGRESQL_CONFIG="${withval}" | |
| 73 ]) | |
| 74 ], | |
| 75 [want_postgresql="yes"]) | |
| 76 | |
| 77 dnl | |
| 78 dnl Check PostgreSQL libraries (libpq) | |
| 79 dnl | |
| 80 | |
| 81 AS_IF([test "x${want_postgresql}" = "xyes"], | |
| 82 [ | |
| 83 AS_IF([test -z "${POSTGRESQL_CONFIG}" -o test], | |
| 84 [AC_PATH_PROG([POSTGRESQL_CONFIG], [pg_config], [no])]) | |
| 85 | |
| 86 AS_IF([test "x${POSTGRESQL_CONFIG}" != "xno"], | |
| 87 [ | |
| 88 AC_MSG_CHECKING([for PostgreSQL libraries]) | |
| 89 | |
| 90 POSTGRESQL_CFLAGS="-I`${POSTGRESQL_CONFIG} --includedir`" | |
| 91 POSTGRESQL_CPPFLAGS="-I`${POSTGRESQL_CONFIG} --includedir`" | |
| 92 POSTGRESQL_LDFLAGS="-L`${POSTGRESQL_CONFIG} --libdir` -lpq" | |
| 93 | |
| 94 POSTGRESQL_VERSION=`${POSTGRESQL_CONFIG} --version | sed -e 's#PostgreSQL ##'` | |
| 95 | |
| 96 dnl It isn't enough to just test for pg_config as Fedora | |
| 97 dnl provides it in the postgresql RPM even though postgresql-devel may | |
| 98 dnl not be installed | |
| 99 | |
| 100 EMBCPPFLAGS="${CPPFLAGS}" | |
| 101 EMBLDFLAGS="${LDFLAGS}" | |
| 102 | |
| 103 CPPFLAGS="${POSTGRESQL_CPPFLAGS} ${EMBCPPFLAGS}" | |
| 104 LDFLAGS="${POSTGRESQL_LDFLAGS} ${EMBLDFLAGS}" | |
| 105 | |
| 106 AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <stdio.h> | |
| 107 #include "libpq-fe.h"]], | |
| 108 [[PQconnectdb(NULL)]])], | |
| 109 [havepostgresql="yes"], | |
| 110 [havepostgresql="no"]) | |
| 111 | |
| 112 CPPFLAGS="${EMBCPPFLAGS}" | |
| 113 LDFLAGS="${EMBLDFLAGS}" | |
| 114 | |
| 115 AS_IF([test "x${havepostgresql}" = "xyes"], | |
| 116 [ | |
| 117 AC_DEFINE([HAVE_POSTGRESQL], [1], | |
| 118 [Define to 1 if PostgreSQL libraries are available.]) | |
| 119 found_postgresql="yes" | |
| 120 AC_MSG_RESULT([yes]) | |
| 121 ], | |
| 122 [ | |
| 123 POSTGRESQL_CFLAGS="" | |
| 124 POSTGRESQL_CPPFLAGS="" | |
| 125 POSTGRESQL_LDFLAGS="" | |
| 126 found_postgresql="no" | |
| 127 AC_MSG_RESULT([no]) | |
| 128 ]) | |
| 129 ], | |
| 130 [ | |
| 131 found_postgresql="no" | |
| 132 ]) | |
| 133 ]) | |
| 134 | |
| 135 dnl | |
| 136 dnl Check if required version of PostgreSQL is available | |
| 137 dnl | |
| 138 | |
| 139 postgresql_version_req=ifelse([$1], [], [], [$1]) | |
| 140 | |
| 141 AS_IF([test "x${found_postgresql}" = "xyes" -a -n "${postgresql_version_req}"], | |
| 142 [ | |
| 143 AC_MSG_CHECKING([if PostgreSQL version is >= ${postgresql_version_req}]) | |
| 144 | |
| 145 dnl Decompose required version string of PostgreSQL | |
| 146 dnl and calculate its number representation | |
| 147 | |
| 148 postgresql_version_req_major=`expr ${postgresql_version_req} : '\([[0-9]]*\)'` | |
| 149 postgresql_version_req_minor=`expr ${postgresql_version_req} : '[[0-9]]*\.\([[0-9]]*\)'` | |
| 150 postgresql_version_req_micro=`expr ${postgresql_version_req} : '[[0-9]]*\.[[0-9]]*\.\([[0-9]]*\)'` | |
| 151 | |
| 152 AS_IF([test "x${postgresql_version_req_micro}" = "x"], | |
| 153 [postgresql_version_req_micro="0"]) | |
| 154 | |
| 155 postgresql_version_req_number=`expr ${postgresql_version_req_major} \* 1000000 \ | |
| 156 \+ ${postgresql_version_req_minor} \* 1000 \ | |
| 157 \+ ${postgresql_version_req_micro}` | |
| 158 | |
| 159 dnl Decompose version string of installed PostgreSQL | |
| 160 dnl and calculate its number representation | |
| 161 | |
| 162 postgresql_version_major=`expr ${POSTGRESQL_VERSION} : '\([[0-9]]*\)'` | |
| 163 postgresql_version_minor=`expr ${POSTGRESQL_VERSION} : '[[0-9]]*\.\([[0-9]]*\)'` | |
| 164 postgresql_version_micro=`expr ${POSTGRESQL_VERSION} : '[[0-9]]*\.[[0-9]]*\.\([[0-9]]*\)'` | |
| 165 | |
| 166 AS_IF([test "x${postgresql_version_micro}" = "x"], | |
| 167 [postgresql_version_micro="0"]) | |
| 168 | |
| 169 postgresql_version_number=`expr ${postgresql_version_major} \* 1000000 \ | |
| 170 \+ ${postgresql_version_minor} \* 1000 \ | |
| 171 \+ ${postgresql_version_micro}` | |
| 172 | |
| 173 postgresql_version_check=`expr ${postgresql_version_number} \>\= ${postgresql_version_req_number}` | |
| 174 | |
| 175 AS_IF([test "x${postgresql_version_check}" = "x1"], | |
| 176 [AC_MSG_RESULT([yes])], | |
| 177 [AC_MSG_RESULT([no])]) | |
| 178 ]) | |
| 179 | |
| 180 AC_SUBST([POSTGRESQL_CFLAGS]) | |
| 181 AC_SUBST([POSTGRESQL_CPPFLAGS]) | |
| 182 AC_SUBST([POSTGRESQL_LDFLAGS]) | |
| 183 AC_SUBST([POSTGRESQL_VERSION]) | |
| 184 ]) | 
