Merge neco to nepi-3.0
[nepi.git] / Makefile
1 SRCDIR      = $(CURDIR)/src
2 TESTDIR     = $(CURDIR)/test
3 BUILDDIR    = $(CURDIR)/build
4 DISTDIR     = $(CURDIR)/dist
5
6 # stupid distutils, it's broken in so many ways
7 SUBBUILDDIR = $(shell python -c 'import distutils.util, sys; \
8               print "lib.%s-%s" % (distutils.util.get_platform(), \
9               sys.version[0:3])')
10 PYTHON25 := $(shell python -c 'import sys; v = sys.version_info; \
11     print (1 if v[0] <= 2 and v[1] <= 5 else 0)')
12
13 ifeq ($(PYTHON25),0)
14 BUILDDIR := $(BUILDDIR)/$(SUBBUILDDIR)
15 else
16 BUILDDIR := $(BUILDDIR)/lib
17 endif
18
19 PYPATH = $(BUILDDIR):$(PYTHONPATH)
20 COVERAGE = $(or $(shell which coverage), $(shell which python-coverage), \
21            coverage)
22
23 all:
24         ./setup.py build
25
26 install: all
27         ./setup.py install
28
29 test: all
30         retval=0; \
31                for i in `find "$(TESTDIR)" -iname '*.py' -perm -u+x -type f`; do \
32                echo $$i; \
33                PYTHONPATH="$(PYPATH)" $$i -v || retval=$$?; \
34                done; exit $$retval
35
36 coverage: all
37         rm -f .coverage
38         for i in `find "$(TESTDIR)" -perm -u+x -type f`; do \
39                 set -e; \
40                 PYTHONPATH="$(PYPATH)" $(COVERAGE) -x $$i -v; \
41                 done
42         $(COVERAGE) -c
43         $(COVERAGE) -r -m `find "$(BUILDDIR)" -name \\*.py -type f`
44         rm -f .coverage
45
46 clean:
47         ./setup.py clean
48         rm -f `find -name \*.pyc` .coverage *.pcap
49
50 distclean: clean
51         rm -rf "$(DISTDIR)"
52
53 MANIFEST:
54         find . -path ./.hg\* -prune -o -path ./build -prune -o \
55                 -name \*.pyc -prune -o -name \*.swp -prune -o \
56                 -name MANIFEST -prune -o -type f -print | \
57                 sed 's#^\./##' | sort > MANIFEST
58
59 dist: MANIFEST
60         ./setup.py sdist
61
62 .PHONY: all clean distclean dist test coverage install MANIFEST