]> git.ipfire.org Git - thirdparty/git.git/blame - configure.ac
Makefile: customization for supporting HP-UX
[thirdparty/git.git] / configure.ac
CommitLineData
55667714
JN
1# -*- Autoconf -*-
2# Process this file with autoconf to produce a configure script.
3
4AC_PREREQ(2.59)
3900145e 5AC_INIT([git], [@@GIT_VERSION@@], [git@vger.kernel.org])
55667714
JN
6
7AC_CONFIG_SRCDIR([git.c])
8
9config_file=config.mak.autogen
d3a6db98 10config_append=config.mak.append
55667714
JN
11config_in=config.mak.in
12
d3a6db98
JN
13echo "# ${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
657b062d
JN
22#
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 \
b52b1d43 40 AC_MSG_ERROR([You cannot use git without $1]); \
657b062d
JN
41else \
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
a20b4d89
JN
49#
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
d3a6db98 67
633b4239 68
a20b4d89 69## Site configuration related to programs (before tests)
c4b1b140
JN
70## --with-PACKAGE[=ARG] and --without-PACKAGE
71#
10861bea
RS
72# 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])],
3c307bfb 76 [if test "$withval" = "no" || test "$withval" = "yes"; then \
10861bea
RS
77 AC_MSG_WARN([You should provide name for --with-lib=ARG]); \
78else \
79 GIT_CONF_APPEND_LINE(lib=$withval); \
80fi; \
81],[])
82#
465e649d
JN
83# 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#
bef19da9
RS
89# Define ZLIB_PATH to provide path to zlib.
90GIT_ARG_SET_PATH(zlib)
91#
81b63c70
ER
92# 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#
c4b1b140
JN
100
101
633b4239 102## Checks for programs.
fd22c027 103AC_MSG_NOTICE([CHECKS for programs])
f6719572 104#
60a144f2 105AC_PROG_CC([cc gcc])
fd22c027 106#AC_PROG_INSTALL # needs install-sh or install.sh in sources
96e24abc 107AC_CHECK_TOOLS(AR, [gar ar], :)
fd22c027 108AC_CHECK_PROGS(TAR, [gtar tar])
81b63c70
ER
109# 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], )
68daee08 119 else
81b63c70
ER
120 AC_MSG_RESULT([Using Tcl/Tk interpreter $with_tcltk])
121 TCLTK_PATH="$with_tcltk"
122 AC_SUBST(TCLTK_PATH)
81b63c70
ER
123 fi
124fi
923db42e
JN
125AC_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
633b4239
JN
146
147## Checks for libraries.
ebdf5321 148AC_MSG_NOTICE([CHECKS for libraries])
f6719572 149#
633b4239 150# Define NO_OPENSSL environment variable if you do not have OpenSSL.
ebdf5321 151# Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin).
d5c31a1c 152AC_CHECK_LIB([crypto], [SHA1_Init],
424adc50 153[NEEDS_SSL_WITH_CRYPTO=],
3068f6c4 154[AC_CHECK_LIB([ssl], [SHA1_Init],
424adc50
JN
155 [NEEDS_SSL_WITH_CRYPTO=YesPlease
156 NEEDS_SSL_WITH_CRYPTO=],
157 [NO_OPENSSL=YesPlease])])
158AC_SUBST(NEEDS_SSL_WITH_CRYPTO)
159AC_SUBST(NO_OPENSSL)
f6719572 160#
633b4239
JN
161# Define NO_CURL if you do not have curl installed. git-http-pull and
162# git-http-push are not built, and you cannot use http:// and https://
163# transports.
d5c31a1c 164AC_CHECK_LIB([curl], [curl_global_init],
424adc50
JN
165[NO_CURL=],
166[NO_CURL=YesPlease])
167AC_SUBST(NO_CURL)
f6719572 168#
633b4239
JN
169# 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.
d5c31a1c 171AC_CHECK_LIB([expat], [XML_ParserCreate],
424adc50
JN
172[NO_EXPAT=],
173[NO_EXPAT=YesPlease])
174AC_SUBST(NO_EXPAT)
f6719572 175#
e63ccb84
FK
176# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin and
177# some Solaris installations).
6ff88de7 178# Define NO_ICONV if neither libc nor libiconv support iconv.
e63ccb84
FK
179AC_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"])
424adc50 202AC_SUBST(NEEDS_LIBICONV)
baf1219a 203AC_SUBST(NO_ICONV)
825b045f 204test -n "$NEEDS_LIBICONV" && LIBS="$LIBS -liconv"
f6719572 205#
609a2289
DS
206# 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#
633b4239
JN
226# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
227# Patrick Mauritz).
d5c31a1c 228AC_CHECK_LIB([c], [socket],
424adc50
JN
229[NEEDS_SOCKET=],
230[NEEDS_SOCKET=YesPlease])
231AC_SUBST(NEEDS_SOCKET)
d1b9944d 232test -n "$NEEDS_SOCKET" && LIBS="$LIBS -lsocket"
633b4239
JN
233
234
235## Checks for header files.
0f7a9c9b
JN
236AC_MSG_NOTICE([CHECKS for header files])
237#
238# Define OLD_ICONV if your library has an old iconv(), where the second
239# (input buffer pointer) parameter is declared with type (const char **).
240AC_DEFUN([OLDICONVTEST_SRC], [[
241#include <iconv.h>
242
243extern size_t iconv(iconv_t cd,
244 char **inbuf, size_t *inbytesleft,
245 char **outbuf, size_t *outbytesleft);
246
247int main(void)
248{
249 return 0;
250}
251]])
252AC_MSG_CHECKING([for old iconv()])
253AC_COMPILE_IFELSE(OLDICONVTEST_SRC,
254 [AC_MSG_RESULT([no])],
255 [AC_MSG_RESULT([yes])
256 OLD_ICONV=UnfortunatelyYes])
257AC_SUBST(OLD_ICONV)
633b4239
JN
258
259
260## Checks for typedefs, structures, and compiler characteristics.
eb0f255d 261AC_MSG_NOTICE([CHECKS for typedefs, structures, and compiler characteristics])
f6719572 262#
633b4239 263# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
d5c31a1c 264AC_CHECK_MEMBER(struct dirent.d_ino,
424adc50
JN
265[NO_D_INO_IN_DIRENT=],
266[NO_D_INO_IN_DIRENT=YesPlease],
eb0f255d 267[#include <dirent.h>])
424adc50 268AC_SUBST(NO_D_INO_IN_DIRENT)
f6719572 269#
633b4239
JN
270# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
271# d_type in struct dirent (latest Cygwin -- will be fixed soonish).
d5c31a1c 272AC_CHECK_MEMBER(struct dirent.d_type,
424adc50
JN
273[NO_D_TYPE_IN_DIRENT=],
274[NO_D_TYPE_IN_DIRENT=YesPlease],
eb0f255d 275[#include <dirent.h>])
424adc50 276AC_SUBST(NO_D_TYPE_IN_DIRENT)
f6719572 277#
633b4239
JN
278# Define NO_SOCKADDR_STORAGE if your platform does not have struct
279# sockaddr_storage.
d5c31a1c 280AC_CHECK_TYPE(struct sockaddr_storage,
424adc50 281[NO_SOCKADDR_STORAGE=],
ab5573ae
DS
282[NO_SOCKADDR_STORAGE=YesPlease],[
283#include <sys/types.h>
284#include <sys/socket.h>
285])
424adc50
JN
286AC_SUBST(NO_SOCKADDR_STORAGE)
287#
8c6ab35e
JH
288# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
289AC_CHECK_TYPE([struct addrinfo],[
d5c31a1c 290 AC_CHECK_FUNC([getaddrinfo],
424adc50
JN
291 [NO_IPV6=],
292 [NO_IPV6=YesPlease])
293],[NO_IPV6=YesPlease],[
8c6ab35e
JH
294#include <sys/types.h>
295#include <sys/socket.h>
296#include <netdb.h>
297])
424adc50 298AC_SUBST(NO_IPV6)
656517b9
JN
299#
300# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.)
301# do not support the 'size specifiers' introduced by C99, namely ll, hh,
302# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t).
303# some C compilers supported these specifiers prior to C99 as an extension.
f685d07d
JN
304AC_CACHE_CHECK([whether formatted IO functions support C99 size specifiers],
305 [ac_cv_c_c99_format],
656517b9
JN
306[# Actually git uses only %z (%zu) in alloc.c, and %t (%td) in mktag.c
307AC_RUN_IFELSE(
308 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT],
309 [[char buf[64];
310 if (sprintf(buf, "%lld%hhd%jd%zd%td", (long long int)1, (char)2, (intmax_t)3, (size_t)4, (ptrdiff_t)5) != 5)
3c307bfb 311 return 1;
656517b9 312 else if (strcmp(buf, "12345"))
3c307bfb 313 return 2;]])],
656517b9
JN
314 [ac_cv_c_c99_format=yes],
315 [ac_cv_c_c99_format=no])
316])
317if test $ac_cv_c_c99_format = no; then
424adc50 318 NO_C99_FORMAT=YesPlease
d5c31a1c 319else
424adc50 320 NO_C99_FORMAT=
656517b9 321fi
424adc50 322AC_SUBST(NO_C99_FORMAT)
633b4239 323
a20b4d89 324
633b4239 325## Checks for library functions.
1bbbadbc
JN
326## (in default C library and libraries checked by AC_CHECK_LIB)
327AC_MSG_NOTICE([CHECKS for library functions])
f6719572 328#
633b4239 329# Define NO_STRCASESTR if you don't have strcasestr.
d5c31a1c 330AC_CHECK_FUNC(strcasestr,
424adc50
JN
331[NO_STRCASESTR=],
332[NO_STRCASESTR=YesPlease])
333AC_SUBST(NO_STRCASESTR)
f6719572 334#
24397556
JN
335# Define NO_MEMMEM if you don't have memmem.
336AC_CHECK_FUNC(memmem,
337[NO_MEMMEM=],
338[NO_MEMMEM=YesPlease])
339AC_SUBST(NO_MEMMEM)
340#
633b4239 341# Define NO_STRLCPY if you don't have strlcpy.
d5c31a1c 342AC_CHECK_FUNC(strlcpy,
424adc50
JN
343[NO_STRLCPY=],
344[NO_STRLCPY=YesPlease])
345AC_SUBST(NO_STRLCPY)
f6719572 346#
24397556
JN
347# Define NO_STRTOUMAX if you don't have strtoumax in the C library.
348AC_CHECK_FUNC(strtoumax,
349[NO_STRTOUMAX=],
350[NO_STRTOUMAX=YesPlease])
351AC_SUBST(NO_STRTOUMAX)
352#
633b4239 353# Define NO_SETENV if you don't have setenv in the C library.
d5c31a1c 354AC_CHECK_FUNC(setenv,
424adc50
JN
355[NO_SETENV=],
356[NO_SETENV=YesPlease])
357AC_SUBST(NO_SETENV)
f6719572 358#
bfa8fccf
JN
359# Define NO_UNSETENV if you don't have unsetenv in the C library.
360AC_CHECK_FUNC(unsetenv,
361[NO_UNSETENV=],
362[NO_UNSETENV=YesPlease])
363AC_SUBST(NO_UNSETENV)
364#
24397556
JN
365# Define NO_MKDTEMP if you don't have mkdtemp in the C library.
366AC_CHECK_FUNC(mkdtemp,
367[NO_MKDTEMP=],
368[NO_MKDTEMP=YesPlease])
369AC_SUBST(NO_MKDTEMP)
370#
633b4239
JN
371# Define NO_MMAP if you want to avoid mmap.
372#
633b4239
JN
373# Define NO_ICONV if your libc does not properly support iconv.
374
375
376## Other checks.
377# Define USE_PIC if you need the main git objects to be built with -fPIC
378# in order to build and link perl/Git.so. x86-64 seems to need this.
379#
380# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
381# Enable it on Windows. By default, symrefs are still used.
633b4239 382
a20b4d89
JN
383## Site configuration (override autodetection)
384## --with-PACKAGE[=ARG] and --without-PACKAGE
385AC_MSG_NOTICE([CHECKS for site configuration])
386#
387# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
388# tests. These tests take up a significant amount of the total test time
389# but are not needed unless you plan to talk to SVN repos.
390#
391# Define MOZILLA_SHA1 environment variable when running make to make use of
392# a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast
393# on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default
394# choice) has very fast version optimized for i586.
395#
396# Define PPC_SHA1 environment variable when running make to make use of
397# a bundled SHA1 routine optimized for PowerPC.
398#
399# Define ARM_SHA1 environment variable when running make to make use of
400# a bundled SHA1 routine optimized for ARM.
401#
402# Define NO_OPENSSL environment variable if you do not have OpenSSL.
403# This also implies MOZILLA_SHA1.
404#
405# Define OPENSSLDIR=/foo/bar if your openssl header and library files are in
406# /foo/bar/include and /foo/bar/lib directories.
407AC_ARG_WITH(openssl,
408AS_HELP_STRING([--with-openssl],[use OpenSSL library (default is YES)])
409AS_HELP_STRING([], [ARG can be prefix for openssl library and headers]),\
410GIT_PARSE_WITH(openssl))
411#
412# Define NO_CURL if you do not have curl installed. git-http-pull and
413# git-http-push are not built, and you cannot use http:// and https://
414# transports.
415#
416# Define CURLDIR=/foo/bar if your curl header and library files are in
417# /foo/bar/include and /foo/bar/lib directories.
418AC_ARG_WITH(curl,
419AS_HELP_STRING([--with-curl],[support http(s):// transports (default is YES)])
420AS_HELP_STRING([], [ARG can be also prefix for curl library and headers]),
421GIT_PARSE_WITH(curl))
422#
423# Define NO_EXPAT if you do not have expat installed. git-http-push is
424# not built, and you cannot push using http:// and https:// transports.
425#
426# Define EXPATDIR=/foo/bar if your expat header and library files are in
427# /foo/bar/include and /foo/bar/lib directories.
428AC_ARG_WITH(expat,
429AS_HELP_STRING([--with-expat],
430[support git-push using http:// and https:// transports via WebDAV (default is YES)])
431AS_HELP_STRING([], [ARG can be also prefix for expat library and headers]),
432GIT_PARSE_WITH(expat))
433#
434# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
435# installed in /sw, but don't want GIT to link against any libraries
436# installed there. If defined you may specify your own (or Fink's)
437# include directories and library directories by defining CFLAGS
438# and LDFLAGS appropriately.
439#
440# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
441# have DarwinPorts installed in /opt/local, but don't want GIT to
442# link against any libraries installed there. If defined you may
443# specify your own (or DarwinPort's) include directories and
444# library directories by defining CFLAGS and LDFLAGS appropriately.
445#
446# Define NO_MMAP if you want to avoid mmap.
baf1219a
JN
447#
448# Define NO_ICONV if your libc does not properly support iconv.
449AC_ARG_WITH(iconv,
450AS_HELP_STRING([--without-iconv],
451[if your architecture doesn't properly support iconv])
452AS_HELP_STRING([--with-iconv=PATH],
453[PATH is prefix for libiconv library and headers])
454AS_HELP_STRING([],
455[used only if you need linking with libiconv]),
456GIT_PARSE_WITH(iconv))
a20b4d89
JN
457
458## --enable-FEATURE[=ARG] and --disable-FEATURE
459#
a20b4d89
JN
460# Define USE_NSEC below if you want git to care about sub-second file mtimes
461# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
462# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
463# randomly break unless your underlying filesystem supports those sub-second
464# times (my ext3 doesn't).
465#
466# Define USE_STDEV below if you want git to care about the underlying device
10455d2a 467# change being considered an inode change from the update-index perspective.
a20b4d89
JN
468
469
633b4239 470## Output files
d3a6db98 471AC_CONFIG_FILES(["${config_file}":"${config_in}":"${config_append}"])
55667714 472AC_OUTPUT
d3a6db98 473
f6719572 474
d3a6db98
JN
475## Cleanup
476rm -f "${config_append}"