/[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.21
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.21 2011/03/14 08:00:10 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
24
25if [[ -n $PHP_PEAR_CHANNEL ]] ; then
26 PHP_PEAR_PV=${PV/_rc/RC}
27 [[ -z ${PHP_PEAR_PN} ]] && die "Missing PHP_PEAR_PN. Please notify the maintainer"
28 PHP_PEAR_P=${PHP_PEAR_PN}-${PHP_PEAR_PV}
29
30 S=${WORKDIR}/${PHP_PEAR_P}
31
32 SRC_URI="http://${PHP_PEAR_CHANNEL}/get/${PHP_PEAR_P}.tgz"
33fi
34
35
36# @FUNCTION: php-pear-lib-r1_pkg_setup
37# @DESCRIPTION
38# Adds required PEAR channel if necessary
39php-pear-lib-r1_pkg_setup() {
40 if [[ -n $PHP_PEAR_CHANNEL ]] ; then
41 pear channel-discover $PHP_PEAR_CHANNEL
42 pear channel-update $PHP_PEAR_CHANNEL
43 fi
44}
45
46
47# @FUNCTION: php-pear-lib-r1_src_install
48# @DESCRIPTION:
49# Takes care of standard install for PEAR-based libraries.
25php-pear-lib-r1_src_install() { 50php-pear-lib-r1_src_install() {
26 has_php 51 has_php
27 52
28 # SNMP support 53 # SNMP support
29 addpredict /usr/share/snmp/mibs/.index 54 addpredict /usr/share/snmp/mibs/.index
30 addpredict /var/lib/net-snmp/ 55 addpredict /var/lib/net-snmp/
56 addpredict /session_mm_cli0.sem
57
58 PHP_BIN="/usr/bin/php"
31 59
32 cd "${S}" 60 cd "${S}"
33 mv "${WORKDIR}/package.xml" "${S}"
34 pear install --nodeps --installroot="${D}" "${S}/package.xml" || die "Unable to install PEAR package"
35 61
62 if [[ -f "${WORKDIR}"/package2.xml ]] ; then
63 mv -f "${WORKDIR}/package2.xml" "${S}"
64 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
65 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
66 install --force --loose --nodeps --offline --packagingroot="${D}" \
67 "${S}/package2.xml" || die "Unable to install PEAR package"
68 else
69 mv -f "${WORKDIR}/package.xml" "${S}"
70 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
71 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
72 install --force --loose --nodeps --offline --packagingroot="${D}" \
73 "${S}/package.xml" || die "Unable to install PEAR package"
74 fi
75
76 rm -Rf "${D}/usr/share/php/.channels" \
77 "${D}/usr/share/php/.depdblock" \
78 "${D}/usr/share/php/.depdb" \
36 rm -rf "${D}/usr/share/php/.filemap" \ 79 "${D}/usr/share/php/.filemap" \
37 "${D}/usr/share/php/.lock" \ 80 "${D}/usr/share/php/.lock" \
38 "${D}/usr/share/php/.registry" 81 "${D}/usr/share/php/.registry"
39 82
40 # install to the correct phpX folder, if not specified 83 # install to the correct phpX folder, if not specified
41 # /usr/share/php will be kept, also sedding to sobstitute 84 # /usr/share/php will be kept, also sedding to substitute
42 # the path, many files can specify it wrongly 85 # the path, many files can specify it wrongly
43 if [ -n "${PHP_SHARED_CAT}" ] && [ "${PHP_SHARED_CAT}" != "php" ] ; then 86 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" 87 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" 88 find "${D}/" -type f -exec sed -e "s|/usr/share/php|/usr/share/${PHP_SHARED_CAT}|g" -i {} \; \
89 || die "Unable to change PHP path"
46 einfo 90 einfo
47 einfo "Installing to /usr/share/${PHP_SHARED_CAT} ..." 91 einfo "Installing to /usr/share/${PHP_SHARED_CAT} ..."
48 einfo 92 einfo
49 else 93 else
50 einfo 94 einfo

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

  ViewVC Help
Powered by ViewVC 1.1.20