Fix merge-base from getting confused.
[git/git.git] / Makefile
CommitLineData
5bdac8b3
PB
1# Define MOZILLA_SHA1 environment variable when running make to make use of
2# a bundled SHA1 routine coming from Mozilla. It is GPL'd and should be fast
3# on non-x86 architectures (e.g. PowerPC), while the OpenSSL version (default
4# choice) has very fast version optimized for i586.
bdd4da59 5#
5bdac8b3
PB
6# Define NO_OPENSSL environment variable if you do not have OpenSSL. You will
7# miss out git-rev-list --merge-order. This also implies MOZILLA_SHA1.
2cb45e95 8#
5bdac8b3
PB
9# Define PPC_SHA1 environment variable when running make to make use of
10# a bundled SHA1 routine optimized for PowerPC.
11
12
13# Define COLLISION_CHECK below if you believe that SHA1's
14# 1461501637330902918203684832716283019655932542976 hashes do not give you
15# sufficient guarantee that no collisions between objects will ever happen.
16
17# DEFINES += -DCOLLISION_CHECK
18
19# Define USE_NSEC below if you want git to care about sub-second file mtimes
20# and ctimes. Note that you need recent glibc (at least 2.2.4) for this, and
21# it will BREAK YOUR LOCAL DIFFS! show-diff and anything using it will likely
22# randomly break unless your underlying filesystem supports those sub-second
23# times (my ext3 doesn't).
24
25# DEFINES += -DUSE_NSEC
26
27# Define USE_STDEV below if you want git to care about the underlying device
28# change being considered an inode change from the update-cache perspective.
29
30# DEFINES += -DUSE_STDEV
31
2779fad6 32GIT_VERSION=0.99.2
a9db2974 33
5bdac8b3
PB
34COPTS?=-g -O2
35CFLAGS+=$(COPTS) -Wall $(DEFINES)
29c2cce4
TG
36
37prefix=$(HOME)
5bdac8b3 38bindir=$(prefix)/bin
29c2cce4 39# dest=
5c2a7fbc 40
5bdac8b3
PB
41CC?=gcc
42AR?=ar
43INSTALL?=install
44RPMBUILD?=rpmbuild
e83c5163 45
44c9e859
LT
46# sparse is architecture-neutral, which means that we need to tell it
47# explicitly what architecture to check for. Fix this up for yours..
5bdac8b3 48SPARSE_FLAGS?=-D__BIG_ENDIAN__ -D__powerpc__
44c9e859 49
28818ffa
PB
50
51
52### --- END CONFIGURATION SECTION ---
53
54
55
e764b8e8 56SCRIPTS=git git-apply-patch-script git-merge-one-file-script git-prune-script \
e002a16b 57 git-pull-script git-tag-script git-resolve-script git-whatchanged \
c4584ae3 58 git-fetch-script git-status-script git-commit-script \
40d8cfe4 59 git-log-script git-shortlog git-cvsimport-script git-diff-script \
3f571e0b 60 git-reset-script git-add-script git-checkout-script git-clone-script \
0acfc972 61 gitk git-cherry git-rebase-script git-relink-script git-repack-script \
37f1a519 62 git-format-patch-script git-sh-setup-script git-push-script \
0fec0822 63 git-branch-script git-parse-remote git-verify-tag-script \
ab421d2c 64 git-ls-remote-script git-clone-dumb-http git-rename-script \
8cc6a083 65 git-request-pull-script git-bisect-script
bdd4da59 66
a3df1801
LT
67PROG= git-update-cache git-diff-files git-init-db git-write-tree \
68 git-read-tree git-commit-tree git-cat-file git-fsck-cache \
9b23b4bc 69 git-checkout-cache git-diff-tree git-rev-tree git-ls-files \
a3df1801
LT
70 git-check-files git-ls-tree git-merge-base git-merge-cache \
71 git-unpack-file git-export git-diff-cache git-convert-cache \
418aaf84 72 git-http-pull git-ssh-push git-ssh-pull git-rev-list git-mktag \
7672db20 73 git-diff-helper git-tar-tree git-local-pull git-hash-object \
c4584ae3 74 git-get-tar-commit-id git-apply git-stripspace \
def88e9a
LT
75 git-diff-stages git-rev-parse git-patch-id git-pack-objects \
76 git-unpack-objects git-verify-pack git-receive-pack git-send-pack \
0271611e 77 git-prune-packed git-fetch-pack git-upload-pack git-clone-pack \
8f3f9b09
JH
78 git-show-index git-daemon git-var git-peek-remote \
79 git-update-server-info git-show-rev-cache git-build-rev-cache
e83c5163 80
0a02ce72 81LIB_FILE=libgit.a
f3a3214e 82LIB_H=cache.h object.h blob.h tree.h commit.h tag.h delta.h epoch.h csum-file.h \
44c9e859 83 pack.h pkt-line.h refs.h
28818ffa
PB
84LIB_OBJS=read-cache.o sha1_file.o usage.o object.o commit.o tree.o blob.o \
85 tag.o date.o index.o diff-delta.o patch-delta.o entry.o path.o \
dd53c7ab 86 refs.o csum-file.o pack-check.o pkt-line.o connect.o ident.o
0a02ce72 87
8f3f9b09
JH
88LIB_H += rev-cache.h
89LIB_OBJS += rev-cache.o
90
d1df5743
JH
91LIB_H += strbuf.h
92LIB_OBJS += strbuf.o
93
6fb737be
JH
94LIB_H += quote.h
95LIB_OBJS += quote.o
96
85976974 97LIB_H += diff.h count-delta.h
e468305a
PB
98DIFF_OBJS = diff.o diffcore-rename.o diffcore-pickaxe.o diffcore-pathspec.o \
99 diffcore-break.o diffcore-order.o
100LIB_OBJS += $(DIFF_OBJS) count-delta.o
86436c28 101
d19938ab 102LIB_OBJS += gitenv.o
8f3f9b09 103LIB_OBJS += server-info.o
d19938ab 104
cc1ad5c8
LT
105LIBS = $(LIB_FILE)
106LIBS += -lz
cef661fc 107
dd53c7ab
PB
108ifndef NO_OPENSSL
109 LIB_OBJS += epoch.o
9e95049b 110 OPENSSL_LIBSSL=-lssl
dd53c7ab
PB
111else
112 CFLAGS += '-DNO_OPENSSL'
113 MOZILLA_SHA1=1
9e95049b 114 OPENSSL_LIBSSL=
dd53c7ab 115endif
cef661fc
LT
116ifdef MOZILLA_SHA1
117 SHA1_HEADER="mozilla-sha1/sha1.h"
118 LIB_OBJS += mozilla-sha1/sha1.o
a6ef3518
PM
119else
120ifdef PPC_SHA1
121 SHA1_HEADER="ppc/sha1.h"
122 LIB_OBJS += ppc/sha1.o ppc/sha1ppc.o
cef661fc
LT
123else
124 SHA1_HEADER=<openssl/sha.h>
bfb15365
JS
125ifeq ($(shell uname -s),Darwin)
126 LIBS += -lcrypto -lssl
127else
3be4b61a 128 LIBS += -lcrypto
cef661fc 129endif
a6ef3518 130endif
bfb15365 131endif
cef661fc
LT
132
133CFLAGS += '-DSHA1_HEADER=$(SHA1_HEADER)'
cc1ad5c8 134
0a02ce72 135
44c9e859 136
28818ffa
PB
137### Build rules
138
139all: $(PROG)
89967023 140
a310d434 141
623c8a14
PB
142.PRECIOUS: %.o
143git-%: %.o $(LIB_FILE)
144 $(CC) $(CFLAGS) -o $@ $(filter %.o,$^) $(LIBS)
145
146git-http-pull: pull.o
147git-local-pull: pull.o
148git-ssh-pull: rsh.o pull.o
149git-ssh-push: rsh.o
a3df1801
LT
150
151git-http-pull: LIBS += -lcurl
9e95049b 152git-rev-list: LIBS += $(OPENSSL_LIBSSL)
a3df1801 153
e468305a
PB
154$(LIB_OBJS): $(LIB_H)
155$(DIFF_OBJS): diffcore.h
e83c5163 156
28818ffa
PB
157$(LIB_FILE): $(LIB_OBJS)
158 $(AR) rcs $@ $(LIB_OBJS)
159
160doc:
161 $(MAKE) -C Documentation all
162
163
164
165### Testing rules
166
167test: all
168 $(MAKE) -C t/ all
169
170test-date: test-date.c date.o
171 $(CC) $(CFLAGS) -o $@ test-date.c date.o
172
173test-delta: test-delta.c diff-delta.o patch-delta.o
174 $(CC) $(CFLAGS) -o $@ $^
175
176check:
177 for i in *.c; do sparse $(CFLAGS) $(SPARSE_FLAGS) $$i; done
178
179
180
181### Installation rules
182
183install: $(PROG) $(SCRIPTS)
184 $(INSTALL) -m755 -d $(dest)$(bindir)
9e44f898 185 $(INSTALL) $(PROG) $(SCRIPTS) $(dest)$(bindir)
28818ffa
PB
186
187install-tools:
188 $(MAKE) -C tools install
189
190install-doc:
191 $(MAKE) -C Documentation install
192
193
194
195
196### Maintainer's dist rules
197
78d9d414 198git-core.spec: git-core.spec.in Makefile
a9db2974
CW
199 sed -e 's/@@VERSION@@/$(GIT_VERSION)/g' < $< > $@
200
f85639c3
LT
201GIT_TARNAME=git-core-$(GIT_VERSION)
202dist: git-core.spec git-tar-tree
b1de9de2 203 ./git-tar-tree HEAD $(GIT_TARNAME) > $(GIT_TARNAME).tar
a9db2974 204 @mkdir -p $(GIT_TARNAME)
f85639c3
LT
205 @cp git-core.spec $(GIT_TARNAME)
206 tar rf $(GIT_TARNAME).tar $(GIT_TARNAME)/git-core.spec
a9db2974 207 @rm -rf $(GIT_TARNAME)
9dce3c06 208 gzip -f -9 $(GIT_TARNAME).tar
a9db2974
CW
209
210rpm: dist
d7b8a164 211 $(RPMBUILD) -ta git-core-$(GIT_VERSION).tar.gz
a9db2974 212
dfe07051 213
28818ffa
PB
214backup: clean
215 cd .. ; tar czvf dircache.tar.gz dir-cache
87a81c83 216
8cc39306 217
28818ffa
PB
218
219### Cleaning rules
87a81c83 220
e83c5163 221clean:
a6ef3518 222 rm -f *.o mozilla-sha1/*.o ppc/*.o $(PROG) $(LIB_FILE)
ced7c848 223 rm -f git-core-*.tar.gz git-core.spec
8cc39306 224 $(MAKE) -C tools/ clean
ca67f002 225 $(MAKE) -C Documentation/ clean