-rw-r--r-- | Makefile | 98 | ||||
-rwxr-xr-x | gen-version.sh | 24 |
2 files changed, 55 insertions, 67 deletions
@@ -1,94 +1,66 @@ | |||
1 | prefix = /var/www/htdocs/cgit | 1 | CGIT_VERSION = v0.5 |
2 | SHA1_HEADER = <openssl/sha.h> | ||
3 | CACHE_ROOT = /var/cache/cgit | ||
4 | CGIT_CONFIG = /etc/cgitrc | ||
5 | CGIT_SCRIPT_NAME = cgit.cgi | 2 | CGIT_SCRIPT_NAME = cgit.cgi |
3 | CGIT_SCRIPT_PATH = /var/www/htdocs/cgit | ||
4 | CGIT_CONFIG = /etc/cgitrc | ||
5 | CACHE_ROOT = /var/cache/cgit | ||
6 | SHA1_HEADER = <openssl/sha.h> | ||
6 | 7 | ||
7 | # | 8 | # |
8 | # Let the user override the above settings. | 9 | # Let the user override the above settings. |
9 | # | 10 | # |
10 | -include cgit.conf | 11 | -include cgit.conf |
11 | 12 | ||
12 | 13 | ||
13 | CGIT_VERSION = 0.5 | ||
14 | |||
15 | all: cgit | ||
16 | |||
17 | VERSION: | ||
18 | sh gen-version.sh | ||
19 | |||
20 | -include VERSION | ||
21 | |||
22 | |||
23 | EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto | 14 | EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto |
24 | OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ | 15 | OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ |
25 | ui-summary.o ui-log.o ui-tree.o ui-commit.o ui-diff.o \ | 16 | ui-summary.o ui-log.o ui-tree.o ui-commit.o ui-diff.o \ |
26 | ui-snapshot.o ui-blob.o ui-tag.o | 17 | ui-snapshot.o ui-blob.o ui-tag.o |
27 | 18 | ||
28 | CFLAGS += -Wall | ||
29 | 19 | ||
30 | ifdef DEBUG | 20 | .PHONY: all git install clean distclean force-version |
31 | CFLAGS += -g | 21 | |
32 | endif | 22 | all: cgit git |
23 | |||
24 | VERSION: force-version | ||
25 | @./gen-version.sh "$(CGIT_VERSION)" | ||
26 | -include VERSION | ||
27 | |||
33 | 28 | ||
34 | CFLAGS += -Igit | 29 | CFLAGS += -g -Wall -Igit |
35 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' | 30 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' |
36 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' | 31 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' |
37 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' | 32 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' |
38 | CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' | 33 | CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' |
39 | 34 | ||
40 | 35 | ||
41 | # | 36 | cgit: cgit.c $(OBJECTS) |
42 | # If make is run on a nongit platform, get the git sources as a tarball. | ||
43 | # | ||
44 | GITVER = $(shell git version 2>/dev/null || echo nogit) | ||
45 | ifeq ($(GITVER),nogit) | ||
46 | GITURL = http://www.kernel.org/pub/software/scm/git/git-1.5.2.tar.bz2 | ||
47 | INITGIT = test -e git/git.c || ((curl "$(GITURL)" | tar -xj) && mv git-1.5.2 git) | ||
48 | else | ||
49 | INITGIT = ./submodules.sh -i | ||
50 | endif | ||
51 | |||
52 | |||
53 | cgit: cgit.c cgit.h VERSION $(OBJECTS) | ||
54 | $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS) | 37 | $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS) |
55 | 38 | ||
56 | $(OBJECTS): cgit.h git/libgit.a | 39 | $(OBJECTS): cgit.h git/xdiff/lib.a git/libgit.a VERSION |
57 | 40 | ||
58 | git/libgit.a: | 41 | git/xdiff/lib.a: | git |
59 | $(INITGIT) | ||
60 | $(MAKE) -C git | ||
61 | 42 | ||
62 | # | 43 | git/libgit.a: | git |
63 | # phony targets | ||
64 | # | ||
65 | install: all clean-cache | ||
66 | mkdir -p $(prefix) | ||
67 | install cgit $(prefix)/$(CGIT_SCRIPT_NAME) | ||
68 | install cgit.css $(prefix)/cgit.css | ||
69 | 44 | ||
70 | clean-cgit: | 45 | git: |
71 | rm -f cgit VERSION *.o | 46 | cd git && $(MAKE) xdiff/lib.a |
47 | cd git && $(MAKE) libgit.a | ||
72 | 48 | ||
73 | distclean-cgit: clean-cgit | 49 | install: all |
74 | git clean -d -x | 50 | mkdir -p $(CGIT_SCRIPT_PATH) |
75 | 51 | install cgit $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | |
76 | clean-sub: | 52 | install cgit.css $(CGIT_SCRIPT_PATH)/cgit.css |
77 | $(MAKE) -C git clean | ||
78 | |||
79 | distclean-sub: clean-sub | ||
80 | $(shell cd git && git clean -d -x) | ||
81 | |||
82 | clean-cache: | ||
83 | rm -rf $(CACHE_ROOT)/* | 53 | rm -rf $(CACHE_ROOT)/* |
84 | 54 | ||
85 | clean: clean-cgit clean-sub | 55 | uninstall: |
56 | rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) | ||
57 | rm -f $(CGIT_SCRIPT_PATH)/cgit.css | ||
58 | rm -rf $(CACHE_ROOT) | ||
86 | 59 | ||
87 | distclean: distclean-cgit distclean-sub | 60 | clean: |
88 | 61 | rm -f cgit VERSION *.o | |
89 | version: clean-cgit | 62 | cd git && $(MAKE) clean |
90 | ./gen-version.sh | ||
91 | make | ||
92 | 63 | ||
93 | .PHONY: all install clean clean-cgit clean-sub clean-cache \ | 64 | distclean: clean |
94 | distclean distclean-cgit distclean-sub release version | 65 | git clean -d -x |
66 | cd git && git clean -d -x | ||
diff --git a/gen-version.sh b/gen-version.sh index 4c60f60..739c83e 100755 --- a/gen-version.sh +++ b/gen-version.sh | |||
@@ -1,4 +1,20 @@ | |||
1 | v=$(git-describe --abbrev=4 HEAD | sed -e 's/-/./g') | 1 | #!/bin/sh |
2 | test -z "$v" && exit 1 | 2 | |
3 | echo "CGIT_VERSION = $v" | 3 | # Get version-info specified in Makefile |
4 | echo "CGIT_VERSION = $v" > VERSION | 4 | V=$1 |
5 | |||
6 | # Use `git describe` to get current version if we're inside a git repo | ||
7 | if test -d .git | ||
8 | then | ||
9 | V=$(git describe --abbrev=4 HEAD 2>/dev/null | sed -e 's/-/./g') | ||
10 | fi | ||
11 | |||
12 | new="CGIT_VERSION = $V" | ||
13 | old=$(cat VERSION 2>/dev/null) | ||
14 | |||
15 | # Exit if VERSION is uptodate | ||
16 | test "$old" = "$new" && exit 0 | ||
17 | |||
18 | # Update VERSION with new version-info | ||
19 | echo "$new" > VERSION | ||
20 | cat VERSION | ||