summaryrefslogtreecommitdiff
path: root/eclass
diff options
context:
space:
mode:
authorDan Armak <danarmak@gentoo.org>2002-07-12 21:42:38 +0000
committerDan Armak <danarmak@gentoo.org>2002-07-12 21:42:38 +0000
commit75732527fe1359f48bc255b73e1fc10f8db2a612 (patch)
tree79675e21bbc59f56ca9642f8675eaa6693cc2f27 /eclass
parentchange SLOT for kde-base packages to major.minor (i.e. version numbers, e.g. ... (diff)
downloadgentoo-2-75732527fe1359f48bc255b73e1fc10f8db2a612.tar.gz
gentoo-2-75732527fe1359f48bc255b73e1fc10f8db2a612.tar.bz2
gentoo-2-75732527fe1359f48bc255b73e1fc10f8db2a612.zip
big change for multiple kdes, being tested wih 3.1alpha1. barring bugs shouldn't affect current 3.0.x users.
Diffstat (limited to 'eclass')
-rw-r--r--eclass/kde-base.eclass3
-rw-r--r--eclass/kde-functions.eclass113
-rw-r--r--eclass/kde.eclass15
3 files changed, 99 insertions, 32 deletions
diff --git a/eclass/kde-base.eclass b/eclass/kde-base.eclass
index 3826048f6427..7413f8301654 100644
--- a/eclass/kde-base.eclass
+++ b/eclass/kde-base.eclass
@@ -1,10 +1,11 @@
# Copyright 1999-2000 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# Author Dan Armak <danarmak@gentoo.org>
-# $Header: /var/cvsroot/gentoo-x86/eclass/kde-base.eclass,v 1.14 2002/02/06 20:38:10 danarmak Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde-base.eclass,v 1.15 2002/07/12 21:42:38 danarmak Exp $
# This is the kde ebuild for std. kde-dependant apps which follow configure/make/make install
# procedures and have std. configure options.
inherit kde
+INHERITED="$INHERITED $ECLASS"
ECLASS=kde-base
newdepend /c
diff --git a/eclass/kde-functions.eclass b/eclass/kde-functions.eclass
index 9b66ac6f437e..0450ad4f43f8 100644
--- a/eclass/kde-functions.eclass
+++ b/eclass/kde-functions.eclass
@@ -1,11 +1,11 @@
# Copyright 1999-2000 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# Author Dan Armak <danarmak@gentoo.org>
-# $Header: /var/cvsroot/gentoo-x86/eclass/kde-functions.eclass,v 1.14 2002/07/11 06:27:35 drobbins Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde-functions.eclass,v 1.15 2002/07/12 21:42:38 danarmak Exp $
# This contains everything except things that modify ebuild variables and functions (e.g. $P, src_compile() etc.)
ECLASS=kde-functions
-
-# convinience functios for requesting autotools versions
+INHERITED="$INHERITED $ECLASS"
+# convinience functions for requesting autotools versions
need-automake() {
debug-print-function $FUNCNAME $*
@@ -50,8 +50,8 @@ need-kde() {
# if we're a kde-base package, we need an exact version of kdelibs
# to compile correctly.
- if [ "$ECLASS" == "kde-dist" ]; then
- newdepend "=kde-base/kdelibs-${KDEVER}*"
+ if [ "${INHERITED//kde-dist}" != "$INHERITED" ]; then
+ newdepend "~kde-base/kdelibs-${KDEVER}"
set-kdedir $KDEVER
else
# everyone else only needs a minimum version
@@ -70,7 +70,7 @@ need-kde() {
set-kdedir() {
debug-print-function $FUNCNAME $*
-
+
case "$1" in
2*)
need-autoconf 2.1
@@ -82,28 +82,97 @@ set-kdedir() {
;;
esac
- # default settings for older make.globals versions which don't include the default KDE?DIR settings
- [ -z "$KDE2DIR" ] && export KDE2DIR="/usr/kde/2"
- [ -z "$KDE3DIR" ] && export KDE3DIR="/usr/kde/3"
- # not defined at all by default
- [ -z "$KDE2LIBSDIR" ] && export KDE2LIBSDIR="$KDE2DIR"
- [ -z "$KDE3LIBSDIR" ] && export KDE3LIBSDIR="$KDE3DIR"
-
- # select 1st element in dot-separated string
+ # get version elements
IFSBACKUP=$IFS
- IFS="."
- KDEMAJORVER=""
+ IFS=".-_"
for x in $1; do
- [ -z "$KDEMAJORVER" ] && KDEMAJORVER=$x
+ if [ -z "$KDEMAJORVER" ]; then KDEMAJORVER=$x
+ else if [ -z "$KDEMINORVER" ]; then KDEMINORVER=$x
+ else if [ -z "$KDEREVISION" ]; then KDEREVISION=$x
+ fi; fi; fi
done
IFS=$IFSBACKUP
+ # set install location.
+ # 3rd party apps go into /usr/kde/$MAJORVER by default
+ # a kde version goes into /usr/kde/$MAJORVER.$MINORVER by default
+ # and has a SLOT that includes the major and minor version
+ # if $KDE3DIR is defined (by the user), it overrides everything
+ # and both base and 3rd party kde stuff goes in there, while
+ # using the kdelibs (assumedly) present in $KDE3LIBSDIR
+ # which equals $KDE3DIR if not set (for kde3, same applies to kde2 with $KDE2DIR etc.)
+ # kde.eclass:src_compile:myconf doesn't know about it, we just tell it
+ # $KDEDIR (libraries location) and $PREFIX (install location)
+
case $KDEMAJORVER in
- 2) export KDEDIR=${KDE2LIBSDIR};;
- 3) export KDEDIR=${KDE3LIBSDIR};;
+ 2)
+ if [ -n "$KDE2DIR" ]; then
+ export PREFIX=${KDE2DIR}
+ export KDEDIR=${KDE2LIBSDIR}
+ else
+ export PREFIX=/usr/kde/2
+ # backward compatibility, kde 2.2.2 goes in /usr/kde/2 not /usr/kde/2.2
+ export KDEDIR=/usr/kde/2
+ fi
+ ;;
+ 3)
+ if [ -n "$KDE3DIR" ]; then
+ # override all other considerations
+ export PREFIX=${KDE3DIR}
+ else
+ # base kde part
+ if [ "${INHERITED//kde-dist}" != "${INHERITED}" -o PN=kdelibs -o PN=arts ]; then
+ case $KDEMINORVER in
+ "") export PREFIX=/usr/kde/3
+ ;;
+ 0) export PREFIX=/usr/kde/3
+ # kde 3.1 alphas
+ [ "$KDEREVISION" -ge 6 ] && export PREFIX=/usr/kde/3.1
+ ;;
+ 1) export PREFIX=/usr/kde/3.1
+ ;;
+ 2) export PREFIX=/usr/kde/3.2
+ ;;
+ esac
+ else
+ # 3rd party kde app
+ export PREFIX=/usr/kde/3
+ fi
+ fi
+
+ # set kdelibs location
+ # KDE3LIBSDIR overrides all considerations
+ if [ -n "$KDE3LIBSDIR" ]; then
+ export KDEDIR=${KDE3LIBSDIR}
+ else
+ # for kde base, equal to prefix
+ if [ "${INHERITED//kde-dist}" != "$INHERITED" ] || [ "$PN" == kdelibs ] || [ "$PN" == arts ]; then
+ echo "base package"
+ export KDEDIR=$PREFIX
+ else
+ # for everything else: try to locate latest version
+ # of kdelibs installed. if yours is outside the standard
+ # paths, that's what KDE3LIBSDIR is for, use it
+ for x in /usr/kde/{cvs,3.2,3.1,3.0,3} $KDEDIR $KDE3DIR $KDE3LIBSDIR /usr/kde/*; do
+ echo checking for $x/include/kwin.h...
+ if [ -f "${x}/include/kwin.h" ]; then
+ echo found
+ export KDEDIR="$x"
+ break
+ fi
+ done
+ fi
+ fi
+
+ ;;
esac
-
- debug-print "$FUNCNAME: result: KDEDIR=$KDEDIR"
+
+ # check that we've set everything
+ [ -z "$PREFIX" ] && die "$ECLASS: Error: could set install prefix, consult log"
+ [ "${INHERITED//kde-dist}" != "${INHERITED}" -a -z "$KDEDIR" ] && die "$ECLASS: Error: could set kdelibs location, consult log"
+
+ debug-print "$FUNCNAME: result: KDEDIR=$KDEDIR, PREFIX=$PREFIX"
+ echo "$FUNCNAME: result: KDEDIR=$KDEDIR, PREFIX=$PREFIX"
}
@@ -144,7 +213,7 @@ qtver-from-kdever() {
case $1 in
2*) ver=2.3.1;;
3*) ver=3.0.3;;
- *) echo "!!! error: $FUNCNAME() called with invalid parameter: \"$1\", please report bug" && exit 1;;
+ *) echo "!!! error: $FUNCNAME called with invalid parameter: \"$1\", please report bug" && exit 1;;
esac
selected_version="$ver"
diff --git a/eclass/kde.eclass b/eclass/kde.eclass
index c3e6fbd12666..9430d4c40ebb 100644
--- a/eclass/kde.eclass
+++ b/eclass/kde.eclass
@@ -1,10 +1,12 @@
# Copyright 1999-2000 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# Author Dan Armak <danarmak@gentoo.org>
-# $Header: /var/cvsroot/gentoo-x86/eclass/kde.eclass,v 1.49 2002/05/07 19:26:22 danarmak Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde.eclass,v 1.50 2002/07/12 21:42:38 danarmak Exp $
# The kde eclass is inherited by all kde-* eclasses. Few ebuilds inherit straight from here.
inherit base kde-functions
ECLASS=kde
+INHERITED="$INHERITED $ECLASS"
+
newdepend /autotools
DESCRIPTION="Based on the $ECLASS eclass"
@@ -23,12 +25,7 @@ kde_src_compile() {
case $1 in
myconf)
debug-print-section myconf
- myconf="$myconf --host=${CHOST} --with-x --enable-mitshm --with-xinerama --with-qt-dir=${QTDIR}"
- case $KDEMAJORVER in
- 2) myconf="$myconf --prefix=${KDE2DIR}";;
- 3) myconf="$myconf --prefix=${KDE3DIR}";;
- *) echo "!!! $ECLASS: $FUNCNAME: myconf: could not set --prefix based on \$KDEMAJOVER=\"$KDEMAJORVER\"" && exit 1;;
- esac
+ myconf="$myconf --prefix=${PREFIX} --host=${CHOST} --with-x --enable-mitshm --with-xinerama --with-qt-dir=${QTDIR}"
use qtmt && myconf="$myconf --enable-mt"
[ -n "$DEBUG" ] && myconf="$myconf --enable-debug=full --with-debug" || myconf="$myconf --disable-debug --without-debug"
debug-print "$FUNCNAME: myconf: set to ${myconf}"
@@ -43,7 +40,7 @@ kde_src_compile() {
if [ -f "$x" ] && [ -z "$makefile" ]; then makefile="$x"; fi
done
debug-print "$FUNCNAME: configure: generating configure script, running make -f $makefile"
- emake -f $makefile
+ make -f $makefile
[ -f "./configure" ] || die "no configure script found, generation unsuccessful"
fi
@@ -53,7 +50,7 @@ kde_src_compile() {
make)
export PATH="${KDEDIR}/bin:${PATH}"
debug-print-section make
- emake || die "died running emake, $FUNCNAME:make"
+ emake || die "died running emake, $FUNCNAME:make"
;;
all)
debug-print-section all