]>
Commit | Line | Data |
---|---|---|
2731d048 JH |
1 | # The default target of this Makefile is... |
2 | all: | |
3 | ||
5bdac8b3 PB |
4 | # Define MOZILLA_SHA1 environment variable when running make to make use of |
5 | # a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast | |
6 | # on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default | |
7 | # choice) has very fast version optimized for i586. | |
bdd4da59 | 8 | # |
765ac8ec LT |
9 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. |
10 | # This also implies MOZILLA_SHA1. | |
2cb45e95 | 11 | # |
58e60dd2 NH |
12 | # Define NO_CURL if you do not have curl installed. git-http-pull and |
13 | # git-http-push are not built, and you cannot use http:// and https:// | |
14 | # transports. | |
b2c0bd65 | 15 | # |
6d9bbc50 PM |
16 | # Define CURLDIR=/foo/bar if your curl header and library files are in |
17 | # /foo/bar/include and /foo/bar/lib directories. | |
18 | # | |
58e60dd2 NH |
19 | # Define NO_EXPAT if you do not have expat installed. git-http-push is |
20 | # not built, and you cannot push using http:// and https:// transports. | |
21 | # | |
35a730f0 JH |
22 | # Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent. |
23 | # | |
63be37b0 JH |
24 | # Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks |
25 | # d_type in struct dirent (latest Cygwin -- will be fixed soonish). | |
26 | # | |
ef34af24 LT |
27 | # Define NO_STRCASESTR if you don't have strcasestr. |
28 | # | |
e40b61fb JR |
29 | # Define NO_SETENV if you don't have setenv in the C library. |
30 | # | |
2fabd217 PR |
31 | # Define USE_SYMLINK_HEAD if you want .git/HEAD to be a symbolic link. |
32 | # Don't enable it on Windows. | |
33 | # | |
5bdac8b3 PB |
34 | # Define PPC_SHA1 environment variable when running make to make use of |
35 | # a bundled SHA1 routine optimized for PowerPC. | |
597c9cc5 | 36 | # |
7c6ef2f2 NP |
37 | # Define ARM_SHA1 environment variable when running make to make use of |
38 | # a bundled SHA1 routine optimized for ARM. | |
39 | # | |
597c9cc5 | 40 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). |
f0ebff0d | 41 | # |
597c9cc5 | 42 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). |
f0ebff0d PM |
43 | # |
44 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, | |
45 | # Patrick Mauritz). | |
46 | # | |
730d48a2 JS |
47 | # Define NO_MMAP if you want to avoid mmap. |
48 | # | |
343d35c9 JH |
49 | # Define WITH_OWN_SUBPROCESS_PY if you want to use with python 2.3. |
50 | # | |
49744d63 PA |
51 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). |
52 | # | |
bdc37f5a JH |
53 | # Define NO_SOCKADDR_STORAGE if your platform does not have struct |
54 | # sockaddr_storage. | |
55 | # | |
b6e56eca FP |
56 | # Define NO_ICONV if your libc does not properly support iconv. |
57 | # | |
5b5d4d9e JS |
58 | # Define NO_ACCURATE_DIFF if your diff program at least sometimes misses |
59 | # a missing newline at the end of the file. | |
60 | # | |
abb7c7b3 JS |
61 | # Define NO_PYTHON if you want to loose all benefits of the recursive merge. |
62 | # | |
5bdac8b3 PB |
63 | # Define COLLISION_CHECK below if you believe that SHA1's |
64 | # 1461501637330902918203684832716283019655932542976 hashes do not give you | |
65 | # sufficient guarantee that no collisions between objects will ever happen. | |
66 | ||
5bdac8b3 PB |
67 | # Define USE_NSEC below if you want git to care about sub-second file mtimes |
68 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and | |
69 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely | |
70 | # randomly break unless your underlying filesystem supports those sub-second | |
71 | # times (my ext3 doesn't). | |
72 | ||
5bdac8b3 PB |
73 | # Define USE_STDEV below if you want git to care about the underlying device |
74 | # change being considered an inode change from the update-cache perspective. | |
75 | ||
9b88fcef | 76 | GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE |
36546385 | 77 | @$(SHELL_PATH) ./GIT-VERSION-GEN |
9b88fcef | 78 | -include GIT-VERSION-FILE |
a9db2974 | 79 | |
e15f5451 PJ |
80 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') |
81 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') | |
82 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') | |
83 | uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') | |
84 | uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not') | |
85 | ||
94d23317 | 86 | # CFLAGS and LDFLAGS are for the users to override from the command line. |
12aa7456 | 87 | |
b05701c5 | 88 | CFLAGS = -g -O2 -Wall |
94d23317 | 89 | LDFLAGS = |
12aa7456 | 90 | ALL_CFLAGS = $(CFLAGS) |
94d23317 | 91 | ALL_LDFLAGS = $(LDFLAGS) |
4dc00021 | 92 | STRIP ?= strip |
29c2cce4 | 93 | |
b05701c5 PR |
94 | prefix = $(HOME) |
95 | bindir = $(prefix)/bin | |
e15f5451 | 96 | gitexecdir = $(bindir) |
b05701c5 | 97 | template_dir = $(prefix)/share/git-core/templates/ |
720d150c | 98 | GIT_PYTHON_DIR = $(prefix)/share/git-core/python |
a682ef9f | 99 | # DESTDIR= |
5c2a7fbc | 100 | |
b05701c5 PR |
101 | CC = gcc |
102 | AR = ar | |
229a7ed7 | 103 | TAR = tar |
b05701c5 PR |
104 | INSTALL = install |
105 | RPMBUILD = rpmbuild | |
e83c5163 | 106 | |
44c9e859 LT |
107 | # sparse is architecture-neutral, which means that we need to tell it |
108 | # explicitly what architecture to check for. Fix this up for yours.. | |
b05701c5 | 109 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ |
44c9e859 | 110 | |
28818ffa PB |
111 | |
112 | ||
113 | ### --- END CONFIGURATION SECTION --- | |
114 | ||
215a7ad1 JH |
115 | SCRIPT_SH = \ |
116 | git-add.sh git-bisect.sh git-branch.sh git-checkout.sh \ | |
c3b831bd | 117 | git-cherry.sh git-clean.sh git-clone.sh git-commit.sh \ |
215a7ad1 | 118 | git-count-objects.sh git-diff.sh git-fetch.sh \ |
91730800 | 119 | git-format-patch.sh git-ls-remote.sh \ |
e32faa8a | 120 | git-merge-one-file.sh git-parse-remote.sh \ |
215a7ad1 JH |
121 | git-prune.sh git-pull.sh git-push.sh git-rebase.sh \ |
122 | git-repack.sh git-request-pull.sh git-reset.sh \ | |
d4a1cab5 | 123 | git-resolve.sh git-revert.sh git-rm.sh git-sh-setup.sh \ |
27dedf0c | 124 | git-tag.sh git-verify-tag.sh git-whatchanged.sh \ |
d1c5f2a4 | 125 | git-applymbox.sh git-applypatch.sh git-am.sh \ |
2276aa6c | 126 | git-merge.sh git-merge-stupid.sh git-merge-octopus.sh \ |
04e7ca1a | 127 | git-merge-resolve.sh git-merge-ours.sh git-grep.sh \ |
0086e2c8 | 128 | git-lost-found.sh |
215a7ad1 JH |
129 | |
130 | SCRIPT_PERL = \ | |
131 | git-archimport.perl git-cvsimport.perl git-relink.perl \ | |
8389b52b | 132 | git-shortlog.perl git-fmt-merge-msg.perl git-rerere.perl \ |
98214e96 | 133 | git-annotate.perl git-cvsserver.perl \ |
5e0306ad | 134 | git-svnimport.perl git-mv.perl git-cvsexportcommit.perl |
60036a41 | 135 | |
720d150c | 136 | SCRIPT_PYTHON = \ |
e4cf17ce | 137 | git-merge-recursive.py |
720d150c | 138 | |
d6ebd259 AE |
139 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ |
140 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
141 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) \ | |
cf7bb589 | 142 | git-cherry-pick git-show git-status |
d6ebd259 | 143 | |
8eef8e09 | 144 | # The ones that do not have to link with lcrypto, lz nor xdiff. |
597c9cc5 | 145 | SIMPLE_PROGRAMS = \ |
2a3763ef | 146 | git-get-tar-commit-id$X git-mailsplit$X \ |
27dedf0c | 147 | git-stripspace$X git-daemon$X |
597c9cc5 | 148 | |
b42934d6 | 149 | # ... and all the rest that could be moved out of bindir to gitexecdir |
215a7ad1 | 150 | PROGRAMS = \ |
79a9d8ea PA |
151 | git-apply$X git-cat-file$X \ |
152 | git-checkout-index$X git-clone-pack$X git-commit-tree$X \ | |
153 | git-convert-objects$X git-diff-files$X \ | |
154 | git-diff-index$X git-diff-stages$X \ | |
155 | git-diff-tree$X git-fetch-pack$X git-fsck-objects$X \ | |
43f72af1 JH |
156 | git-hash-object$X git-index-pack$X git-init-db$X git-local-fetch$X \ |
157 | git-ls-files$X git-ls-tree$X git-mailinfo$X git-merge-base$X \ | |
83f50539 | 158 | git-merge-index$X git-mktag$X git-mktree$X git-pack-objects$X git-patch-id$X \ |
79a9d8ea PA |
159 | git-peek-remote$X git-prune-packed$X git-read-tree$X \ |
160 | git-receive-pack$X git-rev-list$X git-rev-parse$X \ | |
35eb2d36 | 161 | git-send-pack$X git-show-branch$X git-shell$X \ |
79a9d8ea PA |
162 | git-show-index$X git-ssh-fetch$X \ |
163 | git-ssh-upload$X git-tar-tree$X git-unpack-file$X \ | |
164 | git-unpack-objects$X git-update-index$X git-update-server-info$X \ | |
165 | git-upload-pack$X git-verify-pack$X git-write-tree$X \ | |
03feddd6 | 166 | git-update-ref$X git-symbolic-ref$X git-check-ref-format$X \ |
908e5310 | 167 | git-name-rev$X git-pack-redundant$X git-repo-config$X git-var$X \ |
f2561fda | 168 | git-describe$X git-merge-tree$X git-blame$X git-imap-send$X |
d6ebd259 | 169 | |
91730800 JH |
170 | BUILT_INS = git-log$X |
171 | ||
b42934d6 | 172 | # what 'all' will build and 'install' will install, in gitexecdir |
944e3a88 | 173 | ALL_PROGRAMS = $(PROGRAMS) $(SIMPLE_PROGRAMS) $(BUILT_INS) $(SCRIPTS) |
e83c5163 | 174 | |
894a8a8b | 175 | # Backward compatibility -- to be removed after 1.0 |
2f29dd52 | 176 | PROGRAMS += git-ssh-pull$X git-ssh-push$X |
f71a69ab | 177 | |
3d32051f RA |
178 | # Set paths to tools early so that they can be used for version tests. |
179 | ifndef SHELL_PATH | |
180 | SHELL_PATH = /bin/sh | |
181 | endif | |
182 | ifndef PERL_PATH | |
183 | PERL_PATH = /usr/bin/perl | |
184 | endif | |
185 | ifndef PYTHON_PATH | |
186 | PYTHON_PATH = /usr/bin/python | |
187 | endif | |
188 | ||
720d150c JH |
189 | PYMODULES = \ |
190 | gitMergeCommon.py | |
191 | ||
0a02ce72 | 192 | LIB_FILE=libgit.a |
3443546f | 193 | XDIFF_LIB=xdiff/lib.a |
8f3f9b09 | 194 | |
215a7ad1 | 195 | LIB_H = \ |
f5948cfe | 196 | blob.h cache.h commit.h csum-file.h delta.h \ |
765ac8ec | 197 | diff.h object.h pack.h pkt-line.h quote.h refs.h \ |
1b0c7174 JH |
198 | run-command.h strbuf.h tag.h tree.h git-compat-util.h revision.h \ |
199 | tree-walk.h | |
b1bf95bb | 200 | |
215a7ad1 | 201 | DIFF_OBJS = \ |
77882f60 | 202 | diff.o diffcore-break.o diffcore-order.o \ |
65416758 JH |
203 | diffcore-pickaxe.o diffcore-rename.o tree-diff.o combine-diff.o \ |
204 | diffcore-delta.o | |
d1df5743 | 205 | |
215a7ad1 | 206 | LIB_OBJS = \ |
f5948cfe | 207 | blob.o commit.o connect.o csum-file.o \ |
77cb17e9 | 208 | date.o diff-delta.o entry.o exec_cmd.o ident.o index.o \ |
215a7ad1 | 209 | object.o pack-check.o patch-delta.o path.o pkt-line.o \ |
0f56479d | 210 | quote.o read-cache.o refs.o run-command.o \ |
215a7ad1 | 211 | server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \ |
f3123c4a | 212 | tag.o tree.o usage.o config.o environment.o ctype.o copy.o \ |
d9ea73e0 | 213 | fetch-clone.o revision.o pager.o tree-walk.o xdiff-interface.o \ |
4546738b | 214 | $(DIFF_OBJS) |
d19938ab | 215 | |
54c261f9 JS |
216 | GITLIBS = $(LIB_FILE) $(XDIFF_LIB) |
217 | LIBS = $(GITLIBS) -lz | |
cef661fc | 218 | |
229a7ed7 JH |
219 | # |
220 | # Platform specific tweaks | |
221 | # | |
f7c15343 JH |
222 | |
223 | # We choose to avoid "if .. else if .. else .. endif endif" | |
224 | # because maintaining the nesting to match is a pain. If | |
225 | # we had "elif" things would have been much nicer... | |
f7c15343 JH |
226 | |
227 | ifeq ($(uname_S),Darwin) | |
597c9cc5 JH |
228 | NEEDS_SSL_WITH_CRYPTO = YesPlease |
229 | NEEDS_LIBICONV = YesPlease | |
0cfddacd | 230 | ## fink |
e3601e8b SP |
231 | ifeq ($(shell test -d /sw/lib && echo y),y) |
232 | ALL_CFLAGS += -I/sw/include | |
233 | ALL_LDFLAGS += -L/sw/lib | |
234 | endif | |
0cfddacd | 235 | ## darwinports |
e3601e8b SP |
236 | ifeq ($(shell test -d /opt/local/lib && echo y),y) |
237 | ALL_CFLAGS += -I/opt/local/include | |
238 | ALL_LDFLAGS += -L/opt/local/lib | |
239 | endif | |
597c9cc5 | 240 | endif |
f7c15343 | 241 | ifeq ($(uname_S),SunOS) |
f0ebff0d | 242 | NEEDS_SOCKET = YesPlease |
5a90d4ac | 243 | NEEDS_NSL = YesPlease |
229a7ed7 JH |
244 | SHELL_PATH = /bin/bash |
245 | NO_STRCASESTR = YesPlease | |
e40b61fb | 246 | ifeq ($(uname_R),5.8) |
e15f5451 | 247 | NEEDS_LIBICONV = YesPlease |
731043fd | 248 | NO_UNSETENV = YesPlease |
e40b61fb JR |
249 | NO_SETENV = YesPlease |
250 | endif | |
229a7ed7 JH |
251 | INSTALL = ginstall |
252 | TAR = gtar | |
12aa7456 | 253 | ALL_CFLAGS += -D__EXTENSIONS__ |
f0ebff0d | 254 | endif |
f7c15343 | 255 | ifeq ($(uname_O),Cygwin) |
63be37b0 | 256 | NO_D_TYPE_IN_DIRENT = YesPlease |
35a730f0 | 257 | NO_D_INO_IN_DIRENT = YesPlease |
17754517 PA |
258 | NO_STRCASESTR = YesPlease |
259 | NEEDS_LIBICONV = YesPlease | |
2e67a5f4 JH |
260 | # There are conflicting reports about this. |
261 | # On some boxes NO_MMAP is needed, and not so elsewhere. | |
262 | # Try uncommenting this if you see things break -- YMMV. | |
263 | # NO_MMAP = YesPlease | |
49744d63 | 264 | NO_IPV6 = YesPlease |
a23cd8ec | 265 | X = .exe |
7c6ef2f2 | 266 | endif |
b3bf974c AK |
267 | ifeq ($(uname_S),FreeBSD) |
268 | NEEDS_LIBICONV = YesPlease | |
269 | ALL_CFLAGS += -I/usr/local/include | |
270 | ALL_LDFLAGS += -L/usr/local/lib | |
271 | endif | |
f7c15343 | 272 | ifeq ($(uname_S),OpenBSD) |
5fb41e8a | 273 | NO_STRCASESTR = YesPlease |
18c5a525 | 274 | NEEDS_LIBICONV = YesPlease |
94d23317 JH |
275 | ALL_CFLAGS += -I/usr/local/include |
276 | ALL_LDFLAGS += -L/usr/local/lib | |
277 | endif | |
278 | ifeq ($(uname_S),NetBSD) | |
279 | NEEDS_LIBICONV = YesPlease | |
280 | ALL_CFLAGS += -I/usr/pkg/include | |
281 | ALL_LDFLAGS += -L/usr/pkg/lib -Wl,-rpath,/usr/pkg/lib | |
18c5a525 | 282 | endif |
a6da9395 JR |
283 | ifeq ($(uname_S),AIX) |
284 | NO_STRCASESTR=YesPlease | |
285 | NEEDS_LIBICONV=YesPlease | |
286 | endif | |
289c4b36 JS |
287 | ifeq ($(uname_S),IRIX64) |
288 | NO_IPV6=YesPlease | |
289 | NO_SETENV=YesPlease | |
290 | NO_STRCASESTR=YesPlease | |
291 | NO_SOCKADDR_STORAGE=YesPlease | |
292 | SHELL_PATH=/usr/gnu/bin/bash | |
293 | ALL_CFLAGS += -DPATH_MAX=1024 | |
294 | # for now, build 32-bit version | |
295 | ALL_LDFLAGS += -L/usr/lib32 | |
296 | endif | |
f7c15343 JH |
297 | ifneq (,$(findstring arm,$(uname_M))) |
298 | ARM_SHA1 = YesPlease | |
299 | endif | |
597c9cc5 | 300 | |
f2d6a256 | 301 | -include config.mak |
597c9cc5 | 302 | |
b34403aa TH |
303 | ifdef WITH_OWN_SUBPROCESS_PY |
304 | PYMODULES += compat/subprocess.py | |
305 | else | |
a348ab70 JS |
306 | ifeq ($(NO_PYTHON),) |
307 | ifneq ($(shell $(PYTHON_PATH) -c 'import subprocess;print"OK"' 2>/dev/null),OK) | |
308 | PYMODULES += compat/subprocess.py | |
309 | endif | |
b34403aa TH |
310 | endif |
311 | endif | |
312 | ||
313 | ifdef WITH_SEND_EMAIL | |
314 | SCRIPT_PERL += git-send-email.perl | |
315 | endif | |
316 | ||
229a7ed7 JH |
317 | ifndef NO_CURL |
318 | ifdef CURLDIR | |
94d23317 | 319 | # This is still problematic -- gcc does not always want -R. |
12aa7456 | 320 | ALL_CFLAGS += -I$(CURLDIR)/include |
229a7ed7 JH |
321 | CURL_LIBCURL = -L$(CURLDIR)/lib -R$(CURLDIR)/lib -lcurl |
322 | else | |
323 | CURL_LIBCURL = -lcurl | |
324 | endif | |
2f29dd52 | 325 | PROGRAMS += git-http-fetch$X |
08900987 NH |
326 | curl_check := $(shell (echo 070908; curl-config --vernum) | sort -r | sed -ne 2p) |
327 | ifeq "$(curl_check)" "070908" | |
328 | ifndef NO_EXPAT | |
08900987 NH |
329 | PROGRAMS += git-http-push$X |
330 | endif | |
58e60dd2 | 331 | endif |
459a21bd JS |
332 | ifndef NO_EXPAT |
333 | EXPAT_LIBEXPAT = -lexpat | |
334 | endif | |
229a7ed7 JH |
335 | endif |
336 | ||
dd53c7ab | 337 | ifndef NO_OPENSSL |
215a7ad1 | 338 | OPENSSL_LIBSSL = -lssl |
455a7f32 JH |
339 | ifdef OPENSSLDIR |
340 | # Again this may be problematic -- gcc does not always want -R. | |
12aa7456 | 341 | ALL_CFLAGS += -I$(OPENSSLDIR)/include |
455a7f32 JH |
342 | OPENSSL_LINK = -L$(OPENSSLDIR)/lib -R$(OPENSSLDIR)/lib |
343 | else | |
344 | OPENSSL_LINK = | |
345 | endif | |
dd53c7ab | 346 | else |
12aa7456 | 347 | ALL_CFLAGS += -DNO_OPENSSL |
215a7ad1 JH |
348 | MOZILLA_SHA1 = 1 |
349 | OPENSSL_LIBSSL = | |
dd53c7ab | 350 | endif |
597c9cc5 | 351 | ifdef NEEDS_SSL_WITH_CRYPTO |
455a7f32 | 352 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl |
597c9cc5 | 353 | else |
455a7f32 | 354 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto |
597c9cc5 JH |
355 | endif |
356 | ifdef NEEDS_LIBICONV | |
455a7f32 JH |
357 | ifdef ICONVDIR |
358 | # Again this may be problematic -- gcc does not always want -R. | |
12aa7456 | 359 | ALL_CFLAGS += -I$(ICONVDIR)/include |
455a7f32 JH |
360 | ICONV_LINK = -L$(ICONVDIR)/lib -R$(ICONVDIR)/lib |
361 | else | |
362 | ICONV_LINK = | |
363 | endif | |
364 | LIB_4_ICONV = $(ICONV_LINK) -liconv | |
597c9cc5 JH |
365 | else |
366 | LIB_4_ICONV = | |
367 | endif | |
f0ebff0d PM |
368 | ifdef NEEDS_SOCKET |
369 | LIBS += -lsocket | |
370 | SIMPLE_LIB += -lsocket | |
371 | endif | |
5a90d4ac JH |
372 | ifdef NEEDS_NSL |
373 | LIBS += -lnsl | |
374 | SIMPLE_LIB += -lnsl | |
375 | endif | |
63be37b0 JH |
376 | ifdef NO_D_TYPE_IN_DIRENT |
377 | ALL_CFLAGS += -DNO_D_TYPE_IN_DIRENT | |
378 | endif | |
35a730f0 JH |
379 | ifdef NO_D_INO_IN_DIRENT |
380 | ALL_CFLAGS += -DNO_D_INO_IN_DIRENT | |
381 | endif | |
ef34af24 | 382 | ifdef NO_STRCASESTR |
4050c0df | 383 | COMPAT_CFLAGS += -DNO_STRCASESTR |
e40b61fb JR |
384 | COMPAT_OBJS += compat/strcasestr.o |
385 | endif | |
386 | ifdef NO_SETENV | |
4050c0df | 387 | COMPAT_CFLAGS += -DNO_SETENV |
e40b61fb | 388 | COMPAT_OBJS += compat/setenv.o |
ef34af24 | 389 | endif |
731043fd JR |
390 | ifdef NO_SETENV |
391 | COMPAT_CFLAGS += -DNO_UNSETENV | |
392 | COMPAT_OBJS += compat/unsetenv.o | |
393 | endif | |
730d48a2 | 394 | ifdef NO_MMAP |
4050c0df | 395 | COMPAT_CFLAGS += -DNO_MMAP |
e40b61fb | 396 | COMPAT_OBJS += compat/mmap.o |
730d48a2 | 397 | endif |
49744d63 | 398 | ifdef NO_IPV6 |
bdc37f5a JH |
399 | ALL_CFLAGS += -DNO_IPV6 |
400 | endif | |
401 | ifdef NO_SOCKADDR_STORAGE | |
402 | ifdef NO_IPV6 | |
403 | ALL_CFLAGS += -Dsockaddr_storage=sockaddr_in | |
404 | else | |
405 | ALL_CFLAGS += -Dsockaddr_storage=sockaddr_in6 | |
406 | endif | |
49744d63 | 407 | endif |
cef661fc | 408 | |
b6e56eca FP |
409 | ifdef NO_ICONV |
410 | ALL_CFLAGS += -DNO_ICONV | |
411 | endif | |
412 | ||
7c6ef2f2 NP |
413 | ifdef PPC_SHA1 |
414 | SHA1_HEADER = "ppc/sha1.h" | |
415 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o | |
416 | else | |
417 | ifdef ARM_SHA1 | |
418 | SHA1_HEADER = "arm/sha1.h" | |
419 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o | |
420 | else | |
421 | ifdef MOZILLA_SHA1 | |
422 | SHA1_HEADER = "mozilla-sha1/sha1.h" | |
423 | LIB_OBJS += mozilla-sha1/sha1.o | |
424 | else | |
425 | SHA1_HEADER = <openssl/sha.h> | |
426 | LIBS += $(LIB_4_CRYPTO) | |
427 | endif | |
428 | endif | |
429 | endif | |
5b5d4d9e JS |
430 | ifdef NO_ACCURATE_DIFF |
431 | ALL_CFLAGS += -DNO_ACCURATE_DIFF | |
432 | endif | |
7c6ef2f2 | 433 | |
39c015c5 JS |
434 | # Shell quote (do not use $(call) to accomodate ancient setups); |
435 | ||
436 | SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER)) | |
437 | ||
438 | DESTDIR_SQ = $(subst ','\'',$(DESTDIR)) | |
439 | bindir_SQ = $(subst ','\'',$(bindir)) | |
440 | gitexecdir_SQ = $(subst ','\'',$(gitexecdir)) | |
441 | template_dir_SQ = $(subst ','\'',$(template_dir)) | |
442 | ||
443 | SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) | |
444 | PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) | |
445 | PYTHON_PATH_SQ = $(subst ','\'',$(PYTHON_PATH)) | |
446 | GIT_PYTHON_DIR_SQ = $(subst ','\'',$(GIT_PYTHON_DIR)) | |
447 | ||
448 | ALL_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' $(COMPAT_CFLAGS) | |
e40b61fb | 449 | LIB_OBJS += $(COMPAT_OBJS) |
ec2d1511 | 450 | export prefix TAR INSTALL DESTDIR SHELL_PATH template_dir |
28818ffa PB |
451 | ### Build rules |
452 | ||
944e3a88 | 453 | all: $(ALL_PROGRAMS) git$X gitk |
89967023 | 454 | |
d3af621b JH |
455 | all: |
456 | $(MAKE) -C templates | |
b05701c5 | 457 | |
4dc00021 JH |
458 | strip: $(PROGRAMS) git$X |
459 | $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X | |
460 | ||
8eef8e09 | 461 | git$X: git.c common-cmds.h $(GITLIBS) |
77cb17e9 | 462 | $(CC) -DGIT_VERSION='"$(GIT_VERSION)"' \ |
8eef8e09 | 463 | $(ALL_CFLAGS) -o $@ $(filter %.c,$^) \ |
9c48666a | 464 | $(ALL_LDFLAGS) $(LIBS) |
6a2e50f9 | 465 | |
91730800 JH |
466 | $(BUILT_INS): git$X |
467 | rm -f $@ && ln git$X $@ | |
468 | ||
a87cd02c FK |
469 | common-cmds.h: Documentation/git-*.txt |
470 | ./generate-cmdlist.sh > $@ | |
471 | ||
d6ebd259 | 472 | $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh |
bc6146d2 | 473 | rm -f $@ |
39c015c5 | 474 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ |
3ff8cbed | 475 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
6c5c62f3 | 476 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ |
abb7c7b3 | 477 | -e 's/@@NO_PYTHON@@/$(NO_PYTHON)/g' \ |
3ff8cbed | 478 | $@.sh >$@ |
bc6146d2 JH |
479 | chmod +x $@ |
480 | ||
481 | $(patsubst %.perl,%,$(SCRIPT_PERL)) : % : %.perl | |
482 | rm -f $@ | |
39c015c5 | 483 | sed -e '1s|#!.*perl|#!$(PERL_PATH_SQ)|' \ |
3ff8cbed JH |
484 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
485 | $@.perl >$@ | |
bc6146d2 JH |
486 | chmod +x $@ |
487 | ||
720d150c JH |
488 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) : % : %.py |
489 | rm -f $@ | |
39c015c5 JS |
490 | sed -e '1s|#!.*python|#!$(PYTHON_PATH_SQ)|' \ |
491 | -e 's|@@GIT_PYTHON_PATH@@|$(GIT_PYTHON_DIR_SQ)|g' \ | |
3ff8cbed JH |
492 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
493 | $@.py >$@ | |
720d150c JH |
494 | chmod +x $@ |
495 | ||
4eba0f37 JS |
496 | git-cherry-pick: git-revert |
497 | cp $< $@ | |
498 | ||
80d48ac6 JH |
499 | git-show: git-whatchanged |
500 | cp $< $@ | |
501 | ||
cf7bb589 JH |
502 | git-status: git-commit |
503 | cp $< $@ | |
504 | ||
9b88fcef JH |
505 | # These can record GIT_VERSION |
506 | git$X git.spec \ | |
507 | $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
508 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
509 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) \ | |
510 | : GIT-VERSION-FILE | |
e99fcf96 | 511 | |
b05701c5 PR |
512 | %.o: %.c |
513 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
514 | %.o: %.S | |
515 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
a310d434 | 516 | |
39c015c5 JS |
517 | exec_cmd.o: exec_cmd.c |
518 | $(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' $< | |
77cb17e9 | 519 | |
20fc9bc5 NH |
520 | http.o: http.c |
521 | $(CC) -o $*.o -c $(ALL_CFLAGS) -DGIT_USER_AGENT='"git/$(GIT_VERSION)"' $< | |
522 | ||
8d9fbe57 NH |
523 | ifdef NO_EXPAT |
524 | http-fetch.o: http-fetch.c | |
525 | $(CC) -o $*.o -c $(ALL_CFLAGS) -DNO_EXPAT $< | |
526 | endif | |
527 | ||
8eef8e09 | 528 | git-%$X: %.o $(GITLIBS) |
94d23317 | 529 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) |
623c8a14 | 530 | |
597c9cc5 | 531 | $(SIMPLE_PROGRAMS) : $(LIB_FILE) |
2f29dd52 | 532 | $(SIMPLE_PROGRAMS) : git-%$X : %.o |
94d23317 JH |
533 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ |
534 | $(LIB_FILE) $(SIMPLE_LIB) | |
597c9cc5 | 535 | |
39c015c5 JS |
536 | git-mailinfo$X: mailinfo.o $(LIB_FILE) |
537 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ | |
538 | $(LIB_FILE) $(SIMPLE_LIB) $(LIB_4_ICONV) | |
539 | ||
2f29dd52 PA |
540 | git-local-fetch$X: fetch.o |
541 | git-ssh-fetch$X: rsh.o fetch.o | |
542 | git-ssh-upload$X: rsh.o | |
543 | git-ssh-pull$X: rsh.o fetch.o | |
544 | git-ssh-push$X: rsh.o | |
a3df1801 | 545 | |
f2561fda MM |
546 | git-imap-send$X: imap-send.o $(LIB_FILE) |
547 | ||
b9929338 | 548 | git-http-fetch$X: fetch.o http.o http-fetch.o $(LIB_FILE) |
39c015c5 | 549 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ |
8d9fbe57 | 550 | $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) |
39c015c5 | 551 | |
aa1dbc98 | 552 | git-http-push$X: revision.o http.o http-push.o $(LIB_FILE) |
39c015c5 JS |
553 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ |
554 | $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) | |
555 | ||
b9929338 | 556 | git-rev-list$X: rev-list.o $(LIB_FILE) |
39c015c5 JS |
557 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ |
558 | $(LIBS) $(OPENSSL_LIBSSL) | |
a3df1801 | 559 | |
d3af621b | 560 | init-db.o: init-db.c |
b05701c5 | 561 | $(CC) -c $(ALL_CFLAGS) \ |
39c015c5 | 562 | -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"' $*.c |
d3af621b | 563 | |
e468305a | 564 | $(LIB_OBJS): $(LIB_H) |
54c261f9 | 565 | $(patsubst git-%$X,%.o,$(PROGRAMS)): $(GITLIBS) |
e468305a | 566 | $(DIFF_OBJS): diffcore.h |
e83c5163 | 567 | |
28818ffa PB |
568 | $(LIB_FILE): $(LIB_OBJS) |
569 | $(AR) rcs $@ $(LIB_OBJS) | |
570 | ||
3443546f LT |
571 | XDIFF_OBJS=xdiff/xdiffi.o xdiff/xprepare.o xdiff/xutils.o xdiff/xemit.o |
572 | ||
573 | $(XDIFF_LIB): $(XDIFF_OBJS) | |
574 | $(AR) rcs $@ $(XDIFF_OBJS) | |
575 | ||
576 | ||
28818ffa PB |
577 | doc: |
578 | $(MAKE) -C Documentation all | |
579 | ||
f81e7c62 FK |
580 | TAGS: |
581 | rm -f TAGS | |
582 | find . -name '*.[hcS]' -print | xargs etags -a | |
583 | ||
584 | tags: | |
585 | rm -f tags | |
586 | find . -name '*.[hcS]' -print | xargs ctags -a | |
28818ffa | 587 | |
28818ffa PB |
588 | ### Testing rules |
589 | ||
abb7c7b3 JS |
590 | # GNU make supports exporting all variables by "export" without parameters. |
591 | # However, the environment gets quite big, and some programs have problems | |
592 | # with that. | |
593 | ||
594 | export NO_PYTHON | |
595 | ||
28818ffa PB |
596 | test: all |
597 | $(MAKE) -C t/ all | |
598 | ||
4ccafd7a | 599 | test-date$X: test-date.c date.o ctype.o |
94d23317 | 600 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) test-date.c date.o ctype.o |
28818ffa | 601 | |
2f29dd52 | 602 | test-delta$X: test-delta.c diff-delta.o patch-delta.o |
3d99a7f4 | 603 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $^ -lz |
28818ffa PB |
604 | |
605 | check: | |
773b6339 | 606 | for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; done |
28818ffa PB |
607 | |
608 | ||
609 | ||
610 | ### Installation rules | |
611 | ||
d6ebd259 | 612 | install: all |
39c015c5 JS |
613 | $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(bindir_SQ)' |
614 | $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(gitexecdir_SQ)' | |
615 | $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexecdir_SQ)' | |
616 | $(INSTALL) git$X gitk '$(DESTDIR_SQ)$(bindir_SQ)' | |
8d5afef0 | 617 | $(MAKE) -C templates install |
39c015c5 JS |
618 | $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(GIT_PYTHON_DIR_SQ)' |
619 | $(INSTALL) $(PYMODULES) '$(DESTDIR_SQ)$(GIT_PYTHON_DIR_SQ)' | |
28818ffa PB |
620 | |
621 | install-doc: | |
622 | $(MAKE) -C Documentation install | |
623 | ||
624 | ||
625 | ||
626 | ||
627 | ### Maintainer's dist rules | |
628 | ||
9b88fcef | 629 | git.spec: git.spec.in |
a9db2974 CW |
630 | sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@ |
631 | ||
27dedf0c JH |
632 | GIT_TARNAME=git-$(GIT_VERSION) |
633 | dist: git.spec git-tar-tree | |
b1de9de2 | 634 | ./git-tar-tree HEAD $(GIT_TARNAME) > $(GIT_TARNAME).tar |
a9db2974 | 635 | @mkdir -p $(GIT_TARNAME) |
27dedf0c | 636 | @cp git.spec $(GIT_TARNAME) |
181129d2 PA |
637 | @echo $(GIT_VERSION) > $(GIT_TARNAME)/version |
638 | $(TAR) rf $(GIT_TARNAME).tar \ | |
639 | $(GIT_TARNAME)/git.spec $(GIT_TARNAME)/version | |
a9db2974 | 640 | @rm -rf $(GIT_TARNAME) |
9dce3c06 | 641 | gzip -f -9 $(GIT_TARNAME).tar |
a9db2974 CW |
642 | |
643 | rpm: dist | |
27dedf0c | 644 | $(RPMBUILD) -ta $(GIT_TARNAME).tar.gz |
a9db2974 | 645 | |
28818ffa | 646 | ### Cleaning rules |
87a81c83 | 647 | |
e83c5163 | 648 | clean: |
3467fec5 | 649 | rm -f *.o mozilla-sha1/*.o arm/*.o ppc/*.o compat/*.o xdiff/*.o \ |
944e3a88 | 650 | $(LIB_FILE) $(XDIFF_LIB) |
b42934d6 | 651 | rm -f $(ALL_PROGRAMS) git$X |
f81e7c62 | 652 | rm -f *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h TAGS tags |
f29eaed1 | 653 | rm -rf $(GIT_TARNAME) |
5a571cdd | 654 | rm -f $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz |
ca67f002 | 655 | $(MAKE) -C Documentation/ clean |
229a7ed7 | 656 | $(MAKE) -C templates clean |
4b7581f0 | 657 | $(MAKE) -C t/ clean |
9b88fcef JH |
658 | rm -f GIT-VERSION-FILE |
659 | ||
4dc00021 | 660 | .PHONY: all install clean strip |
f81e7c62 | 661 | .PHONY: .FORCE-GIT-VERSION-FILE TAGS tags |
d89056c2 | 662 |