Packages: improved per-module dependency tracking.

This commit is contained in:
Andrei Belov
2018-01-22 16:39:31 +03:00
parent d1f29ed77e
commit be8df0631a
15 changed files with 74 additions and 20 deletions

View File

@@ -12,7 +12,8 @@ SRCDIR= unit-$(VERSION)
CODENAME = $(shell lsb_release -cs)
BUILD_DEPENDS = debhelper devscripts libxml2-utils lintian lsb-release xsltproc
BUILD_DEPENDS_unit = debhelper devscripts libxml2-utils lintian lsb-release xsltproc
BUILD_DEPENDS = $(BUILD_DEPENDS_unit)
MODULES=
@@ -100,6 +101,25 @@ check-build-depends:
fi \
}
check-build-depends-%:
@{ \
not_installed= ; \
for pkg in $(BUILD_DEPENDS_unit) $(BUILD_DEPENDS_$*); do \
dpkg -s $${pkg} >/dev/null 2>&1 ; \
if [ $$? -ne 0 ]; then \
not_installed="$${not_installed} $${pkg}" ; \
fi ; \
done ; \
if test -n "$${not_installed}" ; then \
echo "" >&2 ; \
echo "The following packages are required in order to proceed:" >&2 ; \
echo "" >&2 ; \
echo $${not_installed} >&2 ; \
echo "" >&2 ; \
exit 1 ; \
fi \
}
debuild/$(SRCDIR)/debian:
@{ \
set -e ; \
@@ -133,7 +153,7 @@ debuild/unit_$(VERSION).orig.tar.gz: | debuild/$(SRCDIR)/debian
mv debuild/$(SRCDIR).tar.gz debuild/unit_$(VERSION).orig.tar.gz
cd debuild && tar zxf unit_$(VERSION).orig.tar.gz
unit: debuild/unit_$(VERSION).orig.tar.gz debuild/$(SRCDIR)/debian/changelog
unit: check-build-depends-unit debuild/unit_$(VERSION).orig.tar.gz debuild/$(SRCDIR)/debian/changelog
@echo "===> Building $@ package"
cd debuild/$(SRCDIR) && debuild -us -uc
mkdir -p debs
@@ -192,7 +212,7 @@ debuild-%: debuild/unit_$(VERSION).orig.tar.gz ../../docs/changes.xml
chmod +x $@/$(SRCDIR)/debian/rules ; \
}
unit-%: | debuild-%
unit-%: check-build-depends-% | debuild-%
@echo "===> Building $@ package"
cd debuild-$*/$(SRCDIR) && debuild -us -uc
mkdir -p debs

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_go= go-install
MODULE_SOURCES_go= unit.example-go-app \
unit.example-go-config
BUILD_DEPENDS+= golang
BUILD_DEPENDS_go= golang
BUILD_DEPENDS+= $(BUILD_DEPENDS_go)
MODULE_BUILD_DEPENDS_go=,golang
MODULE_DEPENDS_go=,golang

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_go17= /usr/lib/go-1.7/bin/go-install
MODULE_SOURCES_go17= unit.example-go-app \
unit.example-go1.7-config
BUILD_DEPENDS+= golang-1.7
BUILD_DEPENDS_go17= golang-1.7
BUILD_DEPENDS+= $(BUILD_DEPENDS_go17)
MODULE_BUILD_DEPENDS_go17=,golang-1.7
MODULE_DEPENDS_go17=,golang-1.7

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_go18= /usr/lib/go-1.8/bin/go-install
MODULE_SOURCES_go18= unit.example-go-app \
unit.example-go1.8-config
BUILD_DEPENDS+= golang-1.8
BUILD_DEPENDS_go18= golang-1.8
BUILD_DEPENDS+= $(BUILD_DEPENDS_go18)
MODULE_BUILD_DEPENDS_go18=,golang-1.8
MODULE_DEPENDS_go18=,golang-1.8

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_go19= /usr/lib/go-1.9/bin/go-install
MODULE_SOURCES_go19= unit.example-go-app \
unit.example-go1.9-config
BUILD_DEPENDS+= golang-1.9
BUILD_DEPENDS_go19= golang-1.9
BUILD_DEPENDS+= $(BUILD_DEPENDS_go19)
MODULE_BUILD_DEPENDS_go19=,golang-1.9
MODULE_DEPENDS_go19=,golang-1.9

View File

@@ -14,15 +14,17 @@ MODULE_SOURCES_php= unit.example-php-app \
unit.example-php-config
ifneq (,$(findstring $(CODENAME),trusty jessie))
BUILD_DEPENDS+= php5-dev libphp5-embed
BUILD_DEPENDS_php= php5-dev libphp5-embed
MODULE_BUILD_DEPENDS_php=,php5-dev,libphp5-embed
MODULE_DEPENDS_php=,libphp5-embed
else
BUILD_DEPENDS+= php-dev libphp-embed
BUILD_DEPENDS_php= php-dev libphp-embed
MODULE_BUILD_DEPENDS_php=,php-dev,libphp-embed
MODULE_DEPENDS_php=,libphp-embed
endif
BUILD_DEPENDS+= $(BUILD_DEPENDS_php)
define MODULE_PREINSTALL_php
mkdir -p debian/unit-php/usr/share/doc/unit-php/examples/phpinfo-app
install -m 644 -p debian/unit.example-php-app debian/unit-php/usr/share/doc/unit-php/examples/phpinfo-app/index.php

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_python= python-install
MODULE_SOURCES_python= unit.example-python-app \
unit.example-python-config
BUILD_DEPENDS+= python-dev
BUILD_DEPENDS_python= python-dev
BUILD_DEPENDS+= $(BUILD_DEPENDS_python)
MODULE_BUILD_DEPENDS_python=,python-dev

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_python27= python2.7-install
MODULE_SOURCES_python27= unit.example-python-app \
unit.example-python2.7-config
BUILD_DEPENDS+= python2.7-dev
BUILD_DEPENDS_python27= python2.7-dev
BUILD_DEPENDS+= $(BUILD_DEPENDS_python27)
MODULE_BUILD_DEPENDS_python27=,python2.7-dev

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_python34= python3.4-install
MODULE_SOURCES_python34= unit.example-python-app \
unit.example-python3.4-config
BUILD_DEPENDS+= python3.4-dev
BUILD_DEPENDS_python34= python3.4-dev
BUILD_DEPENDS+= $(BUILD_DEPENDS_python34)
MODULE_BUILD_DEPENDS_python34=,python3.4-dev

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_python35= python3.5-install
MODULE_SOURCES_python35= unit.example-python-app \
unit.example-python3.5-config
BUILD_DEPENDS+= python3.5-dev
BUILD_DEPENDS_python35= python3.5-dev
BUILD_DEPENDS+= $(BUILD_DEPENDS_python35)
MODULE_BUILD_DEPENDS_python35=,python3.5-dev

View File

@@ -13,7 +13,8 @@ MODULE_INSTARGS_python36= python3.6-install
MODULE_SOURCES_python36= unit.example-python-app \
unit.example-python3.6-config
BUILD_DEPENDS+= python3.6-dev
BUILD_DEPENDS_python36= python3.6-dev
BUILD_DEPENDS+= $(BUILD_DEPENDS_python36)
MODULE_BUILD_DEPENDS_python36=,python3.6-dev