]> git.cameronkatri.com Git - cgit.git/blobdiff - Makefile
Merge branch 'repogroups'
[cgit.git] / Makefile
index 4aa7afec63606d317ec8c52cf5e664b21c3ab5a7..5e16a4f6e2ac7dd4b2f0700d991f4f252c023af0 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,30 +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
 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 \
 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-tree.c ui-commit.c ui-diff.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
 
 CFLAGS += -Wall
 
 
 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
 
 all: cgit
 
-install: all clean-cache
-       install cgit $(INSTALL_BIN)
-       install cgit.css $(INSTALL_CSS)
+cgit: cgit.c cgit.h $(OBJECTS)
+       $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS)
 
 
-cgit: cgit.c cgit.h git.h $(OBJECTS)
-       $(CC) $(CFLAGS) -DCGIT_VERSION='"$(CGIT_VERSION)"' cgit.c -o cgit \
-               $(OBJECTS) $(EXTLIBS)
+$(OBJECTS): cgit.h git/libgit.a
 
 
-$(OBJECTS): cgit.h git.h
+git/libgit.a:
+       $(INITGIT)
+       $(MAKE) -C git
 
 
-.PHONY: clean
-clean:
+#
+# phony targets
+#
+install: all clean-cache
+       mkdir -p $(prefix)
+       install cgit $(prefix)/$(CGIT_SCRIPT_NAME)
+       install cgit.css $(prefix)/cgit.css
+
+clean-cgit:
        rm -f cgit *.o
 
        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-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