aboutsummaryrefslogtreecommitdiff
path: root/eclass
diff options
context:
space:
mode:
authorPetteri Räty <betelgeuse@gentoo.org>2005-03-15 17:03:43 +0000
committerPetteri Räty <betelgeuse@gentoo.org>2005-03-15 17:03:43 +0000
commit35991a062613cd7dd8cddc437d23bb715d633778 (patch)
tree6f4a7ad3424d86a0782e5c2468e5c4a6015aeafb /eclass
parentCorrected indentation problems in the sac ebuild (diff)
downloadjava-35991a062613cd7dd8cddc437d23bb715d633778.tar.gz
java-35991a062613cd7dd8cddc437d23bb715d633778.tar.bz2
java-35991a062613cd7dd8cddc437d23bb715d633778.zip
Added experimental version for java-pkg.eclass
svn path=/gentoo-java-experimental/; revision=99
Diffstat (limited to 'eclass')
-rw-r--r--eclass/java-pkg.eclass354
1 files changed, 354 insertions, 0 deletions
diff --git a/eclass/java-pkg.eclass b/eclass/java-pkg.eclass
new file mode 100644
index 00000000..8edb6448
--- /dev/null
+++ b/eclass/java-pkg.eclass
@@ -0,0 +1,354 @@
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/eclass/java-pkg.eclass,v 1.21 2004/11/29 21:46:16 axxo Exp $
+
+ECLASS=java-pkg
+INHERITED="${INHERITED} ${ECLASS}"
+IUSE="${IUSE}"
+SLOT="${SLOT}"
+
+pkglistpath="${T}/java-pkg-list"
+
+java-pkg_doclass()
+{
+ debug-print-function ${FUNCNAME} $*
+ java-pkg_dojar $*
+}
+
+java-pkg_do_init_()
+{
+ debug-print-function ${FUNCNAME} $*
+
+ if [ -z "${JARDESTTREE}" ] ; then
+ JARDESTTREE="lib"
+ SODESTTREE="lib"
+ fi
+
+ # Set install paths
+ sharepath="${DESTTREE}/share"
+ if [ "$SLOT" == "0" ] ; then
+ pkg_name="${PN}"
+ else
+ pkg_name="${PN}-${SLOT}"
+ fi
+
+ shareroot="${sharepath}/${pkg_name}"
+
+ if [ -z "${jardest}" ] ; then
+ jardest="${shareroot}/${JARDESTTREE}"
+ fi
+
+ if [ -z "${sodest}" ] ; then
+ sodest="/opt/${pkg_name}/${SODESTTREE}"
+ fi
+
+ package_env="${D}${shareroot}/package.env"
+
+ debug-print "JARDESTTREE=${JARDESTTREE}"
+ debug-print "SODESTTREE=${SODESTTREE}"
+ debug-print "sharepath=${sharepath}"
+ debug-print "shareroot=${shareroot}"
+ debug-print "jardest=${jardest}"
+ debug-print "sodest=${sodest}"
+ debug-print "package_env=${package_env}"
+}
+
+java-pkg_do_write_()
+{
+ # Create directory for package.env
+ if [ ! -d "${D}${shareroot}" ] ; then
+ install -d "${D}${shareroot}"
+ fi
+
+ # Create package.env
+ echo "DESCRIPTION=${DESCRIPTION}" > "${package_env}"
+ if [ -n "${cp_pkg}" ]; then
+ echo "CLASSPATH=${cp_prepend}:${cp_pkg}:${cp_append}" >> "${package_env}"
+ fi
+ if [ -n "${lp_pkg}" ]; then
+ echo "LIBRARY_PATH=${lp_prepend}:${lp_pkg}:${lp_append}" >> "${package_env}"
+ fi
+ if [ -f ${pkglistpath} ] ; then
+ pkgs=$(cat ${pkglistpath} | tr '\n' ':')
+ echo "DEPEND=${pkgs}" >> "${package_env}"
+ fi
+
+ # Strip unnecessary leading and trailing colons
+ sed -e "s/=:/=/" -e "s/:$//" -i "${package_env}"
+}
+
+java-pkg_do_getsrc_()
+{
+ # Check for symlink
+ if [ -L "${i}" ] ; then
+ cp "${i}" "${T}"
+ echo "${T}"/`/usr/bin/basename "${i}"`
+
+ # Check for directory
+ elif [ -d "${i}" ] ; then
+ echo "java-pkg: warning, skipping directory ${i}"
+ continue
+ else
+ echo "${i}"
+ fi
+}
+
+
+java-pkg_doso()
+{
+ debug-print-function ${FUNCNAME} $*
+ [ -z "$1" ]
+
+ java-pkg_do_init_
+
+ # Check for arguments
+ if [ -z "$*" ] ; then
+ die "at least one argument needed"
+ fi
+
+ # Make sure directory is created
+ if [ ! -d "${D}${sodest}" ] ; then
+ install -d "${D}${sodest}"
+ fi
+
+ for i in $* ; do
+ mysrc=$(java-pkg_do_getsrc_)
+
+ # Install files
+ install -m 0755 "${mysrc}" "${D}${sodest}" || die "${mysrc} not found"
+ done
+ lp_pkg="${sodest}"
+
+ java-pkg_do_write_
+}
+
+
+java-pkg_dojar()
+{
+ debug-print-function ${FUNCNAME} $*
+ [ -z "$1" ]
+
+ java-pkg_do_init_
+
+ if [ -n "${DEP_PREPEND}" ] ; then
+ for i in ${DEP_PREPEND}
+ do
+ if [ -f "${sharepath}/${i}/package.env" ] ; then
+ debug-print "${i} path: ${sharepath}/${i}"
+ if [ -z "${cp_prepend}" ] ; then
+ cp_prepend=`grep "CLASSPATH=" "${sharepath}/${i}/package.env" | sed "s/CLASSPATH=//"`
+ else
+ cp_prepend="${cp_prepend}:"`grep "CLASSPATH=" "${sharepath}/${i}/package.env" | sed "s/CLASSPATH=//"`
+ fi
+ else
+ debug-print "Error: Package ${i} not found."
+ debug-print "${i} path: ${sharepath}/${i}"
+ die "Error in DEP_PREPEND."
+ fi
+ debug-print "cp_prepend=${cp_prepend}"
+
+ done
+ fi
+
+ if [ -n "${DEP_APPEND}" ] ; then
+ for i in ${DEP_APPEND}
+ do
+ if [ -f "${sharepath}/${i}/package.env" ] ; then
+ debug-print "${i} path: ${sharepath}/${i}"
+ if [ -z "${cp_append}" ] ; then
+ cp_append=`grep "CLASSPATH=" "${sharepath}/${i}/package.env" | sed "s/CLASSPATH=//"`
+ else
+ cp_append="${cp_append}:"`grep "CLASSPATH=" "${sharepath}/${i}/package.env" | sed "s/CLASSPATH=//"`
+ fi
+ else
+ debug-print "Error: Package ${i} not found."
+ debug-print "${i} path: ${sharepath}/${i}"
+ die "Error in DEP_APPEND."
+ fi
+ debug-print "cp_append=${cp_append}"
+ done
+ fi
+
+ # Check for arguments
+ if [ -z "$*" ] ; then
+ die "at least one argument needed"
+ fi
+
+ # Make sure directory is created
+ if [ ! -d "${D}${jardest}" ] ; then
+ install -d "${D}${jardest}"
+ fi
+
+ for i in $* ; do
+ mysrc=$(java-pkg_do_getsrc_)
+
+ # Install files
+ install -m 0644 "${mysrc}" "${D}${jardest}" || die "${mysrc} not found"
+
+ # Build CLASSPATH
+ if [ -z "${cp_pkg}" ] ; then
+ cp_pkg="${jardest}"/`/usr/bin/basename "${i}"`
+ else
+ cp_pkg="${cp_pkg}:${jardest}/"`/usr/bin/basename "${i}"`
+ fi
+ done
+
+ java-pkg_do_write_
+}
+
+java-pkg_dowar()
+{
+ debug-print-function ${FUNCNAME} $*
+ [ -z "$1" ]
+
+ # Check for arguments
+ if [ -z "$*" ] ; then
+ die "at least one argument needed"
+ fi
+
+ if [ -z "${WARDESTTREE}" ] ; then
+ WARDESTTREE="webapps"
+ fi
+
+ sharepath="${DESTTREE}/share"
+ shareroot="${sharepath}/${PN}"
+ wardest="${shareroot}/${WARDESTTREE}"
+
+ debug-print "WARDESTTREE=${WARDESTTREE}"
+ debug-print "sharepath=${sharepath}"
+ debug-print "shareroot=${shareroot}"
+ debug-print "wardest=${wardest}"
+
+ # Patch from Joerg Schaible <joerg.schaible@gmx.de>
+ # Make sure directory is created
+ if [ ! -d "${D}${wardest}" ] ; then
+ install -d "${D}${wardest}"
+ fi
+
+ for i in $* ; do
+ # Check for symlink
+ if [ -L "${i}" ] ; then
+ cp "${i}" "${T}"
+ mysrc="${T}"/`/usr/bin/basename "${i}"`
+
+ # Check for directory
+ elif [ -d "${i}" ] ; then
+ echo "dowar: warning, skipping directory ${i}"
+ continue
+ else
+ mysrc="${i}"
+ fi
+
+ # Install files
+ install -m 0644 "${mysrc}" "${D}${wardest}"
+ done
+}
+
+java-pkg_dozip()
+{
+ debug-print-function ${FUNCNAME} $*
+ java-pkg_dojar $*
+}
+
+_record-jar()
+{
+ echo "$(basename $2)@$1" >> ${pkglistpath}
+}
+
+java-pkg_jarfrom() {
+ java-pkg_jar-from "$@"
+}
+
+java-pkg_jar-from()
+{
+ debug-print-function ${FUNCNAME} $*
+
+ local pkg=$1
+ local jar=$2
+ local destjar=$3
+
+ if [ -z "${destjar}" ] ; then
+ destjar=${jar}
+ fi
+
+ for x in `java-config --classpath=${pkg} | tr ':' ' '`; do
+ if [ ! -f ${x} ] ; then
+ eerror "Installation problems with jars in ${pkg} - is it installed?"
+ return 1
+ fi
+ _record-jar ${pkg} ${x}
+ if [ -z "${jar}" ] ; then
+ ln -sf ${x} $(basename ${x})
+ elif [ "`basename ${x}`" == "${jar}" ] ; then
+ ln -sf ${x} ${destjar}
+ return 0
+ fi
+ done
+ if [ -z "${jar}" ] ; then
+ return 0
+ else
+ return 1
+ fi
+}
+
+java-pkg_getjar()
+{
+
+ debug-print-function ${FUNCNAME} $*
+
+ local pkg=$1
+ local jar=$2
+
+ for x in $(java-config --classpath=${pkg} | tr ':' ' '); do
+
+ if [ ! -f ${x} ] ; then
+ die "Installation problems with jars in ${pkg} - is it installed?"
+ fi
+
+ _record-jar ${pkg} ${x}
+
+ if [ "$(basename ${x})" == "${jar}" ] ; then
+ echo ${x}
+ return 0
+ fi
+ done
+ die "Could not find $2 in $1"
+}
+
+java-pkg_getjars()
+{
+ java-config --classpath=$1
+}
+
+
+java-pkg_dohtml()
+{
+ dohtml -f package-list $@
+}
+
+java-pkg_jarinto()
+{
+ jardest=$1
+}
+
+java-pkg_sointo()
+{
+ sodest=$1
+}
+
+java-pkg_dosrc() {
+ [ $# -lt 1 ] && die "${FUNCNAME[0]}: at least one argument needed"
+
+ local target="/usr/share/doc/${PF}/source/"
+
+ local files
+ local startdir=`pwd`
+ for x in $@; do
+ cd `dirname $x`
+ zip -r ${T}/${PN}-src.zip `basename $x`
+ cd $startdir
+ done
+
+ dodir $target
+ install ${INSOPTIONS} "${T}/${PN}-src.zip" "${D}${target}"
+} \ No newline at end of file