summaryrefslogtreecommitdiffabout
path: root/Makefile
authorLars Hjemli <hjemli@gmail.com>2008-07-22 17:30:06 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-07-22 17:42:06 (UTC)
commitbb7485e8d7932ba04a94714bfe6a86a1e323435c (patch) (unidiff)
tree1add8c867ba8ecd54314e131859d985de5f790fe /Makefile
parentf49ea2c9968a8b30c0c268ca52aa066960fd98f7 (diff)
downloadcgit-bb7485e8d7932ba04a94714bfe6a86a1e323435c.zip
cgit-bb7485e8d7932ba04a94714bfe6a86a1e323435c.tar.gz
cgit-bb7485e8d7932ba04a94714bfe6a86a1e323435c.tar.bz2
Makefile: fix git dependency rules
The objectfiles depends unconditionally on some specific git binaries while those git binaries depends on the phony `git` target and this patch seems to get these dependencies spelled out correctly. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'Makefile') (more/less context) (ignore whitespace changes)
-rw-r--r--Makefile8
1 files changed, 3 insertions, 5 deletions
diff --git a/Makefile b/Makefile
index 3719e96..e807d1e 100644
--- a/Makefile
+++ b/Makefile
@@ -14,123 +14,121 @@ GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2
14 14
15# 15#
16# Define a way to invoke make in subdirs quietly, shamelessly ripped 16# Define a way to invoke make in subdirs quietly, shamelessly ripped
17# from git.git 17# from git.git
18# 18#
19QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir 19QUIET_SUBDIR0 = +$(MAKE) -C # space to separate -C and subdir
20QUIET_SUBDIR1 = 20QUIET_SUBDIR1 =
21 21
22ifneq ($(findstring $(MAKEFLAGS),w),w) 22ifneq ($(findstring $(MAKEFLAGS),w),w)
23PRINT_DIR = --no-print-directory 23PRINT_DIR = --no-print-directory
24else # "make -w" 24else # "make -w"
25NO_SUBDIR = : 25NO_SUBDIR = :
26endif 26endif
27 27
28ifndef V 28ifndef V
29 QUIET_CC = @echo ' ' CC $@; 29 QUIET_CC = @echo ' ' CC $@;
30 QUIET_MM = @echo ' ' MM $@; 30 QUIET_MM = @echo ' ' MM $@;
31 QUIET_SUBDIR0 = +@subdir= 31 QUIET_SUBDIR0 = +@subdir=
32 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \ 32 QUIET_SUBDIR1 = ;$(NO_SUBDIR) echo ' ' SUBDIR $$subdir; \
33 $(MAKE) $(PRINT_DIR) -C $$subdir 33 $(MAKE) $(PRINT_DIR) -C $$subdir
34endif 34endif
35 35
36# 36#
37# Define a pattern rule for automatic dependency building 37# Define a pattern rule for automatic dependency building
38# 38#
39%.d: %.c 39%.d: %.c
40 $(QUIET_MM)$(CC) $(CFLAGS) -MM $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@ 40 $(QUIET_MM)$(CC) $(CFLAGS) -MM $< | sed -e 's/\($*\)\.o:/\1.o $@:/g' >$@
41 41
42# 42#
43# Define a pattern rule for silent object building 43# Define a pattern rule for silent object building
44# 44#
45%.o: %.c 45%.o: %.c
46 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $< 46 $(QUIET_CC)$(CC) -o $*.o -c $(CFLAGS) $<
47 47
48 48
49EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto 49EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto
50OBJECTS = 50OBJECTS =
51OBJECTS += cache.o 51OBJECTS += cache.o
52OBJECTS += cgit.o 52OBJECTS += cgit.o
53OBJECTS += cmd.o 53OBJECTS += cmd.o
54OBJECTS += configfile.o 54OBJECTS += configfile.o
55OBJECTS += html.o 55OBJECTS += html.o
56OBJECTS += parsing.o 56OBJECTS += parsing.o
57OBJECTS += shared.o 57OBJECTS += shared.o
58OBJECTS += ui-blob.o 58OBJECTS += ui-blob.o
59OBJECTS += ui-commit.o 59OBJECTS += ui-commit.o
60OBJECTS += ui-diff.o 60OBJECTS += ui-diff.o
61OBJECTS += ui-log.o 61OBJECTS += ui-log.o
62OBJECTS += ui-patch.o 62OBJECTS += ui-patch.o
63OBJECTS += ui-refs.o 63OBJECTS += ui-refs.o
64OBJECTS += ui-repolist.o 64OBJECTS += ui-repolist.o
65OBJECTS += ui-shared.o 65OBJECTS += ui-shared.o
66OBJECTS += ui-snapshot.o 66OBJECTS += ui-snapshot.o
67OBJECTS += ui-summary.o 67OBJECTS += ui-summary.o
68OBJECTS += ui-tag.o 68OBJECTS += ui-tag.o
69OBJECTS += ui-tree.o 69OBJECTS += ui-tree.o
70 70
71ifdef NEEDS_LIBICONV 71ifdef NEEDS_LIBICONV
72 EXTLIBS += -liconv 72 EXTLIBS += -liconv
73endif 73endif
74 74
75 75
76.PHONY: all git test install clean distclean emptycache force-version get-git 76.PHONY: all git test install clean distclean emptycache force-version get-git
77 77
78all: cgit git 78all: cgit
79 79
80VERSION: force-version 80VERSION: force-version
81 @./gen-version.sh "$(CGIT_VERSION)" 81 @./gen-version.sh "$(CGIT_VERSION)"
82-include VERSION 82-include VERSION
83 83
84 84
85CFLAGS += -g -Wall -Igit 85CFLAGS += -g -Wall -Igit
86CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' 86CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)'
87CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' 87CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"'
88CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' 88CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"'
89CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' 89CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"'
90CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' 90CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"'
91 91
92 92
93cgit: $(OBJECTS) 93cgit: $(OBJECTS)
94 $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) 94 $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS)
95 95
96$(OBJECTS): git/xdiff/lib.a git/libgit.a 96$(OBJECTS): | git/xdiff/lib.a git/libgit.a
97 97
98cgit.o: VERSION 98cgit.o: VERSION
99 99
100-include $(OBJECTS:.o=.d) 100-include $(OBJECTS:.o=.d)
101 101
102git/xdiff/lib.a: | git 102git/xdiff/lib.a, git/libgit.a: git
103
104git/libgit.a: | git
105 103
106git: 104git:
107 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a 105 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a
108 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a 106 $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a
109 107
110test: all 108test: all
111 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all 109 $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all
112 110
113install: all 111install: all
114 mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH) 112 mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH)
115 install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 113 install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
116 install cgit.css $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.css 114 install cgit.css $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.css
117 install cgit.png $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.png 115 install cgit.png $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.png
118 116
119uninstall: 117uninstall:
120 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) 118 rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME)
121 rm -f $(CGIT_SCRIPT_PATH)/cgit.css 119 rm -f $(CGIT_SCRIPT_PATH)/cgit.css
122 rm -f $(CGIT_SCRIPT_PATH)/cgit.png 120 rm -f $(CGIT_SCRIPT_PATH)/cgit.png
123 121
124clean: 122clean:
125 rm -f cgit VERSION *.o *.d 123 rm -f cgit VERSION *.o *.d
126 cd git && $(MAKE) clean 124 cd git && $(MAKE) clean
127 125
128distclean: clean 126distclean: clean
129 git clean -d -x 127 git clean -d -x
130 cd git && git clean -d -x 128 cd git && git clean -d -x
131 129
132emptycache: 130emptycache:
133 rm -rf $(DESTDIR)$(CACHE_ROOT)/* 131 rm -rf $(DESTDIR)$(CACHE_ROOT)/*
134 132
135get-git: 133get-git:
136 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git 134 curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git