/[gentoo-x86]/eclass/php-ext-base-r1.eclass
Gentoo

Diff of /eclass/php-ext-base-r1.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.2 Revision 1.10
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2007 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/php-ext-base-r1.eclass,v 1.2 2005/09/25 15:21:22 kloeri Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/php-ext-base-r1.eclass,v 1.10 2009/12/30 01:05:42 hoffie Exp $
4# 4#
5# Author: Tal Peer <coredumb@gentoo.org> 5# Author: Tal Peer <coredumb@gentoo.org>
6# Author: Stuart Herbert <stuart@gentoo.org> 6# Author: Stuart Herbert <stuart@gentoo.org>
7# Author: Luca Longinotti <chtekk@gentoo.org>
8# Author: Jakub Moc <jakub@gentoo.org> (documentation)
9
10# @ECLASS: php-ext-base-r1.eclass
11# @MAINTAINER:
12# Gentoo PHP team <php-bugs@gentoo.org>
13# @BLURB: A unified interface for adding standalone PHP extensions.
14# @DESCRIPTION:
15# This eclass provides a unified interface for adding standalone
16# PHP extensions (modules) to the php.ini files on your system.
7# 17#
8# The php-ext-base eclass provides a unified interface for adding standalone
9# PHP extensions ('modules') to the php.ini files on your system.
10#
11# Combined with php-ext-source, we have a standardised solution for supporting 18# Combined with php-ext-source-r1, we have a standardised solution for supporting
12# PHP extensions 19# PHP extensions.
13 20
14inherit depend.php 21inherit depend.php
15 22
16EXPORT_FUNCTIONS src_install 23EXPORT_FUNCTIONS src_install
17 24
18# ---begin ebuild configurable settings 25# @ECLASS-VARIABLE: PHP_EXT_NAME
26# @DESCRIPTION:
27# The extension name. This must be set, otherwise the eclass dies.
28# Only automagically set by php-ext-pecl-r1.eclass, so unless your ebuild
29# inherits that eclass, you must set this manually before inherit.
30[[ -z "${PHP_EXT_NAME}" ]] && die "No module name specified for the php-ext-base-r1 eclass"
19 31
20# The extension name, this must be set, otherwise we die. 32# @ECLASS-VARIABLE: PHP_EXT_INI
21[ -z "${PHP_EXT_NAME}" ] && die "No module name specified for the php-ext eclass." 33# @DESCRIPTION:
34# Controls whether or not to add a line to php.ini for the extension.
35# Defaults to "yes" and should not be changed in most cases.
36[[ -z "${PHP_EXT_INI}" ]] && PHP_EXT_INI="yes"
22 37
38# @ECLASS-VARIABLE: PHP_EXT_ZENDEXT
39# @DESCRIPTION:
23# Wether the extensions is a Zend Engine extension 40# Controls whether the extension is a ZendEngine extension or not.
24#(defaults to "no" and if you don't know what is it, you don't need it.) 41# Defaults to "no" and if you don't know what is it, you don't need it.
25[ -z "${PHP_EXT_ZENDEXT}" ] && PHP_EXT_ZENDEXT="no" 42[[ -z "${PHP_EXT_ZENDEXT}" ]] && PHP_EXT_ZENDEXT="no"
26 43
27# Wether or not to add a line in the php.ini for the extension
28# (defaults to "yes" and shouldn't be changed in most cases)
29[ -z "${PHP_EXT_INI}" ] && PHP_EXT_INI="yes"
30
31# find out where to install extensions
32EXT_DIR="`${PHPCONFIG} --extension-dir 2>/dev/null`"
33
34# ---end ebuild configurable settings
35
36DEPEND="${DEPEND}
37 >=sys-devel/m4-1.4.3
38 >=sys-devel/libtool-1.5.18
39 >=sys-devel/automake-1.9.6
40 sys-devel/automake-wrapper
41 >=sys-devel/autoconf-2.59
42 sys-devel/autoconf-wrapper"
43 44
44php-ext-base-r1_buildinilist() { 45php-ext-base-r1_buildinilist() {
45 # work out the list of .ini files to edit/add to 46 # Work out the list of <ext>.ini files to edit/add to
46 if [ -z "${PHPSAPILIST}" ]; then 47 if [[ -z "${PHPSAPILIST}" ]] ; then
47 PHPSAPILIST="apache1 apache2 cli cgi" 48 PHPSAPILIST="apache2 cli cgi"
48 fi 49 fi
49 50
50 PHPINIFILELIST= 51 PHPINIFILELIST=""
51 52
52 for x in ${PHPSAPILIST} ; do 53 for x in ${PHPSAPILIST} ; do
53 if [ -f /etc/php/${x}-php${PHP_VERSION}/php.ini ]; then 54 if [[ -f "/etc/php/${x}-php${PHP_VERSION}/php.ini" ]] ; then
54 PHPINIFILELIST="${PHPINIFILELIST} etc/php/${x}-php${PHP_VERSION}/ext/${PHP_EXT_NAME}.ini" 55 PHPINIFILELIST="${PHPINIFILELIST} etc/php/${x}-php${PHP_VERSION}/ext/${PHP_EXT_NAME}.ini"
55 fi 56 fi
56 done 57 done
57} 58}
58 59
60# @FUNCTION: php-ext-base-r1_src_install
61# @DESCRIPTION:
62# Takes care of standard install for PHP extensions (modules).
59php-ext-base-r1_src_install() { 63php-ext-base-r1_src_install() {
64 # Pull in the PHP settings
60 has_php 65 has_php
61 addpredict /usr/share/snmp/mibs/.index 66 addpredict /usr/share/snmp/mibs/.index
67
68 # Build the list of <ext>.ini files to edit/add to
62 php-ext-base-r1_buildinilist 69 php-ext-base-r1_buildinilist
70
71 # Add the needed lines to the <ext>.ini files
63 if [ "${PHP_EXT_INI}" = "yes" ] ; then 72 if [[ "${PHP_EXT_INI}" = "yes" ]] ; then
64 php-ext-base-r1_addextension "${PHP_EXT_NAME}.so" 73 php-ext-base-r1_addextension "${PHP_EXT_NAME}.so"
65 fi 74 fi
75
76 # Symlink the <ext>.ini files from ext/ to ext-active/
77 for inifile in ${PHPINIFILELIST} ; do
78 inidir="${inifile/${PHP_EXT_NAME}.ini/}"
79 inidir="${inidir/ext/ext-active}"
80 dodir "/${inidir}"
81 dosym "/${inifile}" "/${inifile/ext/ext-active}"
82 done
83
66 # add support for installing php files into a version dependant directory 84 # Add support for installing PHP files into a version dependant directory
67 PHP_EXT_SHARED_DIR="/usr/share/${PHP_SHARED_CAT}/${PHP_EXT_NAME}" 85 PHP_EXT_SHARED_DIR="/usr/share/${PHP_SHARED_CAT}/${PHP_EXT_NAME}"
68} 86}
69 87
70php-ext-base-r1_addextension() { 88php-ext-base-r1_addextension() {
71 if [ "${PHP_EXT_ZENDEXT}" = "yes" ] ; then 89 if [[ "${PHP_EXT_ZENDEXT}" = "yes" ]] ; then
90 # We need the full path for ZendEngine extensions
91 # and we need to check for debugging enabled!
72 if has_zts ; then 92 if has_zts ; then
93 if has_debug ; then
94 ext_type="zend_extension_debug_ts"
95 else
73 ext_type="zend_extension_ts" 96 ext_type="zend_extension_ts"
97 fi
74 ext_file="${EXT_DIR}/$1" 98 ext_file="${EXT_DIR}/$1"
75 else 99 else
100 if has_debug ; then
101 ext_type="zend_extension_debug"
102 else
76 ext_type="zend_extension" 103 ext_type="zend_extension"
104 fi
77 ext_file="${EXT_DIR}/$1" 105 ext_file="${EXT_DIR}/$1"
78 fi 106 fi
107
108 # php-5.3 unifies zend_extension loading and just requires the
109 # zend_extension keyword with no suffix
110 # TODO: drop previous code and this check once <php-5.3 support is
111 # discontinued
112 if has_version '>=dev-lang/php-5.3' ; then
113 ext_type="zend_extension"
114 fi
79 else 115 else
80 # we do *not* add the full path for the extension! 116 # We don't need the full path for normal extensions!
81 ext_type="extension" 117 ext_type="extension"
82 ext_file="$1" 118 ext_file="$1"
83 fi 119 fi
84 120
85 php-ext-base-r1_addtoinifiles "${ext_type}" "${ext_file}" "Extension added" 121 php-ext-base-r1_addtoinifiles "${ext_type}" "${ext_file}" "Extension added"
86} 122}
87 123
88# $1 - setting name 124# $1 - Setting name
89# $2 - setting value 125# $2 - Setting value
90# $3 - file to add to 126# $3 - File to add to
91# $4 - sanitised text to output 127# $4 - Sanitized text to output
92
93php-ext-base-r1_addtoinifile() { 128php-ext-base-r1_addtoinifile() {
94 if [[ ! -d `dirname $3` ]]; then 129 if [[ ! -d $(dirname $3) ]] ; then
95 mkdir -p `dirname $3` 130 mkdir -p $(dirname $3)
96 fi 131 fi
97 132
98 # are we adding the name of a section? 133 # Are we adding the name of a section?
99 if [[ ${1:0:1} == "[" ]] ; then 134 if [[ ${1:0:1} == "[" ]] ; then
100 echo "$1" >> $3 135 echo "$1" >> "$3"
101 my_added="$1" 136 my_added="$1"
102 else 137 else
103 echo "$1=$2" >> $3 138 echo "$1=$2" >> "$3"
104 my_added="$1=$2" 139 my_added="$1=$2"
105 fi 140 fi
106 141
107 if [ -z "$4" ]; then 142 if [[ -z "$4" ]] ; then
108 einfo "Added '$my_added' to /$3" 143 einfo "Added '$my_added' to /$3"
109 else 144 else
110 einfo "$4 to /$3" 145 einfo "$4 to /$3"
111 fi 146 fi
112 147
113 # yes, this is inefficient - but it works every time ;-)
114
115 insinto /`dirname $3` 148 insinto /$(dirname $3)
116 doins $3 149 doins "$3"
117} 150}
118 151
152# @FUNCTION: php-ext-base-r1_addtoinifiles
153# @USAGE: <setting name> <setting value> [message to output]; or just [section name]
154# @DESCRIPTION:
155# Add value settings to php.ini file installed by the extension (module).
156# You can also add a [section], see examples below.
157#
158# @CODE
159# Add some settings for the extension:
160#
161# php-ext-base-r1_addtoinifiles "zend_optimizer.optimization_level" "15"
162# php-ext-base-r1_addtoinifiles "zend_optimizer.enable_loader" "0"
163# php-ext-base-r1_addtoinifiles "zend_optimizer.disable_licensing" "0"
164#
165# Adding values to a section in php.ini file installed by the extension:
166#
167# php-ext-base-r1_addtoinifiles "[Debugger]"
168# php-ext-base-r1_addtoinifiles "debugger.enabled" "on"
169# php-ext-base-r1_addtoinifiles "debugger.profiler_enabled" "on"
170# @CODE
119php-ext-base-r1_addtoinifiles() { 171php-ext-base-r1_addtoinifiles() {
120 for x in ${PHPINIFILELIST} ; do 172 for x in ${PHPINIFILELIST} ; do
121 php-ext-base-r1_addtoinifile "$1" "$2" "$x" "$3" 173 php-ext-base-r1_addtoinifile "$1" "$2" "$x" "$3"
122 done 174 done
123} 175}

Legend:
Removed from v.1.2  
changed lines
  Added in v.1.10

  ViewVC Help
Powered by ViewVC 1.1.20