blob: 7c2856efc92ca55e3cf03fcf1c72ffb70318f7c3 [file] [log] [blame]
Jakub Narebski55667712006-07-03 01:56:48 +02001# -*- Autoconf -*-
2# Process this file with autoconf to produce a configure script.
3
4AC_PREREQ(2.59)
Jakub Narebski39001452006-08-08 18:35:23 +02005AC_INIT([git], [@@GIT_VERSION@@], [git@vger.kernel.org])
Jakub Narebski55667712006-07-03 01:56:48 +02006
7AC_CONFIG_SRCDIR([git.c])
8
9config_file=config.mak.autogen
Jakub Narebskid3a6db92006-07-08 23:07:09 +020010config_append=config.mak.append
Jakub Narebski55667712006-07-03 01:56:48 +020011config_in=config.mak.in
12
Jakub Narebskid3a6db92006-07-08 23:07:09 +020013echo "# ${config_append}. Generated by configure." > "${config_append}"
14
15
16## Definitions of macros
17# GIT_CONF_APPEND_LINE(LINE)
18# --------------------------
19# Append LINE to file ${config_append}
20AC_DEFUN([GIT_CONF_APPEND_LINE],
21[echo "$1" >> "${config_append}"])# GIT_CONF_APPEND_LINE
Jakub Narebski657b0622006-08-03 00:38:11 +020022#
23# GIT_ARG_SET_PATH(PROGRAM)
24# -------------------------
25# Provide --with-PROGRAM=PATH option to set PATH to PROGRAM
26AC_DEFUN([GIT_ARG_SET_PATH],
27[AC_ARG_WITH([$1],
28 [AS_HELP_STRING([--with-$1=PATH],
29 [provide PATH to $1])],
30 [GIT_CONF_APPEND_PATH($1)],[])
31])# GIT_ARG_SET_PATH
32#
33# GIT_CONF_APPEND_PATH(PROGRAM)
34# ------------------------------
35# Parse --with-PROGRAM=PATH option to set PROGRAM_PATH=PATH
36# Used by GIT_ARG_SET_PATH(PROGRAM)
37AC_DEFUN([GIT_CONF_APPEND_PATH],
38[PROGRAM=m4_toupper($1); \
39if test "$withval" = "no"; then \
Jakub Narebskib52b1d42006-08-08 18:36:21 +020040 AC_MSG_ERROR([You cannot use git without $1]); \
Jakub Narebski657b0622006-08-03 00:38:11 +020041else \
42 if test "$withval" = "yes"; then \
43 AC_MSG_WARN([You should provide path for --with-$1=PATH]); \
44 else \
45 GIT_CONF_APPEND_LINE(${PROGRAM}_PATH=$withval); \
46 fi; \
47fi; \
48]) # GIT_CONF_APPEND_PATH
Jakub Narebskia20b4d82006-08-09 02:15:10 +020049#
50# GIT_PARSE_WITH(PACKAGE)
51# -----------------------
52# For use in AC_ARG_WITH action-if-found, for packages default ON.
53# * Set NO_PACKAGE=YesPlease for --without-PACKAGE
54# * Set PACKAGEDIR=PATH for --with-PACKAGE=PATH
55# * Unset NO_PACKAGE for --with-PACKAGE without ARG
56AC_DEFUN([GIT_PARSE_WITH],
57[PACKAGE=m4_toupper($1); \
58if test "$withval" = "no"; then \
59 m4_toupper(NO_$1)=YesPlease; \
60elif test "$withval" = "yes"; then \
61 m4_toupper(NO_$1)=; \
62else \
63 m4_toupper(NO_$1)=; \
64 GIT_CONF_APPEND_LINE(${PACKAGE}DIR=$withval); \
65fi \
66])# GIT_PARSE_WITH
Jakub Narebskid3a6db92006-07-08 23:07:09 +020067
Jakub Narebski633b4232006-07-08 23:07:08 +020068
Jakub Narebskia20b4d82006-08-09 02:15:10 +020069## Site configuration related to programs (before tests)
Jakub Narebskic4b1b142006-08-03 00:38:56 +020070## --with-PACKAGE[=ARG] and --without-PACKAGE
71#
Robert Schiele10861be2007-08-01 06:30:35 +020072# Set lib to alternative name of lib directory (e.g. lib64)
73AC_ARG_WITH([lib],
74 [AS_HELP_STRING([--with-lib=ARG],
75 [ARG specifies alternative name for lib directory])],
Ralf Wildenhues3c307bf2007-11-06 21:12:45 +010076 [if test "$withval" = "no" || test "$withval" = "yes"; then \
Robert Schiele10861be2007-08-01 06:30:35 +020077 AC_MSG_WARN([You should provide name for --with-lib=ARG]); \
78else \
79 GIT_CONF_APPEND_LINE(lib=$withval); \
80fi; \
81],[])
82#
Jakub Narebski465e6492006-08-04 17:55:58 +020083# Define SHELL_PATH to provide path to shell.
84GIT_ARG_SET_PATH(shell)
85#
86# Define PERL_PATH to provide path to Perl.
87GIT_ARG_SET_PATH(perl)
88#
Robert Schielebef19da2007-07-29 20:35:45 +020089# Define ZLIB_PATH to provide path to zlib.
90GIT_ARG_SET_PATH(zlib)
91#
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -070092# Declare the with-tcltk/without-tcltk options.
93AC_ARG_WITH(tcltk,
94AS_HELP_STRING([--with-tcltk],[use Tcl/Tk GUI (default is YES)])
95AS_HELP_STRING([],[ARG is the full path to the Tcl/Tk interpreter.])
96AS_HELP_STRING([],[Bare --with-tcltk will make the GUI part only if])
97AS_HELP_STRING([],[Tcl/Tk interpreter will be found in a system.]),\
98GIT_PARSE_WITH(tcltk))
99#
Jakub Narebskic4b1b142006-08-03 00:38:56 +0200100
101
Jakub Narebski633b4232006-07-08 23:07:08 +0200102## Checks for programs.
Jakub Narebskifd22c022006-07-08 23:07:13 +0200103AC_MSG_NOTICE([CHECKS for programs])
Jakub Narebskif6719572006-07-08 23:07:14 +0200104#
Dennis Stosberg60a144f2006-08-15 11:01:31 +0200105AC_PROG_CC([cc gcc])
Jakub Narebskifd22c022006-07-08 23:07:13 +0200106#AC_PROG_INSTALL # needs install-sh or install.sh in sources
Robert Schiele96e24ab2007-10-03 03:49:34 +0200107AC_CHECK_TOOLS(AR, [gar ar], :)
Jakub Narebskifd22c022006-07-08 23:07:13 +0200108AC_CHECK_PROGS(TAR, [gtar tar])
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700109# TCLTK_PATH will be set to some value if we want Tcl/Tk
110# or will be empty otherwise.
111if test -z "$NO_TCLTK"; then
112 if test "$with_tcltk" = ""; then
113 # No Tcl/Tk switches given. Do not check for Tcl/Tk, use bare 'wish'.
114 TCLTK_PATH=wish
115 AC_SUBST(TCLTK_PATH)
116 elif test "$with_tcltk" = "yes"; then
117 # Tcl/Tk check requested.
118 AC_CHECK_PROGS(TCLTK_PATH, [wish], )
Eygene Ryabinkin68daee02007-03-29 14:06:48 +0400119 else
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700120 AC_MSG_RESULT([Using Tcl/Tk interpreter $with_tcltk])
121 TCLTK_PATH="$with_tcltk"
122 AC_SUBST(TCLTK_PATH)
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700123 fi
124fi
Jakub Narebski923db422007-12-09 13:57:39 +0100125AC_CHECK_PROGS(ASCIIDOC, [asciidoc])
126if test -n "$ASCIIDOC"; then
127 AC_MSG_CHECKING([for asciidoc version])
128 asciidoc_version=`$ASCIIDOC --version 2>&1`
129 case "${asciidoc_version}" in
130 asciidoc' '8*)
131 ASCIIDOC8=YesPlease
132 AC_MSG_RESULT([${asciidoc_version} > 7])
133 ;;
134 asciidoc' '7*)
135 ASCIIDOC8=
136 AC_MSG_RESULT([${asciidoc_version}])
137 ;;
138 *)
139 ASCIIDOC8=
140 AC_MSG_RESULT([${asciidoc_version} (unknown)])
141 ;;
142 esac
143fi
144AC_SUBST(ASCIIDOC8)
145
Jakub Narebski633b4232006-07-08 23:07:08 +0200146
147## Checks for libraries.
Jakub Narebskiebdf5322006-07-08 23:07:12 +0200148AC_MSG_NOTICE([CHECKS for libraries])
Jakub Narebskif6719572006-07-08 23:07:14 +0200149#
Jakub Narebski633b4232006-07-08 23:07:08 +0200150# Define NO_OPENSSL environment variable if you do not have OpenSSL.
Jakub Narebskiebdf5322006-07-08 23:07:12 +0200151# Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin).
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200152AC_CHECK_LIB([crypto], [SHA1_Init],
Jakub Narebski424adc52006-08-08 18:39:06 +0200153[NEEDS_SSL_WITH_CRYPTO=],
Junio C Hamano3068f6c2006-08-04 16:33:18 -0700154[AC_CHECK_LIB([ssl], [SHA1_Init],
Jakub Narebski424adc52006-08-08 18:39:06 +0200155 [NEEDS_SSL_WITH_CRYPTO=YesPlease
156 NEEDS_SSL_WITH_CRYPTO=],
157 [NO_OPENSSL=YesPlease])])
158AC_SUBST(NEEDS_SSL_WITH_CRYPTO)
159AC_SUBST(NO_OPENSSL)
Jakub Narebskif6719572006-07-08 23:07:14 +0200160#
Johan Herland8da1e212008-06-15 12:14:12 +0200161# Define NO_CURL if you do not have libcurl installed. git-http-pull and
Jakub Narebski633b4232006-07-08 23:07:08 +0200162# git-http-push are not built, and you cannot use http:// and https://
163# transports.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200164AC_CHECK_LIB([curl], [curl_global_init],
Jakub Narebski424adc52006-08-08 18:39:06 +0200165[NO_CURL=],
166[NO_CURL=YesPlease])
167AC_SUBST(NO_CURL)
Jakub Narebskif6719572006-07-08 23:07:14 +0200168#
Jakub Narebski633b4232006-07-08 23:07:08 +0200169# Define NO_EXPAT if you do not have expat installed. git-http-push is
170# not built, and you cannot push using http:// and https:// transports.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200171AC_CHECK_LIB([expat], [XML_ParserCreate],
Jakub Narebski424adc52006-08-08 18:39:06 +0200172[NO_EXPAT=],
173[NO_EXPAT=YesPlease])
174AC_SUBST(NO_EXPAT)
Jakub Narebskif6719572006-07-08 23:07:14 +0200175#
Fredrik Kuivinene63ccb82007-02-18 09:44:42 +0100176# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin and
177# some Solaris installations).
Jakub Narebski6ff88de2006-09-07 13:48:08 +0200178# Define NO_ICONV if neither libc nor libiconv support iconv.
Fredrik Kuivinene63ccb82007-02-18 09:44:42 +0100179AC_DEFUN([ICONVTEST_SRC], [
180#include <iconv.h>
181
182int main(void)
183{
184 iconv_open("", "");
185 return 0;
186}
187])
188AC_MSG_CHECKING([for iconv in -lc])
189AC_LINK_IFELSE(ICONVTEST_SRC,
190 [AC_MSG_RESULT([yes])
191 NEEDS_LIBICONV=],
192 [AC_MSG_RESULT([no])
193 old_LIBS="$LIBS"
194 LIBS="$LIBS -liconv"
195 AC_MSG_CHECKING([for iconv in -liconv])
196 AC_LINK_IFELSE(ICONVTEST_SRC,
197 [AC_MSG_RESULT([yes])
198 NEEDS_LIBICONV=YesPlease],
199 [AC_MSG_RESULT([no])
200 NO_ICONV=YesPlease])
201 LIBS="$old_LIBS"])
Jakub Narebski424adc52006-08-08 18:39:06 +0200202AC_SUBST(NEEDS_LIBICONV)
Jakub Narebskibaf12192006-09-07 13:48:49 +0200203AC_SUBST(NO_ICONV)
Jakub Narebski825b0452006-09-05 22:03:48 +0200204test -n "$NEEDS_LIBICONV" && LIBS="$LIBS -liconv"
Jakub Narebskif6719572006-07-08 23:07:14 +0200205#
David Symonds609a2282007-11-07 14:24:28 +1100206# Define NO_DEFLATE_BOUND if deflateBound is missing from zlib.
207AC_DEFUN([ZLIBTEST_SRC], [
208#include <zlib.h>
209
210int main(void)
211{
212 deflateBound(0, 0);
213 return 0;
214}
215])
216AC_MSG_CHECKING([for deflateBound in -lz])
217old_LIBS="$LIBS"
218LIBS="$LIBS -lz"
219AC_LINK_IFELSE(ZLIBTEST_SRC,
220 [AC_MSG_RESULT([yes])],
221 [AC_MSG_RESULT([no])
222 NO_DEFLATE_BOUND=yes])
223LIBS="$old_LIBS"
224AC_SUBST(NO_DEFLATE_BOUND)
225#
Jakub Narebski633b4232006-07-08 23:07:08 +0200226# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
227# Patrick Mauritz).
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200228AC_CHECK_LIB([c], [socket],
Jakub Narebski424adc52006-08-08 18:39:06 +0200229[NEEDS_SOCKET=],
230[NEEDS_SOCKET=YesPlease])
231AC_SUBST(NEEDS_SOCKET)
Dennis Stosbergd1b99442006-08-15 11:01:27 +0200232test -n "$NEEDS_SOCKET" && LIBS="$LIBS -lsocket"
Jakub Narebski633b4232006-07-08 23:07:08 +0200233
234
235## Checks for header files.
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100236AC_MSG_NOTICE([CHECKS for header files])
237#
Jakub Narebski3cf32372008-01-25 12:19:41 +0100238# Define NO_SYS_SELECT_H if you don't have sys/select.h.
239AC_CHECK_HEADER([sys/select.h],
240[NO_SYS_SELECT_H=],
241[NO_SYS_SELECT_H=UnfortunatelyYes])
242AC_SUBST(NO_SYS_SELECT_H)
243#
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100244# Define OLD_ICONV if your library has an old iconv(), where the second
245# (input buffer pointer) parameter is declared with type (const char **).
246AC_DEFUN([OLDICONVTEST_SRC], [[
247#include <iconv.h>
248
249extern size_t iconv(iconv_t cd,
250 char **inbuf, size_t *inbytesleft,
251 char **outbuf, size_t *outbytesleft);
252
253int main(void)
254{
255 return 0;
256}
257]])
258AC_MSG_CHECKING([for old iconv()])
259AC_COMPILE_IFELSE(OLDICONVTEST_SRC,
260 [AC_MSG_RESULT([no])],
261 [AC_MSG_RESULT([yes])
262 OLD_ICONV=UnfortunatelyYes])
263AC_SUBST(OLD_ICONV)
Jakub Narebski633b4232006-07-08 23:07:08 +0200264
265
266## Checks for typedefs, structures, and compiler characteristics.
Jakub Narebskieb0f2552006-07-08 23:07:10 +0200267AC_MSG_NOTICE([CHECKS for typedefs, structures, and compiler characteristics])
Jakub Narebskif6719572006-07-08 23:07:14 +0200268#
Jakub Narebski633b4232006-07-08 23:07:08 +0200269# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200270AC_CHECK_MEMBER(struct dirent.d_ino,
Jakub Narebski424adc52006-08-08 18:39:06 +0200271[NO_D_INO_IN_DIRENT=],
272[NO_D_INO_IN_DIRENT=YesPlease],
Jakub Narebskieb0f2552006-07-08 23:07:10 +0200273[#include <dirent.h>])
Jakub Narebski424adc52006-08-08 18:39:06 +0200274AC_SUBST(NO_D_INO_IN_DIRENT)
Jakub Narebskif6719572006-07-08 23:07:14 +0200275#
Jakub Narebski633b4232006-07-08 23:07:08 +0200276# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
277# d_type in struct dirent (latest Cygwin -- will be fixed soonish).
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200278AC_CHECK_MEMBER(struct dirent.d_type,
Jakub Narebski424adc52006-08-08 18:39:06 +0200279[NO_D_TYPE_IN_DIRENT=],
280[NO_D_TYPE_IN_DIRENT=YesPlease],
Jakub Narebskieb0f2552006-07-08 23:07:10 +0200281[#include <dirent.h>])
Jakub Narebski424adc52006-08-08 18:39:06 +0200282AC_SUBST(NO_D_TYPE_IN_DIRENT)
Jakub Narebskif6719572006-07-08 23:07:14 +0200283#
Jakub Narebski633b4232006-07-08 23:07:08 +0200284# Define NO_SOCKADDR_STORAGE if your platform does not have struct
285# sockaddr_storage.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200286AC_CHECK_TYPE(struct sockaddr_storage,
Jakub Narebski424adc52006-08-08 18:39:06 +0200287[NO_SOCKADDR_STORAGE=],
Dennis Stosbergab5573a2006-08-15 11:01:25 +0200288[NO_SOCKADDR_STORAGE=YesPlease],[
289#include <sys/types.h>
290#include <sys/socket.h>
291])
Jakub Narebski424adc52006-08-08 18:39:06 +0200292AC_SUBST(NO_SOCKADDR_STORAGE)
293#
Junio C Hamano8c6ab352006-08-04 16:46:16 -0700294# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
295AC_CHECK_TYPE([struct addrinfo],[
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200296 AC_CHECK_FUNC([getaddrinfo],
Jakub Narebski424adc52006-08-08 18:39:06 +0200297 [NO_IPV6=],
298 [NO_IPV6=YesPlease])
299],[NO_IPV6=YesPlease],[
Junio C Hamano8c6ab352006-08-04 16:46:16 -0700300#include <sys/types.h>
301#include <sys/socket.h>
302#include <netdb.h>
303])
Jakub Narebski424adc52006-08-08 18:39:06 +0200304AC_SUBST(NO_IPV6)
Jakub Narebski656517b2006-08-04 17:55:57 +0200305#
306# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.)
307# do not support the 'size specifiers' introduced by C99, namely ll, hh,
308# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t).
309# some C compilers supported these specifiers prior to C99 as an extension.
Jakub Narebskif685d072006-09-05 00:58:25 +0200310AC_CACHE_CHECK([whether formatted IO functions support C99 size specifiers],
311 [ac_cv_c_c99_format],
Jakub Narebski656517b2006-08-04 17:55:57 +0200312[# Actually git uses only %z (%zu) in alloc.c, and %t (%td) in mktag.c
313AC_RUN_IFELSE(
314 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT],
315 [[char buf[64];
316 if (sprintf(buf, "%lld%hhd%jd%zd%td", (long long int)1, (char)2, (intmax_t)3, (size_t)4, (ptrdiff_t)5) != 5)
Ralf Wildenhues3c307bf2007-11-06 21:12:45 +0100317 return 1;
Jakub Narebski656517b2006-08-04 17:55:57 +0200318 else if (strcmp(buf, "12345"))
Ralf Wildenhues3c307bf2007-11-06 21:12:45 +0100319 return 2;]])],
Jakub Narebski656517b2006-08-04 17:55:57 +0200320 [ac_cv_c_c99_format=yes],
321 [ac_cv_c_c99_format=no])
322])
323if test $ac_cv_c_c99_format = no; then
Jakub Narebski424adc52006-08-08 18:39:06 +0200324 NO_C99_FORMAT=YesPlease
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200325else
Jakub Narebski424adc52006-08-08 18:39:06 +0200326 NO_C99_FORMAT=
Jakub Narebski656517b2006-08-04 17:55:57 +0200327fi
Jakub Narebski424adc52006-08-08 18:39:06 +0200328AC_SUBST(NO_C99_FORMAT)
Michal Rokosc4582f92008-03-05 16:46:13 +0100329#
Michal Rokos8ce1f242008-03-11 09:48:34 +0100330# Define FREAD_READS_DIRECTORIES if your are on a system which succeeds
331# when attempting to read from an fopen'ed directory.
332AC_CACHE_CHECK([whether system succeeds to read fopen'ed directory],
333 [ac_cv_fread_reads_directories],
334[
335AC_RUN_IFELSE(
336 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT],
337 [[char c;
338 FILE *f = fopen(".", "r");
339 return f && fread(&c, 1, 1, f)]])],
340 [ac_cv_fread_reads_directories=no],
341 [ac_cv_fread_reads_directories=yes])
342])
343if test $ac_cv_fread_reads_directories = yes; then
344 FREAD_READS_DIRECTORIES=UnfortunatelyYes
345else
346 FREAD_READS_DIRECTORIES=
347fi
348AC_SUBST(FREAD_READS_DIRECTORIES)
349#
Michal Rokosc4582f92008-03-05 16:46:13 +0100350# Define SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf()
351# or vsnprintf() return -1 instead of number of characters which would
352# have been written to the final string if enough space had been available.
353AC_CACHE_CHECK([whether snprintf() and/or vsnprintf() return bogus value],
354 [ac_cv_snprintf_returns_bogus],
355[
356AC_RUN_IFELSE(
357 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT
358 #include "stdarg.h"
359
360 int test_vsnprintf(char *str, size_t maxsize, const char *format, ...)
361 {
362 int ret;
363 va_list ap;
364 va_start(ap, format);
365 ret = vsnprintf(str, maxsize, format, ap);
366 va_end(ap);
367 return ret;
368 }],
369 [[char buf[6];
370 if (test_vsnprintf(buf, 3, "%s", "12345") != 5
371 || strcmp(buf, "12")) return 1;
372 if (snprintf(buf, 3, "%s", "12345") != 5
373 || strcmp(buf, "12")) return 1]])],
374 [ac_cv_snprintf_returns_bogus=no],
375 [ac_cv_snprintf_returns_bogus=yes])
376])
377if test $ac_cv_snprintf_returns_bogus = yes; then
378 SNPRINTF_RETURNS_BOGUS=UnfortunatelyYes
379else
380 SNPRINTF_RETURNS_BOGUS=
381fi
382AC_SUBST(SNPRINTF_RETURNS_BOGUS)
Jakub Narebski633b4232006-07-08 23:07:08 +0200383
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200384
Jakub Narebski633b4232006-07-08 23:07:08 +0200385## Checks for library functions.
Jakub Narebski1bbbadb2006-07-08 23:07:11 +0200386## (in default C library and libraries checked by AC_CHECK_LIB)
387AC_MSG_NOTICE([CHECKS for library functions])
Jakub Narebskif6719572006-07-08 23:07:14 +0200388#
Jakub Narebski633b4232006-07-08 23:07:08 +0200389# Define NO_STRCASESTR if you don't have strcasestr.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200390AC_CHECK_FUNC(strcasestr,
Jakub Narebski424adc52006-08-08 18:39:06 +0200391[NO_STRCASESTR=],
392[NO_STRCASESTR=YesPlease])
393AC_SUBST(NO_STRCASESTR)
Jakub Narebskif6719572006-07-08 23:07:14 +0200394#
Jakub Narebski24397552007-11-19 19:47:05 +0100395# Define NO_MEMMEM if you don't have memmem.
396AC_CHECK_FUNC(memmem,
397[NO_MEMMEM=],
398[NO_MEMMEM=YesPlease])
399AC_SUBST(NO_MEMMEM)
400#
Jakub Narebski633b4232006-07-08 23:07:08 +0200401# Define NO_STRLCPY if you don't have strlcpy.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200402AC_CHECK_FUNC(strlcpy,
Jakub Narebski424adc52006-08-08 18:39:06 +0200403[NO_STRLCPY=],
404[NO_STRLCPY=YesPlease])
405AC_SUBST(NO_STRLCPY)
Jakub Narebskif6719572006-07-08 23:07:14 +0200406#
Jakub Narebski24397552007-11-19 19:47:05 +0100407# Define NO_STRTOUMAX if you don't have strtoumax in the C library.
408AC_CHECK_FUNC(strtoumax,
409[NO_STRTOUMAX=],
410[NO_STRTOUMAX=YesPlease])
411AC_SUBST(NO_STRTOUMAX)
412#
Jakub Narebski633b4232006-07-08 23:07:08 +0200413# Define NO_SETENV if you don't have setenv in the C library.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200414AC_CHECK_FUNC(setenv,
Jakub Narebski424adc52006-08-08 18:39:06 +0200415[NO_SETENV=],
416[NO_SETENV=YesPlease])
417AC_SUBST(NO_SETENV)
Jakub Narebskif6719572006-07-08 23:07:14 +0200418#
Jakub Narebskibfa8fcc2008-01-18 02:03:51 +0100419# Define NO_UNSETENV if you don't have unsetenv in the C library.
420AC_CHECK_FUNC(unsetenv,
421[NO_UNSETENV=],
422[NO_UNSETENV=YesPlease])
423AC_SUBST(NO_UNSETENV)
424#
Jakub Narebski24397552007-11-19 19:47:05 +0100425# Define NO_MKDTEMP if you don't have mkdtemp in the C library.
426AC_CHECK_FUNC(mkdtemp,
427[NO_MKDTEMP=],
428[NO_MKDTEMP=YesPlease])
429AC_SUBST(NO_MKDTEMP)
430#
Jakub Narebski633b4232006-07-08 23:07:08 +0200431# Define NO_MMAP if you want to avoid mmap.
432#
Jakub Narebski633b4232006-07-08 23:07:08 +0200433# Define NO_ICONV if your libc does not properly support iconv.
434
435
436## Other checks.
437# Define USE_PIC if you need the main git objects to be built with -fPIC
438# in order to build and link perl/Git.so. x86-64 seems to need this.
439#
440# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
441# Enable it on Windows. By default, symrefs are still used.
Jakub Narebski633b4232006-07-08 23:07:08 +0200442
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200443## Site configuration (override autodetection)
444## --with-PACKAGE[=ARG] and --without-PACKAGE
445AC_MSG_NOTICE([CHECKS for site configuration])
446#
447# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
448# tests. These tests take up a significant amount of the total test time
449# but are not needed unless you plan to talk to SVN repos.
450#
451# Define MOZILLA_SHA1 environment variable when running make to make use of
452# a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast
453# on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default
454# choice) has very fast version optimized for i586.
455#
456# Define PPC_SHA1 environment variable when running make to make use of
457# a bundled SHA1 routine optimized for PowerPC.
458#
459# Define ARM_SHA1 environment variable when running make to make use of
460# a bundled SHA1 routine optimized for ARM.
461#
462# Define NO_OPENSSL environment variable if you do not have OpenSSL.
463# This also implies MOZILLA_SHA1.
464#
465# Define OPENSSLDIR=/foo/bar if your openssl header and library files are in
466# /foo/bar/include and /foo/bar/lib directories.
467AC_ARG_WITH(openssl,
468AS_HELP_STRING([--with-openssl],[use OpenSSL library (default is YES)])
469AS_HELP_STRING([], [ARG can be prefix for openssl library and headers]),\
470GIT_PARSE_WITH(openssl))
471#
472# Define NO_CURL if you do not have curl installed. git-http-pull and
473# git-http-push are not built, and you cannot use http:// and https://
474# transports.
475#
476# Define CURLDIR=/foo/bar if your curl header and library files are in
477# /foo/bar/include and /foo/bar/lib directories.
478AC_ARG_WITH(curl,
479AS_HELP_STRING([--with-curl],[support http(s):// transports (default is YES)])
480AS_HELP_STRING([], [ARG can be also prefix for curl library and headers]),
481GIT_PARSE_WITH(curl))
482#
483# Define NO_EXPAT if you do not have expat installed. git-http-push is
484# not built, and you cannot push using http:// and https:// transports.
485#
486# Define EXPATDIR=/foo/bar if your expat header and library files are in
487# /foo/bar/include and /foo/bar/lib directories.
488AC_ARG_WITH(expat,
489AS_HELP_STRING([--with-expat],
490[support git-push using http:// and https:// transports via WebDAV (default is YES)])
491AS_HELP_STRING([], [ARG can be also prefix for expat library and headers]),
492GIT_PARSE_WITH(expat))
493#
494# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
495# installed in /sw, but don't want GIT to link against any libraries
496# installed there. If defined you may specify your own (or Fink's)
497# include directories and library directories by defining CFLAGS
498# and LDFLAGS appropriately.
499#
500# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
501# have DarwinPorts installed in /opt/local, but don't want GIT to
502# link against any libraries installed there. If defined you may
503# specify your own (or DarwinPort's) include directories and
504# library directories by defining CFLAGS and LDFLAGS appropriately.
505#
506# Define NO_MMAP if you want to avoid mmap.
Jakub Narebskibaf12192006-09-07 13:48:49 +0200507#
508# Define NO_ICONV if your libc does not properly support iconv.
509AC_ARG_WITH(iconv,
510AS_HELP_STRING([--without-iconv],
511[if your architecture doesn't properly support iconv])
512AS_HELP_STRING([--with-iconv=PATH],
513[PATH is prefix for libiconv library and headers])
514AS_HELP_STRING([],
515[used only if you need linking with libiconv]),
516GIT_PARSE_WITH(iconv))
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200517
518## --enable-FEATURE[=ARG] and --disable-FEATURE
519#
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200520# Define USE_NSEC below if you want git to care about sub-second file mtimes
521# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
522# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
523# randomly break unless your underlying filesystem supports those sub-second
524# times (my ext3 doesn't).
525#
526# Define USE_STDEV below if you want git to care about the underlying device
Johannes Schindelin10455d22007-11-30 11:35:23 +0000527# change being considered an inode change from the update-index perspective.
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200528
529
Jakub Narebski633b4232006-07-08 23:07:08 +0200530## Output files
Jakub Narebskid3a6db92006-07-08 23:07:09 +0200531AC_CONFIG_FILES(["${config_file}":"${config_in}":"${config_append}"])
Jakub Narebski55667712006-07-03 01:56:48 +0200532AC_OUTPUT
Jakub Narebskid3a6db92006-07-08 23:07:09 +0200533
Jakub Narebskif6719572006-07-08 23:07:14 +0200534
Jakub Narebskid3a6db92006-07-08 23:07:09 +0200535## Cleanup
536rm -f "${config_append}"