author | Lars Hjemli <hjemli@gmail.com> | 2008-08-06 16:52:27 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-08-06 16:52:27 (UTC) |
commit | 8c2a1367c49dbe54c90f63ae93e0c78473c7dfba (patch) (unidiff) | |
tree | 5ed4ea816af2f82ed43b9f875406b9394cbadde4 | |
parent | e352a013aed6e925a10a92916500c7deccf1410a (diff) | |
download | cgit-8c2a1367c49dbe54c90f63ae93e0c78473c7dfba.zip cgit-8c2a1367c49dbe54c90f63ae93e0c78473c7dfba.tar.gz cgit-8c2a1367c49dbe54c90f63ae93e0c78473c7dfba.tar.bz2 |
Makefile: Git dependency, take 3
In commit a1266edfe the build instructions for the git libs where moved
to their real targets, which in turn depended on the phony target `git`.
But since `git` is an actual directory in cgit the git libs wouldn't be
recompiled when needed.
So with this patch (third time lucky), cgit is declared to depend on the
really phony target `libgit` and the build instructions for `libgit` is
to unconditionally rebuild git/libgit.a and git/xdiff/lib.a.
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | Makefile | 8 |
1 files changed, 3 insertions, 5 deletions
@@ -61,60 +61,58 @@ OBJECTS += ui-commit.o | |||
61 | OBJECTS += ui-diff.o | 61 | OBJECTS += ui-diff.o |
62 | OBJECTS += ui-log.o | 62 | OBJECTS += ui-log.o |
63 | OBJECTS += ui-patch.o | 63 | OBJECTS += ui-patch.o |
64 | OBJECTS += ui-refs.o | 64 | OBJECTS += ui-refs.o |
65 | OBJECTS += ui-repolist.o | 65 | OBJECTS += ui-repolist.o |
66 | OBJECTS += ui-shared.o | 66 | OBJECTS += ui-shared.o |
67 | OBJECTS += ui-snapshot.o | 67 | OBJECTS += ui-snapshot.o |
68 | OBJECTS += ui-summary.o | 68 | OBJECTS += ui-summary.o |
69 | OBJECTS += ui-tag.o | 69 | OBJECTS += ui-tag.o |
70 | OBJECTS += ui-tree.o | 70 | OBJECTS += ui-tree.o |
71 | 71 | ||
72 | ifdef NEEDS_LIBICONV | 72 | ifdef NEEDS_LIBICONV |
73 | EXTLIBS += -liconv | 73 | EXTLIBS += -liconv |
74 | endif | 74 | endif |
75 | 75 | ||
76 | 76 | ||
77 | .PHONY: all git test install uninstall clean force-version get-git | 77 | .PHONY: all libgit test install uninstall clean force-version get-git |
78 | 78 | ||
79 | all: cgit | 79 | all: cgit |
80 | 80 | ||
81 | VERSION: force-version | 81 | VERSION: force-version |
82 | @./gen-version.sh "$(CGIT_VERSION)" | 82 | @./gen-version.sh "$(CGIT_VERSION)" |
83 | -include VERSION | 83 | -include VERSION |
84 | 84 | ||
85 | 85 | ||
86 | CFLAGS += -g -Wall -Igit | 86 | CFLAGS += -g -Wall -Igit |
87 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' | 87 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' |
88 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' | 88 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' |
89 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' | 89 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' |
90 | CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' | 90 | CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' |
91 | CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' | 91 | CFLAGS += -DCGIT_CACHE_ROOT='"$(CACHE_ROOT)"' |
92 | 92 | ||
93 | 93 | ||
94 | cgit: $(OBJECTS) git/libgit.a git/xdiff/lib.a | 94 | cgit: $(OBJECTS) libgit |
95 | $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) | 95 | $(QUIET_CC)$(CC) $(CFLAGS) -o cgit $(OBJECTS) $(EXTLIBS) |
96 | 96 | ||
97 | cgit.o: VERSION | 97 | cgit.o: VERSION |
98 | 98 | ||
99 | -include $(OBJECTS:.o=.d) | 99 | -include $(OBJECTS:.o=.d) |
100 | 100 | ||
101 | git/libgit.a: git | 101 | libgit: |
102 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a | 102 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) libgit.a |
103 | |||
104 | git/xdiff/lib.a: git | ||
105 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a | 103 | $(QUIET_SUBDIR0)git $(QUIET_SUBDIR1) xdiff/lib.a |
106 | 104 | ||
107 | test: all | 105 | test: all |
108 | $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all | 106 | $(QUIET_SUBDIR0)tests $(QUIET_SUBDIR1) all |
109 | 107 | ||
110 | install: all | 108 | install: all |
111 | mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH) | 109 | mkdir -p $(DESTDIR)$(CGIT_SCRIPT_PATH) |
112 | install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | 110 | install cgit $(DESTDIR)$(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) |
113 | install cgit.css $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.css | 111 | install cgit.css $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.css |
114 | install cgit.png $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.png | 112 | install cgit.png $(DESTDIR)$(CGIT_SCRIPT_PATH)/cgit.png |
115 | 113 | ||
116 | uninstall: | 114 | uninstall: |
117 | rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | 115 | rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) |
118 | rm -f $(CGIT_SCRIPT_PATH)/cgit.css | 116 | rm -f $(CGIT_SCRIPT_PATH)/cgit.css |
119 | rm -f $(CGIT_SCRIPT_PATH)/cgit.png | 117 | rm -f $(CGIT_SCRIPT_PATH)/cgit.png |
120 | 118 | ||