blob: 66aedb9288fe5da15df3f681b636ae87e869ca64 [file] [log] [blame]
Jakub Narebski55667712006-07-03 01:56:48 +02001# -*- Autoconf -*-
2# Process this file with autoconf to produce a configure script.
3
Stefano Lattarini5b2d1312012-03-26 18:42:26 +02004## Definitions of private macros.
5
Stefano Lattarini610473a2012-07-19 09:49:57 +02006# GIT_CONF_SUBST(VAL, VAR)
7# ------------------------
Stefano Lattariniac5fc1c2012-07-19 09:50:00 +02008# Cause the line "VAR=VAL" to be eventually appended to ${config_file}.
9AC_DEFUN([GIT_CONF_SUBST],
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +020010[AC_REQUIRE([GIT_CONF_SUBST_INIT])
11config_appended_defs="$config_appended_defs${newline}dnl
12$1=m4_if([$#],[1],[${$1}],[$2])"])
Stefano Lattariniac5fc1c2012-07-19 09:50:00 +020013
14# GIT_CONF_SUBST_INIT
15# -------------------
16# Prepare shell variables and autoconf machine required by later calls
17# to GIT_CONF_SUBST.
18AC_DEFUN([GIT_CONF_SUBST_INIT],
19 [config_appended_defs=; newline='
20'
21 AC_CONFIG_COMMANDS([$config_file],
22 [echo "$config_appended_defs" >> "$config_file"],
23 [config_file=$config_file
24 config_appended_defs="$config_appended_defs"])])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020025
Jakub Narebski657b0622006-08-03 00:38:11 +020026# GIT_ARG_SET_PATH(PROGRAM)
27# -------------------------
28# Provide --with-PROGRAM=PATH option to set PATH to PROGRAM
Ben Waltonf22cd7f2010-01-31 21:15:04 -050029# Optional second argument allows setting NO_PROGRAM=YesPlease if
30# --without-PROGRAM version used.
Jakub Narebski657b0622006-08-03 00:38:11 +020031AC_DEFUN([GIT_ARG_SET_PATH],
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020032 [AC_ARG_WITH([$1],
33 [AS_HELP_STRING([--with-$1=PATH],
34 [provide PATH to $1])],
35 [GIT_CONF_APPEND_PATH([$1], [$2])],
36 [])])
37
Jakub Narebski657b0622006-08-03 00:38:11 +020038# GIT_CONF_APPEND_PATH(PROGRAM)
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020039# -----------------------------
Jakub Narebski657b0622006-08-03 00:38:11 +020040# Parse --with-PROGRAM=PATH option to set PROGRAM_PATH=PATH
41# Used by GIT_ARG_SET_PATH(PROGRAM)
Ben Waltonf22cd7f2010-01-31 21:15:04 -050042# Optional second argument allows setting NO_PROGRAM=YesPlease if
43# --without-PROGRAM is used.
Jakub Narebski657b0622006-08-03 00:38:11 +020044AC_DEFUN([GIT_CONF_APPEND_PATH],
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020045 [m4_pushdef([GIT_UC_PROGRAM], m4_toupper([$1]))dnl
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020046 if test "$withval" = "no"; then
47 if test -n "$2"; then
48 GIT_UC_PROGRAM[]_PATH=$withval
Stefano Lattarini7f8cf482012-07-19 09:49:58 +020049 AC_MSG_NOTICE([Disabling use of GIT_UC_PROGRAM])
50 GIT_CONF_SUBST([NO_]GIT_UC_PROGRAM, [YesPlease])
51 GIT_CONF_SUBST(GIT_UC_PROGRAM[]_PATH, [])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020052 else
53 AC_MSG_ERROR([You cannot use git without $1])
54 fi
55 else
56 if test "$withval" = "yes"; then
57 AC_MSG_WARN([You should provide path for --with-$1=PATH])
58 else
59 GIT_UC_PROGRAM[]_PATH=$withval
60 AC_MSG_NOTICE([Setting GIT_UC_PROGRAM[]_PATH to $withval])
Stefano Lattarini7f8cf482012-07-19 09:49:58 +020061 GIT_CONF_SUBST(GIT_UC_PROGRAM[]_PATH, [$withval])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020062 fi
63 fi
64 m4_popdef([GIT_UC_PROGRAM])])
65
Jakub Narebskia20b4d82006-08-09 02:15:10 +020066# GIT_PARSE_WITH(PACKAGE)
67# -----------------------
68# For use in AC_ARG_WITH action-if-found, for packages default ON.
69# * Set NO_PACKAGE=YesPlease for --without-PACKAGE
70# * Set PACKAGEDIR=PATH for --with-PACKAGE=PATH
71# * Unset NO_PACKAGE for --with-PACKAGE without ARG
72AC_DEFUN([GIT_PARSE_WITH],
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020073 [m4_pushdef([GIT_UC_PACKAGE], m4_toupper([$1]))dnl
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020074 if test "$withval" = "no"; then
75 NO_[]GIT_UC_PACKAGE=YesPlease
76 elif test "$withval" = "yes"; then
77 NO_[]GIT_UC_PACKAGE=
78 else
79 NO_[]GIT_UC_PACKAGE=
80 GIT_UC_PACKAGE[]DIR=$withval
81 AC_MSG_NOTICE([Setting GIT_UC_PACKAGE[]DIR to $withval])
Stefano Lattarini7f8cf482012-07-19 09:49:58 +020082 GIT_CONF_SUBST(GIT_UC_PACKAGE[DIR], [$withval])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020083 fi
84 m4_popdef([GIT_UC_PACKAGE])])
85
Ben Waltond79d9e132009-11-04 13:05:59 -050086# GIT_PARSE_WITH_SET_MAKE_VAR(WITHNAME, VAR, HELP_TEXT)
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020087# -----------------------------------------------------
Elijah Newren15beaaa2019-11-05 17:07:23 +000088# Set VAR to the value specified by --with-WITHNAME.
Ben Waltond79d9e132009-11-04 13:05:59 -050089# No verification of arguments is performed, but warnings are issued
90# if either 'yes' or 'no' is specified.
91# HELP_TEXT is presented when --help is called.
92# This is a direct way to allow setting variables in the Makefile.
93AC_DEFUN([GIT_PARSE_WITH_SET_MAKE_VAR],
94[AC_ARG_WITH([$1],
95 [AS_HELP_STRING([--with-$1=VALUE], $3)],
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020096 if test -n "$withval"; then
97 if test "$withval" = "yes" -o "$withval" = "no"; then
Ben Waltond79d9e132009-11-04 13:05:59 -050098 AC_MSG_WARN([You likely do not want either 'yes' or 'no' as]
Stefano Lattarini5b2d1312012-03-26 18:42:26 +020099 [a value for $1 ($2). Maybe you do...?])
100 fi
101 AC_MSG_NOTICE([Setting $2 to $withval])
Stefano Lattarini610473a2012-07-19 09:49:57 +0200102 GIT_CONF_SUBST([$2], [$withval])
Ben Waltond79d9e132009-11-04 13:05:59 -0500103 fi)])# GIT_PARSE_WITH_SET_MAKE_VAR
Jakub Narebskid3a6db92006-07-08 23:07:09 +0200104
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200105#
106# GIT_CHECK_FUNC(FUNCTION, IFTRUE, IFFALSE)
107# -----------------------------------------
108# Similar to AC_CHECK_FUNC, but on systems that do not generate
109# warnings for missing prototypes (e.g. FreeBSD when compiling without
110# -Wall), it does not work. By looking for function definition in
111# libraries, this problem can be worked around.
David M. Syzdek1689c5d2008-10-26 03:52:19 -0800112AC_DEFUN([GIT_CHECK_FUNC],[AC_CHECK_FUNC([$1],[
113 AC_SEARCH_LIBS([$1],,
114 [$2],[$3])
115],[$3])])
Ben Walton918c8122009-03-12 15:20:08 -0400116
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200117#
118# GIT_STASH_FLAGS(BASEPATH_VAR)
119# -----------------------------
120# Allow for easy stashing of LDFLAGS and CPPFLAGS before running
121# tests that may want to take user settings into account.
Ben Walton918c8122009-03-12 15:20:08 -0400122AC_DEFUN([GIT_STASH_FLAGS],[
123if test -n "$1"; then
124 old_CPPFLAGS="$CPPFLAGS"
125 old_LDFLAGS="$LDFLAGS"
126 CPPFLAGS="-I$1/include $CPPFLAGS"
127 LDFLAGS="-L$1/$lib $LDFLAGS"
128fi
129])
130
131dnl
132dnl GIT_UNSTASH_FLAGS(BASEPATH_VAR)
133dnl -----------------------------
134dnl Restore the stashed *FLAGS values.
135AC_DEFUN([GIT_UNSTASH_FLAGS],[
136if test -n "$1"; then
137 CPPFLAGS="$old_CPPFLAGS"
138 LDFLAGS="$old_LDFLAGS"
139fi
140])
141
Stefano Lattarinie9e8c802012-03-26 18:42:24 +0200142## Configure body starts here.
143
144AC_PREREQ(2.59)
145AC_INIT([git], [@@GIT_VERSION@@], [git@vger.kernel.org])
146
147AC_CONFIG_SRCDIR([git.c])
148
149config_file=config.mak.autogen
Stefano Lattarinie9e8c802012-03-26 18:42:24 +0200150config_in=config.mak.in
151
Stefano Lattarini8242ff42012-07-19 09:50:02 +0200152GIT_CONF_SUBST([AUTOCONFIGURED], [YesPlease])
153
Stefano Lattarini21363942012-03-09 13:43:55 +0100154# Directories holding "saner" versions of common or POSIX binaries.
155AC_ARG_WITH([sane-tool-path],
156 [AS_HELP_STRING(
157 [--with-sane-tool-path=DIR-1[[:DIR-2...:DIR-n]]],
158 [Directories to prepend to PATH in build system and generated scripts])],
159 [if test "$withval" = "no"; then
160 withval=''
161 else
162 AC_MSG_NOTICE([Setting SANE_TOOL_PATH to '$withval'])
163 fi
Stefano Lattarini610473a2012-07-19 09:49:57 +0200164 GIT_CONF_SUBST([SANE_TOOL_PATH], [$withval])],
Stefano Lattarini21363942012-03-09 13:43:55 +0100165 [# If the "--with-sane-tool-path" option was not given, don't touch
166 # SANE_TOOL_PATH here, but let defaults in Makefile take care of it.
167 # This should minimize spurious differences in the behaviour of the
168 # Git build system when configure is used w.r.t. when it is not.
169 :])
170
Jakub Narebskia20b4d82006-08-09 02:15:10 +0200171## Site configuration related to programs (before tests)
Jakub Narebskic4b1b142006-08-03 00:38:56 +0200172## --with-PACKAGE[=ARG] and --without-PACKAGE
173#
Robert Schiele10861be2007-08-01 06:30:35 +0200174# Set lib to alternative name of lib directory (e.g. lib64)
175AC_ARG_WITH([lib],
176 [AS_HELP_STRING([--with-lib=ARG],
177 [ARG specifies alternative name for lib directory])],
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200178 [if test "$withval" = "no" || test "$withval" = "yes"; then
179 AC_MSG_WARN([You should provide name for --with-lib=ARG])
180 else
181 lib=$withval
182 AC_MSG_NOTICE([Setting lib to '$lib'])
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +0200183 GIT_CONF_SUBST([lib])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200184 fi])
Ben Waltone068f4f2009-03-12 15:20:06 -0400185
186if test -z "$lib"; then
187 AC_MSG_NOTICE([Setting lib to 'lib' (the default)])
188 lib=lib
189fi
Ben Walton08df6a32009-03-12 15:20:07 -0400190
Ben Walton1973b0d2009-03-12 15:20:12 -0400191AC_ARG_ENABLE([pthreads],
192 [AS_HELP_STRING([--enable-pthreads=FLAGS],
193 [FLAGS is the value to pass to the compiler to enable POSIX Threads.]
194 [The default if FLAGS is not specified is to try first -pthread]
195 [and then -lpthread.]
Stefano Lattarini94b54042013-06-28 19:19:42 +0200196 [--disable-pthreads will disable threading.])],
Ben Walton1973b0d2009-03-12 15:20:12 -0400197[
198if test "x$enableval" = "xyes"; then
199 AC_MSG_NOTICE([Will try -pthread then -lpthread to enable POSIX Threads])
200elif test "x$enableval" != "xno"; then
201 PTHREAD_CFLAGS=$enableval
202 AC_MSG_NOTICE([Setting '$PTHREAD_CFLAGS' as the FLAGS to enable POSIX Threads])
203else
204 AC_MSG_NOTICE([POSIX Threads will be disabled.])
205 NO_PTHREADS=YesPlease
206 USER_NOPTHREAD=1
207fi],
208[
209 AC_MSG_NOTICE([Will try -pthread then -lpthread to enable POSIX Threads.])
210])
211
Mark Radabb4bbf72010-04-02 20:35:54 -0400212# Define option to enable JavaScript minification
213AC_ARG_ENABLE([jsmin],
214[AS_HELP_STRING([--enable-jsmin=PATH],
215 [PATH is the name of a JavaScript minifier or the absolute path to one.])],
216[
217 JSMIN=$enableval;
218 AC_MSG_NOTICE([Setting JSMIN to '$JSMIN' to enable JavaScript minifying])
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +0200219 GIT_CONF_SUBST([JSMIN])
Mark Radabb4bbf72010-04-02 20:35:54 -0400220])
221
222# Define option to enable CSS minification
223AC_ARG_ENABLE([cssmin],
224[AS_HELP_STRING([--enable-cssmin=PATH],
225 [PATH is the name of a CSS minifier or the absolute path to one.])],
226[
227 CSSMIN=$enableval;
228 AC_MSG_NOTICE([Setting CSSMIN to '$CSSMIN' to enable CSS minifying])
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +0200229 GIT_CONF_SUBST([CSSMIN])
Mark Radabb4bbf72010-04-02 20:35:54 -0400230])
231
Ben Walton08df6a32009-03-12 15:20:07 -0400232## Site configuration (override autodetection)
233## --with-PACKAGE[=ARG] and --without-PACKAGE
234AC_MSG_NOTICE([CHECKS for site configuration])
235#
236# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
237# tests. These tests take up a significant amount of the total test time
238# but are not needed unless you plan to talk to SVN repos.
239#
Ben Walton08df6a32009-03-12 15:20:07 -0400240# Define PPC_SHA1 environment variable when running make to make use of
241# a bundled SHA1 routine optimized for PowerPC.
242#
Ben Walton08df6a32009-03-12 15:20:07 -0400243# Define NO_OPENSSL environment variable if you do not have OpenSSL.
Ben Walton08df6a32009-03-12 15:20:07 -0400244#
245# Define OPENSSLDIR=/foo/bar if your openssl header and library files are in
246# /foo/bar/include and /foo/bar/lib directories.
247AC_ARG_WITH(openssl,
248AS_HELP_STRING([--with-openssl],[use OpenSSL library (default is YES)])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200249AS_HELP_STRING([], [ARG can be prefix for openssl library and headers]),
250GIT_PARSE_WITH([openssl]))
251
Ævar Arnfjörð Bjarmason072473e2017-05-20 21:42:04 +0000252# Define USE_LIBPCRE if you have and want to use libpcre. Various
253# commands such as log and grep offer runtime options to use
254# Perl-compatible regular expressions instead of standard or extended
255# POSIX regular expressions.
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200256#
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000257# USE_LIBPCRE is a synonym for USE_LIBPCRE2, define USE_LIBPCRE1
258# instead if you'd like to use the legacy version 1 of the PCRE
259# library. Support for version 1 will likely be removed in some future
260# release of Git, as upstream has all but abandoned it.
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000261#
262# Define LIBPCREDIR=/foo/bar if your PCRE header and library files are in
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200263# /foo/bar/include and /foo/bar/lib directories.
264#
265AC_ARG_WITH(libpcre,
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000266AS_HELP_STRING([--with-libpcre],[synonym for --with-libpcre2]),
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200267 if test "$withval" = "no"; then
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000268 USE_LIBPCRE2=
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200269 elif test "$withval" = "yes"; then
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000270 USE_LIBPCRE2=YesPlease
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200271 else
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000272 USE_LIBPCRE2=YesPlease
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200273 LIBPCREDIR=$withval
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +0200274 AC_MSG_NOTICE([Setting LIBPCREDIR to $LIBPCREDIR])
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000275 dnl USE_LIBPCRE2 can still be modified below, so don't substitute
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000276 dnl it yet.
277 GIT_CONF_SUBST([LIBPCREDIR])
278 fi)
279
280AC_ARG_WITH(libpcre1,
281AS_HELP_STRING([--with-libpcre1],[support Perl-compatible regexes via libpcre1 (default is NO)])
282AS_HELP_STRING([], [ARG can be also prefix for libpcre library and headers]),
283 if test "$withval" = "no"; then
284 USE_LIBPCRE1=
285 elif test "$withval" = "yes"; then
286 USE_LIBPCRE1=YesPlease
287 else
288 USE_LIBPCRE1=YesPlease
289 LIBPCREDIR=$withval
290 AC_MSG_NOTICE([Setting LIBPCREDIR to $LIBPCREDIR])
291 dnl USE_LIBPCRE1 can still be modified below, so don't substitute
292 dnl it yet.
293 GIT_CONF_SUBST([LIBPCREDIR])
294 fi)
295
296AC_ARG_WITH(libpcre2,
297AS_HELP_STRING([--with-libpcre2],[support Perl-compatible regexes via libpcre2 (default is NO)])
298AS_HELP_STRING([], [ARG can be also prefix for libpcre library and headers]),
Ævar Arnfjörð Bjarmasone6c531b2018-03-11 13:26:09 +0000299 if test -n "$USE_LIBPCRE2"; then
300 AC_MSG_ERROR([Only supply one of --with-libpcre or its synonym --with-libpcre2!])
301 fi
302
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000303 if test -n "$USE_LIBPCRE1"; then
304 AC_MSG_ERROR([Only supply one of --with-libpcre1 or --with-libpcre2!])
305 fi
306
307 if test "$withval" = "no"; then
308 USE_LIBPCRE2=
309 elif test "$withval" = "yes"; then
310 USE_LIBPCRE2=YesPlease
311 else
312 USE_LIBPCRE2=YesPlease
313 LIBPCREDIR=$withval
314 AC_MSG_NOTICE([Setting LIBPCREDIR to $LIBPCREDIR])
315 dnl USE_LIBPCRE2 can still be modified below, so don't substitute
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200316 dnl it yet.
Stefano Lattarini3a34c2b2012-09-11 17:45:29 +0200317 GIT_CONF_SUBST([LIBPCREDIR])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200318 fi)
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200319#
Kirill Smelkov61f76a32014-03-27 18:22:50 +0400320# Define HAVE_ALLOCA_H if you have working alloca(3) defined in that header.
321AC_FUNC_ALLOCA
322case $ac_cv_working_alloca_h in
323 yes) HAVE_ALLOCA_H=YesPlease;;
324 *) HAVE_ALLOCA_H='';;
325esac
326GIT_CONF_SUBST([HAVE_ALLOCA_H])
327#
Ben Walton08df6a32009-03-12 15:20:07 -0400328# Define NO_CURL if you do not have curl installed. git-http-pull and
329# git-http-push are not built, and you cannot use http:// and https://
330# transports.
331#
332# Define CURLDIR=/foo/bar if your curl header and library files are in
333# /foo/bar/include and /foo/bar/lib directories.
334AC_ARG_WITH(curl,
335AS_HELP_STRING([--with-curl],[support http(s):// transports (default is YES)])
336AS_HELP_STRING([], [ARG can be also prefix for curl library and headers]),
337GIT_PARSE_WITH(curl))
338#
339# Define NO_EXPAT if you do not have expat installed. git-http-push is
340# not built, and you cannot push using http:// and https:// transports.
341#
342# Define EXPATDIR=/foo/bar if your expat header and library files are in
343# /foo/bar/include and /foo/bar/lib directories.
344AC_ARG_WITH(expat,
345AS_HELP_STRING([--with-expat],
346[support git-push using http:// and https:// transports via WebDAV (default is YES)])
347AS_HELP_STRING([], [ARG can be also prefix for expat library and headers]),
348GIT_PARSE_WITH(expat))
349#
350# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
351# installed in /sw, but don't want GIT to link against any libraries
352# installed there. If defined you may specify your own (or Fink's)
353# include directories and library directories by defining CFLAGS
354# and LDFLAGS appropriately.
355#
356# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
357# have DarwinPorts installed in /opt/local, but don't want GIT to
358# link against any libraries installed there. If defined you may
359# specify your own (or DarwinPort's) include directories and
360# library directories by defining CFLAGS and LDFLAGS appropriately.
361#
362# Define NO_MMAP if you want to avoid mmap.
363#
364# Define NO_ICONV if your libc does not properly support iconv.
365AC_ARG_WITH(iconv,
366AS_HELP_STRING([--without-iconv],
367[if your architecture doesn't properly support iconv])
368AS_HELP_STRING([--with-iconv=PATH],
369[PATH is prefix for libiconv library and headers])
370AS_HELP_STRING([],
371[used only if you need linking with libiconv]),
372GIT_PARSE_WITH(iconv))
373
374## --enable-FEATURE[=ARG] and --disable-FEATURE
375#
376# Define USE_NSEC below if you want git to care about sub-second file mtimes
377# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
378# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
379# randomly break unless your underlying filesystem supports those sub-second
380# times (my ext3 doesn't).
381#
382# Define USE_STDEV below if you want git to care about the underlying device
383# change being considered an inode change from the update-index perspective.
384
Robert Schiele10861be2007-08-01 06:30:35 +0200385#
Ben Walton5ca53772009-11-04 13:06:00 -0500386# Allow user to set ETC_GITCONFIG variable
387GIT_PARSE_WITH_SET_MAKE_VAR(gitconfig, ETC_GITCONFIG,
388 Use VALUE instead of /etc/gitconfig as the
389 global git configuration file.
Petr Onderka6df42ab2010-09-01 00:42:43 +0200390 If VALUE is not fully qualified it will be interpreted
391 as a path relative to the computed prefix at runtime.)
392
393#
394# Allow user to set ETC_GITATTRIBUTES variable
395GIT_PARSE_WITH_SET_MAKE_VAR(gitattributes, ETC_GITATTRIBUTES,
396 Use VALUE instead of /etc/gitattributes as the
397 global git attributes file.
398 If VALUE is not fully qualified it will be interpreted
Ben Walton5ca53772009-11-04 13:06:00 -0500399 as a path relative to the computed prefix at runtime.)
400
401#
402# Allow user to set the default pager
403GIT_PARSE_WITH_SET_MAKE_VAR(pager, DEFAULT_PAGER,
404 Use VALUE as the fall-back pager instead of 'less'.
405 This is used by things like 'git log' when the user
406 does not specify a pager to use through alternate
407 methods. eg: /usr/bin/pager)
408#
409# Allow user to set the default editor
410GIT_PARSE_WITH_SET_MAKE_VAR(editor, DEFAULT_EDITOR,
411 Use VALUE as the fall-back editor instead of 'vi'.
412 This is used by things like 'git commit' when the user
413 does not specify a preferred editor through other
414 methods. eg: /usr/bin/editor)
415
416#
Jakub Narebski465e6492006-08-04 17:55:58 +0200417# Define SHELL_PATH to provide path to shell.
418GIT_ARG_SET_PATH(shell)
419#
420# Define PERL_PATH to provide path to Perl.
421GIT_ARG_SET_PATH(perl)
422#
Johan Herlandd4e1b472009-11-18 02:42:31 +0100423# Define PYTHON_PATH to provide path to Python.
Ben Waltondc782502010-01-31 21:15:05 -0500424GIT_ARG_SET_PATH(python, allow-without)
Johan Herlandd4e1b472009-11-18 02:42:31 +0100425#
Robert Schielebef19da2007-07-29 20:35:45 +0200426# Define ZLIB_PATH to provide path to zlib.
427GIT_ARG_SET_PATH(zlib)
428#
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700429# Declare the with-tcltk/without-tcltk options.
430AC_ARG_WITH(tcltk,
431AS_HELP_STRING([--with-tcltk],[use Tcl/Tk GUI (default is YES)])
432AS_HELP_STRING([],[ARG is the full path to the Tcl/Tk interpreter.])
433AS_HELP_STRING([],[Bare --with-tcltk will make the GUI part only if])
Stefano Lattarini5b2d1312012-03-26 18:42:26 +0200434AS_HELP_STRING([],[Tcl/Tk interpreter will be found in a system.]),
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700435GIT_PARSE_WITH(tcltk))
436#
Jakub Narebskic4b1b142006-08-03 00:38:56 +0200437
438
Jakub Narebski633b4232006-07-08 23:07:08 +0200439## Checks for programs.
Jakub Narebskifd22c022006-07-08 23:07:13 +0200440AC_MSG_NOTICE([CHECKS for programs])
Jakub Narebskif6719572006-07-08 23:07:14 +0200441#
Dennis Stosberg60a144f2006-08-15 11:01:31 +0200442AC_PROG_CC([cc gcc])
Gary V. Vaughanf9f33cd2010-05-14 09:31:43 +0000443AC_C_INLINE
444case $ac_cv_c_inline in
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200445 inline | yes | no) INLINE='';;
446 *) INLINE=$ac_cv_c_inline ;;
Gary V. Vaughanf9f33cd2010-05-14 09:31:43 +0000447esac
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200448GIT_CONF_SUBST([INLINE])
Gary V. Vaughanf9f33cd2010-05-14 09:31:43 +0000449
Giovanni Funchal798a9452008-08-16 15:01:23 +0200450# which switch to pass runtime path to dynamic libraries to the linker
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100451AC_CACHE_CHECK([if linker supports -R], git_cv_ld_dashr, [
Giovanni Funchal798a9452008-08-16 15:01:23 +0200452 SAVE_LDFLAGS="${LDFLAGS}"
453 LDFLAGS="${SAVE_LDFLAGS} -R /"
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100454 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], [git_cv_ld_dashr=yes], [git_cv_ld_dashr=no])
Giovanni Funchal798a9452008-08-16 15:01:23 +0200455 LDFLAGS="${SAVE_LDFLAGS}"
456])
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100457if test "$git_cv_ld_dashr" = "yes"; then
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200458 CC_LD_DYNPATH=-R
Giovanni Funchal798a9452008-08-16 15:01:23 +0200459else
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100460 AC_CACHE_CHECK([if linker supports -Wl,-rpath,], git_cv_ld_wl_rpath, [
Giovanni Funchal798a9452008-08-16 15:01:23 +0200461 SAVE_LDFLAGS="${LDFLAGS}"
462 LDFLAGS="${SAVE_LDFLAGS} -Wl,-rpath,/"
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100463 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], [git_cv_ld_wl_rpath=yes], [git_cv_ld_wl_rpath=no])
Paul Jarc50a4b352009-01-04 21:27:41 -0500464 LDFLAGS="${SAVE_LDFLAGS}"
Giovanni Funchal798a9452008-08-16 15:01:23 +0200465 ])
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100466 if test "$git_cv_ld_wl_rpath" = "yes"; then
Øyvind A. Holm9979a502012-10-09 16:26:11 +0200467 CC_LD_DYNPATH=-Wl,-rpath,
Giovanni Funchal798a9452008-08-16 15:01:23 +0200468 else
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100469 AC_CACHE_CHECK([if linker supports -rpath], git_cv_ld_rpath, [
Giovanni Funchal798a9452008-08-16 15:01:23 +0200470 SAVE_LDFLAGS="${LDFLAGS}"
471 LDFLAGS="${SAVE_LDFLAGS} -rpath /"
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100472 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], [git_cv_ld_rpath=yes], [git_cv_ld_rpath=no])
Paul Jarc50a4b352009-01-04 21:27:41 -0500473 LDFLAGS="${SAVE_LDFLAGS}"
Giovanni Funchal798a9452008-08-16 15:01:23 +0200474 ])
Ralf Wildenhuesa1a587e2009-01-19 21:34:36 +0100475 if test "$git_cv_ld_rpath" = "yes"; then
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200476 CC_LD_DYNPATH=-rpath
Giovanni Funchal798a9452008-08-16 15:01:23 +0200477 else
Michael Osipov9a1699c2019-05-16 11:34:12 +0200478 AC_CACHE_CHECK([if linker supports -Wl,+b,], git_cv_ld_wl_b, [
479 SAVE_LDFLAGS="${LDFLAGS}"
480 LDFLAGS="${SAVE_LDFLAGS} -Wl,+b,/"
481 AC_LINK_IFELSE([AC_LANG_PROGRAM([], [])], [git_cv_ld_wl_b=yes], [git_cv_ld_wl_b=no])
482 LDFLAGS="${SAVE_LDFLAGS}"
483 ])
484 if test "$git_cv_ld_wl_b" = "yes"; then
485 CC_LD_DYNPATH=-Wl,+b,
486 else
487 CC_LD_DYNPATH=
488 AC_MSG_WARN([linker does not support runtime path to dynamic libraries])
489 fi
Giovanni Funchal798a9452008-08-16 15:01:23 +0200490 fi
491 fi
492fi
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200493GIT_CONF_SUBST([CC_LD_DYNPATH])
Jakub Narebskifd22c022006-07-08 23:07:13 +0200494#AC_PROG_INSTALL # needs install-sh or install.sh in sources
Robert Schiele96e24ab2007-10-03 03:49:34 +0200495AC_CHECK_TOOLS(AR, [gar ar], :)
Jakub Narebskifd22c022006-07-08 23:07:13 +0200496AC_CHECK_PROGS(TAR, [gtar tar])
Gary V. Vaughand1b1a912010-05-14 09:31:36 +0000497AC_CHECK_PROGS(DIFF, [gnudiff gdiff diff])
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700498# TCLTK_PATH will be set to some value if we want Tcl/Tk
499# or will be empty otherwise.
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200500if test -n "$NO_TCLTK"; then
501 TCLTK_PATH=
502else
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700503 if test "$with_tcltk" = ""; then
504 # No Tcl/Tk switches given. Do not check for Tcl/Tk, use bare 'wish'.
505 TCLTK_PATH=wish
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700506 elif test "$with_tcltk" = "yes"; then
507 # Tcl/Tk check requested.
508 AC_CHECK_PROGS(TCLTK_PATH, [wish], )
Eygene Ryabinkin68daee02007-03-29 14:06:48 +0400509 else
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700510 AC_MSG_RESULT([Using Tcl/Tk interpreter $with_tcltk])
511 TCLTK_PATH="$with_tcltk"
Eygene Ryabinkin81b63c72007-03-28 04:12:07 -0700512 fi
513fi
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200514GIT_CONF_SUBST([TCLTK_PATH])
Jakub Narebski923db422007-12-09 13:57:39 +0100515AC_CHECK_PROGS(ASCIIDOC, [asciidoc])
516if test -n "$ASCIIDOC"; then
517 AC_MSG_CHECKING([for asciidoc version])
Ben Walton29adc8b2009-03-12 15:20:10 -0400518 asciidoc_version=`$ASCIIDOC --version 2>/dev/null`
Jakub Narebski923db422007-12-09 13:57:39 +0100519 case "${asciidoc_version}" in
Jeff King79c461d2010-11-19 12:54:24 -0500520 asciidoc' '8*)
Jakub Narebski923db422007-12-09 13:57:39 +0100521 AC_MSG_RESULT([${asciidoc_version}])
522 ;;
523 *)
Jakub Narebski923db422007-12-09 13:57:39 +0100524 AC_MSG_RESULT([${asciidoc_version} (unknown)])
525 ;;
526 esac
527fi
Jakub Narebski923db422007-12-09 13:57:39 +0100528
Junio C Hamano71b40102016-03-08 15:47:57 -0800529if grep -a ascii configure.ac >/dev/null; then
530 AC_MSG_RESULT([Using 'grep -a' for sane_grep])
531 SANE_TEXT_GREP=-a
532else
533 SANE_TEXT_GREP=
534fi
535GIT_CONF_SUBST([SANE_TEXT_GREP])
Jakub Narebski633b4232006-07-08 23:07:08 +0200536
537## Checks for libraries.
Jakub Narebskiebdf5322006-07-08 23:07:12 +0200538AC_MSG_NOTICE([CHECKS for libraries])
Jakub Narebskif6719572006-07-08 23:07:14 +0200539#
Jakub Narebski633b4232006-07-08 23:07:08 +0200540# Define NO_OPENSSL environment variable if you do not have OpenSSL.
Jakub Narebskiebdf5322006-07-08 23:07:12 +0200541# Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin).
Ben Walton310386f2009-03-12 15:20:09 -0400542
543GIT_STASH_FLAGS($OPENSSLDIR)
544
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200545AC_CHECK_LIB([crypto], [SHA1_Init],
Jakub Narebski424adc52006-08-08 18:39:06 +0200546[NEEDS_SSL_WITH_CRYPTO=],
Junio C Hamano3068f6c2006-08-04 16:33:18 -0700547[AC_CHECK_LIB([ssl], [SHA1_Init],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200548 [NEEDS_SSL_WITH_CRYPTO=YesPlease NO_OPENSSL=],
549 [NEEDS_SSL_WITH_CRYPTO= NO_OPENSSL=YesPlease])])
Ben Walton310386f2009-03-12 15:20:09 -0400550
551GIT_UNSTASH_FLAGS($OPENSSLDIR)
552
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200553GIT_CONF_SUBST([NEEDS_SSL_WITH_CRYPTO])
554GIT_CONF_SUBST([NO_OPENSSL])
Ben Walton310386f2009-03-12 15:20:09 -0400555
Jakub Narebskif6719572006-07-08 23:07:14 +0200556#
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000557# Handle the USE_LIBPCRE1 and USE_LIBPCRE2 options potentially set
558# above.
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200559#
560
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000561if test -n "$USE_LIBPCRE1"; then
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200562
563GIT_STASH_FLAGS($LIBPCREDIR)
564
565AC_CHECK_LIB([pcre], [pcre_version],
Ævar Arnfjörð Bjarmasona91b1132018-03-11 13:26:07 +0000566[USE_LIBPCRE1=YesPlease],
567[USE_LIBPCRE1=])
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200568
569GIT_UNSTASH_FLAGS($LIBPCREDIR)
570
Ævar Arnfjörð Bjarmason94da9192017-06-01 18:20:56 +0000571GIT_CONF_SUBST([USE_LIBPCRE1])
572
573fi
574
575
576if test -n "$USE_LIBPCRE2"; then
577
578GIT_STASH_FLAGS($LIBPCREDIR)
579
580AC_CHECK_LIB([pcre2-8], [pcre2_config_8],
581[USE_LIBPCRE2=YesPlease],
582[USE_LIBPCRE2=])
583
584GIT_UNSTASH_FLAGS($LIBPCREDIR)
585
586GIT_CONF_SUBST([USE_LIBPCRE2])
Michał Kiedrowicza119f912011-05-09 23:52:06 +0200587
588fi
589
590#
Johan Herland8da1e212008-06-15 12:14:12 +0200591# Define NO_CURL if you do not have libcurl installed. git-http-pull and
Jakub Narebski633b4232006-07-08 23:07:08 +0200592# git-http-push are not built, and you cannot use http:// and https://
593# transports.
Ben Walton310386f2009-03-12 15:20:09 -0400594
595GIT_STASH_FLAGS($CURLDIR)
596
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200597AC_CHECK_LIB([curl], [curl_global_init],
Jakub Narebski424adc52006-08-08 18:39:06 +0200598[NO_CURL=],
599[NO_CURL=YesPlease])
Ben Walton310386f2009-03-12 15:20:09 -0400600
601GIT_UNSTASH_FLAGS($CURLDIR)
602
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200603GIT_CONF_SUBST([NO_CURL])
Ben Walton310386f2009-03-12 15:20:09 -0400604
Remi Pommarelf8915872015-10-21 19:10:46 +0200605if test -z "$NO_CURL"; then
606
607AC_CHECK_PROG([CURL_CONFIG], [curl-config],
608[curl-config],
609[no])
610
611if test $CURL_CONFIG != no; then
612 GIT_CONF_SUBST([CURL_CONFIG])
James Knight23c4bbe2018-11-03 05:12:11 +0000613
614 if test -z "$CURL_CONFIG_OPTS"; then
615 CURL_CONFIG_OPTS="--libs"
Дилян Палаузов924b7eb2016-06-28 12:04:34 +0000616 fi
James Knight23c4bbe2018-11-03 05:12:11 +0000617
618 CURL_LDFLAGS=$($CURL_CONFIG $CURL_CONFIG_OPTS)
619 AC_MSG_NOTICE([Setting CURL_LDFLAGS to '$CURL_LDFLAGS'])
620 GIT_CONF_SUBST([CURL_LDFLAGS], [$CURL_LDFLAGS])
Remi Pommarelf8915872015-10-21 19:10:46 +0200621fi
622
623fi
624
625
Jakub Narebskif6719572006-07-08 23:07:14 +0200626#
Jakub Narebski633b4232006-07-08 23:07:08 +0200627# Define NO_EXPAT if you do not have expat installed. git-http-push is
628# not built, and you cannot push using http:// and https:// transports.
Ben Walton310386f2009-03-12 15:20:09 -0400629
630GIT_STASH_FLAGS($EXPATDIR)
631
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200632AC_CHECK_LIB([expat], [XML_ParserCreate],
Jakub Narebski424adc52006-08-08 18:39:06 +0200633[NO_EXPAT=],
634[NO_EXPAT=YesPlease])
Ben Walton310386f2009-03-12 15:20:09 -0400635
636GIT_UNSTASH_FLAGS($EXPATDIR)
637
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200638GIT_CONF_SUBST([NO_EXPAT])
Ben Walton310386f2009-03-12 15:20:09 -0400639
Jakub Narebskif6719572006-07-08 23:07:14 +0200640#
Fredrik Kuivinene63ccb82007-02-18 09:44:42 +0100641# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin and
642# some Solaris installations).
Jakub Narebski6ff88de2006-09-07 13:48:08 +0200643# Define NO_ICONV if neither libc nor libiconv support iconv.
Ben Walton310386f2009-03-12 15:20:09 -0400644
Marco Nelissen934f82a2009-06-08 20:46:38 -0700645if test -z "$NO_ICONV"; then
646
Ben Walton310386f2009-03-12 15:20:09 -0400647GIT_STASH_FLAGS($ICONVDIR)
648
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100649AC_DEFUN([ICONVTEST_SRC],
650[AC_LANG_PROGRAM([#include <iconv.h>],
651 [iconv_open("", "");])])
Ben Waltona8304f72009-03-12 15:20:11 -0400652
653if test -n "$ICONVDIR"; then
654 lib_order="-liconv -lc"
655else
656 lib_order="-lc -liconv"
657fi
658
659NO_ICONV=YesPlease
660
661for l in $lib_order; do
662 if test "$l" = "-liconv"; then
663 NEEDS_LIBICONV=YesPlease
664 else
665 NEEDS_LIBICONV=
666 fi
667
668 old_LIBS="$LIBS"
669 LIBS="$LIBS $l"
670 AC_MSG_CHECKING([for iconv in $l])
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100671 AC_LINK_IFELSE([ICONVTEST_SRC],
Fredrik Kuivinene63ccb82007-02-18 09:44:42 +0100672 [AC_MSG_RESULT([yes])
Ben Waltona8304f72009-03-12 15:20:11 -0400673 NO_ICONV=
674 break],
675 [AC_MSG_RESULT([no])])
676 LIBS="$old_LIBS"
677done
678
679#in case of break
680LIBS="$old_LIBS"
Ben Walton310386f2009-03-12 15:20:09 -0400681
682GIT_UNSTASH_FLAGS($ICONVDIR)
683
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200684GIT_CONF_SUBST([NEEDS_LIBICONV])
685GIT_CONF_SUBST([NO_ICONV])
Ben Walton310386f2009-03-12 15:20:09 -0400686
Marco Nelissen934f82a2009-06-08 20:46:38 -0700687if test -n "$NO_ICONV"; then
688 NEEDS_LIBICONV=
689fi
690
691fi
692
Jakub Narebskif6719572006-07-08 23:07:14 +0200693#
David Symonds609a2282007-11-07 14:24:28 +1100694# Define NO_DEFLATE_BOUND if deflateBound is missing from zlib.
Ben Walton310386f2009-03-12 15:20:09 -0400695
696GIT_STASH_FLAGS($ZLIB_PATH)
697
David Symonds609a2282007-11-07 14:24:28 +1100698AC_DEFUN([ZLIBTEST_SRC], [
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100699AC_LANG_PROGRAM([#include <zlib.h>],
700 [deflateBound(0, 0);])])
David Symonds609a2282007-11-07 14:24:28 +1100701AC_MSG_CHECKING([for deflateBound in -lz])
702old_LIBS="$LIBS"
703LIBS="$LIBS -lz"
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100704AC_LINK_IFELSE([ZLIBTEST_SRC],
David Symonds609a2282007-11-07 14:24:28 +1100705 [AC_MSG_RESULT([yes])],
706 [AC_MSG_RESULT([no])
707 NO_DEFLATE_BOUND=yes])
708LIBS="$old_LIBS"
Ben Walton310386f2009-03-12 15:20:09 -0400709
710GIT_UNSTASH_FLAGS($ZLIB_PATH)
711
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200712GIT_CONF_SUBST([NO_DEFLATE_BOUND])
Ben Walton310386f2009-03-12 15:20:09 -0400713
David Symonds609a2282007-11-07 14:24:28 +1100714#
Jakub Narebski633b4232006-07-08 23:07:08 +0200715# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
716# Patrick Mauritz).
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200717AC_CHECK_LIB([c], [socket],
Jakub Narebski424adc52006-08-08 18:39:06 +0200718[NEEDS_SOCKET=],
719[NEEDS_SOCKET=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200720GIT_CONF_SUBST([NEEDS_SOCKET])
Dennis Stosbergd1b99442006-08-15 11:01:27 +0200721test -n "$NEEDS_SOCKET" && LIBS="$LIBS -lsocket"
Jakub Narebski633b4232006-07-08 23:07:08 +0200722
Ralf Wildenhues8fccb002009-06-07 07:40:29 +0200723#
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000724# The next few tests will define NEEDS_RESOLV if linking with
725# libresolv provides some of the functions we would normally get
726# from libc.
727NEEDS_RESOLV=
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000728#
729# Define NO_INET_NTOP if linking with -lresolv is not enough.
730# Solaris 2.7 in particular hos inet_ntop in -lresolv.
731NO_INET_NTOP=
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000732AC_CHECK_FUNC([inet_ntop],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200733 [],
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000734 [AC_CHECK_LIB([resolv], [inet_ntop],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200735 [NEEDS_RESOLV=YesPlease],
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000736 [NO_INET_NTOP=YesPlease])
737])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200738GIT_CONF_SUBST([NO_INET_NTOP])
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000739#
740# Define NO_INET_PTON if linking with -lresolv is not enough.
741# Solaris 2.7 in particular hos inet_pton in -lresolv.
742NO_INET_PTON=
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000743AC_CHECK_FUNC([inet_pton],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200744 [],
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000745 [AC_CHECK_LIB([resolv], [inet_pton],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200746 [NEEDS_RESOLV=YesPlease],
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000747 [NO_INET_PTON=YesPlease])
748])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200749GIT_CONF_SUBST([NO_INET_PTON])
Gary V. Vaughan0a9b1672010-05-14 09:31:40 +0000750#
751# Define NO_HSTRERROR if linking with -lresolv is not enough.
752# Solaris 2.6 in particular has no hstrerror, even in -lresolv.
753NO_HSTRERROR=
754AC_CHECK_FUNC([hstrerror],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200755 [],
Gary V. Vaughan0a9b1672010-05-14 09:31:40 +0000756 [AC_CHECK_LIB([resolv], [hstrerror],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200757 [NEEDS_RESOLV=YesPlease],
Gary V. Vaughan0a9b1672010-05-14 09:31:40 +0000758 [NO_HSTRERROR=YesPlease])
759])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200760GIT_CONF_SUBST([NO_HSTRERROR])
761
762dnl This must go after all the possible places for its initialization,
763dnl in the AC_CHECK_FUNC invocations above.
764GIT_CONF_SUBST([NEEDS_RESOLV])
Gary V. Vaughan5a857c72010-05-14 09:31:41 +0000765#
766# If any of the above tests determined that -lresolv is needed at
767# build-time, also set it here for remaining configure-time checks.
Ralf Wildenhues8fccb002009-06-07 07:40:29 +0200768test -n "$NEEDS_RESOLV" && LIBS="$LIBS -lresolv"
Jakub Narebski633b4232006-07-08 23:07:08 +0200769
Brandon Caseya1142892009-07-21 15:23:06 -0500770AC_CHECK_LIB([c], [basename],
Brandon Caseyecc395c2009-07-10 12:10:45 -0500771[NEEDS_LIBGEN=],
772[NEEDS_LIBGEN=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200773GIT_CONF_SUBST([NEEDS_LIBGEN])
Brandon Caseyecc395c2009-07-10 12:10:45 -0500774test -n "$NEEDS_LIBGEN" && LIBS="$LIBS -lgen"
775
Vadim Kochanb71e56a2019-04-18 08:04:19 +0300776AC_DEFUN([LIBINTL_SRC], [
777AC_LANG_PROGRAM([[
778#include <libintl.h>
779]],[[
780char *msg = gettext("test");
781]])])
782
783AC_MSG_CHECKING([if libc contains libintl])
784AC_LINK_IFELSE([LIBINTL_SRC],
785 [AC_MSG_RESULT([yes])
786 LIBC_CONTAINS_LIBINTL=YesPlease],
787 [AC_MSG_RESULT([no])
788 LIBC_CONTAINS_LIBINTL=])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200789GIT_CONF_SUBST([LIBC_CONTAINS_LIBINTL])
John Szakmeistera8356d42012-02-18 14:38:04 -0500790
791#
792# Define NO_GETTEXT if you don't want Git output to be translated.
793# A translated Git requires GNU libintl or another gettext implementation
794AC_CHECK_HEADER([libintl.h],
795[NO_GETTEXT=],
796[NO_GETTEXT=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200797GIT_CONF_SUBST([NO_GETTEXT])
John Szakmeistera8356d42012-02-18 14:38:04 -0500798
799if test -z "$NO_GETTEXT"; then
800 test -n "$LIBC_CONTAINS_LIBINTL" || LIBS="$LIBS -lintl"
801fi
Ævar Arnfjörð Bjarmason5e9637c2011-11-18 00:14:42 +0100802
Jakub Narebski633b4232006-07-08 23:07:08 +0200803## Checks for header files.
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100804AC_MSG_NOTICE([CHECKS for header files])
805#
Jakub Narebski3cf32372008-01-25 12:19:41 +0100806# Define NO_SYS_SELECT_H if you don't have sys/select.h.
807AC_CHECK_HEADER([sys/select.h],
808[NO_SYS_SELECT_H=],
809[NO_SYS_SELECT_H=UnfortunatelyYes])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200810GIT_CONF_SUBST([NO_SYS_SELECT_H])
Jakub Narebski3cf32372008-01-25 12:19:41 +0100811#
Đoàn Trần Công Danh2648ccc2018-11-14 08:10:43 +0700812# Define NO_POLL_H if you don't have poll.h
813AC_CHECK_HEADER([poll.h],
814[NO_POLL_H=],
815[NO_POLL_H=UnfortunatelyYes])
816GIT_CONF_SUBST([NO_POLL_H])
817#
Markus Duft25fe66f2010-10-27 10:39:53 +0200818# Define NO_SYS_POLL_H if you don't have sys/poll.h
819AC_CHECK_HEADER([sys/poll.h],
820[NO_SYS_POLL_H=],
821[NO_SYS_POLL_H=UnfortunatelyYes])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200822GIT_CONF_SUBST([NO_SYS_POLL_H])
Markus Duft25fe66f2010-10-27 10:39:53 +0200823#
824# Define NO_INTTYPES_H if you don't have inttypes.h
825AC_CHECK_HEADER([inttypes.h],
826[NO_INTTYPES_H=],
827[NO_INTTYPES_H=UnfortunatelyYes])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200828GIT_CONF_SUBST([NO_INTTYPES_H])
Markus Duft25fe66f2010-10-27 10:39:53 +0200829#
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100830# Define OLD_ICONV if your library has an old iconv(), where the second
831# (input buffer pointer) parameter is declared with type (const char **).
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100832AC_DEFUN([OLDICONVTEST_SRC], [
833AC_LANG_PROGRAM([[
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100834#include <iconv.h>
835
836extern size_t iconv(iconv_t cd,
837 char **inbuf, size_t *inbytesleft,
838 char **outbuf, size_t *outbytesleft);
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100839]], [])])
Ben Waltona8304f72009-03-12 15:20:11 -0400840
841GIT_STASH_FLAGS($ICONVDIR)
842
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100843AC_MSG_CHECKING([for old iconv()])
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +0100844AC_COMPILE_IFELSE([OLDICONVTEST_SRC],
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100845 [AC_MSG_RESULT([no])],
846 [AC_MSG_RESULT([yes])
Doan Tran Cong Danh1ba6e7a2019-11-08 16:43:44 +0700847 AC_DEFINE(HAVE_OLD_ICONV, 1)
Jakub Narebski0f7a9c92007-12-07 02:27:20 +0100848 OLD_ICONV=UnfortunatelyYes])
Jakub Narebski633b4232006-07-08 23:07:08 +0200849
Ben Waltona8304f72009-03-12 15:20:11 -0400850GIT_UNSTASH_FLAGS($ICONVDIR)
851
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200852GIT_CONF_SUBST([OLD_ICONV])
Jakub Narebski633b4232006-07-08 23:07:08 +0200853
Doan Tran Cong Danh1ba6e7a2019-11-08 16:43:44 +0700854#
855# Define ICONV_OMITS_BOM if you are on a system which
856# iconv omits bom for utf-{16,32}
857if test -z "$NO_ICONV"; then
858AC_CACHE_CHECK([whether iconv omits bom for utf-16 and utf-32],
859 [ac_cv_iconv_omits_bom],
860[
861old_LIBS="$LIBS"
862if test -n "$NEEDS_LIBICONV"; then
863 LIBS="$LIBS -liconv"
864fi
865
866AC_RUN_IFELSE(
867 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT
868 #include <iconv.h>
869 #ifdef HAVE_OLD_ICONV
870 typedef const char *iconv_ibp;
871 #else
872 typedef char *iconv_ibp;
873 #endif
874 ],
875 [[
876 int v;
877 iconv_t conv;
878 char in[] = "a"; iconv_ibp pin = in;
879 char out[20] = ""; char *pout = out;
880 size_t isz = sizeof in;
881 size_t osz = sizeof out;
882
883 conv = iconv_open("UTF-16", "UTF-8");
884 iconv(conv, &pin, &isz, &pout, &osz);
885 iconv_close(conv);
886 v = (unsigned char)(out[0]) + (unsigned char)(out[1]);
887 return v != 0xfe + 0xff;
888 ]])],
889 [ac_cv_iconv_omits_bom=no],
890 [ac_cv_iconv_omits_bom=yes])
891
892LIBS="$old_LIBS"
893])
894if test "x$ac_cv_iconv_omits_bom" = xyes; then
895 ICONV_OMITS_BOM=Yes
896else
897 ICONV_OMITS_BOM=
898fi
899GIT_CONF_SUBST([ICONV_OMITS_BOM])
900fi
901
Jakub Narebski633b4232006-07-08 23:07:08 +0200902## Checks for typedefs, structures, and compiler characteristics.
Jakub Narebskieb0f2552006-07-08 23:07:10 +0200903AC_MSG_NOTICE([CHECKS for typedefs, structures, and compiler characteristics])
Jakub Narebskif6719572006-07-08 23:07:14 +0200904#
Gary V. Vaughane88a1352010-05-14 09:31:42 +0000905TYPE_SOCKLEN_T
906case $ac_cv_type_socklen_t in
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200907 yes) SOCKLEN_T='';;
908 *) SOCKLEN_T=$git_cv_socklen_t_equiv;;
Gary V. Vaughane88a1352010-05-14 09:31:42 +0000909esac
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200910GIT_CONF_SUBST([SOCKLEN_T])
Gary V. Vaughane88a1352010-05-14 09:31:42 +0000911
Jonas 'Sortie' Termansen64410902014-08-29 09:42:34 -0700912#
913# Define NO_STRUCT_ITIMERVAL if you don't have struct itimerval.
914AC_CHECK_TYPES([struct itimerval],
915[NO_STRUCT_ITIMERVAL=],
916[NO_STRUCT_ITIMERVAL=UnfortunatelyYes],
917[#include <sys/time.h>])
918GIT_CONF_SUBST([NO_STRUCT_ITIMERVAL])
919#
Reuben Hawkins8bd2c972015-01-08 12:00:55 -0800920# Define USE_ST_TIMESPEC=YesPlease when stat.st_mtimespec.tv_nsec exists.
921# Define NO_NSEC=YesPlease when neither stat.st_mtim.tv_nsec nor
922# stat.st_mtimespec.tv_nsec exists.
923AC_CHECK_MEMBER([struct stat.st_mtimespec.tv_nsec])
924AC_CHECK_MEMBER([struct stat.st_mtim.tv_nsec])
925if test x$ac_cv_member_struct_stat_st_mtimespec_tv_nsec = xyes; then
926 USE_ST_TIMESPEC=YesPlease
927 GIT_CONF_SUBST([USE_ST_TIMESPEC])
928elif test x$ac_cv_member_struct_stat_st_mtim_tv_nsec != xyes; then
929 NO_NSEC=YesPlease
930 GIT_CONF_SUBST([NO_NSEC])
931fi
932#
Jakub Narebski633b4232006-07-08 23:07:08 +0200933# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
934# d_type in struct dirent (latest Cygwin -- will be fixed soonish).
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200935AC_CHECK_MEMBER(struct dirent.d_type,
Jakub Narebski424adc52006-08-08 18:39:06 +0200936[NO_D_TYPE_IN_DIRENT=],
937[NO_D_TYPE_IN_DIRENT=YesPlease],
Jakub Narebskieb0f2552006-07-08 23:07:10 +0200938[#include <dirent.h>])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200939GIT_CONF_SUBST([NO_D_TYPE_IN_DIRENT])
Jakub Narebskif6719572006-07-08 23:07:14 +0200940#
David Michael110d6982012-12-14 14:56:59 -0500941# Define NO_GECOS_IN_PWENT if you don't have pw_gecos in struct passwd
942# in the C library.
943AC_CHECK_MEMBER(struct passwd.pw_gecos,
944[NO_GECOS_IN_PWENT=],
945[NO_GECOS_IN_PWENT=YesPlease],
946[#include <pwd.h>])
947GIT_CONF_SUBST([NO_GECOS_IN_PWENT])
948#
Jakub Narebski633b4232006-07-08 23:07:08 +0200949# Define NO_SOCKADDR_STORAGE if your platform does not have struct
950# sockaddr_storage.
Jakub Narebskid5c31a12006-08-04 23:43:59 +0200951AC_CHECK_TYPE(struct sockaddr_storage,
Jakub Narebski424adc52006-08-08 18:39:06 +0200952[NO_SOCKADDR_STORAGE=],
Dennis Stosbergab5573a2006-08-15 11:01:25 +0200953[NO_SOCKADDR_STORAGE=YesPlease],[
954#include <sys/types.h>
955#include <sys/socket.h>
956])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200957GIT_CONF_SUBST([NO_SOCKADDR_STORAGE])
Jakub Narebski424adc52006-08-08 18:39:06 +0200958#
Junio C Hamano8c6ab352006-08-04 16:46:16 -0700959# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
960AC_CHECK_TYPE([struct addrinfo],[
David M. Syzdek1689c5d2008-10-26 03:52:19 -0800961 GIT_CHECK_FUNC([getaddrinfo],
Jakub Narebski424adc52006-08-08 18:39:06 +0200962 [NO_IPV6=],
963 [NO_IPV6=YesPlease])
964],[NO_IPV6=YesPlease],[
Junio C Hamano8c6ab352006-08-04 16:46:16 -0700965#include <sys/types.h>
966#include <sys/socket.h>
967#include <netdb.h>
968])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200969GIT_CONF_SUBST([NO_IPV6])
Jakub Narebski656517b2006-08-04 17:55:57 +0200970#
Jakub Narębski842a5162016-10-07 13:30:52 +0200971# Define NO_REGEX if your C library lacks regex support with REG_STARTEND
972# feature.
973AC_CACHE_CHECK([whether the platform regex supports REG_STARTEND],
974 [ac_cv_c_regex_with_reg_startend], [
Jonathan Niedera1e3b662010-08-17 09:24:42 +0000975AC_EGREP_CPP(yippeeyeswehaveit,
976 AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT
977#include <regex.h>
978],
979[#ifdef REG_STARTEND
980yippeeyeswehaveit
981#endif
982]),
Jakub Narębski842a5162016-10-07 13:30:52 +0200983 [ac_cv_c_regex_with_reg_startend=yes],
984 [ac_cv_c_regex_with_reg_startend=no])
Jonathan Niedera1e3b662010-08-17 09:24:42 +0000985])
Jakub Narębski842a5162016-10-07 13:30:52 +0200986if test $ac_cv_c_regex_with_reg_startend = yes; then
Jonathan Niedera1e3b662010-08-17 09:24:42 +0000987 NO_REGEX=
988else
989 NO_REGEX=YesPlease
990fi
Stefano Lattarini40bfbde2012-09-11 17:45:30 +0200991GIT_CONF_SUBST([NO_REGEX])
Jonathan Niedera1e3b662010-08-17 09:24:42 +0000992#
Michal Rokos8ce1f242008-03-11 09:48:34 +0100993# Define FREAD_READS_DIRECTORIES if your are on a system which succeeds
994# when attempting to read from an fopen'ed directory.
995AC_CACHE_CHECK([whether system succeeds to read fopen'ed directory],
996 [ac_cv_fread_reads_directories],
997[
998AC_RUN_IFELSE(
999 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT],
Jeff King3adf9fd2017-06-14 01:30:18 -04001000 [[
Michal Rokos8ce1f242008-03-11 09:48:34 +01001001 FILE *f = fopen(".", "r");
Eric Sunshine249482d2018-04-09 04:50:42 -04001002 return f != NULL;]])],
Michal Rokos8ce1f242008-03-11 09:48:34 +01001003 [ac_cv_fread_reads_directories=no],
1004 [ac_cv_fread_reads_directories=yes])
1005])
1006if test $ac_cv_fread_reads_directories = yes; then
1007 FREAD_READS_DIRECTORIES=UnfortunatelyYes
1008else
1009 FREAD_READS_DIRECTORIES=
1010fi
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001011GIT_CONF_SUBST([FREAD_READS_DIRECTORIES])
Michal Rokos8ce1f242008-03-11 09:48:34 +01001012#
Michal Rokosc4582f92008-03-05 16:46:13 +01001013# Define SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf()
1014# or vsnprintf() return -1 instead of number of characters which would
1015# have been written to the final string if enough space had been available.
1016AC_CACHE_CHECK([whether snprintf() and/or vsnprintf() return bogus value],
1017 [ac_cv_snprintf_returns_bogus],
1018[
1019AC_RUN_IFELSE(
1020 [AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT
1021 #include "stdarg.h"
1022
1023 int test_vsnprintf(char *str, size_t maxsize, const char *format, ...)
1024 {
1025 int ret;
1026 va_list ap;
1027 va_start(ap, format);
1028 ret = vsnprintf(str, maxsize, format, ap);
1029 va_end(ap);
1030 return ret;
1031 }],
1032 [[char buf[6];
1033 if (test_vsnprintf(buf, 3, "%s", "12345") != 5
1034 || strcmp(buf, "12")) return 1;
1035 if (snprintf(buf, 3, "%s", "12345") != 5
1036 || strcmp(buf, "12")) return 1]])],
1037 [ac_cv_snprintf_returns_bogus=no],
1038 [ac_cv_snprintf_returns_bogus=yes])
1039])
1040if test $ac_cv_snprintf_returns_bogus = yes; then
1041 SNPRINTF_RETURNS_BOGUS=UnfortunatelyYes
1042else
1043 SNPRINTF_RETURNS_BOGUS=
1044fi
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001045GIT_CONF_SUBST([SNPRINTF_RETURNS_BOGUS])
David Michaeld543d9c2014-12-03 21:24:17 -05001046#
1047# Define NEEDS_MODE_TRANSLATION if your OS strays from the typical file type
1048# bits in mode values.
1049AC_CACHE_CHECK([whether the platform uses typical file type bits],
1050 [ac_cv_sane_mode_bits], [
1051AC_EGREP_CPP(yippeeyeswehaveit,
1052 AC_LANG_PROGRAM([AC_INCLUDES_DEFAULT],
1053[#if S_IFMT == 0170000 && \
1054 S_IFREG == 0100000 && S_IFDIR == 0040000 && S_IFLNK == 0120000 && \
1055 S_IFBLK == 0060000 && S_IFCHR == 0020000 && \
1056 S_IFIFO == 0010000 && S_IFSOCK == 0140000
1057yippeeyeswehaveit
1058#endif
1059]),
1060 [ac_cv_sane_mode_bits=yes],
1061 [ac_cv_sane_mode_bits=no])
1062])
1063if test $ac_cv_sane_mode_bits = yes; then
1064 NEEDS_MODE_TRANSLATION=
1065else
1066 NEEDS_MODE_TRANSLATION=UnfortunatelyYes
1067fi
1068GIT_CONF_SUBST([NEEDS_MODE_TRANSLATION])
Jakub Narebski633b4232006-07-08 23:07:08 +02001069
Jakub Narebskia20b4d82006-08-09 02:15:10 +02001070
Jakub Narebski633b4232006-07-08 23:07:08 +02001071## Checks for library functions.
Jakub Narebski1bbbadb2006-07-08 23:07:11 +02001072## (in default C library and libraries checked by AC_CHECK_LIB)
1073AC_MSG_NOTICE([CHECKS for library functions])
Jakub Narebskif6719572006-07-08 23:07:14 +02001074#
David Aguilare1c06882009-05-31 01:35:51 -07001075# Define NO_LIBGEN_H if you don't have libgen.h.
1076AC_CHECK_HEADER([libgen.h],
1077[NO_LIBGEN_H=],
1078[NO_LIBGEN_H=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001079GIT_CONF_SUBST([NO_LIBGEN_H])
David Aguilare1c06882009-05-31 01:35:51 -07001080#
Jakub Narebskibb15e382010-04-15 05:27:49 -07001081# Define HAVE_PATHS_H if you have paths.h.
1082AC_CHECK_HEADER([paths.h],
1083[HAVE_PATHS_H=YesPlease],
1084[HAVE_PATHS_H=])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001085GIT_CONF_SUBST([HAVE_PATHS_H])
Jakub Narebskibb15e382010-04-15 05:27:49 -07001086#
Ævar Arnfjörð Bjarmason5e9637c2011-11-18 00:14:42 +01001087# Define HAVE_LIBCHARSET_H if have libcharset.h
1088AC_CHECK_HEADER([libcharset.h],
1089[HAVE_LIBCHARSET_H=YesPlease],
1090[HAVE_LIBCHARSET_H=])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001091GIT_CONF_SUBST([HAVE_LIBCHARSET_H])
David Michaelb3e103d2012-12-14 14:57:01 -05001092#
1093# Define HAVE_STRINGS_H if you have strings.h
1094AC_CHECK_HEADER([strings.h],
1095[HAVE_STRINGS_H=YesPlease],
1096[HAVE_STRINGS_H=])
1097GIT_CONF_SUBST([HAVE_STRINGS_H])
Дилян Палаузовb5225282012-02-12 17:23:36 +01001098# Define CHARSET_LIB if libiconv does not export the locale_charset symbol
1099# and libcharset does
1100CHARSET_LIB=
1101AC_CHECK_LIB([iconv], [locale_charset],
Dmitry Marakasov62fb6d02014-03-11 22:35:29 +04001102 [CHARSET_LIB=-liconv],
Дилян Палаузовb5225282012-02-12 17:23:36 +01001103 [AC_CHECK_LIB([charset], [locale_charset],
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001104 [CHARSET_LIB=-lcharset])])
1105GIT_CONF_SUBST([CHARSET_LIB])
Ævar Arnfjörð Bjarmason5e9637c2011-11-18 00:14:42 +01001106#
Reuben Hawkinsa6c3c632015-01-08 12:00:56 -08001107# Define HAVE_CLOCK_GETTIME=YesPlease if clock_gettime is available.
1108GIT_CHECK_FUNC(clock_gettime,
1109 [HAVE_CLOCK_GETTIME=YesPlease],
1110 [HAVE_CLOCK_GETTIME=])
1111GIT_CONF_SUBST([HAVE_CLOCK_GETTIME])
1112
1113AC_DEFUN([CLOCK_MONOTONIC_SRC], [
1114AC_LANG_PROGRAM([[
1115#include <time.h>
1116clockid_t id = CLOCK_MONOTONIC;
1117]])])
1118
1119#
1120# Define HAVE_CLOCK_MONOTONIC=YesPlease if CLOCK_MONOTONIC is available.
1121AC_MSG_CHECKING([for CLOCK_MONOTONIC])
1122AC_COMPILE_IFELSE([CLOCK_MONOTONIC_SRC],
1123 [AC_MSG_RESULT([yes])
1124 HAVE_CLOCK_MONOTONIC=YesPlease],
1125 [AC_MSG_RESULT([no])
1126 HAVE_CLOCK_MONOTONIC=])
1127GIT_CONF_SUBST([HAVE_CLOCK_MONOTONIC])
1128#
Jonas 'Sortie' Termansena6fd4fb2014-08-29 09:42:35 -07001129# Define NO_SETITIMER if you don't have setitimer.
1130GIT_CHECK_FUNC(setitimer,
1131[NO_SETITIMER=],
1132[NO_SETITIMER=YesPlease])
1133GIT_CONF_SUBST([NO_SETITIMER])
1134#
Jakub Narebski633b4232006-07-08 23:07:08 +02001135# Define NO_STRCASESTR if you don't have strcasestr.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001136GIT_CHECK_FUNC(strcasestr,
Jakub Narebski424adc52006-08-08 18:39:06 +02001137[NO_STRCASESTR=],
1138[NO_STRCASESTR=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001139GIT_CONF_SUBST([NO_STRCASESTR])
Jakub Narebskif6719572006-07-08 23:07:14 +02001140#
Jakub Narebski24397552007-11-19 19:47:05 +01001141# Define NO_MEMMEM if you don't have memmem.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001142GIT_CHECK_FUNC(memmem,
Jakub Narebski24397552007-11-19 19:47:05 +01001143[NO_MEMMEM=],
1144[NO_MEMMEM=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001145GIT_CONF_SUBST([NO_MEMMEM])
Jakub Narebski24397552007-11-19 19:47:05 +01001146#
Jakub Narebski633b4232006-07-08 23:07:08 +02001147# Define NO_STRLCPY if you don't have strlcpy.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001148GIT_CHECK_FUNC(strlcpy,
Jakub Narebski424adc52006-08-08 18:39:06 +02001149[NO_STRLCPY=],
1150[NO_STRLCPY=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001151GIT_CONF_SUBST([NO_STRLCPY])
Jakub Narebskif6719572006-07-08 23:07:14 +02001152#
David M. Syzdek0bc3e782008-10-26 03:52:37 -08001153# Define NO_UINTMAX_T if your platform does not have uintmax_t
1154AC_CHECK_TYPE(uintmax_t,
1155[NO_UINTMAX_T=],
1156[NO_UINTMAX_T=YesPlease],[
1157#include <inttypes.h>
1158])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001159GIT_CONF_SUBST([NO_UINTMAX_T])
David M. Syzdek0bc3e782008-10-26 03:52:37 -08001160#
Jakub Narebski24397552007-11-19 19:47:05 +01001161# Define NO_STRTOUMAX if you don't have strtoumax in the C library.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001162GIT_CHECK_FUNC(strtoumax,
Jakub Narebski24397552007-11-19 19:47:05 +01001163[NO_STRTOUMAX=],
1164[NO_STRTOUMAX=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001165GIT_CONF_SUBST([NO_STRTOUMAX])
Jakub Narebski24397552007-11-19 19:47:05 +01001166#
Jakub Narebski633b4232006-07-08 23:07:08 +02001167# Define NO_SETENV if you don't have setenv in the C library.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001168GIT_CHECK_FUNC(setenv,
Jakub Narebski424adc52006-08-08 18:39:06 +02001169[NO_SETENV=],
1170[NO_SETENV=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001171GIT_CONF_SUBST([NO_SETENV])
Jakub Narebskif6719572006-07-08 23:07:14 +02001172#
Jakub Narebskibfa8fcc2008-01-18 02:03:51 +01001173# Define NO_UNSETENV if you don't have unsetenv in the C library.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001174GIT_CHECK_FUNC(unsetenv,
Jakub Narebskibfa8fcc2008-01-18 02:03:51 +01001175[NO_UNSETENV=],
1176[NO_UNSETENV=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001177GIT_CONF_SUBST([NO_UNSETENV])
Jakub Narebskibfa8fcc2008-01-18 02:03:51 +01001178#
Jakub Narebski24397552007-11-19 19:47:05 +01001179# Define NO_MKDTEMP if you don't have mkdtemp in the C library.
David M. Syzdek1689c5d2008-10-26 03:52:19 -08001180GIT_CHECK_FUNC(mkdtemp,
Jakub Narebski24397552007-11-19 19:47:05 +01001181[NO_MKDTEMP=],
1182[NO_MKDTEMP=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001183GIT_CONF_SUBST([NO_MKDTEMP])
Jakub Narebski24397552007-11-19 19:47:05 +01001184#
Markus Duft25fe66f2010-10-27 10:39:53 +02001185# Define NO_INITGROUPS if you don't have initgroups in the C library.
1186GIT_CHECK_FUNC(initgroups,
1187[NO_INITGROUPS=],
1188[NO_INITGROUPS=YesPlease])
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001189GIT_CONF_SUBST([NO_INITGROUPS])
Markus Duft25fe66f2010-10-27 10:39:53 +02001190#
Eric Sunshine96658062015-06-02 17:15:44 -04001191# Define HAVE_GETDELIM if you have getdelim in the C library.
1192GIT_CHECK_FUNC(getdelim,
1193[HAVE_GETDELIM=YesPlease],
1194[HAVE_GETDELIM=])
1195GIT_CONF_SUBST([HAVE_GETDELIM])
1196#
David Aguilar0620b392009-05-31 01:35:50 -07001197#
Jakub Narebski633b4232006-07-08 23:07:08 +02001198# Define NO_MMAP if you want to avoid mmap.
1199#
Jakub Narebski633b4232006-07-08 23:07:08 +02001200# Define NO_ICONV if your libc does not properly support iconv.
1201
Kyle J. McKay95290802015-03-07 23:14:36 -08001202AC_DEFUN([BSD_SYSCTL_SRC], [
1203AC_LANG_PROGRAM([[
1204#include <stddef.h>
1205#include <sys/types.h>
1206#include <sys/sysctl.h>
1207]],[[
1208int val, mib[2];
1209size_t len;
1210mib[0] = CTL_HW;
1211mib[1] = 1;
1212len = sizeof(val);
1213return sysctl(mib, 2, &val, &len, NULL, 0) ? 1 : 0;
1214]])])
1215
1216#
1217# Define HAVE_BSD_SYSCTL=YesPlease if a BSD-compatible sysctl function is available.
1218AC_MSG_CHECKING([for BSD sysctl])
1219AC_COMPILE_IFELSE([BSD_SYSCTL_SRC],
1220 [AC_MSG_RESULT([yes])
1221 HAVE_BSD_SYSCTL=YesPlease],
1222 [AC_MSG_RESULT([no])
1223 HAVE_BSD_SYSCTL=])
1224GIT_CONF_SUBST([HAVE_BSD_SYSCTL])
Jakub Narebski633b4232006-07-08 23:07:08 +02001225
1226## Other checks.
1227# Define USE_PIC if you need the main git objects to be built with -fPIC
1228# in order to build and link perl/Git.so. x86-64 seems to need this.
1229#
1230# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
1231# Enable it on Windows. By default, symrefs are still used.
David M. Syzdek20f7a392008-11-03 09:14:28 -09001232#
Dan McGee7eb151d2010-01-29 19:22:19 -06001233# Define NO_PTHREADS if we do not have pthreads.
Junio C Hamano46059cc2008-11-15 04:08:14 -08001234#
Dan McGee7eb151d2010-01-29 19:22:19 -06001235# Define PTHREAD_LIBS to the linker flag used for Pthread support.
Ben Walton1973b0d2009-03-12 15:20:12 -04001236AC_DEFUN([PTHREADTEST_SRC], [
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +01001237AC_LANG_PROGRAM([[
Ben Walton1973b0d2009-03-12 15:20:12 -04001238#include <pthread.h>
Eric Wonga9b02de2016-07-18 10:22:08 +00001239static void *noop(void *ignore) { return ignore; }
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +01001240]], [[
Ben Walton1973b0d2009-03-12 15:20:12 -04001241 pthread_mutex_t test_mutex;
Giuseppe Bilottacea13a82011-03-28 09:39:59 +02001242 pthread_key_t test_key;
Eric Wonga9b02de2016-07-18 10:22:08 +00001243 pthread_t th;
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001244 int retcode = 0;
Eric Wonga9b02de2016-07-18 10:22:08 +00001245 void *ret = (void *)0;
Giuseppe Bilottacea13a82011-03-28 09:39:59 +02001246 retcode |= pthread_key_create(&test_key, (void *)0);
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001247 retcode |= pthread_mutex_init(&test_mutex,(void *)0);
1248 retcode |= pthread_mutex_lock(&test_mutex);
1249 retcode |= pthread_mutex_unlock(&test_mutex);
Eric Wonga9b02de2016-07-18 10:22:08 +00001250 retcode |= pthread_create(&th, ret, noop, ret);
1251 retcode |= pthread_join(th, &ret);
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001252 return retcode;
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +01001253]])])
Ben Walton1973b0d2009-03-12 15:20:12 -04001254
1255dnl AC_LANG_CONFTEST([AC_LANG_PROGRAM(
1256dnl [[#include <pthread.h>]],
1257dnl [[pthread_mutex_t test_mutex;]]
1258dnl )])
1259
1260NO_PTHREADS=UnfortunatelyYes
Ben Walton1973b0d2009-03-12 15:20:12 -04001261PTHREAD_LIBS=
1262
1263if test -n "$USER_NOPTHREAD"; then
1264 AC_MSG_NOTICE([Skipping POSIX Threads at user request.])
1265# handle these separately since PTHREAD_CFLAGS could be '-lpthreads
1266# -D_REENTRANT' or some such.
1267elif test -z "$PTHREAD_CFLAGS"; then
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001268 threads_found=no
Max Horne0a52272012-11-28 00:28:51 +01001269 # Attempt to compile and link some code using pthreads to determine
1270 # required linker flags. The order is somewhat important here: We
1271 # first try it without any extra flags, to catch systems where
1272 # pthreads are part of the C library, then go on testing various other
1273 # flags. We do so to avoid false positives. For example, on Mac OS X
1274 # pthreads are part of the C library; moreover, the compiler allows us
1275 # to add "-mt" to the CFLAGS (although it will do nothing except
1276 # trigger a warning about an unused flag). Hence if we checked for
1277 # "-mt" before "" we would end up picking it. But unfortunately this
1278 # would then trigger compiler warnings on every single file we compile.
1279 for opt in "" -mt -pthread -lpthread; do
Ben Walton1973b0d2009-03-12 15:20:12 -04001280 old_CFLAGS="$CFLAGS"
Rainer M. Canavanbac2c5b2015-11-06 02:11:37 +01001281 old_LIBS="$LIBS"
1282 case "$opt" in
1283 -l*) LIBS="$opt $LIBS" ;;
1284 *) CFLAGS="$opt $CFLAGS" ;;
1285 esac
1286
Stefano Lattarini49aeead2012-10-24 17:34:27 +02001287 AC_MSG_CHECKING([for POSIX Threads with '$opt'])
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +01001288 AC_LINK_IFELSE([PTHREADTEST_SRC],
Ben Walton1973b0d2009-03-12 15:20:12 -04001289 [AC_MSG_RESULT([yes])
1290 NO_PTHREADS=
1291 PTHREAD_LIBS="$opt"
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001292 PTHREAD_CFLAGS="$opt"
1293 threads_found=yes
Ben Walton1973b0d2009-03-12 15:20:12 -04001294 break
1295 ],
1296 [AC_MSG_RESULT([no])])
1297 CFLAGS="$old_CFLAGS"
Rainer M. Canavanbac2c5b2015-11-06 02:11:37 +01001298 LIBS="$old_LIBS"
Ben Walton1973b0d2009-03-12 15:20:12 -04001299 done
Gary V. Vaughan48793cf2010-05-14 09:31:34 +00001300 if test $threads_found != yes; then
1301 AC_CHECK_LIB([pthread], [pthread_create],
1302 [PTHREAD_LIBS="-lpthread"],
1303 [NO_PTHREADS=UnfortunatelyYes])
1304 fi
David M. Syzdek20f7a392008-11-03 09:14:28 -09001305else
Ben Walton1973b0d2009-03-12 15:20:12 -04001306 old_CFLAGS="$CFLAGS"
1307 CFLAGS="$PTHREAD_CFLAGS $CFLAGS"
Stefano Lattarini49aeead2012-10-24 17:34:27 +02001308 AC_MSG_CHECKING([for POSIX Threads with '$PTHREAD_CFLAGS'])
Ralf Wildenhues1e58dba2011-01-02 11:24:55 +01001309 AC_LINK_IFELSE([PTHREADTEST_SRC],
Ben Walton1973b0d2009-03-12 15:20:12 -04001310 [AC_MSG_RESULT([yes])
1311 NO_PTHREADS=
1312 PTHREAD_LIBS="$PTHREAD_CFLAGS"
Ben Walton1973b0d2009-03-12 15:20:12 -04001313 ],
1314 [AC_MSG_RESULT([no])])
1315
1316 CFLAGS="$old_CFLAGS"
David M. Syzdek20f7a392008-11-03 09:14:28 -09001317fi
Ben Walton1973b0d2009-03-12 15:20:12 -04001318
1319CFLAGS="$old_CFLAGS"
1320
Stefano Lattarini40bfbde2012-09-11 17:45:30 +02001321GIT_CONF_SUBST([PTHREAD_CFLAGS])
1322GIT_CONF_SUBST([PTHREAD_LIBS])
1323GIT_CONF_SUBST([NO_PTHREADS])
Jakub Narebski633b4232006-07-08 23:07:08 +02001324
Jakub Narebski633b4232006-07-08 23:07:08 +02001325## Output files
Stefano Lattariniac5fc1c2012-07-19 09:50:00 +02001326AC_CONFIG_FILES(["${config_file}":"${config_in}"])
Jakub Narebski55667712006-07-03 01:56:48 +02001327AC_OUTPUT