]>
Commit | Line | Data |
---|---|---|
5bdac8b3 PB |
1 | # Define MOZILLA_SHA1 environment variable when running make to make use of |
2 | # a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast | |
3 | # on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default | |
4 | # choice) has very fast version optimized for i586. | |
bdd4da59 | 5 | # |
5bdac8b3 PB |
6 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. You will |
7 | # miss out git-rev-list --merge-order. This also implies MOZILLA_SHA1. | |
2cb45e95 | 8 | # |
b2c0bd65 JS |
9 | # Define NO_CURL if you do not have curl installed. git-http-pull is not |
10 | # built, and you cannot use http:// and https:// transports. | |
11 | # | |
6d9bbc50 PM |
12 | # Define CURLDIR=/foo/bar if your curl header and library files are in |
13 | # /foo/bar/include and /foo/bar/lib directories. | |
14 | # | |
ef34af24 LT |
15 | # Define NO_STRCASESTR if you don't have strcasestr. |
16 | # | |
5bdac8b3 PB |
17 | # Define PPC_SHA1 environment variable when running make to make use of |
18 | # a bundled SHA1 routine optimized for PowerPC. | |
597c9cc5 | 19 | # |
7c6ef2f2 NP |
20 | # Define ARM_SHA1 environment variable when running make to make use of |
21 | # a bundled SHA1 routine optimized for ARM. | |
22 | # | |
597c9cc5 | 23 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). |
f0ebff0d | 24 | # |
597c9cc5 | 25 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). |
f0ebff0d PM |
26 | # |
27 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, | |
28 | # Patrick Mauritz). | |
29 | # | |
730d48a2 JS |
30 | # Define NO_MMAP if you want to avoid mmap. |
31 | # | |
343d35c9 JH |
32 | # Define WITH_OWN_SUBPROCESS_PY if you want to use with python 2.3. |
33 | # | |
49744d63 PA |
34 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). |
35 | # | |
5bdac8b3 PB |
36 | # Define COLLISION_CHECK below if you believe that SHA1's |
37 | # 1461501637330902918203684832716283019655932542976 hashes do not give you | |
38 | # sufficient guarantee that no collisions between objects will ever happen. | |
39 | ||
40 | # DEFINES += -DCOLLISION_CHECK | |
41 | ||
42 | # Define USE_NSEC below if you want git to care about sub-second file mtimes | |
43 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and | |
44 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely | |
45 | # randomly break unless your underlying filesystem supports those sub-second | |
46 | # times (my ext3 doesn't). | |
47 | ||
48 | # DEFINES += -DUSE_NSEC | |
49 | ||
50 | # Define USE_STDEV below if you want git to care about the underlying device | |
51 | # change being considered an inode change from the update-cache perspective. | |
52 | ||
53 | # DEFINES += -DUSE_STDEV | |
54 | ||
baaac6a7 | 55 | GIT_VERSION = 0.99.8.GIT |
a9db2974 | 56 | |
b05701c5 | 57 | CFLAGS = -g -O2 -Wall |
f0ebff0d | 58 | ALL_CFLAGS = $(CFLAGS) $(PLATFORM_DEFINES) $(DEFINES) |
29c2cce4 | 59 | |
b05701c5 PR |
60 | prefix = $(HOME) |
61 | bindir = $(prefix)/bin | |
62 | template_dir = $(prefix)/share/git-core/templates/ | |
720d150c | 63 | GIT_PYTHON_DIR = $(prefix)/share/git-core/python |
a682ef9f | 64 | # DESTDIR= |
5c2a7fbc | 65 | |
b05701c5 PR |
66 | CC = gcc |
67 | AR = ar | |
229a7ed7 | 68 | TAR = tar |
b05701c5 PR |
69 | INSTALL = install |
70 | RPMBUILD = rpmbuild | |
e83c5163 | 71 | |
44c9e859 LT |
72 | # sparse is architecture-neutral, which means that we need to tell it |
73 | # explicitly what architecture to check for. Fix this up for yours.. | |
b05701c5 | 74 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ |
44c9e859 | 75 | |
28818ffa PB |
76 | |
77 | ||
78 | ### --- END CONFIGURATION SECTION --- | |
79 | ||
215a7ad1 JH |
80 | SCRIPT_SH = \ |
81 | git-add.sh git-bisect.sh git-branch.sh git-checkout.sh \ | |
82 | git-cherry.sh git-clone.sh git-commit.sh \ | |
83 | git-count-objects.sh git-diff.sh git-fetch.sh \ | |
84 | git-format-patch.sh git-log.sh git-ls-remote.sh \ | |
85 | git-merge-one-file.sh git-octopus.sh git-parse-remote.sh \ | |
86 | git-prune.sh git-pull.sh git-push.sh git-rebase.sh \ | |
87 | git-repack.sh git-request-pull.sh git-reset.sh \ | |
88 | git-resolve.sh git-revert.sh git-sh-setup.sh git-status.sh \ | |
89 | git-tag.sh git-verify-tag.sh git-whatchanged.sh git.sh \ | |
d1c5f2a4 | 90 | git-applymbox.sh git-applypatch.sh git-am.sh \ |
2276aa6c | 91 | git-merge.sh git-merge-stupid.sh git-merge-octopus.sh \ |
f22cc3fc | 92 | git-merge-resolve.sh git-grep.sh |
215a7ad1 JH |
93 | |
94 | SCRIPT_PERL = \ | |
95 | git-archimport.perl git-cvsimport.perl git-relink.perl \ | |
c8b48ba4 | 96 | git-rename.perl git-shortlog.perl git-fmt-merge-msg.perl |
60036a41 | 97 | |
720d150c | 98 | SCRIPT_PYTHON = \ |
e4cf17ce | 99 | git-merge-recursive.py |
720d150c | 100 | |
597c9cc5 JH |
101 | # The ones that do not have to link with lcrypto nor lz. |
102 | SIMPLE_PROGRAMS = \ | |
2f29dd52 PA |
103 | git-get-tar-commit-id$X git-mailinfo$X git-mailsplit$X \ |
104 | git-stripspace$X git-var$X git-daemon$X | |
597c9cc5 JH |
105 | |
106 | # ... and all the rest | |
215a7ad1 | 107 | PROGRAMS = \ |
79a9d8ea PA |
108 | git-apply$X git-cat-file$X \ |
109 | git-checkout-index$X git-clone-pack$X git-commit-tree$X \ | |
110 | git-convert-objects$X git-diff-files$X \ | |
111 | git-diff-index$X git-diff-stages$X \ | |
112 | git-diff-tree$X git-fetch-pack$X git-fsck-objects$X \ | |
113 | git-hash-object$X git-init-db$X \ | |
114 | git-local-fetch$X git-ls-files$X git-ls-tree$X git-merge-base$X \ | |
115 | git-merge-index$X git-mktag$X git-pack-objects$X git-patch-id$X \ | |
116 | git-peek-remote$X git-prune-packed$X git-read-tree$X \ | |
117 | git-receive-pack$X git-rev-list$X git-rev-parse$X \ | |
118 | git-send-pack$X git-show-branch$X \ | |
119 | git-show-index$X git-ssh-fetch$X \ | |
120 | git-ssh-upload$X git-tar-tree$X git-unpack-file$X \ | |
121 | git-unpack-objects$X git-update-index$X git-update-server-info$X \ | |
122 | git-upload-pack$X git-verify-pack$X git-write-tree$X \ | |
123 | git-update-ref$X git-symbolic-ref$X \ | |
597c9cc5 | 124 | $(SIMPLE_PROGRAMS) |
e83c5163 | 125 | |
894a8a8b | 126 | # Backward compatibility -- to be removed after 1.0 |
2f29dd52 | 127 | PROGRAMS += git-ssh-pull$X git-ssh-push$X |
f71a69ab | 128 | |
0842acff JH |
129 | GIT_LIST_TWEAK = |
130 | ||
720d150c JH |
131 | PYMODULES = \ |
132 | gitMergeCommon.py | |
133 | ||
343d35c9 JH |
134 | ifdef WITH_OWN_SUBPROCESS_PY |
135 | PYMODULES += compat/subprocess.py | |
136 | endif | |
137 | ||
90bc118f | 138 | ifdef WITH_SEND_EMAIL |
215a7ad1 | 139 | SCRIPT_PERL += git-send-email.perl |
0842acff JH |
140 | else |
141 | GIT_LIST_TWEAK += -e '/^send-email$$/d' | |
90bc118f JH |
142 | endif |
143 | ||
0a02ce72 | 144 | LIB_FILE=libgit.a |
8f3f9b09 | 145 | |
215a7ad1 JH |
146 | LIB_H = \ |
147 | blob.h cache.h commit.h count-delta.h csum-file.h delta.h \ | |
148 | diff.h epoch.h object.h pack.h pkt-line.h quote.h refs.h \ | |
0f56479d | 149 | run-command.h strbuf.h tag.h tree.h |
b1bf95bb | 150 | |
215a7ad1 JH |
151 | DIFF_OBJS = \ |
152 | diff.o diffcore-break.o diffcore-order.o diffcore-pathspec.o \ | |
153 | diffcore-pickaxe.o diffcore-rename.o | |
d1df5743 | 154 | |
215a7ad1 JH |
155 | LIB_OBJS = \ |
156 | blob.o commit.o connect.o count-delta.o csum-file.o \ | |
a9ab586a | 157 | date.o diff-delta.o entry.o ident.o index.o \ |
215a7ad1 | 158 | object.o pack-check.o patch-delta.o path.o pkt-line.o \ |
0f56479d | 159 | quote.o read-cache.o refs.o run-command.o \ |
215a7ad1 JH |
160 | server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \ |
161 | tag.o tree.o usage.o $(DIFF_OBJS) | |
d19938ab | 162 | |
cc1ad5c8 LT |
163 | LIBS = $(LIB_FILE) |
164 | LIBS += -lz | |
cef661fc | 165 | |
229a7ed7 JH |
166 | # |
167 | # Platform specific tweaks | |
168 | # | |
f7c15343 JH |
169 | |
170 | # We choose to avoid "if .. else if .. else .. endif endif" | |
171 | # because maintaining the nesting to match is a pain. If | |
172 | # we had "elif" things would have been much nicer... | |
173 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') | |
174 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') | |
175 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') | |
176 | ||
177 | ifeq ($(uname_S),Darwin) | |
597c9cc5 JH |
178 | NEEDS_SSL_WITH_CRYPTO = YesPlease |
179 | NEEDS_LIBICONV = YesPlease | |
180 | endif | |
f7c15343 | 181 | ifeq ($(uname_S),SunOS) |
f0ebff0d | 182 | NEEDS_SOCKET = YesPlease |
5a90d4ac | 183 | NEEDS_NSL = YesPlease |
229a7ed7 JH |
184 | SHELL_PATH = /bin/bash |
185 | NO_STRCASESTR = YesPlease | |
186 | CURLDIR = /opt/sfw | |
187 | INSTALL = ginstall | |
188 | TAR = gtar | |
5a90d4ac | 189 | PLATFORM_DEFINES += -D__EXTENSIONS__ |
f0ebff0d | 190 | endif |
f7c15343 | 191 | ifeq ($(uname_O),Cygwin) |
17754517 PA |
192 | NO_STRCASESTR = YesPlease |
193 | NEEDS_LIBICONV = YesPlease | |
49744d63 | 194 | NO_IPV6 = YesPlease |
a23cd8ec | 195 | X = .exe |
4514385e | 196 | PLATFORM_DEFINES += -DUSE_SYMLINK_HEAD=0 |
17754517 | 197 | endif |
f7c15343 | 198 | ifeq ($(uname_S),OpenBSD) |
18c5a525 HB |
199 | NEEDS_LIBICONV = YesPlease |
200 | PLATFORM_DEFINES += -I/usr/local/include -L/usr/local/lib | |
201 | endif | |
f7c15343 JH |
202 | ifneq (,$(findstring arm,$(uname_M))) |
203 | ARM_SHA1 = YesPlease | |
204 | endif | |
597c9cc5 | 205 | |
229a7ed7 JH |
206 | ifndef NO_CURL |
207 | ifdef CURLDIR | |
208 | # This is still problematic -- gcc does not want -R. | |
209 | CFLAGS += -I$(CURLDIR)/include | |
210 | CURL_LIBCURL = -L$(CURLDIR)/lib -R$(CURLDIR)/lib -lcurl | |
211 | else | |
212 | CURL_LIBCURL = -lcurl | |
213 | endif | |
2f29dd52 | 214 | PROGRAMS += git-http-fetch$X |
229a7ed7 JH |
215 | endif |
216 | ||
bc6146d2 JH |
217 | ifndef SHELL_PATH |
218 | SHELL_PATH = /bin/sh | |
219 | endif | |
220 | ifndef PERL_PATH | |
221 | PERL_PATH = /usr/bin/perl | |
222 | endif | |
720d150c JH |
223 | ifndef PYTHON_PATH |
224 | PYTHON_PATH = /usr/bin/python | |
225 | endif | |
bc6146d2 | 226 | |
dd53c7ab PB |
227 | ifndef NO_OPENSSL |
228 | LIB_OBJS += epoch.o | |
215a7ad1 | 229 | OPENSSL_LIBSSL = -lssl |
455a7f32 JH |
230 | ifdef OPENSSLDIR |
231 | # Again this may be problematic -- gcc does not always want -R. | |
232 | CFLAGS += -I$(OPENSSLDIR)/include | |
233 | OPENSSL_LINK = -L$(OPENSSLDIR)/lib -R$(OPENSSLDIR)/lib | |
234 | else | |
235 | OPENSSL_LINK = | |
236 | endif | |
dd53c7ab | 237 | else |
b05701c5 | 238 | DEFINES += '-DNO_OPENSSL' |
215a7ad1 JH |
239 | MOZILLA_SHA1 = 1 |
240 | OPENSSL_LIBSSL = | |
dd53c7ab | 241 | endif |
597c9cc5 | 242 | ifdef NEEDS_SSL_WITH_CRYPTO |
455a7f32 | 243 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl |
597c9cc5 | 244 | else |
455a7f32 | 245 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto |
597c9cc5 JH |
246 | endif |
247 | ifdef NEEDS_LIBICONV | |
455a7f32 JH |
248 | ifdef ICONVDIR |
249 | # Again this may be problematic -- gcc does not always want -R. | |
250 | CFLAGS += -I$(ICONVDIR)/include | |
251 | ICONV_LINK = -L$(ICONVDIR)/lib -R$(ICONVDIR)/lib | |
252 | else | |
253 | ICONV_LINK = | |
254 | endif | |
255 | LIB_4_ICONV = $(ICONV_LINK) -liconv | |
597c9cc5 JH |
256 | else |
257 | LIB_4_ICONV = | |
258 | endif | |
f0ebff0d PM |
259 | ifdef NEEDS_SOCKET |
260 | LIBS += -lsocket | |
261 | SIMPLE_LIB += -lsocket | |
262 | endif | |
5a90d4ac JH |
263 | ifdef NEEDS_NSL |
264 | LIBS += -lnsl | |
265 | SIMPLE_LIB += -lnsl | |
266 | endif | |
ef34af24 LT |
267 | ifdef NO_STRCASESTR |
268 | DEFINES += -Dstrcasestr=gitstrcasestr | |
269 | LIB_OBJS += compat/strcasestr.o | |
270 | endif | |
730d48a2 JS |
271 | ifdef NO_MMAP |
272 | DEFINES += -Dmmap=gitfakemmap -Dmunmap=gitfakemunmap -DNO_MMAP | |
273 | LIB_OBJS += compat/mmap.o | |
274 | endif | |
49744d63 | 275 | ifdef NO_IPV6 |
6573faff | 276 | DEFINES += -DNO_IPV6 -Dsockaddr_storage=sockaddr_in |
49744d63 | 277 | endif |
cef661fc | 278 | |
7c6ef2f2 NP |
279 | ifdef PPC_SHA1 |
280 | SHA1_HEADER = "ppc/sha1.h" | |
281 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o | |
282 | else | |
283 | ifdef ARM_SHA1 | |
284 | SHA1_HEADER = "arm/sha1.h" | |
285 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o | |
286 | else | |
287 | ifdef MOZILLA_SHA1 | |
288 | SHA1_HEADER = "mozilla-sha1/sha1.h" | |
289 | LIB_OBJS += mozilla-sha1/sha1.o | |
290 | else | |
291 | SHA1_HEADER = <openssl/sha.h> | |
292 | LIBS += $(LIB_4_CRYPTO) | |
293 | endif | |
294 | endif | |
295 | endif | |
296 | ||
b05701c5 | 297 | DEFINES += '-DSHA1_HEADER=$(SHA1_HEADER)' |
cc1ad5c8 | 298 | |
bc6146d2 | 299 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ |
720d150c JH |
300 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ |
301 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) \ | |
302 | gitk | |
44c9e859 | 303 | |
d2b8593f | 304 | export prefix TAR INSTALL DESTDIR SHELL_PATH |
28818ffa PB |
305 | ### Build rules |
306 | ||
bb8c91d6 | 307 | all: $(PROGRAMS) $(SCRIPTS) |
89967023 | 308 | |
d3af621b JH |
309 | all: |
310 | $(MAKE) -C templates | |
b05701c5 | 311 | |
bc6146d2 | 312 | git: git.sh Makefile |
6a2e50f9 | 313 | rm -f $@+ $@ |
229a7ed7 | 314 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH)|' \ |
0842acff | 315 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
c8c5b21a | 316 | -e 's/@@X@@/$(X)/g' \ |
0842acff | 317 | $(GIT_LIST_TWEAK) <$@.sh >$@+ |
6a2e50f9 JH |
318 | chmod +x $@+ |
319 | mv $@+ $@ | |
320 | ||
bc6146d2 JH |
321 | $(filter-out git,$(patsubst %.sh,%,$(SCRIPT_SH))) : % : %.sh |
322 | rm -f $@ | |
3ff8cbed JH |
323 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH)|' \ |
324 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
325 | $@.sh >$@ | |
bc6146d2 JH |
326 | chmod +x $@ |
327 | ||
328 | $(patsubst %.perl,%,$(SCRIPT_PERL)) : % : %.perl | |
329 | rm -f $@ | |
3ff8cbed JH |
330 | sed -e '1s|#!.*perl|#!$(PERL_PATH)|' \ |
331 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
332 | $@.perl >$@ | |
bc6146d2 JH |
333 | chmod +x $@ |
334 | ||
720d150c JH |
335 | $(patsubst %.py,%,$(SCRIPT_PYTHON)) : % : %.py |
336 | rm -f $@ | |
337 | sed -e '1s|#!.*python|#!$(PYTHON_PATH)|' \ | |
338 | -e 's|@@GIT_PYTHON_PATH@@|$(GIT_PYTHON_DIR)|g' \ | |
3ff8cbed JH |
339 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ |
340 | $@.py >$@ | |
720d150c JH |
341 | chmod +x $@ |
342 | ||
b05701c5 PR |
343 | %.o: %.c |
344 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
345 | %.o: %.S | |
346 | $(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
a310d434 | 347 | |
2f29dd52 | 348 | git-%$X: %.o $(LIB_FILE) |
b05701c5 | 349 | $(CC) $(ALL_CFLAGS) -o $@ $(filter %.o,$^) $(LIBS) |
623c8a14 | 350 | |
2f29dd52 | 351 | git-mailinfo$X : SIMPLE_LIB += $(LIB_4_ICONV) |
bb8c91d6 | 352 | $(SIMPLE_PROGRAMS) : $(LIB_FILE) |
2f29dd52 | 353 | $(SIMPLE_PROGRAMS) : git-%$X : %.o |
597c9cc5 JH |
354 | $(CC) $(ALL_CFLAGS) -o $@ $(filter %.o,$^) $(LIB_FILE) $(SIMPLE_LIB) |
355 | ||
2f29dd52 PA |
356 | git-http-fetch$X: fetch.o |
357 | git-local-fetch$X: fetch.o | |
358 | git-ssh-fetch$X: rsh.o fetch.o | |
359 | git-ssh-upload$X: rsh.o | |
360 | git-ssh-pull$X: rsh.o fetch.o | |
361 | git-ssh-push$X: rsh.o | |
a3df1801 | 362 | |
2f29dd52 PA |
363 | git-http-fetch$X: LIBS += $(CURL_LIBCURL) |
364 | git-rev-list$X: LIBS += $(OPENSSL_LIBSSL) | |
a3df1801 | 365 | |
d3af621b | 366 | init-db.o: init-db.c |
b05701c5 PR |
367 | $(CC) -c $(ALL_CFLAGS) \ |
368 | -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir)"' $*.c | |
d3af621b | 369 | |
e468305a | 370 | $(LIB_OBJS): $(LIB_H) |
2f29dd52 | 371 | $(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) |
e468305a | 372 | $(DIFF_OBJS): diffcore.h |
e83c5163 | 373 | |
28818ffa PB |
374 | $(LIB_FILE): $(LIB_OBJS) |
375 | $(AR) rcs $@ $(LIB_OBJS) | |
376 | ||
377 | doc: | |
378 | $(MAKE) -C Documentation all | |
379 | ||
380 | ||
28818ffa PB |
381 | ### Testing rules |
382 | ||
383 | test: all | |
384 | $(MAKE) -C t/ all | |
385 | ||
2f29dd52 | 386 | test-date$X: test-date.c date.o |
b05701c5 | 387 | $(CC) $(ALL_CFLAGS) -o $@ test-date.c date.o |
28818ffa | 388 | |
2f29dd52 | 389 | test-delta$X: test-delta.c diff-delta.o patch-delta.o |
b05701c5 | 390 | $(CC) $(ALL_CFLAGS) -o $@ $^ |
28818ffa PB |
391 | |
392 | check: | |
b05701c5 | 393 | for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i; done |
28818ffa PB |
394 | |
395 | ||
396 | ||
397 | ### Installation rules | |
398 | ||
bb8c91d6 | 399 | install: $(PROGRAMS) $(SCRIPTS) |
53764ee4 | 400 | $(INSTALL) -d -m755 $(DESTDIR)$(bindir) |
bb8c91d6 | 401 | $(INSTALL) $(PROGRAMS) $(SCRIPTS) $(DESTDIR)$(bindir) |
bc6146d2 | 402 | $(INSTALL) git-revert $(DESTDIR)$(bindir)/git-cherry-pick |
894a8a8b | 403 | sh ./cmd-rename.sh $(DESTDIR)$(bindir) |
8d5afef0 | 404 | $(MAKE) -C templates install |
53764ee4 | 405 | $(INSTALL) -d -m755 $(DESTDIR)$(GIT_PYTHON_DIR) |
720d150c | 406 | $(INSTALL) $(PYMODULES) $(DESTDIR)$(GIT_PYTHON_DIR) |
28818ffa PB |
407 | |
408 | install-doc: | |
409 | $(MAKE) -C Documentation install | |
410 | ||
411 | ||
412 | ||
413 | ||
414 | ### Maintainer's dist rules | |
415 | ||
78d9d414 | 416 | git-core.spec: git-core.spec.in Makefile |
a9db2974 CW |
417 | sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@ |
418 | ||
f85639c3 LT |
419 | GIT_TARNAME=git-core-$(GIT_VERSION) |
420 | dist: git-core.spec git-tar-tree | |
b1de9de2 | 421 | ./git-tar-tree HEAD $(GIT_TARNAME) > $(GIT_TARNAME).tar |
a9db2974 | 422 | @mkdir -p $(GIT_TARNAME) |
f85639c3 | 423 | @cp git-core.spec $(GIT_TARNAME) |
229a7ed7 | 424 | $(TAR) rf $(GIT_TARNAME).tar $(GIT_TARNAME)/git-core.spec |
a9db2974 | 425 | @rm -rf $(GIT_TARNAME) |
9dce3c06 | 426 | gzip -f -9 $(GIT_TARNAME).tar |
a9db2974 CW |
427 | |
428 | rpm: dist | |
d7b8a164 | 429 | $(RPMBUILD) -ta git-core-$(GIT_VERSION).tar.gz |
a9db2974 | 430 | |
7a590132 | 431 | deb: dist |
f29eaed1 | 432 | rm -rf $(GIT_TARNAME) |
229a7ed7 | 433 | $(TAR) zxf $(GIT_TARNAME).tar.gz |
5a571cdd | 434 | dpkg-source -b $(GIT_TARNAME) |
f29eaed1 | 435 | cd $(GIT_TARNAME) && fakeroot debian/rules binary |
28818ffa PB |
436 | |
437 | ### Cleaning rules | |
87a81c83 | 438 | |
e83c5163 | 439 | clean: |
bb8c91d6 | 440 | rm -f *.o mozilla-sha1/*.o ppc/*.o compat/*.o $(PROGRAMS) $(LIB_FILE) |
bc6146d2 | 441 | rm -f $(filter-out gitk,$(SCRIPTS)) |
a5579767 | 442 | rm -f git-core.spec *.pyc *.pyo |
f29eaed1 | 443 | rm -rf $(GIT_TARNAME) |
5a571cdd JH |
444 | rm -f $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz |
445 | rm -f git-core_$(GIT_VERSION)-*.deb git-core_$(GIT_VERSION)-*.dsc | |
446 | rm -f git-tk_$(GIT_VERSION)-*.deb | |
ca67f002 | 447 | $(MAKE) -C Documentation/ clean |
229a7ed7 | 448 | $(MAKE) -C templates clean |
4b7581f0 | 449 | $(MAKE) -C t/ clean |