]>
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 | # |
5bdac8b3 PB |
9 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. You will |
10 | # miss out git-rev-list --merge-order. 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 | # | |
ef34af24 LT |
22 | # Define NO_STRCASESTR if you don't have strcasestr. |
23 | # | |
e40b61fb JR |
24 | # Define NO_SETENV if you don't have setenv in the C library. |
25 | # | |
5bdac8b3 PB |
26 | # Define PPC_SHA1 environment variable when running make to make use of |
27 | # a bundled SHA1 routine optimized for PowerPC. | |
597c9cc5 | 28 | # |
7c6ef2f2 NP |
29 | # Define ARM_SHA1 environment variable when running make to make use of |
30 | # a bundled SHA1 routine optimized for ARM. | |
31 | # | |
597c9cc5 | 32 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). |
f0ebff0d | 33 | # |
597c9cc5 | 34 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). |
f0ebff0d PM |
35 | # |
36 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, | |
37 | # Patrick Mauritz). | |
38 | # | |
730d48a2 JS |
39 | # Define NO_MMAP if you want to avoid mmap. |
40 | # | |
343d35c9 JH |
41 | # Define WITH_OWN_SUBPROCESS_PY if you want to use with python 2.3. |
42 | # | |
49744d63 PA |
43 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). |
44 | # | |
5bdac8b3 PB |
45 | # Define COLLISION_CHECK below if you believe that SHA1's |
46 | # 1461501637330902918203684832716283019655932542976 hashes do not give you | |
47 | # sufficient guarantee that no collisions between objects will ever happen. | |
48 | ||
5bdac8b3 PB |
49 | # Define USE_NSEC below if you want git to care about sub-second file mtimes |
50 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and | |
51 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely | |
52 | # randomly break unless your underlying filesystem supports those sub-second | |
53 | # times (my ext3 doesn't). | |
54 | ||
5bdac8b3 PB |
55 | # Define USE_STDEV below if you want git to care about the underlying device |
56 | # change being considered an inode change from the update-cache perspective. | |
57 | ||
9b88fcef JH |
58 | GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE |
59 | @sh ./GIT-VERSION-GEN | |
60 | -include GIT-VERSION-FILE | |
a9db2974 | 61 | |
94d23317 | 62 | # CFLAGS and LDFLAGS are for the users to override from the command line. |
12aa7456 | 63 | |
b05701c5 | 64 | CFLAGS = -g -O2 -Wall |
94d23317 | 65 | LDFLAGS = |
12aa7456 | 66 | ALL_CFLAGS = $(CFLAGS) |
94d23317 | 67 | ALL_LDFLAGS = $(LDFLAGS) |
4dc00021 | 68 | STRIP ?= strip |
29c2cce4 | 69 | |
b05701c5 PR |
70 | prefix = $(HOME) |
71 | bindir = $(prefix)/bin | |
72 | template_dir = $(prefix)/share/git-core/templates/ | |
720d150c | 73 | GIT_PYTHON_DIR = $(prefix)/share/git-core/python |
a682ef9f | 74 | # DESTDIR= |
5c2a7fbc | 75 | |
b05701c5 PR |
76 | CC = gcc |
77 | AR = ar | |
229a7ed7 | 78 | TAR = tar |
b05701c5 PR |
79 | INSTALL = install |
80 | RPMBUILD = rpmbuild | |
e83c5163 | 81 | |
44c9e859 LT |
82 | # sparse is architecture-neutral, which means that we need to tell it |
83 | # explicitly what architecture to check for. Fix this up for yours.. | |
b05701c5 | 84 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ |
44c9e859 | 85 | |
28818ffa PB |
86 | |
87 | ||
88 | ### --- END CONFIGURATION SECTION --- | |
89 | ||
215a7ad1 JH |
90 | SCRIPT_SH = \ |
91 | git-add.sh git-bisect.sh git-branch.sh git-checkout.sh \ | |
92 | git-cherry.sh git-clone.sh git-commit.sh \ | |
93 | git-count-objects.sh git-diff.sh git-fetch.sh \ | |
94 | git-format-patch.sh git-log.sh git-ls-remote.sh \ | |
e32faa8a | 95 | git-merge-one-file.sh git-parse-remote.sh \ |
215a7ad1 JH |
96 | git-prune.sh git-pull.sh git-push.sh git-rebase.sh \ |
97 | git-repack.sh git-request-pull.sh git-reset.sh \ | |
98 | git-resolve.sh git-revert.sh git-sh-setup.sh git-status.sh \ | |
27dedf0c | 99 | git-tag.sh git-verify-tag.sh git-whatchanged.sh \ |
d1c5f2a4 | 100 | git-applymbox.sh git-applypatch.sh git-am.sh \ |
2276aa6c | 101 | git-merge.sh git-merge-stupid.sh git-merge-octopus.sh \ |
04e7ca1a | 102 | git-merge-resolve.sh git-merge-ours.sh git-grep.sh \ |
0086e2c8 | 103 | git-lost-found.sh |
215a7ad1 JH |
104 | |
105 | SCRIPT_PERL = \ | |
106 | git-archimport.perl git-cvsimport.perl git-relink.perl \ | |
1331df87 | 107 | git-shortlog.perl git-fmt-merge-msg.perl \ |
5e0306ad | 108 | git-svnimport.perl git-mv.perl git-cvsexportcommit.perl |
60036a41 | 109 | |
720d150c | 110 | SCRIPT_PYTHON = \ |
e4cf17ce | 111 | git-merge-recursive.py |
720d150c | 112 | |
d6ebd259 AE |
113 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ |
114 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
115 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) \ | |
116 | gitk git-cherry-pick | |
117 | ||
597c9cc5 JH |
118 | # The ones that do not have to link with lcrypto nor lz. |
119 | SIMPLE_PROGRAMS = \ | |
2f29dd52 | 120 | git-get-tar-commit-id$X git-mailinfo$X git-mailsplit$X \ |
27dedf0c | 121 | git-stripspace$X git-daemon$X |
597c9cc5 JH |
122 | |
123 | # ... and all the rest | |
215a7ad1 | 124 | PROGRAMS = \ |
79a9d8ea PA |
125 | git-apply$X git-cat-file$X \ |
126 | git-checkout-index$X git-clone-pack$X git-commit-tree$X \ | |
127 | git-convert-objects$X git-diff-files$X \ | |
128 | git-diff-index$X git-diff-stages$X \ | |
129 | git-diff-tree$X git-fetch-pack$X git-fsck-objects$X \ | |
9cf6d335 | 130 | git-hash-object$X git-index-pack$X git-init-db$X \ |
79a9d8ea PA |
131 | git-local-fetch$X git-ls-files$X git-ls-tree$X git-merge-base$X \ |
132 | git-merge-index$X git-mktag$X git-pack-objects$X git-patch-id$X \ | |
133 | git-peek-remote$X git-prune-packed$X git-read-tree$X \ | |
134 | git-receive-pack$X git-rev-list$X git-rev-parse$X \ | |
35eb2d36 | 135 | git-send-pack$X git-show-branch$X git-shell$X \ |
79a9d8ea PA |
136 | git-show-index$X git-ssh-fetch$X \ |
137 | git-ssh-upload$X git-tar-tree$X git-unpack-file$X \ | |
138 | git-unpack-objects$X git-update-index$X git-update-server-info$X \ | |
139 | git-upload-pack$X git-verify-pack$X git-write-tree$X \ | |
03feddd6 | 140 | git-update-ref$X git-symbolic-ref$X git-check-ref-format$X \ |
908e5310 LT |
141 | git-name-rev$X git-pack-redundant$X git-repo-config$X git-var$X \ |
142 | git-describe$X | |
d6ebd259 AE |
143 | |
144 | # what 'all' will build and 'install' will install. | |
145 | ALL_PROGRAMS = $(PROGRAMS) $(SIMPLE_PROGRAMS) $(SCRIPTS) git$X | |
e83c5163 | 146 | |
894a8a8b | 147 | # Backward compatibility -- to be removed after 1.0 |
2f29dd52 | 148 | PROGRAMS += git-ssh-pull$X git-ssh-push$X |
f71a69ab | 149 | |
3d32051f RA |
150 | # Set paths to tools early so that they can be used for version tests. |
151 | ifndef SHELL_PATH | |
152 | SHELL_PATH = /bin/sh | |
153 | endif | |
154 | ifndef PERL_PATH | |
155 | PERL_PATH = /usr/bin/perl | |
156 | endif | |
157 | ifndef PYTHON_PATH | |
158 | PYTHON_PATH = /usr/bin/python | |
159 | endif | |
160 | ||
720d150c JH |
161 | PYMODULES = \ |
162 | gitMergeCommon.py | |
163 | ||
0a02ce72 | 164 | LIB_FILE=libgit.a |
8f3f9b09 | 165 | |
215a7ad1 JH |
166 | LIB_H = \ |
167 | blob.h cache.h commit.h count-delta.h csum-file.h delta.h \ | |
168 | diff.h epoch.h object.h pack.h pkt-line.h quote.h refs.h \ | |
4050c0df | 169 | run-command.h strbuf.h tag.h tree.h git-compat-util.h |
b1bf95bb | 170 | |
215a7ad1 JH |
171 | DIFF_OBJS = \ |
172 | diff.o diffcore-break.o diffcore-order.o diffcore-pathspec.o \ | |
ac1b3d12 | 173 | diffcore-pickaxe.o diffcore-rename.o tree-diff.o |
d1df5743 | 174 | |
215a7ad1 JH |
175 | LIB_OBJS = \ |
176 | blob.o commit.o connect.o count-delta.o csum-file.o \ | |
a9ab586a | 177 | date.o diff-delta.o entry.o ident.o index.o \ |
215a7ad1 | 178 | object.o pack-check.o patch-delta.o path.o pkt-line.o \ |
0f56479d | 179 | quote.o read-cache.o refs.o run-command.o \ |
215a7ad1 | 180 | server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \ |
f3123c4a | 181 | tag.o tree.o usage.o config.o environment.o ctype.o copy.o \ |
ad897215 | 182 | fetch-clone.o \ |
4546738b | 183 | $(DIFF_OBJS) |
d19938ab | 184 | |
cc1ad5c8 LT |
185 | LIBS = $(LIB_FILE) |
186 | LIBS += -lz | |
cef661fc | 187 | |
4769948a JH |
188 | # Shell quote; |
189 | # Result of this needs to be placed inside '' | |
190 | shq = $(subst ','\'',$(1)) | |
191 | # This has surrounding '' | |
192 | shellquote = '$(call shq,$(1))' | |
193 | ||
229a7ed7 JH |
194 | # |
195 | # Platform specific tweaks | |
196 | # | |
f7c15343 JH |
197 | |
198 | # We choose to avoid "if .. else if .. else .. endif endif" | |
199 | # because maintaining the nesting to match is a pain. If | |
200 | # we had "elif" things would have been much nicer... | |
201 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') | |
202 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') | |
203 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') | |
e40b61fb | 204 | uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') |
f7c15343 JH |
205 | |
206 | ifeq ($(uname_S),Darwin) | |
597c9cc5 JH |
207 | NEEDS_SSL_WITH_CRYPTO = YesPlease |
208 | NEEDS_LIBICONV = YesPlease | |
0cfddacd | 209 | ## fink |
94d23317 JH |
210 | ALL_CFLAGS += -I/sw/include |
211 | ALL_LDFLAGS += -L/sw/lib | |
0cfddacd | 212 | ## darwinports |
94d23317 JH |
213 | ALL_CFLAGS += -I/opt/local/include |
214 | ALL_LDFLAGS += -L/opt/local/lib | |
597c9cc5 | 215 | endif |
f7c15343 | 216 | ifeq ($(uname_S),SunOS) |
f0ebff0d | 217 | NEEDS_SOCKET = YesPlease |
5a90d4ac | 218 | NEEDS_NSL = YesPlease |
2fd955cc | 219 | NEEDS_LIBICONV = YesPlease |
229a7ed7 JH |
220 | SHELL_PATH = /bin/bash |
221 | NO_STRCASESTR = YesPlease | |
e40b61fb JR |
222 | ifeq ($(uname_R),5.8) |
223 | NO_SETENV = YesPlease | |
224 | endif | |
229a7ed7 JH |
225 | INSTALL = ginstall |
226 | TAR = gtar | |
12aa7456 | 227 | ALL_CFLAGS += -D__EXTENSIONS__ |
f0ebff0d | 228 | endif |
f7c15343 | 229 | ifeq ($(uname_O),Cygwin) |
17754517 PA |
230 | NO_STRCASESTR = YesPlease |
231 | NEEDS_LIBICONV = YesPlease | |
2e67a5f4 JH |
232 | # There are conflicting reports about this. |
233 | # On some boxes NO_MMAP is needed, and not so elsewhere. | |
234 | # Try uncommenting this if you see things break -- YMMV. | |
235 | # NO_MMAP = YesPlease | |
49744d63 | 236 | NO_IPV6 = YesPlease |
a23cd8ec | 237 | X = .exe |
12aa7456 | 238 | ALL_CFLAGS += -DUSE_SYMLINK_HEAD=0 |
7c6ef2f2 | 239 | endif |
f7c15343 | 240 | ifeq ($(uname_S),OpenBSD) |
5fb41e8a | 241 | NO_STRCASESTR = YesPlease |
18c5a525 | 242 | NEEDS_LIBICONV = YesPlease |
94d23317 JH |
243 | ALL_CFLAGS += -I/usr/local/include |
244 | ALL_LDFLAGS += -L/usr/local/lib | |
245 | endif | |
246 | ifeq ($(uname_S),NetBSD) | |
247 | NEEDS_LIBICONV = YesPlease | |
248 | ALL_CFLAGS += -I/usr/pkg/include | |
249 | ALL_LDFLAGS += -L/usr/pkg/lib -Wl,-rpath,/usr/pkg/lib | |
18c5a525 | 250 | endif |
a6da9395 JR |
251 | ifeq ($(uname_S),AIX) |
252 | NO_STRCASESTR=YesPlease | |
253 | NEEDS_LIBICONV=YesPlease | |
254 | endif | |
f7c15343 JH |
255 | ifneq (,$(findstring arm,$(uname_M))) |
256 | ARM_SHA1 = YesPlease | |
257 | endif | |
597c9cc5 | 258 | |
f2d6a256 | 259 | -include config.mak |
597c9cc5 | 260 | |
b34403aa TH |
261 | ifdef WITH_OWN_SUBPROCESS_PY |
262 | PYMODULES += compat/subprocess.py | |
263 | else | |
264 | ifneq ($(shell $(PYTHON_PATH) -c 'import subprocess;print"OK"' 2>/dev/null),OK) | |
265 | PYMODULES += compat/subprocess.py | |
266 | endif | |
267 | endif | |
268 | ||
269 | ifdef WITH_SEND_EMAIL | |
270 | SCRIPT_PERL += git-send-email.perl | |
271 | endif | |
272 | ||
229a7ed7 JH |
273 | ifndef NO_CURL |
274 | ifdef CURLDIR | |
94d23317 | 275 | # This is still problematic -- gcc does not always want -R. |
12aa7456 | 276 | ALL_CFLAGS += -I$(CURLDIR)/include |
229a7ed7 JH |
277 | CURL_LIBCURL = -L$(CURLDIR)/lib -R$(CURLDIR)/lib -lcurl |
278 | else | |
279 | CURL_LIBCURL = -lcurl | |
280 | endif | |
2f29dd52 | 281 | PROGRAMS += git-http-fetch$X |
08900987 NH |
282 | curl_check := $(shell (echo 070908; curl-config --vernum) | sort -r | sed -ne 2p) |
283 | ifeq "$(curl_check)" "070908" | |
284 | ifndef NO_EXPAT | |
285 | EXPAT_LIBEXPAT = -lexpat | |
286 | PROGRAMS += git-http-push$X | |
287 | endif | |
58e60dd2 | 288 | endif |
229a7ed7 JH |
289 | endif |
290 | ||
dd53c7ab PB |
291 | ifndef NO_OPENSSL |
292 | LIB_OBJS += epoch.o | |
215a7ad1 | 293 | OPENSSL_LIBSSL = -lssl |
455a7f32 JH |
294 | ifdef OPENSSLDIR |
295 | # Again this may be problematic -- gcc does not always want -R. | |
12aa7456 | 296 | ALL_CFLAGS += -I$(OPENSSLDIR)/include |
455a7f32 JH |
297 | OPENSSL_LINK = -L$(OPENSSLDIR)/lib -R$(OPENSSLDIR)/lib |
298 | else | |
299 | OPENSSL_LINK = | |
300 | endif | |
dd53c7ab | 301 | else |
12aa7456 | 302 | ALL_CFLAGS += -DNO_OPENSSL |
215a7ad1 JH |
303 | MOZILLA_SHA1 = 1 |
304 | OPENSSL_LIBSSL = | |
dd53c7ab | 305 | endif |
597c9cc5 | 306 | ifdef NEEDS_SSL_WITH_CRYPTO |
455a7f32 | 307 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl |
597c9cc5 | 308 | else |
455a7f32 | 309 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto |
597c9cc5 JH |
310 | endif |
311 | ifdef NEEDS_LIBICONV | |
455a7f32 JH |
312 | ifdef ICONVDIR |
313 | # Again this may be problematic -- gcc does not always want -R. | |
12aa7456 | 314 | ALL_CFLAGS += -I$(ICONVDIR)/include |
455a7f32 JH |
315 | ICONV_LINK = -L$(ICONVDIR)/lib -R$(ICONVDIR)/lib |
316 | else | |
317 | ICONV_LINK = | |
318 | endif | |
319 | LIB_4_ICONV = $(ICONV_LINK) -liconv | |
597c9cc5 JH |
320 | else |
321 | LIB_4_ICONV = | |
322 | endif | |
f0ebff0d PM |
323 | ifdef NEEDS_SOCKET |
324 | LIBS += -lsocket | |
325 | SIMPLE_LIB += -lsocket | |
326 | endif | |
5a90d4ac JH |
327 | ifdef NEEDS_NSL |
328 | LIBS += -lnsl | |
329 | SIMPLE_LIB += -lnsl | |
330 | endif | |
ef34af24 | 331 | ifdef NO_STRCASESTR |
4050c0df | 332 | COMPAT_CFLAGS += -DNO_STRCASESTR |
e40b61fb JR |
333 | COMPAT_OBJS += compat/strcasestr.o |
334 | endif | |
335 | ifdef NO_SETENV | |
4050c0df | 336 | COMPAT_CFLAGS += -DNO_SETENV |
e40b61fb | 337 | COMPAT_OBJS += compat/setenv.o |
ef34af24 | 338 | endif |
730d48a2 | 339 | ifdef NO_MMAP |
4050c0df | 340 | COMPAT_CFLAGS += -DNO_MMAP |
e40b61fb | 341 | COMPAT_OBJS += compat/mmap.o |
730d48a2 | 342 | endif |
49744d63 | 343 | ifdef NO_IPV6 |
12aa7456 | 344 | ALL_CFLAGS += -DNO_IPV6 -Dsockaddr_storage=sockaddr_in |
49744d63 | 345 | endif |
cef661fc | 346 | |
7c6ef2f2 NP |
347 | ifdef PPC_SHA1 |
348 | SHA1_HEADER = "ppc/sha1.h" | |
349 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o | |
350 | else | |
351 | ifdef ARM_SHA1 | |
352 | SHA1_HEADER = "arm/sha1.h" | |
353 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o | |
354 | else | |
355 | ifdef MOZILLA_SHA1 | |
356 | SHA1_HEADER = "mozilla-sha1/sha1.h" | |
357 | LIB_OBJS += mozilla-sha1/sha1.o | |
358 | else | |
359 | SHA1_HEADER = <openssl/sha.h> | |
360 | LIBS += $(LIB_4_CRYPTO) | |
361 | endif | |
362 | endif | |
363 | endif | |
364 | ||
e40b61fb JR |
365 | ALL_CFLAGS += -DSHA1_HEADER=$(call shellquote,$(SHA1_HEADER)) $(COMPAT_CFLAGS) |
366 | LIB_OBJS += $(COMPAT_OBJS) | |
ec2d1511 | 367 | export prefix TAR INSTALL DESTDIR SHELL_PATH template_dir |
28818ffa PB |
368 | ### Build rules |
369 | ||
d6ebd259 | 370 | all: $(ALL_PROGRAMS) |
89967023 | 371 | |
d3af621b JH |
372 | all: |
373 | $(MAKE) -C templates | |
b05701c5 | 374 | |
4dc00021 JH |
375 | strip: $(PROGRAMS) git$X |
376 | $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X | |
377 | ||
9b88fcef | 378 | git$X: git.c $(LIB_FILE) |
27dedf0c | 379 | $(CC) -DGIT_EXEC_PATH='"$(bindir)"' -DGIT_VERSION='"$(GIT_VERSION)"' \ |
4050c0df | 380 | $(CFLAGS) $(COMPAT_CFLAGS) -o $@ $(filter %.c,$^) $(LIB_FILE) |
6a2e50f9 | 381 | |
d6ebd259 | 382 | $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh |
bc6146d2 | 383 | rm -f $@ |
4769948a | 384 | sed -e '1s|#!.*/sh|#!$(call shq,$(SHELL_PATH))|' \ |
3ff8cbed JH |
385 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
386 | $@.sh >$@ | |
bc6146d2 JH |
387 | chmod +x $@ |
388 | ||
389 | $(patsubst %.perl,%,$(SCRIPT_PERL)) : % : %.perl | |
390 | rm -f $@ | |
4769948a | 391 | sed -e '1s|#!.*perl|#!$(call shq,$(PERL_PATH))|' \ |
3ff8cbed JH |
392 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
393 | $@.perl >$@ | |
bc6146d2 JH |
394 | chmod +x $@ |
395 | ||
720d150c JH |
396 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) : % : %.py |
397 | rm -f $@ | |
4769948a JH |
398 | sed -e '1s|#!.*python|#!$(call shq,$(PYTHON_PATH))|' \ |
399 | -e 's|@@GIT_PYTHON_PATH@@|$(call shq,$(GIT_PYTHON_DIR))|g' \ | |
3ff8cbed JH |
400 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
401 | $@.py >$@ | |
720d150c JH |
402 | chmod +x $@ |
403 | ||
4eba0f37 JS |
404 | git-cherry-pick: git-revert |
405 | cp $< $@ | |
406 | ||
9b88fcef JH |
407 | # These can record GIT_VERSION |
408 | git$X git.spec \ | |
409 | $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
410 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
411 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) \ | |
412 | : GIT-VERSION-FILE | |
e99fcf96 | 413 | |
b05701c5 PR |
414 | %.o: %.c |
415 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
416 | %.o: %.S | |
417 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
a310d434 | 418 | |
2f29dd52 | 419 | git-%$X: %.o $(LIB_FILE) |
94d23317 | 420 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) |
623c8a14 | 421 | |
2f29dd52 | 422 | git-mailinfo$X : SIMPLE_LIB += $(LIB_4_ICONV) |
597c9cc5 | 423 | $(SIMPLE_PROGRAMS) : $(LIB_FILE) |
2f29dd52 | 424 | $(SIMPLE_PROGRAMS) : git-%$X : %.o |
94d23317 JH |
425 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ |
426 | $(LIB_FILE) $(SIMPLE_LIB) | |
597c9cc5 | 427 | |
29508e1e NH |
428 | git-http-fetch$X: fetch.o http.o |
429 | git-http-push$X: http.o | |
2f29dd52 PA |
430 | git-local-fetch$X: fetch.o |
431 | git-ssh-fetch$X: rsh.o fetch.o | |
432 | git-ssh-upload$X: rsh.o | |
433 | git-ssh-pull$X: rsh.o fetch.o | |
434 | git-ssh-push$X: rsh.o | |
a3df1801 | 435 | |
2f29dd52 | 436 | git-http-fetch$X: LIBS += $(CURL_LIBCURL) |
58e60dd2 | 437 | git-http-push$X: LIBS += $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) |
2f29dd52 | 438 | git-rev-list$X: LIBS += $(OPENSSL_LIBSSL) |
a3df1801 | 439 | |
d3af621b | 440 | init-db.o: init-db.c |
b05701c5 | 441 | $(CC) -c $(ALL_CFLAGS) \ |
4769948a | 442 | -DDEFAULT_GIT_TEMPLATE_DIR=$(call shellquote,"$(template_dir)") $*.c |
d3af621b | 443 | |
e468305a | 444 | $(LIB_OBJS): $(LIB_H) |
2f29dd52 | 445 | $(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) |
e468305a | 446 | $(DIFF_OBJS): diffcore.h |
e83c5163 | 447 | |
28818ffa PB |
448 | $(LIB_FILE): $(LIB_OBJS) |
449 | $(AR) rcs $@ $(LIB_OBJS) | |
450 | ||
451 | doc: | |
452 | $(MAKE) -C Documentation all | |
453 | ||
454 | ||
28818ffa PB |
455 | ### Testing rules |
456 | ||
457 | test: all | |
458 | $(MAKE) -C t/ all | |
459 | ||
4ccafd7a | 460 | test-date$X: test-date.c date.o ctype.o |
94d23317 | 461 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) test-date.c date.o ctype.o |
28818ffa | 462 | |
2f29dd52 | 463 | test-delta$X: test-delta.c diff-delta.o patch-delta.o |
94d23317 | 464 | $(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $^ |
28818ffa PB |
465 | |
466 | check: | |
773b6339 | 467 | for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; done |
28818ffa PB |
468 | |
469 | ||
470 | ||
471 | ### Installation rules | |
472 | ||
d6ebd259 | 473 | install: all |
4769948a | 474 | $(INSTALL) -d -m755 $(call shellquote,$(DESTDIR)$(bindir)) |
d6ebd259 | 475 | $(INSTALL) $(ALL_PROGRAMS) $(call shellquote,$(DESTDIR)$(bindir)) |
8d5afef0 | 476 | $(MAKE) -C templates install |
4769948a JH |
477 | $(INSTALL) -d -m755 $(call shellquote,$(DESTDIR)$(GIT_PYTHON_DIR)) |
478 | $(INSTALL) $(PYMODULES) $(call shellquote,$(DESTDIR)$(GIT_PYTHON_DIR)) | |
28818ffa PB |
479 | |
480 | install-doc: | |
481 | $(MAKE) -C Documentation install | |
482 | ||
483 | ||
484 | ||
485 | ||
486 | ### Maintainer's dist rules | |
487 | ||
9b88fcef | 488 | git.spec: git.spec.in |
a9db2974 CW |
489 | sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@ |
490 | ||
27dedf0c JH |
491 | GIT_TARNAME=git-$(GIT_VERSION) |
492 | dist: git.spec git-tar-tree | |
b1de9de2 | 493 | ./git-tar-tree HEAD $(GIT_TARNAME) > $(GIT_TARNAME).tar |
a9db2974 | 494 | @mkdir -p $(GIT_TARNAME) |
27dedf0c | 495 | @cp git.spec $(GIT_TARNAME) |
181129d2 PA |
496 | @echo $(GIT_VERSION) > $(GIT_TARNAME)/version |
497 | $(TAR) rf $(GIT_TARNAME).tar \ | |
498 | $(GIT_TARNAME)/git.spec $(GIT_TARNAME)/version | |
a9db2974 | 499 | @rm -rf $(GIT_TARNAME) |
9dce3c06 | 500 | gzip -f -9 $(GIT_TARNAME).tar |
a9db2974 CW |
501 | |
502 | rpm: dist | |
27dedf0c | 503 | $(RPMBUILD) -ta $(GIT_TARNAME).tar.gz |
a9db2974 | 504 | |
28818ffa | 505 | ### Cleaning rules |
87a81c83 | 506 | |
e83c5163 | 507 | clean: |
9ce392f4 JH |
508 | rm -f *.o mozilla-sha1/*.o arm/*.o ppc/*.o compat/*.o $(LIB_FILE) |
509 | rm -f $(PROGRAMS) $(SIMPLE_PROGRAMS) git$X | |
bc6146d2 | 510 | rm -f $(filter-out gitk,$(SCRIPTS)) |
d89056c2 | 511 | rm -f *.spec *.pyc *.pyo */*.pyc */*.pyo |
f29eaed1 | 512 | rm -rf $(GIT_TARNAME) |
5a571cdd | 513 | rm -f $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz |
ca67f002 | 514 | $(MAKE) -C Documentation/ clean |
229a7ed7 | 515 | $(MAKE) -C templates clean |
4b7581f0 | 516 | $(MAKE) -C t/ clean |
9b88fcef JH |
517 | rm -f GIT-VERSION-FILE |
518 | ||
4dc00021 | 519 | .PHONY: all install clean strip |
9b88fcef | 520 | .PHONY: .FORCE-GIT-VERSION-FILE |
d89056c2 | 521 |