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