Makefileon commit Merge branch 'nd/ls-tree-pathspec' (5700772)
   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.
  23#
  24# Define NO_OPENSSL environment variable if you do not have OpenSSL.
  25# This also implies BLK_SHA1.
  26#
  27# Define USE_LIBPCRE if you have and want to use libpcre. git-grep will be
  28# able to use Perl-compatible regular expressions.
  29#
  30# Define LIBPCREDIR=/foo/bar if your libpcre header and library files are in
  31# /foo/bar/include and /foo/bar/lib directories.
  32#
  33# Define HAVE_ALLOCA_H if you have working alloca(3) defined in that header.
  34#
  35# Define NO_CURL if you do not have libcurl installed.  git-http-fetch and
  36# git-http-push are not built, and you cannot use http:// and https://
  37# transports (neither smart nor dumb).
  38#
  39# Define CURLDIR=/foo/bar if your curl header and library files are in
  40# /foo/bar/include and /foo/bar/lib directories.
  41#
  42# Define NO_EXPAT if you do not have expat installed.  git-http-push is
  43# not built, and you cannot push using http:// and https:// transports (dumb).
  44#
  45# Define EXPATDIR=/foo/bar if your expat header and library files are in
  46# /foo/bar/include and /foo/bar/lib directories.
  47#
  48# Define EXPAT_NEEDS_XMLPARSE_H if you have an old version of expat (e.g.,
  49# 1.1 or 1.2) that provides xmlparse.h instead of expat.h.
  50#
  51# Define NO_GETTEXT if you don't want Git output to be translated.
  52# A translated Git requires GNU libintl or another gettext implementation,
  53# plus libintl-perl at runtime.
  54#
  55# Define USE_GETTEXT_SCHEME and set it to 'fallthrough', if you don't trust
  56# the installed gettext translation of the shell scripts output.
  57#
  58# Define HAVE_LIBCHARSET_H if you haven't set NO_GETTEXT and you can't
  59# trust the langinfo.h's nl_langinfo(CODESET) function to return the
  60# current character set. GNU and Solaris have a nl_langinfo(CODESET),
  61# FreeBSD can use either, but MinGW and some others need to use
  62# libcharset.h's locale_charset() instead.
  63#
  64# Define CHARSET_LIB to the library you need to link with in order to
  65# use locale_charset() function.  On some platforms this needs to set to
  66# -lcharset, on others to -liconv .
  67#
  68# Define LIBC_CONTAINS_LIBINTL if your gettext implementation doesn't
  69# need -lintl when linking.
  70#
  71# Define NO_MSGFMT_EXTENDED_OPTIONS if your implementation of msgfmt
  72# doesn't support GNU extensions like --check and --statistics
  73#
  74# Define HAVE_PATHS_H if you have paths.h and want to use the default PATH
  75# it specifies.
  76#
  77# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
  78#
  79# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
  80# d_type in struct dirent (Cygwin 1.5, fixed in Cygwin 1.7).
  81#
  82# Define HAVE_STRINGS_H if you have strings.h and need it for strcasecmp.
  83#
  84# Define NO_STRCASESTR if you don't have strcasestr.
  85#
  86# Define NO_MEMMEM if you don't have memmem.
  87#
  88# Define NO_GETPAGESIZE if you don't have getpagesize.
  89#
  90# Define NO_STRLCPY if you don't have strlcpy.
  91#
  92# Define NO_STRTOUMAX if you don't have both strtoimax and strtoumax in the
  93# C library. If your compiler also does not support long long or does not have
  94# strtoull, define NO_STRTOULL.
  95#
  96# Define NO_SETENV if you don't have setenv in the C library.
  97#
  98# Define NO_UNSETENV if you don't have unsetenv in the C library.
  99#
 100# Define NO_MKDTEMP if you don't have mkdtemp in the C library.
 101#
 102# Define MKDIR_WO_TRAILING_SLASH if your mkdir() can't deal with trailing slash.
 103#
 104# Define NO_MKSTEMPS if you don't have mkstemps in the C library.
 105#
 106# Define NO_GECOS_IN_PWENT if you don't have pw_gecos in struct passwd
 107# in the C library.
 108#
 109# Define NO_LIBGEN_H if you don't have libgen.h.
 110#
 111# Define NEEDS_LIBGEN if your libgen needs -lgen when linking
 112#
 113# Define NO_SYS_SELECT_H if you don't have sys/select.h.
 114#
 115# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
 116# Enable it on Windows.  By default, symrefs are still used.
 117#
 118# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
 119# tests.  These tests take up a significant amount of the total test time
 120# but are not needed unless you plan to talk to SVN repos.
 121#
 122# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
 123# installed in /sw, but don't want GIT to link against any libraries
 124# installed there.  If defined you may specify your own (or Fink's)
 125# include directories and library directories by defining CFLAGS
 126# and LDFLAGS appropriately.
 127#
 128# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
 129# have DarwinPorts installed in /opt/local, but don't want GIT to
 130# link against any libraries installed there.  If defined you may
 131# specify your own (or DarwinPort's) include directories and
 132# library directories by defining CFLAGS and LDFLAGS appropriately.
 133#
 134# Define NO_APPLE_COMMON_CRYPTO if you are building on Darwin/Mac OS X
 135# and do not want to use Apple's CommonCrypto library.  This allows you
 136# to provide your own OpenSSL library, for example from MacPorts.
 137#
 138# Define BLK_SHA1 environment variable to make use of the bundled
 139# optimized C SHA1 routine.
 140#
 141# Define PPC_SHA1 environment variable when running make to make use of
 142# a bundled SHA1 routine optimized for PowerPC.
 143#
 144# Define NEEDS_CRYPTO_WITH_SSL if you need -lcrypto when using -lssl (Darwin).
 145#
 146# Define NEEDS_SSL_WITH_CRYPTO if you need -lssl when using -lcrypto (Darwin).
 147#
 148# Define NEEDS_SSL_WITH_CURL if you need -lssl with -lcurl (Minix).
 149#
 150# Define NEEDS_IDN_WITH_CURL if you need -lidn when using -lcurl (Minix).
 151#
 152# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin).
 153#
 154# Define NEEDS_LIBINTL_BEFORE_LIBICONV if you need libintl before libiconv.
 155#
 156# Define NO_INTPTR_T if you don't have intptr_t or uintptr_t.
 157#
 158# Define NO_UINTMAX_T if you don't have uintmax_t.
 159#
 160# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
 161# Patrick Mauritz).
 162#
 163# Define NEEDS_RESOLV if linking with -lnsl and/or -lsocket is not enough.
 164# Notably on Solaris hstrerror resides in libresolv and on Solaris 7
 165# inet_ntop and inet_pton additionally reside there.
 166#
 167# Define NO_MMAP if you want to avoid mmap.
 168#
 169# Define NO_SYS_POLL_H if you don't have sys/poll.h.
 170#
 171# Define NO_POLL if you do not have or don't want to use poll().
 172# This also implies NO_SYS_POLL_H.
 173#
 174# Define NEEDS_SYS_PARAM_H if you need to include sys/param.h to compile,
 175# *PLEASE* REPORT to git@vger.kernel.org if your platform needs this;
 176# we want to know more about the issue.
 177#
 178# Define NO_PTHREADS if you do not have or do not want to use Pthreads.
 179#
 180# Define NO_PREAD if you have a problem with pread() system call (e.g.
 181# cygwin1.dll before v1.5.22).
 182#
 183# Define NO_SETITIMER if you don't have setitimer()
 184#
 185# Define NO_STRUCT_ITIMERVAL if you don't have struct itimerval
 186# This also implies NO_SETITIMER
 187#
 188# Define NO_FAST_WORKING_DIRECTORY if accessing objects in pack files is
 189# generally faster on your platform than accessing the working directory.
 190#
 191# Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support
 192# the executable mode bit, but doesn't really do so.
 193#
 194# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
 195#
 196# Define NO_UNIX_SOCKETS if your system does not offer unix sockets.
 197#
 198# Define NO_SOCKADDR_STORAGE if your platform does not have struct
 199# sockaddr_storage.
 200#
 201# Define NO_ICONV if your libc does not properly support iconv.
 202#
 203# Define OLD_ICONV if your library has an old iconv(), where the second
 204# (input buffer pointer) parameter is declared with type (const char **).
 205#
 206# Define NO_DEFLATE_BOUND if your zlib does not have deflateBound.
 207#
 208# Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib"
 209# that tells runtime paths to dynamic libraries;
 210# "-Wl,-rpath=/path/lib" is used instead.
 211#
 212# Define NO_NORETURN if using buggy versions of gcc 4.6+ and profile feedback,
 213# as the compiler can crash (http://gcc.gnu.org/bugzilla/show_bug.cgi?id=49299)
 214#
 215# Define USE_NSEC below if you want git to care about sub-second file mtimes
 216# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
 217# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
 218# randomly break unless your underlying filesystem supports those sub-second
 219# times (my ext3 doesn't).
 220#
 221# Define USE_ST_TIMESPEC if your "struct stat" uses "st_ctimespec" instead of
 222# "st_ctim"
 223#
 224# Define NO_NSEC if your "struct stat" does not have "st_ctim.tv_nsec"
 225# available.  This automatically turns USE_NSEC off.
 226#
 227# Define USE_STDEV below if you want git to care about the underlying device
 228# change being considered an inode change from the update-index perspective.
 229#
 230# Define NO_ST_BLOCKS_IN_STRUCT_STAT if your platform does not have st_blocks
 231# field that counts the on-disk footprint in 512-byte blocks.
 232#
 233# Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72
 234# (not v1.73 or v1.71).
 235#
 236# Define ASCIIDOC_ROFF if your DocBook XSL does not escape raw roff directives
 237# (versions 1.68.1 through v1.72).
 238#
 239# Define GNU_ROFF if your target system uses GNU groff.  This forces
 240# apostrophes to be ASCII so that cut&pasting examples to the shell
 241# will work.
 242#
 243# Define PERL_PATH to the path of your Perl binary (usually /usr/bin/perl).
 244#
 245# Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's
 246# MakeMaker (e.g. using ActiveState under Cygwin).
 247#
 248# Define NO_PERL if you do not want Perl scripts or libraries at all.
 249#
 250# Define PYTHON_PATH to the path of your Python binary (often /usr/bin/python
 251# but /usr/bin/python2.7 on some platforms).
 252#
 253# Define NO_PYTHON if you do not want Python scripts or libraries at all.
 254#
 255# Define NO_TCLTK if you do not want Tcl/Tk GUI.
 256#
 257# The TCL_PATH variable governs the location of the Tcl interpreter
 258# used to optimize git-gui for your system.  Only used if NO_TCLTK
 259# is not set.  Defaults to the bare 'tclsh'.
 260#
 261# The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter.
 262# If not set it defaults to the bare 'wish'. If it is set to the empty
 263# string then NO_TCLTK will be forced (this is used by configure script).
 264#
 265# Define INTERNAL_QSORT to use Git's implementation of qsort(), which
 266# is a simplified version of the merge sort used in glibc. This is
 267# recommended if Git triggers O(n^2) behavior in your platform's qsort().
 268#
 269# Define UNRELIABLE_FSTAT if your system's fstat does not return the same
 270# information on a not yet closed file that lstat would return for the same
 271# file after it was closed.
 272#
 273# Define OBJECT_CREATION_USES_RENAMES if your operating systems has problems
 274# when hardlinking a file to another name and unlinking the original file right
 275# away (some NTFS drivers seem to zero the contents in that scenario).
 276#
 277# Define NO_CROSS_DIRECTORY_HARDLINKS if you plan to distribute the installed
 278# programs as a tar, where bin/ and libexec/ might be on different file systems.
 279#
 280# Define NO_INSTALL_HARDLINKS if you prefer to use either symbolic links or
 281# copies to install built-in git commands e.g. git-cat-file.
 282#
 283# Define USE_NED_ALLOCATOR if you want to replace the platforms default
 284# memory allocators with the nedmalloc allocator written by Niall Douglas.
 285#
 286# Define NO_REGEX if you have no or inferior regex support in your C library.
 287#
 288# Define HAVE_DEV_TTY if your system can open /dev/tty to interact with the
 289# user.
 290#
 291# Define GETTEXT_POISON if you are debugging the choice of strings marked
 292# for translation.  In a GETTEXT_POISON build, you can turn all strings marked
 293# for translation into gibberish by setting the GIT_GETTEXT_POISON variable
 294# (to any value) in your environment.
 295#
 296# Define JSMIN to point to JavaScript minifier that functions as
 297# a filter to have gitweb.js minified.
 298#
 299# Define CSSMIN to point to a CSS minifier in order to generate a minified
 300# version of gitweb.css
 301#
 302# Define DEFAULT_PAGER to a sensible pager command (defaults to "less") if
 303# you want to use something different.  The value will be interpreted by the
 304# shell at runtime when it is used.
 305#
 306# Define DEFAULT_EDITOR to a sensible editor command (defaults to "vi") if you
 307# want to use something different.  The value will be interpreted by the shell
 308# if necessary when it is used.  Examples:
 309#
 310#   DEFAULT_EDITOR='~/bin/vi',
 311#   DEFAULT_EDITOR='$GIT_FALLBACK_EDITOR',
 312#   DEFAULT_EDITOR='"C:\Program Files\Vim\gvim.exe" --nofork'
 313#
 314# Define COMPUTE_HEADER_DEPENDENCIES to "yes" if you want dependencies on
 315# header files to be automatically computed, to avoid rebuilding objects when
 316# an unrelated header file changes.  Define it to "no" to use the hard-coded
 317# dependency rules.  The default is "auto", which means to use computed header
 318# dependencies if your compiler is detected to support it.
 319#
 320# Define NATIVE_CRLF if your platform uses CRLF for line endings.
 321#
 322# Define XDL_FAST_HASH to use an alternative line-hashing method in
 323# the diff algorithm.  It gives a nice speedup if your processor has
 324# fast unaligned word loads.  Does NOT work on big-endian systems!
 325# Enabled by default on x86_64.
 326#
 327# Define GIT_USER_AGENT if you want to change how git identifies itself during
 328# network interactions.  The default is "git/$(GIT_VERSION)".
 329#
 330# Define DEFAULT_HELP_FORMAT to "man", "info" or "html"
 331# (defaults to "man") if you want to have a different default when
 332# "git help" is called without a parameter specifying the format.
 333#
 334# Define TEST_GIT_INDEX_VERSION to 2, 3 or 4 to run the test suite
 335# with a different indexfile format version.  If it isn't set the index
 336# file format used is index-v[23].
 337#
 338# Define GMTIME_UNRELIABLE_ERRORS if your gmtime() function does not
 339# return NULL when it receives a bogus time_t.
 340#
 341# Define HAVE_CLOCK_GETTIME if your platform has clock_gettime in librt.
 342
 343GIT-VERSION-FILE: FORCE
 344        @$(SHELL_PATH) ./GIT-VERSION-GEN
 345-include GIT-VERSION-FILE
 346
 347# CFLAGS and LDFLAGS are for the users to override from the command line.
 348
 349CFLAGS = -g -O2 -Wall
 350LDFLAGS =
 351ALL_CFLAGS = $(CPPFLAGS) $(CFLAGS)
 352ALL_LDFLAGS = $(LDFLAGS)
 353STRIP ?= strip
 354
 355# Among the variables below, these:
 356#   gitexecdir
 357#   template_dir
 358#   sysconfdir
 359# can be specified as a relative path some/where/else;
 360# this is interpreted as relative to $(prefix) and "git" at
 361# runtime figures out where they are based on the path to the executable.
 362# Additionally, the following will be treated as relative by "git" if they
 363# begin with "$(prefix)/":
 364#   mandir
 365#   infodir
 366#   htmldir
 367# This can help installing the suite in a relocatable way.
 368
 369prefix = $(HOME)
 370bindir_relative = bin
 371bindir = $(prefix)/$(bindir_relative)
 372mandir = $(prefix)/share/man
 373infodir = $(prefix)/share/info
 374gitexecdir = libexec/git-core
 375mergetoolsdir = $(gitexecdir)/mergetools
 376sharedir = $(prefix)/share
 377gitwebdir = $(sharedir)/gitweb
 378localedir = $(sharedir)/locale
 379template_dir = share/git-core/templates
 380htmldir = $(prefix)/share/doc/git-doc
 381ETC_GITCONFIG = $(sysconfdir)/gitconfig
 382ETC_GITATTRIBUTES = $(sysconfdir)/gitattributes
 383lib = lib
 384# DESTDIR =
 385pathsep = :
 386
 387mandir_relative = $(patsubst $(prefix)/%,%,$(mandir))
 388infodir_relative = $(patsubst $(prefix)/%,%,$(infodir))
 389htmldir_relative = $(patsubst $(prefix)/%,%,$(htmldir))
 390
 391export prefix bindir sharedir sysconfdir gitwebdir localedir
 392
 393CC = cc
 394AR = ar
 395RM = rm -f
 396DIFF = diff
 397TAR = tar
 398FIND = find
 399INSTALL = install
 400RPMBUILD = rpmbuild
 401TCL_PATH = tclsh
 402TCLTK_PATH = wish
 403XGETTEXT = xgettext
 404MSGFMT = msgfmt
 405PTHREAD_LIBS = -lpthread
 406PTHREAD_CFLAGS =
 407GCOV = gcov
 408
 409export TCL_PATH TCLTK_PATH
 410
 411SPARSE_FLAGS =
 412
 413
 414
 415### --- END CONFIGURATION SECTION ---
 416
 417# Those must not be GNU-specific; they are shared with perl/ which may
 418# be built by a different compiler. (Note that this is an artifact now
 419# but it still might be nice to keep that distinction.)
 420BASIC_CFLAGS = -I.
 421BASIC_LDFLAGS =
 422
 423# Guard against environment variables
 424BUILTIN_OBJS =
 425BUILT_INS =
 426COMPAT_CFLAGS =
 427COMPAT_OBJS =
 428XDIFF_OBJS =
 429VCSSVN_OBJS =
 430GENERATED_H =
 431EXTRA_CPPFLAGS =
 432LIB_OBJS =
 433PROGRAM_OBJS =
 434PROGRAMS =
 435SCRIPT_PERL =
 436SCRIPT_PYTHON =
 437SCRIPT_SH =
 438SCRIPT_LIB =
 439TEST_PROGRAMS_NEED_X =
 440
 441# Having this variable in your environment would break pipelines because
 442# you cause "cd" to echo its destination to stdout.  It can also take
 443# scripts to unexpected places.  If you like CDPATH, define it for your
 444# interactive shell sessions without exporting it.
 445unexport CDPATH
 446
 447SCRIPT_SH += git-am.sh
 448SCRIPT_SH += git-bisect.sh
 449SCRIPT_SH += git-difftool--helper.sh
 450SCRIPT_SH += git-filter-branch.sh
 451SCRIPT_SH += git-merge-octopus.sh
 452SCRIPT_SH += git-merge-one-file.sh
 453SCRIPT_SH += git-merge-resolve.sh
 454SCRIPT_SH += git-mergetool.sh
 455SCRIPT_SH += git-pull.sh
 456SCRIPT_SH += git-quiltimport.sh
 457SCRIPT_SH += git-rebase.sh
 458SCRIPT_SH += git-remote-testgit.sh
 459SCRIPT_SH += git-request-pull.sh
 460SCRIPT_SH += git-stash.sh
 461SCRIPT_SH += git-submodule.sh
 462SCRIPT_SH += git-web--browse.sh
 463
 464SCRIPT_LIB += git-mergetool--lib
 465SCRIPT_LIB += git-parse-remote
 466SCRIPT_LIB += git-rebase--am
 467SCRIPT_LIB += git-rebase--interactive
 468SCRIPT_LIB += git-rebase--merge
 469SCRIPT_LIB += git-sh-setup
 470SCRIPT_LIB += git-sh-i18n
 471
 472SCRIPT_PERL += git-add--interactive.perl
 473SCRIPT_PERL += git-difftool.perl
 474SCRIPT_PERL += git-archimport.perl
 475SCRIPT_PERL += git-cvsexportcommit.perl
 476SCRIPT_PERL += git-cvsimport.perl
 477SCRIPT_PERL += git-cvsserver.perl
 478SCRIPT_PERL += git-relink.perl
 479SCRIPT_PERL += git-send-email.perl
 480SCRIPT_PERL += git-svn.perl
 481
 482SCRIPT_PYTHON += git-p4.py
 483
 484NO_INSTALL += git-remote-testgit
 485
 486# Generated files for scripts
 487SCRIPT_SH_GEN = $(patsubst %.sh,%,$(SCRIPT_SH))
 488SCRIPT_PERL_GEN = $(patsubst %.perl,%,$(SCRIPT_PERL))
 489SCRIPT_PYTHON_GEN = $(patsubst %.py,%,$(SCRIPT_PYTHON))
 490
 491SCRIPT_SH_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_SH_GEN))
 492SCRIPT_PERL_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_PERL_GEN))
 493SCRIPT_PYTHON_INS = $(filter-out $(NO_INSTALL),$(SCRIPT_PYTHON_GEN))
 494
 495# Individual rules to allow e.g.
 496# "make -C ../.. SCRIPT_PERL=contrib/foo/bar.perl build-perl-script"
 497# from subdirectories like contrib/*/
 498.PHONY: build-perl-script build-sh-script build-python-script
 499build-perl-script: $(SCRIPT_PERL_GEN)
 500build-sh-script: $(SCRIPT_SH_GEN)
 501build-python-script: $(SCRIPT_PYTHON_GEN)
 502
 503.PHONY: install-perl-script install-sh-script install-python-script
 504install-sh-script: $(SCRIPT_SH_INS)
 505        $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
 506install-perl-script: $(SCRIPT_PERL_INS)
 507        $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
 508install-python-script: $(SCRIPT_PYTHON_INS)
 509        $(INSTALL) $^ '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
 510
 511.PHONY: clean-perl-script clean-sh-script clean-python-script
 512clean-sh-script:
 513        $(RM) $(SCRIPT_SH_GEN)
 514clean-perl-script:
 515        $(RM) $(SCRIPT_PERL_GEN)
 516clean-python-script:
 517        $(RM) $(SCRIPT_PYTHON_GEN)
 518
 519SCRIPTS = $(SCRIPT_SH_INS) \
 520          $(SCRIPT_PERL_INS) \
 521          $(SCRIPT_PYTHON_INS) \
 522          git-instaweb
 523
 524ETAGS_TARGET = TAGS
 525
 526# Empty...
 527EXTRA_PROGRAMS =
 528
 529# ... and all the rest that could be moved out of bindir to gitexecdir
 530PROGRAMS += $(EXTRA_PROGRAMS)
 531
 532PROGRAM_OBJS += credential-store.o
 533PROGRAM_OBJS += daemon.o
 534PROGRAM_OBJS += fast-import.o
 535PROGRAM_OBJS += http-backend.o
 536PROGRAM_OBJS += imap-send.o
 537PROGRAM_OBJS += sh-i18n--envsubst.o
 538PROGRAM_OBJS += shell.o
 539PROGRAM_OBJS += show-index.o
 540PROGRAM_OBJS += upload-pack.o
 541PROGRAM_OBJS += remote-testsvn.o
 542
 543# Binary suffix, set to .exe for Windows builds
 544X =
 545
 546PROGRAMS += $(patsubst %.o,git-%$X,$(PROGRAM_OBJS))
 547
 548TEST_PROGRAMS_NEED_X += test-chmtime
 549TEST_PROGRAMS_NEED_X += test-ctype
 550TEST_PROGRAMS_NEED_X += test-config
 551TEST_PROGRAMS_NEED_X += test-date
 552TEST_PROGRAMS_NEED_X += test-delta
 553TEST_PROGRAMS_NEED_X += test-dump-cache-tree
 554TEST_PROGRAMS_NEED_X += test-dump-split-index
 555TEST_PROGRAMS_NEED_X += test-genrandom
 556TEST_PROGRAMS_NEED_X += test-hashmap
 557TEST_PROGRAMS_NEED_X += test-index-version
 558TEST_PROGRAMS_NEED_X += test-line-buffer
 559TEST_PROGRAMS_NEED_X += test-match-trees
 560TEST_PROGRAMS_NEED_X += test-mergesort
 561TEST_PROGRAMS_NEED_X += test-mktemp
 562TEST_PROGRAMS_NEED_X += test-parse-options
 563TEST_PROGRAMS_NEED_X += test-path-utils
 564TEST_PROGRAMS_NEED_X += test-prio-queue
 565TEST_PROGRAMS_NEED_X += test-read-cache
 566TEST_PROGRAMS_NEED_X += test-regex
 567TEST_PROGRAMS_NEED_X += test-revision-walking
 568TEST_PROGRAMS_NEED_X += test-run-command
 569TEST_PROGRAMS_NEED_X += test-scrap-cache-tree
 570TEST_PROGRAMS_NEED_X += test-sha1
 571TEST_PROGRAMS_NEED_X += test-sha1-array
 572TEST_PROGRAMS_NEED_X += test-sigchain
 573TEST_PROGRAMS_NEED_X += test-string-list
 574TEST_PROGRAMS_NEED_X += test-subprocess
 575TEST_PROGRAMS_NEED_X += test-svn-fe
 576TEST_PROGRAMS_NEED_X += test-urlmatch-normalization
 577TEST_PROGRAMS_NEED_X += test-wildmatch
 578
 579TEST_PROGRAMS = $(patsubst %,%$X,$(TEST_PROGRAMS_NEED_X))
 580
 581# List built-in command $C whose implementation cmd_$C() is not in
 582# builtin/$C.o but is linked in as part of some other command.
 583BUILT_INS += $(patsubst builtin/%.o,git-%$X,$(BUILTIN_OBJS))
 584
 585BUILT_INS += git-cherry$X
 586BUILT_INS += git-cherry-pick$X
 587BUILT_INS += git-format-patch$X
 588BUILT_INS += git-fsck-objects$X
 589BUILT_INS += git-init$X
 590BUILT_INS += git-merge-subtree$X
 591BUILT_INS += git-show$X
 592BUILT_INS += git-stage$X
 593BUILT_INS += git-status$X
 594BUILT_INS += git-whatchanged$X
 595
 596# what 'all' will build and 'install' will install in gitexecdir,
 597# excluding programs for built-in commands
 598ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS)
 599
 600# what 'all' will build but not install in gitexecdir
 601OTHER_PROGRAMS = git$X
 602
 603# what test wrappers are needed and 'install' will install, in bindir
 604BINDIR_PROGRAMS_NEED_X += git
 605BINDIR_PROGRAMS_NEED_X += git-upload-pack
 606BINDIR_PROGRAMS_NEED_X += git-receive-pack
 607BINDIR_PROGRAMS_NEED_X += git-upload-archive
 608BINDIR_PROGRAMS_NEED_X += git-shell
 609
 610BINDIR_PROGRAMS_NO_X += git-cvsserver
 611
 612# Set paths to tools early so that they can be used for version tests.
 613ifndef SHELL_PATH
 614        SHELL_PATH = /bin/sh
 615endif
 616ifndef PERL_PATH
 617        PERL_PATH = /usr/bin/perl
 618endif
 619ifndef PYTHON_PATH
 620        PYTHON_PATH = /usr/bin/python
 621endif
 622
 623export PERL_PATH
 624export PYTHON_PATH
 625
 626LIB_FILE = libgit.a
 627XDIFF_LIB = xdiff/lib.a
 628VCSSVN_LIB = vcs-svn/lib.a
 629
 630GENERATED_H += common-cmds.h
 631
 632LIB_H = $(shell $(FIND) . \
 633        -name .git -prune -o \
 634        -name t -prune -o \
 635        -name Documentation -prune -o \
 636        -name '*.h' -print)
 637
 638LIB_OBJS += abspath.o
 639LIB_OBJS += advice.o
 640LIB_OBJS += alias.o
 641LIB_OBJS += alloc.o
 642LIB_OBJS += archive.o
 643LIB_OBJS += archive-tar.o
 644LIB_OBJS += archive-zip.o
 645LIB_OBJS += argv-array.o
 646LIB_OBJS += attr.o
 647LIB_OBJS += base85.o
 648LIB_OBJS += bisect.o
 649LIB_OBJS += blob.o
 650LIB_OBJS += branch.o
 651LIB_OBJS += bulk-checkin.o
 652LIB_OBJS += bundle.o
 653LIB_OBJS += cache-tree.o
 654LIB_OBJS += color.o
 655LIB_OBJS += column.o
 656LIB_OBJS += combine-diff.o
 657LIB_OBJS += commit.o
 658LIB_OBJS += compat/obstack.o
 659LIB_OBJS += compat/terminal.o
 660LIB_OBJS += config.o
 661LIB_OBJS += connect.o
 662LIB_OBJS += connected.o
 663LIB_OBJS += convert.o
 664LIB_OBJS += copy.o
 665LIB_OBJS += credential.o
 666LIB_OBJS += csum-file.o
 667LIB_OBJS += ctype.o
 668LIB_OBJS += date.o
 669LIB_OBJS += decorate.o
 670LIB_OBJS += diffcore-break.o
 671LIB_OBJS += diffcore-delta.o
 672LIB_OBJS += diffcore-order.o
 673LIB_OBJS += diffcore-pickaxe.o
 674LIB_OBJS += diffcore-rename.o
 675LIB_OBJS += diff-delta.o
 676LIB_OBJS += diff-lib.o
 677LIB_OBJS += diff-no-index.o
 678LIB_OBJS += diff.o
 679LIB_OBJS += dir.o
 680LIB_OBJS += editor.o
 681LIB_OBJS += entry.o
 682LIB_OBJS += environment.o
 683LIB_OBJS += ewah/bitmap.o
 684LIB_OBJS += ewah/ewah_bitmap.o
 685LIB_OBJS += ewah/ewah_io.o
 686LIB_OBJS += ewah/ewah_rlw.o
 687LIB_OBJS += exec_cmd.o
 688LIB_OBJS += fetch-pack.o
 689LIB_OBJS += fsck.o
 690LIB_OBJS += gettext.o
 691LIB_OBJS += gpg-interface.o
 692LIB_OBJS += graph.o
 693LIB_OBJS += grep.o
 694LIB_OBJS += hashmap.o
 695LIB_OBJS += help.o
 696LIB_OBJS += hex.o
 697LIB_OBJS += ident.o
 698LIB_OBJS += kwset.o
 699LIB_OBJS += levenshtein.o
 700LIB_OBJS += line-log.o
 701LIB_OBJS += line-range.o
 702LIB_OBJS += list-objects.o
 703LIB_OBJS += ll-merge.o
 704LIB_OBJS += lockfile.o
 705LIB_OBJS += log-tree.o
 706LIB_OBJS += mailmap.o
 707LIB_OBJS += match-trees.o
 708LIB_OBJS += merge.o
 709LIB_OBJS += merge-blobs.o
 710LIB_OBJS += merge-recursive.o
 711LIB_OBJS += mergesort.o
 712LIB_OBJS += name-hash.o
 713LIB_OBJS += notes.o
 714LIB_OBJS += notes-cache.o
 715LIB_OBJS += notes-merge.o
 716LIB_OBJS += notes-utils.o
 717LIB_OBJS += object.o
 718LIB_OBJS += pack-bitmap.o
 719LIB_OBJS += pack-bitmap-write.o
 720LIB_OBJS += pack-check.o
 721LIB_OBJS += pack-objects.o
 722LIB_OBJS += pack-revindex.o
 723LIB_OBJS += pack-write.o
 724LIB_OBJS += pager.o
 725LIB_OBJS += parse-options.o
 726LIB_OBJS += parse-options-cb.o
 727LIB_OBJS += patch-delta.o
 728LIB_OBJS += patch-ids.o
 729LIB_OBJS += path.o
 730LIB_OBJS += pathspec.o
 731LIB_OBJS += pkt-line.o
 732LIB_OBJS += preload-index.o
 733LIB_OBJS += pretty.o
 734LIB_OBJS += prio-queue.o
 735LIB_OBJS += progress.o
 736LIB_OBJS += prompt.o
 737LIB_OBJS += quote.o
 738LIB_OBJS += reachable.o
 739LIB_OBJS += read-cache.o
 740LIB_OBJS += reflog-walk.o
 741LIB_OBJS += refs.o
 742LIB_OBJS += remote.o
 743LIB_OBJS += replace_object.o
 744LIB_OBJS += rerere.o
 745LIB_OBJS += resolve-undo.o
 746LIB_OBJS += revision.o
 747LIB_OBJS += run-command.o
 748LIB_OBJS += send-pack.o
 749LIB_OBJS += sequencer.o
 750LIB_OBJS += server-info.o
 751LIB_OBJS += setup.o
 752LIB_OBJS += sha1-array.o
 753LIB_OBJS += sha1-lookup.o
 754LIB_OBJS += sha1_file.o
 755LIB_OBJS += sha1_name.o
 756LIB_OBJS += shallow.o
 757LIB_OBJS += sideband.o
 758LIB_OBJS += sigchain.o
 759LIB_OBJS += split-index.o
 760LIB_OBJS += strbuf.o
 761LIB_OBJS += streaming.o
 762LIB_OBJS += string-list.o
 763LIB_OBJS += submodule.o
 764LIB_OBJS += symlinks.o
 765LIB_OBJS += tag.o
 766LIB_OBJS += trace.o
 767LIB_OBJS += trailer.o
 768LIB_OBJS += transport.o
 769LIB_OBJS += transport-helper.o
 770LIB_OBJS += tree-diff.o
 771LIB_OBJS += tree.o
 772LIB_OBJS += tree-walk.o
 773LIB_OBJS += unpack-trees.o
 774LIB_OBJS += url.o
 775LIB_OBJS += urlmatch.o
 776LIB_OBJS += usage.o
 777LIB_OBJS += userdiff.o
 778LIB_OBJS += utf8.o
 779LIB_OBJS += varint.o
 780LIB_OBJS += version.o
 781LIB_OBJS += versioncmp.o
 782LIB_OBJS += walker.o
 783LIB_OBJS += wildmatch.o
 784LIB_OBJS += wrapper.o
 785LIB_OBJS += write_or_die.o
 786LIB_OBJS += ws.o
 787LIB_OBJS += wt-status.o
 788LIB_OBJS += xdiff-interface.o
 789LIB_OBJS += zlib.o
 790
 791BUILTIN_OBJS += builtin/add.o
 792BUILTIN_OBJS += builtin/annotate.o
 793BUILTIN_OBJS += builtin/apply.o
 794BUILTIN_OBJS += builtin/archive.o
 795BUILTIN_OBJS += builtin/bisect--helper.o
 796BUILTIN_OBJS += builtin/blame.o
 797BUILTIN_OBJS += builtin/branch.o
 798BUILTIN_OBJS += builtin/bundle.o
 799BUILTIN_OBJS += builtin/cat-file.o
 800BUILTIN_OBJS += builtin/check-attr.o
 801BUILTIN_OBJS += builtin/check-ignore.o
 802BUILTIN_OBJS += builtin/check-mailmap.o
 803BUILTIN_OBJS += builtin/check-ref-format.o
 804BUILTIN_OBJS += builtin/checkout-index.o
 805BUILTIN_OBJS += builtin/checkout.o
 806BUILTIN_OBJS += builtin/clean.o
 807BUILTIN_OBJS += builtin/clone.o
 808BUILTIN_OBJS += builtin/column.o
 809BUILTIN_OBJS += builtin/commit-tree.o
 810BUILTIN_OBJS += builtin/commit.o
 811BUILTIN_OBJS += builtin/config.o
 812BUILTIN_OBJS += builtin/count-objects.o
 813BUILTIN_OBJS += builtin/credential.o
 814BUILTIN_OBJS += builtin/describe.o
 815BUILTIN_OBJS += builtin/diff-files.o
 816BUILTIN_OBJS += builtin/diff-index.o
 817BUILTIN_OBJS += builtin/diff-tree.o
 818BUILTIN_OBJS += builtin/diff.o
 819BUILTIN_OBJS += builtin/fast-export.o
 820BUILTIN_OBJS += builtin/fetch-pack.o
 821BUILTIN_OBJS += builtin/fetch.o
 822BUILTIN_OBJS += builtin/fmt-merge-msg.o
 823BUILTIN_OBJS += builtin/for-each-ref.o
 824BUILTIN_OBJS += builtin/fsck.o
 825BUILTIN_OBJS += builtin/gc.o
 826BUILTIN_OBJS += builtin/get-tar-commit-id.o
 827BUILTIN_OBJS += builtin/grep.o
 828BUILTIN_OBJS += builtin/hash-object.o
 829BUILTIN_OBJS += builtin/help.o
 830BUILTIN_OBJS += builtin/index-pack.o
 831BUILTIN_OBJS += builtin/init-db.o
 832BUILTIN_OBJS += builtin/interpret-trailers.o
 833BUILTIN_OBJS += builtin/log.o
 834BUILTIN_OBJS += builtin/ls-files.o
 835BUILTIN_OBJS += builtin/ls-remote.o
 836BUILTIN_OBJS += builtin/ls-tree.o
 837BUILTIN_OBJS += builtin/mailinfo.o
 838BUILTIN_OBJS += builtin/mailsplit.o
 839BUILTIN_OBJS += builtin/merge.o
 840BUILTIN_OBJS += builtin/merge-base.o
 841BUILTIN_OBJS += builtin/merge-file.o
 842BUILTIN_OBJS += builtin/merge-index.o
 843BUILTIN_OBJS += builtin/merge-ours.o
 844BUILTIN_OBJS += builtin/merge-recursive.o
 845BUILTIN_OBJS += builtin/merge-tree.o
 846BUILTIN_OBJS += builtin/mktag.o
 847BUILTIN_OBJS += builtin/mktree.o
 848BUILTIN_OBJS += builtin/mv.o
 849BUILTIN_OBJS += builtin/name-rev.o
 850BUILTIN_OBJS += builtin/notes.o
 851BUILTIN_OBJS += builtin/pack-objects.o
 852BUILTIN_OBJS += builtin/pack-redundant.o
 853BUILTIN_OBJS += builtin/pack-refs.o
 854BUILTIN_OBJS += builtin/patch-id.o
 855BUILTIN_OBJS += builtin/prune-packed.o
 856BUILTIN_OBJS += builtin/prune.o
 857BUILTIN_OBJS += builtin/push.o
 858BUILTIN_OBJS += builtin/read-tree.o
 859BUILTIN_OBJS += builtin/receive-pack.o
 860BUILTIN_OBJS += builtin/reflog.o
 861BUILTIN_OBJS += builtin/remote.o
 862BUILTIN_OBJS += builtin/remote-ext.o
 863BUILTIN_OBJS += builtin/remote-fd.o
 864BUILTIN_OBJS += builtin/repack.o
 865BUILTIN_OBJS += builtin/replace.o
 866BUILTIN_OBJS += builtin/rerere.o
 867BUILTIN_OBJS += builtin/reset.o
 868BUILTIN_OBJS += builtin/rev-list.o
 869BUILTIN_OBJS += builtin/rev-parse.o
 870BUILTIN_OBJS += builtin/revert.o
 871BUILTIN_OBJS += builtin/rm.o
 872BUILTIN_OBJS += builtin/send-pack.o
 873BUILTIN_OBJS += builtin/shortlog.o
 874BUILTIN_OBJS += builtin/show-branch.o
 875BUILTIN_OBJS += builtin/show-ref.o
 876BUILTIN_OBJS += builtin/stripspace.o
 877BUILTIN_OBJS += builtin/symbolic-ref.o
 878BUILTIN_OBJS += builtin/tag.o
 879BUILTIN_OBJS += builtin/unpack-file.o
 880BUILTIN_OBJS += builtin/unpack-objects.o
 881BUILTIN_OBJS += builtin/update-index.o
 882BUILTIN_OBJS += builtin/update-ref.o
 883BUILTIN_OBJS += builtin/update-server-info.o
 884BUILTIN_OBJS += builtin/upload-archive.o
 885BUILTIN_OBJS += builtin/var.o
 886BUILTIN_OBJS += builtin/verify-commit.o
 887BUILTIN_OBJS += builtin/verify-pack.o
 888BUILTIN_OBJS += builtin/verify-tag.o
 889BUILTIN_OBJS += builtin/write-tree.o
 890
 891GITLIBS = $(LIB_FILE) $(XDIFF_LIB)
 892EXTLIBS =
 893
 894GIT_USER_AGENT = git/$(GIT_VERSION)
 895
 896include config.mak.uname
 897-include config.mak.autogen
 898-include config.mak
 899
 900ifndef sysconfdir
 901ifeq ($(prefix),/usr)
 902sysconfdir = /etc
 903else
 904sysconfdir = etc
 905endif
 906endif
 907
 908ifndef COMPUTE_HEADER_DEPENDENCIES
 909COMPUTE_HEADER_DEPENDENCIES = auto
 910endif
 911
 912ifeq ($(COMPUTE_HEADER_DEPENDENCIES),auto)
 913dep_check = $(shell $(CC) $(ALL_CFLAGS) \
 914        -c -MF /dev/null -MQ /dev/null -MMD -MP \
 915        -x c /dev/null -o /dev/null 2>&1; \
 916        echo $$?)
 917ifeq ($(dep_check),0)
 918override COMPUTE_HEADER_DEPENDENCIES = yes
 919else
 920override COMPUTE_HEADER_DEPENDENCIES = no
 921endif
 922endif
 923
 924ifeq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
 925USE_COMPUTED_HEADER_DEPENDENCIES = YesPlease
 926else
 927ifneq ($(COMPUTE_HEADER_DEPENDENCIES),no)
 928$(error please set COMPUTE_HEADER_DEPENDENCIES to yes, no, or auto \
 929(not "$(COMPUTE_HEADER_DEPENDENCIES)"))
 930endif
 931endif
 932
 933ifdef SANE_TOOL_PATH
 934SANE_TOOL_PATH_SQ = $(subst ','\'',$(SANE_TOOL_PATH))
 935BROKEN_PATH_FIX = 's|^\# @@BROKEN_PATH_FIX@@$$|git_broken_path_fix $(SANE_TOOL_PATH_SQ)|'
 936PATH := $(SANE_TOOL_PATH):${PATH}
 937else
 938BROKEN_PATH_FIX = '/^\# @@BROKEN_PATH_FIX@@$$/d'
 939endif
 940
 941ifneq (,$(INLINE))
 942        BASIC_CFLAGS += -Dinline=$(INLINE)
 943endif
 944
 945ifneq (,$(SOCKLEN_T))
 946        BASIC_CFLAGS += -Dsocklen_t=$(SOCKLEN_T)
 947endif
 948
 949ifeq ($(uname_S),Darwin)
 950        ifndef NO_FINK
 951                ifeq ($(shell test -d /sw/lib && echo y),y)
 952                        BASIC_CFLAGS += -I/sw/include
 953                        BASIC_LDFLAGS += -L/sw/lib
 954                endif
 955        endif
 956        ifndef NO_DARWIN_PORTS
 957                ifeq ($(shell test -d /opt/local/lib && echo y),y)
 958                        BASIC_CFLAGS += -I/opt/local/include
 959                        BASIC_LDFLAGS += -L/opt/local/lib
 960                endif
 961        endif
 962        ifndef NO_APPLE_COMMON_CRYPTO
 963                APPLE_COMMON_CRYPTO = YesPlease
 964                COMPAT_CFLAGS += -DAPPLE_COMMON_CRYPTO
 965        endif
 966        NO_REGEX = YesPlease
 967        PTHREAD_LIBS =
 968endif
 969
 970ifndef CC_LD_DYNPATH
 971        ifdef NO_R_TO_GCC_LINKER
 972                # Some gcc does not accept and pass -R to the linker to specify
 973                # the runtime dynamic library path.
 974                CC_LD_DYNPATH = -Wl,-rpath,
 975        else
 976                CC_LD_DYNPATH = -R
 977        endif
 978endif
 979
 980ifdef NO_LIBGEN_H
 981        COMPAT_CFLAGS += -DNO_LIBGEN_H
 982        COMPAT_OBJS += compat/basename.o
 983endif
 984
 985ifdef USE_LIBPCRE
 986        BASIC_CFLAGS += -DUSE_LIBPCRE
 987        ifdef LIBPCREDIR
 988                BASIC_CFLAGS += -I$(LIBPCREDIR)/include
 989                EXTLIBS += -L$(LIBPCREDIR)/$(lib) $(CC_LD_DYNPATH)$(LIBPCREDIR)/$(lib)
 990        endif
 991        EXTLIBS += -lpcre
 992endif
 993
 994ifdef HAVE_ALLOCA_H
 995        BASIC_CFLAGS += -DHAVE_ALLOCA_H
 996endif
 997
 998ifdef NO_CURL
 999        BASIC_CFLAGS += -DNO_CURL
1000        REMOTE_CURL_PRIMARY =
1001        REMOTE_CURL_ALIASES =
1002        REMOTE_CURL_NAMES =
1003else
1004        ifdef CURLDIR
1005                # Try "-Wl,-rpath=$(CURLDIR)/$(lib)" in such a case.
1006                BASIC_CFLAGS += -I$(CURLDIR)/include
1007                CURL_LIBCURL = -L$(CURLDIR)/$(lib) $(CC_LD_DYNPATH)$(CURLDIR)/$(lib) -lcurl
1008        else
1009                CURL_LIBCURL = -lcurl
1010        endif
1011        ifdef NEEDS_SSL_WITH_CURL
1012                CURL_LIBCURL += -lssl
1013                ifdef NEEDS_CRYPTO_WITH_SSL
1014                        CURL_LIBCURL += -lcrypto
1015                endif
1016        endif
1017        ifdef NEEDS_IDN_WITH_CURL
1018                CURL_LIBCURL += -lidn
1019        endif
1020
1021        REMOTE_CURL_PRIMARY = git-remote-http$X
1022        REMOTE_CURL_ALIASES = git-remote-https$X git-remote-ftp$X git-remote-ftps$X
1023        REMOTE_CURL_NAMES = $(REMOTE_CURL_PRIMARY) $(REMOTE_CURL_ALIASES)
1024        PROGRAM_OBJS += http-fetch.o
1025        PROGRAMS += $(REMOTE_CURL_NAMES)
1026        curl_check := $(shell (echo 070908; curl-config --vernum) 2>/dev/null | sort -r | sed -ne 2p)
1027        ifeq "$(curl_check)" "070908"
1028                ifndef NO_EXPAT
1029                        PROGRAM_OBJS += http-push.o
1030                endif
1031        endif
1032        ifndef NO_EXPAT
1033                ifdef EXPATDIR
1034                        BASIC_CFLAGS += -I$(EXPATDIR)/include
1035                        EXPAT_LIBEXPAT = -L$(EXPATDIR)/$(lib) $(CC_LD_DYNPATH)$(EXPATDIR)/$(lib) -lexpat
1036                else
1037                        EXPAT_LIBEXPAT = -lexpat
1038                endif
1039                ifdef EXPAT_NEEDS_XMLPARSE_H
1040                        BASIC_CFLAGS += -DEXPAT_NEEDS_XMLPARSE_H
1041                endif
1042        endif
1043endif
1044
1045ifdef ZLIB_PATH
1046        BASIC_CFLAGS += -I$(ZLIB_PATH)/include
1047        EXTLIBS += -L$(ZLIB_PATH)/$(lib) $(CC_LD_DYNPATH)$(ZLIB_PATH)/$(lib)
1048endif
1049EXTLIBS += -lz
1050
1051ifndef NO_OPENSSL
1052        OPENSSL_LIBSSL = -lssl
1053        ifdef OPENSSLDIR
1054                BASIC_CFLAGS += -I$(OPENSSLDIR)/include
1055                OPENSSL_LINK = -L$(OPENSSLDIR)/$(lib) $(CC_LD_DYNPATH)$(OPENSSLDIR)/$(lib)
1056        else
1057                OPENSSL_LINK =
1058        endif
1059        ifdef NEEDS_CRYPTO_WITH_SSL
1060                OPENSSL_LIBSSL += -lcrypto
1061        endif
1062else
1063        BASIC_CFLAGS += -DNO_OPENSSL
1064        BLK_SHA1 = 1
1065        OPENSSL_LIBSSL =
1066endif
1067ifdef NO_OPENSSL
1068        LIB_4_CRYPTO =
1069else
1070ifdef NEEDS_SSL_WITH_CRYPTO
1071        LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl
1072else
1073        LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto
1074endif
1075ifdef APPLE_COMMON_CRYPTO
1076        LIB_4_CRYPTO += -framework Security -framework CoreFoundation
1077endif
1078endif
1079ifdef NEEDS_LIBICONV
1080        ifdef ICONVDIR
1081                BASIC_CFLAGS += -I$(ICONVDIR)/include
1082                ICONV_LINK = -L$(ICONVDIR)/$(lib) $(CC_LD_DYNPATH)$(ICONVDIR)/$(lib)
1083        else
1084                ICONV_LINK =
1085        endif
1086        ifdef NEEDS_LIBINTL_BEFORE_LIBICONV
1087                ICONV_LINK += -lintl
1088        endif
1089        EXTLIBS += $(ICONV_LINK) -liconv
1090endif
1091ifdef NEEDS_LIBGEN
1092        EXTLIBS += -lgen
1093endif
1094ifndef NO_GETTEXT
1095ifndef LIBC_CONTAINS_LIBINTL
1096        EXTLIBS += -lintl
1097endif
1098endif
1099ifdef NEEDS_SOCKET
1100        EXTLIBS += -lsocket
1101endif
1102ifdef NEEDS_NSL
1103        EXTLIBS += -lnsl
1104endif
1105ifdef NEEDS_RESOLV
1106        EXTLIBS += -lresolv
1107endif
1108ifdef NO_D_TYPE_IN_DIRENT
1109        BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT
1110endif
1111ifdef NO_D_INO_IN_DIRENT
1112        BASIC_CFLAGS += -DNO_D_INO_IN_DIRENT
1113endif
1114ifdef NO_GECOS_IN_PWENT
1115        BASIC_CFLAGS += -DNO_GECOS_IN_PWENT
1116endif
1117ifdef NO_ST_BLOCKS_IN_STRUCT_STAT
1118        BASIC_CFLAGS += -DNO_ST_BLOCKS_IN_STRUCT_STAT
1119endif
1120ifdef USE_NSEC
1121        BASIC_CFLAGS += -DUSE_NSEC
1122endif
1123ifdef USE_ST_TIMESPEC
1124        BASIC_CFLAGS += -DUSE_ST_TIMESPEC
1125endif
1126ifdef NO_NORETURN
1127        BASIC_CFLAGS += -DNO_NORETURN
1128endif
1129ifdef NO_NSEC
1130        BASIC_CFLAGS += -DNO_NSEC
1131endif
1132ifdef SNPRINTF_RETURNS_BOGUS
1133        COMPAT_CFLAGS += -DSNPRINTF_RETURNS_BOGUS
1134        COMPAT_OBJS += compat/snprintf.o
1135endif
1136ifdef FREAD_READS_DIRECTORIES
1137        COMPAT_CFLAGS += -DFREAD_READS_DIRECTORIES
1138        COMPAT_OBJS += compat/fopen.o
1139endif
1140ifdef NO_SYMLINK_HEAD
1141        BASIC_CFLAGS += -DNO_SYMLINK_HEAD
1142endif
1143ifdef GETTEXT_POISON
1144        BASIC_CFLAGS += -DGETTEXT_POISON
1145endif
1146ifdef NO_GETTEXT
1147        BASIC_CFLAGS += -DNO_GETTEXT
1148        USE_GETTEXT_SCHEME ?= fallthrough
1149endif
1150ifdef NO_POLL
1151        NO_SYS_POLL_H = YesPlease
1152        COMPAT_CFLAGS += -DNO_POLL -Icompat/poll
1153        COMPAT_OBJS += compat/poll/poll.o
1154endif
1155ifdef NO_STRCASESTR
1156        COMPAT_CFLAGS += -DNO_STRCASESTR
1157        COMPAT_OBJS += compat/strcasestr.o
1158endif
1159ifdef NO_STRLCPY
1160        COMPAT_CFLAGS += -DNO_STRLCPY
1161        COMPAT_OBJS += compat/strlcpy.o
1162endif
1163ifdef NO_STRTOUMAX
1164        COMPAT_CFLAGS += -DNO_STRTOUMAX
1165        COMPAT_OBJS += compat/strtoumax.o compat/strtoimax.o
1166endif
1167ifdef NO_STRTOULL
1168        COMPAT_CFLAGS += -DNO_STRTOULL
1169endif
1170ifdef NO_SETENV
1171        COMPAT_CFLAGS += -DNO_SETENV
1172        COMPAT_OBJS += compat/setenv.o
1173endif
1174ifdef NO_MKDTEMP
1175        COMPAT_CFLAGS += -DNO_MKDTEMP
1176        COMPAT_OBJS += compat/mkdtemp.o
1177endif
1178ifdef MKDIR_WO_TRAILING_SLASH
1179        COMPAT_CFLAGS += -DMKDIR_WO_TRAILING_SLASH
1180        COMPAT_OBJS += compat/mkdir.o
1181endif
1182ifdef NO_MKSTEMPS
1183        COMPAT_CFLAGS += -DNO_MKSTEMPS
1184endif
1185ifdef NO_UNSETENV
1186        COMPAT_CFLAGS += -DNO_UNSETENV
1187        COMPAT_OBJS += compat/unsetenv.o
1188endif
1189ifdef NO_SYS_SELECT_H
1190        BASIC_CFLAGS += -DNO_SYS_SELECT_H
1191endif
1192ifdef NO_SYS_POLL_H
1193        BASIC_CFLAGS += -DNO_SYS_POLL_H
1194endif
1195ifdef NEEDS_SYS_PARAM_H
1196        BASIC_CFLAGS += -DNEEDS_SYS_PARAM_H
1197endif
1198ifdef NO_INTTYPES_H
1199        BASIC_CFLAGS += -DNO_INTTYPES_H
1200endif
1201ifdef NO_INITGROUPS
1202        BASIC_CFLAGS += -DNO_INITGROUPS
1203endif
1204ifdef NO_MMAP
1205        COMPAT_CFLAGS += -DNO_MMAP
1206        COMPAT_OBJS += compat/mmap.o
1207else
1208        ifdef USE_WIN32_MMAP
1209                COMPAT_CFLAGS += -DUSE_WIN32_MMAP
1210                COMPAT_OBJS += compat/win32mmap.o
1211        endif
1212endif
1213ifdef OBJECT_CREATION_USES_RENAMES
1214        COMPAT_CFLAGS += -DOBJECT_CREATION_MODE=1
1215endif
1216ifdef NO_STRUCT_ITIMERVAL
1217        COMPAT_CFLAGS += -DNO_STRUCT_ITIMERVAL
1218        NO_SETITIMER = YesPlease
1219endif
1220ifdef NO_SETITIMER
1221        COMPAT_CFLAGS += -DNO_SETITIMER
1222endif
1223ifdef NO_PREAD
1224        COMPAT_CFLAGS += -DNO_PREAD
1225        COMPAT_OBJS += compat/pread.o
1226endif
1227ifdef NO_FAST_WORKING_DIRECTORY
1228        BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY
1229endif
1230ifdef NO_TRUSTABLE_FILEMODE
1231        BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE
1232endif
1233ifdef NO_IPV6
1234        BASIC_CFLAGS += -DNO_IPV6
1235endif
1236ifdef NO_INTPTR_T
1237        COMPAT_CFLAGS += -DNO_INTPTR_T
1238endif
1239ifdef NO_UINTMAX_T
1240        BASIC_CFLAGS += -Duintmax_t=uint32_t
1241endif
1242ifdef NO_SOCKADDR_STORAGE
1243ifdef NO_IPV6
1244        BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in
1245else
1246        BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6
1247endif
1248endif
1249ifdef NO_INET_NTOP
1250        LIB_OBJS += compat/inet_ntop.o
1251        BASIC_CFLAGS += -DNO_INET_NTOP
1252endif
1253ifdef NO_INET_PTON
1254        LIB_OBJS += compat/inet_pton.o
1255        BASIC_CFLAGS += -DNO_INET_PTON
1256endif
1257ifndef NO_UNIX_SOCKETS
1258        LIB_OBJS += unix-socket.o
1259        PROGRAM_OBJS += credential-cache.o
1260        PROGRAM_OBJS += credential-cache--daemon.o
1261endif
1262
1263ifdef NO_ICONV
1264        BASIC_CFLAGS += -DNO_ICONV
1265endif
1266
1267ifdef OLD_ICONV
1268        BASIC_CFLAGS += -DOLD_ICONV
1269endif
1270
1271ifdef NO_DEFLATE_BOUND
1272        BASIC_CFLAGS += -DNO_DEFLATE_BOUND
1273endif
1274
1275ifdef NO_POSIX_GOODIES
1276        BASIC_CFLAGS += -DNO_POSIX_GOODIES
1277endif
1278
1279ifdef BLK_SHA1
1280        SHA1_HEADER = "block-sha1/sha1.h"
1281        LIB_OBJS += block-sha1/sha1.o
1282else
1283ifdef PPC_SHA1
1284        SHA1_HEADER = "ppc/sha1.h"
1285        LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o
1286else
1287ifdef APPLE_COMMON_CRYPTO
1288        COMPAT_CFLAGS += -DCOMMON_DIGEST_FOR_OPENSSL
1289        SHA1_HEADER = <CommonCrypto/CommonDigest.h>
1290else
1291        SHA1_HEADER = <openssl/sha.h>
1292        EXTLIBS += $(LIB_4_CRYPTO)
1293endif
1294endif
1295endif
1296
1297ifdef NO_PERL_MAKEMAKER
1298        export NO_PERL_MAKEMAKER
1299endif
1300ifdef NO_HSTRERROR
1301        COMPAT_CFLAGS += -DNO_HSTRERROR
1302        COMPAT_OBJS += compat/hstrerror.o
1303endif
1304ifdef NO_MEMMEM
1305        COMPAT_CFLAGS += -DNO_MEMMEM
1306        COMPAT_OBJS += compat/memmem.o
1307endif
1308ifdef NO_GETPAGESIZE
1309        COMPAT_CFLAGS += -DNO_GETPAGESIZE
1310endif
1311ifdef INTERNAL_QSORT
1312        COMPAT_CFLAGS += -DINTERNAL_QSORT
1313        COMPAT_OBJS += compat/qsort.o
1314endif
1315ifdef RUNTIME_PREFIX
1316        COMPAT_CFLAGS += -DRUNTIME_PREFIX
1317endif
1318
1319ifdef NO_PTHREADS
1320        BASIC_CFLAGS += -DNO_PTHREADS
1321else
1322        BASIC_CFLAGS += $(PTHREAD_CFLAGS)
1323        EXTLIBS += $(PTHREAD_LIBS)
1324        LIB_OBJS += thread-utils.o
1325endif
1326
1327ifdef HAVE_PATHS_H
1328        BASIC_CFLAGS += -DHAVE_PATHS_H
1329endif
1330
1331ifdef HAVE_LIBCHARSET_H
1332        BASIC_CFLAGS += -DHAVE_LIBCHARSET_H
1333        EXTLIBS += $(CHARSET_LIB)
1334endif
1335
1336ifdef HAVE_STRINGS_H
1337        BASIC_CFLAGS += -DHAVE_STRINGS_H
1338endif
1339
1340ifdef HAVE_DEV_TTY
1341        BASIC_CFLAGS += -DHAVE_DEV_TTY
1342endif
1343
1344ifdef DIR_HAS_BSD_GROUP_SEMANTICS
1345        COMPAT_CFLAGS += -DDIR_HAS_BSD_GROUP_SEMANTICS
1346endif
1347ifdef UNRELIABLE_FSTAT
1348        BASIC_CFLAGS += -DUNRELIABLE_FSTAT
1349endif
1350ifdef NO_REGEX
1351        COMPAT_CFLAGS += -Icompat/regex
1352        COMPAT_OBJS += compat/regex/regex.o
1353endif
1354ifdef NATIVE_CRLF
1355        BASIC_CFLAGS += -DNATIVE_CRLF
1356endif
1357
1358ifdef USE_NED_ALLOCATOR
1359       COMPAT_CFLAGS += -Icompat/nedmalloc
1360       COMPAT_OBJS += compat/nedmalloc/nedmalloc.o
1361endif
1362
1363ifdef GIT_TEST_CMP_USE_COPIED_CONTEXT
1364        export GIT_TEST_CMP_USE_COPIED_CONTEXT
1365endif
1366
1367ifndef NO_MSGFMT_EXTENDED_OPTIONS
1368        MSGFMT += --check --statistics
1369endif
1370
1371ifneq (,$(XDL_FAST_HASH))
1372        BASIC_CFLAGS += -DXDL_FAST_HASH
1373endif
1374
1375ifdef GMTIME_UNRELIABLE_ERRORS
1376        COMPAT_OBJS += compat/gmtime.o
1377        BASIC_CFLAGS += -DGMTIME_UNRELIABLE_ERRORS
1378endif
1379
1380ifdef HAVE_CLOCK_GETTIME
1381        BASIC_CFLAGS += -DHAVE_CLOCK_GETTIME
1382        EXTLIBS += -lrt
1383endif
1384
1385ifeq ($(TCLTK_PATH),)
1386NO_TCLTK = NoThanks
1387endif
1388
1389ifeq ($(PERL_PATH),)
1390NO_PERL = NoThanks
1391endif
1392
1393ifeq ($(PYTHON_PATH),)
1394NO_PYTHON = NoThanks
1395endif
1396
1397QUIET_SUBDIR0  = +$(MAKE) -C # space to separate -C and subdir
1398QUIET_SUBDIR1  =
1399
1400ifneq ($(findstring $(MAKEFLAGS),w),w)
1401PRINT_DIR = --no-print-directory
1402else # "make -w"
1403NO_SUBDIR = :
1404endif
1405
1406ifneq ($(findstring $(MAKEFLAGS),s),s)
1407ifndef V
1408        QUIET_CC       = @echo '   ' CC $@;
1409        QUIET_AR       = @echo '   ' AR $@;
1410        QUIET_LINK     = @echo '   ' LINK $@;
1411        QUIET_BUILT_IN = @echo '   ' BUILTIN $@;
1412        QUIET_GEN      = @echo '   ' GEN $@;
1413        QUIET_LNCP     = @echo '   ' LN/CP $@;
1414        QUIET_XGETTEXT = @echo '   ' XGETTEXT $@;
1415        QUIET_MSGFMT   = @echo '   ' MSGFMT $@;
1416        QUIET_GCOV     = @echo '   ' GCOV $@;
1417        QUIET_SP       = @echo '   ' SP $<;
1418        QUIET_RC       = @echo '   ' RC $@;
1419        QUIET_SUBDIR0  = +@subdir=
1420        QUIET_SUBDIR1  = ;$(NO_SUBDIR) echo '   ' SUBDIR $$subdir; \
1421                         $(MAKE) $(PRINT_DIR) -C $$subdir
1422        export V
1423        export QUIET_GEN
1424        export QUIET_BUILT_IN
1425endif
1426endif
1427
1428ifdef NO_INSTALL_HARDLINKS
1429        export NO_INSTALL_HARDLINKS
1430endif
1431
1432### profile feedback build
1433#
1434
1435# Can adjust this to be a global directory if you want to do extended
1436# data gathering
1437PROFILE_DIR := $(CURDIR)
1438
1439ifeq ("$(PROFILE)","GEN")
1440        BASIC_CFLAGS += -fprofile-generate=$(PROFILE_DIR) -DNO_NORETURN=1
1441        EXTLIBS += -lgcov
1442        export CCACHE_DISABLE = t
1443        V = 1
1444else
1445ifneq ("$(PROFILE)","")
1446        BASIC_CFLAGS += -fprofile-use=$(PROFILE_DIR) -fprofile-correction -DNO_NORETURN=1
1447        export CCACHE_DISABLE = t
1448        V = 1
1449endif
1450endif
1451
1452# Shell quote (do not use $(call) to accommodate ancient setups);
1453
1454SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER))
1455ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG))
1456ETC_GITATTRIBUTES_SQ = $(subst ','\'',$(ETC_GITATTRIBUTES))
1457
1458DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
1459bindir_SQ = $(subst ','\'',$(bindir))
1460bindir_relative_SQ = $(subst ','\'',$(bindir_relative))
1461mandir_relative_SQ = $(subst ','\'',$(mandir_relative))
1462infodir_relative_SQ = $(subst ','\'',$(infodir_relative))
1463localedir_SQ = $(subst ','\'',$(localedir))
1464gitexecdir_SQ = $(subst ','\'',$(gitexecdir))
1465template_dir_SQ = $(subst ','\'',$(template_dir))
1466htmldir_relative_SQ = $(subst ','\'',$(htmldir_relative))
1467prefix_SQ = $(subst ','\'',$(prefix))
1468gitwebdir_SQ = $(subst ','\'',$(gitwebdir))
1469
1470SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
1471PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
1472PYTHON_PATH_SQ = $(subst ','\'',$(PYTHON_PATH))
1473TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH))
1474DIFF_SQ = $(subst ','\'',$(DIFF))
1475PERLLIB_EXTRA_SQ = $(subst ','\'',$(PERLLIB_EXTRA))
1476
1477LIBS = $(GITLIBS) $(EXTLIBS)
1478
1479BASIC_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' \
1480        $(COMPAT_CFLAGS)
1481LIB_OBJS += $(COMPAT_OBJS)
1482
1483# Quote for C
1484
1485ifdef DEFAULT_EDITOR
1486DEFAULT_EDITOR_CQ = "$(subst ",\",$(subst \,\\,$(DEFAULT_EDITOR)))"
1487DEFAULT_EDITOR_CQ_SQ = $(subst ','\'',$(DEFAULT_EDITOR_CQ))
1488
1489BASIC_CFLAGS += -DDEFAULT_EDITOR='$(DEFAULT_EDITOR_CQ_SQ)'
1490endif
1491
1492ifdef DEFAULT_PAGER
1493DEFAULT_PAGER_CQ = "$(subst ",\",$(subst \,\\,$(DEFAULT_PAGER)))"
1494DEFAULT_PAGER_CQ_SQ = $(subst ','\'',$(DEFAULT_PAGER_CQ))
1495
1496BASIC_CFLAGS += -DDEFAULT_PAGER='$(DEFAULT_PAGER_CQ_SQ)'
1497endif
1498
1499ifdef SHELL_PATH
1500SHELL_PATH_CQ = "$(subst ",\",$(subst \,\\,$(SHELL_PATH)))"
1501SHELL_PATH_CQ_SQ = $(subst ','\'',$(SHELL_PATH_CQ))
1502
1503BASIC_CFLAGS += -DSHELL_PATH='$(SHELL_PATH_CQ_SQ)'
1504endif
1505
1506GIT_USER_AGENT_SQ = $(subst ','\'',$(GIT_USER_AGENT))
1507GIT_USER_AGENT_CQ = "$(subst ",\",$(subst \,\\,$(GIT_USER_AGENT)))"
1508GIT_USER_AGENT_CQ_SQ = $(subst ','\'',$(GIT_USER_AGENT_CQ))
1509GIT-USER-AGENT: FORCE
1510        @if test x'$(GIT_USER_AGENT_SQ)' != x"`cat GIT-USER-AGENT 2>/dev/null`"; then \
1511                echo '$(GIT_USER_AGENT_SQ)' >GIT-USER-AGENT; \
1512        fi
1513
1514ifdef DEFAULT_HELP_FORMAT
1515BASIC_CFLAGS += -DDEFAULT_HELP_FORMAT='"$(DEFAULT_HELP_FORMAT)"'
1516endif
1517
1518ALL_CFLAGS += $(BASIC_CFLAGS)
1519ALL_LDFLAGS += $(BASIC_LDFLAGS)
1520
1521export DIFF TAR INSTALL DESTDIR SHELL_PATH
1522
1523
1524### Build rules
1525
1526SHELL = $(SHELL_PATH)
1527
1528all:: shell_compatibility_test
1529
1530ifeq "$(PROFILE)" "BUILD"
1531all:: profile
1532endif
1533
1534profile:: profile-clean
1535        $(MAKE) PROFILE=GEN all
1536        $(MAKE) PROFILE=GEN -j1 test
1537        @if test -n "$$GIT_PERF_REPO" || test -d .git; then \
1538                $(MAKE) PROFILE=GEN -j1 perf; \
1539        else \
1540                echo "Skipping profile of perf tests..."; \
1541        fi
1542        $(MAKE) PROFILE=USE all
1543
1544profile-fast: profile-clean
1545        $(MAKE) PROFILE=GEN all
1546        $(MAKE) PROFILE=GEN -j1 perf
1547        $(MAKE) PROFILE=USE all
1548
1549
1550all:: $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS) $(OTHER_PROGRAMS) GIT-BUILD-OPTIONS
1551ifneq (,$X)
1552        $(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';)
1553endif
1554
1555all::
1556ifndef NO_TCLTK
1557        $(QUIET_SUBDIR0)git-gui $(QUIET_SUBDIR1) gitexecdir='$(gitexec_instdir_SQ)' all
1558        $(QUIET_SUBDIR0)gitk-git $(QUIET_SUBDIR1) all
1559endif
1560ifndef NO_PERL
1561        $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' localedir='$(localedir_SQ)' all
1562endif
1563        $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1) SHELL_PATH='$(SHELL_PATH_SQ)' PERL_PATH='$(PERL_PATH_SQ)'
1564
1565please_set_SHELL_PATH_to_a_more_modern_shell:
1566        @$$(:)
1567
1568shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell
1569
1570strip: $(PROGRAMS) git$X
1571        $(STRIP) $(STRIP_OPTS) $^
1572
1573### Target-specific flags and dependencies
1574
1575# The generic compilation pattern rule and automatically
1576# computed header dependencies (falling back to a dependency on
1577# LIB_H) are enough to describe how most targets should be built,
1578# but some targets are special enough to need something a little
1579# different.
1580#
1581# - When a source file "foo.c" #includes a generated header file,
1582#   we need to list that dependency for the "foo.o" target.
1583#
1584#   We also list it from other targets that are built from foo.c
1585#   like "foo.sp" and "foo.s", even though that is easy to forget
1586#   to do because the generated header is already present around
1587#   after a regular build attempt.
1588#
1589# - Some code depends on configuration kept in makefile
1590#   variables. The target-specific variable EXTRA_CPPFLAGS can
1591#   be used to convey that information to the C preprocessor
1592#   using -D options.
1593#
1594#   The "foo.o" target should have a corresponding dependency on
1595#   a file that changes when the value of the makefile variable
1596#   changes.  For example, targets making use of the
1597#   $(GIT_VERSION) variable depend on GIT-VERSION-FILE.
1598#
1599#   Technically the ".sp" and ".s" targets do not need this
1600#   dependency because they are force-built, but they get the
1601#   same dependency for consistency. This way, you do not have to
1602#   know how each target is implemented. And it means the
1603#   dependencies here will not need to change if the force-build
1604#   details change some day.
1605
1606git.sp git.s git.o: GIT-PREFIX
1607git.sp git.s git.o: EXTRA_CPPFLAGS = \
1608        '-DGIT_HTML_PATH="$(htmldir_relative_SQ)"' \
1609        '-DGIT_MAN_PATH="$(mandir_relative_SQ)"' \
1610        '-DGIT_INFO_PATH="$(infodir_relative_SQ)"'
1611
1612git$X: git.o GIT-LDFLAGS $(BUILTIN_OBJS) $(GITLIBS)
1613        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) git.o \
1614                $(BUILTIN_OBJS) $(LIBS)
1615
1616help.sp help.s help.o: common-cmds.h
1617
1618builtin/help.sp builtin/help.s builtin/help.o: common-cmds.h GIT-PREFIX
1619builtin/help.sp builtin/help.s builtin/help.o: EXTRA_CPPFLAGS = \
1620        '-DGIT_HTML_PATH="$(htmldir_relative_SQ)"' \
1621        '-DGIT_MAN_PATH="$(mandir_relative_SQ)"' \
1622        '-DGIT_INFO_PATH="$(infodir_relative_SQ)"'
1623
1624version.sp version.s version.o: GIT-VERSION-FILE GIT-USER-AGENT
1625version.sp version.s version.o: EXTRA_CPPFLAGS = \
1626        '-DGIT_VERSION="$(GIT_VERSION)"' \
1627        '-DGIT_USER_AGENT=$(GIT_USER_AGENT_CQ_SQ)'
1628
1629$(BUILT_INS): git$X
1630        $(QUIET_BUILT_IN)$(RM) $@ && \
1631        ln $< $@ 2>/dev/null || \
1632        ln -s $< $@ 2>/dev/null || \
1633        cp $< $@
1634
1635common-cmds.h: ./generate-cmdlist.sh command-list.txt
1636
1637common-cmds.h: $(wildcard Documentation/git-*.txt)
1638        $(QUIET_GEN)./generate-cmdlist.sh > $@+ && mv $@+ $@
1639
1640SCRIPT_DEFINES = $(SHELL_PATH_SQ):$(DIFF_SQ):$(GIT_VERSION):\
1641        $(localedir_SQ):$(NO_CURL):$(USE_GETTEXT_SCHEME):$(SANE_TOOL_PATH_SQ):\
1642        $(gitwebdir_SQ):$(PERL_PATH_SQ)
1643define cmd_munge_script
1644$(RM) $@ $@+ && \
1645sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
1646    -e 's|@SHELL_PATH@|$(SHELL_PATH_SQ)|' \
1647    -e 's|@@DIFF@@|$(DIFF_SQ)|' \
1648    -e 's|@@LOCALEDIR@@|$(localedir_SQ)|g' \
1649    -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
1650    -e 's/@@USE_GETTEXT_SCHEME@@/$(USE_GETTEXT_SCHEME)/g' \
1651    -e $(BROKEN_PATH_FIX) \
1652    -e 's|@@GITWEBDIR@@|$(gitwebdir_SQ)|g' \
1653    -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
1654    $@.sh >$@+
1655endef
1656
1657GIT-SCRIPT-DEFINES: FORCE
1658        @FLAGS='$(SCRIPT_DEFINES)'; \
1659            if test x"$$FLAGS" != x"`cat $@ 2>/dev/null`" ; then \
1660                echo >&2 "    * new script parameters"; \
1661                echo "$$FLAGS" >$@; \
1662            fi
1663
1664
1665$(SCRIPT_SH_GEN) : % : %.sh GIT-SCRIPT-DEFINES
1666        $(QUIET_GEN)$(cmd_munge_script) && \
1667        chmod +x $@+ && \
1668        mv $@+ $@
1669
1670$(SCRIPT_LIB) : % : %.sh GIT-SCRIPT-DEFINES
1671        $(QUIET_GEN)$(cmd_munge_script) && \
1672        mv $@+ $@
1673
1674git.res: git.rc GIT-VERSION-FILE
1675        $(QUIET_RC)$(RC) \
1676          $(join -DMAJOR= -DMINOR=, $(wordlist 1,2,$(subst -, ,$(subst ., ,$(GIT_VERSION))))) \
1677          -DGIT_VERSION="\\\"$(GIT_VERSION)\\\"" $< -o $@
1678
1679# This makes sure we depend on the NO_PERL setting itself.
1680$(SCRIPT_PERL_GEN): GIT-BUILD-OPTIONS
1681
1682ifndef NO_PERL
1683$(SCRIPT_PERL_GEN): perl/perl.mak
1684
1685perl/perl.mak: perl/PM.stamp
1686
1687perl/PM.stamp: FORCE
1688        $(QUIET_GEN)$(FIND) perl -type f -name '*.pm' | sort >$@+ && \
1689        { cmp $@+ $@ >/dev/null 2>/dev/null || mv $@+ $@; } && \
1690        $(RM) $@+
1691
1692perl/perl.mak: GIT-CFLAGS GIT-PREFIX perl/Makefile perl/Makefile.PL
1693        $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' $(@F)
1694
1695PERL_DEFINES = $(PERL_PATH_SQ):$(PERLLIB_EXTRA_SQ)
1696$(SCRIPT_PERL_GEN): % : %.perl perl/perl.mak GIT-PERL-DEFINES GIT-VERSION-FILE
1697        $(QUIET_GEN)$(RM) $@ $@+ && \
1698        INSTLIBDIR=`MAKEFLAGS= $(MAKE) -C perl -s --no-print-directory instlibdir` && \
1699        INSTLIBDIR_EXTRA='$(PERLLIB_EXTRA_SQ)' && \
1700        INSTLIBDIR="$$INSTLIBDIR$${INSTLIBDIR_EXTRA:+:$$INSTLIBDIR_EXTRA}" && \
1701        sed -e '1{' \
1702            -e '        s|#!.*perl|#!$(PERL_PATH_SQ)|' \
1703            -e '        h' \
1704            -e '        s=.*=use lib (split(/$(pathsep)/, $$ENV{GITPERLLIB} || "'"$$INSTLIBDIR"'"));=' \
1705            -e '        H' \
1706            -e '        x' \
1707            -e '}' \
1708            -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
1709            $< >$@+ && \
1710        chmod +x $@+ && \
1711        mv $@+ $@
1712
1713GIT-PERL-DEFINES: FORCE
1714        @FLAGS='$(PERL_DEFINES)'; \
1715            if test x"$$FLAGS" != x"`cat $@ 2>/dev/null`" ; then \
1716                echo >&2 "    * new perl-specific parameters"; \
1717                echo "$$FLAGS" >$@; \
1718            fi
1719
1720
1721.PHONY: gitweb
1722gitweb:
1723        $(QUIET_SUBDIR0)gitweb $(QUIET_SUBDIR1) all
1724
1725git-instaweb: git-instaweb.sh gitweb GIT-SCRIPT-DEFINES
1726        $(QUIET_GEN)$(cmd_munge_script) && \
1727        chmod +x $@+ && \
1728        mv $@+ $@
1729else # NO_PERL
1730$(SCRIPT_PERL_GEN) git-instaweb: % : unimplemented.sh
1731        $(QUIET_GEN)$(RM) $@ $@+ && \
1732        sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
1733            -e 's|@@REASON@@|NO_PERL=$(NO_PERL)|g' \
1734            unimplemented.sh >$@+ && \
1735        chmod +x $@+ && \
1736        mv $@+ $@
1737endif # NO_PERL
1738
1739# This makes sure we depend on the NO_PYTHON setting itself.
1740$(SCRIPT_PYTHON_GEN): GIT-BUILD-OPTIONS
1741
1742ifndef NO_PYTHON
1743$(SCRIPT_PYTHON_GEN): GIT-CFLAGS GIT-PREFIX GIT-PYTHON-VARS
1744$(SCRIPT_PYTHON_GEN): % : %.py
1745        $(QUIET_GEN)$(RM) $@ $@+ && \
1746        sed -e '1s|#!.*python|#!$(PYTHON_PATH_SQ)|' \
1747            $< >$@+ && \
1748        chmod +x $@+ && \
1749        mv $@+ $@
1750else # NO_PYTHON
1751$(SCRIPT_PYTHON_GEN): % : unimplemented.sh
1752        $(QUIET_GEN)$(RM) $@ $@+ && \
1753        sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
1754            -e 's|@@REASON@@|NO_PYTHON=$(NO_PYTHON)|g' \
1755            unimplemented.sh >$@+ && \
1756        chmod +x $@+ && \
1757        mv $@+ $@
1758endif # NO_PYTHON
1759
1760CONFIGURE_RECIPE = $(RM) configure configure.ac+ && \
1761                   sed -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
1762                        configure.ac >configure.ac+ && \
1763                   autoconf -o configure configure.ac+ && \
1764                   $(RM) configure.ac+
1765
1766configure: configure.ac GIT-VERSION-FILE
1767        $(QUIET_GEN)$(CONFIGURE_RECIPE)
1768
1769ifdef AUTOCONFIGURED
1770# We avoid depending on 'configure' here, because it gets rebuilt
1771# every time GIT-VERSION-FILE is modified, only to update the embedded
1772# version number string, which config.status does not care about.  We
1773# do want to recheck when the platform/environment detection logic
1774# changes, hence this depends on configure.ac.
1775config.status: configure.ac
1776        $(QUIET_GEN)$(CONFIGURE_RECIPE) && \
1777        if test -f config.status; then \
1778          ./config.status --recheck; \
1779        else \
1780          ./configure; \
1781        fi
1782reconfigure config.mak.autogen: config.status
1783        $(QUIET_GEN)./config.status
1784.PHONY: reconfigure # This is a convenience target.
1785endif
1786
1787XDIFF_OBJS += xdiff/xdiffi.o
1788XDIFF_OBJS += xdiff/xprepare.o
1789XDIFF_OBJS += xdiff/xutils.o
1790XDIFF_OBJS += xdiff/xemit.o
1791XDIFF_OBJS += xdiff/xmerge.o
1792XDIFF_OBJS += xdiff/xpatience.o
1793XDIFF_OBJS += xdiff/xhistogram.o
1794
1795VCSSVN_OBJS += vcs-svn/line_buffer.o
1796VCSSVN_OBJS += vcs-svn/sliding_window.o
1797VCSSVN_OBJS += vcs-svn/repo_tree.o
1798VCSSVN_OBJS += vcs-svn/fast_export.o
1799VCSSVN_OBJS += vcs-svn/svndiff.o
1800VCSSVN_OBJS += vcs-svn/svndump.o
1801
1802TEST_OBJS := $(patsubst test-%$X,test-%.o,$(TEST_PROGRAMS))
1803OBJECTS := $(LIB_OBJS) $(BUILTIN_OBJS) $(PROGRAM_OBJS) $(TEST_OBJS) \
1804        $(XDIFF_OBJS) \
1805        $(VCSSVN_OBJS) \
1806        git.o
1807ifndef NO_CURL
1808        OBJECTS += http.o http-walker.o remote-curl.o
1809endif
1810
1811dep_files := $(foreach f,$(OBJECTS),$(dir $f).depend/$(notdir $f).d)
1812dep_dirs := $(addsuffix .depend,$(sort $(dir $(OBJECTS))))
1813
1814ifeq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
1815$(dep_dirs):
1816        @mkdir -p $@
1817
1818missing_dep_dirs := $(filter-out $(wildcard $(dep_dirs)),$(dep_dirs))
1819dep_file = $(dir $@).depend/$(notdir $@).d
1820dep_args = -MF $(dep_file) -MQ $@ -MMD -MP
1821endif
1822
1823ifneq ($(COMPUTE_HEADER_DEPENDENCIES),yes)
1824dep_dirs =
1825missing_dep_dirs =
1826dep_args =
1827endif
1828
1829ASM_SRC := $(wildcard $(OBJECTS:o=S))
1830ASM_OBJ := $(ASM_SRC:S=o)
1831C_OBJ := $(filter-out $(ASM_OBJ),$(OBJECTS))
1832
1833.SUFFIXES:
1834
1835$(C_OBJ): %.o: %.c GIT-CFLAGS $(missing_dep_dirs)
1836        $(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
1837$(ASM_OBJ): %.o: %.S GIT-CFLAGS $(missing_dep_dirs)
1838        $(QUIET_CC)$(CC) -o $*.o -c $(dep_args) $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
1839
1840%.s: %.c GIT-CFLAGS FORCE
1841        $(QUIET_CC)$(CC) -o $@ -S $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) $<
1842
1843ifdef USE_COMPUTED_HEADER_DEPENDENCIES
1844# Take advantage of gcc's on-the-fly dependency generation
1845# See <http://gcc.gnu.org/gcc-3.0/features.html>.
1846dep_files_present := $(wildcard $(dep_files))
1847ifneq ($(dep_files_present),)
1848include $(dep_files_present)
1849endif
1850else
1851# Dependencies on header files, for platforms that do not support
1852# the gcc -MMD option.
1853#
1854# Dependencies on automatically generated headers such as common-cmds.h
1855# should _not_ be included here, since they are necessary even when
1856# building an object for the first time.
1857
1858$(OBJECTS): $(LIB_H)
1859endif
1860
1861exec_cmd.sp exec_cmd.s exec_cmd.o: GIT-PREFIX
1862exec_cmd.sp exec_cmd.s exec_cmd.o: EXTRA_CPPFLAGS = \
1863        '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' \
1864        '-DBINDIR="$(bindir_relative_SQ)"' \
1865        '-DPREFIX="$(prefix_SQ)"'
1866
1867builtin/init-db.sp builtin/init-db.s builtin/init-db.o: GIT-PREFIX
1868builtin/init-db.sp builtin/init-db.s builtin/init-db.o: EXTRA_CPPFLAGS = \
1869        -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"'
1870
1871config.sp config.s config.o: GIT-PREFIX
1872config.sp config.s config.o: EXTRA_CPPFLAGS = \
1873        -DETC_GITCONFIG='"$(ETC_GITCONFIG_SQ)"'
1874
1875attr.sp attr.s attr.o: GIT-PREFIX
1876attr.sp attr.s attr.o: EXTRA_CPPFLAGS = \
1877        -DETC_GITATTRIBUTES='"$(ETC_GITATTRIBUTES_SQ)"'
1878
1879gettext.sp gettext.s gettext.o: GIT-PREFIX
1880gettext.sp gettext.s gettext.o: EXTRA_CPPFLAGS = \
1881        -DGIT_LOCALE_PATH='"$(localedir_SQ)"'
1882
1883http-push.sp http.sp http-walker.sp remote-curl.sp: SPARSE_FLAGS += \
1884        -DCURL_DISABLE_TYPECHECK
1885
1886ifdef NO_EXPAT
1887http-walker.sp http-walker.s http-walker.o: EXTRA_CPPFLAGS = -DNO_EXPAT
1888endif
1889
1890ifdef NO_REGEX
1891compat/regex/regex.sp compat/regex/regex.o: EXTRA_CPPFLAGS = \
1892        -DGAWK -DNO_MBSUPPORT
1893endif
1894
1895ifdef USE_NED_ALLOCATOR
1896compat/nedmalloc/nedmalloc.sp compat/nedmalloc/nedmalloc.o: EXTRA_CPPFLAGS = \
1897        -DNDEBUG -DOVERRIDE_STRDUP -DREPLACE_SYSTEM_ALLOCATOR
1898compat/nedmalloc/nedmalloc.sp: SPARSE_FLAGS += -Wno-non-pointer-null
1899endif
1900
1901git-%$X: %.o GIT-LDFLAGS $(GITLIBS)
1902        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS)
1903
1904git-imap-send$X: imap-send.o GIT-LDFLAGS $(GITLIBS)
1905        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
1906                $(LIBS) $(OPENSSL_LINK) $(OPENSSL_LIBSSL) $(LIB_4_CRYPTO)
1907
1908git-http-fetch$X: http.o http-walker.o http-fetch.o GIT-LDFLAGS $(GITLIBS)
1909        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
1910                $(LIBS) $(CURL_LIBCURL)
1911git-http-push$X: http.o http-push.o GIT-LDFLAGS $(GITLIBS)
1912        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
1913                $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT)
1914
1915git-remote-testsvn$X: remote-testsvn.o GIT-LDFLAGS $(GITLIBS) $(VCSSVN_LIB)
1916        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) \
1917        $(VCSSVN_LIB)
1918
1919$(REMOTE_CURL_ALIASES): $(REMOTE_CURL_PRIMARY)
1920        $(QUIET_LNCP)$(RM) $@ && \
1921        ln $< $@ 2>/dev/null || \
1922        ln -s $< $@ 2>/dev/null || \
1923        cp $< $@
1924
1925$(REMOTE_CURL_PRIMARY): remote-curl.o http.o http-walker.o GIT-LDFLAGS $(GITLIBS)
1926        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
1927                $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT)
1928
1929$(LIB_FILE): $(LIB_OBJS)
1930        $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $^
1931
1932$(XDIFF_LIB): $(XDIFF_OBJS)
1933        $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $^
1934
1935$(VCSSVN_LIB): $(VCSSVN_OBJS)
1936        $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $^
1937
1938export DEFAULT_EDITOR DEFAULT_PAGER
1939
1940doc:
1941        $(MAKE) -C Documentation all
1942
1943man:
1944        $(MAKE) -C Documentation man
1945
1946html:
1947        $(MAKE) -C Documentation html
1948
1949info:
1950        $(MAKE) -C Documentation info
1951
1952pdf:
1953        $(MAKE) -C Documentation pdf
1954
1955XGETTEXT_FLAGS = \
1956        --force-po \
1957        --add-comments=TRANSLATORS: \
1958        --msgid-bugs-address="Git Mailing List <git@vger.kernel.org>" \
1959        --from-code=UTF-8
1960XGETTEXT_FLAGS_C = $(XGETTEXT_FLAGS) --language=C \
1961        --keyword=_ --keyword=N_ --keyword="Q_:1,2"
1962XGETTEXT_FLAGS_SH = $(XGETTEXT_FLAGS) --language=Shell \
1963        --keyword=gettextln --keyword=eval_gettextln
1964XGETTEXT_FLAGS_PERL = $(XGETTEXT_FLAGS) --keyword=__ --language=Perl
1965LOCALIZED_C = $(C_OBJ:o=c) $(LIB_H) $(GENERATED_H)
1966LOCALIZED_SH = $(SCRIPT_SH)
1967LOCALIZED_PERL = $(SCRIPT_PERL)
1968
1969ifdef XGETTEXT_INCLUDE_TESTS
1970LOCALIZED_C += t/t0200/test.c
1971LOCALIZED_SH += t/t0200/test.sh
1972LOCALIZED_PERL += t/t0200/test.perl
1973endif
1974
1975po/git.pot: $(GENERATED_H) FORCE
1976        $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ $(XGETTEXT_FLAGS_C) $(LOCALIZED_C)
1977        $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ --join-existing $(XGETTEXT_FLAGS_SH) \
1978                $(LOCALIZED_SH)
1979        $(QUIET_XGETTEXT)$(XGETTEXT) -o$@+ --join-existing $(XGETTEXT_FLAGS_PERL) \
1980                $(LOCALIZED_PERL)
1981        mv $@+ $@
1982
1983pot: po/git.pot
1984
1985POFILES := $(wildcard po/*.po)
1986MOFILES := $(patsubst po/%.po,po/build/locale/%/LC_MESSAGES/git.mo,$(POFILES))
1987
1988ifndef NO_GETTEXT
1989all:: $(MOFILES)
1990endif
1991
1992po/build/locale/%/LC_MESSAGES/git.mo: po/%.po
1993        $(QUIET_MSGFMT)mkdir -p $(dir $@) && $(MSGFMT) -o $@ $<
1994
1995FIND_SOURCE_FILES = ( git ls-files '*.[hcS]' 2>/dev/null || \
1996                        $(FIND) . \( -name .git -type d -prune \) \
1997                                -o \( -name '*.[hcS]' -type f -print \) )
1998
1999$(ETAGS_TARGET): FORCE
2000        $(RM) $(ETAGS_TARGET)
2001        $(FIND_SOURCE_FILES) | xargs etags -a -o $(ETAGS_TARGET)
2002
2003tags: FORCE
2004        $(RM) tags
2005        $(FIND_SOURCE_FILES) | xargs ctags -a
2006
2007cscope:
2008        $(RM) cscope*
2009        $(FIND_SOURCE_FILES) | xargs cscope -b
2010
2011### Detect prefix changes
2012TRACK_PREFIX = $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ):\
2013                $(localedir_SQ)
2014
2015GIT-PREFIX: FORCE
2016        @FLAGS='$(TRACK_PREFIX)'; \
2017        if test x"$$FLAGS" != x"`cat GIT-PREFIX 2>/dev/null`" ; then \
2018                echo >&2 "    * new prefix flags"; \
2019                echo "$$FLAGS" >GIT-PREFIX; \
2020        fi
2021
2022TRACK_CFLAGS = $(CC):$(subst ','\'',$(ALL_CFLAGS)):$(USE_GETTEXT_SCHEME)
2023
2024GIT-CFLAGS: FORCE
2025        @FLAGS='$(TRACK_CFLAGS)'; \
2026            if test x"$$FLAGS" != x"`cat GIT-CFLAGS 2>/dev/null`" ; then \
2027                echo >&2 "    * new build flags"; \
2028                echo "$$FLAGS" >GIT-CFLAGS; \
2029            fi
2030
2031TRACK_LDFLAGS = $(subst ','\'',$(ALL_LDFLAGS))
2032
2033GIT-LDFLAGS: FORCE
2034        @FLAGS='$(TRACK_LDFLAGS)'; \
2035            if test x"$$FLAGS" != x"`cat GIT-LDFLAGS 2>/dev/null`" ; then \
2036                echo >&2 "    * new link flags"; \
2037                echo "$$FLAGS" >GIT-LDFLAGS; \
2038            fi
2039
2040# We need to apply sq twice, once to protect from the shell
2041# that runs GIT-BUILD-OPTIONS, and then again to protect it
2042# and the first level quoting from the shell that runs "echo".
2043GIT-BUILD-OPTIONS: FORCE
2044        @echo SHELL_PATH=\''$(subst ','\'',$(SHELL_PATH_SQ))'\' >$@
2045        @echo PERL_PATH=\''$(subst ','\'',$(PERL_PATH_SQ))'\' >>$@
2046        @echo DIFF=\''$(subst ','\'',$(subst ','\'',$(DIFF)))'\' >>$@
2047        @echo PYTHON_PATH=\''$(subst ','\'',$(PYTHON_PATH_SQ))'\' >>$@
2048        @echo TAR=\''$(subst ','\'',$(subst ','\'',$(TAR)))'\' >>$@
2049        @echo NO_CURL=\''$(subst ','\'',$(subst ','\'',$(NO_CURL)))'\' >>$@
2050        @echo USE_LIBPCRE=\''$(subst ','\'',$(subst ','\'',$(USE_LIBPCRE)))'\' >>$@
2051        @echo NO_PERL=\''$(subst ','\'',$(subst ','\'',$(NO_PERL)))'\' >>$@
2052        @echo NO_PYTHON=\''$(subst ','\'',$(subst ','\'',$(NO_PYTHON)))'\' >>$@
2053        @echo NO_UNIX_SOCKETS=\''$(subst ','\'',$(subst ','\'',$(NO_UNIX_SOCKETS)))'\' >>$@
2054ifdef TEST_OUTPUT_DIRECTORY
2055        @echo TEST_OUTPUT_DIRECTORY=\''$(subst ','\'',$(subst ','\'',$(TEST_OUTPUT_DIRECTORY)))'\' >>$@
2056endif
2057ifdef GIT_TEST_OPTS
2058        @echo GIT_TEST_OPTS=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_OPTS)))'\' >>$@
2059endif
2060ifdef GIT_TEST_CMP
2061        @echo GIT_TEST_CMP=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_CMP)))'\' >>$@
2062endif
2063ifdef GIT_TEST_CMP_USE_COPIED_CONTEXT
2064        @echo GIT_TEST_CMP_USE_COPIED_CONTEXT=YesPlease >>$@
2065endif
2066        @echo NO_GETTEXT=\''$(subst ','\'',$(subst ','\'',$(NO_GETTEXT)))'\' >>$@
2067        @echo GETTEXT_POISON=\''$(subst ','\'',$(subst ','\'',$(GETTEXT_POISON)))'\' >>$@
2068ifdef GIT_PERF_REPEAT_COUNT
2069        @echo GIT_PERF_REPEAT_COUNT=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_REPEAT_COUNT)))'\' >>$@
2070endif
2071ifdef GIT_PERF_REPO
2072        @echo GIT_PERF_REPO=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_REPO)))'\' >>$@
2073endif
2074ifdef GIT_PERF_LARGE_REPO
2075        @echo GIT_PERF_LARGE_REPO=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_LARGE_REPO)))'\' >>$@
2076endif
2077ifdef GIT_PERF_MAKE_OPTS
2078        @echo GIT_PERF_MAKE_OPTS=\''$(subst ','\'',$(subst ','\'',$(GIT_PERF_MAKE_OPTS)))'\' >>$@
2079endif
2080ifdef TEST_GIT_INDEX_VERSION
2081        @echo TEST_GIT_INDEX_VERSION=\''$(subst ','\'',$(subst ','\'',$(TEST_GIT_INDEX_VERSION)))'\' >>$@
2082endif
2083
2084### Detect Python interpreter path changes
2085ifndef NO_PYTHON
2086TRACK_PYTHON = $(subst ','\'',-DPYTHON_PATH='$(PYTHON_PATH_SQ)')
2087
2088GIT-PYTHON-VARS: FORCE
2089        @VARS='$(TRACK_PYTHON)'; \
2090            if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \
2091                echo >&2 "    * new Python interpreter location"; \
2092                echo "$$VARS" >$@; \
2093            fi
2094endif
2095
2096test_bindir_programs := $(patsubst %,bin-wrappers/%,$(BINDIR_PROGRAMS_NEED_X) $(BINDIR_PROGRAMS_NO_X) $(TEST_PROGRAMS_NEED_X))
2097
2098all:: $(TEST_PROGRAMS) $(test_bindir_programs)
2099all:: $(NO_INSTALL)
2100
2101bin-wrappers/%: wrap-for-bin.sh
2102        @mkdir -p bin-wrappers
2103        $(QUIET_GEN)sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
2104             -e 's|@@BUILD_DIR@@|$(shell pwd)|' \
2105             -e 's|@@PROG@@|$(@F)|' < $< > $@ && \
2106        chmod +x $@
2107
2108# GNU make supports exporting all variables by "export" without parameters.
2109# However, the environment gets quite big, and some programs have problems
2110# with that.
2111
2112export NO_SVN_TESTS
2113export TEST_NO_MALLOC_CHECK
2114
2115### Testing rules
2116
2117test: all
2118        $(MAKE) -C t/ all
2119
2120perf: all
2121        $(MAKE) -C t/perf/ all
2122
2123.PHONY: test perf
2124
2125test-ctype$X: ctype.o
2126
2127test-date$X: date.o ctype.o
2128
2129test-delta$X: diff-delta.o patch-delta.o
2130
2131test-line-buffer$X: vcs-svn/lib.a
2132
2133test-parse-options$X: parse-options.o parse-options-cb.o
2134
2135test-svn-fe$X: vcs-svn/lib.a
2136
2137.PRECIOUS: $(TEST_OBJS)
2138
2139test-%$X: test-%.o GIT-LDFLAGS $(GITLIBS)
2140        $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(filter %.a,$^) $(LIBS)
2141
2142check-sha1:: test-sha1$X
2143        ./test-sha1.sh
2144
2145SP_OBJ = $(patsubst %.o,%.sp,$(C_OBJ))
2146
2147$(SP_OBJ): %.sp: %.c GIT-CFLAGS FORCE
2148        $(QUIET_SP)cgcc -no-compile $(ALL_CFLAGS) $(EXTRA_CPPFLAGS) \
2149                $(SPARSE_FLAGS) $<
2150
2151.PHONY: sparse $(SP_OBJ)
2152sparse: $(SP_OBJ)
2153
2154check: common-cmds.h
2155        @if sparse; \
2156        then \
2157                echo 2>&1 "Use 'make sparse' instead"; \
2158                $(MAKE) --no-print-directory sparse; \
2159        else \
2160                echo 2>&1 "Did you mean 'make test'?"; \
2161                exit 1; \
2162        fi
2163
2164### Installation rules
2165
2166ifneq ($(filter /%,$(firstword $(template_dir))),)
2167template_instdir = $(template_dir)
2168else
2169template_instdir = $(prefix)/$(template_dir)
2170endif
2171export template_instdir
2172
2173ifneq ($(filter /%,$(firstword $(gitexecdir))),)
2174gitexec_instdir = $(gitexecdir)
2175else
2176gitexec_instdir = $(prefix)/$(gitexecdir)
2177endif
2178gitexec_instdir_SQ = $(subst ','\'',$(gitexec_instdir))
2179export gitexec_instdir
2180
2181ifneq ($(filter /%,$(firstword $(mergetoolsdir))),)
2182mergetools_instdir = $(mergetoolsdir)
2183else
2184mergetools_instdir = $(prefix)/$(mergetoolsdir)
2185endif
2186mergetools_instdir_SQ = $(subst ','\'',$(mergetools_instdir))
2187
2188install_bindir_programs := $(patsubst %,%$X,$(BINDIR_PROGRAMS_NEED_X)) $(BINDIR_PROGRAMS_NO_X)
2189
2190profile-install: profile
2191        $(MAKE) install
2192
2193profile-fast-install: profile-fast
2194        $(MAKE) install
2195
2196install: all
2197        $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)'
2198        $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2199        $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2200        $(INSTALL) -m 644 $(SCRIPT_LIB) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)'
2201        $(INSTALL) $(install_bindir_programs) '$(DESTDIR_SQ)$(bindir_SQ)'
2202        $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install
2203        $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(mergetools_instdir_SQ)'
2204        $(INSTALL) -m 644 mergetools/* '$(DESTDIR_SQ)$(mergetools_instdir_SQ)'
2205ifndef NO_GETTEXT
2206        $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(localedir_SQ)'
2207        (cd po/build/locale && $(TAR) cf - .) | \
2208        (cd '$(DESTDIR_SQ)$(localedir_SQ)' && umask 022 && $(TAR) xof -)
2209endif
2210ifndef NO_PERL
2211        $(MAKE) -C perl prefix='$(prefix_SQ)' DESTDIR='$(DESTDIR_SQ)' install
2212        $(MAKE) -C gitweb install
2213endif
2214ifndef NO_TCLTK
2215        $(MAKE) -C gitk-git install
2216        $(MAKE) -C git-gui gitexecdir='$(gitexec_instdir_SQ)' install
2217endif
2218ifneq (,$X)
2219        $(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';)
2220endif
2221
2222        bindir=$$(cd '$(DESTDIR_SQ)$(bindir_SQ)' && pwd) && \
2223        execdir=$$(cd '$(DESTDIR_SQ)$(gitexec_instdir_SQ)' && pwd) && \
2224        { test "$$bindir/" = "$$execdir/" || \
2225          for p in git$X $(filter $(install_bindir_programs),$(ALL_PROGRAMS)); do \
2226                $(RM) "$$execdir/$$p" && \
2227                test -z "$(NO_INSTALL_HARDLINKS)$(NO_CROSS_DIRECTORY_HARDLINKS)" && \
2228                ln "$$bindir/$$p" "$$execdir/$$p" 2>/dev/null || \
2229                cp "$$bindir/$$p" "$$execdir/$$p" || exit; \
2230          done; \
2231        } && \
2232        for p in $(filter $(install_bindir_programs),$(BUILT_INS)); do \
2233                $(RM) "$$bindir/$$p" && \
2234                test -z "$(NO_INSTALL_HARDLINKS)" && \
2235                ln "$$bindir/git$X" "$$bindir/$$p" 2>/dev/null || \
2236                ln -s "git$X" "$$bindir/$$p" 2>/dev/null || \
2237                cp "$$bindir/git$X" "$$bindir/$$p" || exit; \
2238        done && \
2239        for p in $(BUILT_INS); do \
2240                $(RM) "$$execdir/$$p" && \
2241                test -z "$(NO_INSTALL_HARDLINKS)" && \
2242                ln "$$execdir/git$X" "$$execdir/$$p" 2>/dev/null || \
2243                ln -s "git$X" "$$execdir/$$p" 2>/dev/null || \
2244                cp "$$execdir/git$X" "$$execdir/$$p" || exit; \
2245        done && \
2246        remote_curl_aliases="$(REMOTE_CURL_ALIASES)" && \
2247        for p in $$remote_curl_aliases; do \
2248                $(RM) "$$execdir/$$p" && \
2249                test -z "$(NO_INSTALL_HARDLINKS)" && \
2250                ln "$$execdir/git-remote-http$X" "$$execdir/$$p" 2>/dev/null || \
2251                ln -s "git-remote-http$X" "$$execdir/$$p" 2>/dev/null || \
2252                cp "$$execdir/git-remote-http$X" "$$execdir/$$p" || exit; \
2253        done && \
2254        ./check_bindir "z$$bindir" "z$$execdir" "$$bindir/git-add$X"
2255
2256install-gitweb:
2257        $(MAKE) -C gitweb install
2258
2259install-doc:
2260        $(MAKE) -C Documentation install
2261
2262install-man:
2263        $(MAKE) -C Documentation install-man
2264
2265install-html:
2266        $(MAKE) -C Documentation install-html
2267
2268install-info:
2269        $(MAKE) -C Documentation install-info
2270
2271install-pdf:
2272        $(MAKE) -C Documentation install-pdf
2273
2274quick-install-doc:
2275        $(MAKE) -C Documentation quick-install
2276
2277quick-install-man:
2278        $(MAKE) -C Documentation quick-install-man
2279
2280quick-install-html:
2281        $(MAKE) -C Documentation quick-install-html
2282
2283
2284
2285### Maintainer's dist rules
2286
2287git.spec: git.spec.in GIT-VERSION-FILE
2288        sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@+
2289        mv $@+ $@
2290
2291GIT_TARNAME = git-$(GIT_VERSION)
2292dist: git.spec git-archive$(X) configure
2293        ./git-archive --format=tar \
2294                --prefix=$(GIT_TARNAME)/ HEAD^{tree} > $(GIT_TARNAME).tar
2295        @mkdir -p $(GIT_TARNAME)
2296        @cp git.spec configure $(GIT_TARNAME)
2297        @echo $(GIT_VERSION) > $(GIT_TARNAME)/version
2298        @$(MAKE) -C git-gui TARDIR=../$(GIT_TARNAME)/git-gui dist-version
2299        $(TAR) rf $(GIT_TARNAME).tar \
2300                $(GIT_TARNAME)/git.spec \
2301                $(GIT_TARNAME)/configure \
2302                $(GIT_TARNAME)/version \
2303                $(GIT_TARNAME)/git-gui/version
2304        @$(RM) -r $(GIT_TARNAME)
2305        gzip -f -9 $(GIT_TARNAME).tar
2306
2307rpm: dist
2308        $(RPMBUILD) \
2309                --define "_source_filedigest_algorithm md5" \
2310                --define "_binary_filedigest_algorithm md5" \
2311                -ta $(GIT_TARNAME).tar.gz
2312
2313htmldocs = git-htmldocs-$(GIT_VERSION)
2314manpages = git-manpages-$(GIT_VERSION)
2315dist-doc:
2316        $(RM) -r .doc-tmp-dir
2317        mkdir .doc-tmp-dir
2318        $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc
2319        cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar .
2320        gzip -n -9 -f $(htmldocs).tar
2321        :
2322        $(RM) -r .doc-tmp-dir
2323        mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7
2324        $(MAKE) -C Documentation DESTDIR=./ \
2325                man1dir=../.doc-tmp-dir/man1 \
2326                man5dir=../.doc-tmp-dir/man5 \
2327                man7dir=../.doc-tmp-dir/man7 \
2328                install
2329        cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar .
2330        gzip -n -9 -f $(manpages).tar
2331        $(RM) -r .doc-tmp-dir
2332
2333### Cleaning rules
2334
2335distclean: clean
2336        $(RM) configure
2337        $(RM) config.log config.status config.cache
2338        $(RM) config.mak.autogen config.mak.append
2339        $(RM) -r autom4te.cache
2340
2341profile-clean:
2342        $(RM) $(addsuffix *.gcda,$(addprefix $(PROFILE_DIR)/, $(object_dirs)))
2343        $(RM) $(addsuffix *.gcno,$(addprefix $(PROFILE_DIR)/, $(object_dirs)))
2344
2345clean: profile-clean coverage-clean
2346        $(RM) *.o *.res block-sha1/*.o ppc/*.o compat/*.o compat/*/*.o
2347        $(RM) xdiff/*.o vcs-svn/*.o ewah/*.o builtin/*.o
2348        $(RM) $(LIB_FILE) $(XDIFF_LIB) $(VCSSVN_LIB)
2349        $(RM) $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS) git$X
2350        $(RM) $(TEST_PROGRAMS) $(NO_INSTALL)
2351        $(RM) -r bin-wrappers $(dep_dirs)
2352        $(RM) -r po/build/
2353        $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h $(ETAGS_TARGET) tags cscope*
2354        $(RM) -r $(GIT_TARNAME) .doc-tmp-dir
2355        $(RM) $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz
2356        $(RM) $(htmldocs).tar.gz $(manpages).tar.gz
2357        $(MAKE) -C Documentation/ clean
2358ifndef NO_PERL
2359        $(MAKE) -C gitweb clean
2360        $(MAKE) -C perl clean
2361endif
2362        $(MAKE) -C templates/ clean
2363        $(MAKE) -C t/ clean
2364ifndef NO_TCLTK
2365        $(MAKE) -C gitk-git clean
2366        $(MAKE) -C git-gui clean
2367endif
2368        $(RM) GIT-VERSION-FILE GIT-CFLAGS GIT-LDFLAGS GIT-BUILD-OPTIONS
2369        $(RM) GIT-USER-AGENT GIT-PREFIX
2370        $(RM) GIT-SCRIPT-DEFINES GIT-PERL-DEFINES GIT-PYTHON-VARS
2371
2372.PHONY: all install profile-clean clean strip
2373.PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell
2374.PHONY: FORCE cscope
2375
2376### Check documentation
2377#
2378ALL_COMMANDS = $(ALL_PROGRAMS) $(SCRIPT_LIB) $(BUILT_INS)
2379ALL_COMMANDS += git
2380ALL_COMMANDS += gitk
2381ALL_COMMANDS += gitweb
2382ALL_COMMANDS += git-gui git-citool
2383check-docs::
2384        @(for v in $(ALL_COMMANDS); \
2385        do \
2386                case "$$v" in \
2387                git-merge-octopus | git-merge-ours | git-merge-recursive | \
2388                git-merge-resolve | git-merge-subtree | \
2389                git-fsck-objects | git-init-db | \
2390                git-remote-* | git-stage | \
2391                git-?*--?* ) continue ;; \
2392                esac ; \
2393                test -f "Documentation/$$v.txt" || \
2394                echo "no doc: $$v"; \
2395                sed -e '/^#/d' command-list.txt | \
2396                grep -q "^$$v[  ]" || \
2397                case "$$v" in \
2398                git) ;; \
2399                *) echo "no link: $$v";; \
2400                esac ; \
2401        done; \
2402        ( \
2403                sed -e '/^#/d' \
2404                    -e 's/[     ].*//' \
2405                    -e 's/^/listed /' command-list.txt; \
2406                $(MAKE) -C Documentation print-man1 | \
2407                grep '\.txt$$' | \
2408                sed -e 's|Documentation/|documented |' \
2409                    -e 's/\.txt//'; \
2410        ) | while read how cmd; \
2411        do \
2412                case " $(ALL_COMMANDS) " in \
2413                *" $$cmd "*)    ;; \
2414                *) echo "removed but $$how: $$cmd" ;; \
2415                esac; \
2416        done ) | sort
2417
2418### Make sure built-ins do not have dups and listed in git.c
2419#
2420check-builtins::
2421        ./check-builtins.sh
2422
2423### Test suite coverage testing
2424#
2425.PHONY: coverage coverage-clean coverage-compile coverage-test coverage-report
2426.PHONY: coverage-clean-results
2427
2428coverage:
2429        $(MAKE) coverage-test
2430        $(MAKE) coverage-untested-functions
2431
2432object_dirs := $(sort $(dir $(OBJECTS)))
2433coverage-clean-results:
2434        $(RM) $(addsuffix *.gcov,$(object_dirs))
2435        $(RM) $(addsuffix *.gcda,$(object_dirs))
2436        $(RM) coverage-untested-functions
2437        $(RM) -r cover_db/
2438        $(RM) -r cover_db_html/
2439
2440coverage-clean: coverage-clean-results
2441        $(RM) $(addsuffix *.gcno,$(object_dirs))
2442
2443COVERAGE_CFLAGS = $(CFLAGS) -O0 -ftest-coverage -fprofile-arcs
2444COVERAGE_LDFLAGS = $(CFLAGS)  -O0 -lgcov
2445GCOVFLAGS = --preserve-paths --branch-probabilities --all-blocks
2446
2447coverage-compile:
2448        $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" all
2449
2450coverage-test: coverage-clean-results coverage-compile
2451        $(MAKE) CFLAGS="$(COVERAGE_CFLAGS)" LDFLAGS="$(COVERAGE_LDFLAGS)" \
2452                DEFAULT_TEST_TARGET=test -j1 test
2453
2454coverage-report:
2455        $(QUIET_GCOV)for dir in $(object_dirs); do \
2456                $(GCOV) $(GCOVFLAGS) --object-directory=$$dir $$dir*.c || exit; \
2457        done
2458
2459coverage-untested-functions: coverage-report
2460        grep '^function.*called 0 ' *.c.gcov \
2461                | sed -e 's/\([^:]*\)\.gcov: *function \([^ ]*\) called.*/\1: \2/' \
2462                > coverage-untested-functions
2463
2464cover_db: coverage-report
2465        gcov2perl -db cover_db *.gcov
2466
2467cover_db_html: cover_db
2468        cover -report html -outputdir cover_db_html cover_db
2469