]> git.cameronkatri.com Git - cgit.git/blobdiff - Makefile
Merge branch 'index-header'
[cgit.git] / Makefile
index c02963718f28bf5782379f76d9078a21e563d172..5e16a4f6e2ac7dd4b2f0700d991f4f252c023af0 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,28 +1,87 @@
-CGIT_VERSION = 0.1-pre
+CGIT_VERSION = 0.4
 
-INSTALL_BIN = /var/www/htdocs/cgit.cgi
-INSTALL_CSS = /var/www/htdocs/cgit.css
+prefix = /var/www/htdocs/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.
+#
+-include cgit.conf
 
-EXTLIBS = ../git/libgit.a ../git/xdiff/lib.a -lz -lcrypto
+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.c
+       ui-summary.o ui-log.o ui-view.o ui-tree.o ui-commit.o ui-diff.o \
+       ui-snapshot.o ui-blob.o
 
 CFLAGS += -Wall
 
+ifdef DEBUG
+       CFLAGS += -g
+endif
+
+CFLAGS += -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
 
-install: all
-       install cgit $(INSTALL_BIN)
-       install cgit.css $(INSTALL_CSS)
-       rm -rf $(CACHE_ROOT)/*
+cgit: cgit.c cgit.h $(OBJECTS)
+       $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS)
+
+$(OBJECTS): cgit.h git/libgit.a
 
-cgit: cgit.c cgit.h git.h $(OBJECTS)
-       $(CC) $(CFLAGS) -DCGIT_VERSION='"$(CGIT_VERSION)"' cgit.c -o cgit \
-               $(OBJECTS) $(EXTLIBS)
+git/libgit.a:
+       $(INITGIT)
+       $(MAKE) -C git
 
-$(OBJECTS): cgit.h git.h
+#
+# phony targets
+#
+install: all clean-cache
+       mkdir -p $(prefix)
+       install cgit $(prefix)/$(CGIT_SCRIPT_NAME)
+       install cgit.css $(prefix)/cgit.css
 
-.PHONY: clean
-clean:
+clean-cgit:
        rm -f cgit *.o
+
+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:
+       rm -rf $(CACHE_ROOT)/*
+
+clean: clean-cgit clean-sub
+
+distclean: distclean-cgit distclean-sub
+
+.PHONY: all install clean clean-cgit clean-sub clean-cache \
+       distclean distclean-cgit distclean-sub