/[gentoo-x86]/eclass/php-pear-lib-r1.eclass
Gentoo

Diff of /eclass/php-pear-lib-r1.eclass

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

Revision 1.1 Revision 1.23
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-pear-lib-r1.eclass,v 1.1 2005/10/31 14:08:42 chtekk Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/php-pear-lib-r1.eclass,v 1.23 2011/06/28 07:03:59 olemarkus Exp $
4# 4#
5# Author: Luca Longinotti <chtekk@gentoo.org> 5# Author: Luca Longinotti <chtekk@gentoo.org>
6#
7# Based on Tal Peer's <coredumb@gentoo.org> work on php-pear.eclass.
8#
9# The php-pear-lib eclass provides means for easy installation of PEAR
10# based libraries, such as Creole, Jargon, Phing etc., while retaining
11# the functionality to put the libraries into version-dependant dirs.
12 6
13inherit depend.php 7# @ECLASS: php-pear-lib-r1.eclass
8# @MAINTAINER:
9# Gentoo PHP team <php-bugs@gentoo.org>
10# @BLURB: Provides means for an easy installation of PEAR-based libraries.
11# @DESCRIPTION:
12# This class provides means for an easy installation of PEAR-based libraries,
13# such as Creole, Jargon, Phing etc., while retaining the functionality to put
14# the libraries into version-dependant directories.
14 15
15EXPORT_FUNCTIONS src_install 16inherit depend.php multilib
16 17
17# Set this is the the package name on PEAR is different than the one in 18EXPORT_FUNCTIONS pkg_setup src_install
18# portage (generally shouldn't be the case).
19 19
20# We must depend on the base package as we need it to let 20DEPEND="dev-lang/php
21# PEAR work, as well as PEAR itself. 21 >=dev-php/pear-1.9.0"
22DEPEND="${DEPEND} dev-lang/php >=dev-php/PEAR-PEAR-1.3.6"
23RDEPEND="${RDEPEND} ${DEPEND}" 22RDEPEND="${DEPEND}"
24 23
24if [[ -n $PHP_PEAR_CHANNEL ]] ; then
25 PHP_PEAR_PV=${PV/_rc/RC}
26 [[ -z ${PHP_PEAR_PN} ]] && die "Missing PHP_PEAR_PN. Please notify the maintainer"
27 PHP_PEAR_P=${PHP_PEAR_PN}-${PHP_PEAR_PV}
28
29 S=${WORKDIR}/${PHP_PEAR_P}
30
31 SRC_URI="http://${PHP_PEAR_URI}/get/${PHP_PEAR_P}.tgz"
32fi
33
34
35# @FUNCTION: php-pear-lib-r1_pkg_setup
36# @DESCRIPTION
37# Adds required PEAR channel if necessary
38php-pear-lib-r1_pkg_setup() {
39 if [[ -n $PHP_PEAR_CHANNEL ]] ; then
40 if [[ -f $PHP_PEAR_CHANNEL ]]; then
41 pear channel-add $PHP_PEAR_CHANNEL
42 else
43 pear channel-discover $PHP_PEAR_CHANNEL
44 pear channel-update $PHP_PEAR_CHANNEL
45 fi
46 fi
47}
48
49
50# @FUNCTION: php-pear-lib-r1_src_install
51# @DESCRIPTION:
52# Takes care of standard install for PEAR-based libraries.
25php-pear-lib-r1_src_install() { 53php-pear-lib-r1_src_install() {
26 has_php 54 has_php
27 55
28 # SNMP support 56 # SNMP support
29 addpredict /usr/share/snmp/mibs/.index 57 addpredict /usr/share/snmp/mibs/.index
30 addpredict /var/lib/net-snmp/ 58 addpredict /var/lib/net-snmp/
59 addpredict /session_mm_cli0.sem
60
61 PHP_BIN="/usr/bin/php"
31 62
32 cd "${S}" 63 cd "${S}"
33 mv "${WORKDIR}/package.xml" "${S}"
34 pear install --nodeps --installroot="${D}" "${S}/package.xml" || die "Unable to install PEAR package"
35 64
65 if [[ -f "${WORKDIR}"/package2.xml ]] ; then
66 mv -f "${WORKDIR}/package2.xml" "${S}"
67 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
68 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
69 install --force --loose --nodeps --offline --packagingroot="${D}" \
70 "${S}/package2.xml" || die "Unable to install PEAR package"
71 else
72 mv -f "${WORKDIR}/package.xml" "${S}"
73 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
74 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
75 install --force --loose --nodeps --offline --packagingroot="${D}" \
76 "${S}/package.xml" || die "Unable to install PEAR package"
77 fi
78
79 rm -Rf "${D}/usr/share/php/.channels" \
80 "${D}/usr/share/php/.depdblock" \
81 "${D}/usr/share/php/.depdb" \
36 rm -rf "${D}/usr/share/php/.filemap" \ 82 "${D}/usr/share/php/.filemap" \
37 "${D}/usr/share/php/.lock" \ 83 "${D}/usr/share/php/.lock" \
38 "${D}/usr/share/php/.registry" 84 "${D}/usr/share/php/.registry"
39 85
40 # install to the correct phpX folder, if not specified 86 # install to the correct phpX folder, if not specified
41 # /usr/share/php will be kept, also sedding to sobstitute 87 # /usr/share/php will be kept, also sedding to substitute
42 # the path, many files can specify it wrongly 88 # the path, many files can specify it wrongly
43 if [ -n "${PHP_SHARED_CAT}" ] && [ "${PHP_SHARED_CAT}" != "php" ] ; then 89 if [[ -n "${PHP_SHARED_CAT}" ]] && [[ "${PHP_SHARED_CAT}" != "php" ]] ; then
44 mv -f "${D}/usr/share/php" "${D}/usr/share/${PHP_SHARED_CAT}" || die "Unable to move files" 90 mv -f "${D}/usr/share/php" "${D}/usr/share/${PHP_SHARED_CAT}" || die "Unable to move files"
45 find "${D}/" -type f -exec sed -e "s|/usr/share/php|/usr/share/${PHP_SHARED_CAT}|g" -i {} \; || die "Unable to change PHP path" 91 find "${D}/" -type f -exec sed -e "s|/usr/share/php|/usr/share/${PHP_SHARED_CAT}|g" -i {} \; \
92 || die "Unable to change PHP path"
46 einfo 93 einfo
47 einfo "Installing to /usr/share/${PHP_SHARED_CAT} ..." 94 einfo "Installing to /usr/share/${PHP_SHARED_CAT} ..."
48 einfo 95 einfo
49 else 96 else
50 einfo 97 einfo

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.23

  ViewVC Help
Powered by ViewVC 1.1.20