diff options
Diffstat (limited to 'Makefile')
| -rw-r--r-- | Makefile | 102 | 
1 files changed, 43 insertions, 59 deletions
| @@ -1,87 +1,71 @@ -CGIT_VERSION = 0.5 - -prefix = /var/www/htdocs/cgit - -SHA1_HEADER = <openssl/sha.h> -CACHE_ROOT = /var/cache/cgit -CGIT_CONFIG = /etc/cgitrc +CGIT_VERSION = v0.5  CGIT_SCRIPT_NAME = cgit.cgi +CGIT_SCRIPT_PATH = /var/www/htdocs/cgit +CGIT_CONFIG = /etc/cgitrc +CACHE_ROOT = /var/cache/cgit +SHA1_HEADER = <openssl/sha.h> +GIT_VER = 1.5.2 +GIT_URL = http://www.kernel.org/pub/software/scm/git/git-$(GIT_VER).tar.bz2  #  # Let the user override the above settings.  #  -include cgit.conf +  EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto  OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ -	ui-summary.o ui-log.o ui-view.o ui-tree.o ui-commit.o ui-diff.o \ -	ui-snapshot.o ui-blob.o +	ui-summary.o ui-log.o ui-tree.o ui-commit.o ui-diff.o \ +	ui-snapshot.o ui-blob.o ui-tag.o + + +.PHONY: all git install clean distclean force-version get-git -CFLAGS += -Wall +all: cgit git -ifdef DEBUG -	CFLAGS += -g -endif +VERSION: force-version +	@./gen-version.sh "$(CGIT_VERSION)" +-include VERSION -CFLAGS += -Igit + +CFLAGS += -g -Wall -Igit  CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)'  CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"'  CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"'  CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' -# -# If make is run on a nongit platform, get the git sources as a tarball. -# -GITVER = $(shell git version 2>/dev/null || echo nogit) -ifeq ($(GITVER),nogit) -GITURL = http://www.kernel.org/pub/software/scm/git/git-1.5.2.tar.bz2 -INITGIT = test -e git/git.c || ((curl "$(GITURL)" | tar -xj) && mv git-1.5.2 git) -else -INITGIT = ./submodules.sh -i -endif - - -# -# basic build rules -# -all: cgit - -cgit: cgit.c cgit.h $(OBJECTS) +cgit: cgit.c $(OBJECTS)  	$(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS) -$(OBJECTS): cgit.h git/libgit.a +$(OBJECTS): cgit.h git/xdiff/lib.a git/libgit.a VERSION -git/libgit.a: -	$(INITGIT) -	$(MAKE) -C git +git/xdiff/lib.a: | git -# -# phony targets -# -install: all clean-cache -	mkdir -p $(prefix) -	install cgit $(prefix)/$(CGIT_SCRIPT_NAME) -	install cgit.css $(prefix)/cgit.css +git/libgit.a: | git -clean-cgit: -	rm -f cgit *.o +git: +	cd git && $(MAKE) xdiff/lib.a +	cd git && $(MAKE) libgit.a -distclean-cgit: clean-cgit -	git clean -d -x - -clean-sub: -	$(MAKE) -C git clean - -distclean-sub: clean-sub -	$(shell cd git && git clean -d -x) - -clean-cache: +install: all +	mkdir -p $(CGIT_SCRIPT_PATH) +	install cgit $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) +	install cgit.css $(CGIT_SCRIPT_PATH)/cgit.css  	rm -rf $(CACHE_ROOT)/* -clean: clean-cgit clean-sub +uninstall: +	rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) +	rm -f $(CGIT_SCRIPT_PATH)/cgit.css +	rm -rf $(CACHE_ROOT) + +clean: +	rm -f cgit VERSION *.o +	cd git && $(MAKE) clean -distclean: distclean-cgit distclean-sub +distclean: clean +	git clean -d -x +	cd git && git clean -d -x -.PHONY: all install clean clean-cgit clean-sub clean-cache \ -	distclean distclean-cgit distclean-sub +get-git: +	curl $(GIT_URL) | tar -xj && rm -rf git && mv git-$(GIT_VER) git | 
