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

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

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

Revision 1.2 Revision 1.32
1# Copyright 1999-2005 Gentoo Foundation 1# Copyright 1999-2013 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-r1.eclass,v 1.2 2005/09/08 10:49:51 sebastian Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/php-pear-r1.eclass,v 1.32 2013/11/25 23:22:57 mabi Exp $
4# 4
5# @ECLASS: php-pear-r1.eclass
6# @MAINTAINER:
7# Gentoo PHP Team <php-bugs@gentoo.org>
8# @AUTHOR:
5# Author: Tal Peer <coredumb@gentoo.org> 9# Author: Tal Peer <coredumb@gentoo.org>
6# 10# Author: Luca Longinotti <chtekk@gentoo.org>
11# @BLURB: Provides means for an easy installation of PEAR packages.
12# @DESCRIPTION:
7# The php-pear eclass provides means for easy installation of PEAR 13# This eclass provides means for an easy installation of PEAR packages.
8# packages, see http://pear.php.net 14# For more information on PEAR, see http://pear.php.net/
15# Note that this eclass doesn't handle dependencies of PEAR packages
16# on purpose; please use (R)DEPEND to define them correctly!
9 17
10# Note that this eclass doesn't handle PEAR packages' dependencies on 18inherit multilib
11# purpose, please use (R)DEPEND to define them.
12 19
13EXPORT_FUNCTIONS src_install 20EXPORT_FUNCTIONS pkg_setup src_install
14 21
15# Set this is the the package name on PEAR is different than the one in 22DEPEND="dev-lang/php
16# portage (generally shouldn't be the case). 23 >=dev-php/pear-1.8.1"
17[ -z "${PHP_PEAR_PKG_NAME}" ] && PHP_PEAR_PKG_NAME=${PN/PEAR-/} 24RDEPEND="${DEPEND}"
18 25
19# We must depend on the base package as we need it to do 26# @ECLASS-VARIABLE: PHP_PEAR_PKG_NAME
20# install tasks (it provides the pear binary). 27# @DESCRIPTION:
21DEPEND="${DEPEND} dev-lang/php" 28# Set this if the the PEAR package name differs from ${PN/PEAR-/}
22RDEPEND="${RDEPEND} ${DEPEND}" 29# (generally shouldn't be the case).
30[[ -z "${PHP_PEAR_PKG_NAME}" ]] && PHP_PEAR_PKG_NAME="${PN/PEAR-/}"
23 31
24fix_PEAR_PV() { 32fix_PEAR_PV() {
25 tmp=${PV} 33 tmp="${PV}"
26 tmp=${tmp/_/} 34 tmp="${tmp/_/}"
27 tmp=${tmp/rc/RC} 35 tmp="${tmp/rc/RC}"
28 tmp=${tmp/beta/b} 36 tmp="${tmp/beta/b}"
37 tmp="${tmp/alpha/a}"
29 PEAR_PV=${tmp} 38 PEAR_PV="${tmp}"
30} 39}
31 40
32PEAR_PV="" 41# @ECLASS-VARIABLE: PEAR_PV
33fix_PEAR_PV 42# @DESCRIPTION:
34PEAR_PN=${PHP_PEAR_PKG_NAME}-${PEAR_PV} 43# Set in ebuild if the eclass ${PV} mangling breaks SRC_URI for alpha/beta/rc versions
44[[ -z "${PEAR_PV}" ]] && fix_PEAR_PV
35 45
46PEAR_PN="${PHP_PEAR_PKG_NAME}-${PEAR_PV}"
47: ${PHP_PEAR_URI:=pear.php.net}
48: ${PHP_PEAR_CHANNEL:=${FILESDIR}/channel.xml}
49
36[ -z "${SRC_URI}" ] && SRC_URI="http://pear.php.net/get/${PEAR_PN}.tgz" 50[[ -z "${SRC_URI}" ]] && SRC_URI="http://${PHP_PEAR_URI}/get/${PEAR_PN}.tgz"
37[ -z "${HOMEPAGE}" ] && HOMEPAGE="http://pear.php.net/${PHP_PEAR_PKG_NAME}" 51[[ -z "${HOMEPAGE}" ]] && HOMEPAGE="http://${PHP_PEAR_URI}/${PHP_PEAR_PKG_NAME}"
52
38S="${WORKDIR}/${PEAR_PN}" 53S="${WORKDIR}/${PEAR_PN}"
39 54
55# @FUNCTION: php-pear-lib-r1_pkg_setup
56# @DESCRIPTION:
57# Adds required PEAR channel if necessary
58php-pear-r1_pkg_setup() {
59 if [[ -f $PHP_PEAR_CHANNEL ]]; then
60 pear channel-add $PHP_PEAR_CHANNEL || einfo "Ignore any errors about existing channels"
61 fi
62}
63
64# @FUNCTION: php-pear-r1_src_install
65# @DESCRIPTION:
66# Takes care of standard install for PEAR packages.
40php-pear_src_install-r1() { 67php-pear-r1_src_install() {
41 # SNMP is nuts sometimes 68 # SNMP support
42 addpredict /usr/share/snmp/mibs/.index 69 addpredict /usr/share/snmp/mibs/.index
43 addpredict /var/lib/net-snmp/ 70 addpredict /var/lib/net-snmp/
71 addpredict /var/lib/net-snmp/mib_indexes
72 addpredict /session_mm_cli0.sem
44 73
74 PHP_BIN="/usr/bin/php"
75
45 cd ${S} 76 cd "${S}"
77
78 if [[ -f "${WORKDIR}"/package2.xml ]] ; then
79 mv -f "${WORKDIR}/package2.xml" "${S}"
80 if has_version '>=dev-php/PEAR-PEAR-1.7.0' ; then
81 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
82 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
83 install --force --loose --nodeps --offline --packagingroot="${D}" \
84 "${S}/package2.xml" || die "Unable to install PEAR package"
85 else
86 peardev -d php_bin="${PHP_BIN}" install --force --loose --nodeps --offline --packagingroot="${D}" \
87 "${S}/package2.xml" || die "Unable to install PEAR package"
88 fi
89 else
46 mv ${WORKDIR}/package.xml ${S} 90 mv -f "${WORKDIR}/package.xml" "${S}"
47 pear install --nodeps --installroot=${D} ${S}/package.xml || die "Unable to install PEAR package" 91 if has_version '>=dev-php/PEAR-PEAR-1.7.0' ; then
92 local WWW_DIR="/usr/share/webapps/${PN}/${PVR}/htdocs"
93 peardev -d php_bin="${PHP_BIN}" -d www_dir="${WWW_DIR}" \
94 install --force --loose --nodeps --offline --packagingroot="${D}" \
95 "${S}/package.xml" || die "Unable to install PEAR package"
96 else
97 peardev -d php_bin="${PHP_BIN}" install --force --loose --nodeps --offline --packagingroot="${D}" \
98 "${S}/package.xml" || die "Unable to install PEAR package"
99 fi
100 fi
101
102 rm -Rf "${D}/usr/share/php/.channels" \
103 "${D}/usr/share/php/.depdblock" \
104 "${D}/usr/share/php/.depdb" \
105 "${D}/usr/share/php/.filemap" \
106 "${D}/usr/share/php/.lock" \
107 "${D}/usr/share/php/.registry"
48} 108}

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

  ViewVC Help
Powered by ViewVC 1.1.20