]>
Commit | Line | Data |
---|---|---|
1 | # The default target of this Makefile is... | |
2 | all:: | |
3 | ||
4 | # Define V=1 to have a more verbose compile. | |
5 | # | |
6 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. | |
7 | # This also implies MOZILLA_SHA1. | |
8 | # | |
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. | |
12 | # | |
13 | # Define CURLDIR=/foo/bar if your curl header and library files are in | |
14 | # /foo/bar/include and /foo/bar/lib directories. | |
15 | # | |
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 | # | |
19 | # Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent. | |
20 | # | |
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 | # | |
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). | |
27 | # some C compilers supported these specifiers prior to C99 as an extension. | |
28 | # | |
29 | # Define NO_STRCASESTR if you don't have strcasestr. | |
30 | # | |
31 | # Define NO_STRLCPY if you don't have strlcpy. | |
32 | # | |
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 | # | |
37 | # Define NO_SETENV if you don't have setenv in the C library. | |
38 | # | |
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. | |
41 | # | |
42 | # Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability | |
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 | # | |
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 | # | |
58 | # Define PPC_SHA1 environment variable when running make to make use of | |
59 | # a bundled SHA1 routine optimized for PowerPC. | |
60 | # | |
61 | # Define ARM_SHA1 environment variable when running make to make use of | |
62 | # a bundled SHA1 routine optimized for ARM. | |
63 | # | |
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 | # | |
69 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). | |
70 | # | |
71 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). | |
72 | # | |
73 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, | |
74 | # Patrick Mauritz). | |
75 | # | |
76 | # Define NO_MMAP if you want to avoid mmap. | |
77 | # | |
78 | # Define NO_PREAD if you have a problem with pread() system call (e.g. | |
79 | # cygwin.dll before v1.5.22). | |
80 | # | |
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 | # | |
84 | # Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support | |
85 | # the executable mode bit, but doesn't really do so. | |
86 | # | |
87 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). | |
88 | # | |
89 | # Define NO_SOCKADDR_STORAGE if your platform does not have struct | |
90 | # sockaddr_storage. | |
91 | # | |
92 | # Define NO_ICONV if your libc does not properly support iconv. | |
93 | # | |
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 | # | |
97 | # Define NO_DEFLATE_BOUND if your zlib does not have deflateBound. | |
98 | # | |
99 | # Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib" | |
100 | # that tells runtime paths to dynamic libraries; | |
101 | # "-Wl,-rpath=/path/lib" is used instead. | |
102 | # | |
103 | # Define USE_NSEC below if you want git to care about sub-second file mtimes | |
104 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and | |
105 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely | |
106 | # randomly break unless your underlying filesystem supports those sub-second | |
107 | # times (my ext3 doesn't). | |
108 | # | |
109 | # Define USE_STDEV below if you want git to care about the underlying device | |
110 | # change being considered an inode change from the update-cache perspective. | |
111 | # | |
112 | # Define ASCIIDOC8 if you want to format documentation with AsciiDoc 8 | |
113 | # | |
114 | # Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72. | |
115 | # | |
116 | # Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's | |
117 | # MakeMaker (e.g. using ActiveState under Cygwin). | |
118 | # | |
119 | # Define NO_TCLTK if you do not want Tcl/Tk GUI. | |
120 | # | |
121 | # The TCL_PATH variable governs the location of the Tcl interpreter | |
122 | # used to optimize git-gui for your system. Only used if NO_TCLTK | |
123 | # is not set. Defaults to the bare 'tclsh'. | |
124 | # | |
125 | # The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter. | |
126 | # If not set it defaults to the bare 'wish'. If it is set to the empty | |
127 | # string then NO_TCLTK will be forced (this is used by configure script). | |
128 | # | |
129 | ||
130 | GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE | |
131 | @$(SHELL_PATH) ./GIT-VERSION-GEN | |
132 | -include GIT-VERSION-FILE | |
133 | ||
134 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') | |
135 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') | |
136 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') | |
137 | uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') | |
138 | uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not') | |
139 | ||
140 | # CFLAGS and LDFLAGS are for the users to override from the command line. | |
141 | ||
142 | CFLAGS = -g -O2 -Wall | |
143 | LDFLAGS = | |
144 | ALL_CFLAGS = $(CFLAGS) | |
145 | ALL_LDFLAGS = $(LDFLAGS) | |
146 | STRIP ?= strip | |
147 | ||
148 | prefix = $(HOME) | |
149 | bindir = $(prefix)/bin | |
150 | gitexecdir = $(bindir) | |
151 | sharedir = $(prefix)/share | |
152 | template_dir = $(sharedir)/git-core/templates | |
153 | ifeq ($(prefix),/usr) | |
154 | sysconfdir = /etc | |
155 | else | |
156 | sysconfdir = $(prefix)/etc | |
157 | endif | |
158 | lib = lib | |
159 | ETC_GITCONFIG = $(sysconfdir)/gitconfig | |
160 | # DESTDIR= | |
161 | ||
162 | # default configuration for gitweb | |
163 | GITWEB_CONFIG = gitweb_config.perl | |
164 | GITWEB_HOME_LINK_STR = projects | |
165 | GITWEB_SITENAME = | |
166 | GITWEB_PROJECTROOT = /pub/git | |
167 | GITWEB_EXPORT_OK = | |
168 | GITWEB_STRICT_EXPORT = | |
169 | GITWEB_BASE_URL = | |
170 | GITWEB_LIST = | |
171 | GITWEB_HOMETEXT = indextext.html | |
172 | GITWEB_CSS = gitweb.css | |
173 | GITWEB_LOGO = git-logo.png | |
174 | GITWEB_FAVICON = git-favicon.png | |
175 | GITWEB_SITE_HEADER = | |
176 | GITWEB_SITE_FOOTER = | |
177 | ||
178 | export prefix bindir gitexecdir sharedir template_dir sysconfdir | |
179 | ||
180 | CC = gcc | |
181 | AR = ar | |
182 | RM = rm -f | |
183 | TAR = tar | |
184 | FIND = find | |
185 | INSTALL = install | |
186 | RPMBUILD = rpmbuild | |
187 | TCL_PATH = tclsh | |
188 | TCLTK_PATH = wish | |
189 | ||
190 | export TCL_PATH TCLTK_PATH | |
191 | ||
192 | # sparse is architecture-neutral, which means that we need to tell it | |
193 | # explicitly what architecture to check for. Fix this up for yours.. | |
194 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ | |
195 | ||
196 | ||
197 | ||
198 | ### --- END CONFIGURATION SECTION --- | |
199 | ||
200 | # Those must not be GNU-specific; they are shared with perl/ which may | |
201 | # be built by a different compiler. (Note that this is an artifact now | |
202 | # but it still might be nice to keep that distinction.) | |
203 | BASIC_CFLAGS = | |
204 | BASIC_LDFLAGS = | |
205 | ||
206 | SCRIPT_SH = \ | |
207 | git-bisect.sh git-checkout.sh \ | |
208 | git-clean.sh git-clone.sh git-commit.sh \ | |
209 | git-fetch.sh \ | |
210 | git-ls-remote.sh \ | |
211 | git-merge-one-file.sh git-mergetool.sh git-parse-remote.sh \ | |
212 | git-pull.sh git-rebase.sh git-rebase--interactive.sh \ | |
213 | git-repack.sh git-request-pull.sh git-reset.sh \ | |
214 | git-sh-setup.sh \ | |
215 | git-am.sh \ | |
216 | git-merge.sh git-merge-stupid.sh git-merge-octopus.sh \ | |
217 | git-merge-resolve.sh git-merge-ours.sh \ | |
218 | git-lost-found.sh git-quiltimport.sh git-submodule.sh \ | |
219 | git-filter-branch.sh \ | |
220 | git-stash.sh | |
221 | ||
222 | SCRIPT_PERL = \ | |
223 | git-add--interactive.perl \ | |
224 | git-archimport.perl git-cvsimport.perl git-relink.perl \ | |
225 | git-cvsserver.perl git-remote.perl \ | |
226 | git-svnimport.perl git-cvsexportcommit.perl \ | |
227 | git-send-email.perl git-svn.perl | |
228 | ||
229 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
230 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
231 | git-status git-instaweb | |
232 | ||
233 | # ... and all the rest that could be moved out of bindir to gitexecdir | |
234 | PROGRAMS = \ | |
235 | git-convert-objects$X git-fetch-pack$X \ | |
236 | git-hash-object$X git-index-pack$X git-local-fetch$X \ | |
237 | git-fast-import$X \ | |
238 | git-daemon$X \ | |
239 | git-merge-index$X git-mktag$X git-mktree$X git-patch-id$X \ | |
240 | git-peek-remote$X git-receive-pack$X \ | |
241 | git-send-pack$X git-shell$X \ | |
242 | git-show-index$X git-ssh-fetch$X \ | |
243 | git-ssh-upload$X git-unpack-file$X \ | |
244 | git-update-server-info$X \ | |
245 | git-upload-pack$X \ | |
246 | git-pack-redundant$X git-var$X \ | |
247 | git-merge-tree$X git-imap-send$X \ | |
248 | git-merge-recursive$X \ | |
249 | $(EXTRA_PROGRAMS) | |
250 | ||
251 | # Empty... | |
252 | EXTRA_PROGRAMS = | |
253 | ||
254 | BUILT_INS = \ | |
255 | git-format-patch$X git-show$X git-whatchanged$X git-cherry$X \ | |
256 | git-get-tar-commit-id$X git-init$X git-repo-config$X \ | |
257 | git-fsck-objects$X git-cherry-pick$X \ | |
258 | $(patsubst builtin-%.o,git-%$X,$(BUILTIN_OBJS)) | |
259 | ||
260 | # what 'all' will build and 'install' will install, in gitexecdir | |
261 | ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) | |
262 | ||
263 | ALL_PROGRAMS += git-merge-subtree$X | |
264 | ||
265 | # what 'all' will build but not install in gitexecdir | |
266 | OTHER_PROGRAMS = git$X gitweb/gitweb.cgi | |
267 | ifndef NO_TCLTK | |
268 | OTHER_PROGRAMS += gitk-wish | |
269 | endif | |
270 | ||
271 | # Backward compatibility -- to be removed after 1.0 | |
272 | PROGRAMS += git-ssh-pull$X git-ssh-push$X | |
273 | ||
274 | # Set paths to tools early so that they can be used for version tests. | |
275 | ifndef SHELL_PATH | |
276 | SHELL_PATH = /bin/sh | |
277 | endif | |
278 | ifndef PERL_PATH | |
279 | PERL_PATH = /usr/bin/perl | |
280 | endif | |
281 | ||
282 | export PERL_PATH | |
283 | ||
284 | LIB_FILE=libgit.a | |
285 | XDIFF_LIB=xdiff/lib.a | |
286 | ||
287 | LIB_H = \ | |
288 | archive.h blob.h cache.h cache-tree.h commit.h csum-file.h delta.h grep.h \ | |
289 | diff.h object.h pack.h pkt-line.h quote.h refs.h list-objects.h sideband.h \ | |
290 | run-command.h strbuf.h tag.h tree.h git-compat-util.h revision.h \ | |
291 | tree-walk.h log-tree.h dir.h path-list.h unpack-trees.h builtin.h \ | |
292 | utf8.h reflog-walk.h patch-ids.h attr.h decorate.h progress.h \ | |
293 | mailmap.h remote.h | |
294 | ||
295 | DIFF_OBJS = \ | |
296 | diff.o diff-lib.o diffcore-break.o diffcore-order.o \ | |
297 | diffcore-pickaxe.o diffcore-rename.o tree-diff.o combine-diff.o \ | |
298 | diffcore-delta.o log-tree.o | |
299 | ||
300 | LIB_OBJS = \ | |
301 | blob.o commit.o connect.o csum-file.o cache-tree.o base85.o \ | |
302 | date.o diff-delta.o entry.o exec_cmd.o ident.o \ | |
303 | interpolate.o \ | |
304 | lockfile.o \ | |
305 | patch-ids.o \ | |
306 | object.o pack-check.o pack-write.o patch-delta.o path.o pkt-line.o \ | |
307 | sideband.o reachable.o reflog-walk.o \ | |
308 | quote.o read-cache.o refs.o run-command.o dir.o object-refs.o \ | |
309 | server-info.o setup.o sha1_file.o sha1_name.o strbuf.o \ | |
310 | tag.o tree.o usage.o config.o environment.o ctype.o copy.o \ | |
311 | revision.o pager.o tree-walk.o xdiff-interface.o \ | |
312 | write_or_die.o trace.o list-objects.o grep.o match-trees.o \ | |
313 | alloc.o merge-file.o path-list.o help.o unpack-trees.o $(DIFF_OBJS) \ | |
314 | color.o wt-status.o archive-zip.o archive-tar.o shallow.o utf8.o \ | |
315 | convert.o attr.o decorate.o progress.o mailmap.o symlinks.o remote.o | |
316 | ||
317 | BUILTIN_OBJS = \ | |
318 | builtin-add.o \ | |
319 | builtin-annotate.o \ | |
320 | builtin-apply.o \ | |
321 | builtin-archive.o \ | |
322 | builtin-blame.o \ | |
323 | builtin-branch.o \ | |
324 | builtin-bundle.o \ | |
325 | builtin-cat-file.o \ | |
326 | builtin-check-attr.o \ | |
327 | builtin-checkout-index.o \ | |
328 | builtin-check-ref-format.o \ | |
329 | builtin-commit-tree.o \ | |
330 | builtin-count-objects.o \ | |
331 | builtin-describe.o \ | |
332 | builtin-diff.o \ | |
333 | builtin-diff-files.o \ | |
334 | builtin-diff-index.o \ | |
335 | builtin-diff-tree.o \ | |
336 | builtin-fetch--tool.o \ | |
337 | builtin-fmt-merge-msg.o \ | |
338 | builtin-for-each-ref.o \ | |
339 | builtin-fsck.o \ | |
340 | builtin-gc.o \ | |
341 | builtin-grep.o \ | |
342 | builtin-init-db.o \ | |
343 | builtin-log.o \ | |
344 | builtin-ls-files.o \ | |
345 | builtin-ls-tree.o \ | |
346 | builtin-mailinfo.o \ | |
347 | builtin-mailsplit.o \ | |
348 | builtin-merge-base.o \ | |
349 | builtin-merge-file.o \ | |
350 | builtin-mv.o \ | |
351 | builtin-name-rev.o \ | |
352 | builtin-pack-objects.o \ | |
353 | builtin-prune.o \ | |
354 | builtin-prune-packed.o \ | |
355 | builtin-push.o \ | |
356 | builtin-read-tree.o \ | |
357 | builtin-reflog.o \ | |
358 | builtin-config.o \ | |
359 | builtin-rerere.o \ | |
360 | builtin-rev-list.o \ | |
361 | builtin-rev-parse.o \ | |
362 | builtin-revert.o \ | |
363 | builtin-rm.o \ | |
364 | builtin-runstatus.o \ | |
365 | builtin-shortlog.o \ | |
366 | builtin-show-branch.o \ | |
367 | builtin-stripspace.o \ | |
368 | builtin-symbolic-ref.o \ | |
369 | builtin-tag.o \ | |
370 | builtin-tar-tree.o \ | |
371 | builtin-unpack-objects.o \ | |
372 | builtin-update-index.o \ | |
373 | builtin-update-ref.o \ | |
374 | builtin-upload-archive.o \ | |
375 | builtin-verify-pack.o \ | |
376 | builtin-verify-tag.o \ | |
377 | builtin-write-tree.o \ | |
378 | builtin-show-ref.o \ | |
379 | builtin-pack-refs.o | |
380 | ||
381 | GITLIBS = $(LIB_FILE) $(XDIFF_LIB) | |
382 | EXTLIBS = | |
383 | ||
384 | # | |
385 | # Platform specific tweaks | |
386 | # | |
387 | ||
388 | # We choose to avoid "if .. else if .. else .. endif endif" | |
389 | # because maintaining the nesting to match is a pain. If | |
390 | # we had "elif" things would have been much nicer... | |
391 | ||
392 | ifeq ($(uname_S),Linux) | |
393 | NO_STRLCPY = YesPlease | |
394 | endif | |
395 | ifeq ($(uname_S),GNU/kFreeBSD) | |
396 | NO_STRLCPY = YesPlease | |
397 | endif | |
398 | ifeq ($(uname_S),Darwin) | |
399 | NEEDS_SSL_WITH_CRYPTO = YesPlease | |
400 | NEEDS_LIBICONV = YesPlease | |
401 | OLD_ICONV = UnfortunatelyYes | |
402 | NO_STRLCPY = YesPlease | |
403 | endif | |
404 | ifeq ($(uname_S),SunOS) | |
405 | NEEDS_SOCKET = YesPlease | |
406 | NEEDS_NSL = YesPlease | |
407 | SHELL_PATH = /bin/bash | |
408 | NO_STRCASESTR = YesPlease | |
409 | NO_HSTRERROR = YesPlease | |
410 | ifeq ($(uname_R),5.8) | |
411 | NEEDS_LIBICONV = YesPlease | |
412 | NO_UNSETENV = YesPlease | |
413 | NO_SETENV = YesPlease | |
414 | NO_C99_FORMAT = YesPlease | |
415 | NO_STRTOUMAX = YesPlease | |
416 | endif | |
417 | ifeq ($(uname_R),5.9) | |
418 | NO_UNSETENV = YesPlease | |
419 | NO_SETENV = YesPlease | |
420 | NO_C99_FORMAT = YesPlease | |
421 | NO_STRTOUMAX = YesPlease | |
422 | endif | |
423 | INSTALL = ginstall | |
424 | TAR = gtar | |
425 | BASIC_CFLAGS += -D__EXTENSIONS__ | |
426 | endif | |
427 | ifeq ($(uname_O),Cygwin) | |
428 | NO_D_TYPE_IN_DIRENT = YesPlease | |
429 | NO_D_INO_IN_DIRENT = YesPlease | |
430 | NO_STRCASESTR = YesPlease | |
431 | NO_SYMLINK_HEAD = YesPlease | |
432 | NEEDS_LIBICONV = YesPlease | |
433 | NO_FAST_WORKING_DIRECTORY = UnfortunatelyYes | |
434 | NO_TRUSTABLE_FILEMODE = UnfortunatelyYes | |
435 | # There are conflicting reports about this. | |
436 | # On some boxes NO_MMAP is needed, and not so elsewhere. | |
437 | # Try commenting this out if you suspect MMAP is more efficient | |
438 | NO_MMAP = YesPlease | |
439 | NO_IPV6 = YesPlease | |
440 | X = .exe | |
441 | endif | |
442 | ifeq ($(uname_S),FreeBSD) | |
443 | NEEDS_LIBICONV = YesPlease | |
444 | BASIC_CFLAGS += -I/usr/local/include | |
445 | BASIC_LDFLAGS += -L/usr/local/lib | |
446 | endif | |
447 | ifeq ($(uname_S),OpenBSD) | |
448 | NO_STRCASESTR = YesPlease | |
449 | NEEDS_LIBICONV = YesPlease | |
450 | BASIC_CFLAGS += -I/usr/local/include | |
451 | BASIC_LDFLAGS += -L/usr/local/lib | |
452 | endif | |
453 | ifeq ($(uname_S),NetBSD) | |
454 | ifeq ($(shell expr "$(uname_R)" : '[01]\.'),2) | |
455 | NEEDS_LIBICONV = YesPlease | |
456 | endif | |
457 | BASIC_CFLAGS += -I/usr/pkg/include | |
458 | BASIC_LDFLAGS += -L/usr/pkg/lib | |
459 | ALL_LDFLAGS += -Wl,-rpath,/usr/pkg/lib | |
460 | endif | |
461 | ifeq ($(uname_S),AIX) | |
462 | NO_STRCASESTR=YesPlease | |
463 | NO_STRLCPY = YesPlease | |
464 | NEEDS_LIBICONV=YesPlease | |
465 | endif | |
466 | ifeq ($(uname_S),GNU) | |
467 | # GNU/Hurd | |
468 | NO_STRLCPY=YesPlease | |
469 | endif | |
470 | ifeq ($(uname_S),IRIX64) | |
471 | NO_IPV6=YesPlease | |
472 | NO_SETENV=YesPlease | |
473 | NO_STRCASESTR=YesPlease | |
474 | NO_STRLCPY = YesPlease | |
475 | NO_SOCKADDR_STORAGE=YesPlease | |
476 | SHELL_PATH=/usr/gnu/bin/bash | |
477 | BASIC_CFLAGS += -DPATH_MAX=1024 | |
478 | # for now, build 32-bit version | |
479 | BASIC_LDFLAGS += -L/usr/lib32 | |
480 | endif | |
481 | ifneq (,$(findstring arm,$(uname_M))) | |
482 | ARM_SHA1 = YesPlease | |
483 | endif | |
484 | ||
485 | -include config.mak.autogen | |
486 | -include config.mak | |
487 | ||
488 | ifeq ($(uname_S),Darwin) | |
489 | ifndef NO_FINK | |
490 | ifeq ($(shell test -d /sw/lib && echo y),y) | |
491 | BASIC_CFLAGS += -I/sw/include | |
492 | BASIC_LDFLAGS += -L/sw/lib | |
493 | endif | |
494 | endif | |
495 | ifndef NO_DARWIN_PORTS | |
496 | ifeq ($(shell test -d /opt/local/lib && echo y),y) | |
497 | BASIC_CFLAGS += -I/opt/local/include | |
498 | BASIC_LDFLAGS += -L/opt/local/lib | |
499 | endif | |
500 | endif | |
501 | endif | |
502 | ||
503 | ifdef NO_R_TO_GCC_LINKER | |
504 | # Some gcc does not accept and pass -R to the linker to specify | |
505 | # the runtime dynamic library path. | |
506 | CC_LD_DYNPATH = -Wl,-rpath= | |
507 | else | |
508 | CC_LD_DYNPATH = -R | |
509 | endif | |
510 | ||
511 | ifndef NO_CURL | |
512 | ifdef CURLDIR | |
513 | # Try "-Wl,-rpath=$(CURLDIR)/$(lib)" in such a case. | |
514 | BASIC_CFLAGS += -I$(CURLDIR)/include | |
515 | CURL_LIBCURL = -L$(CURLDIR)/$(lib) $(CC_LD_DYNPATH)$(CURLDIR)/$(lib) -lcurl | |
516 | else | |
517 | CURL_LIBCURL = -lcurl | |
518 | endif | |
519 | PROGRAMS += git-http-fetch$X | |
520 | curl_check := $(shell (echo 070908; curl-config --vernum) | sort -r | sed -ne 2p) | |
521 | ifeq "$(curl_check)" "070908" | |
522 | ifndef NO_EXPAT | |
523 | PROGRAMS += git-http-push$X | |
524 | endif | |
525 | endif | |
526 | ifndef NO_EXPAT | |
527 | EXPAT_LIBEXPAT = -lexpat | |
528 | endif | |
529 | endif | |
530 | ||
531 | ifdef ZLIB_PATH | |
532 | BASIC_CFLAGS += -I$(ZLIB_PATH)/include | |
533 | EXTLIBS += -L$(ZLIB_PATH)/$(lib) $(CC_LD_DYNPATH)$(ZLIB_PATH)/$(lib) | |
534 | endif | |
535 | EXTLIBS += -lz | |
536 | ||
537 | ifndef NO_OPENSSL | |
538 | OPENSSL_LIBSSL = -lssl | |
539 | ifdef OPENSSLDIR | |
540 | BASIC_CFLAGS += -I$(OPENSSLDIR)/include | |
541 | OPENSSL_LINK = -L$(OPENSSLDIR)/$(lib) $(CC_LD_DYNPATH)$(OPENSSLDIR)/$(lib) | |
542 | else | |
543 | OPENSSL_LINK = | |
544 | endif | |
545 | else | |
546 | BASIC_CFLAGS += -DNO_OPENSSL | |
547 | MOZILLA_SHA1 = 1 | |
548 | OPENSSL_LIBSSL = | |
549 | endif | |
550 | ifdef NEEDS_SSL_WITH_CRYPTO | |
551 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl | |
552 | else | |
553 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto | |
554 | endif | |
555 | ifdef NEEDS_LIBICONV | |
556 | ifdef ICONVDIR | |
557 | BASIC_CFLAGS += -I$(ICONVDIR)/include | |
558 | ICONV_LINK = -L$(ICONVDIR)/$(lib) $(CC_LD_DYNPATH)$(ICONVDIR)/$(lib) | |
559 | else | |
560 | ICONV_LINK = | |
561 | endif | |
562 | EXTLIBS += $(ICONV_LINK) -liconv | |
563 | endif | |
564 | ifdef NEEDS_SOCKET | |
565 | EXTLIBS += -lsocket | |
566 | endif | |
567 | ifdef NEEDS_NSL | |
568 | EXTLIBS += -lnsl | |
569 | endif | |
570 | ifdef NO_D_TYPE_IN_DIRENT | |
571 | BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT | |
572 | endif | |
573 | ifdef NO_D_INO_IN_DIRENT | |
574 | BASIC_CFLAGS += -DNO_D_INO_IN_DIRENT | |
575 | endif | |
576 | ifdef NO_C99_FORMAT | |
577 | BASIC_CFLAGS += -DNO_C99_FORMAT | |
578 | endif | |
579 | ifdef NO_SYMLINK_HEAD | |
580 | BASIC_CFLAGS += -DNO_SYMLINK_HEAD | |
581 | endif | |
582 | ifdef NO_STRCASESTR | |
583 | COMPAT_CFLAGS += -DNO_STRCASESTR | |
584 | COMPAT_OBJS += compat/strcasestr.o | |
585 | endif | |
586 | ifdef NO_STRLCPY | |
587 | COMPAT_CFLAGS += -DNO_STRLCPY | |
588 | COMPAT_OBJS += compat/strlcpy.o | |
589 | endif | |
590 | ifdef NO_STRTOUMAX | |
591 | COMPAT_CFLAGS += -DNO_STRTOUMAX | |
592 | COMPAT_OBJS += compat/strtoumax.o | |
593 | endif | |
594 | ifdef NO_STRTOULL | |
595 | COMPAT_CFLAGS += -DNO_STRTOULL | |
596 | endif | |
597 | ifdef NO_SETENV | |
598 | COMPAT_CFLAGS += -DNO_SETENV | |
599 | COMPAT_OBJS += compat/setenv.o | |
600 | endif | |
601 | ifdef NO_UNSETENV | |
602 | COMPAT_CFLAGS += -DNO_UNSETENV | |
603 | COMPAT_OBJS += compat/unsetenv.o | |
604 | endif | |
605 | ifdef NO_MMAP | |
606 | COMPAT_CFLAGS += -DNO_MMAP | |
607 | COMPAT_OBJS += compat/mmap.o | |
608 | endif | |
609 | ifdef NO_PREAD | |
610 | COMPAT_CFLAGS += -DNO_PREAD | |
611 | COMPAT_OBJS += compat/pread.o | |
612 | endif | |
613 | ifdef NO_FAST_WORKING_DIRECTORY | |
614 | BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY | |
615 | endif | |
616 | ifdef NO_TRUSTABLE_FILEMODE | |
617 | BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE | |
618 | endif | |
619 | ifdef NO_IPV6 | |
620 | BASIC_CFLAGS += -DNO_IPV6 | |
621 | endif | |
622 | ifdef NO_SOCKADDR_STORAGE | |
623 | ifdef NO_IPV6 | |
624 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in | |
625 | else | |
626 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6 | |
627 | endif | |
628 | endif | |
629 | ifdef NO_INET_NTOP | |
630 | LIB_OBJS += compat/inet_ntop.o | |
631 | endif | |
632 | ifdef NO_INET_PTON | |
633 | LIB_OBJS += compat/inet_pton.o | |
634 | endif | |
635 | ||
636 | ifdef NO_ICONV | |
637 | BASIC_CFLAGS += -DNO_ICONV | |
638 | endif | |
639 | ||
640 | ifdef OLD_ICONV | |
641 | BASIC_CFLAGS += -DOLD_ICONV | |
642 | endif | |
643 | ||
644 | ifdef NO_DEFLATE_BOUND | |
645 | BASIC_CFLAGS += -DNO_DEFLATE_BOUND | |
646 | endif | |
647 | ||
648 | ifdef PPC_SHA1 | |
649 | SHA1_HEADER = "ppc/sha1.h" | |
650 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o | |
651 | else | |
652 | ifdef ARM_SHA1 | |
653 | SHA1_HEADER = "arm/sha1.h" | |
654 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o | |
655 | else | |
656 | ifdef MOZILLA_SHA1 | |
657 | SHA1_HEADER = "mozilla-sha1/sha1.h" | |
658 | LIB_OBJS += mozilla-sha1/sha1.o | |
659 | else | |
660 | SHA1_HEADER = <openssl/sha.h> | |
661 | EXTLIBS += $(LIB_4_CRYPTO) | |
662 | endif | |
663 | endif | |
664 | endif | |
665 | ifdef NO_PERL_MAKEMAKER | |
666 | export NO_PERL_MAKEMAKER | |
667 | endif | |
668 | ifdef NO_HSTRERROR | |
669 | COMPAT_CFLAGS += -DNO_HSTRERROR | |
670 | COMPAT_OBJS += compat/hstrerror.o | |
671 | endif | |
672 | ||
673 | ifeq ($(TCLTK_PATH),) | |
674 | NO_TCLTK=NoThanks | |
675 | endif | |
676 | ||
677 | QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir | |
678 | QUIET_SUBDIR1 = | |
679 | ||
680 | ifneq ($(findstring $(MAKEFLAGS),w),w) | |
681 | PRINT_DIR = --no-print-directory | |
682 | else # "make -w" | |
683 | NO_SUBDIR = : | |
684 | endif | |
685 | ||
686 | ifneq ($(findstring $(MAKEFLAGS),s),s) | |
687 | ifndef V | |
688 | QUIET_CC = @echo ' ' CC $@; | |
689 | QUIET_AR = @echo ' ' AR $@; | |
690 | QUIET_LINK = @echo ' ' LINK $@; | |
691 | QUIET_BUILT_IN = @echo ' ' BUILTIN $@; | |
692 | QUIET_GEN = @echo ' ' GEN $@; | |
693 | QUIET_SUBDIR0 = +@subdir= | |
694 | QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ | |
695 | $(MAKE) $(PRINT_DIR) -C $$subdir | |
696 | export V | |
697 | export QUIET_GEN | |
698 | export QUIET_BUILT_IN | |
699 | endif | |
700 | endif | |
701 | ||
702 | ifdef ASCIIDOC8 | |
703 | export ASCIIDOC8 | |
704 | endif | |
705 | ||
706 | # Shell quote (do not use $(call) to accommodate ancient setups); | |
707 | ||
708 | SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER)) | |
709 | ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG)) | |
710 | ||
711 | DESTDIR_SQ = $(subst ','\'',$(DESTDIR)) | |
712 | bindir_SQ = $(subst ','\'',$(bindir)) | |
713 | gitexecdir_SQ = $(subst ','\'',$(gitexecdir)) | |
714 | template_dir_SQ = $(subst ','\'',$(template_dir)) | |
715 | prefix_SQ = $(subst ','\'',$(prefix)) | |
716 | ||
717 | SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) | |
718 | PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) | |
719 | TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH)) | |
720 | ||
721 | LIBS = $(GITLIBS) $(EXTLIBS) | |
722 | ||
723 | BASIC_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' \ | |
724 | -DETC_GITCONFIG='"$(ETC_GITCONFIG_SQ)"' $(COMPAT_CFLAGS) | |
725 | LIB_OBJS += $(COMPAT_OBJS) | |
726 | ||
727 | ALL_CFLAGS += $(BASIC_CFLAGS) | |
728 | ALL_LDFLAGS += $(BASIC_LDFLAGS) | |
729 | ||
730 | export TAR INSTALL DESTDIR SHELL_PATH | |
731 | ||
732 | ||
733 | ### Build rules | |
734 | ||
735 | all:: $(ALL_PROGRAMS) $(BUILT_INS) $(OTHER_PROGRAMS) | |
736 | ifneq (,$X) | |
737 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), $(RM) '$p';) | |
738 | endif | |
739 | ||
740 | all:: | |
741 | ifndef NO_TCLTK | |
742 | $(QUIET_SUBDIR0)git-gui $(QUIET_SUBDIR1) all | |
743 | endif | |
744 | $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' all | |
745 | $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1) | |
746 | ||
747 | strip: $(PROGRAMS) git$X | |
748 | $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X | |
749 | ||
750 | gitk-wish: gitk GIT-GUI-VARS | |
751 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
752 | sed -e '1,3s|^exec .* "$$0"|exec $(subst |,'\|',$(TCLTK_PATH_SQ)) "$$0"|' <gitk >$@+ && \ | |
753 | chmod +x $@+ && \ | |
754 | mv -f $@+ $@ | |
755 | ||
756 | git.o: git.c common-cmds.h GIT-CFLAGS | |
757 | $(QUIET_CC)$(CC) -DGIT_VERSION='"$(GIT_VERSION)"' \ | |
758 | $(ALL_CFLAGS) -c $(filter %.c,$^) | |
759 | ||
760 | git$X: git.o $(BUILTIN_OBJS) $(GITLIBS) | |
761 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ git.o \ | |
762 | $(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS) | |
763 | ||
764 | help.o: common-cmds.h | |
765 | ||
766 | git-merge-subtree$X: git-merge-recursive$X | |
767 | $(QUIET_BUILT_IN)$(RM) $@ && ln git-merge-recursive$X $@ | |
768 | ||
769 | $(BUILT_INS): git$X | |
770 | $(QUIET_BUILT_IN)$(RM) $@ && ln git$X $@ | |
771 | ||
772 | common-cmds.h: ./generate-cmdlist.sh | |
773 | ||
774 | common-cmds.h: $(wildcard Documentation/git-*.txt) | |
775 | $(QUIET_GEN)./generate-cmdlist.sh > $@+ && mv $@+ $@ | |
776 | ||
777 | $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh | |
778 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
779 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ | |
780 | -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \ | |
781 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
782 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ | |
783 | $@.sh >$@+ && \ | |
784 | chmod +x $@+ && \ | |
785 | mv $@+ $@ | |
786 | ||
787 | $(patsubst %.perl,%,$(SCRIPT_PERL)): perl/perl.mak | |
788 | ||
789 | perl/perl.mak: GIT-CFLAGS perl/Makefile perl/Makefile.PL | |
790 | $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' $(@F) | |
791 | ||
792 | $(patsubst %.perl,%,$(SCRIPT_PERL)): % : %.perl | |
793 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
794 | INSTLIBDIR=`MAKEFLAGS= $(MAKE) -C perl -s --no-print-directory instlibdir` && \ | |
795 | sed -e '1{' \ | |
796 | -e ' s|#!.*perl|#!$(PERL_PATH_SQ)|' \ | |
797 | -e ' h' \ | |
798 | -e ' s=.*=use lib (split(/:/, $$ENV{GITPERLLIB} || "@@INSTLIBDIR@@"));=' \ | |
799 | -e ' H' \ | |
800 | -e ' x' \ | |
801 | -e '}' \ | |
802 | -e 's|@@INSTLIBDIR@@|'"$$INSTLIBDIR"'|g' \ | |
803 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
804 | $@.perl >$@+ && \ | |
805 | chmod +x $@+ && \ | |
806 | mv $@+ $@ | |
807 | ||
808 | git-status: git-commit | |
809 | $(QUIET_GEN)cp $< $@+ && mv $@+ $@ | |
810 | ||
811 | gitweb/gitweb.cgi: gitweb/gitweb.perl | |
812 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
813 | sed -e '1s|#!.*perl|#!$(PERL_PATH_SQ)|' \ | |
814 | -e 's|++GIT_VERSION++|$(GIT_VERSION)|g' \ | |
815 | -e 's|++GIT_BINDIR++|$(bindir)|g' \ | |
816 | -e 's|++GITWEB_CONFIG++|$(GITWEB_CONFIG)|g' \ | |
817 | -e 's|++GITWEB_HOME_LINK_STR++|$(GITWEB_HOME_LINK_STR)|g' \ | |
818 | -e 's|++GITWEB_SITENAME++|$(GITWEB_SITENAME)|g' \ | |
819 | -e 's|++GITWEB_PROJECTROOT++|$(GITWEB_PROJECTROOT)|g' \ | |
820 | -e 's|++GITWEB_EXPORT_OK++|$(GITWEB_EXPORT_OK)|g' \ | |
821 | -e 's|++GITWEB_STRICT_EXPORT++|$(GITWEB_STRICT_EXPORT)|g' \ | |
822 | -e 's|++GITWEB_BASE_URL++|$(GITWEB_BASE_URL)|g' \ | |
823 | -e 's|++GITWEB_LIST++|$(GITWEB_LIST)|g' \ | |
824 | -e 's|++GITWEB_HOMETEXT++|$(GITWEB_HOMETEXT)|g' \ | |
825 | -e 's|++GITWEB_CSS++|$(GITWEB_CSS)|g' \ | |
826 | -e 's|++GITWEB_LOGO++|$(GITWEB_LOGO)|g' \ | |
827 | -e 's|++GITWEB_FAVICON++|$(GITWEB_FAVICON)|g' \ | |
828 | -e 's|++GITWEB_SITE_HEADER++|$(GITWEB_SITE_HEADER)|g' \ | |
829 | -e 's|++GITWEB_SITE_FOOTER++|$(GITWEB_SITE_FOOTER)|g' \ | |
830 | $< >$@+ && \ | |
831 | chmod +x $@+ && \ | |
832 | mv $@+ $@ | |
833 | ||
834 | git-instaweb: git-instaweb.sh gitweb/gitweb.cgi gitweb/gitweb.css | |
835 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
836 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ | |
837 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
838 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ | |
839 | -e '/@@GITWEB_CGI@@/r gitweb/gitweb.cgi' \ | |
840 | -e '/@@GITWEB_CGI@@/d' \ | |
841 | -e '/@@GITWEB_CSS@@/r gitweb/gitweb.css' \ | |
842 | -e '/@@GITWEB_CSS@@/d' \ | |
843 | $@.sh > $@+ && \ | |
844 | chmod +x $@+ && \ | |
845 | mv $@+ $@ | |
846 | ||
847 | configure: configure.ac | |
848 | $(QUIET_GEN)$(RM) $@ $<+ && \ | |
849 | sed -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
850 | $< > $<+ && \ | |
851 | autoconf -o $@ $<+ && \ | |
852 | $(RM) $<+ | |
853 | ||
854 | # These can record GIT_VERSION | |
855 | git.o git.spec \ | |
856 | $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
857 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
858 | : GIT-VERSION-FILE | |
859 | ||
860 | %.o: %.c GIT-CFLAGS | |
861 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
862 | %.s: %.c GIT-CFLAGS | |
863 | $(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $< | |
864 | %.o: %.S | |
865 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
866 | ||
867 | exec_cmd.o: exec_cmd.c GIT-CFLAGS | |
868 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' $< | |
869 | builtin-init-db.o: builtin-init-db.c GIT-CFLAGS | |
870 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"' $< | |
871 | ||
872 | http.o: http.c GIT-CFLAGS | |
873 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DGIT_USER_AGENT='"git/$(GIT_VERSION)"' $< | |
874 | ||
875 | ifdef NO_EXPAT | |
876 | http-fetch.o: http-fetch.c http.h GIT-CFLAGS | |
877 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DNO_EXPAT $< | |
878 | endif | |
879 | ||
880 | git-%$X: %.o $(GITLIBS) | |
881 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) | |
882 | ||
883 | ssh-pull.o: ssh-fetch.c | |
884 | ssh-push.o: ssh-upload.c | |
885 | git-local-fetch$X: fetch.o | |
886 | git-ssh-fetch$X: rsh.o fetch.o | |
887 | git-ssh-upload$X: rsh.o | |
888 | git-ssh-pull$X: rsh.o fetch.o | |
889 | git-ssh-push$X: rsh.o | |
890 | ||
891 | git-imap-send$X: imap-send.o $(LIB_FILE) | |
892 | ||
893 | http.o http-fetch.o http-push.o: http.h | |
894 | git-http-fetch$X: fetch.o http.o http-fetch.o $(GITLIBS) | |
895 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ | |
896 | $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) | |
897 | ||
898 | git-http-push$X: revision.o http.o http-push.o $(GITLIBS) | |
899 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ | |
900 | $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) | |
901 | ||
902 | $(LIB_OBJS) $(BUILTIN_OBJS) fetch.o: $(LIB_H) | |
903 | $(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) $(wildcard */*.h) | |
904 | $(DIFF_OBJS): diffcore.h | |
905 | builtin-revert.o builtin-runstatus.o wt-status.o: wt-status.h | |
906 | ||
907 | $(LIB_FILE): $(LIB_OBJS) | |
908 | $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS) | |
909 | ||
910 | XDIFF_OBJS=xdiff/xdiffi.o xdiff/xprepare.o xdiff/xutils.o xdiff/xemit.o \ | |
911 | xdiff/xmerge.o | |
912 | $(XDIFF_OBJS): xdiff/xinclude.h xdiff/xmacros.h xdiff/xdiff.h xdiff/xtypes.h \ | |
913 | xdiff/xutils.h xdiff/xprepare.h xdiff/xdiffi.h xdiff/xemit.h | |
914 | ||
915 | $(XDIFF_LIB): $(XDIFF_OBJS) | |
916 | $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(XDIFF_OBJS) | |
917 | ||
918 | ||
919 | doc: | |
920 | $(MAKE) -C Documentation all | |
921 | ||
922 | info: | |
923 | $(MAKE) -C Documentation info | |
924 | ||
925 | TAGS: | |
926 | $(RM) TAGS | |
927 | $(FIND) . -name '*.[hcS]' -print | xargs etags -a | |
928 | ||
929 | tags: | |
930 | $(RM) tags | |
931 | $(FIND) . -name '*.[hcS]' -print | xargs ctags -a | |
932 | ||
933 | ### Detect prefix changes | |
934 | TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):\ | |
935 | $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ) | |
936 | ||
937 | GIT-CFLAGS: .FORCE-GIT-CFLAGS | |
938 | @FLAGS='$(TRACK_CFLAGS)'; \ | |
939 | if test x"$$FLAGS" != x"`cat GIT-CFLAGS 2>/dev/null`" ; then \ | |
940 | echo 1>&2 " * new build flags or prefix"; \ | |
941 | echo "$$FLAGS" >GIT-CFLAGS; \ | |
942 | fi | |
943 | ||
944 | ### Detect Tck/Tk interpreter path changes | |
945 | ifndef NO_TCLTK | |
946 | TRACK_VARS = $(subst ','\'',-DTCLTK_PATH='$(TCLTK_PATH_SQ)') | |
947 | ||
948 | GIT-GUI-VARS: .FORCE-GIT-GUI-VARS | |
949 | @VARS='$(TRACK_VARS)'; \ | |
950 | if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \ | |
951 | echo 1>&2 " * new Tcl/Tk interpreter location"; \ | |
952 | echo "$$VARS" >$@; \ | |
953 | fi | |
954 | ||
955 | .PHONY: .FORCE-GIT-GUI-VARS | |
956 | endif | |
957 | ||
958 | ### Testing rules | |
959 | ||
960 | TEST_PROGRAMS = test-chmtime$X test-genrandom$X test-date$X test-delta$X test-sha1$X test-match-trees$X test-absolute-path$X | |
961 | ||
962 | all:: $(TEST_PROGRAMS) | |
963 | ||
964 | # GNU make supports exporting all variables by "export" without parameters. | |
965 | # However, the environment gets quite big, and some programs have problems | |
966 | # with that. | |
967 | ||
968 | export NO_SVN_TESTS | |
969 | ||
970 | test: all | |
971 | $(MAKE) -C t/ all | |
972 | ||
973 | test-date$X: date.o ctype.o | |
974 | ||
975 | test-delta$X: diff-delta.o patch-delta.o | |
976 | ||
977 | .PRECIOUS: $(patsubst test-%$X,test-%.o,$(TEST_PROGRAMS)) | |
978 | ||
979 | test-%$X: test-%.o $(GITLIBS) | |
980 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) | |
981 | ||
982 | check-sha1:: test-sha1$X | |
983 | ./test-sha1.sh | |
984 | ||
985 | check: common-cmds.h | |
986 | for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; done | |
987 | ||
988 | remove-dashes: | |
989 | ./fixup-builtins $(BUILT_INS) | |
990 | ||
991 | ### Installation rules | |
992 | ||
993 | install: all | |
994 | $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(bindir_SQ)' | |
995 | $(INSTALL) -d -m755 '$(DESTDIR_SQ)$(gitexecdir_SQ)' | |
996 | $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexecdir_SQ)' | |
997 | $(INSTALL) git$X '$(DESTDIR_SQ)$(bindir_SQ)' | |
998 | $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install | |
999 | $(MAKE) -C perl prefix='$(prefix_SQ)' install | |
1000 | ifndef NO_TCLTK | |
1001 | $(INSTALL) gitk-wish '$(DESTDIR_SQ)$(bindir_SQ)'/gitk | |
1002 | $(MAKE) -C git-gui install | |
1003 | endif | |
1004 | if test 'z$(bindir_SQ)' != 'z$(gitexecdir_SQ)'; \ | |
1005 | then \ | |
1006 | ln -f '$(DESTDIR_SQ)$(bindir_SQ)/git$X' \ | |
1007 | '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X' || \ | |
1008 | cp '$(DESTDIR_SQ)$(bindir_SQ)/git$X' \ | |
1009 | '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X'; \ | |
1010 | fi | |
1011 | $(foreach p,$(BUILT_INS), $(RM) '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p' && ln '$(DESTDIR_SQ)$(gitexecdir_SQ)/git$X' '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p' ;) | |
1012 | ifneq (,$X) | |
1013 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), $(RM) '$(DESTDIR_SQ)$(gitexecdir_SQ)/$p';) | |
1014 | endif | |
1015 | ||
1016 | install-doc: | |
1017 | $(MAKE) -C Documentation install | |
1018 | ||
1019 | install-info: | |
1020 | $(MAKE) -C Documentation install-info | |
1021 | ||
1022 | quick-install-doc: | |
1023 | $(MAKE) -C Documentation quick-install | |
1024 | ||
1025 | ||
1026 | ||
1027 | ### Maintainer's dist rules | |
1028 | ||
1029 | git.spec: git.spec.in | |
1030 | sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@+ | |
1031 | mv $@+ $@ | |
1032 | ||
1033 | GIT_TARNAME=git-$(GIT_VERSION) | |
1034 | dist: git.spec git-archive configure | |
1035 | ./git-archive --format=tar \ | |
1036 | --prefix=$(GIT_TARNAME)/ HEAD^{tree} > $(GIT_TARNAME).tar | |
1037 | @mkdir -p $(GIT_TARNAME) | |
1038 | @cp git.spec configure $(GIT_TARNAME) | |
1039 | @echo $(GIT_VERSION) > $(GIT_TARNAME)/version | |
1040 | @$(MAKE) -C git-gui TARDIR=../$(GIT_TARNAME)/git-gui dist-version | |
1041 | $(TAR) rf $(GIT_TARNAME).tar \ | |
1042 | $(GIT_TARNAME)/git.spec \ | |
1043 | $(GIT_TARNAME)/configure \ | |
1044 | $(GIT_TARNAME)/version \ | |
1045 | $(GIT_TARNAME)/git-gui/version | |
1046 | @$(RM) -r $(GIT_TARNAME) | |
1047 | gzip -f -9 $(GIT_TARNAME).tar | |
1048 | ||
1049 | rpm: dist | |
1050 | $(RPMBUILD) -ta $(GIT_TARNAME).tar.gz | |
1051 | ||
1052 | htmldocs = git-htmldocs-$(GIT_VERSION) | |
1053 | manpages = git-manpages-$(GIT_VERSION) | |
1054 | dist-doc: | |
1055 | $(RM) -r .doc-tmp-dir | |
1056 | mkdir .doc-tmp-dir | |
1057 | $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc | |
1058 | cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar . | |
1059 | gzip -n -9 -f $(htmldocs).tar | |
1060 | : | |
1061 | $(RM) -r .doc-tmp-dir | |
1062 | mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7 | |
1063 | $(MAKE) -C Documentation DESTDIR=./ \ | |
1064 | man1dir=../.doc-tmp-dir/man1 \ | |
1065 | man5dir=../.doc-tmp-dir/man5 \ | |
1066 | man7dir=../.doc-tmp-dir/man7 \ | |
1067 | install | |
1068 | cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar . | |
1069 | gzip -n -9 -f $(manpages).tar | |
1070 | $(RM) -r .doc-tmp-dir | |
1071 | ||
1072 | ### Cleaning rules | |
1073 | ||
1074 | distclean: clean | |
1075 | $(RM) configure | |
1076 | ||
1077 | clean: | |
1078 | $(RM) *.o mozilla-sha1/*.o arm/*.o ppc/*.o compat/*.o xdiff/*.o \ | |
1079 | $(LIB_FILE) $(XDIFF_LIB) | |
1080 | $(RM) $(ALL_PROGRAMS) $(BUILT_INS) git$X | |
1081 | $(RM) $(TEST_PROGRAMS) | |
1082 | $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h TAGS tags | |
1083 | $(RM) -r autom4te.cache | |
1084 | $(RM) config.log config.mak.autogen config.mak.append config.status config.cache | |
1085 | $(RM) -r $(GIT_TARNAME) .doc-tmp-dir | |
1086 | $(RM) $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz | |
1087 | $(RM) $(htmldocs).tar.gz $(manpages).tar.gz | |
1088 | $(RM) gitweb/gitweb.cgi | |
1089 | $(MAKE) -C Documentation/ clean | |
1090 | $(MAKE) -C perl clean | |
1091 | $(MAKE) -C templates/ clean | |
1092 | $(MAKE) -C t/ clean | |
1093 | ifndef NO_TCLTK | |
1094 | $(RM) gitk-wish | |
1095 | $(MAKE) -C git-gui clean | |
1096 | endif | |
1097 | $(RM) GIT-VERSION-FILE GIT-CFLAGS GIT-GUI-VARS | |
1098 | ||
1099 | .PHONY: all install clean strip | |
1100 | .PHONY: .FORCE-GIT-VERSION-FILE TAGS tags .FORCE-GIT-CFLAGS | |
1101 | ||
1102 | ### Check documentation | |
1103 | # | |
1104 | check-docs:: | |
1105 | @for v in $(ALL_PROGRAMS) $(BUILT_INS) git$X gitk; \ | |
1106 | do \ | |
1107 | case "$$v" in \ | |
1108 | git-merge-octopus | git-merge-ours | git-merge-recursive | \ | |
1109 | git-merge-resolve | git-merge-stupid | \ | |
1110 | git-add--interactive | git-fsck-objects | git-init-db | \ | |
1111 | git-repo-config | git-fetch--tool | \ | |
1112 | git-ssh-pull | git-ssh-push ) continue ;; \ | |
1113 | esac ; \ | |
1114 | test -f "Documentation/$$v.txt" || \ | |
1115 | echo "no doc: $$v"; \ | |
1116 | sed -e '1,/^__DATA__/d' Documentation/cmd-list.perl | \ | |
1117 | grep -q "^$$v[ ]" || \ | |
1118 | case "$$v" in \ | |
1119 | git) ;; \ | |
1120 | *) echo "no link: $$v";; \ | |
1121 | esac ; \ | |
1122 | done | sort | |
1123 | ||
1124 | ### Make sure built-ins do not have dups and listed in git.c | |
1125 | # | |
1126 | check-builtins:: | |
1127 | ./check-builtins.sh |