-rw-r--r-- | Makefile | 98 | ||||
-rwxr-xr-x | gen-version.sh | 24 |
2 files changed, 55 insertions, 67 deletions
@@ -1,6 +1,7 @@ -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> @@ -12,12 +13,2 @@ CGIT_SCRIPT_NAME = cgit.cgi -CGIT_VERSION = 0.5 - -all: cgit - -VERSION: - sh gen-version.sh - --include VERSION - - EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto @@ -27,9 +18,13 @@ OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ -CFLAGS += -Wall -ifdef DEBUG - CFLAGS += -g -endif +.PHONY: all git install clean distclean force-version + +all: cgit git + +VERSION: force-version + @./gen-version.sh "$(CGIT_VERSION)" +-include VERSION + -CFLAGS += -Igit +CFLAGS += -g -Wall -Igit CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' @@ -40,55 +35,32 @@ 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 - - -cgit: cgit.c cgit.h VERSION $(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 VERSION *.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) -distclean: distclean-cgit distclean-sub - -version: clean-cgit - ./gen-version.sh - make +clean: + rm -f cgit VERSION *.o + cd git && $(MAKE) clean -.PHONY: all install clean clean-cgit clean-sub clean-cache \ - distclean distclean-cgit distclean-sub release version +distclean: clean + git clean -d -x + 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 @@ -v=$(git-describe --abbrev=4 HEAD | sed -e 's/-/./g') -test -z "$v" && exit 1 -echo "CGIT_VERSION = $v" -echo "CGIT_VERSION = $v" > VERSION +#!/bin/sh + +# Get version-info specified in Makefile +V=$1 + +# Use `git describe` to get current version if we're inside a git repo +if test -d .git +then + V=$(git describe --abbrev=4 HEAD 2>/dev/null | sed -e 's/-/./g') +fi + +new="CGIT_VERSION = $V" +old=$(cat VERSION 2>/dev/null) + +# Exit if VERSION is uptodate +test "$old" = "$new" && exit 0 + +# Update VERSION with new version-info +echo "$new" > VERSION +cat VERSION |