]>
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 SNPRINTF_RETURNS_BOGUS if your are on a system which snprintf() | |
7 | # or vsnprintf() return -1 instead of number of characters which would | |
8 | # have been written to the final string if enough space had been available. | |
9 | # | |
10 | # Define FREAD_READS_DIRECTORIES if your are on a system which succeeds | |
11 | # when attempting to read from an fopen'ed directory. | |
12 | # | |
13 | # Define NO_OPENSSL environment variable if you do not have OpenSSL. | |
14 | # This also implies MOZILLA_SHA1. | |
15 | # | |
16 | # Define NO_CURL if you do not have libcurl installed. git-http-pull and | |
17 | # git-http-push are not built, and you cannot use http:// and https:// | |
18 | # transports. | |
19 | # | |
20 | # Define CURLDIR=/foo/bar if your curl header and library files are in | |
21 | # /foo/bar/include and /foo/bar/lib directories. | |
22 | # | |
23 | # Define NO_EXPAT if you do not have expat installed. git-http-push is | |
24 | # not built, and you cannot push using http:// and https:// transports. | |
25 | # | |
26 | # Define NO_D_INO_IN_DIRENT if you don't have d_ino in your struct dirent. | |
27 | # | |
28 | # Define NO_D_TYPE_IN_DIRENT if your platform defines DT_UNKNOWN but lacks | |
29 | # d_type in struct dirent (latest Cygwin -- will be fixed soonish). | |
30 | # | |
31 | # Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.) | |
32 | # do not support the 'size specifiers' introduced by C99, namely ll, hh, | |
33 | # j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t). | |
34 | # some C compilers supported these specifiers prior to C99 as an extension. | |
35 | # | |
36 | # Define NO_STRCASESTR if you don't have strcasestr. | |
37 | # | |
38 | # Define NO_MEMMEM if you don't have memmem. | |
39 | # | |
40 | # Define NO_STRLCPY if you don't have strlcpy. | |
41 | # | |
42 | # Define NO_STRTOUMAX if you don't have strtoumax in the C library. | |
43 | # If your compiler also does not support long long or does not have | |
44 | # strtoull, define NO_STRTOULL. | |
45 | # | |
46 | # Define NO_SETENV if you don't have setenv in the C library. | |
47 | # | |
48 | # Define NO_UNSETENV if you don't have unsetenv in the C library. | |
49 | # | |
50 | # Define NO_MKDTEMP if you don't have mkdtemp in the C library. | |
51 | # | |
52 | # Define NO_SYS_SELECT_H if you don't have sys/select.h. | |
53 | # | |
54 | # Define NO_SYMLINK_HEAD if you never want .git/HEAD to be a symbolic link. | |
55 | # Enable it on Windows. By default, symrefs are still used. | |
56 | # | |
57 | # Define NO_SVN_TESTS if you want to skip time-consuming SVN interoperability | |
58 | # tests. These tests take up a significant amount of the total test time | |
59 | # but are not needed unless you plan to talk to SVN repos. | |
60 | # | |
61 | # Define NO_FINK if you are building on Darwin/Mac OS X, have Fink | |
62 | # installed in /sw, but don't want GIT to link against any libraries | |
63 | # installed there. If defined you may specify your own (or Fink's) | |
64 | # include directories and library directories by defining CFLAGS | |
65 | # and LDFLAGS appropriately. | |
66 | # | |
67 | # Define NO_DARWIN_PORTS if you are building on Darwin/Mac OS X, | |
68 | # have DarwinPorts installed in /opt/local, but don't want GIT to | |
69 | # link against any libraries installed there. If defined you may | |
70 | # specify your own (or DarwinPort's) include directories and | |
71 | # library directories by defining CFLAGS and LDFLAGS appropriately. | |
72 | # | |
73 | # Define PPC_SHA1 environment variable when running make to make use of | |
74 | # a bundled SHA1 routine optimized for PowerPC. | |
75 | # | |
76 | # Define ARM_SHA1 environment variable when running make to make use of | |
77 | # a bundled SHA1 routine optimized for ARM. | |
78 | # | |
79 | # Define MOZILLA_SHA1 environment variable when running make to make use of | |
80 | # a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast | |
81 | # on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default | |
82 | # choice) has very fast version optimized for i586. | |
83 | # | |
84 | # Define NEEDS_SSL_WITH_CRYPTO if you need -lcrypto with -lssl (Darwin). | |
85 | # | |
86 | # Define NEEDS_LIBICONV if linking with libc is not enough (Darwin). | |
87 | # | |
88 | # Define NEEDS_SOCKET if linking with libc is not enough (SunOS, | |
89 | # Patrick Mauritz). | |
90 | # | |
91 | # Define NO_MMAP if you want to avoid mmap. | |
92 | # | |
93 | # Define NO_PREAD if you have a problem with pread() system call (e.g. | |
94 | # cygwin.dll before v1.5.22). | |
95 | # | |
96 | # Define NO_FAST_WORKING_DIRECTORY if accessing objects in pack files is | |
97 | # generally faster on your platform than accessing the working directory. | |
98 | # | |
99 | # Define NO_TRUSTABLE_FILEMODE if your filesystem may claim to support | |
100 | # the executable mode bit, but doesn't really do so. | |
101 | # | |
102 | # Define NO_IPV6 if you lack IPv6 support and getaddrinfo(). | |
103 | # | |
104 | # Define NO_SOCKADDR_STORAGE if your platform does not have struct | |
105 | # sockaddr_storage. | |
106 | # | |
107 | # Define NO_ICONV if your libc does not properly support iconv. | |
108 | # | |
109 | # Define OLD_ICONV if your library has an old iconv(), where the second | |
110 | # (input buffer pointer) parameter is declared with type (const char **). | |
111 | # | |
112 | # Define NO_DEFLATE_BOUND if your zlib does not have deflateBound. | |
113 | # | |
114 | # Define NO_R_TO_GCC_LINKER if your gcc does not like "-R/path/lib" | |
115 | # that tells runtime paths to dynamic libraries; | |
116 | # "-Wl,-rpath=/path/lib" is used instead. | |
117 | # | |
118 | # Define USE_NSEC below if you want git to care about sub-second file mtimes | |
119 | # and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and | |
120 | # it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely | |
121 | # randomly break unless your underlying filesystem supports those sub-second | |
122 | # times (my ext3 doesn't). | |
123 | # | |
124 | # Define USE_STDEV below if you want git to care about the underlying device | |
125 | # change being considered an inode change from the update-index perspective. | |
126 | # | |
127 | # Define NO_ST_BLOCKS_IN_STRUCT_STAT if your platform does not have st_blocks | |
128 | # field that counts the on-disk footprint in 512-byte blocks. | |
129 | # | |
130 | # Define ASCIIDOC8 if you want to format documentation with AsciiDoc 8 | |
131 | # | |
132 | # Define DOCBOOK_XSL_172 if you want to format man pages with DocBook XSL v1.72. | |
133 | # | |
134 | # Define NO_PERL_MAKEMAKER if you cannot use Makefiles generated by perl's | |
135 | # MakeMaker (e.g. using ActiveState under Cygwin). | |
136 | # | |
137 | # Define NO_TCLTK if you do not want Tcl/Tk GUI. | |
138 | # | |
139 | # The TCL_PATH variable governs the location of the Tcl interpreter | |
140 | # used to optimize git-gui for your system. Only used if NO_TCLTK | |
141 | # is not set. Defaults to the bare 'tclsh'. | |
142 | # | |
143 | # The TCLTK_PATH variable governs the location of the Tcl/Tk interpreter. | |
144 | # If not set it defaults to the bare 'wish'. If it is set to the empty | |
145 | # string then NO_TCLTK will be forced (this is used by configure script). | |
146 | # | |
147 | # Define THREADED_DELTA_SEARCH if you have pthreads and wish to exploit | |
148 | # parallel delta searching when packing objects. | |
149 | # | |
150 | # Define INTERNAL_QSORT to use Git's implementation of qsort(), which | |
151 | # is a simplified version of the merge sort used in glibc. This is | |
152 | # recommended if Git triggers O(n^2) behavior in your platform's qsort(). | |
153 | # | |
154 | # Define NO_EXTERNAL_GREP if you don't want "git grep" to ever call | |
155 | # your external grep (e.g., if your system lacks grep, if its grep is | |
156 | # broken, or spawning external process is slower than built-in grep git has). | |
157 | ||
158 | GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE | |
159 | @$(SHELL_PATH) ./GIT-VERSION-GEN | |
160 | -include GIT-VERSION-FILE | |
161 | ||
162 | uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') | |
163 | uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not') | |
164 | uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') | |
165 | uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') | |
166 | uname_P := $(shell sh -c 'uname -p 2>/dev/null || echo not') | |
167 | ||
168 | # CFLAGS and LDFLAGS are for the users to override from the command line. | |
169 | ||
170 | CFLAGS = -g -O2 -Wall | |
171 | LDFLAGS = | |
172 | ALL_CFLAGS = $(CFLAGS) | |
173 | ALL_LDFLAGS = $(LDFLAGS) | |
174 | STRIP ?= strip | |
175 | ||
176 | # Among the variables below, these: | |
177 | # gitexecdir | |
178 | # template_dir | |
179 | # htmldir | |
180 | # ETC_GITCONFIG (but not sysconfdir) | |
181 | # can be specified as a relative path ../some/where/else (which must begin | |
182 | # with ../); this is interpreted as relative to $(bindir) and "git" at | |
183 | # runtime figures out where they are based on the path to the executable. | |
184 | # This can help installing the suite in a relocatable way. | |
185 | ||
186 | prefix = $(HOME) | |
187 | bindir = $(prefix)/bin | |
188 | mandir = $(prefix)/share/man | |
189 | infodir = $(prefix)/share/info | |
190 | gitexecdir = $(prefix)/libexec/git-core | |
191 | sharedir = $(prefix)/share | |
192 | template_dir = $(sharedir)/git-core/templates | |
193 | htmldir=$(sharedir)/doc/git-doc | |
194 | ifeq ($(prefix),/usr) | |
195 | sysconfdir = /etc | |
196 | else | |
197 | sysconfdir = $(prefix)/etc | |
198 | endif | |
199 | lib = lib | |
200 | ETC_GITCONFIG = $(sysconfdir)/gitconfig | |
201 | # DESTDIR= | |
202 | ||
203 | # default configuration for gitweb | |
204 | GITWEB_CONFIG = gitweb_config.perl | |
205 | GITWEB_CONFIG_SYSTEM = /etc/gitweb.conf | |
206 | GITWEB_HOME_LINK_STR = projects | |
207 | GITWEB_SITENAME = | |
208 | GITWEB_PROJECTROOT = /pub/git | |
209 | GITWEB_PROJECT_MAXDEPTH = 2007 | |
210 | GITWEB_EXPORT_OK = | |
211 | GITWEB_STRICT_EXPORT = | |
212 | GITWEB_BASE_URL = | |
213 | GITWEB_LIST = | |
214 | GITWEB_HOMETEXT = indextext.html | |
215 | GITWEB_CSS = gitweb.css | |
216 | GITWEB_LOGO = git-logo.png | |
217 | GITWEB_FAVICON = git-favicon.png | |
218 | GITWEB_SITE_HEADER = | |
219 | GITWEB_SITE_FOOTER = | |
220 | ||
221 | export prefix bindir sharedir htmldir sysconfdir | |
222 | ||
223 | CC = gcc | |
224 | AR = ar | |
225 | RM = rm -f | |
226 | TAR = tar | |
227 | FIND = find | |
228 | INSTALL = install | |
229 | RPMBUILD = rpmbuild | |
230 | TCL_PATH = tclsh | |
231 | TCLTK_PATH = wish | |
232 | ||
233 | export TCL_PATH TCLTK_PATH | |
234 | ||
235 | # sparse is architecture-neutral, which means that we need to tell it | |
236 | # explicitly what architecture to check for. Fix this up for yours.. | |
237 | SPARSE_FLAGS = -D__BIG_ENDIAN__ -D__powerpc__ | |
238 | ||
239 | ||
240 | ||
241 | ### --- END CONFIGURATION SECTION --- | |
242 | ||
243 | # Those must not be GNU-specific; they are shared with perl/ which may | |
244 | # be built by a different compiler. (Note that this is an artifact now | |
245 | # but it still might be nice to keep that distinction.) | |
246 | BASIC_CFLAGS = | |
247 | BASIC_LDFLAGS = | |
248 | ||
249 | SCRIPT_SH += git-am.sh | |
250 | SCRIPT_SH += git-bisect.sh | |
251 | SCRIPT_SH += git-filter-branch.sh | |
252 | SCRIPT_SH += git-lost-found.sh | |
253 | SCRIPT_SH += git-merge-octopus.sh | |
254 | SCRIPT_SH += git-merge-one-file.sh | |
255 | SCRIPT_SH += git-merge-resolve.sh | |
256 | SCRIPT_SH += git-mergetool.sh | |
257 | SCRIPT_SH += git-parse-remote.sh | |
258 | SCRIPT_SH += git-pull.sh | |
259 | SCRIPT_SH += git-quiltimport.sh | |
260 | SCRIPT_SH += git-rebase--interactive.sh | |
261 | SCRIPT_SH += git-rebase.sh | |
262 | SCRIPT_SH += git-repack.sh | |
263 | SCRIPT_SH += git-request-pull.sh | |
264 | SCRIPT_SH += git-sh-setup.sh | |
265 | SCRIPT_SH += git-stash.sh | |
266 | SCRIPT_SH += git-submodule.sh | |
267 | SCRIPT_SH += git-web--browse.sh | |
268 | ||
269 | SCRIPT_PERL += git-add--interactive.perl | |
270 | SCRIPT_PERL += git-archimport.perl | |
271 | SCRIPT_PERL += git-cvsexportcommit.perl | |
272 | SCRIPT_PERL += git-cvsimport.perl | |
273 | SCRIPT_PERL += git-cvsserver.perl | |
274 | SCRIPT_PERL += git-relink.perl | |
275 | SCRIPT_PERL += git-send-email.perl | |
276 | SCRIPT_PERL += git-svn.perl | |
277 | ||
278 | SCRIPTS = $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
279 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
280 | git-instaweb | |
281 | ||
282 | # Empty... | |
283 | EXTRA_PROGRAMS = | |
284 | ||
285 | # ... and all the rest that could be moved out of bindir to gitexecdir | |
286 | PROGRAMS += $(EXTRA_PROGRAMS) | |
287 | PROGRAMS += git-fast-import$X | |
288 | PROGRAMS += git-fetch-pack$X | |
289 | PROGRAMS += git-hash-object$X | |
290 | PROGRAMS += git-index-pack$X | |
291 | PROGRAMS += git-merge-index$X | |
292 | PROGRAMS += git-merge-tree$X | |
293 | PROGRAMS += git-mktag$X | |
294 | PROGRAMS += git-mktree$X | |
295 | PROGRAMS += git-pack-redundant$X | |
296 | PROGRAMS += git-patch-id$X | |
297 | PROGRAMS += git-receive-pack$X | |
298 | PROGRAMS += git-send-pack$X | |
299 | PROGRAMS += git-show-index$X | |
300 | PROGRAMS += git-unpack-file$X | |
301 | PROGRAMS += git-update-server-info$X | |
302 | PROGRAMS += git-upload-pack$X | |
303 | PROGRAMS += git-var$X | |
304 | ||
305 | # List built-in command $C whose implementation cmd_$C() is not in | |
306 | # builtin-$C.o but is linked in as part of some other command. | |
307 | BUILT_INS += $(patsubst builtin-%.o,git-%$X,$(BUILTIN_OBJS)) | |
308 | ||
309 | BUILT_INS += git-cherry-pick$X | |
310 | BUILT_INS += git-cherry$X | |
311 | BUILT_INS += git-format-patch$X | |
312 | BUILT_INS += git-fsck-objects$X | |
313 | BUILT_INS += git-get-tar-commit-id$X | |
314 | BUILT_INS += git-init$X | |
315 | BUILT_INS += git-merge-subtree$X | |
316 | BUILT_INS += git-peek-remote$X | |
317 | BUILT_INS += git-repo-config$X | |
318 | BUILT_INS += git-show$X | |
319 | BUILT_INS += git-status$X | |
320 | BUILT_INS += git-whatchanged$X | |
321 | ||
322 | # what 'all' will build and 'install' will install, in gitexecdir | |
323 | ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) | |
324 | ||
325 | # what 'all' will build but not install in gitexecdir | |
326 | OTHER_PROGRAMS = git$X gitweb/gitweb.cgi | |
327 | ||
328 | # Set paths to tools early so that they can be used for version tests. | |
329 | ifndef SHELL_PATH | |
330 | SHELL_PATH = /bin/sh | |
331 | endif | |
332 | ifndef PERL_PATH | |
333 | PERL_PATH = /usr/bin/perl | |
334 | endif | |
335 | ||
336 | export PERL_PATH | |
337 | ||
338 | LIB_FILE=libgit.a | |
339 | XDIFF_LIB=xdiff/lib.a | |
340 | ||
341 | LIB_H += archive.h | |
342 | LIB_H += attr.h | |
343 | LIB_H += blob.h | |
344 | LIB_H += builtin.h | |
345 | LIB_H += cache.h | |
346 | LIB_H += cache-tree.h | |
347 | LIB_H += commit.h | |
348 | LIB_H += compat/mingw.h | |
349 | LIB_H += csum-file.h | |
350 | LIB_H += decorate.h | |
351 | LIB_H += delta.h | |
352 | LIB_H += diffcore.h | |
353 | LIB_H += diff.h | |
354 | LIB_H += dir.h | |
355 | LIB_H += fsck.h | |
356 | LIB_H += git-compat-util.h | |
357 | LIB_H += graph.h | |
358 | LIB_H += grep.h | |
359 | LIB_H += hash.h | |
360 | LIB_H += help.h | |
361 | LIB_H += list-objects.h | |
362 | LIB_H += ll-merge.h | |
363 | LIB_H += log-tree.h | |
364 | LIB_H += mailmap.h | |
365 | LIB_H += object.h | |
366 | LIB_H += pack.h | |
367 | LIB_H += pack-refs.h | |
368 | LIB_H += pack-revindex.h | |
369 | LIB_H += parse-options.h | |
370 | LIB_H += patch-ids.h | |
371 | LIB_H += string-list.h | |
372 | LIB_H += pkt-line.h | |
373 | LIB_H += progress.h | |
374 | LIB_H += quote.h | |
375 | LIB_H += reflog-walk.h | |
376 | LIB_H += refs.h | |
377 | LIB_H += remote.h | |
378 | LIB_H += rerere.h | |
379 | LIB_H += revision.h | |
380 | LIB_H += run-command.h | |
381 | LIB_H += sha1-lookup.h | |
382 | LIB_H += sideband.h | |
383 | LIB_H += strbuf.h | |
384 | LIB_H += tag.h | |
385 | LIB_H += transport.h | |
386 | LIB_H += tree.h | |
387 | LIB_H += tree-walk.h | |
388 | LIB_H += unpack-trees.h | |
389 | LIB_H += utf8.h | |
390 | LIB_H += wt-status.h | |
391 | ||
392 | LIB_OBJS += abspath.o | |
393 | LIB_OBJS += alias.o | |
394 | LIB_OBJS += alloc.o | |
395 | LIB_OBJS += archive.o | |
396 | LIB_OBJS += archive-tar.o | |
397 | LIB_OBJS += archive-zip.o | |
398 | LIB_OBJS += attr.o | |
399 | LIB_OBJS += base85.o | |
400 | LIB_OBJS += blob.o | |
401 | LIB_OBJS += branch.o | |
402 | LIB_OBJS += bundle.o | |
403 | LIB_OBJS += cache-tree.o | |
404 | LIB_OBJS += color.o | |
405 | LIB_OBJS += combine-diff.o | |
406 | LIB_OBJS += commit.o | |
407 | LIB_OBJS += config.o | |
408 | LIB_OBJS += connect.o | |
409 | LIB_OBJS += convert.o | |
410 | LIB_OBJS += copy.o | |
411 | LIB_OBJS += csum-file.o | |
412 | LIB_OBJS += ctype.o | |
413 | LIB_OBJS += date.o | |
414 | LIB_OBJS += decorate.o | |
415 | LIB_OBJS += diffcore-break.o | |
416 | LIB_OBJS += diffcore-delta.o | |
417 | LIB_OBJS += diffcore-order.o | |
418 | LIB_OBJS += diffcore-pickaxe.o | |
419 | LIB_OBJS += diffcore-rename.o | |
420 | LIB_OBJS += diff-delta.o | |
421 | LIB_OBJS += diff-no-index.o | |
422 | LIB_OBJS += diff-lib.o | |
423 | LIB_OBJS += diff.o | |
424 | LIB_OBJS += dir.o | |
425 | LIB_OBJS += editor.o | |
426 | LIB_OBJS += entry.o | |
427 | LIB_OBJS += environment.o | |
428 | LIB_OBJS += exec_cmd.o | |
429 | LIB_OBJS += fsck.o | |
430 | LIB_OBJS += graph.o | |
431 | LIB_OBJS += grep.o | |
432 | LIB_OBJS += hash.o | |
433 | LIB_OBJS += help.o | |
434 | LIB_OBJS += ident.o | |
435 | LIB_OBJS += interpolate.o | |
436 | LIB_OBJS += list-objects.o | |
437 | LIB_OBJS += ll-merge.o | |
438 | LIB_OBJS += lockfile.o | |
439 | LIB_OBJS += log-tree.o | |
440 | LIB_OBJS += mailmap.o | |
441 | LIB_OBJS += match-trees.o | |
442 | LIB_OBJS += merge-file.o | |
443 | LIB_OBJS += name-hash.o | |
444 | LIB_OBJS += object.o | |
445 | LIB_OBJS += pack-check.o | |
446 | LIB_OBJS += pack-refs.o | |
447 | LIB_OBJS += pack-revindex.o | |
448 | LIB_OBJS += pack-write.o | |
449 | LIB_OBJS += pager.o | |
450 | LIB_OBJS += parse-options.o | |
451 | LIB_OBJS += patch-delta.o | |
452 | LIB_OBJS += patch-ids.o | |
453 | LIB_OBJS += string-list.o | |
454 | LIB_OBJS += path.o | |
455 | LIB_OBJS += pkt-line.o | |
456 | LIB_OBJS += pretty.o | |
457 | LIB_OBJS += progress.o | |
458 | LIB_OBJS += quote.o | |
459 | LIB_OBJS += reachable.o | |
460 | LIB_OBJS += read-cache.o | |
461 | LIB_OBJS += reflog-walk.o | |
462 | LIB_OBJS += refs.o | |
463 | LIB_OBJS += remote.o | |
464 | LIB_OBJS += rerere.o | |
465 | LIB_OBJS += revision.o | |
466 | LIB_OBJS += run-command.o | |
467 | LIB_OBJS += server-info.o | |
468 | LIB_OBJS += setup.o | |
469 | LIB_OBJS += sha1_file.o | |
470 | LIB_OBJS += sha1-lookup.o | |
471 | LIB_OBJS += sha1_name.o | |
472 | LIB_OBJS += shallow.o | |
473 | LIB_OBJS += sideband.o | |
474 | LIB_OBJS += strbuf.o | |
475 | LIB_OBJS += symlinks.o | |
476 | LIB_OBJS += tag.o | |
477 | LIB_OBJS += trace.o | |
478 | LIB_OBJS += transport.o | |
479 | LIB_OBJS += tree-diff.o | |
480 | LIB_OBJS += tree.o | |
481 | LIB_OBJS += tree-walk.o | |
482 | LIB_OBJS += unpack-trees.o | |
483 | LIB_OBJS += usage.o | |
484 | LIB_OBJS += utf8.o | |
485 | LIB_OBJS += walker.o | |
486 | LIB_OBJS += wrapper.o | |
487 | LIB_OBJS += write_or_die.o | |
488 | LIB_OBJS += ws.o | |
489 | LIB_OBJS += wt-status.o | |
490 | LIB_OBJS += xdiff-interface.o | |
491 | ||
492 | BUILTIN_OBJS += builtin-add.o | |
493 | BUILTIN_OBJS += builtin-annotate.o | |
494 | BUILTIN_OBJS += builtin-apply.o | |
495 | BUILTIN_OBJS += builtin-archive.o | |
496 | BUILTIN_OBJS += builtin-blame.o | |
497 | BUILTIN_OBJS += builtin-branch.o | |
498 | BUILTIN_OBJS += builtin-bundle.o | |
499 | BUILTIN_OBJS += builtin-cat-file.o | |
500 | BUILTIN_OBJS += builtin-check-attr.o | |
501 | BUILTIN_OBJS += builtin-check-ref-format.o | |
502 | BUILTIN_OBJS += builtin-checkout-index.o | |
503 | BUILTIN_OBJS += builtin-checkout.o | |
504 | BUILTIN_OBJS += builtin-clean.o | |
505 | BUILTIN_OBJS += builtin-clone.o | |
506 | BUILTIN_OBJS += builtin-commit-tree.o | |
507 | BUILTIN_OBJS += builtin-commit.o | |
508 | BUILTIN_OBJS += builtin-config.o | |
509 | BUILTIN_OBJS += builtin-count-objects.o | |
510 | BUILTIN_OBJS += builtin-describe.o | |
511 | BUILTIN_OBJS += builtin-diff-files.o | |
512 | BUILTIN_OBJS += builtin-diff-index.o | |
513 | BUILTIN_OBJS += builtin-diff-tree.o | |
514 | BUILTIN_OBJS += builtin-diff.o | |
515 | BUILTIN_OBJS += builtin-fast-export.o | |
516 | BUILTIN_OBJS += builtin-fetch--tool.o | |
517 | BUILTIN_OBJS += builtin-fetch-pack.o | |
518 | BUILTIN_OBJS += builtin-fetch.o | |
519 | BUILTIN_OBJS += builtin-fmt-merge-msg.o | |
520 | BUILTIN_OBJS += builtin-for-each-ref.o | |
521 | BUILTIN_OBJS += builtin-fsck.o | |
522 | BUILTIN_OBJS += builtin-gc.o | |
523 | BUILTIN_OBJS += builtin-grep.o | |
524 | BUILTIN_OBJS += builtin-help.o | |
525 | BUILTIN_OBJS += builtin-init-db.o | |
526 | BUILTIN_OBJS += builtin-log.o | |
527 | BUILTIN_OBJS += builtin-ls-files.o | |
528 | BUILTIN_OBJS += builtin-ls-remote.o | |
529 | BUILTIN_OBJS += builtin-ls-tree.o | |
530 | BUILTIN_OBJS += builtin-mailinfo.o | |
531 | BUILTIN_OBJS += builtin-mailsplit.o | |
532 | BUILTIN_OBJS += builtin-merge.o | |
533 | BUILTIN_OBJS += builtin-merge-base.o | |
534 | BUILTIN_OBJS += builtin-merge-file.o | |
535 | BUILTIN_OBJS += builtin-merge-ours.o | |
536 | BUILTIN_OBJS += builtin-merge-recursive.o | |
537 | BUILTIN_OBJS += builtin-mv.o | |
538 | BUILTIN_OBJS += builtin-name-rev.o | |
539 | BUILTIN_OBJS += builtin-pack-objects.o | |
540 | BUILTIN_OBJS += builtin-pack-refs.o | |
541 | BUILTIN_OBJS += builtin-prune-packed.o | |
542 | BUILTIN_OBJS += builtin-prune.o | |
543 | BUILTIN_OBJS += builtin-push.o | |
544 | BUILTIN_OBJS += builtin-read-tree.o | |
545 | BUILTIN_OBJS += builtin-reflog.o | |
546 | BUILTIN_OBJS += builtin-remote.o | |
547 | BUILTIN_OBJS += builtin-rerere.o | |
548 | BUILTIN_OBJS += builtin-reset.o | |
549 | BUILTIN_OBJS += builtin-rev-list.o | |
550 | BUILTIN_OBJS += builtin-rev-parse.o | |
551 | BUILTIN_OBJS += builtin-revert.o | |
552 | BUILTIN_OBJS += builtin-rm.o | |
553 | BUILTIN_OBJS += builtin-send-pack.o | |
554 | BUILTIN_OBJS += builtin-shortlog.o | |
555 | BUILTIN_OBJS += builtin-show-branch.o | |
556 | BUILTIN_OBJS += builtin-show-ref.o | |
557 | BUILTIN_OBJS += builtin-stripspace.o | |
558 | BUILTIN_OBJS += builtin-symbolic-ref.o | |
559 | BUILTIN_OBJS += builtin-tag.o | |
560 | BUILTIN_OBJS += builtin-tar-tree.o | |
561 | BUILTIN_OBJS += builtin-unpack-objects.o | |
562 | BUILTIN_OBJS += builtin-update-index.o | |
563 | BUILTIN_OBJS += builtin-update-ref.o | |
564 | BUILTIN_OBJS += builtin-upload-archive.o | |
565 | BUILTIN_OBJS += builtin-verify-pack.o | |
566 | BUILTIN_OBJS += builtin-verify-tag.o | |
567 | BUILTIN_OBJS += builtin-write-tree.o | |
568 | ||
569 | GITLIBS = $(LIB_FILE) $(XDIFF_LIB) | |
570 | EXTLIBS = | |
571 | ||
572 | # | |
573 | # Platform specific tweaks | |
574 | # | |
575 | ||
576 | # We choose to avoid "if .. else if .. else .. endif endif" | |
577 | # because maintaining the nesting to match is a pain. If | |
578 | # we had "elif" things would have been much nicer... | |
579 | ||
580 | ifeq ($(uname_S),Linux) | |
581 | NO_STRLCPY = YesPlease | |
582 | THREADED_DELTA_SEARCH = YesPlease | |
583 | endif | |
584 | ifeq ($(uname_S),GNU/kFreeBSD) | |
585 | NO_STRLCPY = YesPlease | |
586 | THREADED_DELTA_SEARCH = YesPlease | |
587 | endif | |
588 | ifeq ($(uname_S),UnixWare) | |
589 | CC = cc | |
590 | NEEDS_SOCKET = YesPlease | |
591 | NEEDS_NSL = YesPlease | |
592 | NEEDS_SSL_WITH_CRYPTO = YesPlease | |
593 | NEEDS_LIBICONV = YesPlease | |
594 | SHELL_PATH = /usr/local/bin/bash | |
595 | NO_IPV6 = YesPlease | |
596 | NO_HSTRERROR = YesPlease | |
597 | BASIC_CFLAGS += -Kthread | |
598 | BASIC_CFLAGS += -I/usr/local/include | |
599 | BASIC_LDFLAGS += -L/usr/local/lib | |
600 | INSTALL = ginstall | |
601 | TAR = gtar | |
602 | NO_STRCASESTR = YesPlease | |
603 | NO_MEMMEM = YesPlease | |
604 | endif | |
605 | ifeq ($(uname_S),SCO_SV) | |
606 | ifeq ($(uname_R),3.2) | |
607 | CFLAGS = -O2 | |
608 | endif | |
609 | ifeq ($(uname_R),5) | |
610 | CC = cc | |
611 | BASIC_CFLAGS += -Kthread | |
612 | endif | |
613 | NEEDS_SOCKET = YesPlease | |
614 | NEEDS_NSL = YesPlease | |
615 | NEEDS_SSL_WITH_CRYPTO = YesPlease | |
616 | NEEDS_LIBICONV = YesPlease | |
617 | SHELL_PATH = /usr/bin/bash | |
618 | NO_IPV6 = YesPlease | |
619 | NO_HSTRERROR = YesPlease | |
620 | BASIC_CFLAGS += -I/usr/local/include | |
621 | BASIC_LDFLAGS += -L/usr/local/lib | |
622 | NO_STRCASESTR = YesPlease | |
623 | NO_MEMMEM = YesPlease | |
624 | INSTALL = ginstall | |
625 | TAR = gtar | |
626 | endif | |
627 | ifeq ($(uname_S),Darwin) | |
628 | NEEDS_SSL_WITH_CRYPTO = YesPlease | |
629 | NEEDS_LIBICONV = YesPlease | |
630 | ifneq ($(shell expr "$(uname_R)" : '9\.'),2) | |
631 | OLD_ICONV = UnfortunatelyYes | |
632 | endif | |
633 | NO_STRLCPY = YesPlease | |
634 | NO_MEMMEM = YesPlease | |
635 | endif | |
636 | ifeq ($(uname_S),SunOS) | |
637 | NEEDS_SOCKET = YesPlease | |
638 | NEEDS_NSL = YesPlease | |
639 | SHELL_PATH = /bin/bash | |
640 | NO_STRCASESTR = YesPlease | |
641 | NO_MEMMEM = YesPlease | |
642 | NO_HSTRERROR = YesPlease | |
643 | NO_MKDTEMP = YesPlease | |
644 | ifeq ($(uname_R),5.8) | |
645 | NEEDS_LIBICONV = YesPlease | |
646 | NO_UNSETENV = YesPlease | |
647 | NO_SETENV = YesPlease | |
648 | NO_C99_FORMAT = YesPlease | |
649 | NO_STRTOUMAX = YesPlease | |
650 | endif | |
651 | ifeq ($(uname_R),5.9) | |
652 | NO_UNSETENV = YesPlease | |
653 | NO_SETENV = YesPlease | |
654 | NO_C99_FORMAT = YesPlease | |
655 | NO_STRTOUMAX = YesPlease | |
656 | endif | |
657 | INSTALL = ginstall | |
658 | TAR = gtar | |
659 | BASIC_CFLAGS += -D__EXTENSIONS__ | |
660 | endif | |
661 | ifeq ($(uname_O),Cygwin) | |
662 | NO_D_TYPE_IN_DIRENT = YesPlease | |
663 | NO_D_INO_IN_DIRENT = YesPlease | |
664 | NO_STRCASESTR = YesPlease | |
665 | NO_MEMMEM = YesPlease | |
666 | NO_SYMLINK_HEAD = YesPlease | |
667 | NEEDS_LIBICONV = YesPlease | |
668 | NO_FAST_WORKING_DIRECTORY = UnfortunatelyYes | |
669 | NO_TRUSTABLE_FILEMODE = UnfortunatelyYes | |
670 | OLD_ICONV = UnfortunatelyYes | |
671 | # There are conflicting reports about this. | |
672 | # On some boxes NO_MMAP is needed, and not so elsewhere. | |
673 | # Try commenting this out if you suspect MMAP is more efficient | |
674 | NO_MMAP = YesPlease | |
675 | NO_IPV6 = YesPlease | |
676 | X = .exe | |
677 | endif | |
678 | ifeq ($(uname_S),FreeBSD) | |
679 | NEEDS_LIBICONV = YesPlease | |
680 | NO_MEMMEM = YesPlease | |
681 | BASIC_CFLAGS += -I/usr/local/include | |
682 | BASIC_LDFLAGS += -L/usr/local/lib | |
683 | DIR_HAS_BSD_GROUP_SEMANTICS = YesPlease | |
684 | THREADED_DELTA_SEARCH = YesPlease | |
685 | endif | |
686 | ifeq ($(uname_S),OpenBSD) | |
687 | NO_STRCASESTR = YesPlease | |
688 | NO_MEMMEM = YesPlease | |
689 | NEEDS_LIBICONV = YesPlease | |
690 | BASIC_CFLAGS += -I/usr/local/include | |
691 | BASIC_LDFLAGS += -L/usr/local/lib | |
692 | THREADED_DELTA_SEARCH = YesPlease | |
693 | endif | |
694 | ifeq ($(uname_S),NetBSD) | |
695 | ifeq ($(shell expr "$(uname_R)" : '[01]\.'),2) | |
696 | NEEDS_LIBICONV = YesPlease | |
697 | endif | |
698 | BASIC_CFLAGS += -I/usr/pkg/include | |
699 | BASIC_LDFLAGS += -L/usr/pkg/lib | |
700 | ALL_LDFLAGS += -Wl,-rpath,/usr/pkg/lib | |
701 | THREADED_DELTA_SEARCH = YesPlease | |
702 | endif | |
703 | ifeq ($(uname_S),AIX) | |
704 | NO_STRCASESTR=YesPlease | |
705 | NO_MEMMEM = YesPlease | |
706 | NO_MKDTEMP = YesPlease | |
707 | NO_STRLCPY = YesPlease | |
708 | FREAD_READS_DIRECTORIES = UnfortunatelyYes | |
709 | INTERNAL_QSORT = UnfortunatelyYes | |
710 | NEEDS_LIBICONV=YesPlease | |
711 | BASIC_CFLAGS += -D_LARGE_FILES | |
712 | endif | |
713 | ifeq ($(uname_S),GNU) | |
714 | # GNU/Hurd | |
715 | NO_STRLCPY=YesPlease | |
716 | endif | |
717 | ifeq ($(uname_S),IRIX64) | |
718 | NO_IPV6=YesPlease | |
719 | NO_SETENV=YesPlease | |
720 | NO_STRCASESTR=YesPlease | |
721 | NO_MEMMEM = YesPlease | |
722 | NO_STRLCPY = YesPlease | |
723 | NO_SOCKADDR_STORAGE=YesPlease | |
724 | SHELL_PATH=/usr/gnu/bin/bash | |
725 | BASIC_CFLAGS += -DPATH_MAX=1024 | |
726 | # for now, build 32-bit version | |
727 | BASIC_LDFLAGS += -L/usr/lib32 | |
728 | endif | |
729 | ifeq ($(uname_S),HP-UX) | |
730 | NO_IPV6=YesPlease | |
731 | NO_SETENV=YesPlease | |
732 | NO_STRCASESTR=YesPlease | |
733 | NO_MEMMEM = YesPlease | |
734 | NO_STRLCPY = YesPlease | |
735 | NO_MKDTEMP = YesPlease | |
736 | NO_UNSETENV = YesPlease | |
737 | NO_HSTRERROR = YesPlease | |
738 | NO_SYS_SELECT_H = YesPlease | |
739 | SNPRINTF_RETURNS_BOGUS = YesPlease | |
740 | endif | |
741 | ifneq (,$(findstring MINGW,$(uname_S))) | |
742 | NO_MMAP = YesPlease | |
743 | NO_PREAD = YesPlease | |
744 | NO_OPENSSL = YesPlease | |
745 | NO_CURL = YesPlease | |
746 | NO_SYMLINK_HEAD = YesPlease | |
747 | NO_IPV6 = YesPlease | |
748 | NO_SETENV = YesPlease | |
749 | NO_UNSETENV = YesPlease | |
750 | NO_STRCASESTR = YesPlease | |
751 | NO_STRLCPY = YesPlease | |
752 | NO_MEMMEM = YesPlease | |
753 | NEEDS_LIBICONV = YesPlease | |
754 | OLD_ICONV = YesPlease | |
755 | NO_C99_FORMAT = YesPlease | |
756 | NO_STRTOUMAX = YesPlease | |
757 | NO_MKDTEMP = YesPlease | |
758 | SNPRINTF_RETURNS_BOGUS = YesPlease | |
759 | NO_SVN_TESTS = YesPlease | |
760 | NO_PERL_MAKEMAKER = YesPlease | |
761 | NO_POSIX_ONLY_PROGRAMS = YesPlease | |
762 | NO_ST_BLOCKS_IN_STRUCT_STAT = YesPlease | |
763 | COMPAT_CFLAGS += -D__USE_MINGW_ACCESS -DNOGDI -Icompat | |
764 | COMPAT_CFLAGS += -DSNPRINTF_SIZE_CORR=1 | |
765 | COMPAT_CFLAGS += -DSTRIP_EXTENSION=\".exe\" | |
766 | COMPAT_OBJS += compat/mingw.o compat/fnmatch.o compat/regex.o compat/winansi.o | |
767 | EXTLIBS += -lws2_32 | |
768 | X = .exe | |
769 | gitexecdir = ../libexec/git-core | |
770 | template_dir = ../share/git-core/templates/ | |
771 | ETC_GITCONFIG = ../etc/gitconfig | |
772 | endif | |
773 | ifneq (,$(findstring arm,$(uname_M))) | |
774 | ARM_SHA1 = YesPlease | |
775 | endif | |
776 | ||
777 | -include config.mak.autogen | |
778 | -include config.mak | |
779 | ||
780 | ifeq ($(uname_S),Darwin) | |
781 | ifndef NO_FINK | |
782 | ifeq ($(shell test -d /sw/lib && echo y),y) | |
783 | BASIC_CFLAGS += -I/sw/include | |
784 | BASIC_LDFLAGS += -L/sw/lib | |
785 | endif | |
786 | endif | |
787 | ifndef NO_DARWIN_PORTS | |
788 | ifeq ($(shell test -d /opt/local/lib && echo y),y) | |
789 | BASIC_CFLAGS += -I/opt/local/include | |
790 | BASIC_LDFLAGS += -L/opt/local/lib | |
791 | endif | |
792 | endif | |
793 | endif | |
794 | ||
795 | ifdef NO_R_TO_GCC_LINKER | |
796 | # Some gcc does not accept and pass -R to the linker to specify | |
797 | # the runtime dynamic library path. | |
798 | CC_LD_DYNPATH = -Wl,-rpath= | |
799 | else | |
800 | CC_LD_DYNPATH = -R | |
801 | endif | |
802 | ||
803 | ifdef NO_CURL | |
804 | BASIC_CFLAGS += -DNO_CURL | |
805 | else | |
806 | ifdef CURLDIR | |
807 | # Try "-Wl,-rpath=$(CURLDIR)/$(lib)" in such a case. | |
808 | BASIC_CFLAGS += -I$(CURLDIR)/include | |
809 | CURL_LIBCURL = -L$(CURLDIR)/$(lib) $(CC_LD_DYNPATH)$(CURLDIR)/$(lib) -lcurl | |
810 | else | |
811 | CURL_LIBCURL = -lcurl | |
812 | endif | |
813 | BUILTIN_OBJS += builtin-http-fetch.o | |
814 | EXTLIBS += $(CURL_LIBCURL) | |
815 | LIB_OBJS += http.o http-walker.o | |
816 | curl_check := $(shell (echo 070908; curl-config --vernum) | sort -r | sed -ne 2p) | |
817 | ifeq "$(curl_check)" "070908" | |
818 | ifndef NO_EXPAT | |
819 | PROGRAMS += git-http-push$X | |
820 | endif | |
821 | endif | |
822 | ifndef NO_EXPAT | |
823 | EXPAT_LIBEXPAT = -lexpat | |
824 | endif | |
825 | endif | |
826 | ||
827 | ifdef ZLIB_PATH | |
828 | BASIC_CFLAGS += -I$(ZLIB_PATH)/include | |
829 | EXTLIBS += -L$(ZLIB_PATH)/$(lib) $(CC_LD_DYNPATH)$(ZLIB_PATH)/$(lib) | |
830 | endif | |
831 | EXTLIBS += -lz | |
832 | ||
833 | ifndef NO_POSIX_ONLY_PROGRAMS | |
834 | PROGRAMS += git-daemon$X | |
835 | PROGRAMS += git-imap-send$X | |
836 | PROGRAMS += git-shell$X | |
837 | endif | |
838 | ifndef NO_OPENSSL | |
839 | OPENSSL_LIBSSL = -lssl | |
840 | ifdef OPENSSLDIR | |
841 | BASIC_CFLAGS += -I$(OPENSSLDIR)/include | |
842 | OPENSSL_LINK = -L$(OPENSSLDIR)/$(lib) $(CC_LD_DYNPATH)$(OPENSSLDIR)/$(lib) | |
843 | else | |
844 | OPENSSL_LINK = | |
845 | endif | |
846 | else | |
847 | BASIC_CFLAGS += -DNO_OPENSSL | |
848 | MOZILLA_SHA1 = 1 | |
849 | OPENSSL_LIBSSL = | |
850 | endif | |
851 | ifdef NEEDS_SSL_WITH_CRYPTO | |
852 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto -lssl | |
853 | else | |
854 | LIB_4_CRYPTO = $(OPENSSL_LINK) -lcrypto | |
855 | endif | |
856 | ifdef NEEDS_LIBICONV | |
857 | ifdef ICONVDIR | |
858 | BASIC_CFLAGS += -I$(ICONVDIR)/include | |
859 | ICONV_LINK = -L$(ICONVDIR)/$(lib) $(CC_LD_DYNPATH)$(ICONVDIR)/$(lib) | |
860 | else | |
861 | ICONV_LINK = | |
862 | endif | |
863 | EXTLIBS += $(ICONV_LINK) -liconv | |
864 | endif | |
865 | ifdef NEEDS_SOCKET | |
866 | EXTLIBS += -lsocket | |
867 | endif | |
868 | ifdef NEEDS_NSL | |
869 | EXTLIBS += -lnsl | |
870 | endif | |
871 | ifdef NO_D_TYPE_IN_DIRENT | |
872 | BASIC_CFLAGS += -DNO_D_TYPE_IN_DIRENT | |
873 | endif | |
874 | ifdef NO_D_INO_IN_DIRENT | |
875 | BASIC_CFLAGS += -DNO_D_INO_IN_DIRENT | |
876 | endif | |
877 | ifdef NO_ST_BLOCKS_IN_STRUCT_STAT | |
878 | BASIC_CFLAGS += -DNO_ST_BLOCKS_IN_STRUCT_STAT | |
879 | endif | |
880 | ifdef NO_C99_FORMAT | |
881 | BASIC_CFLAGS += -DNO_C99_FORMAT | |
882 | endif | |
883 | ifdef SNPRINTF_RETURNS_BOGUS | |
884 | COMPAT_CFLAGS += -DSNPRINTF_RETURNS_BOGUS | |
885 | COMPAT_OBJS += compat/snprintf.o | |
886 | endif | |
887 | ifdef FREAD_READS_DIRECTORIES | |
888 | COMPAT_CFLAGS += -DFREAD_READS_DIRECTORIES | |
889 | COMPAT_OBJS += compat/fopen.o | |
890 | endif | |
891 | ifdef NO_SYMLINK_HEAD | |
892 | BASIC_CFLAGS += -DNO_SYMLINK_HEAD | |
893 | endif | |
894 | ifdef NO_STRCASESTR | |
895 | COMPAT_CFLAGS += -DNO_STRCASESTR | |
896 | COMPAT_OBJS += compat/strcasestr.o | |
897 | endif | |
898 | ifdef NO_STRLCPY | |
899 | COMPAT_CFLAGS += -DNO_STRLCPY | |
900 | COMPAT_OBJS += compat/strlcpy.o | |
901 | endif | |
902 | ifdef NO_STRTOUMAX | |
903 | COMPAT_CFLAGS += -DNO_STRTOUMAX | |
904 | COMPAT_OBJS += compat/strtoumax.o | |
905 | endif | |
906 | ifdef NO_STRTOULL | |
907 | COMPAT_CFLAGS += -DNO_STRTOULL | |
908 | endif | |
909 | ifdef NO_SETENV | |
910 | COMPAT_CFLAGS += -DNO_SETENV | |
911 | COMPAT_OBJS += compat/setenv.o | |
912 | endif | |
913 | ifdef NO_MKDTEMP | |
914 | COMPAT_CFLAGS += -DNO_MKDTEMP | |
915 | COMPAT_OBJS += compat/mkdtemp.o | |
916 | endif | |
917 | ifdef NO_UNSETENV | |
918 | COMPAT_CFLAGS += -DNO_UNSETENV | |
919 | COMPAT_OBJS += compat/unsetenv.o | |
920 | endif | |
921 | ifdef NO_SYS_SELECT_H | |
922 | BASIC_CFLAGS += -DNO_SYS_SELECT_H | |
923 | endif | |
924 | ifdef NO_MMAP | |
925 | COMPAT_CFLAGS += -DNO_MMAP | |
926 | COMPAT_OBJS += compat/mmap.o | |
927 | endif | |
928 | ifdef NO_PREAD | |
929 | COMPAT_CFLAGS += -DNO_PREAD | |
930 | COMPAT_OBJS += compat/pread.o | |
931 | endif | |
932 | ifdef NO_FAST_WORKING_DIRECTORY | |
933 | BASIC_CFLAGS += -DNO_FAST_WORKING_DIRECTORY | |
934 | endif | |
935 | ifdef NO_TRUSTABLE_FILEMODE | |
936 | BASIC_CFLAGS += -DNO_TRUSTABLE_FILEMODE | |
937 | endif | |
938 | ifdef NO_IPV6 | |
939 | BASIC_CFLAGS += -DNO_IPV6 | |
940 | endif | |
941 | ifdef NO_SOCKADDR_STORAGE | |
942 | ifdef NO_IPV6 | |
943 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in | |
944 | else | |
945 | BASIC_CFLAGS += -Dsockaddr_storage=sockaddr_in6 | |
946 | endif | |
947 | endif | |
948 | ifdef NO_INET_NTOP | |
949 | LIB_OBJS += compat/inet_ntop.o | |
950 | endif | |
951 | ifdef NO_INET_PTON | |
952 | LIB_OBJS += compat/inet_pton.o | |
953 | endif | |
954 | ||
955 | ifdef NO_ICONV | |
956 | BASIC_CFLAGS += -DNO_ICONV | |
957 | endif | |
958 | ||
959 | ifdef OLD_ICONV | |
960 | BASIC_CFLAGS += -DOLD_ICONV | |
961 | endif | |
962 | ||
963 | ifdef NO_DEFLATE_BOUND | |
964 | BASIC_CFLAGS += -DNO_DEFLATE_BOUND | |
965 | endif | |
966 | ||
967 | ifdef PPC_SHA1 | |
968 | SHA1_HEADER = "ppc/sha1.h" | |
969 | LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o | |
970 | else | |
971 | ifdef ARM_SHA1 | |
972 | SHA1_HEADER = "arm/sha1.h" | |
973 | LIB_OBJS += arm/sha1.o arm/sha1_arm.o | |
974 | else | |
975 | ifdef MOZILLA_SHA1 | |
976 | SHA1_HEADER = "mozilla-sha1/sha1.h" | |
977 | LIB_OBJS += mozilla-sha1/sha1.o | |
978 | else | |
979 | SHA1_HEADER = <openssl/sha.h> | |
980 | EXTLIBS += $(LIB_4_CRYPTO) | |
981 | endif | |
982 | endif | |
983 | endif | |
984 | ifdef NO_PERL_MAKEMAKER | |
985 | export NO_PERL_MAKEMAKER | |
986 | endif | |
987 | ifdef NO_HSTRERROR | |
988 | COMPAT_CFLAGS += -DNO_HSTRERROR | |
989 | COMPAT_OBJS += compat/hstrerror.o | |
990 | endif | |
991 | ifdef NO_MEMMEM | |
992 | COMPAT_CFLAGS += -DNO_MEMMEM | |
993 | COMPAT_OBJS += compat/memmem.o | |
994 | endif | |
995 | ifdef INTERNAL_QSORT | |
996 | COMPAT_CFLAGS += -DINTERNAL_QSORT | |
997 | COMPAT_OBJS += compat/qsort.o | |
998 | endif | |
999 | ||
1000 | ifdef THREADED_DELTA_SEARCH | |
1001 | BASIC_CFLAGS += -DTHREADED_DELTA_SEARCH | |
1002 | EXTLIBS += -lpthread | |
1003 | LIB_OBJS += thread-utils.o | |
1004 | endif | |
1005 | ifdef DIR_HAS_BSD_GROUP_SEMANTICS | |
1006 | COMPAT_CFLAGS += -DDIR_HAS_BSD_GROUP_SEMANTICS | |
1007 | endif | |
1008 | ifdef NO_EXTERNAL_GREP | |
1009 | BASIC_CFLAGS += -DNO_EXTERNAL_GREP | |
1010 | endif | |
1011 | ||
1012 | ifeq ($(TCLTK_PATH),) | |
1013 | NO_TCLTK=NoThanks | |
1014 | endif | |
1015 | ||
1016 | QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir | |
1017 | QUIET_SUBDIR1 = | |
1018 | ||
1019 | ifneq ($(findstring $(MAKEFLAGS),w),w) | |
1020 | PRINT_DIR = --no-print-directory | |
1021 | else # "make -w" | |
1022 | NO_SUBDIR = : | |
1023 | endif | |
1024 | ||
1025 | ifneq ($(findstring $(MAKEFLAGS),s),s) | |
1026 | ifndef V | |
1027 | QUIET_CC = @echo ' ' CC $@; | |
1028 | QUIET_AR = @echo ' ' AR $@; | |
1029 | QUIET_LINK = @echo ' ' LINK $@; | |
1030 | QUIET_BUILT_IN = @echo ' ' BUILTIN $@; | |
1031 | QUIET_GEN = @echo ' ' GEN $@; | |
1032 | QUIET_SUBDIR0 = +@subdir= | |
1033 | QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ | |
1034 | $(MAKE) $(PRINT_DIR) -C $$subdir | |
1035 | export V | |
1036 | export QUIET_GEN | |
1037 | export QUIET_BUILT_IN | |
1038 | endif | |
1039 | endif | |
1040 | ||
1041 | ifdef ASCIIDOC8 | |
1042 | export ASCIIDOC8 | |
1043 | endif | |
1044 | ||
1045 | # Shell quote (do not use $(call) to accommodate ancient setups); | |
1046 | ||
1047 | SHA1_HEADER_SQ = $(subst ','\'',$(SHA1_HEADER)) | |
1048 | ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG)) | |
1049 | ||
1050 | DESTDIR_SQ = $(subst ','\'',$(DESTDIR)) | |
1051 | bindir_SQ = $(subst ','\'',$(bindir)) | |
1052 | mandir_SQ = $(subst ','\'',$(mandir)) | |
1053 | infodir_SQ = $(subst ','\'',$(infodir)) | |
1054 | gitexecdir_SQ = $(subst ','\'',$(gitexecdir)) | |
1055 | template_dir_SQ = $(subst ','\'',$(template_dir)) | |
1056 | htmldir_SQ = $(subst ','\'',$(htmldir)) | |
1057 | prefix_SQ = $(subst ','\'',$(prefix)) | |
1058 | ||
1059 | SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH)) | |
1060 | PERL_PATH_SQ = $(subst ','\'',$(PERL_PATH)) | |
1061 | TCLTK_PATH_SQ = $(subst ','\'',$(TCLTK_PATH)) | |
1062 | ||
1063 | LIBS = $(GITLIBS) $(EXTLIBS) | |
1064 | ||
1065 | BASIC_CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER_SQ)' \ | |
1066 | $(COMPAT_CFLAGS) | |
1067 | LIB_OBJS += $(COMPAT_OBJS) | |
1068 | ||
1069 | ALL_CFLAGS += $(BASIC_CFLAGS) | |
1070 | ALL_LDFLAGS += $(BASIC_LDFLAGS) | |
1071 | ||
1072 | export TAR INSTALL DESTDIR SHELL_PATH | |
1073 | ||
1074 | ||
1075 | ### Build rules | |
1076 | ||
1077 | SHELL = $(SHELL_PATH) | |
1078 | ||
1079 | all:: shell_compatibility_test $(ALL_PROGRAMS) $(BUILT_INS) $(OTHER_PROGRAMS) GIT-BUILD-OPTIONS | |
1080 | ifneq (,$X) | |
1081 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), test '$p' -ef '$p$X' || $(RM) '$p';) | |
1082 | endif | |
1083 | ||
1084 | all:: | |
1085 | ifndef NO_TCLTK | |
1086 | $(QUIET_SUBDIR0)git-gui $(QUIET_SUBDIR1) gitexecdir='$(gitexec_instdir_SQ)' all | |
1087 | $(QUIET_SUBDIR0)gitk-git $(QUIET_SUBDIR1) all | |
1088 | endif | |
1089 | $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' all | |
1090 | $(QUIET_SUBDIR0)templates $(QUIET_SUBDIR1) | |
1091 | ||
1092 | please_set_SHELL_PATH_to_a_more_modern_shell: | |
1093 | @$$(:) | |
1094 | ||
1095 | shell_compatibility_test: please_set_SHELL_PATH_to_a_more_modern_shell | |
1096 | ||
1097 | strip: $(PROGRAMS) git$X | |
1098 | $(STRIP) $(STRIP_OPTS) $(PROGRAMS) git$X | |
1099 | ||
1100 | git.o: git.c common-cmds.h GIT-CFLAGS | |
1101 | $(QUIET_CC)$(CC) -DGIT_VERSION='"$(GIT_VERSION)"' \ | |
1102 | $(ALL_CFLAGS) -c $(filter %.c,$^) | |
1103 | ||
1104 | git$X: git.o $(BUILTIN_OBJS) $(GITLIBS) | |
1105 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ git.o \ | |
1106 | $(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS) | |
1107 | ||
1108 | builtin-help.o: builtin-help.c common-cmds.h GIT-CFLAGS | |
1109 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) \ | |
1110 | '-DGIT_HTML_PATH="$(htmldir_SQ)"' \ | |
1111 | '-DGIT_MAN_PATH="$(mandir_SQ)"' \ | |
1112 | '-DGIT_INFO_PATH="$(infodir_SQ)"' $< | |
1113 | ||
1114 | $(BUILT_INS): git$X | |
1115 | $(QUIET_BUILT_IN)$(RM) $@ && \ | |
1116 | ln git$X $@ 2>/dev/null || \ | |
1117 | ln -s git$X $@ 2>/dev/null || \ | |
1118 | cp git$X $@ | |
1119 | ||
1120 | common-cmds.h: ./generate-cmdlist.sh command-list.txt | |
1121 | ||
1122 | common-cmds.h: $(wildcard Documentation/git-*.txt) | |
1123 | $(QUIET_GEN)./generate-cmdlist.sh > $@+ && mv $@+ $@ | |
1124 | ||
1125 | $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh | |
1126 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
1127 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ | |
1128 | -e 's|@SHELL_PATH@|$(SHELL_PATH_SQ)|' \ | |
1129 | -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \ | |
1130 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
1131 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ | |
1132 | $@.sh >$@+ && \ | |
1133 | chmod +x $@+ && \ | |
1134 | mv $@+ $@ | |
1135 | ||
1136 | $(patsubst %.perl,%,$(SCRIPT_PERL)): perl/perl.mak | |
1137 | ||
1138 | perl/perl.mak: GIT-CFLAGS perl/Makefile perl/Makefile.PL | |
1139 | $(QUIET_SUBDIR0)perl $(QUIET_SUBDIR1) PERL_PATH='$(PERL_PATH_SQ)' prefix='$(prefix_SQ)' $(@F) | |
1140 | ||
1141 | $(patsubst %.perl,%,$(SCRIPT_PERL)): % : %.perl | |
1142 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
1143 | INSTLIBDIR=`MAKEFLAGS= $(MAKE) -C perl -s --no-print-directory instlibdir` && \ | |
1144 | sed -e '1{' \ | |
1145 | -e ' s|#!.*perl|#!$(PERL_PATH_SQ)|' \ | |
1146 | -e ' h' \ | |
1147 | -e ' s=.*=use lib (split(/:/, $$ENV{GITPERLLIB} || "@@INSTLIBDIR@@"));=' \ | |
1148 | -e ' H' \ | |
1149 | -e ' x' \ | |
1150 | -e '}' \ | |
1151 | -e 's|@@INSTLIBDIR@@|'"$$INSTLIBDIR"'|g' \ | |
1152 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
1153 | $@.perl >$@+ && \ | |
1154 | chmod +x $@+ && \ | |
1155 | mv $@+ $@ | |
1156 | ||
1157 | gitweb/gitweb.cgi: gitweb/gitweb.perl | |
1158 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
1159 | sed -e '1s|#!.*perl|#!$(PERL_PATH_SQ)|' \ | |
1160 | -e 's|++GIT_VERSION++|$(GIT_VERSION)|g' \ | |
1161 | -e 's|++GIT_BINDIR++|$(bindir)|g' \ | |
1162 | -e 's|++GITWEB_CONFIG++|$(GITWEB_CONFIG)|g' \ | |
1163 | -e 's|++GITWEB_CONFIG_SYSTEM++|$(GITWEB_CONFIG_SYSTEM)|g' \ | |
1164 | -e 's|++GITWEB_HOME_LINK_STR++|$(GITWEB_HOME_LINK_STR)|g' \ | |
1165 | -e 's|++GITWEB_SITENAME++|$(GITWEB_SITENAME)|g' \ | |
1166 | -e 's|++GITWEB_PROJECTROOT++|$(GITWEB_PROJECTROOT)|g' \ | |
1167 | -e 's|"++GITWEB_PROJECT_MAXDEPTH++"|$(GITWEB_PROJECT_MAXDEPTH)|g' \ | |
1168 | -e 's|++GITWEB_EXPORT_OK++|$(GITWEB_EXPORT_OK)|g' \ | |
1169 | -e 's|++GITWEB_STRICT_EXPORT++|$(GITWEB_STRICT_EXPORT)|g' \ | |
1170 | -e 's|++GITWEB_BASE_URL++|$(GITWEB_BASE_URL)|g' \ | |
1171 | -e 's|++GITWEB_LIST++|$(GITWEB_LIST)|g' \ | |
1172 | -e 's|++GITWEB_HOMETEXT++|$(GITWEB_HOMETEXT)|g' \ | |
1173 | -e 's|++GITWEB_CSS++|$(GITWEB_CSS)|g' \ | |
1174 | -e 's|++GITWEB_LOGO++|$(GITWEB_LOGO)|g' \ | |
1175 | -e 's|++GITWEB_FAVICON++|$(GITWEB_FAVICON)|g' \ | |
1176 | -e 's|++GITWEB_SITE_HEADER++|$(GITWEB_SITE_HEADER)|g' \ | |
1177 | -e 's|++GITWEB_SITE_FOOTER++|$(GITWEB_SITE_FOOTER)|g' \ | |
1178 | $< >$@+ && \ | |
1179 | chmod +x $@+ && \ | |
1180 | mv $@+ $@ | |
1181 | ||
1182 | git-instaweb: git-instaweb.sh gitweb/gitweb.cgi gitweb/gitweb.css | |
1183 | $(QUIET_GEN)$(RM) $@ $@+ && \ | |
1184 | sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ | |
1185 | -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
1186 | -e 's/@@NO_CURL@@/$(NO_CURL)/g' \ | |
1187 | -e '/@@GITWEB_CGI@@/r gitweb/gitweb.cgi' \ | |
1188 | -e '/@@GITWEB_CGI@@/d' \ | |
1189 | -e '/@@GITWEB_CSS@@/r gitweb/gitweb.css' \ | |
1190 | -e '/@@GITWEB_CSS@@/d' \ | |
1191 | -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \ | |
1192 | $@.sh > $@+ && \ | |
1193 | chmod +x $@+ && \ | |
1194 | mv $@+ $@ | |
1195 | ||
1196 | configure: configure.ac | |
1197 | $(QUIET_GEN)$(RM) $@ $<+ && \ | |
1198 | sed -e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \ | |
1199 | $< > $<+ && \ | |
1200 | autoconf -o $@ $<+ && \ | |
1201 | $(RM) $<+ | |
1202 | ||
1203 | # These can record GIT_VERSION | |
1204 | git.o git.spec \ | |
1205 | $(patsubst %.sh,%,$(SCRIPT_SH)) \ | |
1206 | $(patsubst %.perl,%,$(SCRIPT_PERL)) \ | |
1207 | : GIT-VERSION-FILE | |
1208 | ||
1209 | %.o: %.c GIT-CFLAGS | |
1210 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
1211 | %.s: %.c GIT-CFLAGS | |
1212 | $(QUIET_CC)$(CC) -S $(ALL_CFLAGS) $< | |
1213 | %.o: %.S | |
1214 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) $< | |
1215 | ||
1216 | exec_cmd.o: exec_cmd.c GIT-CFLAGS | |
1217 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_EXEC_PATH="$(gitexecdir_SQ)"' $< | |
1218 | builtin-init-db.o: builtin-init-db.c GIT-CFLAGS | |
1219 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DDEFAULT_GIT_TEMPLATE_DIR='"$(template_dir_SQ)"' $< | |
1220 | ||
1221 | config.o: config.c GIT-CFLAGS | |
1222 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DETC_GITCONFIG='"$(ETC_GITCONFIG_SQ)"' $< | |
1223 | ||
1224 | http.o: http.c GIT-CFLAGS | |
1225 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DGIT_USER_AGENT='"git/$(GIT_VERSION)"' $< | |
1226 | ||
1227 | ifdef NO_EXPAT | |
1228 | http-walker.o: http-walker.c http.h GIT-CFLAGS | |
1229 | $(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) -DNO_EXPAT $< | |
1230 | endif | |
1231 | ||
1232 | git-%$X: %.o $(GITLIBS) | |
1233 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) | |
1234 | ||
1235 | git-imap-send$X: imap-send.o $(GITLIBS) | |
1236 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ | |
1237 | $(LIBS) $(OPENSSL_LINK) $(OPENSSL_LIBSSL) | |
1238 | ||
1239 | http.o http-walker.o http-push.o transport.o: http.h | |
1240 | ||
1241 | git-http-push$X: revision.o http.o http-push.o $(GITLIBS) | |
1242 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) \ | |
1243 | $(LIBS) $(CURL_LIBCURL) $(EXPAT_LIBEXPAT) | |
1244 | ||
1245 | $(LIB_OBJS) $(BUILTIN_OBJS): $(LIB_H) | |
1246 | $(patsubst git-%$X,%.o,$(PROGRAMS)): $(LIB_H) $(wildcard */*.h) | |
1247 | builtin-revert.o wt-status.o: wt-status.h | |
1248 | ||
1249 | $(LIB_FILE): $(LIB_OBJS) | |
1250 | $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(LIB_OBJS) | |
1251 | ||
1252 | XDIFF_OBJS=xdiff/xdiffi.o xdiff/xprepare.o xdiff/xutils.o xdiff/xemit.o \ | |
1253 | xdiff/xmerge.o | |
1254 | $(XDIFF_OBJS): xdiff/xinclude.h xdiff/xmacros.h xdiff/xdiff.h xdiff/xtypes.h \ | |
1255 | xdiff/xutils.h xdiff/xprepare.h xdiff/xdiffi.h xdiff/xemit.h | |
1256 | ||
1257 | $(XDIFF_LIB): $(XDIFF_OBJS) | |
1258 | $(QUIET_AR)$(RM) $@ && $(AR) rcs $@ $(XDIFF_OBJS) | |
1259 | ||
1260 | ||
1261 | doc: | |
1262 | $(MAKE) -C Documentation all | |
1263 | ||
1264 | info: | |
1265 | $(MAKE) -C Documentation info | |
1266 | ||
1267 | TAGS: | |
1268 | $(RM) TAGS | |
1269 | $(FIND) . -name '*.[hcS]' -print | xargs etags -a | |
1270 | ||
1271 | tags: | |
1272 | $(RM) tags | |
1273 | $(FIND) . -name '*.[hcS]' -print | xargs ctags -a | |
1274 | ||
1275 | cscope: | |
1276 | $(RM) cscope* | |
1277 | $(FIND) . -name '*.[hcS]' -print | xargs cscope -b | |
1278 | ||
1279 | ### Detect prefix changes | |
1280 | TRACK_CFLAGS = $(subst ','\'',$(ALL_CFLAGS)):\ | |
1281 | $(bindir_SQ):$(gitexecdir_SQ):$(template_dir_SQ):$(prefix_SQ) | |
1282 | ||
1283 | GIT-CFLAGS: .FORCE-GIT-CFLAGS | |
1284 | @FLAGS='$(TRACK_CFLAGS)'; \ | |
1285 | if test x"$$FLAGS" != x"`cat GIT-CFLAGS 2>/dev/null`" ; then \ | |
1286 | echo 1>&2 " * new build flags or prefix"; \ | |
1287 | echo "$$FLAGS" >GIT-CFLAGS; \ | |
1288 | fi | |
1289 | ||
1290 | # We need to apply sq twice, once to protect from the shell | |
1291 | # that runs GIT-BUILD-OPTIONS, and then again to protect it | |
1292 | # and the first level quoting from the shell that runs "echo". | |
1293 | GIT-BUILD-OPTIONS: .FORCE-GIT-BUILD-OPTIONS | |
1294 | @echo SHELL_PATH=\''$(subst ','\'',$(SHELL_PATH_SQ))'\' >$@ | |
1295 | @echo TAR=\''$(subst ','\'',$(subst ','\'',$(TAR)))'\' >>$@ | |
1296 | ||
1297 | ### Detect Tck/Tk interpreter path changes | |
1298 | ifndef NO_TCLTK | |
1299 | TRACK_VARS = $(subst ','\'',-DTCLTK_PATH='$(TCLTK_PATH_SQ)') | |
1300 | ||
1301 | GIT-GUI-VARS: .FORCE-GIT-GUI-VARS | |
1302 | @VARS='$(TRACK_VARS)'; \ | |
1303 | if test x"$$VARS" != x"`cat $@ 2>/dev/null`" ; then \ | |
1304 | echo 1>&2 " * new Tcl/Tk interpreter location"; \ | |
1305 | echo "$$VARS" >$@; \ | |
1306 | fi | |
1307 | ||
1308 | .PHONY: .FORCE-GIT-GUI-VARS | |
1309 | endif | |
1310 | ||
1311 | ### Testing rules | |
1312 | ||
1313 | TEST_PROGRAMS = test-chmtime$X test-genrandom$X test-date$X test-delta$X test-sha1$X test-match-trees$X test-parse-options$X test-path-utils$X | |
1314 | ||
1315 | all:: $(TEST_PROGRAMS) | |
1316 | ||
1317 | # GNU make supports exporting all variables by "export" without parameters. | |
1318 | # However, the environment gets quite big, and some programs have problems | |
1319 | # with that. | |
1320 | ||
1321 | export NO_SVN_TESTS | |
1322 | ||
1323 | test: all | |
1324 | $(MAKE) -C t/ all | |
1325 | ||
1326 | test-date$X: date.o ctype.o | |
1327 | ||
1328 | test-delta$X: diff-delta.o patch-delta.o | |
1329 | ||
1330 | test-parse-options$X: parse-options.o | |
1331 | ||
1332 | .PRECIOUS: $(patsubst test-%$X,test-%.o,$(TEST_PROGRAMS)) | |
1333 | ||
1334 | test-%$X: test-%.o $(GITLIBS) | |
1335 | $(QUIET_LINK)$(CC) $(ALL_CFLAGS) -o $@ $(ALL_LDFLAGS) $(filter %.o,$^) $(LIBS) | |
1336 | ||
1337 | check-sha1:: test-sha1$X | |
1338 | ./test-sha1.sh | |
1339 | ||
1340 | check: common-cmds.h | |
1341 | for i in *.c; do sparse $(ALL_CFLAGS) $(SPARSE_FLAGS) $$i || exit; done | |
1342 | ||
1343 | remove-dashes: | |
1344 | ./fixup-builtins $(BUILT_INS) $(PROGRAMS) $(SCRIPTS) | |
1345 | ||
1346 | ### Installation rules | |
1347 | ||
1348 | ifeq ($(firstword $(subst /, ,$(template_dir))),..) | |
1349 | template_instdir = $(bindir)/$(template_dir) | |
1350 | else | |
1351 | template_instdir = $(template_dir) | |
1352 | endif | |
1353 | export template_instdir | |
1354 | ||
1355 | ifeq ($(firstword $(subst /, ,$(gitexecdir))),..) | |
1356 | gitexec_instdir = $(bindir)/$(gitexecdir) | |
1357 | else | |
1358 | gitexec_instdir = $(gitexecdir) | |
1359 | endif | |
1360 | gitexec_instdir_SQ = $(subst ','\'',$(gitexec_instdir)) | |
1361 | export gitexec_instdir | |
1362 | ||
1363 | install: all | |
1364 | $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(bindir_SQ)' | |
1365 | $(INSTALL) -d -m 755 '$(DESTDIR_SQ)$(gitexec_instdir_SQ)' | |
1366 | $(INSTALL) $(ALL_PROGRAMS) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)' | |
1367 | $(INSTALL) git$X git-upload-pack$X git-receive-pack$X git-upload-archive$X git-shell$X '$(DESTDIR_SQ)$(bindir_SQ)' | |
1368 | $(MAKE) -C templates DESTDIR='$(DESTDIR_SQ)' install | |
1369 | $(MAKE) -C perl prefix='$(prefix_SQ)' DESTDIR='$(DESTDIR_SQ)' install | |
1370 | ifndef NO_TCLTK | |
1371 | $(MAKE) -C gitk-git install | |
1372 | $(MAKE) -C git-gui gitexecdir='$(gitexec_instdir_SQ)' install | |
1373 | endif | |
1374 | ifneq (,$X) | |
1375 | $(foreach p,$(patsubst %$X,%,$(filter %$X,$(ALL_PROGRAMS) $(BUILT_INS) git$X)), $(RM) '$(DESTDIR_SQ)$(gitexec_instdir_SQ)/$p';) | |
1376 | endif | |
1377 | bindir=$$(cd '$(DESTDIR_SQ)$(bindir_SQ)' && pwd) && \ | |
1378 | execdir=$$(cd '$(DESTDIR_SQ)$(gitexec_instdir_SQ)' && pwd) && \ | |
1379 | { $(RM) "$$execdir/git-add$X" && \ | |
1380 | ln git-add$X "$$execdir/git-add$X" 2>/dev/null || \ | |
1381 | cp git-add$X "$$execdir/git-add$X"; } && \ | |
1382 | { $(foreach p,$(filter-out git-add$X,$(BUILT_INS)), $(RM) "$$execdir/$p" && \ | |
1383 | ln "$$execdir/git-add$X" "$$execdir/$p" 2>/dev/null || \ | |
1384 | ln -s "git-add$X" "$$execdir/$p" 2>/dev/null || \ | |
1385 | cp "$$execdir/git-add$X" "$$execdir/$p" || exit;) } && \ | |
1386 | ./check_bindir "z$$bindir" "z$$execdir" "$$bindir/git-add$X" | |
1387 | ||
1388 | install-doc: | |
1389 | $(MAKE) -C Documentation install | |
1390 | ||
1391 | install-html: | |
1392 | $(MAKE) -C Documentation install-html | |
1393 | ||
1394 | install-info: | |
1395 | $(MAKE) -C Documentation install-info | |
1396 | ||
1397 | quick-install-doc: | |
1398 | $(MAKE) -C Documentation quick-install | |
1399 | ||
1400 | ||
1401 | ||
1402 | ### Maintainer's dist rules | |
1403 | ||
1404 | git.spec: git.spec.in | |
1405 | sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@+ | |
1406 | mv $@+ $@ | |
1407 | ||
1408 | GIT_TARNAME=git-$(GIT_VERSION) | |
1409 | dist: git.spec git-archive$(X) configure | |
1410 | ./git-archive --format=tar \ | |
1411 | --prefix=$(GIT_TARNAME)/ HEAD^{tree} > $(GIT_TARNAME).tar | |
1412 | @mkdir -p $(GIT_TARNAME) | |
1413 | @cp git.spec configure $(GIT_TARNAME) | |
1414 | @echo $(GIT_VERSION) > $(GIT_TARNAME)/version | |
1415 | @$(MAKE) -C git-gui TARDIR=../$(GIT_TARNAME)/git-gui dist-version | |
1416 | $(TAR) rf $(GIT_TARNAME).tar \ | |
1417 | $(GIT_TARNAME)/git.spec \ | |
1418 | $(GIT_TARNAME)/configure \ | |
1419 | $(GIT_TARNAME)/version \ | |
1420 | $(GIT_TARNAME)/git-gui/version | |
1421 | @$(RM) -r $(GIT_TARNAME) | |
1422 | gzip -f -9 $(GIT_TARNAME).tar | |
1423 | ||
1424 | rpm: dist | |
1425 | $(RPMBUILD) -ta $(GIT_TARNAME).tar.gz | |
1426 | ||
1427 | htmldocs = git-htmldocs-$(GIT_VERSION) | |
1428 | manpages = git-manpages-$(GIT_VERSION) | |
1429 | dist-doc: | |
1430 | $(RM) -r .doc-tmp-dir | |
1431 | mkdir .doc-tmp-dir | |
1432 | $(MAKE) -C Documentation WEBDOC_DEST=../.doc-tmp-dir install-webdoc | |
1433 | cd .doc-tmp-dir && $(TAR) cf ../$(htmldocs).tar . | |
1434 | gzip -n -9 -f $(htmldocs).tar | |
1435 | : | |
1436 | $(RM) -r .doc-tmp-dir | |
1437 | mkdir -p .doc-tmp-dir/man1 .doc-tmp-dir/man5 .doc-tmp-dir/man7 | |
1438 | $(MAKE) -C Documentation DESTDIR=./ \ | |
1439 | man1dir=../.doc-tmp-dir/man1 \ | |
1440 | man5dir=../.doc-tmp-dir/man5 \ | |
1441 | man7dir=../.doc-tmp-dir/man7 \ | |
1442 | install | |
1443 | cd .doc-tmp-dir && $(TAR) cf ../$(manpages).tar . | |
1444 | gzip -n -9 -f $(manpages).tar | |
1445 | $(RM) -r .doc-tmp-dir | |
1446 | ||
1447 | ### Cleaning rules | |
1448 | ||
1449 | distclean: clean | |
1450 | $(RM) configure | |
1451 | ||
1452 | clean: | |
1453 | $(RM) *.o mozilla-sha1/*.o arm/*.o ppc/*.o compat/*.o xdiff/*.o \ | |
1454 | $(LIB_FILE) $(XDIFF_LIB) | |
1455 | $(RM) $(ALL_PROGRAMS) $(BUILT_INS) git$X | |
1456 | $(RM) $(TEST_PROGRAMS) | |
1457 | $(RM) *.spec *.pyc *.pyo */*.pyc */*.pyo common-cmds.h TAGS tags cscope* | |
1458 | $(RM) -r autom4te.cache | |
1459 | $(RM) config.log config.mak.autogen config.mak.append config.status config.cache | |
1460 | $(RM) -r $(GIT_TARNAME) .doc-tmp-dir | |
1461 | $(RM) $(GIT_TARNAME).tar.gz git-core_$(GIT_VERSION)-*.tar.gz | |
1462 | $(RM) $(htmldocs).tar.gz $(manpages).tar.gz | |
1463 | $(RM) gitweb/gitweb.cgi | |
1464 | $(MAKE) -C Documentation/ clean | |
1465 | $(MAKE) -C perl clean | |
1466 | $(MAKE) -C templates/ clean | |
1467 | $(MAKE) -C t/ clean | |
1468 | ifndef NO_TCLTK | |
1469 | $(MAKE) -C gitk-git clean | |
1470 | $(MAKE) -C git-gui clean | |
1471 | endif | |
1472 | $(RM) GIT-VERSION-FILE GIT-CFLAGS GIT-GUI-VARS GIT-BUILD-OPTIONS | |
1473 | ||
1474 | .PHONY: all install clean strip | |
1475 | .PHONY: shell_compatibility_test please_set_SHELL_PATH_to_a_more_modern_shell | |
1476 | .PHONY: .FORCE-GIT-VERSION-FILE TAGS tags cscope .FORCE-GIT-CFLAGS | |
1477 | .PHONY: .FORCE-GIT-BUILD-OPTIONS | |
1478 | ||
1479 | ### Check documentation | |
1480 | # | |
1481 | check-docs:: | |
1482 | @(for v in $(ALL_PROGRAMS) $(BUILT_INS) git gitk; \ | |
1483 | do \ | |
1484 | case "$$v" in \ | |
1485 | git-merge-octopus | git-merge-ours | git-merge-recursive | \ | |
1486 | git-merge-resolve | git-merge-subtree | \ | |
1487 | git-fsck-objects | git-init-db | \ | |
1488 | git-?*--?* ) continue ;; \ | |
1489 | esac ; \ | |
1490 | test -f "Documentation/$$v.txt" || \ | |
1491 | echo "no doc: $$v"; \ | |
1492 | sed -e '/^#/d' command-list.txt | \ | |
1493 | grep -q "^$$v[ ]" || \ | |
1494 | case "$$v" in \ | |
1495 | git) ;; \ | |
1496 | *) echo "no link: $$v";; \ | |
1497 | esac ; \ | |
1498 | done; \ | |
1499 | ( \ | |
1500 | sed -e '/^#/d' \ | |
1501 | -e 's/[ ].*//' \ | |
1502 | -e 's/^/listed /' command-list.txt; \ | |
1503 | ls -1 Documentation/git*txt | \ | |
1504 | sed -e 's|Documentation/|documented |' \ | |
1505 | -e 's/\.txt//'; \ | |
1506 | ) | while read how cmd; \ | |
1507 | do \ | |
1508 | case "$$how,$$cmd" in \ | |
1509 | *,git-citool | \ | |
1510 | *,git-gui | \ | |
1511 | *,git-help | \ | |
1512 | documented,gitattributes | \ | |
1513 | documented,gitignore | \ | |
1514 | documented,gitmodules | \ | |
1515 | documented,gitcli | \ | |
1516 | documented,git-tools | \ | |
1517 | documented,gitcore-tutorial | \ | |
1518 | documented,gitcvs-migration | \ | |
1519 | documented,gitdiffcore | \ | |
1520 | documented,gitglossary | \ | |
1521 | documented,githooks | \ | |
1522 | documented,gitrepository-layout | \ | |
1523 | documented,gittutorial | \ | |
1524 | documented,gittutorial-2 | \ | |
1525 | sentinel,not,matching,is,ok ) continue ;; \ | |
1526 | esac; \ | |
1527 | case " $(ALL_PROGRAMS) $(BUILT_INS) git gitk " in \ | |
1528 | *" $$cmd "*) ;; \ | |
1529 | *) echo "removed but $$how: $$cmd" ;; \ | |
1530 | esac; \ | |
1531 | done ) | sort | |
1532 | ||
1533 | ### Make sure built-ins do not have dups and listed in git.c | |
1534 | # | |
1535 | check-builtins:: | |
1536 | ./check-builtins.sh | |
1537 |