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 ]) |