]> git.ipfire.org Git - thirdparty/git.git/blame_incremental - Makefile
Makefile: move the setting of *FLAGS closer to "include"
[thirdparty/git.git] / Makefile
... / ...
CommitLineData
1# The default target of this Makefile is...
2all::
3
4# Define V=1 to have a more verbose compile.
5#
6# Define SHELL_PATH to a POSIX shell if your /bin/sh is broken.
7#
8# Define SANE_TOOL_PATH to a colon-separated list of paths to prepend
9# to PATH if your tools in /usr/bin are broken.
10#
11# Define SOCKLEN_T to a suitable type (such as 'size_t') if your
12# system headers do not define a socklen_t type.
13#
14# Define INLINE to a suitable substitute (such as '__inline' or '') if git
15# fails to compile with errors about undefined inline functions or similar.
16#
17# Define SNPRINTF_RETURNS_BOGUS if you are on a system which snprintf()
18# or vsnprintf() return -1 instead of number of characters which would
19# have been written to the final string if enough space had been available.
20#
21# Define FREAD_READS_DIRECTORIES if you are on a system which succeeds
22# when attempting to read from an fopen'ed directory (or even to fopen
23# it at all).
24#
25# Define NO_OPENSSL environment variable if you do not have OpenSSL.
26#
27# Define USE_LIBPCRE if you have and want to use libpcre. Various
28# commands such as log and grep offer runtime options to use
29# Perl-compatible regular expressions instead of standard or extended
30# POSIX regular expressions.
31#
32# USE_LIBPCRE is a synonym for USE_LIBPCRE2, define USE_LIBPCRE1
33# instead if you'd like to use the legacy version 1 of the PCRE
34# library. Support for version 1 will likely be removed in some future
35# release of Git, as upstream has all but abandoned it.
36#
37# When using USE_LIBPCRE1, define NO_LIBPCRE1_JIT if the PCRE v1
38# library is compiled without --enable-jit. We will auto-detect
39# whether the version of the PCRE v1 library in use has JIT support at
40# all, but we unfortunately can't auto-detect whether JIT support
41# hasn't been compiled in in an otherwise JIT-supporting version. If
42# you have link-time errors about a missing `pcre_jit_exec` define
43# this, or recompile PCRE v1 with --enable-jit.
44#
45# Define LIBPCREDIR=/foo/bar if your PCRE header and library files are
46# in /foo/bar/include and /foo/bar/lib directories. Which version of
47# PCRE this points to determined by the USE_LIBPCRE1 and USE_LIBPCRE2
48# variables.
49#
50# Define HAVE_ALLOCA_H if you have working alloca(3) defined in that header.
51#
52# Define NO_CURL if you do not have libcurl installed. git-http-fetch and
53# git-http-push are not built, and you cannot use http:// and https://
54# transports (neither smart nor dumb).
55#
56# Define CURLDIR=/foo/bar if your curl header and library files are in
57# /foo/bar/include and /foo/bar/lib directories.
58#
59# Define CURL_CONFIG to curl's configuration program that prints information
60# about the library (e.g., its version number). The default is 'curl-config'.
61#
62# Define CURL_LDFLAGS to specify flags that you need to link when using libcurl,
63# if you do not want to rely on the libraries provided by CURL_CONFIG. The
64# default value is a result of `curl-config --libs`. An example value for
65# CURL_LDFLAGS is as follows:
66#
67# CURL_LDFLAGS=-lcurl
68#
69# Define NO_EXPAT if you do not have expat installed. git-http-push is
70# not built, and you cannot push using http:// and https:// transports (dumb).
71#
72# Define EXPATDIR=/foo/bar if your expat header and library files are in
73# /foo/bar/include and /foo/bar/lib directories.
74#
75# Define EXPAT_NEEDS_XMLPARSE_H if you have an old version of expat (e.g.,
76# 1.1 or 1.2) that provides xmlparse.h instead of expat.h.
77#
78# Define NO_GETTEXT if you don't want Git output to be translated.
79# A translated Git requires GNU libintl or another gettext implementation,
80# plus libintl-perl at runtime.
81#
82# Define USE_GETTEXT_SCHEME and set it to 'fallthrough', if you don't trust
83# the installed gettext translation of the shell scripts output.
84#
85# Define HAVE_LIBCHARSET_H if you haven't set NO_GETTEXT and you can't
86# trust the langinfo.h's nl_langinfo(CODESET) function to return the
87# current character set. GNU and Solaris have a nl_langinfo(CODESET),
88# FreeBSD can use either, but MinGW and some others need to use
89# libcharset.h's locale_charset() instead.
90#
91# Define CHARSET_LIB to the library you need to link with in order to
92# use locale_charset() function. On some platforms this needs to set to
93# -lcharset, on others to -liconv .
94#
95# Define LIBC_CONTAINS_LIBINTL if your gettext implementation doesn't
96# need -lintl when linking.
97#
98# Define NO_MSGFMT_EXTENDED_OPTIONS if your implementation of msgfmt
99# doesn't support GNU extensions like --check and --statistics
100#
101# Define HAVE_PATHS_H if you have paths.h and want to use the default PATH
102# it specifies.
103#
104# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
105# d_type in struct dirent (Cygwin 1.5, fixed in Cygwin 1.7).
106#
107# Define HAVE_STRINGS_H if you have strings.h and need it for strcasecmp.
108#
109# Define NO_STRCASESTR if you don't have strcasestr.
110#
111# Define NO_MEMMEM if you don't have memmem.
112#
113# Define NO_GETPAGESIZE if you don't have getpagesize.
114#
115# Define NO_STRLCPY if you don't have strlcpy.
116#
117# Define NO_STRTOUMAX if you don't have both strtoimax and strtoumax in the
118# C library. If your compiler also does not support long long or does not have
119# strtoull, define NO_STRTOULL.
120#
121# Define NO_SETENV if you don't have setenv in the C library.
122#
123# Define NO_UNSETENV if you don't have unsetenv in the C library.
124#
125# Define NO_MKDTEMP if you don't have mkdtemp in the C library.
126#
127# Define MKDIR_WO_TRAILING_SLASH if your mkdir() can't deal with trailing slash.
128#
129# Define NO_GECOS_IN_PWENT if you don't have pw_gecos in struct passwd
130# in the C library.
131#
132# Define NO_LIBGEN_H if you don't have libgen.h.
133#
134# Define NEEDS_LIBGEN if your libgen needs -lgen when linking
135#
136# Define NO_SYS_SELECT_H if you don't have sys/select.h.
137#
138# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
139# Enable it on Windows. By default, symrefs are still used.
140#
141# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
142# tests. These tests take up a significant amount of the total test time
143# but are not needed unless you plan to talk to SVN repos.
144#
145# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
146# installed in /sw, but don't want GIT to link against any libraries
147# installed there. If defined you may specify your own (or Fink's)
148# include directories and library directories by defining CFLAGS
149# and LDFLAGS appropriately.
150#
151# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
152# have DarwinPorts installed in /opt/local, but don't want GIT to
153# link against any libraries installed there. If defined you may
154# specify your own (or DarwinPort's) include directories and
155# library directories by defining CFLAGS and LDFLAGS appropriately.
156#
157# Define NO_APPLE_COMMON_CRYPTO if you are building on Darwin/Mac OS X
158# and do not want to use Apple's CommonCrypto library. This allows you
159# to provide your own OpenSSL library, for example from MacPorts.
160#
161# Define BLK_SHA1 environment variable to make use of the bundled
162# optimized C SHA1 routine.
163#
164# Define PPC_SHA1 environment variable when running make to make use of
165# a bundled SHA1 routine optimized for PowerPC.
166#
167# Define DC_SHA1 to unconditionally enable the collision-detecting sha1
168# algorithm. This is slower, but may detect attempted collision attacks.
169# Takes priority over other *_SHA1 knobs.
170#
171# Define DC_SHA1_EXTERNAL in addition to DC_SHA1 if you want to build / link
172# git with the external SHA1 collision-detect library.
173# Without this option, i.e. the default behavior is to build git with its
174# own built-in code (or submodule).
175#
176# Define DC_SHA1_SUBMODULE in addition to DC_SHA1 to use the
177# sha1collisiondetection shipped as a submodule instead of the
178# non-submodule copy in sha1dc/. This is an experimental option used
179# by the git project to migrate to using sha1collisiondetection as a
180# submodule.
181#
182# Define OPENSSL_SHA1 environment variable when running make to link
183# with the SHA1 routine from openssl library.
184#
185# Define SHA1_MAX_BLOCK_SIZE to limit the amount of data that will be hashed
186# in one call to the platform's SHA1_Update(). e.g. APPLE_COMMON_CRYPTO
187# wants 'SHA1_MAX_BLOCK_SIZE=1024L*1024L*1024L' defined.
188#
189# Define BLK_SHA256 to use the built-in SHA-256 routines.
190#
191# Define GCRYPT_SHA256 to use the SHA-256 routines in libgcrypt.
192#
193# Define OPENSSL_SHA256 to use the SHA-256 routines in OpenSSL.
194#
195# Define NEEDS_CRYPTO_WITH_SSL if you need -lcrypto when using -lssl (Darwin).
196#
197# Define NEEDS_SSL_WITH_CRYPTO if you need -lssl when using -lcrypto (Darwin).
198#
199# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin).
200#
201# Define NEEDS_LIBINTL_BEFORE_LIBICONV if you need libintl before libiconv.
202#
203# Define NO_INTPTR_T if you don't have intptr_t or uintptr_t.
204#
205# Define NO_UINTMAX_T if you don't have uintmax_t.
206#
207# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
208# Patrick Mauritz).
209#
210# Define NEEDS_RESOLV if linking with -lnsl and/or -lsocket is not enough.
211# Notably on Solaris hstrerror resides in libresolv and on Solaris 7
212# inet_ntop and inet_pton additionally reside there.
213#
214# Define NO_MMAP if you want to avoid mmap.
215#
216# Define MMAP_PREVENTS_DELETE if a file that is currently mmapped cannot be
217# deleted or cannot be replaced using rename().
218#
219# Define NO_POLL_H if you don't have poll.h.
220#
221# Define NO_SYS_POLL_H if you don't have sys/poll.h.
222#
223# Define NO_POLL if you do not have or don't want to use poll().
224# This also implies NO_POLL_H and NO_SYS_POLL_H.
225#
226# Define NEEDS_SYS_PARAM_H if you need to include sys/param.h to compile,
227# *PLEASE* REPORT to git@vger.kernel.org if your platform needs this;
228# we want to know more about the issue.
229#
230# Define NO_PTHREADS if you do not have or do not want to use Pthreads.
231#
232# Define NO_PREAD if you have a problem with pread() system call (e.g.
233# cygwin1.dll before v1.5.22).
234#
235# Define NO_SETITIMER if you don't have setitimer()
236#
237# Define NO_STRUCT_ITIMERVAL if you don't have struct itimerval
238# This also implies NO_SETITIMER
239#
240# Define NO_FAST_WORKING_DIRECTORY if accessing objects in pack files is
241# generally faster on your platform than accessing the working directory.
242#
243# Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support
244# the executable mode bit, but doesn't really do so.
245#
246# Define NEEDS_MODE_TRANSLATION if your OS strays from the typical file type
247# bits in mode values (e.g. z/OS defines I_SFMT to 0xFF000000 as opposed to the
248# usual 0xF000).
249#
250# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
251#
252# Define NO_UNIX_SOCKETS if your system does not offer unix sockets.
253#
254# Define NO_SOCKADDR_STORAGE if your platform does not have struct
255# sockaddr_storage.
256#
257# Define NO_ICONV if your libc does not properly support iconv.
258#
259# Define OLD_ICONV if your library has an old iconv(), where the second
260# (input buffer pointer) parameter is declared with type (const char **).
261#
262# Define ICONV_OMITS_BOM if your iconv implementation does not write a
263# byte-order mark (BOM) when writing UTF-16 or UTF-32 and always writes in
264# big-endian format.
265#
266# Define NO_DEFLATE_BOUND if your zlib does not have deflateBound.
267#
268# Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib"
269# that tells runtime paths to dynamic libraries;
270# "-Wl,-rpath=/path/lib" is used instead.
271#
272# Define NO_NORETURN if using buggy versions of gcc 4.6+ and profile feedback,
273# as the compiler can crash (http://gcc.gnu.org/bugzilla/show_bug.cgi?id=49299)
274#
275# Define USE_NSEC below if you want git to care about sub-second file mtimes
276# and ctimes. Note that you need recent glibc (at least 2.2.4) for this. On
277# Linux, kernel 2.6.11 or newer is required for reliable sub-second file times
278# on file systems with exactly 1 ns or 1 s resolution. If you intend to use Git
279# on other file systems (e.g. CEPH, CIFS, NTFS, UDF), don't enable USE_NSEC. See
280# Documentation/technical/racy-git.txt for details.
281#
282# Define USE_ST_TIMESPEC if your "struct stat" uses "st_ctimespec" instead of
283# "st_ctim"
284#
285# Define NO_NSEC if your "struct stat" does not have "st_ctim.tv_nsec"
286# available. This automatically turns USE_NSEC off.
287#
288# Define USE_STDEV below if you want git to care about the underlying device
289# change being considered an inode change from the update-index perspective.
290#
291# Define NO_ST_BLOCKS_IN_STRUCT_STAT if your platform does not have st_blocks
292# field that counts the on-disk footprint in 512-byte blocks.
293#
294# Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72
295# (not v1.73 or v1.71).
296#
297# Define ASCIIDOC_ROFF if your DocBook XSL does not escape raw roff directives
298# (versions 1.68.1 through v1.72).
299#
300# Define GNU_ROFF if your target system uses GNU groff. This forces
301# apostrophes to be ASCII so that cut&pasting examples to the shell
302# will work.
303#
304# Define USE_ASCIIDOCTOR to use Asciidoctor instead of AsciiDoc to build the
305# documentation.
306#
307# Define ASCIIDOCTOR_EXTENSIONS_LAB to point to the location of the Asciidoctor
308# Extensions Lab if you have it available.
309#
310# Define PERL_PATH to the path of your Perl binary (usually /usr/bin/perl).
311#
312# Define NO_PERL if you do not want Perl scripts or libraries at all.
313#
314# Define NO_PERL_CPAN_FALLBACKS if you do not want to install bundled
315# copies of CPAN modules that serve as a fallback in case the modules
316# are not available on the system. This option is intended for
317# distributions that want to use their packaged versions of Perl
318# modules, instead of the fallbacks shipped with Git.
319#
320# Define PYTHON_PATH to the path of your Python binary (often /usr/bin/python
321# but /usr/bin/python2.7 on some platforms).
322#
323# Define NO_PYTHON if you do not want Python scripts or libraries at all.
324#
325# Define NO_TCLTK if you do not want Tcl/Tk GUI.
326#
327# Define SANE_TEXT_GREP to "-a" if you use recent versions of GNU grep
328# and egrep that are pickier when their input contains non-ASCII data.
329#
330# The TCL_PATH variable governs the location of the Tcl interpreter
331# used to optimize git-gui for your system. Only used if NO_TCLTK
332# is not set. Defaults to the bare 'tclsh'.
333#
334# The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter.
335# If not set it defaults to the bare 'wish'. If it is set to the empty
336# string then NO_TCLTK will be forced (this is used by configure script).
337#
338# Define INTERNAL_QSORT to use Git's implementation of qsort(), which
339# is a simplified version of the merge sort used in glibc. This is
340# recommended if Git triggers O(n^2) behavior in your platform's qsort().
341#
342# Define HAVE_ISO_QSORT_S if your platform provides a qsort_s() that's
343# compatible with the one described in C11 Annex K.
344#
345# Define UNRELIABLE_FSTAT if your system's fstat does not return the same
346# information on a not yet closed file that lstat would return for the same
347# file after it was closed.
348#
349# Define OBJECT_CREATION_USES_RENAMES if your operating systems has problems
350# when hardlinking a file to another name and unlinking the original file right
351# away (some NTFS drivers seem to zero the contents in that scenario).
352#
353# Define INSTALL_SYMLINKS if you prefer to have everything that can be
354# symlinked between bin/ and libexec/ to use relative symlinks between
355# the two. This option overrides NO_CROSS_DIRECTORY_HARDLINKS and
356# NO_INSTALL_HARDLINKS which will also use symlinking by indirection
357# within the same directory in some cases, INSTALL_SYMLINKS will
358# always symlink to the final target directly.
359#
360# Define NO_CROSS_DIRECTORY_HARDLINKS if you plan to distribute the installed
361# programs as a tar, where bin/ and libexec/ might be on different file systems.
362#
363# Define NO_INSTALL_HARDLINKS if you prefer to use either symbolic links or
364# copies to install built-in git commands e.g. git-cat-file.
365#
366# Define USE_NED_ALLOCATOR if you want to replace the platforms default
367# memory allocators with the nedmalloc allocator written by Niall Douglas.
368#
369# Define OVERRIDE_STRDUP to override the libc version of strdup(3).
370# This is necessary when using a custom allocator in order to avoid
371# crashes due to allocation and free working on different 'heaps'.
372# It's defined automatically if USE_NED_ALLOCATOR is set.
373#
374# Define NO_REGEX if your C library lacks regex support with REG_STARTEND
375# feature.
376#
377# Define HAVE_DEV_TTY if your system can open /dev/tty to interact with the
378# user.
379#
380# Define JSMIN to point to JavaScript minifier that functions as
381# a filter to have gitweb.js minified.
382#
383# Define CSSMIN to point to a CSS minifier in order to generate a minified
384# version of gitweb.css
385#
386# Define DEFAULT_PAGER to a sensible pager command (defaults to "less") if
387# you want to use something different. The value will be interpreted by the
388# shell at runtime when it is used.
389#
390# Define DEFAULT_EDITOR to a sensible editor command (defaults to "vi") if you
391# want to use something different. The value will be interpreted by the shell
392# if necessary when it is used. Examples:
393#
394# DEFAULT_EDITOR='~/bin/vi',
395# DEFAULT_EDITOR='$GIT_FALLBACK_EDITOR',
396# DEFAULT_EDITOR='"C:\Program Files\Vim\gvim.exe" --nofork'
397#
398# Define COMPUTE_HEADER_DEPENDENCIES to "yes" if you want dependencies on
399# header files to be automatically computed, to avoid rebuilding objects when
400# an unrelated header file changes. Define it to "no" to use the hard-coded
401# dependency rules. The default is "auto", which means to use computed header
402# dependencies if your compiler is detected to support it.
403#
404# Define NATIVE_CRLF if your platform uses CRLF for line endings.
405#
406# Define GIT_USER_AGENT if you want to change how git identifies itself during
407# network interactions. The default is "git/$(GIT_VERSION)".
408#
409# Define DEFAULT_HELP_FORMAT to "man", "info" or "html"
410# (defaults to "man") if you want to have a different default when
411# "git help" is called without a parameter specifying the format.
412#
413# Define GIT_TEST_INDEX_VERSION to 2, 3 or 4 to run the test suite
414# with a different indexfile format version. If it isn't set the index
415# file format used is index-v[23].
416#
417# Define GMTIME_UNRELIABLE_ERRORS if your gmtime() function does not
418# return NULL when it receives a bogus time_t.
419#
420# Define HAVE_CLOCK_GETTIME if your platform has clock_gettime.
421#
422# Define HAVE_CLOCK_MONOTONIC if your platform has CLOCK_MONOTONIC.
423#
424# Define NEEDS_LIBRT if your platform requires linking with librt (glibc version
425# before 2.17) for clock_gettime and CLOCK_MONOTONIC.
426#
427# Define USE_PARENS_AROUND_GETTEXT_N to "yes" if your compiler happily
428# compiles the following initialization:
429#
430# static const char s[] = ("FOO");
431#
432# and define it to "no" if you need to remove the parentheses () around the
433# constant. The default is "auto", which means to use parentheses if your
434# compiler is detected to support it.
435#
436# Define HAVE_BSD_SYSCTL if your platform has a BSD-compatible sysctl function.
437#
438# Define HAVE_GETDELIM if your system has the getdelim() function.
439#
440# Define FILENO_IS_A_MACRO if fileno() is a macro, not a real function.
441#
442# Define PAGER_ENV to a SP separated VAR=VAL pairs to define
443# default environment variables to be passed when a pager is spawned, e.g.
444#
445# PAGER_ENV = LESS=FRX LV=-c
446#
447# to say "export LESS=FRX (and LV=-c) if the environment variable
448# LESS (and LV) is not set, respectively".
449#
450# Define TEST_SHELL_PATH if you want to use a shell besides SHELL_PATH for
451# running the test scripts (e.g., bash has better support for "set -x"
452# tracing).
453#
454# When cross-compiling, define HOST_CPU as the canonical name of the CPU on
455# which the built Git will run (for instance "x86_64").
456#
457# Define RUNTIME_PREFIX to configure Git to resolve its ancillary tooling and
458# support files relative to the location of the runtime binary, rather than
459# hard-coding them into the binary. Git installations built with RUNTIME_PREFIX
460# can be moved to arbitrary filesystem locations. RUNTIME_PREFIX also causes
461# Perl scripts to use a modified entry point header allowing them to resolve
462# support files at runtime.
463#
464# When using RUNTIME_PREFIX, define HAVE_BSD_KERN_PROC_SYSCTL if your platform
465# supports the KERN_PROC BSD sysctl function.
466#
467# When using RUNTIME_PREFIX, define PROCFS_EXECUTABLE_PATH if your platform
468# mounts a "procfs" filesystem capable of resolving the path of the current
469# executable. If defined, this must be the canonical path for the "procfs"
470# current executable path.
471#
472# When using RUNTIME_PREFIX, define HAVE_NS_GET_EXECUTABLE_PATH if your platform
473# supports calling _NSGetExecutablePath to retrieve the path of the running
474# executable.
475#
476# When using RUNTIME_PREFIX, define HAVE_WPGMPTR if your platform offers
477# the global variable _wpgmptr containing the absolute path of the current
478# executable (this is the case on Windows).
479#
480# Define DEVELOPER to enable more compiler warnings. Compiler version
481# and family are auto detected, but could be overridden by defining
482# COMPILER_FEATURES (see config.mak.dev)
483#
484# When DEVELOPER is set, DEVOPTS can be used to control compiler
485# options. This variable contains keywords separated by
486# whitespace. The following keywords are are recognized:
487#
488# no-error:
489#
490# suppresses the -Werror that implicitly comes with
491# DEVELOPER=1. Useful for getting the full set of errors
492# without immediately dying, or for logging them.
493#
494# extra-all:
495#
496# The DEVELOPER mode enables -Wextra with a few exceptions. By
497# setting this flag the exceptions are removed, and all of
498# -Wextra is used.
499#
500# pedantic:
501#
502# Enable -pedantic compilation. This also disables
503# USE_PARENS_AROUND_GETTEXT_N to produce only relevant warnings.
504
505GIT-VERSION-FILE: FORCE
506 @$(SHELL_PATH) ./GIT-VERSION-GEN
507-include GIT-VERSION-FILE
508
509# Set our default configuration.
510#
511# Among the variables below, these:
512# gitexecdir
513# template_dir
514# sysconfdir
515# can be specified as a relative path some/where/else;
516# this is interpreted as relative to $(prefix) and "git" at
517# runtime figures out where they are based on the path to the executable.
518# Additionally, the following will be treated as relative by "git" if they
519# begin with "$(prefix)/":
520# mandir
521# infodir
522# htmldir
523# localedir
524# perllibdir
525# This can help installing the suite in a relocatable way.
526
527prefix = $(HOME)
528bindir = $(prefix)/bin
529mandir = $(prefix)/share/man
530infodir = $(prefix)/share/info
531gitexecdir = libexec/git-core
532mergetoolsdir = $(gitexecdir)/mergetools
533sharedir = $(prefix)/share
534gitwebdir = $(sharedir)/gitweb
535perllibdir = $(sharedir)/perl5
536localedir = $(sharedir)/locale
537template_dir = share/git-core/templates
538htmldir = $(prefix)/share/doc/git-doc
539ETC_GITCONFIG = $(sysconfdir)/gitconfig
540ETC_GITATTRIBUTES = $(sysconfdir)/gitattributes
541lib = lib
542# DESTDIR =
543pathsep = :
544
545bindir_relative = $(patsubst $(prefix)/%,%,$(bindir))
546mandir_relative = $(patsubst $(prefix)/%,%,$(mandir))
547infodir_relative = $(patsubst $(prefix)/%,%,$(infodir))
548gitexecdir_relative = $(patsubst $(prefix)/%,%,$(gitexecdir))
549localedir_relative = $(patsubst $(prefix)/%,%,$(localedir))
550htmldir_relative = $(patsubst $(prefix)/%,%,$(htmldir))
551perllibdir_relative = $(patsubst $(prefix)/%,%,$(perllibdir))
552
553export prefix bindir sharedir sysconfdir gitwebdir perllibdir localedir
554
555# Set our default programs
556CC = cc
557AR = ar
558RM = rm -f
559DIFF = diff
560TAR = tar
561FIND = find
562INSTALL = install
563TCL_PATH = tclsh
564TCLTK_PATH = wish
565XGETTEXT = xgettext
566MSGFMT = msgfmt
567CURL_CONFIG = curl-config
568GCOV = gcov
569STRIP = strip
570SPATCH = spatch
571
572export TCL_PATH TCLTK_PATH
573
574# Set our default LIBS variables
575PTHREAD_LIBS = -lpthread
576
577# Guard against environment variables
578BUILTIN_OBJS =
579BUILT_INS =
580COMPAT_CFLAGS =
581COMPAT_OBJS =
582XDIFF_OBJS =
583VCSSVN_OBJS =
584GENERATED_H =
585EXTRA_CPPFLAGS =
586FUZZ_OBJS =
587FUZZ_PROGRAMS =
588LIB_OBJS =
589PROGRAM_OBJS =
590PROGRAMS =
591SCRIPT_PERL =
592SCRIPT_PYTHON =
593SCRIPT_SH =
594SCRIPT_LIB =
595TEST_BUILTINS_OBJS =
596TEST_PROGRAMS_NEED_X =
597
598# Having this variable in your environment would break pipelines because
599# you cause "cd" to echo its destination to stdout. It can also take
600# scripts to unexpected places. If you like CDPATH, define it for your
601# interactive shell sessions without exporting it.
602unexport CDPATH
603
604SCRIPT_SH += git-bisect.sh
605SCRIPT_SH += git-difftool--helper.sh
606SCRIPT_SH += git-filter-branch.sh
607SCRIPT_SH += git-merge-octopus.sh
608SCRIPT_SH += git-merge-one-file.sh
609SCRIPT_SH += git-merge-resolve.sh
610SCRIPT_SH += git-mergetool.sh
611SCRIPT_SH += git-quiltimport.sh
612SCRIPT_SH += git-legacy-rebase.sh
613SCRIPT_SH += git-remote-testgit.sh
614SCRIPT_SH += git-request-pull.sh
615SCRIPT_SH += git-stash.sh
616SCRIPT_SH += git-submodule.sh
617SCRIPT_SH += git-web--browse.sh
618
619SCRIPT_LIB += git-mergetool--lib
620SCRIPT_LIB += git-parse-remote
621SCRIPT_LIB += git-rebase--am
622SCRIPT_LIB += git-rebase--common
623SCRIPT_LIB += git-rebase--preserve-merges
624SCRIPT_LIB += git-sh-setup
625SCRIPT_LIB += git-sh-i18n
626
627SCRIPT_PERL += git-add--interactive.perl
628SCRIPT_PERL += git-archimport.perl
629SCRIPT_PERL += git-cvsexportcommit.perl
630SCRIPT_PERL += git-cvsimport.perl
631SCRIPT_PERL += git-cvsserver.perl
632SCRIPT_PERL += git-send-email.perl
633SCRIPT_PERL += git-svn.perl
634
635SCRIPT_PYTHON += git-p4.py
636
637NO_INSTALL += git-remote-testgit
638
639# Generated files for scripts
640SCRIPT_SH_GEN = $(patsubst %.sh,%,$(SCRIPT_SH))
641SCRIPT_PERL_GEN = $(patsubst %.perl,%,$(SCRIPT_PERL))
642SCRIPT_PYTHON_GEN = $(patsubst %.py,%,$(SCRIPT_PYTHON))
643
644SCRIPT_SH_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_SH_GEN))
645SCRIPT_PERL_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_PERL_GEN))
646SCRIPT_PYTHON_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_PYTHON_GEN))
647
648# Individual rules to allow e.g.
649# "make -C ../.. SCRIPT_PERL=contrib/foo/bar.perl build-perl-script"
650# from subdirectories like contrib/*/
651.PHONY: build-perl-script build-sh-script build-python-script
652build-perl-script: $(SCRIPT_PERL_GEN)
653build-sh-script: $(SCRIPT_SH_GEN)
654build-python-script: $(SCRIPT_PYTHON_GEN)
655
656.PHONY: install-perl-script install-sh-script install-python-script
657install-sh-script: $(SCRIPT_SH_INS)
658 $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
659install-perl-script: $(SCRIPT_PERL_INS)
660 $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
661install-python-script: $(SCRIPT_PYTHON_INS)
662 $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
663
664.PHONY: clean-perl-script clean-sh-script clean-python-script
665clean-sh-script:
666 $(RM) $(SCRIPT_SH_GEN)
667clean-perl-script:
668 $(RM) $(SCRIPT_PERL_GEN)
669clean-python-script:
670 $(RM) $(SCRIPT_PYTHON_GEN)
671
672SCRIPTS = $(SCRIPT_SH_INS) \
673 $(SCRIPT_PERL_INS) \
674 $(SCRIPT_PYTHON_INS) \
675 git-instaweb
676
677ETAGS_TARGET = TAGS
678
679FUZZ_OBJS += fuzz-commit-graph.o
680FUZZ_OBJS += fuzz-pack-headers.o
681FUZZ_OBJS += fuzz-pack-idx.o
682
683# Always build fuzz objects even if not testing, to prevent bit-rot.
684all:: $(FUZZ_OBJS)
685
686FUZZ_PROGRAMS += $(patsubst %.o,%,$(FUZZ_OBJS))
687
688# Empty...
689EXTRA_PROGRAMS =
690
691# ... and all the rest that could be moved out of bindir to gitexecdir
692PROGRAMS += $(EXTRA_PROGRAMS)
693
694PROGRAM_OBJS += credential-store.o
695PROGRAM_OBJS += daemon.o
696PROGRAM_OBJS += fast-import.o
697PROGRAM_OBJS += http-backend.o
698PROGRAM_OBJS += imap-send.o
699PROGRAM_OBJS += sh-i18n--envsubst.o
700PROGRAM_OBJS += shell.o
701PROGRAM_OBJS += remote-testsvn.o
702
703# Binary suffix, set to .exe for Windows builds
704X =
705
706PROGRAMS += $(patsubst %.o,git-%$X,$(PROGRAM_OBJS))
707
708TEST_BUILTINS_OBJS += test-chmtime.o
709TEST_BUILTINS_OBJS += test-config.o
710TEST_BUILTINS_OBJS += test-ctype.o
711TEST_BUILTINS_OBJS += test-date.o
712TEST_BUILTINS_OBJS += test-delta.o
713TEST_BUILTINS_OBJS += test-drop-caches.o
714TEST_BUILTINS_OBJS += test-dump-cache-tree.o
715TEST_BUILTINS_OBJS += test-dump-fsmonitor.o
716TEST_BUILTINS_OBJS += test-dump-split-index.o
717TEST_BUILTINS_OBJS += test-dump-untracked-cache.o
718TEST_BUILTINS_OBJS += test-example-decorate.o
719TEST_BUILTINS_OBJS += test-genrandom.o
720TEST_BUILTINS_OBJS += test-genzeros.o
721TEST_BUILTINS_OBJS += test-hash.o
722TEST_BUILTINS_OBJS += test-hashmap.o
723TEST_BUILTINS_OBJS += test-hash-speed.o
724TEST_BUILTINS_OBJS += test-index-version.o
725TEST_BUILTINS_OBJS += test-json-writer.o
726TEST_BUILTINS_OBJS += test-lazy-init-name-hash.o
727TEST_BUILTINS_OBJS += test-match-trees.o
728TEST_BUILTINS_OBJS += test-mergesort.o
729TEST_BUILTINS_OBJS += test-mktemp.o
730TEST_BUILTINS_OBJS += test-online-cpus.o
731TEST_BUILTINS_OBJS += test-parse-options.o
732TEST_BUILTINS_OBJS += test-path-utils.o
733TEST_BUILTINS_OBJS += test-pkt-line.o
734TEST_BUILTINS_OBJS += test-prio-queue.o
735TEST_BUILTINS_OBJS += test-reach.o
736TEST_BUILTINS_OBJS += test-read-cache.o
737TEST_BUILTINS_OBJS += test-read-midx.o
738TEST_BUILTINS_OBJS += test-ref-store.o
739TEST_BUILTINS_OBJS += test-regex.o
740TEST_BUILTINS_OBJS += test-repository.o
741TEST_BUILTINS_OBJS += test-revision-walking.o
742TEST_BUILTINS_OBJS += test-run-command.o
743TEST_BUILTINS_OBJS += test-scrap-cache-tree.o
744TEST_BUILTINS_OBJS += test-sha1.o
745TEST_BUILTINS_OBJS += test-sha1-array.o
746TEST_BUILTINS_OBJS += test-sha256.o
747TEST_BUILTINS_OBJS += test-sigchain.o
748TEST_BUILTINS_OBJS += test-strcmp-offset.o
749TEST_BUILTINS_OBJS += test-string-list.o
750TEST_BUILTINS_OBJS += test-submodule-config.o
751TEST_BUILTINS_OBJS += test-submodule-nested-repo-config.o
752TEST_BUILTINS_OBJS += test-subprocess.o
753TEST_BUILTINS_OBJS += test-urlmatch-normalization.o
754TEST_BUILTINS_OBJS += test-xml-encode.o
755TEST_BUILTINS_OBJS += test-wildmatch.o
756TEST_BUILTINS_OBJS += test-windows-named-pipe.o
757TEST_BUILTINS_OBJS += test-write-cache.o
758
759# Do not add more tests here unless they have extra dependencies. Add
760# them in TEST_BUILTINS_OBJS above.
761TEST_PROGRAMS_NEED_X += test-fake-ssh
762TEST_PROGRAMS_NEED_X += test-line-buffer
763TEST_PROGRAMS_NEED_X += test-svn-fe
764TEST_PROGRAMS_NEED_X += test-tool
765
766TEST_PROGRAMS = $(patsubst %,t/helper/%$X,$(TEST_PROGRAMS_NEED_X))
767
768# List built-in command $C whose implementation cmd_$C() is not in
769# builtin/$C.o but is linked in as part of some other command.
770BUILT_INS += $(patsubst builtin/%.o,git-%$X,$(BUILTIN_OBJS))
771
772BUILT_INS += git-cherry$X
773BUILT_INS += git-cherry-pick$X
774BUILT_INS += git-format-patch$X
775BUILT_INS += git-fsck-objects$X
776BUILT_INS += git-init$X
777BUILT_INS += git-merge-subtree$X
778BUILT_INS += git-show$X
779BUILT_INS += git-stage$X
780BUILT_INS += git-status$X
781BUILT_INS += git-whatchanged$X
782
783# what 'all' will build and 'install' will install in gitexecdir,
784# excluding programs for built-in commands
785ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS)
786
787# what 'all' will build but not install in gitexecdir
788OTHER_PROGRAMS = git$X
789
790# what test wrappers are needed and 'install' will install, in bindir
791BINDIR_PROGRAMS_NEED_X += git
792BINDIR_PROGRAMS_NEED_X += git-upload-pack
793BINDIR_PROGRAMS_NEED_X += git-receive-pack
794BINDIR_PROGRAMS_NEED_X += git-upload-archive
795BINDIR_PROGRAMS_NEED_X += git-shell
796
797BINDIR_PROGRAMS_NO_X += git-cvsserver
798
799# Set paths to tools early so that they can be used for version tests.
800ifndef SHELL_PATH
801 SHELL_PATH = /bin/sh
802endif
803ifndef PERL_PATH
804 PERL_PATH = /usr/bin/perl
805endif
806ifndef PYTHON_PATH
807 PYTHON_PATH = /usr/bin/python
808endif
809
810export PERL_PATH
811export PYTHON_PATH
812
813TEST_SHELL_PATH = $(SHELL_PATH)
814
815LIB_FILE = libgit.a
816XDIFF_LIB = xdiff/lib.a
817VCSSVN_LIB = vcs-svn/lib.a
818
819GENERATED_H += command-list.h
820
821LIB_H = $(shell $(FIND) . \
822 -name .git -prune -o \
823 -name t -prune -o \
824 -name Documentation -prune -o \
825 -name '*.h' -print)
826
827LIB_OBJS += abspath.o
828LIB_OBJS += advice.o
829LIB_OBJS += alias.o
830LIB_OBJS += alloc.o
831LIB_OBJS += apply.o
832LIB_OBJS += archive.o
833LIB_OBJS += archive-tar.o
834LIB_OBJS += archive-zip.o
835LIB_OBJS += argv-array.o
836LIB_OBJS += attr.o
837LIB_OBJS += base85.o
838LIB_OBJS += bisect.o
839LIB_OBJS += blame.o
840LIB_OBJS += blob.o
841LIB_OBJS += branch.o
842LIB_OBJS += bulk-checkin.o
843LIB_OBJS += bundle.o
844LIB_OBJS += cache-tree.o
845LIB_OBJS += chdir-notify.o
846LIB_OBJS += checkout.o
847LIB_OBJS += color.o
848LIB_OBJS += column.o
849LIB_OBJS += combine-diff.o
850LIB_OBJS += commit.o
851LIB_OBJS += commit-graph.o
852LIB_OBJS += commit-reach.o
853LIB_OBJS += compat/obstack.o
854LIB_OBJS += compat/terminal.o
855LIB_OBJS += config.o
856LIB_OBJS += connect.o
857LIB_OBJS += connected.o
858LIB_OBJS += convert.o
859LIB_OBJS += copy.o
860LIB_OBJS += credential.o
861LIB_OBJS += csum-file.o
862LIB_OBJS += ctype.o
863LIB_OBJS += date.o
864LIB_OBJS += decorate.o
865LIB_OBJS += delta-islands.o
866LIB_OBJS += diffcore-break.o
867LIB_OBJS += diffcore-delta.o
868LIB_OBJS += diffcore-order.o
869LIB_OBJS += diffcore-pickaxe.o
870LIB_OBJS += diffcore-rename.o
871LIB_OBJS += diff-delta.o
872LIB_OBJS += diff-lib.o
873LIB_OBJS += diff-no-index.o
874LIB_OBJS += diff.o
875LIB_OBJS += dir.o
876LIB_OBJS += dir-iterator.o
877LIB_OBJS += editor.o
878LIB_OBJS += entry.o
879LIB_OBJS += environment.o
880LIB_OBJS += ewah/bitmap.o
881LIB_OBJS += ewah/ewah_bitmap.o
882LIB_OBJS += ewah/ewah_io.o
883LIB_OBJS += ewah/ewah_rlw.o
884LIB_OBJS += exec-cmd.o
885LIB_OBJS += fetch-negotiator.o
886LIB_OBJS += fetch-object.o
887LIB_OBJS += fetch-pack.o
888LIB_OBJS += fsck.o
889LIB_OBJS += fsmonitor.o
890LIB_OBJS += gettext.o
891LIB_OBJS += gpg-interface.o
892LIB_OBJS += graph.o
893LIB_OBJS += grep.o
894LIB_OBJS += hashmap.o
895LIB_OBJS += linear-assignment.o
896LIB_OBJS += help.o
897LIB_OBJS += hex.o
898LIB_OBJS += ident.o
899LIB_OBJS += interdiff.o
900LIB_OBJS += json-writer.o
901LIB_OBJS += kwset.o
902LIB_OBJS += levenshtein.o
903LIB_OBJS += line-log.o
904LIB_OBJS += line-range.o
905LIB_OBJS += list-objects.o
906LIB_OBJS += list-objects-filter.o
907LIB_OBJS += list-objects-filter-options.o
908LIB_OBJS += ll-merge.o
909LIB_OBJS += lockfile.o
910LIB_OBJS += log-tree.o
911LIB_OBJS += ls-refs.o
912LIB_OBJS += mailinfo.o
913LIB_OBJS += mailmap.o
914LIB_OBJS += match-trees.o
915LIB_OBJS += mem-pool.o
916LIB_OBJS += merge.o
917LIB_OBJS += merge-blobs.o
918LIB_OBJS += merge-recursive.o
919LIB_OBJS += mergesort.o
920LIB_OBJS += midx.o
921LIB_OBJS += name-hash.o
922LIB_OBJS += negotiator/default.o
923LIB_OBJS += negotiator/skipping.o
924LIB_OBJS += notes.o
925LIB_OBJS += notes-cache.o
926LIB_OBJS += notes-merge.o
927LIB_OBJS += notes-utils.o
928LIB_OBJS += object.o
929LIB_OBJS += oidmap.o
930LIB_OBJS += oidset.o
931LIB_OBJS += packfile.o
932LIB_OBJS += pack-bitmap.o
933LIB_OBJS += pack-bitmap-write.o
934LIB_OBJS += pack-check.o
935LIB_OBJS += pack-objects.o
936LIB_OBJS += pack-revindex.o
937LIB_OBJS += pack-write.o
938LIB_OBJS += pager.o
939LIB_OBJS += parse-options.o
940LIB_OBJS += parse-options-cb.o
941LIB_OBJS += patch-delta.o
942LIB_OBJS += patch-ids.o
943LIB_OBJS += path.o
944LIB_OBJS += pathspec.o
945LIB_OBJS += pkt-line.o
946LIB_OBJS += preload-index.o
947LIB_OBJS += pretty.o
948LIB_OBJS += prio-queue.o
949LIB_OBJS += progress.o
950LIB_OBJS += prompt.o
951LIB_OBJS += protocol.o
952LIB_OBJS += quote.o
953LIB_OBJS += range-diff.o
954LIB_OBJS += reachable.o
955LIB_OBJS += read-cache.o
956LIB_OBJS += rebase-interactive.o
957LIB_OBJS += reflog-walk.o
958LIB_OBJS += refs.o
959LIB_OBJS += refs/files-backend.o
960LIB_OBJS += refs/iterator.o
961LIB_OBJS += refs/packed-backend.o
962LIB_OBJS += refs/ref-cache.o
963LIB_OBJS += refspec.o
964LIB_OBJS += ref-filter.o
965LIB_OBJS += remote.o
966LIB_OBJS += replace-object.o
967LIB_OBJS += repository.o
968LIB_OBJS += rerere.o
969LIB_OBJS += resolve-undo.o
970LIB_OBJS += revision.o
971LIB_OBJS += run-command.o
972LIB_OBJS += send-pack.o
973LIB_OBJS += sequencer.o
974LIB_OBJS += serve.o
975LIB_OBJS += server-info.o
976LIB_OBJS += setup.o
977LIB_OBJS += sha1-array.o
978LIB_OBJS += sha1-lookup.o
979LIB_OBJS += sha1-file.o
980LIB_OBJS += sha1-name.o
981LIB_OBJS += shallow.o
982LIB_OBJS += sideband.o
983LIB_OBJS += sigchain.o
984LIB_OBJS += split-index.o
985LIB_OBJS += strbuf.o
986LIB_OBJS += streaming.o
987LIB_OBJS += string-list.o
988LIB_OBJS += submodule.o
989LIB_OBJS += submodule-config.o
990LIB_OBJS += sub-process.o
991LIB_OBJS += symlinks.o
992LIB_OBJS += tag.o
993LIB_OBJS += tempfile.o
994LIB_OBJS += thread-utils.o
995LIB_OBJS += tmp-objdir.o
996LIB_OBJS += trace.o
997LIB_OBJS += trailer.o
998LIB_OBJS += transport.o
999LIB_OBJS += transport-helper.o
1000LIB_OBJS += tree-diff.o
1001LIB_OBJS += tree.o
1002LIB_OBJS += tree-walk.o
1003LIB_OBJS += unpack-trees.o
1004LIB_OBJS += upload-pack.o
1005LIB_OBJS += url.o
1006LIB_OBJS += urlmatch.o
1007LIB_OBJS += usage.o
1008LIB_OBJS += userdiff.o
1009LIB_OBJS += utf8.o
1010LIB_OBJS += varint.o
1011LIB_OBJS += version.o
1012LIB_OBJS += versioncmp.o
1013LIB_OBJS += walker.o
1014LIB_OBJS += wildmatch.o
1015LIB_OBJS += worktree.o
1016LIB_OBJS += wrapper.o
1017LIB_OBJS += write-or-die.o
1018LIB_OBJS += ws.o
1019LIB_OBJS += wt-status.o
1020LIB_OBJS += xdiff-interface.o
1021LIB_OBJS += zlib.o
1022
1023BUILTIN_OBJS += builtin/add.o
1024BUILTIN_OBJS += builtin/am.o
1025BUILTIN_OBJS += builtin/annotate.o
1026BUILTIN_OBJS += builtin/apply.o
1027BUILTIN_OBJS += builtin/archive.o
1028BUILTIN_OBJS += builtin/bisect--helper.o
1029BUILTIN_OBJS += builtin/blame.o
1030BUILTIN_OBJS += builtin/branch.o
1031BUILTIN_OBJS += builtin/bundle.o
1032BUILTIN_OBJS += builtin/cat-file.o
1033BUILTIN_OBJS += builtin/check-attr.o
1034BUILTIN_OBJS += builtin/check-ignore.o
1035BUILTIN_OBJS += builtin/check-mailmap.o
1036BUILTIN_OBJS += builtin/check-ref-format.o
1037BUILTIN_OBJS += builtin/checkout-index.o
1038BUILTIN_OBJS += builtin/checkout.o
1039BUILTIN_OBJS += builtin/clean.o
1040BUILTIN_OBJS += builtin/clone.o
1041BUILTIN_OBJS += builtin/column.o
1042BUILTIN_OBJS += builtin/commit-tree.o
1043BUILTIN_OBJS += builtin/commit.o
1044BUILTIN_OBJS += builtin/commit-graph.o
1045BUILTIN_OBJS += builtin/config.o
1046BUILTIN_OBJS += builtin/count-objects.o
1047BUILTIN_OBJS += builtin/credential.o
1048BUILTIN_OBJS += builtin/describe.o
1049BUILTIN_OBJS += builtin/diff-files.o
1050BUILTIN_OBJS += builtin/diff-index.o
1051BUILTIN_OBJS += builtin/diff-tree.o
1052BUILTIN_OBJS += builtin/diff.o
1053BUILTIN_OBJS += builtin/difftool.o
1054BUILTIN_OBJS += builtin/fast-export.o
1055BUILTIN_OBJS += builtin/fetch-pack.o
1056BUILTIN_OBJS += builtin/fetch.o
1057BUILTIN_OBJS += builtin/fmt-merge-msg.o
1058BUILTIN_OBJS += builtin/for-each-ref.o
1059BUILTIN_OBJS += builtin/fsck.o
1060BUILTIN_OBJS += builtin/gc.o
1061BUILTIN_OBJS += builtin/get-tar-commit-id.o
1062BUILTIN_OBJS += builtin/grep.o
1063BUILTIN_OBJS += builtin/hash-object.o
1064BUILTIN_OBJS += builtin/help.o
1065BUILTIN_OBJS += builtin/index-pack.o
1066BUILTIN_OBJS += builtin/init-db.o
1067BUILTIN_OBJS += builtin/interpret-trailers.o
1068BUILTIN_OBJS += builtin/log.o
1069BUILTIN_OBJS += builtin/ls-files.o
1070BUILTIN_OBJS += builtin/ls-remote.o
1071BUILTIN_OBJS += builtin/ls-tree.o
1072BUILTIN_OBJS += builtin/mailinfo.o
1073BUILTIN_OBJS += builtin/mailsplit.o
1074BUILTIN_OBJS += builtin/merge.o
1075BUILTIN_OBJS += builtin/merge-base.o
1076BUILTIN_OBJS += builtin/merge-file.o
1077BUILTIN_OBJS += builtin/merge-index.o
1078BUILTIN_OBJS += builtin/merge-ours.o
1079BUILTIN_OBJS += builtin/merge-recursive.o
1080BUILTIN_OBJS += builtin/merge-tree.o
1081BUILTIN_OBJS += builtin/mktag.o
1082BUILTIN_OBJS += builtin/mktree.o
1083BUILTIN_OBJS += builtin/multi-pack-index.o
1084BUILTIN_OBJS += builtin/mv.o
1085BUILTIN_OBJS += builtin/name-rev.o
1086BUILTIN_OBJS += builtin/notes.o
1087BUILTIN_OBJS += builtin/pack-objects.o
1088BUILTIN_OBJS += builtin/pack-redundant.o
1089BUILTIN_OBJS += builtin/pack-refs.o
1090BUILTIN_OBJS += builtin/patch-id.o
1091BUILTIN_OBJS += builtin/prune-packed.o
1092BUILTIN_OBJS += builtin/prune.o
1093BUILTIN_OBJS += builtin/pull.o
1094BUILTIN_OBJS += builtin/push.o
1095BUILTIN_OBJS += builtin/range-diff.o
1096BUILTIN_OBJS += builtin/read-tree.o
1097BUILTIN_OBJS += builtin/rebase.o
1098BUILTIN_OBJS += builtin/rebase--interactive.o
1099BUILTIN_OBJS += builtin/receive-pack.o
1100BUILTIN_OBJS += builtin/reflog.o
1101BUILTIN_OBJS += builtin/remote.o
1102BUILTIN_OBJS += builtin/remote-ext.o
1103BUILTIN_OBJS += builtin/remote-fd.o
1104BUILTIN_OBJS += builtin/repack.o
1105BUILTIN_OBJS += builtin/replace.o
1106BUILTIN_OBJS += builtin/rerere.o
1107BUILTIN_OBJS += builtin/reset.o
1108BUILTIN_OBJS += builtin/rev-list.o
1109BUILTIN_OBJS += builtin/rev-parse.o
1110BUILTIN_OBJS += builtin/revert.o
1111BUILTIN_OBJS += builtin/rm.o
1112BUILTIN_OBJS += builtin/send-pack.o
1113BUILTIN_OBJS += builtin/serve.o
1114BUILTIN_OBJS += builtin/shortlog.o
1115BUILTIN_OBJS += builtin/show-branch.o
1116BUILTIN_OBJS += builtin/show-index.o
1117BUILTIN_OBJS += builtin/show-ref.o
1118BUILTIN_OBJS += builtin/stripspace.o
1119BUILTIN_OBJS += builtin/submodule--helper.o
1120BUILTIN_OBJS += builtin/symbolic-ref.o
1121BUILTIN_OBJS += builtin/tag.o
1122BUILTIN_OBJS += builtin/unpack-file.o
1123BUILTIN_OBJS += builtin/unpack-objects.o
1124BUILTIN_OBJS += builtin/update-index.o
1125BUILTIN_OBJS += builtin/update-ref.o
1126BUILTIN_OBJS += builtin/update-server-info.o
1127BUILTIN_OBJS += builtin/upload-archive.o
1128BUILTIN_OBJS += builtin/upload-pack.o
1129BUILTIN_OBJS += builtin/var.o
1130BUILTIN_OBJS += builtin/verify-commit.o
1131BUILTIN_OBJS += builtin/verify-pack.o
1132BUILTIN_OBJS += builtin/verify-tag.o
1133BUILTIN_OBJS += builtin/worktree.o
1134BUILTIN_OBJS += builtin/write-tree.o
1135
1136GITLIBS = common-main.o $(LIB_FILE) $(XDIFF_LIB)
1137EXTLIBS =
1138
1139GIT_USER_AGENT = git/$(GIT_VERSION)
1140
1141ifeq ($(wildcard sha1collisiondetection/lib/sha1.h),sha1collisiondetection/lib/sha1.h)
1142DC_SHA1_SUBMODULE = auto
1143endif
1144
1145# Set CFLAGS, LDFLAGS and other *FLAGS variables. These might be
1146# tweaked by config.* below as well as the command-line, both of
1147# which'll override these defaults.
1148CFLAGS = -g -O2 -Wall
1149LDFLAGS =
1150BASIC_CFLAGS = -I.
1151BASIC_LDFLAGS =
1152
1153# library flags
1154ARFLAGS = rcs
1155PTHREAD_CFLAGS =
1156
1157# For the 'sparse' target
1158SPARSE_FLAGS ?=
1159SP_EXTRA_FLAGS =
1160
1161# For the 'coccicheck' target
1162SPATCH_FLAGS = --all-includes --patch .
1163
1164include config.mak.uname
1165-include config.mak.autogen
1166-include config.mak
1167
1168ifdef DEVELOPER
1169include config.mak.dev
1170endif
1171
1172ALL_CFLAGS = $(CPPFLAGS) $(CFLAGS)
1173ALL_LDFLAGS = $(LDFLAGS)
1174
1175comma := ,
1176empty :=
1177space := $(empty) $(empty)
1178
1179ifdef SANITIZE
1180SANITIZERS := $(foreach flag,$(subst $(comma),$(space),$(SANITIZE)),$(flag))
1181BASIC_CFLAGS += -fsanitize=$(SANITIZE) -fno-sanitize-recover=$(SANITIZE)
1182BASIC_CFLAGS += -fno-omit-frame-pointer
1183ifneq ($(filter undefined,$(SANITIZERS)),)
1184BASIC_CFLAGS += -DNO_UNALIGNED_LOADS
1185endif
1186ifneq ($(filter leak,$(SANITIZERS)),)
1187BASIC_CFLAGS += -DSUPPRESS_ANNOTATED_LEAKS
1188endif
1189endif
1190
1191ifndef sysconfdir
1192ifeq ($(prefix),/usr)
1193sysconfdir = /etc
1194else
1195sysconfdir = etc
1196endif
1197endif
1198
1199ifndef COMPUTE_HEADER_DEPENDENCIES
1200COMPUTE_HEADER_DEPENDENCIES = auto
1201endif
1202
1203ifeq ($(COMPUTE_HEADER_DEPENDENCIES),auto)
1204dep_check = $(shell $(CC) $(ALL_CFLAGS) \
1205 -c -MF /dev/null -MQ /dev/null -MMD -MP \
1206 -x c /dev/null -o /dev/null 2>&1; \
1207 echo $$?)
1208ifeq ($(dep_check),0)
1209override COMPUTE_HEADER_DEPENDENCIES = yes
1210else
1211override COMPUTE_HEADER_DEPENDENCIES = no
1212endif
1213endif
1214
1215ifeq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
1216USE_COMPUTED_HEADER_DEPENDENCIES = YesPlease
1217else
1218ifneq ($(COMPUTE_HEADER_DEPENDENCIES),no)
1219$(error please set COMPUTE_HEADER_DEPENDENCIES to yes, no, or auto \
1220(not "$(COMPUTE_HEADER_DEPENDENCIES)"))
1221endif
1222endif
1223
1224ifdef SANE_TOOL_PATH
1225SANE_TOOL_PATH_SQ = $(subst ','\'',$(SANE_TOOL_PATH))
1226BROKEN_PATH_FIX = 's|^\# @@BROKEN_PATH_FIX@@$$|git_broken_path_fix $(SANE_TOOL_PATH_SQ)|'
1227PATH := $(SANE_TOOL_PATH):${PATH}
1228else
1229BROKEN_PATH_FIX = '/^\# @@BROKEN_PATH_FIX@@$$/d'
1230endif
1231
1232ifeq (,$(HOST_CPU))
1233 BASIC_CFLAGS += -DGIT_HOST_CPU="\"$(firstword $(subst -, ,$(uname_M)))\""
1234else
1235 BASIC_CFLAGS += -DGIT_HOST_CPU="\"$(HOST_CPU)\""
1236endif
1237
1238ifneq (,$(INLINE))
1239 BASIC_CFLAGS += -Dinline=$(INLINE)
1240endif
1241
1242ifneq (,$(SOCKLEN_T))
1243 BASIC_CFLAGS += -Dsocklen_t=$(SOCKLEN_T)
1244endif
1245
1246ifeq (yes,$(USE_PARENS_AROUND_GETTEXT_N))
1247 BASIC_CFLAGS += -DUSE_PARENS_AROUND_GETTEXT_N=1
1248else
1249ifeq (no,$(USE_PARENS_AROUND_GETTEXT_N))
1250 BASIC_CFLAGS += -DUSE_PARENS_AROUND_GETTEXT_N=0
1251endif
1252endif
1253
1254ifeq ($(uname_S),Darwin)
1255 ifndef NO_FINK
1256 ifeq ($(shell test -d /sw/lib && echo y),y)
1257 BASIC_CFLAGS += -I/sw/include
1258 BASIC_LDFLAGS += -L/sw/lib
1259 endif
1260 endif
1261 ifndef NO_DARWIN_PORTS
1262 ifeq ($(shell test -d /opt/local/lib && echo y),y)
1263 BASIC_CFLAGS += -I/opt/local/include
1264 BASIC_LDFLAGS += -L/opt/local/lib
1265 endif
1266 endif
1267 ifndef NO_APPLE_COMMON_CRYPTO
1268 NO_OPENSSL = YesPlease
1269 APPLE_COMMON_CRYPTO = YesPlease
1270 COMPAT_CFLAGS += -DAPPLE_COMMON_CRYPTO
1271 endif
1272 NO_REGEX = YesPlease
1273 PTHREAD_LIBS =
1274endif
1275
1276ifndef CC_LD_DYNPATH
1277 ifdef NO_R_TO_GCC_LINKER
1278 # Some gcc does not accept and pass -R to the linker to specify
1279 # the runtime dynamic library path.
1280 CC_LD_DYNPATH = -Wl,-rpath,
1281 else
1282 CC_LD_DYNPATH = -R
1283 endif
1284endif
1285
1286ifdef NO_LIBGEN_H
1287 COMPAT_CFLAGS += -DNO_LIBGEN_H
1288 COMPAT_OBJS += compat/basename.o
1289endif
1290
1291USE_LIBPCRE2 ?= $(USE_LIBPCRE)
1292
1293ifneq (,$(USE_LIBPCRE2))
1294 ifdef USE_LIBPCRE1
1295$(error Only set USE_LIBPCRE2 (or its alias USE_LIBPCRE) or USE_LIBPCRE1, not both!)
1296 endif
1297
1298 BASIC_CFLAGS += -DUSE_LIBPCRE2
1299 EXTLIBS += -lpcre2-8
1300endif
1301
1302ifdef USE_LIBPCRE1
1303 BASIC_CFLAGS += -DUSE_LIBPCRE1
1304 EXTLIBS += -lpcre
1305
1306ifdef NO_LIBPCRE1_JIT
1307 BASIC_CFLAGS += -DNO_LIBPCRE1_JIT
1308endif
1309endif
1310
1311ifdef LIBPCREDIR
1312 BASIC_CFLAGS += -I$(LIBPCREDIR)/include
1313 EXTLIBS += -L$(LIBPCREDIR)/$(lib) $(CC_LD_DYNPATH)$(LIBPCREDIR)/$(lib)
1314endif
1315
1316ifdef HAVE_ALLOCA_H
1317 BASIC_CFLAGS += -DHAVE_ALLOCA_H
1318endif
1319
1320IMAP_SEND_BUILDDEPS =
1321IMAP_SEND_LDFLAGS =
1322
1323ifdef NO_CURL
1324 BASIC_CFLAGS += -DNO_CURL
1325 REMOTE_CURL_PRIMARY =
1326 REMOTE_CURL_ALIASES =
1327 REMOTE_CURL_NAMES =
1328else
1329 ifdef CURLDIR
1330 # Try "-Wl,-rpath=$(CURLDIR)/$(lib)" in such a case.
1331 BASIC_CFLAGS += -I$(CURLDIR)/include
1332 CURL_LIBCURL = -L$(CURLDIR)/$(lib) $(CC_LD_DYNPATH)$(CURLDIR)/$(lib)
1333 else
1334 CURL_LIBCURL =
1335 endif
1336
1337ifdef CURL_LDFLAGS
1338 CURL_LIBCURL += $(CURL_LDFLAGS)
1339else
1340 CURL_LIBCURL += $(shell $(CURL_CONFIG) --libs)
1341endif
1342
1343 REMOTE_CURL_PRIMARY = git-remote-http$X
1344 REMOTE_CURL_ALIASES = git-remote-https$X git-remote-ftp$X git-remote-ftps$X
1345 REMOTE_CURL_NAMES = $(REMOTE_CURL_PRIMARY) $(REMOTE_CURL_ALIASES)
1346 PROGRAM_OBJS += http-fetch.o
1347 PROGRAMS += $(REMOTE_CURL_NAMES)
1348 curl_check := $(shell (echo 070908; $(CURL_CONFIG) --vernum | sed -e '/^70[BC]/s/^/0/') 2>/dev/null | sort -r | sed -ne 2p)
1349 ifeq "$(curl_check)" "070908"
1350 ifndef NO_EXPAT
1351 PROGRAM_OBJS += http-push.o
1352 endif
1353 endif
1354 curl_check := $(shell (echo 072200; $(CURL_CONFIG) --vernum | sed -e '/^70[BC]/s/^/0/') 2>/dev/null | sort -r | sed -ne 2p)
1355 ifeq "$(curl_check)" "072200"
1356 USE_CURL_FOR_IMAP_SEND = YesPlease
1357 endif
1358 ifdef USE_CURL_FOR_IMAP_SEND
1359 BASIC_CFLAGS += -DUSE_CURL_FOR_IMAP_SEND
1360 IMAP_SEND_BUILDDEPS = http.o
1361 IMAP_SEND_LDFLAGS += $(CURL_LIBCURL)
1362 endif
1363 ifndef NO_EXPAT
1364 ifdef EXPATDIR
1365 BASIC_CFLAGS += -I$(EXPATDIR)/include
1366 EXPAT_LIBEXPAT = -L$(EXPATDIR)/$(lib) $(CC_LD_DYNPATH)$(EXPATDIR)/$(lib) -lexpat
1367 else
1368 EXPAT_LIBEXPAT = -lexpat
1369 endif
1370 ifdef EXPAT_NEEDS_XMLPARSE_H
1371 BASIC_CFLAGS += -DEXPAT_NEEDS_XMLPARSE_H
1372 endif
1373 endif
1374endif
1375IMAP_SEND_LDFLAGS += $(OPENSSL_LINK) $(OPENSSL_LIBSSL) $(LIB_4_CRYPTO)
1376
1377ifdef ZLIB_PATH
1378 BASIC_CFLAGS += -I$(ZLIB_PATH)/include
1379 EXTLIBS += -L$(ZLIB_PATH)/$(lib) $(CC_LD_DYNPATH)$(ZLIB_PATH)/$(lib)
1380endif
1381EXTLIBS += -lz
1382
1383ifndef NO_OPENSSL
1384 OPENSSL_LIBSSL = -lssl
1385 ifdef OPENSSLDIR
1386 BASIC_CFLAGS += -I$(OPENSSLDIR)/include
1387 OPENSSL_LINK = -L$(OPENSSLDIR)/$(lib) $(CC_LD_DYNPATH)$(OPENSSLDIR)/$(lib)
1388 else
1389 OPENSSL_LINK =
1390 endif
1391 ifdef NEEDS_CRYPTO_WITH_SSL
1392 OPENSSL_LIBSSL += -lcrypto
1393 endif
1394else
1395 BASIC_CFLAGS += -DNO_OPENSSL
1396 OPENSSL_LIBSSL =
1397endif
1398ifdef NO_OPENSSL
1399 LIB_4_CRYPTO =
1400else
1401ifdef NEEDS_SSL_WITH_CRYPTO
1402 LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl
1403else
1404 LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto
1405endif
1406ifdef APPLE_COMMON_CRYPTO
1407 LIB_4_CRYPTO += -framework Security -framework CoreFoundation
1408endif
1409endif
1410ifndef NO_ICONV
1411 ifdef NEEDS_LIBICONV
1412 ifdef ICONVDIR
1413 BASIC_CFLAGS += -I$(ICONVDIR)/include
1414 ICONV_LINK = -L$(ICONVDIR)/$(lib) $(CC_LD_DYNPATH)$(ICONVDIR)/$(lib)
1415 else
1416 ICONV_LINK =
1417 endif
1418 ifdef NEEDS_LIBINTL_BEFORE_LIBICONV
1419 ICONV_LINK += -lintl
1420 endif
1421 EXTLIBS += $(ICONV_LINK) -liconv
1422 endif
1423endif
1424ifdef ICONV_OMITS_BOM
1425 BASIC_CFLAGS += -DICONV_OMITS_BOM
1426endif
1427ifdef NEEDS_LIBGEN
1428 EXTLIBS += -lgen
1429endif
1430ifndef NO_GETTEXT
1431ifndef LIBC_CONTAINS_LIBINTL
1432 EXTLIBS += -lintl
1433endif
1434endif
1435ifdef NEEDS_SOCKET
1436 EXTLIBS += -lsocket
1437endif
1438ifdef NEEDS_NSL
1439 EXTLIBS += -lnsl
1440endif
1441ifdef NEEDS_RESOLV
1442 EXTLIBS += -lresolv
1443endif
1444ifdef NO_D_TYPE_IN_DIRENT
1445 BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT
1446endif
1447ifdef NO_GECOS_IN_PWENT
1448 BASIC_CFLAGS += -DNO_GECOS_IN_PWENT
1449endif
1450ifdef NO_ST_BLOCKS_IN_STRUCT_STAT
1451 BASIC_CFLAGS += -DNO_ST_BLOCKS_IN_STRUCT_STAT
1452endif
1453ifdef USE_NSEC
1454 BASIC_CFLAGS += -DUSE_NSEC
1455endif
1456ifdef USE_ST_TIMESPEC
1457 BASIC_CFLAGS += -DUSE_ST_TIMESPEC
1458endif
1459ifdef NO_NORETURN
1460 BASIC_CFLAGS += -DNO_NORETURN
1461endif
1462ifdef NO_NSEC
1463 BASIC_CFLAGS += -DNO_NSEC
1464endif
1465ifdef SNPRINTF_RETURNS_BOGUS
1466 COMPAT_CFLAGS += -DSNPRINTF_RETURNS_BOGUS
1467 COMPAT_OBJS += compat/snprintf.o
1468endif
1469ifdef FREAD_READS_DIRECTORIES
1470 COMPAT_CFLAGS += -DFREAD_READS_DIRECTORIES
1471 COMPAT_OBJS += compat/fopen.o
1472endif
1473ifdef NO_SYMLINK_HEAD
1474 BASIC_CFLAGS += -DNO_SYMLINK_HEAD
1475endif
1476ifdef GETTEXT_POISON
1477$(warning The GETTEXT_POISON option has been removed in favor of runtime GIT_TEST_GETTEXT_POISON. See t/README!)
1478endif
1479ifdef NO_GETTEXT
1480 BASIC_CFLAGS += -DNO_GETTEXT
1481 USE_GETTEXT_SCHEME ?= fallthrough
1482endif
1483ifdef NO_POLL
1484 NO_POLL_H = YesPlease
1485 NO_SYS_POLL_H = YesPlease
1486 COMPAT_CFLAGS += -DNO_POLL -Icompat/poll
1487 COMPAT_OBJS += compat/poll/poll.o
1488endif
1489ifdef NO_STRCASESTR
1490 COMPAT_CFLAGS += -DNO_STRCASESTR
1491 COMPAT_OBJS += compat/strcasestr.o
1492endif
1493ifdef NO_STRLCPY
1494 COMPAT_CFLAGS += -DNO_STRLCPY
1495 COMPAT_OBJS += compat/strlcpy.o
1496endif
1497ifdef NO_STRTOUMAX
1498 COMPAT_CFLAGS += -DNO_STRTOUMAX
1499 COMPAT_OBJS += compat/strtoumax.o compat/strtoimax.o
1500endif
1501ifdef NO_STRTOULL
1502 COMPAT_CFLAGS += -DNO_STRTOULL
1503endif
1504ifdef NO_SETENV
1505 COMPAT_CFLAGS += -DNO_SETENV
1506 COMPAT_OBJS += compat/setenv.o
1507endif
1508ifdef NO_MKDTEMP
1509 COMPAT_CFLAGS += -DNO_MKDTEMP
1510 COMPAT_OBJS += compat/mkdtemp.o
1511endif
1512ifdef MKDIR_WO_TRAILING_SLASH
1513 COMPAT_CFLAGS += -DMKDIR_WO_TRAILING_SLASH
1514 COMPAT_OBJS += compat/mkdir.o
1515endif
1516ifdef NO_UNSETENV
1517 COMPAT_CFLAGS += -DNO_UNSETENV
1518 COMPAT_OBJS += compat/unsetenv.o
1519endif
1520ifdef NO_SYS_SELECT_H
1521 BASIC_CFLAGS += -DNO_SYS_SELECT_H
1522endif
1523ifdef NO_POLL_H
1524 BASIC_CFLAGS += -DNO_POLL_H
1525endif
1526ifdef NO_SYS_POLL_H
1527 BASIC_CFLAGS += -DNO_SYS_POLL_H
1528endif
1529ifdef NEEDS_SYS_PARAM_H
1530 BASIC_CFLAGS += -DNEEDS_SYS_PARAM_H
1531endif
1532ifdef NO_INTTYPES_H
1533 BASIC_CFLAGS += -DNO_INTTYPES_H
1534endif
1535ifdef NO_INITGROUPS
1536 BASIC_CFLAGS += -DNO_INITGROUPS
1537endif
1538ifdef NO_MMAP
1539 COMPAT_CFLAGS += -DNO_MMAP
1540 COMPAT_OBJS += compat/mmap.o
1541else
1542 ifdef USE_WIN32_MMAP
1543 COMPAT_CFLAGS += -DUSE_WIN32_MMAP
1544 COMPAT_OBJS += compat/win32mmap.o
1545 endif
1546endif
1547ifdef MMAP_PREVENTS_DELETE
1548 BASIC_CFLAGS += -DMMAP_PREVENTS_DELETE
1549endif
1550ifdef OBJECT_CREATION_USES_RENAMES
1551 COMPAT_CFLAGS += -DOBJECT_CREATION_MODE=1
1552endif
1553ifdef NO_STRUCT_ITIMERVAL
1554 COMPAT_CFLAGS += -DNO_STRUCT_ITIMERVAL
1555 NO_SETITIMER = YesPlease
1556endif
1557ifdef NO_SETITIMER
1558 COMPAT_CFLAGS += -DNO_SETITIMER
1559endif
1560ifdef NO_PREAD
1561 COMPAT_CFLAGS += -DNO_PREAD
1562 COMPAT_OBJS += compat/pread.o
1563endif
1564ifdef NO_FAST_WORKING_DIRECTORY
1565 BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY
1566endif
1567ifdef NO_TRUSTABLE_FILEMODE
1568 BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE
1569endif
1570ifdef NEEDS_MODE_TRANSLATION
1571 COMPAT_CFLAGS += -DNEEDS_MODE_TRANSLATION
1572 COMPAT_OBJS += compat/stat.o
1573endif
1574ifdef NO_IPV6
1575 BASIC_CFLAGS += -DNO_IPV6
1576endif
1577ifdef NO_INTPTR_T
1578 COMPAT_CFLAGS += -DNO_INTPTR_T
1579endif
1580ifdef NO_UINTMAX_T
1581 BASIC_CFLAGS += -Duintmax_t=uint32_t
1582endif
1583ifdef NO_SOCKADDR_STORAGE
1584ifdef NO_IPV6
1585 BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in
1586else
1587 BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6
1588endif
1589endif
1590ifdef NO_INET_NTOP
1591 LIB_OBJS += compat/inet_ntop.o
1592 BASIC_CFLAGS += -DNO_INET_NTOP
1593endif
1594ifdef NO_INET_PTON
1595 LIB_OBJS += compat/inet_pton.o
1596 BASIC_CFLAGS += -DNO_INET_PTON
1597endif
1598ifndef NO_UNIX_SOCKETS
1599 LIB_OBJS += unix-socket.o
1600 PROGRAM_OBJS += credential-cache.o
1601 PROGRAM_OBJS += credential-cache--daemon.o
1602endif
1603
1604ifdef NO_ICONV
1605 BASIC_CFLAGS += -DNO_ICONV
1606endif
1607
1608ifdef OLD_ICONV
1609 BASIC_CFLAGS += -DOLD_ICONV
1610endif
1611
1612ifdef NO_DEFLATE_BOUND
1613 BASIC_CFLAGS += -DNO_DEFLATE_BOUND
1614endif
1615
1616ifdef NO_POSIX_GOODIES
1617 BASIC_CFLAGS += -DNO_POSIX_GOODIES
1618endif
1619
1620ifdef APPLE_COMMON_CRYPTO
1621 # Apple CommonCrypto requires chunking
1622 SHA1_MAX_BLOCK_SIZE = 1024L*1024L*1024L
1623endif
1624
1625ifdef OPENSSL_SHA1
1626 EXTLIBS += $(LIB_4_CRYPTO)
1627 BASIC_CFLAGS += -DSHA1_OPENSSL
1628else
1629ifdef BLK_SHA1
1630 LIB_OBJS += block-sha1/sha1.o
1631 BASIC_CFLAGS += -DSHA1_BLK
1632else
1633ifdef PPC_SHA1
1634 LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o
1635 BASIC_CFLAGS += -DSHA1_PPC
1636else
1637ifdef APPLE_COMMON_CRYPTO
1638 COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL
1639 BASIC_CFLAGS += -DSHA1_APPLE
1640else
1641 DC_SHA1 := YesPlease
1642 BASIC_CFLAGS += -DSHA1_DC
1643 LIB_OBJS += sha1dc_git.o
1644ifdef DC_SHA1_EXTERNAL
1645 ifdef DC_SHA1_SUBMODULE
1646 ifneq ($(DC_SHA1_SUBMODULE),auto)
1647$(error Only set DC_SHA1_EXTERNAL or DC_SHA1_SUBMODULE, not both)
1648 endif
1649 endif
1650 BASIC_CFLAGS += -DDC_SHA1_EXTERNAL
1651 EXTLIBS += -lsha1detectcoll
1652else
1653ifdef DC_SHA1_SUBMODULE
1654 LIB_OBJS += sha1collisiondetection/lib/sha1.o
1655 LIB_OBJS += sha1collisiondetection/lib/ubc_check.o
1656 BASIC_CFLAGS += -DDC_SHA1_SUBMODULE
1657else
1658 LIB_OBJS += sha1dc/sha1.o
1659 LIB_OBJS += sha1dc/ubc_check.o
1660endif
1661 BASIC_CFLAGS += \
1662 -DSHA1DC_NO_STANDARD_INCLUDES \
1663 -DSHA1DC_INIT_SAFE_HASH_DEFAULT=0 \
1664 -DSHA1DC_CUSTOM_INCLUDE_SHA1_C="\"cache.h\"" \
1665 -DSHA1DC_CUSTOM_INCLUDE_UBC_CHECK_C="\"git-compat-util.h\""
1666endif
1667endif
1668endif
1669endif
1670endif
1671
1672ifdef OPENSSL_SHA256
1673 EXTLIBS += $(LIB_4_CRYPTO)
1674 BASIC_CFLAGS += -DSHA256_OPENSSL
1675else
1676ifdef GCRYPT_SHA256
1677 BASIC_CFLAGS += -DSHA256_GCRYPT
1678 EXTLIBS += -lgcrypt
1679else
1680 LIB_OBJS += sha256/block/sha256.o
1681 BASIC_CFLAGS += -DSHA256_BLK
1682endif
1683endif
1684
1685ifdef SHA1_MAX_BLOCK_SIZE
1686 LIB_OBJS += compat/sha1-chunked.o
1687 BASIC_CFLAGS += -DSHA1_MAX_BLOCK_SIZE="$(SHA1_MAX_BLOCK_SIZE)"
1688endif
1689ifdef NO_HSTRERROR
1690 COMPAT_CFLAGS += -DNO_HSTRERROR
1691 COMPAT_OBJS += compat/hstrerror.o
1692endif
1693ifdef NO_MEMMEM
1694 COMPAT_CFLAGS += -DNO_MEMMEM
1695 COMPAT_OBJS += compat/memmem.o
1696endif
1697ifdef NO_GETPAGESIZE
1698 COMPAT_CFLAGS += -DNO_GETPAGESIZE
1699endif
1700ifdef INTERNAL_QSORT
1701 COMPAT_CFLAGS += -DINTERNAL_QSORT
1702 COMPAT_OBJS += compat/qsort.o
1703endif
1704ifdef HAVE_ISO_QSORT_S
1705 COMPAT_CFLAGS += -DHAVE_ISO_QSORT_S
1706else
1707 COMPAT_OBJS += compat/qsort_s.o
1708endif
1709ifdef RUNTIME_PREFIX
1710 COMPAT_CFLAGS += -DRUNTIME_PREFIX
1711endif
1712
1713ifdef NO_PTHREADS
1714 BASIC_CFLAGS += -DNO_PTHREADS
1715else
1716 BASIC_CFLAGS += $(PTHREAD_CFLAGS)
1717 EXTLIBS += $(PTHREAD_LIBS)
1718endif
1719
1720ifdef HAVE_PATHS_H
1721 BASIC_CFLAGS += -DHAVE_PATHS_H
1722endif
1723
1724ifdef HAVE_LIBCHARSET_H
1725 BASIC_CFLAGS += -DHAVE_LIBCHARSET_H
1726 EXTLIBS += $(CHARSET_LIB)
1727endif
1728
1729ifdef HAVE_STRINGS_H
1730 BASIC_CFLAGS += -DHAVE_STRINGS_H
1731endif
1732
1733ifdef HAVE_DEV_TTY
1734 BASIC_CFLAGS += -DHAVE_DEV_TTY
1735endif
1736
1737ifdef DIR_HAS_BSD_GROUP_SEMANTICS
1738 COMPAT_CFLAGS += -DDIR_HAS_BSD_GROUP_SEMANTICS
1739endif
1740ifdef UNRELIABLE_FSTAT
1741 BASIC_CFLAGS += -DUNRELIABLE_FSTAT
1742endif
1743ifdef NO_REGEX
1744 COMPAT_CFLAGS += -Icompat/regex
1745 COMPAT_OBJS += compat/regex/regex.o
1746endif
1747ifdef NATIVE_CRLF
1748 BASIC_CFLAGS += -DNATIVE_CRLF
1749endif
1750
1751ifdef USE_NED_ALLOCATOR
1752 COMPAT_CFLAGS += -Icompat/nedmalloc
1753 COMPAT_OBJS += compat/nedmalloc/nedmalloc.o
1754 OVERRIDE_STRDUP = YesPlease
1755endif
1756
1757ifdef OVERRIDE_STRDUP
1758 COMPAT_CFLAGS += -DOVERRIDE_STRDUP
1759 COMPAT_OBJS += compat/strdup.o
1760endif
1761
1762ifdef GIT_TEST_CMP_USE_COPIED_CONTEXT
1763 export GIT_TEST_CMP_USE_COPIED_CONTEXT
1764endif
1765
1766ifndef NO_MSGFMT_EXTENDED_OPTIONS
1767 MSGFMT += --check --statistics
1768endif
1769
1770ifdef GMTIME_UNRELIABLE_ERRORS
1771 COMPAT_OBJS += compat/gmtime.o
1772 BASIC_CFLAGS += -DGMTIME_UNRELIABLE_ERRORS
1773endif
1774
1775ifdef HAVE_CLOCK_GETTIME
1776 BASIC_CFLAGS += -DHAVE_CLOCK_GETTIME
1777endif
1778
1779ifdef HAVE_CLOCK_MONOTONIC
1780 BASIC_CFLAGS += -DHAVE_CLOCK_MONOTONIC
1781endif
1782
1783ifdef NEEDS_LIBRT
1784 EXTLIBS += -lrt
1785endif
1786
1787ifdef HAVE_BSD_SYSCTL
1788 BASIC_CFLAGS += -DHAVE_BSD_SYSCTL
1789endif
1790
1791ifdef HAVE_BSD_KERN_PROC_SYSCTL
1792 BASIC_CFLAGS += -DHAVE_BSD_KERN_PROC_SYSCTL
1793endif
1794
1795ifdef HAVE_GETDELIM
1796 BASIC_CFLAGS += -DHAVE_GETDELIM
1797endif
1798
1799ifneq ($(PROCFS_EXECUTABLE_PATH),)
1800 procfs_executable_path_SQ = $(subst ','\'',$(PROCFS_EXECUTABLE_PATH))
1801 BASIC_CFLAGS += '-DPROCFS_EXECUTABLE_PATH="$(procfs_executable_path_SQ)"'
1802endif
1803
1804ifdef HAVE_NS_GET_EXECUTABLE_PATH
1805 BASIC_CFLAGS += -DHAVE_NS_GET_EXECUTABLE_PATH
1806endif
1807
1808ifdef HAVE_WPGMPTR
1809 BASIC_CFLAGS += -DHAVE_WPGMPTR
1810endif
1811
1812ifdef FILENO_IS_A_MACRO
1813 COMPAT_CFLAGS += -DFILENO_IS_A_MACRO
1814 COMPAT_OBJS += compat/fileno.o
1815endif
1816
1817ifeq ($(TCLTK_PATH),)
1818NO_TCLTK = NoThanks
1819endif
1820
1821ifeq ($(PERL_PATH),)
1822NO_PERL = NoThanks
1823endif
1824
1825ifeq ($(PYTHON_PATH),)
1826NO_PYTHON = NoThanks
1827endif
1828
1829ifndef PAGER_ENV
1830PAGER_ENV = LESS=FRX LV=-c
1831endif
1832
1833QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir
1834QUIET_SUBDIR1 =
1835
1836ifneq ($(findstring w,$(MAKEFLAGS)),w)
1837PRINT_DIR = --no-print-directory
1838else # "make -w"
1839NO_SUBDIR = :
1840endif
1841
1842ifneq ($(findstring s,$(MAKEFLAGS)),s)
1843ifndef V
1844 QUIET_CC = @echo ' ' CC $@;
1845 QUIET_AR = @echo ' ' AR $@;
1846 QUIET_LINK = @echo ' ' LINK $@;
1847 QUIET_BUILT_IN = @echo ' ' BUILTIN $@;
1848 QUIET_GEN = @echo ' ' GEN $@;
1849 QUIET_LNCP = @echo ' ' LN/CP $@;
1850 QUIET_XGETTEXT = @echo ' ' XGETTEXT $@;
1851 QUIET_MSGFMT = @echo ' ' MSGFMT $@;
1852 QUIET_GCOV = @echo ' ' GCOV $@;
1853 QUIET_SP = @echo ' ' SP $<;
1854 QUIET_HDR = @echo ' ' HDR $<;
1855 QUIET_RC = @echo ' ' RC $@;
1856 QUIET_SUBDIR0 = +@subdir=
1857 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \
1858 $(MAKE) $(PRINT_DIR) -C $$subdir
1859 export V
1860 export QUIET_GEN
1861 export QUIET_BUILT_IN
1862endif
1863endif
1864
1865ifdef NO_INSTALL_HARDLINKS
1866 export NO_INSTALL_HARDLINKS
1867endif
1868
1869### profile feedback build
1870#
1871
1872# Can adjust this to be a global directory if you want to do extended
1873# data gathering
1874PROFILE_DIR := $(CURDIR)
1875
1876ifeq ("$(PROFILE)","GEN")
1877 BASIC_CFLAGS += -fprofile-generate=$(PROFILE_DIR) -DNO_NORETURN=1
1878 EXTLIBS += -lgcov
1879 export CCACHE_DISABLE = t
1880 V = 1
1881else
1882ifneq ("$(PROFILE)","")
1883 BASIC_CFLAGS += -fprofile-use=$(PROFILE_DIR) -fprofile-correction -DNO_NORETURN=1
1884 export CCACHE_DISABLE = t
1885 V = 1
1886endif
1887endif
1888
1889# Shell quote (do not use $(call) to accommodate ancient setups);
1890
1891ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG))
1892ETC_GITATTRIBUTES_SQ = $(subst ','\'',$(ETC_GITATTRIBUTES))
1893
1894DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
1895bindir_SQ = $(subst ','\'',$(bindir))
1896bindir_relative_SQ = $(subst ','\'',$(bindir_relative))
1897mandir_SQ = $(subst ','\'',$(mandir))
1898mandir_relative_SQ = $(subst ','\'',$(mandir_relative))
1899infodir_relative_SQ = $(subst ','\'',$(infodir_relative))
1900perllibdir_SQ = $(subst ','\'',$(perllibdir))
1901localedir_SQ = $(subst ','\'',$(localedir))
1902localedir_relative_SQ = $(subst ','\'',$(localedir_relative))
1903gitexecdir_SQ = $(subst ','\'',$(gitexecdir))
1904gitexecdir_relative_SQ = $(subst ','\'',$(gitexecdir_relative))
1905template_dir_SQ = $(subst ','\'',$(template_dir))
1906htmldir_relative_SQ = $(subst ','\'',$(htmldir_relative))
1907prefix_SQ = $(subst ','\'',$(prefix))
1908perllibdir_relative_SQ = $(subst ','\'',$(perllibdir_relative))
1909gitwebdir_SQ = $(subst ','\'',$(gitwebdir))
1910
1911SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
1912TEST_SHELL_PATH_SQ = $(subst ','\'',$(TEST_SHELL_PATH))
1913PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
1914PYTHON_PATH_SQ = $(subst ','\'',$(PYTHON_PATH))
1915TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH))
1916DIFF_SQ = $(subst ','\'',$(DIFF))
1917PERLLIB_EXTRA_SQ = $(subst ','\'',$(PERLLIB_EXTRA))
1918
1919# RUNTIME_PREFIX's resolution logic requires resource paths to be expressed
1920# relative to each other and share an installation path.
1921#
1922# This is a dependency in:
1923# - Git's binary RUNTIME_PREFIX logic in (see "exec_cmd.c").
1924# - The runtime prefix Perl header (see
1925# "perl/header_templates/runtime_prefix.template.pl").
1926ifdef RUNTIME_PREFIX
1927
1928ifneq ($(filter /%,$(firstword $(gitexecdir_relative))),)
1929$(error RUNTIME_PREFIX requires a relative gitexecdir, not: $(gitexecdir))
1930endif
1931
1932ifneq ($(filter /%,$(firstword $(localedir_relative))),)
1933$(error RUNTIME_PREFIX requires a relative localedir, not: $(localedir))
1934endif
1935
1936ifndef NO_PERL
1937ifneq ($(filter /%,$(firstword $(perllibdir_relative))),)
1938$(error RUNTIME_PREFIX requires a relative perllibdir, not: $(perllibdir))
1939endif
1940endif
1941
1942endif
1943
1944# We must filter out any object files from $(GITLIBS),
1945# as it is typically used like:
1946#
1947# foo: foo.o $(GITLIBS)
1948# $(CC) $(filter %.o,$^) $(LIBS)
1949#
1950# where we use it as a dependency. Since we also pull object files
1951# from the dependency list, that would make each entry appear twice.
1952LIBS = $(filter-out %.o, $(GITLIBS)) $(EXTLIBS)
1953
1954BASIC_CFLAGS += $(COMPAT_CFLAGS)
1955LIB_OBJS += $(COMPAT_OBJS)
1956
1957# Quote for C
1958
1959ifdef DEFAULT_EDITOR
1960DEFAULT_EDITOR_CQ = "$(subst ",\",$(subst \,\\,$(DEFAULT_EDITOR)))"
1961DEFAULT_EDITOR_CQ_SQ = $(subst ','\'',$(DEFAULT_EDITOR_CQ))
1962
1963BASIC_CFLAGS += -DDEFAULT_EDITOR='$(DEFAULT_EDITOR_CQ_SQ)'
1964endif
1965
1966ifdef DEFAULT_PAGER
1967DEFAULT_PAGER_CQ = "$(subst ",\",$(subst \,\\,$(DEFAULT_PAGER)))"
1968DEFAULT_PAGER_CQ_SQ = $(subst ','\'',$(DEFAULT_PAGER_CQ))
1969
1970BASIC_CFLAGS += -DDEFAULT_PAGER='$(DEFAULT_PAGER_CQ_SQ)'
1971endif
1972
1973ifdef SHELL_PATH
1974SHELL_PATH_CQ = "$(subst ",\",$(subst \,\\,$(SHELL_PATH)))"
1975SHELL_PATH_CQ_SQ = $(subst ','\'',$(SHELL_PATH_CQ))
1976
1977BASIC_CFLAGS += -DSHELL_PATH='$(SHELL_PATH_CQ_SQ)'
1978endif
1979
1980GIT_USER_AGENT_SQ = $(subst ','\'',$(GIT_USER_AGENT))
1981GIT_USER_AGENT_CQ = "$(subst ",\",$(subst \,\\,$(GIT_USER_AGENT)))"
1982GIT_USER_AGENT_CQ_SQ = $(subst ','\'',$(GIT_USER_AGENT_CQ))
1983GIT-USER-AGENT: FORCE
1984 @if test x'$(GIT_USER_AGENT_SQ)' != x"`cat GIT-USER-AGENT 2>/dev/null`"; then \
1985 echo '$(GIT_USER_AGENT_SQ)' >GIT-USER-AGENT; \
1986 fi
1987
1988ifdef DEFAULT_HELP_FORMAT
1989BASIC_CFLAGS += -DDEFAULT_HELP_FORMAT='"$(DEFAULT_HELP_FORMAT)"'
1990endif
1991
1992PAGER_ENV_SQ = $(subst ','\'',$(PAGER_ENV))
1993PAGER_ENV_CQ = "$(subst ",\",$(subst \,\\,$(PAGER_ENV)))"
1994PAGER_ENV_CQ_SQ = $(subst ','\'',$(PAGER_ENV_CQ))
1995BASIC_CFLAGS += -DPAGER_ENV='$(PAGER_ENV_CQ_SQ)'
1996
1997ALL_CFLAGS += $(BASIC_CFLAGS)
1998ALL_LDFLAGS += $(BASIC_LDFLAGS)
1999
2000export DIFF TAR INSTALL DESTDIR SHELL_PATH
2001
2002
2003### Build rules
2004
2005SHELL = $(SHELL_PATH)
2006
2007all:: shell_compatibility_test
2008
2009ifeq "$(PROFILE)" "BUILD"
2010all:: profile
2011endif
2012
2013profile:: profile-clean
2014 $(MAKE) PROFILE=GEN all
2015 $(MAKE) PROFILE=GEN -j1 test
2016 @if test -n "$$GIT_PERF_REPO" || test -d .git; then \
2017 $(MAKE) PROFILE=GEN -j1 perf; \
2018 else \
2019 echo "Skipping profile of perf tests..."; \
2020 fi
2021 $(MAKE) PROFILE=USE all
2022
2023profile-fast: profile-clean
2024 $(MAKE) PROFILE=GEN all
2025 $(MAKE) PROFILE=GEN -j1 perf
2026 $(MAKE) PROFILE=USE all
2027
2028
2029all:: $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS) $(OTHER_PROGRAMS) GIT-BUILD-OPTIONS
2030ifneq (,$X)
2031 $(QUIET_BUILT_IN)$(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), test -d '$p' -o '$p' -ef '$p$X' || $(RM) '$p';)
2032endif
2033
2034all::
2035ifndef NO_TCLTK
2036 $(QUIET_SUBDIR0)git-gui $(QUIET_SUBDIR1) gitexecdir='$(gitexec_instdir_SQ)' all
2037 $(QUIET_SUBDIR0)gitk-git $(QUIET_SUBDIR1) all
2038endif
2039 $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1) SHELL_PATH='$(SHELL_PATH_SQ)' PERL_PATH='$(PERL_PATH_SQ)'
2040
2041please_set_SHELL_PATH_to_a_more_modern_shell:
2042 @$$(:)
2043
2044shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell
2045
2046strip: $(PROGRAMS) git$X
2047 $(STRIP) $(STRIP_OPTS) $^
2048
2049### Target-specific flags and dependencies
2050
2051# The generic compilation pattern rule and automatically
2052# computed header dependencies (falling back to a dependency on
2053# LIB_H) are enough to describe how most targets should be built,
2054# but some targets are special enough to need something a little
2055# different.
2056#
2057# - When a source file "foo.c" #includes a generated header file,
2058# we need to list that dependency for the "foo.o" target.
2059#
2060# We also list it from other targets that are built from foo.c
2061# like "foo.sp" and "foo.s", even though that is easy to forget
2062# to do because the generated header is already present around
2063# after a regular build attempt.
2064#
2065# - Some code depends on configuration kept in makefile
2066# variables. The target-specific variable EXTRA_CPPFLAGS can
2067# be used to convey that information to the C preprocessor
2068# using -D options.
2069#
2070# The "foo.o" target should have a corresponding dependency on
2071# a file that changes when the value of the makefile variable
2072# changes. For example, targets making use of the
2073# $(GIT_VERSION) variable depend on GIT-VERSION-FILE.
2074#
2075# Technically the ".sp" and ".s" targets do not need this
2076# dependency because they are force-built, but they get the
2077# same dependency for consistency. This way, you do not have to
2078# know how each target is implemented. And it means the
2079# dependencies here will not need to change if the force-build
2080# details change some day.
2081
2082git.sp git.s git.o: GIT-PREFIX
2083git.sp git.s git.o: EXTRA_CPPFLAGS = \
2084 '-DGIT_HTML_PATH="$(htmldir_relative_SQ)"' \
2085 '-DGIT_MAN_PATH="$(mandir_relative_SQ)"' \
2086 '-DGIT_INFO_PATH="$(infodir_relative_SQ)"'
2087
2088git$X: git.o GIT-LDFLAGS $(BUILTIN_OBJS) $(GITLIBS)
2089 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) \
2090 $(filter %.o,$^) $(LIBS)
2091
2092help.sp help.s help.o: command-list.h
2093
2094builtin/help.sp builtin/help.s builtin/help.o: command-list.h GIT-PREFIX
2095builtin/help.sp builtin/help.s builtin/help.o: EXTRA_CPPFLAGS = \
2096 '-DGIT_HTML_PATH="$(htmldir_relative_SQ)"' \
2097 '-DGIT_MAN_PATH="$(mandir_relative_SQ)"' \
2098 '-DGIT_INFO_PATH="$(infodir_relative_SQ)"'
2099
2100version.sp version.s version.o: GIT-VERSION-FILE GIT-USER-AGENT
2101version.sp version.s version.o: EXTRA_CPPFLAGS = \
2102 '-DGIT_VERSION="$(GIT_VERSION)"' \
2103 '-DGIT_USER_AGENT=$(GIT_USER_AGENT_CQ_SQ)' \
2104 '-DGIT_BUILT_FROM_COMMIT="$(shell \
2105 GIT_CEILING_DIRECTORIES="$(CURDIR)/.." \
2106 git rev-parse -q --verify HEAD 2>/dev/null)"'
2107
2108$(BUILT_INS): git$X
2109 $(QUIET_BUILT_IN)$(RM) $@ && \
2110 ln $< $@ 2>/dev/null || \
2111 ln -s $< $@ 2>/dev/null || \
2112 cp $< $@
2113
2114command-list.h: generate-cmdlist.sh command-list.txt
2115
2116command-list.h: $(wildcard Documentation/git*.txt) Documentation/*config.txt Documentation/config/*.txt
2117 $(QUIET_GEN)$(SHELL_PATH) ./generate-cmdlist.sh command-list.txt >$@+ && mv $@+ $@
2118
2119SCRIPT_DEFINES = $(SHELL_PATH_SQ):$(DIFF_SQ):$(GIT_VERSION):\
2120 $(localedir_SQ):$(NO_CURL):$(USE_GETTEXT_SCHEME):$(SANE_TOOL_PATH_SQ):\
2121 $(gitwebdir_SQ):$(PERL_PATH_SQ):$(SANE_TEXT_GREP):$(PAGER_ENV):\
2122 $(perllibdir_SQ)
2123define cmd_munge_script
2124$(RM) $@ $@+ && \
2125sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
2126 -e 's|@SHELL_PATH@|$(SHELL_PATH_SQ)|' \
2127 -e 's|@@DIFF@@|$(DIFF_SQ)|' \
2128 -e 's|@@LOCALEDIR@@|$(localedir_SQ)|g' \
2129 -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
2130 -e 's/@@USE_GETTEXT_SCHEME@@/$(USE_GETTEXT_SCHEME)/g' \
2131 -e $(BROKEN_PATH_FIX) \
2132 -e 's|@@GITWEBDIR@@|$(gitwebdir_SQ)|g' \
2133 -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
2134 -e 's|@@SANE_TEXT_GREP@@|$(SANE_TEXT_GREP)|g' \
2135 -e 's|@@PAGER_ENV@@|$(PAGER_ENV_SQ)|g' \
2136 $@.sh >$@+
2137endef
2138
2139GIT-SCRIPT-DEFINES: FORCE
2140 @FLAGS='$(SCRIPT_DEFINES)'; \
2141 if test x"$$FLAGS" != x"`cat $@ 2>/dev/null`" ; then \
2142 echo >&2 " * new script parameters"; \
2143 echo "$$FLAGS" >$@; \
2144 fi
2145
2146
2147$(SCRIPT_SH_GEN) : % : %.sh GIT-SCRIPT-DEFINES
2148 $(QUIET_GEN)$(cmd_munge_script) && \
2149 chmod +x $@+ && \
2150 mv $@+ $@
2151
2152$(SCRIPT_LIB) : % : %.sh GIT-SCRIPT-DEFINES
2153 $(QUIET_GEN)$(cmd_munge_script) && \
2154 mv $@+ $@
2155
2156git.res: git.rc GIT-VERSION-FILE GIT-PREFIX
2157 $(QUIET_RC)$(RC) \
2158 $(join -DMAJOR= -DMINOR= -DMICRO= -DPATCHLEVEL=, $(wordlist 1, 4, \
2159 $(shell echo $(GIT_VERSION) 0 0 0 0 | tr '.a-zA-Z-' ' '))) \
2160 -DGIT_VERSION="\\\"$(GIT_VERSION)\\\"" -i $< -o $@
2161
2162# This makes sure we depend on the NO_PERL setting itself.
2163$(SCRIPT_PERL_GEN): GIT-BUILD-OPTIONS
2164
2165# Used for substitution in Perl modules. Disabled when using RUNTIME_PREFIX
2166# since the locale directory is injected.
2167perl_localedir_SQ = $(localedir_SQ)
2168
2169ifndef NO_PERL
2170PERL_HEADER_TEMPLATE = perl/header_templates/fixed_prefix.template.pl
2171PERL_DEFINES = $(PERL_PATH_SQ):$(PERLLIB_EXTRA_SQ):$(perllibdir_SQ)
2172
2173PERL_DEFINES := $(PERL_PATH_SQ) $(PERLLIB_EXTRA_SQ) $(perllibdir_SQ)
2174PERL_DEFINES += $(RUNTIME_PREFIX)
2175
2176# Support Perl runtime prefix. In this mode, a different header is installed
2177# into Perl scripts.
2178ifdef RUNTIME_PREFIX
2179
2180PERL_HEADER_TEMPLATE = perl/header_templates/runtime_prefix.template.pl
2181
2182# Don't export a fixed $(localedir) path; it will be resolved by the Perl header
2183# at runtime.
2184perl_localedir_SQ =
2185
2186endif
2187
2188PERL_DEFINES += $(gitexecdir) $(perllibdir) $(localedir)
2189
2190$(SCRIPT_PERL_GEN): % : %.perl GIT-PERL-DEFINES GIT-PERL-HEADER GIT-VERSION-FILE
2191 $(QUIET_GEN)$(RM) $@ $@+ && \
2192 sed -e '1{' \
2193 -e ' s|#!.*perl|#!$(PERL_PATH_SQ)|' \
2194 -e ' r GIT-PERL-HEADER' \
2195 -e ' G' \
2196 -e '}' \
2197 -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
2198 $< >$@+ && \
2199 chmod +x $@+ && \
2200 mv $@+ $@
2201
2202PERL_DEFINES := $(subst $(space),:,$(PERL_DEFINES))
2203GIT-PERL-DEFINES: FORCE
2204 @FLAGS='$(PERL_DEFINES)'; \
2205 if test x"$$FLAGS" != x"`cat $@ 2>/dev/null`" ; then \
2206 echo >&2 " * new perl-specific parameters"; \
2207 echo "$$FLAGS" >$@; \
2208 fi
2209
2210GIT-PERL-HEADER: $(PERL_HEADER_TEMPLATE) GIT-PERL-DEFINES Makefile
2211 $(QUIET_GEN)$(RM) $@ && \
2212 INSTLIBDIR='$(perllibdir_SQ)' && \
2213 INSTLIBDIR_EXTRA='$(PERLLIB_EXTRA_SQ)' && \
2214 INSTLIBDIR="$$INSTLIBDIR$${INSTLIBDIR_EXTRA:+:$$INSTLIBDIR_EXTRA}" && \
2215 sed -e 's=@@PATHSEP@@=$(pathsep)=g' \
2216 -e "s=@@INSTLIBDIR@@=$$INSTLIBDIR=g" \
2217 -e 's=@@PERLLIBDIR_REL@@=$(perllibdir_relative_SQ)=g' \
2218 -e 's=@@GITEXECDIR_REL@@=$(gitexecdir_relative_SQ)=g' \
2219 -e 's=@@LOCALEDIR_REL@@=$(localedir_relative_SQ)=g' \
2220 $< >$@+ && \
2221 mv $@+ $@
2222
2223.PHONY: perllibdir
2224perllibdir:
2225 @echo '$(perllibdir_SQ)'
2226
2227.PHONY: gitweb
2228gitweb:
2229 $(QUIET_SUBDIR0)gitweb $(QUIET_SUBDIR1) all
2230
2231git-instaweb: git-instaweb.sh GIT-SCRIPT-DEFINES
2232 $(QUIET_GEN)$(cmd_munge_script) && \
2233 chmod +x $@+ && \
2234 mv $@+ $@
2235else # NO_PERL
2236$(SCRIPT_PERL_GEN) git-instaweb: % : unimplemented.sh
2237 $(QUIET_GEN)$(RM) $@ $@+ && \
2238 sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
2239 -e 's|@@REASON@@|NO_PERL=$(NO_PERL)|g' \
2240 unimplemented.sh >$@+ && \
2241 chmod +x $@+ && \
2242 mv $@+ $@
2243endif # NO_PERL
2244
2245# This makes sure we depend on the NO_PYTHON setting itself.
2246$(SCRIPT_PYTHON_GEN): GIT-BUILD-OPTIONS
2247
2248ifndef NO_PYTHON
2249$(SCRIPT_PYTHON_GEN): GIT-CFLAGS GIT-PREFIX GIT-PYTHON-VARS
2250$(SCRIPT_PYTHON_GEN): % : %.py
2251 $(QUIET_GEN)$(RM) $@ $@+ && \
2252 sed -e '1s|#!.*python|#!$(PYTHON_PATH_SQ)|' \
2253 $< >$@+ && \
2254 chmod +x $@+ && \
2255 mv $@+ $@
2256else # NO_PYTHON
2257$(SCRIPT_PYTHON_GEN): % : unimplemented.sh
2258 $(QUIET_GEN)$(RM) $@ $@+ && \
2259 sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
2260 -e 's|@@REASON@@|NO_PYTHON=$(NO_PYTHON)|g' \
2261 unimplemented.sh >$@+ && \
2262 chmod +x $@+ && \
2263 mv $@+ $@
2264endif # NO_PYTHON
2265
2266CONFIGURE_RECIPE = $(RM) configure configure.ac+ && \
2267 sed -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
2268 configure.ac >configure.ac+ && \
2269 autoconf -o configure configure.ac+ && \
2270 $(RM) configure.ac+
2271
2272configure: configure.ac GIT-VERSION-FILE
2273 $(QUIET_GEN)$(CONFIGURE_RECIPE)
2274
2275ifdef AUTOCONFIGURED
2276# We avoid depending on 'configure' here, because it gets rebuilt
2277# every time GIT-VERSION-FILE is modified, only to update the embedded
2278# version number string, which config.status does not care about. We
2279# do want to recheck when the platform/environment detection logic
2280# changes, hence this depends on configure.ac.
2281config.status: configure.ac
2282 $(QUIET_GEN)$(CONFIGURE_RECIPE) && \
2283 if test -f config.status; then \
2284 ./config.status --recheck; \
2285 else \
2286 ./configure; \
2287 fi
2288reconfigure config.mak.autogen: config.status
2289 $(QUIET_GEN)./config.status
2290.PHONY: reconfigure # This is a convenience target.
2291endif
2292
2293XDIFF_OBJS += xdiff/xdiffi.o
2294XDIFF_OBJS += xdiff/xprepare.o
2295XDIFF_OBJS += xdiff/xutils.o
2296XDIFF_OBJS += xdiff/xemit.o
2297XDIFF_OBJS += xdiff/xmerge.o
2298XDIFF_OBJS += xdiff/xpatience.o
2299XDIFF_OBJS += xdiff/xhistogram.o
2300
2301VCSSVN_OBJS += vcs-svn/line_buffer.o
2302VCSSVN_OBJS += vcs-svn/sliding_window.o
2303VCSSVN_OBJS += vcs-svn/fast_export.o
2304VCSSVN_OBJS += vcs-svn/svndiff.o
2305VCSSVN_OBJS += vcs-svn/svndump.o
2306
2307TEST_OBJS := $(patsubst %$X,%.o,$(TEST_PROGRAMS)) $(patsubst %,t/helper/%,$(TEST_BUILTINS_OBJS))
2308OBJECTS := $(LIB_OBJS) $(BUILTIN_OBJS) $(PROGRAM_OBJS) $(TEST_OBJS) \
2309 $(XDIFF_OBJS) \
2310 $(VCSSVN_OBJS) \
2311 $(FUZZ_OBJS) \
2312 common-main.o \
2313 git.o
2314ifndef NO_CURL
2315 OBJECTS += http.o http-walker.o remote-curl.o
2316endif
2317
2318dep_files := $(foreach f,$(OBJECTS),$(dir $f).depend/$(notdir $f).d)
2319dep_dirs := $(addsuffix .depend,$(sort $(dir $(OBJECTS))))
2320
2321ifeq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
2322$(dep_dirs):
2323 @mkdir -p $@
2324
2325missing_dep_dirs := $(filter-out $(wildcard $(dep_dirs)),$(dep_dirs))
2326dep_file = $(dir $@).depend/$(notdir $@).d
2327dep_args = -MF $(dep_file) -MQ $@ -MMD -MP
2328endif
2329
2330ifneq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
2331dep_dirs =
2332missing_dep_dirs =
2333dep_args =
2334endif
2335
2336ASM_SRC := $(wildcard $(OBJECTS:o=S))
2337ASM_OBJ := $(ASM_SRC:S=o)
2338C_OBJ := $(filter-out $(ASM_OBJ),$(OBJECTS))
2339
2340.SUFFIXES:
2341
2342$(C_OBJ): %.o: %.c GIT-CFLAGS $(missing_dep_dirs)
2343 $(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
2344$(ASM_OBJ): %.o: %.S GIT-CFLAGS $(missing_dep_dirs)
2345 $(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
2346
2347%.s: %.c GIT-CFLAGS FORCE
2348 $(QUIET_CC)$(CC) -o $@ -S $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
2349
2350ifdef USE_COMPUTED_HEADER_DEPENDENCIES
2351# Take advantage of gcc's on-the-fly dependency generation
2352# See <http://gcc.gnu.org/gcc-3.0/features.html>.
2353dep_files_present := $(wildcard $(dep_files))
2354ifneq ($(dep_files_present),)
2355include $(dep_files_present)
2356endif
2357else
2358# Dependencies on header files, for platforms that do not support
2359# the gcc -MMD option.
2360#
2361# Dependencies on automatically generated headers such as command-list.h
2362# should _not_ be included here, since they are necessary even when
2363# building an object for the first time.
2364
2365$(OBJECTS): $(LIB_H)
2366endif
2367
2368exec-cmd.sp exec-cmd.s exec-cmd.o: GIT-PREFIX
2369exec-cmd.sp exec-cmd.s exec-cmd.o: EXTRA_CPPFLAGS = \
2370 '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' \
2371 '-DGIT_LOCALE_PATH="$(localedir_relative_SQ)"' \
2372 '-DBINDIR="$(bindir_relative_SQ)"' \
2373 '-DFALLBACK_RUNTIME_PREFIX="$(prefix_SQ)"'
2374
2375builtin/init-db.sp builtin/init-db.s builtin/init-db.o: GIT-PREFIX
2376builtin/init-db.sp builtin/init-db.s builtin/init-db.o: EXTRA_CPPFLAGS = \
2377 -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"'
2378
2379config.sp config.s config.o: GIT-PREFIX
2380config.sp config.s config.o: EXTRA_CPPFLAGS = \
2381 -DETC_GITCONFIG='"$(ETC_GITCONFIG_SQ)"'
2382
2383attr.sp attr.s attr.o: GIT-PREFIX
2384attr.sp attr.s attr.o: EXTRA_CPPFLAGS = \
2385 -DETC_GITATTRIBUTES='"$(ETC_GITATTRIBUTES_SQ)"'
2386
2387gettext.sp gettext.s gettext.o: GIT-PREFIX
2388gettext.sp gettext.s gettext.o: EXTRA_CPPFLAGS = \
2389 -DGIT_LOCALE_PATH='"$(localedir_relative_SQ)"'
2390
2391http-push.sp http.sp http-walker.sp remote-curl.sp imap-send.sp: SP_EXTRA_FLAGS += \
2392 -DCURL_DISABLE_TYPECHECK
2393
2394pack-revindex.sp: SP_EXTRA_FLAGS += -Wno-memcpy-max-count
2395
2396ifdef NO_EXPAT
2397http-walker.sp http-walker.s http-walker.o: EXTRA_CPPFLAGS = -DNO_EXPAT
2398endif
2399
2400ifdef NO_REGEX
2401compat/regex/regex.sp compat/regex/regex.o: EXTRA_CPPFLAGS = \
2402 -DGAWK -DNO_MBSUPPORT
2403endif
2404
2405ifdef USE_NED_ALLOCATOR
2406compat/nedmalloc/nedmalloc.sp compat/nedmalloc/nedmalloc.o: EXTRA_CPPFLAGS = \
2407 -DNDEBUG -DREPLACE_SYSTEM_ALLOCATOR
2408compat/nedmalloc/nedmalloc.sp: SP_EXTRA_FLAGS += -Wno-non-pointer-null
2409endif
2410
2411git-%$X: %.o GIT-LDFLAGS $(GITLIBS)
2412 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS)
2413
2414git-imap-send$X: imap-send.o $(IMAP_SEND_BUILDDEPS) GIT-LDFLAGS $(GITLIBS)
2415 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
2416 $(IMAP_SEND_LDFLAGS) $(LIBS)
2417
2418git-http-fetch$X: http.o http-walker.o http-fetch.o GIT-LDFLAGS $(GITLIBS)
2419 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
2420 $(CURL_LIBCURL) $(LIBS)
2421git-http-push$X: http.o http-push.o GIT-LDFLAGS $(GITLIBS)
2422 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
2423 $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) $(LIBS)
2424
2425git-remote-testsvn$X: remote-testsvn.o GIT-LDFLAGS $(GITLIBS) $(VCSSVN_LIB)
2426 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) \
2427 $(VCSSVN_LIB)
2428
2429$(REMOTE_CURL_ALIASES): $(REMOTE_CURL_PRIMARY)
2430 $(QUIET_LNCP)$(RM) $@ && \
2431 ln $< $@ 2>/dev/null || \
2432 ln -s $< $@ 2>/dev/null || \
2433 cp $< $@
2434
2435$(REMOTE_CURL_PRIMARY): remote-curl.o http.o http-walker.o GIT-LDFLAGS $(GITLIBS)
2436 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
2437 $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) $(LIBS)
2438
2439$(LIB_FILE): $(LIB_OBJS)
2440 $(QUIET_AR)$(RM) $@ && $(AR) $(ARFLAGS) $@ $^
2441
2442$(XDIFF_LIB): $(XDIFF_OBJS)
2443 $(QUIET_AR)$(RM) $@ && $(AR) $(ARFLAGS) $@ $^
2444
2445$(VCSSVN_LIB): $(VCSSVN_OBJS)
2446 $(QUIET_AR)$(RM) $@ && $(AR) $(ARFLAGS) $@ $^
2447
2448export DEFAULT_EDITOR DEFAULT_PAGER
2449
2450.PHONY: doc man man-perl html info pdf
2451doc: man-perl
2452 $(MAKE) -C Documentation all
2453
2454man: man-perl
2455 $(MAKE) -C Documentation man
2456
2457man-perl: perl/build/man/man3/Git.3pm
2458
2459html:
2460 $(MAKE) -C Documentation html
2461
2462info:
2463 $(MAKE) -C Documentation info
2464
2465pdf:
2466 $(MAKE) -C Documentation pdf
2467
2468XGETTEXT_FLAGS = \
2469 --force-po \
2470 --add-comments=TRANSLATORS: \
2471 --msgid-bugs-address="Git Mailing List <git@vger.kernel.org>" \
2472 --from-code=UTF-8
2473XGETTEXT_FLAGS_C = $(XGETTEXT_FLAGS) --language=C \
2474 --keyword=_ --keyword=N_ --keyword="Q_:1,2"
2475XGETTEXT_FLAGS_SH = $(XGETTEXT_FLAGS) --language=Shell \
2476 --keyword=gettextln --keyword=eval_gettextln
2477XGETTEXT_FLAGS_PERL = $(XGETTEXT_FLAGS) --language=Perl \
2478 --keyword=__ --keyword=N__ --keyword="__n:1,2"
2479LOCALIZED_C = $(C_OBJ:o=c) $(LIB_H) $(GENERATED_H)
2480LOCALIZED_SH = $(SCRIPT_SH)
2481LOCALIZED_SH += git-parse-remote.sh
2482LOCALIZED_SH += git-rebase--preserve-merges.sh
2483LOCALIZED_SH += git-sh-setup.sh
2484LOCALIZED_PERL = $(SCRIPT_PERL)
2485
2486ifdef XGETTEXT_INCLUDE_TESTS
2487LOCALIZED_C += t/t0200/test.c
2488LOCALIZED_SH += t/t0200/test.sh
2489LOCALIZED_PERL += t/t0200/test.perl
2490endif
2491
2492## Note that this is meant to be run only by the localization coordinator
2493## under a very controlled condition, i.e. (1) it is to be run in a
2494## Git repository (not a tarball extract), (2) any local modifications
2495## will be lost.
2496## Gettext tools cannot work with our own custom PRItime type, so
2497## we replace PRItime with PRIuMAX. We need to update this to
2498## PRIdMAX if we switch to a signed type later.
2499
2500po/git.pot: $(GENERATED_H) FORCE
2501 # All modifications will be reverted at the end, so we do not
2502 # want to have any local change.
2503 git diff --quiet HEAD && git diff --quiet --cached
2504
2505 @for s in $(LOCALIZED_C) $(LOCALIZED_SH) $(LOCALIZED_PERL); \
2506 do \
2507 sed -e 's|PRItime|PRIuMAX|g' <"$$s" >"$$s+" && \
2508 cat "$$s+" >"$$s" && rm "$$s+"; \
2509 done
2510
2511 $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ $(XGETTEXT_FLAGS_C) $(LOCALIZED_C)
2512 $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ --join-existing $(XGETTEXT_FLAGS_SH) \
2513 $(LOCALIZED_SH)
2514 $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ --join-existing $(XGETTEXT_FLAGS_PERL) \
2515 $(LOCALIZED_PERL)
2516
2517 # Reverting the munged source, leaving only the updated $@
2518 git reset --hard
2519 mv $@+ $@
2520
2521.PHONY: pot
2522pot: po/git.pot
2523
2524POFILES := $(wildcard po/*.po)
2525MOFILES := $(patsubst po/%.po,po/build/locale/%/LC_MESSAGES/git.mo,$(POFILES))
2526
2527ifndef NO_GETTEXT
2528all:: $(MOFILES)
2529endif
2530
2531po/build/locale/%/LC_MESSAGES/git.mo: po/%.po
2532 $(QUIET_MSGFMT)mkdir -p $(dir $@) && $(MSGFMT) -o $@ $<
2533
2534LIB_PERL := $(wildcard perl/Git.pm perl/Git/*.pm perl/Git/*/*.pm perl/Git/*/*/*.pm)
2535LIB_PERL_GEN := $(patsubst perl/%.pm,perl/build/lib/%.pm,$(LIB_PERL))
2536LIB_CPAN := $(wildcard perl/FromCPAN/*.pm perl/FromCPAN/*/*.pm)
2537LIB_CPAN_GEN := $(patsubst perl/%.pm,perl/build/lib/%.pm,$(LIB_CPAN))
2538
2539ifndef NO_PERL
2540all:: $(LIB_PERL_GEN)
2541ifndef NO_PERL_CPAN_FALLBACKS
2542all:: $(LIB_CPAN_GEN)
2543endif
2544NO_PERL_CPAN_FALLBACKS_SQ = $(subst ','\'',$(NO_PERL_CPAN_FALLBACKS))
2545endif
2546
2547perl/build/lib/%.pm: perl/%.pm
2548 $(QUIET_GEN)mkdir -p $(dir $@) && \
2549 sed -e 's|@@LOCALEDIR@@|$(perl_localedir_SQ)|g' \
2550 -e 's|@@NO_PERL_CPAN_FALLBACKS@@|$(NO_PERL_CPAN_FALLBACKS_SQ)|g' \
2551 < $< > $@
2552
2553perl/build/man/man3/Git.3pm: perl/Git.pm
2554 $(QUIET_GEN)mkdir -p $(dir $@) && \
2555 pod2man $< $@
2556
2557FIND_SOURCE_FILES = ( \
2558 git ls-files \
2559 '*.[hcS]' \
2560 '*.sh' \
2561 ':!*[tp][0-9][0-9][0-9][0-9]*' \
2562 ':!contrib' \
2563 2>/dev/null || \
2564 $(FIND) . \
2565 \( -name .git -type d -prune \) \
2566 -o \( -name '[tp][0-9][0-9][0-9][0-9]*' -prune \) \
2567 -o \( -name contrib -type d -prune \) \
2568 -o \( -name build -type d -prune \) \
2569 -o \( -name 'trash*' -type d -prune \) \
2570 -o \( -name '*.[hcS]' -type f -print \) \
2571 -o \( -name '*.sh' -type f -print \) \
2572 )
2573
2574$(ETAGS_TARGET): FORCE
2575 $(RM) $(ETAGS_TARGET)
2576 $(FIND_SOURCE_FILES) | xargs etags -a -o $(ETAGS_TARGET)
2577
2578tags: FORCE
2579 $(RM) tags
2580 $(FIND_SOURCE_FILES) | xargs ctags -a
2581
2582cscope:
2583 $(RM) cscope*
2584 $(FIND_SOURCE_FILES) | xargs cscope -b
2585
2586### Detect prefix changes
2587TRACK_PREFIX = $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ):\
2588 $(localedir_SQ)
2589
2590GIT-PREFIX: FORCE
2591 @FLAGS='$(TRACK_PREFIX)'; \
2592 if test x"$$FLAGS" != x"`cat GIT-PREFIX 2>/dev/null`" ; then \
2593 echo >&2 " * new prefix flags"; \
2594 echo "$$FLAGS" >GIT-PREFIX; \
2595 fi
2596
2597TRACK_CFLAGS = $(CC):$(subst ','\'',$(ALL_CFLAGS)):$(USE_GETTEXT_SCHEME)
2598
2599GIT-CFLAGS: FORCE
2600 @FLAGS='$(TRACK_CFLAGS)'; \
2601 if test x"$$FLAGS" != x"`cat GIT-CFLAGS 2>/dev/null`" ; then \
2602 echo >&2 " * new build flags"; \
2603 echo "$$FLAGS" >GIT-CFLAGS; \
2604 fi
2605
2606TRACK_LDFLAGS = $(subst ','\'',$(ALL_LDFLAGS))
2607
2608GIT-LDFLAGS: FORCE
2609 @FLAGS='$(TRACK_LDFLAGS)'; \
2610 if test x"$$FLAGS" != x"`cat GIT-LDFLAGS 2>/dev/null`" ; then \
2611 echo >&2 " * new link flags"; \
2612 echo "$$FLAGS" >GIT-LDFLAGS; \
2613 fi
2614
2615# We need to apply sq twice, once to protect from the shell
2616# that runs GIT-BUILD-OPTIONS, and then again to protect it
2617# and the first level quoting from the shell that runs "echo".
2618GIT-BUILD-OPTIONS: FORCE
2619 @echo SHELL_PATH=\''$(subst ','\'',$(SHELL_PATH_SQ))'\' >$@+
2620 @echo TEST_SHELL_PATH=\''$(subst ','\'',$(TEST_SHELL_PATH_SQ))'\' >>$@+
2621 @echo PERL_PATH=\''$(subst ','\'',$(PERL_PATH_SQ))'\' >>$@+
2622 @echo DIFF=\''$(subst ','\'',$(subst ','\'',$(DIFF)))'\' >>$@+
2623 @echo PYTHON_PATH=\''$(subst ','\'',$(PYTHON_PATH_SQ))'\' >>$@+
2624 @echo TAR=\''$(subst ','\'',$(subst ','\'',$(TAR)))'\' >>$@+
2625 @echo NO_CURL=\''$(subst ','\'',$(subst ','\'',$(NO_CURL)))'\' >>$@+
2626 @echo NO_EXPAT=\''$(subst ','\'',$(subst ','\'',$(NO_EXPAT)))'\' >>$@+
2627 @echo USE_LIBPCRE1=\''$(subst ','\'',$(subst ','\'',$(USE_LIBPCRE1)))'\' >>$@+
2628 @echo USE_LIBPCRE2=\''$(subst ','\'',$(subst ','\'',$(USE_LIBPCRE2)))'\' >>$@+
2629 @echo NO_LIBPCRE1_JIT=\''$(subst ','\'',$(subst ','\'',$(NO_LIBPCRE1_JIT)))'\' >>$@+
2630 @echo NO_PERL=\''$(subst ','\'',$(subst ','\'',$(NO_PERL)))'\' >>$@+
2631 @echo NO_PTHREADS=\''$(subst ','\'',$(subst ','\'',$(NO_PTHREADS)))'\' >>$@+
2632 @echo NO_PYTHON=\''$(subst ','\'',$(subst ','\'',$(NO_PYTHON)))'\' >>$@+
2633 @echo NO_UNIX_SOCKETS=\''$(subst ','\'',$(subst ','\'',$(NO_UNIX_SOCKETS)))'\' >>$@+
2634 @echo PAGER_ENV=\''$(subst ','\'',$(subst ','\'',$(PAGER_ENV)))'\' >>$@+
2635 @echo DC_SHA1=\''$(subst ','\'',$(subst ','\'',$(DC_SHA1)))'\' >>$@+
2636 @echo X=\'$(X)\' >>$@+
2637ifdef TEST_OUTPUT_DIRECTORY
2638 @echo TEST_OUTPUT_DIRECTORY=\''$(subst ','\'',$(subst ','\'',$(TEST_OUTPUT_DIRECTORY)))'\' >>$@+
2639endif
2640ifdef GIT_TEST_OPTS
2641 @echo GIT_TEST_OPTS=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_OPTS)))'\' >>$@+
2642endif
2643ifdef GIT_TEST_CMP
2644 @echo GIT_TEST_CMP=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_CMP)))'\' >>$@+
2645endif
2646ifdef GIT_TEST_CMP_USE_COPIED_CONTEXT
2647 @echo GIT_TEST_CMP_USE_COPIED_CONTEXT=YesPlease >>$@+
2648endif
2649 @echo NO_GETTEXT=\''$(subst ','\'',$(subst ','\'',$(NO_GETTEXT)))'\' >>$@+
2650ifdef GIT_PERF_REPEAT_COUNT
2651 @echo GIT_PERF_REPEAT_COUNT=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_REPEAT_COUNT)))'\' >>$@+
2652endif
2653ifdef GIT_PERF_REPO
2654 @echo GIT_PERF_REPO=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_REPO)))'\' >>$@+
2655endif
2656ifdef GIT_PERF_LARGE_REPO
2657 @echo GIT_PERF_LARGE_REPO=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_LARGE_REPO)))'\' >>$@+
2658endif
2659ifdef GIT_PERF_MAKE_OPTS
2660 @echo GIT_PERF_MAKE_OPTS=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_MAKE_OPTS)))'\' >>$@+
2661endif
2662ifdef GIT_PERF_MAKE_COMMAND
2663 @echo GIT_PERF_MAKE_COMMAND=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_MAKE_COMMAND)))'\' >>$@+
2664endif
2665ifdef GIT_INTEROP_MAKE_OPTS
2666 @echo GIT_INTEROP_MAKE_OPTS=\''$(subst ','\'',$(subst ','\'',$(GIT_INTEROP_MAKE_OPTS)))'\' >>$@+
2667endif
2668ifdef GIT_TEST_INDEX_VERSION
2669 @echo GIT_TEST_INDEX_VERSION=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_INDEX_VERSION)))'\' >>$@+
2670endif
2671 @if cmp $@+ $@ >/dev/null 2>&1; then $(RM) $@+; else mv $@+ $@; fi
2672
2673### Detect Python interpreter path changes
2674ifndef NO_PYTHON
2675TRACK_PYTHON = $(subst ','\'',-DPYTHON_PATH='$(PYTHON_PATH_SQ)')
2676
2677GIT-PYTHON-VARS: FORCE
2678 @VARS='$(TRACK_PYTHON)'; \
2679 if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \
2680 echo >&2 " * new Python interpreter location"; \
2681 echo "$$VARS" >$@; \
2682 fi
2683endif
2684
2685test_bindir_programs := $(patsubst %,bin-wrappers/%,$(BINDIR_PROGRAMS_NEED_X) $(BINDIR_PROGRAMS_NO_X) $(TEST_PROGRAMS_NEED_X))
2686
2687all:: $(TEST_PROGRAMS) $(test_bindir_programs)
2688all:: $(NO_INSTALL)
2689
2690bin-wrappers/%: wrap-for-bin.sh
2691 @mkdir -p bin-wrappers
2692 $(QUIET_GEN)sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
2693 -e 's|@@BUILD_DIR@@|$(shell pwd)|' \
2694 -e 's|@@PROG@@|$(patsubst test-%,t/helper/test-%,$(@F))|' < $< > $@ && \
2695 chmod +x $@
2696
2697# GNU make supports exporting all variables by "export" without parameters.
2698# However, the environment gets quite big, and some programs have problems
2699# with that.
2700
2701export NO_SVN_TESTS
2702export TEST_NO_MALLOC_CHECK
2703
2704### Testing rules
2705
2706test: all
2707 $(MAKE) -C t/ all
2708
2709perf: all
2710 $(MAKE) -C t/perf/ all
2711
2712.PHONY: test perf
2713
2714t/helper/test-line-buffer$X: $(VCSSVN_LIB)
2715
2716t/helper/test-svn-fe$X: $(VCSSVN_LIB)
2717
2718.PRECIOUS: $(TEST_OBJS)
2719
2720t/helper/test-tool$X: $(patsubst %,t/helper/%,$(TEST_BUILTINS_OBJS))
2721
2722t/helper/test-%$X: t/helper/test-%.o GIT-LDFLAGS $(GITLIBS)
2723 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(filter %.a,$^) $(LIBS)
2724
2725check-sha1:: t/helper/test-tool$X
2726 t/helper/test-sha1.sh
2727
2728SP_OBJ = $(patsubst %.o,%.sp,$(C_OBJ))
2729
2730$(SP_OBJ): %.sp: %.c GIT-CFLAGS FORCE
2731 $(QUIET_SP)cgcc -no-compile $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) \
2732 $(SPARSE_FLAGS) $(SP_EXTRA_FLAGS) $<
2733
2734.PHONY: sparse $(SP_OBJ)
2735sparse: $(SP_OBJ)
2736
2737GEN_HDRS := command-list.h unicode-width.h
2738EXCEPT_HDRS := $(GEN_HDRS) compat% xdiff%
2739CHK_HDRS = $(filter-out $(EXCEPT_HDRS),$(patsubst ./%,%,$(LIB_H)))
2740HCO = $(patsubst %.h,%.hco,$(CHK_HDRS))
2741
2742$(HCO): %.hco: %.h FORCE
2743 $(QUIET_HDR)$(CC) -include git-compat-util.h -I. -o /dev/null -c -xc $<
2744
2745.PHONY: hdr-check $(HCO)
2746hdr-check: $(HCO)
2747
2748.PHONY: style
2749style:
2750 git clang-format --style file --diff --extensions c,h
2751
2752check: command-list.h
2753 @if sparse; \
2754 then \
2755 echo >&2 "Use 'make sparse' instead"; \
2756 $(MAKE) --no-print-directory sparse; \
2757 else \
2758 echo >&2 "Did you mean 'make test'?"; \
2759 exit 1; \
2760 fi
2761
2762C_SOURCES = $(patsubst %.o,%.c,$(C_OBJ))
2763ifdef DC_SHA1_SUBMODULE
2764COCCI_SOURCES = $(filter-out sha1collisiondetection/%,$(C_SOURCES))
2765else
2766COCCI_SOURCES = $(filter-out sha1dc/%,$(C_SOURCES))
2767endif
2768
2769%.cocci.patch: %.cocci $(COCCI_SOURCES)
2770 @echo ' ' SPATCH $<; \
2771 ret=0; \
2772 for f in $(COCCI_SOURCES); do \
2773 $(SPATCH) --sp-file $< $$f $(SPATCH_FLAGS) || \
2774 { ret=$$?; break; }; \
2775 done >$@+ 2>$@.log; \
2776 if test $$ret != 0; \
2777 then \
2778 cat $@.log; \
2779 exit 1; \
2780 fi; \
2781 mv $@+ $@; \
2782 if test -s $@; \
2783 then \
2784 echo ' ' SPATCH result: $@; \
2785 fi
2786coccicheck: $(addsuffix .patch,$(filter-out %.pending.cocci,$(wildcard contrib/coccinelle/*.cocci)))
2787
2788# See contrib/coccinelle/README
2789coccicheck-pending: $(addsuffix .patch,$(wildcard contrib/coccinelle/*.pending.cocci))
2790
2791.PHONY: coccicheck coccicheck-pending
2792
2793### Installation rules
2794
2795ifneq ($(filter /%,$(firstword $(template_dir))),)
2796template_instdir = $(template_dir)
2797else
2798template_instdir = $(prefix)/$(template_dir)
2799endif
2800export template_instdir
2801
2802ifneq ($(filter /%,$(firstword $(gitexecdir))),)
2803gitexec_instdir = $(gitexecdir)
2804else
2805gitexec_instdir = $(prefix)/$(gitexecdir)
2806endif
2807gitexec_instdir_SQ = $(subst ','\'',$(gitexec_instdir))
2808export gitexec_instdir
2809
2810ifneq ($(filter /%,$(firstword $(mergetoolsdir))),)
2811mergetools_instdir = $(mergetoolsdir)
2812else
2813mergetools_instdir = $(prefix)/$(mergetoolsdir)
2814endif
2815mergetools_instdir_SQ = $(subst ','\'',$(mergetools_instdir))
2816
2817install_bindir_programs := $(patsubst %,%$X,$(BINDIR_PROGRAMS_NEED_X)) $(BINDIR_PROGRAMS_NO_X)
2818
2819.PHONY: profile-install profile-fast-install
2820profile-install: profile
2821 $(MAKE) install
2822
2823profile-fast-install: profile-fast
2824 $(MAKE) install
2825
2826install: all
2827 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)'
2828 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2829 $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2830 $(INSTALL) -m 644 $(SCRIPT_LIB) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2831 $(INSTALL) $(install_bindir_programs) '$(DESTDIR_SQ)$(bindir_SQ)'
2832 $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install
2833 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(mergetools_instdir_SQ)'
2834 $(INSTALL) -m 644 mergetools/* '$(DESTDIR_SQ)$(mergetools_instdir_SQ)'
2835ifndef NO_GETTEXT
2836 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(localedir_SQ)'
2837 (cd po/build/locale && $(TAR) cf - .) | \
2838 (cd '$(DESTDIR_SQ)$(localedir_SQ)' && umask 022 && $(TAR) xof -)
2839endif
2840ifndef NO_PERL
2841 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(perllibdir_SQ)'
2842 (cd perl/build/lib && $(TAR) cf - .) | \
2843 (cd '$(DESTDIR_SQ)$(perllibdir_SQ)' && umask 022 && $(TAR) xof -)
2844 $(MAKE) -C gitweb install
2845endif
2846ifndef NO_TCLTK
2847 $(MAKE) -C gitk-git install
2848 $(MAKE) -C git-gui gitexecdir='$(gitexec_instdir_SQ)' install
2849endif
2850ifneq (,$X)
2851 $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), test '$(DESTDIR_SQ)$(gitexec_instdir_SQ)/$p' -ef '$(DESTDIR_SQ)$(gitexec_instdir_SQ)/$p$X' || $(RM) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)/$p';)
2852endif
2853
2854 bindir=$$(cd '$(DESTDIR_SQ)$(bindir_SQ)' && pwd) && \
2855 execdir=$$(cd '$(DESTDIR_SQ)$(gitexec_instdir_SQ)' && pwd) && \
2856 destdir_from_execdir_SQ=$$(echo '$(gitexecdir_relative_SQ)' | sed -e 's|[^/][^/]*|..|g') && \
2857 { test "$$bindir/" = "$$execdir/" || \
2858 for p in git$X $(filter $(install_bindir_programs),$(ALL_PROGRAMS)); do \
2859 $(RM) "$$execdir/$$p" && \
2860 test -n "$(INSTALL_SYMLINKS)" && \
2861 ln -s "$$destdir_from_execdir_SQ/$(bindir_relative_SQ)/$$p" "$$execdir/$$p" || \
2862 { test -z "$(NO_INSTALL_HARDLINKS)$(NO_CROSS_DIRECTORY_HARDLINKS)" && \
2863 ln "$$bindir/$$p" "$$execdir/$$p" 2>/dev/null || \
2864 cp "$$bindir/$$p" "$$execdir/$$p" || exit; } \
2865 done; \
2866 } && \
2867 for p in $(filter $(install_bindir_programs),$(BUILT_INS)); do \
2868 $(RM) "$$bindir/$$p" && \
2869 test -n "$(INSTALL_SYMLINKS)" && \
2870 ln -s "git$X" "$$bindir/$$p" || \
2871 { test -z "$(NO_INSTALL_HARDLINKS)" && \
2872 ln "$$bindir/git$X" "$$bindir/$$p" 2>/dev/null || \
2873 ln -s "git$X" "$$bindir/$$p" 2>/dev/null || \
2874 cp "$$bindir/git$X" "$$bindir/$$p" || exit; } \
2875 done && \
2876 for p in $(BUILT_INS); do \
2877 $(RM) "$$execdir/$$p" && \
2878 test -n "$(INSTALL_SYMLINKS)" && \
2879 ln -s "$$destdir_from_execdir_SQ/$(bindir_relative_SQ)/git$X" "$$execdir/$$p" || \
2880 { test -z "$(NO_INSTALL_HARDLINKS)" && \
2881 ln "$$execdir/git$X" "$$execdir/$$p" 2>/dev/null || \
2882 ln -s "git$X" "$$execdir/$$p" 2>/dev/null || \
2883 cp "$$execdir/git$X" "$$execdir/$$p" || exit; } \
2884 done && \
2885 remote_curl_aliases="$(REMOTE_CURL_ALIASES)" && \
2886 for p in $$remote_curl_aliases; do \
2887 $(RM) "$$execdir/$$p" && \
2888 test -n "$(INSTALL_SYMLINKS)" && \
2889 ln -s "git-remote-http$X" "$$execdir/$$p" || \
2890 { test -z "$(NO_INSTALL_HARDLINKS)" && \
2891 ln "$$execdir/git-remote-http$X" "$$execdir/$$p" 2>/dev/null || \
2892 ln -s "git-remote-http$X" "$$execdir/$$p" 2>/dev/null || \
2893 cp "$$execdir/git-remote-http$X" "$$execdir/$$p" || exit; } \
2894 done && \
2895 ./check_bindir "z$$bindir" "z$$execdir" "$$bindir/git-add$X"
2896
2897.PHONY: install-gitweb install-doc install-man install-man-perl install-html install-info install-pdf
2898.PHONY: quick-install-doc quick-install-man quick-install-html
2899install-gitweb:
2900 $(MAKE) -C gitweb install
2901
2902install-doc: install-man-perl
2903 $(MAKE) -C Documentation install
2904
2905install-man: install-man-perl
2906 $(MAKE) -C Documentation install-man
2907
2908install-man-perl: man-perl
2909 $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(mandir_SQ)/man3'
2910 (cd perl/build/man/man3 && $(TAR) cf - .) | \
2911 (cd '$(DESTDIR_SQ)$(mandir_SQ)/man3' && umask 022 && $(TAR) xof -)
2912
2913install-html:
2914 $(MAKE) -C Documentation install-html
2915
2916install-info:
2917 $(MAKE) -C Documentation install-info
2918
2919install-pdf:
2920 $(MAKE) -C Documentation install-pdf
2921
2922quick-install-doc:
2923 $(MAKE) -C Documentation quick-install
2924
2925quick-install-man:
2926 $(MAKE) -C Documentation quick-install-man
2927
2928quick-install-html:
2929 $(MAKE) -C Documentation quick-install-html
2930
2931
2932
2933### Maintainer's dist rules
2934
2935GIT_TARNAME = git-$(GIT_VERSION)
2936dist: git-archive$(X) configure
2937 ./git-archive --format=tar \
2938 --prefix=$(GIT_TARNAME)/ HEAD^{tree} > $(GIT_TARNAME).tar
2939 @mkdir -p $(GIT_TARNAME)
2940 @cp configure $(GIT_TARNAME)
2941 @echo $(GIT_VERSION) > $(GIT_TARNAME)/version
2942 @$(MAKE) -C git-gui TARDIR=../$(GIT_TARNAME)/git-gui dist-version
2943 $(TAR) rf $(GIT_TARNAME).tar \
2944 $(GIT_TARNAME)/configure \
2945 $(GIT_TARNAME)/version \
2946 $(GIT_TARNAME)/git-gui/version
2947ifdef DC_SHA1_SUBMODULE
2948 @mkdir -p $(GIT_TARNAME)/sha1collisiondetection/lib
2949 @cp sha1collisiondetection/LICENSE.txt \
2950 $(GIT_TARNAME)/sha1collisiondetection/
2951 @cp sha1collisiondetection/LICENSE.txt \
2952 $(GIT_TARNAME)/sha1collisiondetection/
2953 @cp sha1collisiondetection/lib/sha1.[ch] \
2954 $(GIT_TARNAME)/sha1collisiondetection/lib/
2955 @cp sha1collisiondetection/lib/ubc_check.[ch] \
2956 $(GIT_TARNAME)/sha1collisiondetection/lib/
2957 $(TAR) rf $(GIT_TARNAME).tar \
2958 $(GIT_TARNAME)/sha1collisiondetection/LICENSE.txt \
2959 $(GIT_TARNAME)/sha1collisiondetection/lib/sha1.[ch] \
2960 $(GIT_TARNAME)/sha1collisiondetection/lib/ubc_check.[ch]
2961endif
2962 @$(RM) -r $(GIT_TARNAME)
2963 gzip -f -9 $(GIT_TARNAME).tar
2964
2965rpm::
2966 @echo >&2 "Use distro packaged sources to run rpmbuild"
2967 @false
2968.PHONY: rpm
2969
2970artifacts-tar:: $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS) $(OTHER_PROGRAMS) \
2971 GIT-BUILD-OPTIONS $(TEST_PROGRAMS) $(test_bindir_programs) \
2972 $(NO_INSTALL) $(MOFILES)
2973 $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1) \
2974 SHELL_PATH='$(SHELL_PATH_SQ)' PERL_PATH='$(PERL_PATH_SQ)'
2975 test -n "$(ARTIFACTS_DIRECTORY)"
2976 mkdir -p "$(ARTIFACTS_DIRECTORY)"
2977 $(TAR) czf "$(ARTIFACTS_DIRECTORY)/artifacts.tar.gz" $^ templates/blt/
2978.PHONY: artifacts-tar
2979
2980htmldocs = git-htmldocs-$(GIT_VERSION)
2981manpages = git-manpages-$(GIT_VERSION)
2982.PHONY: dist-doc distclean
2983dist-doc:
2984 $(RM) -r .doc-tmp-dir
2985 mkdir .doc-tmp-dir
2986 $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc
2987 cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar .
2988 gzip -n -9 -f $(htmldocs).tar
2989 :
2990 $(RM) -r .doc-tmp-dir
2991 mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7
2992 $(MAKE) -C Documentation DESTDIR=./ \
2993 man1dir=../.doc-tmp-dir/man1 \
2994 man5dir=../.doc-tmp-dir/man5 \
2995 man7dir=../.doc-tmp-dir/man7 \
2996 install
2997 cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar .
2998 gzip -n -9 -f $(manpages).tar
2999 $(RM) -r .doc-tmp-dir
3000
3001### Cleaning rules
3002
3003distclean: clean
3004 $(RM) configure
3005 $(RM) config.log config.status config.cache
3006 $(RM) config.mak.autogen config.mak.append
3007 $(RM) -r autom4te.cache
3008
3009profile-clean:
3010 $(RM) $(addsuffix *.gcda,$(addprefix $(PROFILE_DIR)/, $(object_dirs)))
3011 $(RM) $(addsuffix *.gcno,$(addprefix $(PROFILE_DIR)/, $(object_dirs)))
3012
3013cocciclean:
3014 $(RM) contrib/coccinelle/*.cocci.patch*
3015
3016clean: profile-clean coverage-clean cocciclean
3017 $(RM) *.res
3018 $(RM) $(OBJECTS)
3019 $(RM) $(LIB_FILE) $(XDIFF_LIB) $(VCSSVN_LIB)
3020 $(RM) $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS) git$X
3021 $(RM) $(TEST_PROGRAMS) $(NO_INSTALL)
3022 $(RM) $(FUZZ_PROGRAMS)
3023 $(RM) -r bin-wrappers $(dep_dirs)
3024 $(RM) -r po/build/
3025 $(RM) *.pyc *.pyo */*.pyc */*.pyo command-list.h $(ETAGS_TARGET) tags cscope*
3026 $(RM) -r $(GIT_TARNAME) .doc-tmp-dir
3027 $(RM) $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz
3028 $(RM) $(htmldocs).tar.gz $(manpages).tar.gz
3029 $(MAKE) -C Documentation/ clean
3030ifndef NO_PERL
3031 $(MAKE) -C gitweb clean
3032 $(RM) -r perl/build/
3033endif
3034 $(MAKE) -C templates/ clean
3035 $(MAKE) -C t/ clean
3036ifndef NO_TCLTK
3037 $(MAKE) -C gitk-git clean
3038 $(MAKE) -C git-gui clean
3039endif
3040 $(RM) GIT-VERSION-FILE GIT-CFLAGS GIT-LDFLAGS GIT-BUILD-OPTIONS
3041 $(RM) GIT-USER-AGENT GIT-PREFIX
3042 $(RM) GIT-SCRIPT-DEFINES GIT-PERL-DEFINES GIT-PERL-HEADER GIT-PYTHON-VARS
3043
3044.PHONY: all install profile-clean cocciclean clean strip
3045.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
3046.PHONY: FORCE cscope
3047
3048### Check documentation
3049#
3050ALL_COMMANDS = $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS)
3051ALL_COMMANDS += git
3052ALL_COMMANDS += gitk
3053ALL_COMMANDS += gitweb
3054ALL_COMMANDS += git-gui git-citool
3055
3056.PHONY: check-docs
3057check-docs::
3058 $(MAKE) -C Documentation lint-docs
3059 @(for v in $(ALL_COMMANDS); \
3060 do \
3061 case "$$v" in \
3062 git-merge-octopus | git-merge-ours | git-merge-recursive | \
3063 git-merge-resolve | git-merge-subtree | \
3064 git-fsck-objects | git-init-db | \
3065 git-remote-* | git-stage | \
3066 git-?*--?* ) continue ;; \
3067 esac ; \
3068 test -f "Documentation/$$v.txt" || \
3069 echo "no doc: $$v"; \
3070 sed -e '1,/^### command list/d' -e '/^#/d' command-list.txt | \
3071 grep -q "^$$v[ ]" || \
3072 case "$$v" in \
3073 git) ;; \
3074 *) echo "no link: $$v";; \
3075 esac ; \
3076 done; \
3077 ( \
3078 sed -e '1,/^### command list/d' \
3079 -e '/^#/d' \
3080 -e 's/[ ].*//' \
3081 -e 's/^/listed /' command-list.txt; \
3082 $(MAKE) -C Documentation print-man1 | \
3083 grep '\.txt$$' | \
3084 sed -e 's|Documentation/|documented |' \
3085 -e 's/\.txt//'; \
3086 ) | while read how cmd; \
3087 do \
3088 case " $(ALL_COMMANDS) " in \
3089 *" $$cmd "*) ;; \
3090 *) echo "removed but $$how: $$cmd" ;; \
3091 esac; \
3092 done ) | sort
3093
3094### Make sure built-ins do not have dups and listed in git.c
3095#
3096check-builtins::
3097 ./check-builtins.sh
3098
3099### Test suite coverage testing
3100#
3101.PHONY: coverage coverage-clean coverage-compile coverage-test coverage-report
3102.PHONY: coverage-untested-functions cover_db cover_db_html
3103.PHONY: coverage-clean-results
3104
3105coverage:
3106 $(MAKE) coverage-test
3107 $(MAKE) coverage-untested-functions
3108
3109object_dirs := $(sort $(dir $(OBJECTS)))
3110coverage-clean-results:
3111 $(RM) $(addsuffix *.gcov,$(object_dirs))
3112 $(RM) $(addsuffix *.gcda,$(object_dirs))
3113 $(RM) coverage-untested-functions
3114 $(RM) -r cover_db/
3115 $(RM) -r cover_db_html/
3116
3117coverage-clean: coverage-clean-results
3118 $(RM) $(addsuffix *.gcno,$(object_dirs))
3119
3120COVERAGE_CFLAGS = $(CFLAGS) -O0 -ftest-coverage -fprofile-arcs
3121COVERAGE_LDFLAGS = $(CFLAGS) -O0 -lgcov
3122GCOVFLAGS = --preserve-paths --branch-probabilities --all-blocks
3123
3124coverage-compile:
3125 $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" all
3126
3127coverage-test: coverage-clean-results coverage-compile
3128 $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" \
3129 DEFAULT_TEST_TARGET=test -j1 test
3130
3131coverage-prove: coverage-clean-results coverage-compile
3132 $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" \
3133 DEFAULT_TEST_TARGET=prove GIT_PROVE_OPTS="$(GIT_PROVE_OPTS) -j1" \
3134 -j1 test
3135
3136coverage-report:
3137 $(QUIET_GCOV)for dir in $(object_dirs); do \
3138 $(GCOV) $(GCOVFLAGS) --object-directory=$$dir $$dir*.c || exit; \
3139 done
3140
3141coverage-untested-functions: coverage-report
3142 grep '^function.*called 0 ' *.c.gcov \
3143 | sed -e 's/\([^:]*\)\.gcov: *function \([^ ]*\) called.*/\1: \2/' \
3144 > coverage-untested-functions
3145
3146cover_db: coverage-report
3147 gcov2perl -db cover_db *.gcov
3148
3149cover_db_html: cover_db
3150 cover -report html -outputdir cover_db_html cover_db
3151
3152
3153### Fuzz testing
3154#
3155# Building fuzz targets generally requires a special set of compiler flags that
3156# are not necessarily appropriate for general builds, and that vary greatly
3157# depending on the compiler version used.
3158#
3159# An example command to build against libFuzzer from LLVM 4.0.0:
3160#
3161# make CC=clang CXX=clang++ \
3162# CFLAGS="-fsanitize-coverage=trace-pc-guard -fsanitize=address" \
3163# LIB_FUZZING_ENGINE=/usr/lib/llvm-4.0/lib/libFuzzer.a \
3164# fuzz-all
3165#
3166FUZZ_CXXFLAGS ?= $(CFLAGS)
3167
3168.PHONY: fuzz-all
3169
3170$(FUZZ_PROGRAMS): all
3171 $(QUIET_LINK)$(CXX) $(FUZZ_CXXFLAGS) $(LIB_OBJS) $(BUILTIN_OBJS) \
3172 $(XDIFF_OBJS) $(EXTLIBS) git.o $@.o $(LIB_FUZZING_ENGINE) -o $@
3173
3174fuzz-all: $(FUZZ_PROGRAMS)