X-Git-Url: https://git.distorted.org.uk/~mdw/cfd/blobdiff_plain/1a7628a4057a6a852f488c4e3d70d165f1666d49..e465fcf35d2b465d54be7fdb6457daabc98970a6:/pysetup.mk diff --git a/pysetup.mk b/pysetup.mk index 0e7a218..c828b02 100644 --- a/pysetup.mk +++ b/pysetup.mk @@ -5,6 +5,7 @@ default: all PYTHON ?= python +PYTHONS ?= $(PYTHON) prefix ?= /usr/local ###-------------------------------------------------------------------------- @@ -15,14 +16,18 @@ distdir := $(shell $(PYTHON) setup.py -q distdir) ###-------------------------------------------------------------------------- ### Useful targets implemented by the `setup.py' program. +SINGLE_PYTARGETS += gen +CMD-gen ?= build_gen + PYTARGETS += all CMD-all ?= build +$(foreach p,$(PYTHONS),all/$p):: all/%: gen PYTARGETS += clean OPTS-clean ?= --all clean-hook::; rm -f MANIFEST RELEASE -PYTARGETS += dist +SINGLE_PYTARGETS += dist CMD-dist ?= sdist OPTS-dist += --dist-dir . @@ -34,15 +39,25 @@ PYTARGETS += check ###-------------------------------------------------------------------------- ### Interfacing `setup.py' to make. -pysetup = $(PYTHON) setup.py \ +pysetup = $(or $2,$(PYTHON)) setup.py \ $(if $(filter-out undefined,$(origin CMD-$1)),$(CMD-$1),$1) \ - $(OPTS-$1) + $(OPTS-$1) $(OPTS-$1/$(or $2,$(PYTHON))) + +PYTHON_PYTARGETS = $(foreach t, $(PYTARGETS), \ + $(foreach p, $(PYTHONS), \ + $t/$p)) +ALL_PYTARGETS = $(PYTARGETS) +ALL_PYTARGETS += $(SINGLE_PYTARGETS) $(PYTHON_PYTARGETS) + +$(foreach t, $(ALL_PYTARGETS), $t-hook):: %: -$(foreach t, $(PYTARGETS), $t-hook):: %: -$(PYTARGETS):: %: %-hook setup.py +$(SINGLE_PYTARGETS):: %: %-hook setup.py $(call pysetup,$*) +$(PYTARGETS):: %: %-hook $(foreach p, $(PYTHONS), %/$p) +$(PYTHON_PYTARGETS):: %: %-hook setup.py + $(call pysetup,$(patsubst %/,%,$(dir $*)),$(notdir $*)) -.PHONY: $(PYTARGETS) +.PHONY: $(ALL_PYTARGETS) ###-------------------------------------------------------------------------- ### Release builds. @@ -51,7 +66,7 @@ distcheck: rm -rf _distcheck $(PYTHON) setup.py sdist --dist-dir _distcheck cd _distcheck && tar xvfz $(distdir).tar.gz - cd _distcheck/$(distdir) && make && make check && make dist + cd _distcheck/$(distdir) && $(MAKE) && $(MAKE) check && $(MAKE) dist cp _distcheck/$(distdir)/$(distdir).tar.gz . rm -rf _distcheck