summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2010-11-09 17:08:38 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2010-11-09 23:20:50 (UTC)
commit53f487dd71b597b0771359f2125388af0913f25e (patch) (unidiff)
treec1eef6fd5af9d53790f136cc9e19499668f2e8b9
parent1415f3f3e017d0123e850707c55cb7e5e5887406 (diff)
downloadcgit-53f487dd71b597b0771359f2125388af0913f25e.zip
cgit-53f487dd71b597b0771359f2125388af0913f25e.tar.gz
cgit-53f487dd71b597b0771359f2125388af0913f25e.tar.bz2
Makefile: avoid spurious rebuilds of git sources due to `sudo make`
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--Makefile2
1 files changed, 2 insertions, 0 deletions
diff --git a/Makefile b/Makefile
index 15c7c20..be1d796 100644
--- a/Makefile
+++ b/Makefile
@@ -1,191 +1,193 @@
1CGIT_VERSION = v0.8.3.4 1CGIT_VERSION = v0.8.3.4
2CGIT_SCRIPT_NAME = cgit.cgi 2CGIT_SCRIPT_NAME = cgit.cgi
3CGIT_SCRIPT_PATH = /var/www/htdocs/cgit 3CGIT_SCRIPT_PATH = /var/www/htdocs/cgit
4CGIT_DATA_PATH = $(CGIT_SCRIPT_PATH) 4CGIT_DATA_PATH = $(CGIT_SCRIPT_PATH)
5CGIT_CONFIG = /etc/cgitrc 5CGIT_CONFIG = /etc/cgitrc
6CACHE_ROOT = /var/cache/cgit 6CACHE_ROOT = /var/cache/cgit
7SHA1_HEADER = <openssl/sha.h> 7SHA1_HEADER = <openssl/sha.h>
8GIT_VER = 1.7.3 8GIT_VER = 1.7.3
9GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2 9GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2
10INSTALL = install 10INSTALL = install
11 11
12# Define NO_STRCASESTR if you don't have strcasestr. 12# Define NO_STRCASESTR if you don't have strcasestr.
13# 13#
14# Define NO_OPENSSL to disable linking with OpenSSL and use bundled SHA1 14# Define NO_OPENSSL to disable linking with OpenSSL and use bundled SHA1
15# implementation (slower). 15# implementation (slower).
16# 16#
17# Define NEEDS_LIBICONV if linking with libc is not enough (eg. Darwin). 17# Define NEEDS_LIBICONV if linking with libc is not enough (eg. Darwin).
18# 18#
19# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.) 19# Define NO_C99_FORMAT if your formatted IO functions (printf/scanf et.al.)
20# do not support the 'size specifiers' introduced by C99, namely ll, hh, 20# do not support the 'size specifiers' introduced by C99, namely ll, hh,
21# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t). 21# j, z, t. (representing long long int, char, intmax_t, size_t, ptrdiff_t).
22# some C compilers supported these specifiers prior to C99 as an extension. 22# some C compilers supported these specifiers prior to C99 as an extension.
23# 23#
24 24
25#-include config.mak 25#-include config.mak
26 26
27# 27#
28# Platform specific tweaks 28# Platform specific tweaks
29# 29#
30 30
31uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not') 31uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
32uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not') 32uname_O := $(shell sh -c 'uname -o 2>/dev/null || echo not')
33uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not') 33uname_R := $(shell sh -c 'uname -r 2>/dev/null || echo not')
34 34
35ifeq ($(uname_O),Cygwin) 35ifeq ($(uname_O),Cygwin)
36 NO_STRCASESTR = YesPlease 36 NO_STRCASESTR = YesPlease
37 NEEDS_LIBICONV = YesPlease 37 NEEDS_LIBICONV = YesPlease
38endif 38endif
39 39
40# 40#
41# Let the user override the above settings. 41# Let the user override the above settings.
42# 42#
43-include cgit.conf 43-include cgit.conf
44 44
45# 45#
46# Define a way to invoke make in subdirs quietly, shamelessly ripped 46# Define a way to invoke make in subdirs quietly, shamelessly ripped
47# from git.git 47# from git.git
48# 48#
49QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir 49QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir
50QUIET_SUBDIR1 = 50QUIET_SUBDIR1 =
51 51
52ifneq ($(findstring $(MAKEFLAGS),w),w) 52ifneq ($(findstring $(MAKEFLAGS),w),w)
53PRINT_DIR = --no-print-directory 53PRINT_DIR = --no-print-directory
54else # "make -w" 54else # "make -w"
55NO_SUBDIR = : 55NO_SUBDIR = :
56endif 56endif
57 57
58ifndef V 58ifndef V
59 QUIET_CC = @echo ' ' CC $@; 59 QUIET_CC = @echo ' ' CC $@;
60 QUIET_MM = @echo ' ' MM $@; 60 QUIET_MM = @echo ' ' MM $@;
61 QUIET_SUBDIR0 = +@subdir= 61 QUIET_SUBDIR0 = +@subdir=
62 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ 62 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \
63 $(MAKE) $(PRINT_DIR) -C $$subdir 63 $(MAKE) $(PRINT_DIR) -C $$subdir
64endif 64endif
65 65
66# 66#
67# Define a pattern rule for automatic dependency building 67# Define a pattern rule for automatic dependency building
68# 68#
69%.d: %.c 69%.d: %.c
70 $(QUIET_MM)$(CC) $(CFLAGS) -MM -MP $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@ 70 $(QUIET_MM)$(CC) $(CFLAGS) -MM -MP $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@
71 71
72# 72#
73# Define a pattern rule for silent object building 73# Define a pattern rule for silent object building
74# 74#
75%.o: %.c 75%.o: %.c
76 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $< 76 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $<
77 77
78 78
79EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lpthread 79EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lpthread
80OBJECTS = 80OBJECTS =
81OBJECTS += cache.o 81OBJECTS += cache.o
82OBJECTS += cgit.o 82OBJECTS += cgit.o
83OBJECTS += cmd.o 83OBJECTS += cmd.o
84OBJECTS += configfile.o 84OBJECTS += configfile.o
85OBJECTS += html.o 85OBJECTS += html.o
86OBJECTS += parsing.o 86OBJECTS += parsing.o
87OBJECTS += scan-tree.o 87OBJECTS += scan-tree.o
88OBJECTS += shared.o 88OBJECTS += shared.o
89OBJECTS += ui-atom.o 89OBJECTS += ui-atom.o
90OBJECTS += ui-blob.o 90OBJECTS += ui-blob.o
91OBJECTS += ui-clone.o 91OBJECTS += ui-clone.o
92OBJECTS += ui-commit.o 92OBJECTS += ui-commit.o
93OBJECTS += ui-diff.o 93OBJECTS += ui-diff.o
94OBJECTS += ui-log.o 94OBJECTS += ui-log.o
95OBJECTS += ui-patch.o 95OBJECTS += ui-patch.o
96OBJECTS += ui-plain.o 96OBJECTS += ui-plain.o
97OBJECTS += ui-refs.o 97OBJECTS += ui-refs.o
98OBJECTS += ui-repolist.o 98OBJECTS += ui-repolist.o
99OBJECTS += ui-shared.o 99OBJECTS += ui-shared.o
100OBJECTS += ui-snapshot.o 100OBJECTS += ui-snapshot.o
101OBJECTS += ui-ssdiff.o 101OBJECTS += ui-ssdiff.o
102OBJECTS += ui-stats.o 102OBJECTS += ui-stats.o
103OBJECTS += ui-summary.o 103OBJECTS += ui-summary.o
104OBJECTS += ui-tag.o 104OBJECTS += ui-tag.o
105OBJECTS += ui-tree.o 105OBJECTS += ui-tree.o
106 106
107ifdef NEEDS_LIBICONV 107ifdef NEEDS_LIBICONV
108 EXTLIBS += -liconv 108 EXTLIBS += -liconv
109endif 109endif
110 110
111 111
112.PHONY: all libgit test install uninstall clean force-version get-git \ 112.PHONY: all libgit test install uninstall clean force-version get-git \
113 doc man-doc html-doc clean-doc 113 doc man-doc html-doc clean-doc
114 114
115all: cgit 115all: cgit
116 116
117VERSION: force-version 117VERSION: force-version
118 @./gen-version.sh "$(CGIT_VERSION)" 118 @./gen-version.sh "$(CGIT_VERSION)"
119-include VERSION 119-include VERSION
120 120
121 121
122CFLAGS += -g -Wall -Igit 122CFLAGS += -g -Wall -Igit
123CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' 123CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)'
124CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' 124CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"'
125CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' 125CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"'
126CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' 126CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"'
127CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' 127CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"'
128 128
129GIT_OPTIONS = prefix=/usr
130
129ifdef NO_ICONV 131ifdef NO_ICONV
130 CFLAGS += -DNO_ICONV 132 CFLAGS += -DNO_ICONV
131endif 133endif
132ifdef NO_STRCASESTR 134ifdef NO_STRCASESTR
133 CFLAGS += -DNO_STRCASESTR 135 CFLAGS += -DNO_STRCASESTR
134endif 136endif
135ifdef NO_C99_FORMAT 137ifdef NO_C99_FORMAT
136 CFLAGS += -DNO_C99_FORMAT 138 CFLAGS += -DNO_C99_FORMAT
137endif 139endif
138ifdef NO_OPENSSL 140ifdef NO_OPENSSL
139 CFLAGS += -DNO_OPENSSL 141 CFLAGS += -DNO_OPENSSL
140 GIT_OPTIONS += NO_OPENSSL=1 142 GIT_OPTIONS += NO_OPENSSL=1
141else 143else
142 EXTLIBS += -lcrypto 144 EXTLIBS += -lcrypto
143endif 145endif
144 146
145cgit: $(OBJECTS) libgit 147cgit: $(OBJECTS) libgit
146 $(QUIET_CC)$(CC) $(CFLAGS) $(LDFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) 148 $(QUIET_CC)$(CC) $(CFLAGS) $(LDFLAGS) -o cgit $(OBJECTS) $(EXTLIBS)
147 149
148cgit.o: VERSION 150cgit.o: VERSION
149 151
150ifneq "$(MAKECMDGOALS)" "clean" 152ifneq "$(MAKECMDGOALS)" "clean"
151 -include $(OBJECTS:.o=.d) 153 -include $(OBJECTS:.o=.d)
152endif 154endif
153 155
154libgit: 156libgit:
155 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) libgit.a 157 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) libgit.a
156 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) xdiff/lib.a 158 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) NO_CURL=1 $(GIT_OPTIONS) xdiff/lib.a
157 159
158test: all 160test: all
159 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all 161 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all
160 162
161install: all 163install: all
162 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_SCRIPT_PATH) 164 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_SCRIPT_PATH)
163 $(INSTALL) -m 0755 cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 165 $(INSTALL) -m 0755 cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
164 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_DATA_PATH) 166 $(INSTALL) -m 0755 -d $(DESTDIR)$(CGIT_DATA_PATH)
165 $(INSTALL) -m 0644 cgit.css $(DESTDIR)$(CGIT_DATA_PATH)/cgit.css 167 $(INSTALL) -m 0644 cgit.css $(DESTDIR)$(CGIT_DATA_PATH)/cgit.css
166 $(INSTALL) -m 0644 cgit.png $(DESTDIR)$(CGIT_DATA_PATH)/cgit.png 168 $(INSTALL) -m 0644 cgit.png $(DESTDIR)$(CGIT_DATA_PATH)/cgit.png
167 169
168uninstall: 170uninstall:
169 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 171 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
170 rm -f $(CGIT_DATA_PATH)/cgit.css 172 rm -f $(CGIT_DATA_PATH)/cgit.css
171 rm -f $(CGIT_DATA_PATH)/cgit.png 173 rm -f $(CGIT_DATA_PATH)/cgit.png
172 174
173doc: man-doc html-doc pdf-doc 175doc: man-doc html-doc pdf-doc
174 176
175man-doc: cgitrc.5.txt 177man-doc: cgitrc.5.txt
176 a2x -f manpage cgitrc.5.txt 178 a2x -f manpage cgitrc.5.txt
177 179
178html-doc: cgitrc.5.txt 180html-doc: cgitrc.5.txt
179 a2x -f xhtml --stylesheet=cgit-doc.css cgitrc.5.txt 181 a2x -f xhtml --stylesheet=cgit-doc.css cgitrc.5.txt
180 182
181pdf-doc: cgitrc.5.txt 183pdf-doc: cgitrc.5.txt
182 a2x -f pdf cgitrc.5.txt 184 a2x -f pdf cgitrc.5.txt
183 185
184clean: clean-doc 186clean: clean-doc
185 rm -f cgit VERSION *.o *.d 187 rm -f cgit VERSION *.o *.d
186 188
187clean-doc: 189clean-doc:
188 rm -f cgitrc.5 cgitrc.5.html cgitrc.5.pdf cgitrc.5.xml cgitrc.5.fo 190 rm -f cgitrc.5 cgitrc.5.html cgitrc.5.pdf cgitrc.5.xml cgitrc.5.fo
189 191
190get-git: 192get-git:
191 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git 193 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git