Merge branch 'maint'
[git/git.git] / Makefile
CommitLineData
2731d048 1# The default target of this Makefile is...
6fc301bb 2all::
2731d048 3
2314c947 4# Define V=1 to have a more verbose compile.
74f2b2a8 5#
765ac8ec
LT
6# Define NO_OPENSSL environment variable if you do not have OpenSSL.
7# This also implies MOZILLA_SHA1.
2cb45e95 8#
58e60dd2
NH
9# Define NO_CURL if you do not have curl installed. git-http-pull and
10# git-http-push are not built, and you cannot use http:// and https://
11# transports.
b2c0bd65 12#
6d9bbc50
PM
13# Define CURLDIR=/foo/bar if your curl header and library files are in
14# /foo/bar/include and /foo/bar/lib directories.
15#
58e60dd2
NH
16# Define NO_EXPAT if you do not have expat installed. git-http-push is
17# not built, and you cannot push using http:// and https:// transports.
18#
35a730f0
JH
19# Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent.
20#
63be37b0
JH
21# Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks
22# d_type in struct dirent (latest Cygwin -- will be fixed soonish).
23#
579d1fbf
RJ
24# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.)
25# do not support the 'size specifiers' introduced by C99, namely ll, hh,
26# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t).
465e649d 27# some C compilers supported these specifiers prior to C99 as an extension.
579d1fbf 28#
ef34af24
LT
29# Define NO_STRCASESTR if you don't have strcasestr.
30#
817151e6
PE
31# Define NO_STRLCPY if you don't have strlcpy.
32#
bc6b4f52
JR
33# Define NO_STRTOUMAX if you don't have strtoumax in the C library.
34# If your compiler also does not support long long or does not have
35# strtoull, define NO_STRTOULL.
36#
e40b61fb
JR
37# Define NO_SETENV if you don't have setenv in the C library.
38#
9f0bb90d
JH
39# Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link.
40# Enable it on Windows. By default, symrefs are still used.
2fabd217 41#
02853588 42# Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability
60d02ccc
EW
43# tests. These tests take up a significant amount of the total test time
44# but are not needed unless you plan to talk to SVN repos.
45#
8eb38cad
SP
46# Define NO_FINK if you are building on Darwin/Mac OS X, have Fink
47# installed in /sw, but don't want GIT to link against any libraries
48# installed there. If defined you may specify your own (or Fink's)
49# include directories and library directories by defining CFLAGS
50# and LDFLAGS appropriately.
51#
52# Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X,
53# have DarwinPorts installed in /opt/local, but don't want GIT to
54# link against any libraries installed there. If defined you may
55# specify your own (or DarwinPort's) include directories and
56# library directories by defining CFLAGS and LDFLAGS appropriately.
57#
5bdac8b3
PB
58# Define PPC_SHA1 environment variable when running make to make use of
59# a bundled SHA1 routine optimized for PowerPC.
597c9cc5 60#
7c6ef2f2
NP
61# Define ARM_SHA1 environment variable when running make to make use of
62# a bundled SHA1 routine optimized for ARM.
63#
f6af75d2
JH
64# Define MOZILLA_SHA1 environment variable when running make to make use of
65# a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast
66# on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default
67# choice) has very fast version optimized for i586.
68#
597c9cc5 69# Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin).
f0ebff0d 70#
597c9cc5 71# Define NEEDS_LIBICONV if linking with libc is not enough (Darwin).
f0ebff0d
PM
72#
73# Define NEEDS_SOCKET if linking with libc is not enough (SunOS,
74# Patrick Mauritz).
75#
730d48a2
JS
76# Define NO_MMAP if you want to avoid mmap.
77#
6900679c
SH
78# Define NO_PREAD if you have a problem with pread() system call (e.g.
79# cygwin.dll before v1.5.22).
80#
1510fea7
SP
81# Define NO_FAST_WORKING_DIRECTORY if accessing objects in pack files is
82# generally faster on your platform than accessing the working directory.
83#
c869753e
SP
84# Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support
85# the executable mode bit, but doesn't really do so.
86#
49744d63
PA
87# Define NO_IPV6 if you lack IPv6 support and getaddrinfo().
88#
bdc37f5a
JH
89# Define NO_SOCKADDR_STORAGE if your platform does not have struct
90# sockaddr_storage.
91#
b6e56eca
FP
92# Define NO_ICONV if your libc does not properly support iconv.
93#
fd547a97
RJ
94# Define OLD_ICONV if your library has an old iconv(), where the second
95# (input buffer pointer) parameter is declared with type (const char **).
96#
20648877
MK
97# Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib"
98# that tells runtime paths to dynamic libraries;
99# "-Wl,-rpath=/path/lib" is used instead.
bbfc63dd 100#
5bdac8b3
PB
101# Define USE_NSEC below if you want git to care about sub-second file mtimes
102# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
103# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
104# randomly break unless your underlying filesystem supports those sub-second
105# times (my ext3 doesn't).
f6af75d2 106#
5bdac8b3
PB
107# Define USE_STDEV below if you want git to care about the underlying device
108# change being considered an inode change from the update-cache perspective.
f848718a 109#
4c7100a9
JH
110# Define ASCIIDOC8 if you want to format documentation with AsciiDoc 8
111#
f848718a
AR
112# Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's
113# MakeMaker (e.g. using ActiveState under Cygwin).
114#
3cfaf11b
ER
115# Define NO_TCLTK if you do not want Tcl/Tk GUI.
116#
5f5dbd71
SP
117# The TCL_PATH variable governs the location of the Tcl interpreter
118# used to optimize git-gui for your system. Only used if NO_TCLTK
119# is not set. Defaults to the bare 'tclsh'.
120#
121# The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter.
81b63c70
ER
122# If not set it defaults to the bare 'wish'. If it is set to the empty
123# string then NO_TCLTK will be forced (this is used by configure script).
124#
5bdac8b3 125
9b88fcef 126GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
36546385 127 @$(SHELL_PATH) ./GIT-VERSION-GEN
9b88fcef 128-include GIT-VERSION-FILE
a9db2974 129
e15f5451
PJ
130uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
131uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not')
132uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not')
133uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not')
134uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not')
135
94d23317 136# CFLAGS and LDFLAGS are for the users to override from the command line.
12aa7456 137
b05701c5 138CFLAGS = -g -O2 -Wall
94d23317 139LDFLAGS =
12aa7456 140ALL_CFLAGS = $(CFLAGS)
94d23317 141ALL_LDFLAGS = $(LDFLAGS)
4dc00021 142STRIP ?= strip
29c2cce4 143
b05701c5
PR
144prefix = $(HOME)
145bindir = $(prefix)/bin
e15f5451 146gitexecdir = $(bindir)
9354768a 147sharedir = $(prefix)/share
d52fd42a 148template_dir = $(sharedir)/git-core/templates
b51b8bbf
JT
149ifeq ($(prefix),/usr)
150sysconfdir = /etc
151else
152sysconfdir = $(prefix)/etc
153endif
154ETC_GITCONFIG = $(sysconfdir)/gitconfig
a682ef9f 155# DESTDIR=
5c2a7fbc 156
5d043a3d 157# default configuration for gitweb
c8d138a8 158GITWEB_CONFIG = gitweb_config.perl
2de21fac 159GITWEB_HOME_LINK_STR = projects
5d043a3d
MW
160GITWEB_SITENAME =
161GITWEB_PROJECTROOT = /pub/git
32f4aacc
ML
162GITWEB_EXPORT_OK =
163GITWEB_STRICT_EXPORT =
19a8721e 164GITWEB_BASE_URL =
5d043a3d
MW
165GITWEB_LIST =
166GITWEB_HOMETEXT = indextext.html
167GITWEB_CSS = gitweb.css
281f2f6b 168GITWEB_LOGO = git-logo.png
0b5deba1 169GITWEB_FAVICON = git-favicon.png
b2d3476e
AC
170GITWEB_SITE_HEADER =
171GITWEB_SITE_FOOTER =
5d043a3d 172
5f5dbd71 173export prefix bindir gitexecdir sharedir template_dir sysconfdir
e14421b9 174
b05701c5
PR
175CC = gcc
176AR = ar
4cb08df5 177RM = rm -f
229a7ed7 178TAR = tar
89b2f19c 179FIND = find
b05701c5
PR
180INSTALL = install
181RPMBUILD = rpmbuild
5f5dbd71 182TCL_PATH = tclsh
81b63c70 183TCLTK_PATH = wish
e83c5163 184
5f5dbd71
SP
185export TCL_PATH TCLTK_PATH
186
44c9e859
LT
187# sparse is architecture-neutral, which means that we need to tell it
188# explicitly what architecture to check for. Fix this up for yours..
b05701c5 189SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__
44c9e859 190
28818ffa
PB
191
192
193### --- END CONFIGURATION SECTION ---
194
8d7f586f 195# Those must not be GNU-specific; they are shared with perl/ which may
18b0fc1c
PB
196# be built by a different compiler. (Note that this is an artifact now
197# but it still might be nice to keep that distinction.)
198BASIC_CFLAGS =
199BASIC_LDFLAGS =
8d7f586f 200
215a7ad1 201SCRIPT_SH = \
c31820c2 202 git-bisect.sh git-checkout.sh \
e827633a 203 git-clean.sh git-clone.sh git-commit.sh \
6757ada4 204 git-fetch.sh \
68563738 205 git-ls-remote.sh \
c4b4a5af 206 git-merge-one-file.sh git-mergetool.sh git-parse-remote.sh \
1b1dce4b 207 git-pull.sh git-rebase.sh git-rebase--interactive.sh \
215a7ad1 208 git-repack.sh git-request-pull.sh git-reset.sh \
9509af68 209 git-sh-setup.sh \
7b763f7c 210 git-tag.sh git-verify-tag.sh \
59c8e2cb 211 git-am.sh \
2276aa6c 212 git-merge.sh git-merge-stupid.sh git-merge-octopus.sh \
63dffdf0 213 git-merge-resolve.sh git-merge-ours.sh \
6f6826c5 214 git-lost-found.sh git-quiltimport.sh git-submodule.sh \
f2c66ed1
NS
215 git-filter-branch.sh \
216 git-stash.sh
215a7ad1
JH
217
218SCRIPT_PERL = \
5cde71d6 219 git-add--interactive.perl \
215a7ad1 220 git-archimport.perl git-cvsimport.perl git-relink.perl \
e194cd1e 221 git-cvsserver.perl git-remote.perl \
11be42a4 222 git-svnimport.perl git-cvsexportcommit.perl \
60d02ccc 223 git-send-email.perl git-svn.perl
60036a41 224
d6ebd259
AE
225SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \
226 $(patsubst %.perl,%,$(SCRIPT_PERL)) \
9509af68 227 git-status git-instaweb
d6ebd259 228
b42934d6 229# ... and all the rest that could be moved out of bindir to gitexecdir
215a7ad1 230PROGRAMS = \
59d10247 231 git-convert-objects$X git-fetch-pack$X \
c3c8835f 232 git-hash-object$X git-index-pack$X git-local-fetch$X \
db5e523f 233 git-fast-import$X \
af8ffbed 234 git-daemon$X \
5d4a6003 235 git-merge-index$X git-mktag$X git-mktree$X git-patch-id$X \
53bb2c00 236 git-peek-remote$X git-receive-pack$X \
51ce34b9 237 git-send-pack$X git-shell$X \
79a9d8ea 238 git-show-index$X git-ssh-fetch$X \
56d1398a 239 git-ssh-upload$X git-unpack-file$X \
64413630 240 git-update-server-info$X \
59d10247 241 git-upload-pack$X \
d6b64ed0 242 git-pack-redundant$X git-var$X \
9a0eaf83 243 git-merge-tree$X git-imap-send$X \
a06f678e 244 git-merge-recursive$X \
42f77406
JH
245 $(EXTRA_PROGRAMS)
246
247# Empty...
248EXTRA_PROGRAMS =
d6ebd259 249
e414156a 250BUILT_INS = \
e827633a 251 git-format-patch$X git-show$X git-whatchanged$X git-cherry$X \
e0d10e1c 252 git-get-tar-commit-id$X git-init$X git-repo-config$X \
9509af68 253 git-fsck-objects$X git-cherry-pick$X \
f754fa9c 254 $(patsubst builtin-%.o,git-%$X,$(BUILTIN_OBJS))
91730800 255
b42934d6 256# what 'all' will build and 'install' will install, in gitexecdir
6506e156 257ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS)
e83c5163 258
68faf689
JH
259ALL_PROGRAMS += git-merge-subtree$X
260
3cfaf11b
ER
261# what 'all' will build but not install in gitexecdir
262OTHER_PROGRAMS = git$X gitweb/gitweb.cgi
263ifndef NO_TCLTK
6bdb18a9 264OTHER_PROGRAMS += gitk-wish
3cfaf11b
ER
265endif
266
894a8a8b 267# Backward compatibility -- to be removed after 1.0
2f29dd52 268PROGRAMS += git-ssh-pull$X git-ssh-push$X
f71a69ab 269
3d32051f
RA
270# Set paths to tools early so that they can be used for version tests.
271ifndef SHELL_PATH
272 SHELL_PATH = /bin/sh
273endif
274ifndef PERL_PATH
275 PERL_PATH = /usr/bin/perl
276endif
720d150c 277
3a793478
LT
278export PERL_PATH
279
0a02ce72 280LIB_FILE=libgit.a
3443546f 281XDIFF_LIB=xdiff/lib.a
8f3f9b09 282
215a7ad1 283LIB_H = \
83b5d2f5 284 archive.h blob.h cache.h commit.h csum-file.h delta.h grep.h \
4405fb77 285 diff.h object.h pack.h pkt-line.h quote.h refs.h list-objects.h sideband.h \
1b0c7174 286 run-command.h strbuf.h tag.h tree.h git-compat-util.h revision.h \
9e832665 287 tree-walk.h log-tree.h dir.h path-list.h unpack-trees.h builtin.h \
5751f490
DB
288 utf8.h reflog-walk.h patch-ids.h attr.h decorate.h progress.h \
289 mailmap.h remote.h
b1bf95bb 290
215a7ad1 291DIFF_OBJS = \
6973dcae 292 diff.o diff-lib.o diffcore-break.o diffcore-order.o \
65416758 293 diffcore-pickaxe.o diffcore-rename.o tree-diff.o combine-diff.o \
5f1c3f07 294 diffcore-delta.o log-tree.o
d1df5743 295
215a7ad1 296LIB_OBJS = \
283c8eef 297 blob.o commit.o connect.o csum-file.o cache-tree.o base85.o \
49ba83fb
JL
298 date.o diff-delta.o entry.o exec_cmd.o ident.o \
299 interpolate.o \
300 lockfile.o \
5d23e133 301 patch-ids.o \
8b0eca7c
DH
302 object.o pack-check.o pack-write.o patch-delta.o path.o pkt-line.o \
303 sideband.o reachable.o reflog-walk.o \
3e4339e6 304 quote.o read-cache.o refs.o run-command.o dir.o object-refs.o \
215a7ad1 305 server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \
f3123c4a 306 tag.o tree.o usage.o config.o environment.o ctype.o copy.o \
da093d37 307 revision.o pager.o tree-walk.o xdiff-interface.o \
68faf689 308 write_or_die.o trace.o list-objects.o grep.o match-trees.o \
7c92fe0e 309 alloc.o merge-file.o path-list.o help.o unpack-trees.o $(DIFF_OBJS) \
6c510bee 310 color.o wt-status.o archive-zip.o archive-tar.o shallow.o utf8.o \
5751f490 311 convert.o attr.o decorate.o progress.o mailmap.o symlinks.o remote.o
d19938ab 312
70827b15 313BUILTIN_OBJS = \
f754fa9c 314 builtin-add.o \
f789e347 315 builtin-annotate.o \
f754fa9c 316 builtin-apply.o \
4df096a5 317 builtin-archive.o \
acca687f 318 builtin-blame.o \
c31820c2 319 builtin-branch.o \
2e0afafe 320 builtin-bundle.o \
f754fa9c 321 builtin-cat-file.o \
d0bfd026 322 builtin-check-attr.o \
e414156a 323 builtin-checkout-index.o \
f754fa9c
JH
324 builtin-check-ref-format.o \
325 builtin-commit-tree.o \
326 builtin-count-objects.o \
9a0eaf83 327 builtin-describe.o \
f754fa9c
JH
328 builtin-diff.o \
329 builtin-diff-files.o \
330 builtin-diff-index.o \
f754fa9c 331 builtin-diff-tree.o \
d4289fff 332 builtin-fetch--tool.o \
f754fa9c 333 builtin-fmt-merge-msg.o \
9f613ddd 334 builtin-for-each-ref.o \
b4dfefe0 335 builtin-fsck.o \
6757ada4 336 builtin-gc.o \
f754fa9c
JH
337 builtin-grep.o \
338 builtin-init-db.o \
339 builtin-log.o \
340 builtin-ls-files.o \
341 builtin-ls-tree.o \
342 builtin-mailinfo.o \
343 builtin-mailsplit.o \
71dfbf22 344 builtin-merge-base.o \
ba1f5f35 345 builtin-merge-file.o \
f754fa9c
JH
346 builtin-mv.o \
347 builtin-name-rev.o \
348 builtin-pack-objects.o \
349 builtin-prune.o \
350 builtin-prune-packed.o \
351 builtin-push.o \
352 builtin-read-tree.o \
4264dc15 353 builtin-reflog.o \
e0d10e1c 354 builtin-config.o \
658f3650 355 builtin-rerere.o \
f754fa9c
JH
356 builtin-rev-list.o \
357 builtin-rev-parse.o \
9509af68 358 builtin-revert.o \
f754fa9c 359 builtin-rm.o \
c91f0d92 360 builtin-runstatus.o \
b8ec5923 361 builtin-shortlog.o \
f754fa9c
JH
362 builtin-show-branch.o \
363 builtin-stripspace.o \
364 builtin-symbolic-ref.o \
365 builtin-tar-tree.o \
366 builtin-unpack-objects.o \
367 builtin-update-index.o \
368 builtin-update-ref.o \
39345a21 369 builtin-upload-archive.o \
2e3ed670 370 builtin-verify-pack.o \
e4fbbfe9 371 builtin-write-tree.o \
eaf12a8c 372 builtin-show-ref.o \
e1e22e37 373 builtin-pack-refs.o
70827b15 374
54c261f9 375GITLIBS = $(LIB_FILE) $(XDIFF_LIB)
bef19da9 376EXTLIBS =
cef661fc 377
229a7ed7
JH
378#
379# Platform specific tweaks
380#
f7c15343
JH
381
382# We choose to avoid "if .. else if .. else .. endif endif"
383# because maintaining the nesting to match is a pain. If
384# we had "elif" things would have been much nicer...
f7c15343 385
817151e6
PE
386ifeq ($(uname_S),Linux)
387 NO_STRLCPY = YesPlease
388endif
ca7a7416
GP
389ifeq ($(uname_S),GNU/kFreeBSD)
390 NO_STRLCPY = YesPlease
391endif
f7c15343 392ifeq ($(uname_S),Darwin)
597c9cc5
JH
393 NEEDS_SSL_WITH_CRYPTO = YesPlease
394 NEEDS_LIBICONV = YesPlease
63b4b7a7 395 OLD_ICONV = UnfortunatelyYes
817151e6 396 NO_STRLCPY = YesPlease
597c9cc5 397endif
f7c15343 398ifeq ($(uname_S),SunOS)
f0ebff0d 399 NEEDS_SOCKET = YesPlease
5a90d4ac 400 NEEDS_NSL = YesPlease
229a7ed7
JH
401 SHELL_PATH = /bin/bash
402 NO_STRCASESTR = YesPlease
fa0c87c3 403 NO_HSTRERROR = YesPlease
e40b61fb 404 ifeq ($(uname_R),5.8)
e15f5451 405 NEEDS_LIBICONV = YesPlease
731043fd 406 NO_UNSETENV = YesPlease
e40b61fb 407 NO_SETENV = YesPlease
66c4509b 408 NO_C99_FORMAT = YesPlease
bc6b4f52 409 NO_STRTOUMAX = YesPlease
e40b61fb 410 endif
40d88d4f
DS
411 ifeq ($(uname_R),5.9)
412 NO_UNSETENV = YesPlease
413 NO_SETENV = YesPlease
66c4509b 414 NO_C99_FORMAT = YesPlease
bc6b4f52 415 NO_STRTOUMAX = YesPlease
40d88d4f 416 endif
229a7ed7
JH
417 INSTALL = ginstall
418 TAR = gtar
8d7f586f 419 BASIC_CFLAGS += -D__EXTENSIONS__
f0ebff0d 420endif
f7c15343 421ifeq ($(uname_O),Cygwin)
63be37b0 422 NO_D_TYPE_IN_DIRENT = YesPlease
35a730f0 423 NO_D_INO_IN_DIRENT = YesPlease
17754517 424 NO_STRCASESTR = YesPlease
9f0bb90d 425 NO_SYMLINK_HEAD = YesPlease
17754517 426 NEEDS_LIBICONV = YesPlease
1510fea7 427 NO_FAST_WORKING_DIRECTORY = UnfortunatelyYes
c869753e 428 NO_TRUSTABLE_FILEMODE = UnfortunatelyYes
2e67a5f4
JH
429 # There are conflicting reports about this.
430 # On some boxes NO_MMAP is needed, and not so elsewhere.
87ac1390
JH
431 # Try commenting this out if you suspect MMAP is more efficient
432 NO_MMAP = YesPlease
49744d63 433 NO_IPV6 = YesPlease
a23cd8ec 434 X = .exe
7c6ef2f2 435endif
b3bf974c
AK
436ifeq ($(uname_S),FreeBSD)
437 NEEDS_LIBICONV = YesPlease
8d7f586f
PB
438 BASIC_CFLAGS += -I/usr/local/include
439 BASIC_LDFLAGS += -L/usr/local/lib
b3bf974c 440endif
f7c15343 441ifeq ($(uname_S),OpenBSD)
5fb41e8a 442 NO_STRCASESTR = YesPlease
18c5a525 443 NEEDS_LIBICONV = YesPlease
8d7f586f
PB
444 BASIC_CFLAGS += -I/usr/local/include
445 BASIC_LDFLAGS += -L/usr/local/lib
94d23317
JH
446endif
447ifeq ($(uname_S),NetBSD)
e88856b4
DS
448 ifeq ($(shell expr "$(uname_R)" : '[01]\.'),2)
449 NEEDS_LIBICONV = YesPlease
450 endif
8d7f586f
PB
451 BASIC_CFLAGS += -I/usr/pkg/include
452 BASIC_LDFLAGS += -L/usr/pkg/lib
453 ALL_LDFLAGS += -Wl,-rpath,/usr/pkg/lib
18c5a525 454endif
a6da9395
JR
455ifeq ($(uname_S),AIX)
456 NO_STRCASESTR=YesPlease
817151e6 457 NO_STRLCPY = YesPlease
a6da9395
JR
458 NEEDS_LIBICONV=YesPlease
459endif
289c4b36
JS
460ifeq ($(uname_S),IRIX64)
461 NO_IPV6=YesPlease
462 NO_SETENV=YesPlease
463 NO_STRCASESTR=YesPlease
817151e6 464 NO_STRLCPY = YesPlease
289c4b36
JS
465 NO_SOCKADDR_STORAGE=YesPlease
466 SHELL_PATH=/usr/gnu/bin/bash
8d7f586f 467 BASIC_CFLAGS += -DPATH_MAX=1024
289c4b36 468 # for now, build 32-bit version
8d7f586f 469 BASIC_LDFLAGS += -L/usr/lib32
289c4b36 470endif
f7c15343
JH
471ifneq (,$(findstring arm,$(uname_M)))
472 ARM_SHA1 = YesPlease
473endif
597c9cc5 474
55667714 475-include config.mak.autogen
f2d6a256 476-include config.mak
597c9cc5 477
59f86740
BG
478ifeq ($(uname_S),Darwin)
479 ifndef NO_FINK
480 ifeq ($(shell test -d /sw/lib && echo y),y)
481 BASIC_CFLAGS += -I/sw/include
482 BASIC_LDFLAGS += -L/sw/lib
483 endif
484 endif
485 ifndef NO_DARWIN_PORTS
486 ifeq ($(shell test -d /opt/local/lib && echo y),y)
487 BASIC_CFLAGS += -I/opt/local/include
488 BASIC_LDFLAGS += -L/opt/local/lib
489 endif
490 endif
491endif
492
bbfc63dd
JH
493ifdef NO_R_TO_GCC_LINKER
494 # Some gcc does not accept and pass -R to the linker to specify
495 # the runtime dynamic library path.
496 CC_LD_DYNPATH = -Wl,-rpath=
497else
498 CC_LD_DYNPATH = -R
499endif
500
229a7ed7
JH
501ifndef NO_CURL
502 ifdef CURLDIR
bbfc63dd 503 # Try "-Wl,-rpath=$(CURLDIR)/lib" in such a case.
8d7f586f 504 BASIC_CFLAGS += -I$(CURLDIR)/include
bbfc63dd 505 CURL_LIBCURL = -L$(CURLDIR)/lib $(CC_LD_DYNPATH)$(CURLDIR)/lib -lcurl
229a7ed7
JH
506 else
507 CURL_LIBCURL = -lcurl
508 endif
2f29dd52 509 PROGRAMS += git-http-fetch$X
08900987
NH
510 curl_check := $(shell (echo 070908; curl-config --vernum) | sort -r | sed -ne 2p)
511 ifeq "$(curl_check)" "070908"
512 ifndef NO_EXPAT
08900987
NH
513 PROGRAMS += git-http-push$X
514 endif
58e60dd2 515 endif
459a21bd
JS
516 ifndef NO_EXPAT
517 EXPAT_LIBEXPAT = -lexpat
518 endif
229a7ed7
JH
519endif
520
bef19da9
RS
521ifdef ZLIB_PATH
522 BASIC_CFLAGS += -I$(ZLIB_PATH)/include
523 EXTLIBS += -L$(ZLIB_PATH)/lib $(CC_LD_DYNPATH)$(ZLIB_PATH)/lib
524endif
525EXTLIBS += -lz
526
dd53c7ab 527ifndef NO_OPENSSL
215a7ad1 528 OPENSSL_LIBSSL = -lssl
455a7f32 529 ifdef OPENSSLDIR
8d7f586f 530 BASIC_CFLAGS += -I$(OPENSSLDIR)/include
bbfc63dd 531 OPENSSL_LINK = -L$(OPENSSLDIR)/lib $(CC_LD_DYNPATH)$(OPENSSLDIR)/lib
455a7f32
JH
532 else
533 OPENSSL_LINK =
534 endif
dd53c7ab 535else
8d7f586f 536 BASIC_CFLAGS += -DNO_OPENSSL
215a7ad1
JH
537 MOZILLA_SHA1 = 1
538 OPENSSL_LIBSSL =
dd53c7ab 539endif
597c9cc5 540ifdef NEEDS_SSL_WITH_CRYPTO
455a7f32 541 LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl
597c9cc5 542else
455a7f32 543 LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto
597c9cc5
JH
544endif
545ifdef NEEDS_LIBICONV
455a7f32 546 ifdef ICONVDIR
8d7f586f 547 BASIC_CFLAGS += -I$(ICONVDIR)/include
bbfc63dd 548 ICONV_LINK = -L$(ICONVDIR)/lib $(CC_LD_DYNPATH)$(ICONVDIR)/lib
455a7f32
JH
549 else
550 ICONV_LINK =
551 endif
d595a473 552 EXTLIBS += $(ICONV_LINK) -liconv
597c9cc5 553endif
f0ebff0d 554ifdef NEEDS_SOCKET
d595a473 555 EXTLIBS += -lsocket
f0ebff0d 556endif
5a90d4ac 557ifdef NEEDS_NSL
d595a473 558 EXTLIBS += -lnsl
5a90d4ac 559endif
63be37b0 560ifdef NO_D_TYPE_IN_DIRENT
8d7f586f 561 BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT
63be37b0 562endif
35a730f0 563ifdef NO_D_INO_IN_DIRENT
8d7f586f 564 BASIC_CFLAGS += -DNO_D_INO_IN_DIRENT
35a730f0 565endif
579d1fbf 566ifdef NO_C99_FORMAT
8188e73b 567 BASIC_CFLAGS += -DNO_C99_FORMAT
579d1fbf 568endif
9f0bb90d 569ifdef NO_SYMLINK_HEAD
8d7f586f 570 BASIC_CFLAGS += -DNO_SYMLINK_HEAD
9f0bb90d 571endif
ef34af24 572ifdef NO_STRCASESTR
4050c0df 573 COMPAT_CFLAGS += -DNO_STRCASESTR
e40b61fb
JR
574 COMPAT_OBJS += compat/strcasestr.o
575endif
817151e6
PE
576ifdef NO_STRLCPY
577 COMPAT_CFLAGS += -DNO_STRLCPY
578 COMPAT_OBJS += compat/strlcpy.o
579endif
bc6b4f52
JR
580ifdef NO_STRTOUMAX
581 COMPAT_CFLAGS += -DNO_STRTOUMAX
582 COMPAT_OBJS += compat/strtoumax.o
583endif
584ifdef NO_STRTOULL
585 COMPAT_CFLAGS += -DNO_STRTOULL
586endif
e40b61fb 587ifdef NO_SETENV
4050c0df 588 COMPAT_CFLAGS += -DNO_SETENV
e40b61fb 589 COMPAT_OBJS += compat/setenv.o
ef34af24 590endif
104ff34a 591ifdef NO_UNSETENV
731043fd
JR
592 COMPAT_CFLAGS += -DNO_UNSETENV
593 COMPAT_OBJS += compat/unsetenv.o
594endif
730d48a2 595ifdef NO_MMAP
4050c0df 596 COMPAT_CFLAGS += -DNO_MMAP
e40b61fb 597 COMPAT_OBJS += compat/mmap.o
730d48a2 598endif
6900679c
SH
599ifdef NO_PREAD
600 COMPAT_CFLAGS += -DNO_PREAD
601 COMPAT_OBJS += compat/pread.o
602endif
1510fea7
SP
603ifdef NO_FAST_WORKING_DIRECTORY
604 BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY
605endif
c869753e
SP
606ifdef NO_TRUSTABLE_FILEMODE
607 BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE
608endif
49744d63 609ifdef NO_IPV6
8d7f586f 610 BASIC_CFLAGS += -DNO_IPV6
bdc37f5a
JH
611endif
612ifdef NO_SOCKADDR_STORAGE
613ifdef NO_IPV6
8d7f586f 614 BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in
bdc37f5a 615else
8d7f586f 616 BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6
bdc37f5a 617endif
49744d63 618endif
6ba68ab2
YL
619ifdef NO_INET_NTOP
620 LIB_OBJS += compat/inet_ntop.o
621endif
dd467629
JL
622ifdef NO_INET_PTON
623 LIB_OBJS += compat/inet_pton.o
624endif
cef661fc 625
b6e56eca 626ifdef NO_ICONV
8d7f586f 627 BASIC_CFLAGS += -DNO_ICONV
b6e56eca
FP
628endif
629
fd547a97
RJ
630ifdef OLD_ICONV
631 BASIC_CFLAGS += -DOLD_ICONV
632endif
633
7c6ef2f2
NP
634ifdef PPC_SHA1
635 SHA1_HEADER = "ppc/sha1.h"
636 LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o
637else
638ifdef ARM_SHA1
639 SHA1_HEADER = "arm/sha1.h"
640 LIB_OBJS += arm/sha1.o arm/sha1_arm.o
641else
642ifdef MOZILLA_SHA1
643 SHA1_HEADER = "mozilla-sha1/sha1.h"
644 LIB_OBJS += mozilla-sha1/sha1.o
645else
646 SHA1_HEADER = <openssl/sha.h>
d595a473 647 EXTLIBS += $(LIB_4_CRYPTO)
7c6ef2f2
NP
648endif
649endif
650endif
f848718a
AR
651ifdef NO_PERL_MAKEMAKER
652 export NO_PERL_MAKEMAKER
653endif
fa0c87c3
AR
654ifdef NO_HSTRERROR
655 COMPAT_CFLAGS += -DNO_HSTRERROR
656 COMPAT_OBJS += compat/hstrerror.o
657endif
b7774343 658
81b63c70
ER
659ifeq ($(TCLTK_PATH),)
660NO_TCLTK=NoThanks
661endif
662
3b486cd2 663QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir
b7774343
AR
664QUIET_SUBDIR1 =
665
a6f37099
AR
666ifneq ($(findstring $(MAKEFLAGS),w),w)
667PRINT_DIR = --no-print-directory
668else # "make -w"
669NO_SUBDIR = :
670endif
671
b7774343 672ifneq ($(findstring $(MAKEFLAGS),s),s)
2314c947 673ifndef V
31d0399c 674 QUIET_CC = @echo ' ' CC $@;
74f2b2a8
SP
675 QUIET_AR = @echo ' ' AR $@;
676 QUIET_LINK = @echo ' ' LINK $@;
677 QUIET_BUILT_IN = @echo ' ' BUILTIN $@;
678 QUIET_GEN = @echo ' ' GEN $@;
3b486cd2 679 QUIET_SUBDIR0 = +@subdir=
a6f37099
AR
680 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \
681 $(MAKE) $(PRINT_DIR) -C $$subdir
2314c947 682 export V
31d0399c 683 export QUIET_GEN
b7774343
AR
684 export QUIET_BUILT_IN
685endif
74f2b2a8 686endif
7c6ef2f2 687
4c7100a9
JH
688ifdef ASCIIDOC8
689 export ASCIIDOC8
690endif
691
addf88e4 692# Shell quote (do not use $(call) to accommodate ancient setups);
39c015c5
JS
693
694SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER))
32043c9f 695ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG))
39c015c5
JS
696
697DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
698bindir_SQ = $(subst ','\'',$(bindir))
699gitexecdir_SQ = $(subst ','\'',$(gitexecdir))
700template_dir_SQ = $(subst ','\'',$(template_dir))
ca3bcabf 701prefix_SQ = $(subst ','\'',$(prefix))
39c015c5
JS
702
703SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
704PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH))
81b63c70 705TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH))
39c015c5 706
d595a473
PB
707LIBS = $(GITLIBS) $(EXTLIBS)
708
32043c9f
JS
709BASIC_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' \
710 -DETC_GITCONFIG='"$(ETC_GITCONFIG_SQ)"' $(COMPAT_CFLAGS)
e40b61fb 711LIB_OBJS += $(COMPAT_OBJS)
8d7f586f
PB
712
713ALL_CFLAGS += $(BASIC_CFLAGS)
714ALL_LDFLAGS += $(BASIC_LDFLAGS)
715
a42cbacc 716export TAR INSTALL DESTDIR SHELL_PATH
d595a473
PB
717
718
28818ffa
PB
719### Build rules
720
3cfaf11b 721all:: $(ALL_PROGRAMS) $(BUILT_INS) $(OTHER_PROGRAMS)
6fc301bb 722ifneq (,$X)
4cb08df5 723 $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), $(RM) '$p';)
6fc301bb 724endif
89967023 725
6fc301bb 726all::
3cfaf11b 727ifndef NO_TCLTK
5f5dbd71 728 $(QUIET_SUBDIR0)git-gui $(QUIET_SUBDIR1) all
3cfaf11b 729endif
74f2b2a8
SP
730 $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' all
731 $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1)
b05701c5 732
4dc00021
JH
733strip: $(PROGRAMS) git$X
734 $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X
735
6bdb18a9 736gitk-wish: gitk GIT-GUI-VARS
4cb08df5 737 $(QUIET_GEN)$(RM) $@ $@+ && \
6bdb18a9
ER
738 sed -e '1,3s|^exec .* "$$0"|exec $(subst |,'\|',$(TCLTK_PATH_SQ)) "$$0"|' <gitk >$@+ && \
739 chmod +x $@+ && \
740 mv -f $@+ $@
741
334d28ae
JH
742git.o: git.c common-cmds.h GIT-CFLAGS
743 $(QUIET_CC)$(CC) -DGIT_VERSION='"$(GIT_VERSION)"' \
744 $(ALL_CFLAGS) -c $(filter %.c,$^)
745
746git$X: git.o $(BUILTIN_OBJS) $(GITLIBS)
54dadbdb 747 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ git.o \
70827b15 748 $(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS)
6a2e50f9 749
f754fa9c 750help.o: common-cmds.h
08df6171 751
68faf689 752git-merge-subtree$X: git-merge-recursive$X
4cb08df5 753 $(QUIET_BUILT_IN)$(RM) $@ && ln git-merge-recursive$X $@
68faf689 754
91730800 755$(BUILT_INS): git$X
4cb08df5 756 $(QUIET_BUILT_IN)$(RM) $@ && ln git$X $@
91730800 757
48dd1da8
JH
758common-cmds.h: ./generate-cmdlist.sh
759
766b084f 760common-cmds.h: $(wildcard Documentation/git-*.txt)
74f2b2a8 761 $(QUIET_GEN)./generate-cmdlist.sh > $@+ && mv $@+ $@
a87cd02c 762
d6ebd259 763$(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh
4cb08df5 764 $(QUIET_GEN)$(RM) $@ $@+ && \
39c015c5 765 sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
d9bffc08 766 -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
3ff8cbed 767 -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
6c5c62f3 768 -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
74f2b2a8
SP
769 $@.sh >$@+ && \
770 chmod +x $@+ && \
fc36f6a6 771 mv $@+ $@
bc6146d2 772
f848718a
AR
773$(patsubst %.perl,%,$(SCRIPT_PERL)): perl/perl.mak
774
775perl/perl.mak: GIT-CFLAGS
31d0399c 776 $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' $(@F)
f848718a 777
f6276fe1 778$(patsubst %.perl,%,$(SCRIPT_PERL)): % : %.perl
4cb08df5 779 $(QUIET_GEN)$(RM) $@ $@+ && \
893973a6 780 INSTLIBDIR=`$(MAKE) -C perl -s --no-print-directory instlibdir` && \
998c4daa
JH
781 sed -e '1{' \
782 -e ' s|#!.*perl|#!$(PERL_PATH_SQ)|' \
783 -e ' h' \
784 -e ' s=.*=use lib (split(/:/, $$ENV{GITPERLLIB} || "@@INSTLIBDIR@@"));=' \
785 -e ' H' \
786 -e ' x' \
787 -e '}' \
f6276fe1 788 -e 's|@@INSTLIBDIR@@|'"$$INSTLIBDIR"'|g' \
3ff8cbed 789 -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
74f2b2a8
SP
790 $@.perl >$@+ && \
791 chmod +x $@+ && \
fc36f6a6 792 mv $@+ $@
bc6146d2 793
cf7bb589 794git-status: git-commit
74f2b2a8 795 $(QUIET_GEN)cp $< $@+ && mv $@+ $@
cf7bb589 796
5d043a3d 797gitweb/gitweb.cgi: gitweb/gitweb.perl
4cb08df5 798 $(QUIET_GEN)$(RM) $@ $@+ && \
5d043a3d 799 sed -e '1s|#!.*perl|#!$(PERL_PATH_SQ)|' \
06c084d2
JH
800 -e 's|++GIT_VERSION++|$(GIT_VERSION)|g' \
801 -e 's|++GIT_BINDIR++|$(bindir)|g' \
802 -e 's|++GITWEB_CONFIG++|$(GITWEB_CONFIG)|g' \
2de21fac 803 -e 's|++GITWEB_HOME_LINK_STR++|$(GITWEB_HOME_LINK_STR)|g' \
06c084d2
JH
804 -e 's|++GITWEB_SITENAME++|$(GITWEB_SITENAME)|g' \
805 -e 's|++GITWEB_PROJECTROOT++|$(GITWEB_PROJECTROOT)|g' \
32f4aacc
ML
806 -e 's|++GITWEB_EXPORT_OK++|$(GITWEB_EXPORT_OK)|g' \
807 -e 's|++GITWEB_STRICT_EXPORT++|$(GITWEB_STRICT_EXPORT)|g' \
19a8721e 808 -e 's|++GITWEB_BASE_URL++|$(GITWEB_BASE_URL)|g' \
06c084d2
JH
809 -e 's|++GITWEB_LIST++|$(GITWEB_LIST)|g' \
810 -e 's|++GITWEB_HOMETEXT++|$(GITWEB_HOMETEXT)|g' \
811 -e 's|++GITWEB_CSS++|$(GITWEB_CSS)|g' \
812 -e 's|++GITWEB_LOGO++|$(GITWEB_LOGO)|g' \
0b5deba1 813 -e 's|++GITWEB_FAVICON++|$(GITWEB_FAVICON)|g' \
b2d3476e
AC
814 -e 's|++GITWEB_SITE_HEADER++|$(GITWEB_SITE_HEADER)|g' \
815 -e 's|++GITWEB_SITE_FOOTER++|$(GITWEB_SITE_FOOTER)|g' \
74f2b2a8
SP
816 $< >$@+ && \
817 chmod +x $@+ && \
5d043a3d
MW
818 mv $@+ $@
819
a51d37c1 820git-instaweb: git-instaweb.sh gitweb/gitweb.cgi gitweb/gitweb.css
4cb08df5 821 $(QUIET_GEN)$(RM) $@ $@+ && \
a51d37c1
EW
822 sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
823 -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
824 -e 's/@@NO_CURL@@/$(NO_CURL)/g' \
6e959ab0 825 -e '/@@GITWEB_CGI@@/r gitweb/gitweb.cgi' \
07002287 826 -e '/@@GITWEB_CGI@@/d' \
6e959ab0 827 -e '/@@GITWEB_CSS@@/r gitweb/gitweb.css' \
07002287 828 -e '/@@GITWEB_CSS@@/d' \
74f2b2a8
SP
829 $@.sh > $@+ && \
830 chmod +x $@+ && \
a51d37c1
EW
831 mv $@+ $@
832
3900145e 833configure: configure.ac
4cb08df5 834 $(QUIET_GEN)$(RM) $@ $<+ && \
3900145e 835 sed -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
74f2b2a8
SP
836 $< > $<+ && \
837 autoconf -o $@ $<+ && \
4cb08df5 838 $(RM) $<+
3900145e 839
9b88fcef 840# These can record GIT_VERSION
54dadbdb 841git.o git.spec \
9b88fcef
JH
842 $(patsubst %.sh,%,$(SCRIPT_SH)) \
843 $(patsubst %.perl,%,$(SCRIPT_PERL)) \
9b88fcef 844 : GIT-VERSION-FILE
e99fcf96 845
ca3bcabf 846%.o: %.c GIT-CFLAGS
74f2b2a8 847 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $<
e36cb1c1
LT
848%.s: %.c GIT-CFLAGS
849 $(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $<
b05701c5 850%.o: %.S
74f2b2a8 851 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $<
a310d434 852
ca3bcabf 853exec_cmd.o: exec_cmd.c GIT-CFLAGS
74f2b2a8 854 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' $<
c1f8064b 855builtin-init-db.o: builtin-init-db.c GIT-CFLAGS
74f2b2a8 856 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"' $<
77cb17e9 857
ca3bcabf 858http.o: http.c GIT-CFLAGS
74f2b2a8 859 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DGIT_USER_AGENT='"git/$(GIT_VERSION)"' $<
20fc9bc5 860
8d9fbe57 861ifdef NO_EXPAT
ca3bcabf 862http-fetch.o: http-fetch.c http.h GIT-CFLAGS
74f2b2a8 863 $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DNO_EXPAT $<
8d9fbe57
NH
864endif
865
8eef8e09 866git-%$X: %.o $(GITLIBS)
74f2b2a8 867 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS)
623c8a14 868
2941cab9
JS
869ssh-pull.o: ssh-fetch.c
870ssh-push.o: ssh-upload.c
2f29dd52
PA
871git-local-fetch$X: fetch.o
872git-ssh-fetch$X: rsh.o fetch.o
873git-ssh-upload$X: rsh.o
874git-ssh-pull$X: rsh.o fetch.o
875git-ssh-push$X: rsh.o
a3df1801 876
f2561fda
MM
877git-imap-send$X: imap-send.o $(LIB_FILE)
878
dd8239f9 879http.o http-fetch.o http-push.o: http.h
8fced61c 880git-http-fetch$X: fetch.o http.o http-fetch.o $(GITLIBS)
74f2b2a8 881 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
8d9fbe57 882 $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT)
39c015c5 883
8fced61c 884git-http-push$X: revision.o http.o http-push.o $(GITLIBS)
74f2b2a8 885 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \
39c015c5
JS
886 $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT)
887
0df56eab 888$(LIB_OBJS) $(BUILTIN_OBJS) fetch.o: $(LIB_H)
1f330269 889$(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) $(wildcard */*.h)
e468305a 890$(DIFF_OBJS): diffcore.h
e83c5163 891
28818ffa 892$(LIB_FILE): $(LIB_OBJS)
4cb08df5 893 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS)
28818ffa 894
857b933e
JS
895XDIFF_OBJS=xdiff/xdiffi.o xdiff/xprepare.o xdiff/xutils.o xdiff/xemit.o \
896 xdiff/xmerge.o
17b96be2
AW
897$(XDIFF_OBJS): xdiff/xinclude.h xdiff/xmacros.h xdiff/xdiff.h xdiff/xtypes.h \
898 xdiff/xutils.h xdiff/xprepare.h xdiff/xdiffi.h xdiff/xemit.h
3443546f
LT
899
900$(XDIFF_LIB): $(XDIFF_OBJS)
4cb08df5 901 $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(XDIFF_OBJS)
3443546f
LT
902
903
d595a473 904perl/Makefile: perl/Git.pm perl/Makefile.PL GIT-CFLAGS
63df97ae 905 (cd perl && $(PERL_PATH) Makefile.PL \
18b0fc1c 906 PREFIX='$(prefix_SQ)')
b1edc53d 907
28818ffa
PB
908doc:
909 $(MAKE) -C Documentation all
910
f81e7c62 911TAGS:
4cb08df5 912 $(RM) TAGS
89b2f19c 913 $(FIND) . -name '*.[hcS]' -print | xargs etags -a
f81e7c62
FK
914
915tags:
4cb08df5 916 $(RM) tags
89b2f19c 917 $(FIND) . -name '*.[hcS]' -print | xargs ctags -a
28818ffa 918
ca3bcabf 919### Detect prefix changes
7cdbff14 920TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):\
ca3bcabf
YL
921 $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ)
922
923GIT-CFLAGS: .FORCE-GIT-CFLAGS
924 @FLAGS='$(TRACK_CFLAGS)'; \
925 if test x"$$FLAGS" != x"`cat GIT-CFLAGS 2>/dev/null`" ; then \
926 echo 1>&2 " * new build flags or prefix"; \
927 echo "$$FLAGS" >GIT-CFLAGS; \
928 fi
929
6bdb18a9
ER
930### Detect Tck/Tk interpreter path changes
931ifndef NO_TCLTK
932TRACK_VARS = $(subst ','\'',-DTCLTK_PATH='$(TCLTK_PATH_SQ)')
933
934GIT-GUI-VARS: .FORCE-GIT-GUI-VARS
935 @VARS='$(TRACK_VARS)'; \
936 if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \
937 echo 1>&2 " * new Tcl/Tk interpreter location"; \
938 echo "$$VARS" >$@; \
939 fi
940
941.PHONY: .FORCE-GIT-GUI-VARS
942endif
943
28818ffa
PB
944### Testing rules
945
5c5ba73b 946TEST_PROGRAMS = test-chmtime$X test-genrandom$X test-date$X test-delta$X test-sha1$X test-match-trees$X
96651ef5
JH
947
948all:: $(TEST_PROGRAMS)
949
abb7c7b3
JS
950# GNU make supports exporting all variables by "export" without parameters.
951# However, the environment gets quite big, and some programs have problems
952# with that.
953
140245b3 954export NO_SVN_TESTS
abb7c7b3 955
96651ef5 956test: all
28818ffa
PB
957 $(MAKE) -C t/ all
958
5c5ba73b 959test-date$X: date.o ctype.o
28818ffa 960
5c5ba73b 961test-delta$X: diff-delta.o patch-delta.o
28818ffa 962
5c5ba73b
JP
963test-%$X: test-%.o $(GITLIBS)
964 $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS)
2dca1af4 965
b65bc21e
JH
966check-sha1:: test-sha1$X
967 ./test-sha1.sh
968
7c4c9f4c 969check: common-cmds.h
773b6339 970 for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; done
28818ffa 971
36e5e70e
LT
972remove-dashes:
973 ./fixup-builtins $(BUILT_INS)
28818ffa
PB
974
975### Installation rules
976
d6ebd259 977install: all
39c015c5
JS
978 $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(bindir_SQ)'
979 $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(gitexecdir_SQ)'
980 $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexecdir_SQ)'
3cfaf11b 981 $(INSTALL) git$X '$(DESTDIR_SQ)$(bindir_SQ)'
7ffe7098 982 $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install
f848718a 983 $(MAKE) -C perl prefix='$(prefix_SQ)' install
3cfaf11b 984ifndef NO_TCLTK
6bdb18a9 985 $(INSTALL) gitk-wish '$(DESTDIR_SQ)$(bindir_SQ)'/gitk
d647c2ea 986 $(MAKE) -C git-gui install
3cfaf11b 987endif
7f7e6eac
SE
988 if test 'z$(bindir_SQ)' != 'z$(gitexecdir_SQ)'; \
989 then \
990 ln -f '$(DESTDIR_SQ)$(bindir_SQ)/git$X' \
991 '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X' || \
992 cp '$(DESTDIR_SQ)$(bindir_SQ)/git$X' \
993 '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X'; \
994 fi
4cb08df5 995 $(foreach p,$(BUILT_INS), $(RM) '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p' && ln '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X' '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p' ;)
6fc301bb 996ifneq (,$X)
4cb08df5 997 $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), $(RM) '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p';)
6fc301bb 998endif
28818ffa
PB
999
1000install-doc:
1001 $(MAKE) -C Documentation install
1002
6538d1ef
EW
1003quick-install-doc:
1004 $(MAKE) -C Documentation quick-install
28818ffa
PB
1005
1006
1007
1008### Maintainer's dist rules
1009
9b88fcef 1010git.spec: git.spec.in
fc36f6a6
JM
1011 sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@+
1012 mv $@+ $@
a9db2974 1013
27dedf0c 1014GIT_TARNAME=git-$(GIT_VERSION)
f58494bf 1015dist: git.spec git-archive configure
9ccb64c8
JH
1016 ./git-archive --format=tar \
1017 --prefix=$(GIT_TARNAME)/ HEAD^{tree} > $(GIT_TARNAME).tar
a9db2974 1018 @mkdir -p $(GIT_TARNAME)
f58494bf 1019 @cp git.spec configure $(GIT_TARNAME)
181129d2 1020 @echo $(GIT_VERSION) > $(GIT_TARNAME)/version
d647c2ea 1021 @$(MAKE) -C git-gui TARDIR=../$(GIT_TARNAME)/git-gui dist-version
181129d2 1022 $(TAR) rf $(GIT_TARNAME).tar \
d647c2ea 1023 $(GIT_TARNAME)/git.spec \
f58494bf 1024 $(GIT_TARNAME)/configure \
d647c2ea 1025 $(GIT_TARNAME)/version \
115f0fe4 1026 $(GIT_TARNAME)/git-gui/version
4cb08df5 1027 @$(RM) -r $(GIT_TARNAME)
9dce3c06 1028 gzip -f -9 $(GIT_TARNAME).tar
a9db2974
CW
1029
1030rpm: dist
27dedf0c 1031 $(RPMBUILD) -ta $(GIT_TARNAME).tar.gz
a9db2974 1032
52db0495
TS
1033htmldocs = git-htmldocs-$(GIT_VERSION)
1034manpages = git-manpages-$(GIT_VERSION)
1035dist-doc:
4cb08df5 1036 $(RM) -r .doc-tmp-dir
52db0495
TS
1037 mkdir .doc-tmp-dir
1038 $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc
1039 cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar .
1040 gzip -n -9 -f $(htmldocs).tar
1041 :
4cb08df5 1042 $(RM) -r .doc-tmp-dir
4392da4d 1043 mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7
c5360324 1044 $(MAKE) -C Documentation DESTDIR=./ \
7b8cf0cf 1045 man1dir=../.doc-tmp-dir/man1 \
4392da4d 1046 man5dir=../.doc-tmp-dir/man5 \
7b8cf0cf 1047 man7dir=../.doc-tmp-dir/man7 \
52db0495
TS
1048 install
1049 cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar .
1050 gzip -n -9 -f $(manpages).tar
4cb08df5 1051 $(RM) -r .doc-tmp-dir
52db0495 1052
28818ffa 1053### Cleaning rules
87a81c83 1054
e83c5163 1055clean:
4cb08df5 1056 $(RM) *.o mozilla-sha1/*.o arm/*.o ppc/*.o compat/*.o xdiff/*.o \
d0f51a8b 1057 $(LIB_FILE) $(XDIFF_LIB)
4cb08df5
EM
1058 $(RM) $(ALL_PROGRAMS) $(BUILT_INS) git$X
1059 $(RM) $(TEST_PROGRAMS)
1060 $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h TAGS tags
1061 $(RM) -r autom4te.cache
1062 $(RM) configure config.log config.mak.autogen config.mak.append config.status config.cache
1063 $(RM) -r $(GIT_TARNAME) .doc-tmp-dir
1064 $(RM) $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz
1065 $(RM) $(htmldocs).tar.gz $(manpages).tar.gz
1066 $(RM) gitweb/gitweb.cgi
ca67f002 1067 $(MAKE) -C Documentation/ clean
f848718a 1068 $(MAKE) -C perl clean
b1edc53d 1069 $(MAKE) -C templates/ clean
4b7581f0 1070 $(MAKE) -C t/ clean
3cfaf11b 1071ifndef NO_TCLTK
4cb08df5 1072 $(RM) gitk-wish
3cfaf11b
ER
1073 $(MAKE) -C git-gui clean
1074endif
4cb08df5 1075 $(RM) GIT-VERSION-FILE GIT-CFLAGS GIT-GUI-VARS
9b88fcef 1076
4dc00021 1077.PHONY: all install clean strip
ca3bcabf 1078.PHONY: .FORCE-GIT-VERSION-FILE TAGS tags .FORCE-GIT-CFLAGS
d89056c2 1079
8c989ec5
JH
1080### Check documentation
1081#
1082check-docs::
1083 @for v in $(ALL_PROGRAMS) $(BUILT_INS) git$X gitk; \
1084 do \
1085 case "$$v" in \
8c989ec5 1086 git-merge-octopus | git-merge-ours | git-merge-recursive | \
6506e156 1087 git-merge-resolve | git-merge-stupid | \
4b02c529 1088 git-add--interactive | git-fsck-objects | git-init-db | \
aa453216 1089 git-repo-config | git-fetch--tool | \
8c989ec5
JH
1090 git-ssh-pull | git-ssh-push ) continue ;; \
1091 esac ; \
1092 test -f "Documentation/$$v.txt" || \
1093 echo "no doc: $$v"; \
4b02c529
JH
1094 sed -e '1,/^__DATA__/d' Documentation/cmd-list.perl | \
1095 grep -q "^$$v[ ]" || \
8c989ec5
JH
1096 case "$$v" in \
1097 git) ;; \
1098 *) echo "no link: $$v";; \
1099 esac ; \
1100 done | sort
c74390e4
JH
1101
1102### Make sure built-ins do not have dups and listed in git.c
1103#
1104check-builtins::
1105 ./check-builtins.sh