blob: cd1481e3852845abf4bab9432cb22e05fdffe968 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
|
# Copyright 1999-2003 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/eclass/php-ext-base.eclass,v 1.7 2003/08/18 12:54:30 stuart Exp $
#
# Author: Tal Peer <coredumb@gentoo.org>
# Author: Stuart Herbert <stuart@gentoo.org>
#
# The php-ext-base eclass provides a unified interface for adding standalone
# PHP extensions ('modules') to the php.ini files on your system.
#
# Combined with php-ext-source, we have a standardised solution for supporting
# PHP extensions
ECLASS=php-ext-base
INHERITED="$INHERITED $ECLASS"
EXPORT_FUNCTIONS src_install
# ---begin ebuild configurable settings
# The extension name, this must be set, otherwise we die.
[ -z "$PHP_EXT_NAME" ] && die "No module name specified for the php-ext eclass."
# Wether the extensions is a Zend Engine extension
#(defaults to "no" and if you don't know what is it, you don't need it.)
[ -z "$PHP_EXT_ZENDEXT" ] && PHP_EXT_ZENDEXT="no"
# Wether or not to add a line in the php.ini for the extension
# (defaults to "yes" and shouldn't be changed in most cases)
[ -z "$PHP_EXT_INI" ] && PHP_EXT_INI="yes"
# find out where to install extensions
EXT_DIR="`php-config --extension-dir`"
# ---end ebuild configurable settings
DEPEND="${DEPEND}
virtual/php
=sys-devel/m4-1.4
>=sys-devel/libtool-1.4.3"
php-ext-base_buildinilist () {
# work out the list of .ini files to edit/add to
if [ -z "${PHPSAPILIST}" ]; then
PHPSAPILIST="apache1 apache2 cli"
fi
PHPINIFILELIST=
for x in ${PHPSAPILIST} ; do
if [ -f /etc/php/${x}-php4/php.ini ]; then
PHPINIFILELIST="${PHPINIFILELIST} etc/php/${x}-php4/php.ini"
fi
done
if [ "${PHPINIFILELIST}+" = "+" ] ; then
# backwards support for the old location
if [ -f /etc/php4/php.ini ] ; then
PHPINIFILELIST="etc/php4/php.ini"
else
msg="No PHP ini files found for this extension"
eerror ${msg}
die ${msg}
fi
fi
# einfo "php.ini files found in $PHPINIFILELIST"
}
php-ext-base_src_install() {
if [ "$PHP_EXT_INI" = "yes" ] ; then
php-ext-base_addextension "${PHP_EXT_NAME}.so"
fi
}
php-ext-base_addextension () {
if [ "${PHP_EXT_ZENDEXT}" = "yes" ]; then
ext_type="zend_extension"
ext_file="${EXT_DIR}/$1"
else
# we do *not* add the full path for the extension!
ext_type="extension"
ext_file="$1"
fi
php-ext-base_addtoinifiles "$ext_type" "$ext_file" "Extension added"
}
php-ext-base_setting_is_present () {
grep "^$1=$2" /$3 > /dev/null 2>&1
}
php-ext-base_inifileinimage () {
if [ ! -f $1 ]; then
mkdir -p `dirname $1`
cp /$1 $1
fi
}
# $1 - setting name
# $2 - setting value
# $3 - file to add to
# $4 - sanitised text to output
php-ext-base_addtoinifile () {
if [ "$1" != "extension" ] && [ "$1" != "zend_extension" ]; then
php-ext-base_setting_is_present $1 "" $3 && return
else
php-ext-base_setting_is_present "$1" "$2" "$3" && return
fi
php-ext-base_inifileinimage $3
echo "$1=$2" >> $3
if [ -z "$4" ]; then
einfo "Added '$1=$2' to /$3"
else
einfo "$4 to /$3"
fi
# yes, this is inefficient - but it works every time ;-)
insinto /`dirname $3`
doins $3
}
php-ext-base_addtoinifiles () {
for x in ${PHPINIFILELIST} ; do
php-ext-base_addtoinifile $1 $2 $x "$3"
done
}
# now, we build the INI file list for use in this class
php-ext-base_buildinilist
|