Author: Lars Hjemli <hjemli@gmail.com>
Rewrite the makefile + gen-version.sh The old files were simply broken, hopefully the new ones will work out somewhat better. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Makefile | 98 ++++++++++++++++++--------------------------------- gen-version.sh | 24 ++++++++++--
diff --git a/Makefile b/Makefile index 50d0011e83a99cdccd5a548181c3b05d77c989b1..12fd652647c2b14d0ebb57806d1ba90d5582924e 100644 --- a/Makefile +++ b/Makefile @@ -1,8 +1,9 @@ -prefix = /var/www/htdocs/cgit +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> -CACHE_ROOT = /var/cache/cgit -CGIT_CONFIG = /etc/cgitrc -CGIT_SCRIPT_NAME = cgit.cgi # # Let the user override the above settings. @@ -10,85 +11,56 @@ # -include cgit.conf -CGIT_VERSION = 0.5 - -all: cgit - -VERSION: - sh gen-version.sh - --include VERSION - - 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-tree.o ui-commit.o ui-diff.o \ ui-snapshot.o ui-blob.o ui-tag.o -CFLAGS += -Wall + +.PHONY: all git install clean distclean force-version + +all: cgit git + +VERSION: force-version + @./gen-version.sh "$(CGIT_VERSION)" +-include VERSION -ifdef DEBUG - CFLAGS += -g -endif -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 - - -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 - -git/libgit.a: - $(INITGIT) - $(MAKE) -C git +$(OBJECTS): cgit.h git/xdiff/lib.a git/libgit.a VERSION -# -# phony targets -# -install: all clean-cache - mkdir -p $(prefix) - install cgit $(prefix)/$(CGIT_SCRIPT_NAME) - install cgit.css $(prefix)/cgit.css +git/xdiff/lib.a: | git -clean-cgit: - rm -f cgit VERSION *.o +git/libgit.a: | git -distclean-cgit: clean-cgit - git clean -d -x +git: + cd git && $(MAKE) xdiff/lib.a + cd git && $(MAKE) libgit.a -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 - -distclean: distclean-cgit distclean-sub +uninstall: + rm -f $(CGIT_SCRIPT_PATH)/$(CGIT_SCRIPT_NAME) + rm -f $(CGIT_SCRIPT_PATH)/cgit.css + rm -rf $(CACHE_ROOT) -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 4c60f60758428c59aaf3a1f577ac59378261b8ab..739c83e9956a5b5ef1d821503a349055fc2a5193 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