From 6a7f2fa6c72867cf5a751db0c33a7fbc77b0eaa1 Mon Sep 17 00:00:00 2001 From: jdolecek Date: Sun, 31 Oct 2004 19:30:29 +0000 Subject: new PHP extension module framework, which makes it possible to build individual PHP extension packages with either PHP 4.x or PHP 5.x convert existing php4-* packages to this framework and import as php-* --- lang/php/ext.mk | 13 +++++++++ lang/php/phpversion.mk | 71 ++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 84 insertions(+) create mode 100644 lang/php/ext.mk create mode 100644 lang/php/phpversion.mk (limited to 'lang') diff --git a/lang/php/ext.mk b/lang/php/ext.mk new file mode 100644 index 00000000000..d9883819eba --- /dev/null +++ b/lang/php/ext.mk @@ -0,0 +1,13 @@ +# $NetBSD: ext.mk,v 1.1.1.1 2004/10/31 19:30:30 jdolecek Exp $ +# PHP wrapper, for module builds + +.if !defined(PHPEXT_MK) +PHPEXT_MK= defined + +.include "../../lang/php/phpversion.mk" + +.if (defined(USE_BUILDLINK3) && empty(USE_BUILDLINK3:M[nN][oO])) +. include "${PHPPKGSRCDIR}/Makefile.module" +.endif + +.endif # PHPEXT_MK diff --git a/lang/php/phpversion.mk b/lang/php/phpversion.mk new file mode 100644 index 00000000000..9ff4f5c3d22 --- /dev/null +++ b/lang/php/phpversion.mk @@ -0,0 +1,71 @@ +# $NetBSD: phpversion.mk,v 1.1.1.1 2004/10/31 19:30:30 jdolecek Exp $ +# PHP wrapper, for module builds + +.if !defined(PHPVERSION_MK) +PHPVERSION_MK= defined + +.include "../../mk/bsd.prefs.mk" + +PHP_VERSION_DEFAULT?= 4 +PHP_VERSIONS_ACCEPTED?= 4 5 + +# transform the list into individual variables +.for pv in ${PHP_VERSIONS_ACCEPTED} +_PHP_VERSION_${pv}_OK= yes +.endfor + +# check what is installed +.if exists(${LOCALBASE}/lib/php/20020429) +_PHP_VERSION_4_INSTALLED= yes +.endif +.if exists(${LOCALBASE}/lib/php/20040412) +_PHP_VERSION_5_INSTALLED= yes +.endif + +# if a version is explicitely required, take it +.if defined(PHP_VERSION_REQD) +_PHP_VERSION= ${PHP_VERSION_REQD} +.endif +# if the default is already installed, it is first choice +.if !defined(_PHP_VERSION) +.if defined(_PHP_VERSION_${PHP_VERSION_DEFAULT}_OK) +.if defined(_PHP_VERSION_${PHP_VERSION_DEFAULT}_INSTALLED) +_PHP_VERSION= ${PHP_VERSION_DEFAULT} +.endif +.endif +.endif +# prefer an already installed version, in order of "accepted" +.if !defined(_PHP_VERSION) +.for pv in ${PHP_VERSIONS_ACCEPTED} +.if defined(_PHP_VERSION_${pv}_INSTALLED) +_PHP_VERSION?= ${pv} +.else +# keep information as last resort - see below +_PHP_VERSION_FIRSTACCEPTED?= ${pv} +.endif +.endfor +.endif +# if the default is OK for the addon pkg, take this +.if !defined(_PHP_VERSION) +.if defined(_PHP_VERSION_${PHP_VERSION_DEFAULT}_OK) +_PHP_VERSION= ${PHP_VERSION_DEFAULT} +.endif +.endif +# take the first one accepted by the package +.if !defined(_PHP_VERSION) +_PHP_VERSION= ${_PHP_VERSION_FIRSTACCEPTED} +.endif + +# +# set variables for the version we decided to use: +# +.if ${_PHP_VERSION} == "4" +PHPPKGSRCDIR= ../../www/php4 +.elif ${_PHP_VERSION} == "5" +PHPPKGSRCDIR= ../../lang/php5 +.else +# force an error +PKG_SKIP_REASON+= "PHP${_PHP_VERSION} is not a valid package" +.endif + +.endif # PHPVERSION_MK -- cgit v1.2.3