1 # -DCOLLISION_CHECK if you believe that SHA1's
2 # 1461501637330902918203684832716283019655932542976 hashes do not give you
3 # enough guarantees about no collisions between objects ever hapenning.
5 # -DNSEC if you want git to care about sub-second file mtimes and ctimes.
6 # Note that you need some new glibc (at least >2.2.4) for this, and it will
7 # BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely randomly
8 # break unless your underlying filesystem supports those sub-second times
15 SCRIPTS
=git-merge-one-file-script git-prune-script git-pull-script \
18 PROG
= git-update-cache git-diff-files git-init-db git-write-tree \
19 git-read-tree git-commit-tree git-cat-file git-fsck-cache \
20 git-checkout-cache git-diff-tree git-rev-tree git-show-files \
21 git-check-files git-ls-tree git-merge-base git-merge-cache \
22 git-unpack-file git-export git-diff-cache git-convert-cache \
23 git-http-pull git-rpush git-rpull git-rev-list git-mktag \
24 git-diff-tree-helper git-tar-tree
28 install: $(PROG
) $(SCRIPTS
)
29 install $(PROG
) $(SCRIPTS
) $(HOME
)/bin
/
31 LIB_OBJS
=read-cache.o sha1_file.o usage.o object.o commit.o tree.o blob.o tag.o
33 LIB_H
=cache.h object.h blob.h tree.h commit.h tag.h
45 SHA1_HEADER
="mozilla-sha1/sha1.h"
46 LIB_OBJS
+= mozilla-sha1
/sha1.o
49 SHA1_HEADER
="ppc/sha1.h"
50 LIB_OBJS
+= ppc
/sha1.o ppc
/sha1ppc.o
52 SHA1_HEADER
=<openssl
/sha.h
>
57 CFLAGS
+= '-DSHA1_HEADER=$(SHA1_HEADER)'
59 $(LIB_FILE
): $(LIB_OBJS
)
60 $(AR
) rcs
$@
$(LIB_OBJS
)
62 git-
%: %.c
$(LIB_FILE
)
63 $(CC
) $(CFLAGS
) -o
$@
$(filter %.c
,$^
) $(LIBS
)
65 git-update-cache
: update-cache.c
66 git-diff-files
: diff-files.c
67 git-init-db
: init-db.c
68 git-write-tree
: write-tree.c
69 git-read-tree
: read-tree.c
70 git-commit-tree
: commit-tree.c
71 git-cat-file
: cat-file.c
72 git-fsck-cache
: fsck-cache.c
73 git-checkout-cache
: checkout-cache.c
74 git-diff-tree
: diff-tree.c
75 git-rev-tree
: rev-tree.c
76 git-show-files
: show-files.c
77 git-check-files
: check-files.c
78 git-ls-tree
: ls-tree.c
79 git-merge-base
: merge-base.c
80 git-merge-cache
: merge-cache.c
81 git-unpack-file
: unpack-file.c
83 git-diff-cache
: diff-cache.c
84 git-convert-cache
: convert-cache.c
85 git-http-pull
: http-pull.c
88 git-rev-list
: rev-list.c
90 git-diff-tree-helper
: diff-tree-helper.c
91 git-tar-tree
: tar-tree.c
93 git-http-pull
: LIBS
+= -lcurl
101 read-cache.o
: $(LIB_H
)
102 sha1_file.o
: $(LIB_H
)
108 rm -f
*.o mozilla-sha1
/*.o ppc
/*.o
$(PROG
) $(LIB_FILE
)
111 cd ..
; tar czvf dircache.
tar.gz dir-cache