summaryrefslogtreecommitdiff
path: root/eclass
diff options
context:
space:
mode:
authorDan Armak <danarmak@gentoo.org>2001-12-29 17:41:37 +0000
committerDan Armak <danarmak@gentoo.org>2001-12-29 17:41:37 +0000
commit31ea401556c658c3b023797bba71370f471437d6 (patch)
tree8675242200fdcbca6ae10a94064e5ff3fbe4c818 /eclass
parentunmasked fam (diff)
downloadgentoo-2-31ea401556c658c3b023797bba71370f471437d6.tar.gz
gentoo-2-31ea401556c658c3b023797bba71370f471437d6.tar.bz2
gentoo-2-31ea401556c658c3b023797bba71370f471437d6.zip
big commit :-) read gentoo-announce msg and eclass/doc/news.txt for details
Diffstat (limited to 'eclass')
-rw-r--r--eclass/doc/news.txt31
-rw-r--r--eclass/kde-i18n.eclass12
-rw-r--r--eclass/kde.eclass313
3 files changed, 88 insertions, 268 deletions
diff --git a/eclass/doc/news.txt b/eclass/doc/news.txt
index 72489c477a8c..0758fa87e1eb 100644
--- a/eclass/doc/news.txt
+++ b/eclass/doc/news.txt
@@ -1,4 +1,33 @@
-14/12
+28/12
+v5.1
+Really big changes. Most of what has been added in the last versions has been deleted. Summary of changes:
+- There is now only one 2.x and one 3.x version of qt and kdelibs installed at any given time, should be the latest.
+They go into /usr/qt/{2,3} and /usr/kde/{2,3} respectively. Also the actual qt libs live in /usr/lib, while /usr/qt/{2,3}/lib
+is a symlink to /usr/lib.
+- The qt ebuild is now called x11-libs/qt (not qt-x11). It contains only the actual library, developer tools like the qt designer,
+the headers and moc. There is also an app-doc/qt-docs which installs the manpages, documentation, examples and tutorials.
+- An ebuild now calls need-kde $ver. This does:
+ a. add kdelibs $ver to DEPEND/RDEPEND
+ b. call set-kdedir, which sets KDEDIR to /usr/kde/2 or /usr/kde/3 based on the first char of $ver.
+ c. call need-qt $qtver, where qtver is derived from kdever via qtver-from-kdever().
+ d. need-qt adds $ver to DEPEND, RDEPEND and calls set-qtdir $ver.
+ e. set-qtdir acts like set-kdedir wrt. QTDIR.
+- An ebuild that needs a special version of qt, or qt without kde, can call need-qt directly.
+- select-version() and separate-string() have been removed.
+- objprelink support has been removed since it doesn't work with the latest binutils; we are promised generic system-wide
+prelinking support Real Soon Now. All objprelink functions, calls, refs, deps etc. have been deleted, and the ebuilds
+will shortly be removed as well.
+
+27/12
+KDEVER[] renamed to KDEVERPARTS[] because it turns out if you have a KDEVER[]
+array in bash, you can't have a separate KDEVER variable but will access
+KDEVER[0] instead.
+Also many small misc fixes in kde.eclass.
+In particular to support versions like 3.0_beta1 which avtually have a source
+tarball/dir name of 3.0beta1 we now have kde.org.eclass and kde.eclass use
+${P//_} for SRC_URI and S.
+
+24/12
fix for emerging a new kdelibs
23/12
diff --git a/eclass/kde-i18n.eclass b/eclass/kde-i18n.eclass
index b86094f6f74b..670db750a040 100644
--- a/eclass/kde-i18n.eclass
+++ b/eclass/kde-i18n.eclass
@@ -1,7 +1,7 @@
# 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-i18n.eclass,v 1.7 2001/12/23 21:35:15 danarmak Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde-i18n.eclass,v 1.8 2001/12/29 17:41:37 danarmak Exp $
inherit kde kde.org || die
ECLASS=kde-i18n
@@ -13,4 +13,12 @@ need-kde ${PV}
PROVIDE="virtual/kde-i18n-${PV}"
-myconf=$"myconf --enable-final"
+myconf="$myconf --enable-final"
+
+SRC_URI="$SRC_URI http://www.ibiblio.org/gentoo/distfiles/kde-i18n-gentoo.patch"
+
+src_unpack() {
+ base_src_unpack
+ cd ${S}
+ patch -p0 < ${ECLASSDIR}/kde-i18n-gentoo.patch
+} \ No newline at end of file
diff --git a/eclass/kde.eclass b/eclass/kde.eclass
index dae57001e9b9..37717712b6e8 100644
--- a/eclass/kde.eclass
+++ b/eclass/kde.eclass
@@ -1,37 +1,18 @@
# 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.25 2001/12/27 16:58:56 drobbins Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/kde.eclass,v 1.26 2001/12/29 17:41:37 danarmak Exp $
# The kde eclass is inherited by all kde-* eclasses. Few ebuilds inherit straight from here.
inherit autoconf base || die
ECLASS=kde
+# for versions with _alpha/_beta etc in them
+#S=${WORKDIR}/${P//_}
+
DESCRIPTION="Based on the $ECLASS eclass"
HOMEPAGE="http://www.kde.org/"
-DEPEND="$DEPEND"
-
-# resolution function: kde version -> qt version
-# wish we had something like python dictionaries here :-)
-# gets kde version in $1 and returns matching qt version in $matching_qt_ver
-# if none matches, returns -1
-qtver-from-kdever() {
-
- debug-print-function $FUNCNAME $*
-
- case "$1" in
- 2_* | 2 | 2.0*) matching_qt_ver=2;;
- 2.1*) matching_qt_ver=2.1;;
- 2.2*) matching_qt_ver=2.3.1;;
- 3_* | 3 | 3.0*) matching_qt_ver=3.0.1;;
- *) matching_qt_ver=-1
- esac
-
- debug-print "$FUNCNAME: resolved KDE version $1 to QT version $matching_qt_ver"
-
-}
-
kde_src_compile() {
debug-print-function $FUNCNAME $*
@@ -42,14 +23,9 @@ kde_src_compile() {
case $1 in
myconf)
debug-print-section myconf
- if [ ! -d "$KDEDIR" ]; then
- # possible if portage installed a version newer than the one requested
- debug-print "$FUNCNAME::myconf: calling set-kdedir again"
- set-kdedir
- fi
myconf="$myconf --host=${CHOST} --with-x --enable-mitshm --with-xinerama --prefix=/usr --with-qt-dir=${QTDIR}"
use qtmt && myconf="$myconf --enable-mt"
- myconf="$myconf --disable-objprelink"
+ [ -n "$DEBUG" ] && myconf="$myconf --enable-debug" || myconf="$myconf --disable-debug"
debug-print "$FUNCNAME: myconf: set to ${myconf}"
;;
configure)
@@ -59,7 +35,7 @@ kde_src_compile() {
;;
make)
debug-print-section make
- LIBRARY_PATH=${LIBRARY_PATH}:${QTDIR}/lib make || die
+ make || die
;;
all)
debug-print-section all
@@ -106,278 +82,85 @@ EXPORT_FUNCTIONS src_compile src_install
#---------------
-# This provides the need-kde and need-qt functions, which handle setting KDEDIR
-# and QTDIR for the multi-qt and multi-kdelibs schemes. The functions set-kdedir and
-# set-qtdir are called from kde.eclass; the need-* functions from the ebuild.
-
-# A helper function that takes a dot-separated string and builds an array from its parts.
-# We need this for version comparisons becaus bash can't compare e.g. 2.2.2 and 2.12.3.
-# array created is called version_parts
-# 1st parameter: string to separate
-# 2nd parameter: separator char(s) (optional, defaults to "._" dot and underscore)
-# 3rd parameter: name of array to create (optional, defaults to "version")
-# 4th parameter: minimal number of version parts (optional, defaults to 0). If after
-# separation this number is not reached, the necessary amount of parts is added with value 0.
-# This is a very ugly kludge as there is also a 0th element of the array which isn't counted on
-# purpose, because that's how we want it to be. In short, you shouldn't use this outside depend.eclass :-)
-separate-string() {
-
- debug-print-function $FUNCNAME $*
-
- [ -n "$3" ] && arr="$3" || arr="version"
- [ -n "$2" ] && sep="$2" || sep="._"
- [ -n "$4" ] && min="$4" || min=0
- IFSBACKUP=$IFS
- IFS=$sep
-
- local index
- index=0
- for x in $1
- do
- eval $arr[$index]=$x
- debug-print "$FUNCNAME: adding to array, index = $index, value = $x"
- let "index+=1"
- done
-
- while [ "$index" -le "$min" ] # <= not < because $index ends up being larger by 1 than the amount of elements in the array
- do
- eval $arr[$index]=0
- debug-print "$FUNCNAME: adding to array, index = $index, value = 0"
- let "index+=1"
- done
+need-kde() {
- debug-print
+ debug-print-function $FUNCNAME $*
+ KDEVER="$1"
+ newdepend ">=kde-base/kdelibs-$KDEVER"
+ set-kdedir $KDEVER
- IFS=$IFSBACKUP
+ qtver-from-kdever $KDEVER
+ need-qt $selected_version
}
-# The version comparison/selection function. Uses separate-string() to break down
-# version numbers into their components and selects the one to use. Assumes *some*
-# good version is installed, as we add the requirment to DEPEND/RDEPEND. Is used for
-# both qt and kdelibs.
-# 1st parameter: required (minimal) version
-# 2nd parameter: list of space-separated versions to choose from
-select-version() {
-
- debug-print-function $FUNCNAME $*
-
- # 2d arrays in bash are troublesome, so we do this:
- # sanity check - make sure we've got all parameters
- if [ $# != 2 ]; then
- echo "!!! Error: $FUNCNAME did not get all required parameters.
-!!! You can check what it did get with eclass debug output."
- exit 1
- fi
-
- # to facilitate handling of release types (alpha,beta,pre,rc) we replace them with numbers
- local needed list
- needed="`echo $1 | sed -e 's/alpha/-4./' \
- -e 's/beta/-3./' \
- -e 's/pre/-2./' \
- -e 's/rc/-1./' `"
- list="`echo $2 | sed -e 's/alpha/-4./' \
- -e 's/beta/-3./' \
- -e 's/pre/-2./' \
- -e 's/rc/-1./' `"
-
- # because we're going to separate each version number into its components,
- # once we've selected one it'll be difficult to "unseparate" it, recreatg e.g.
- # beta/alpha/underscores etc. So we prepend a ser. number to each. Since we
- # don't know the length/number of parts in a version number at this stage,
- # we can't append the index but must prepend it. Then it'll live as part 0
- # of the separated version number, while we'll deal with parts 1 through 5.
- local index templist
- index=1
- templist="$list"
- list=""
- for x in $templist; do
- list="${list} ${index}.${x}"
- let "index+=1"
- done
-
- debug-print "$FUNCNAME: after parsing, list = $list"
-
- # parse required version number $1 -> array "req"
- separate-string 0.$1 ._ req 5
- debug-print "$FUNCNAME: for \$1 = $1, we've got back a req with contents = ${req[*]}"
-
- # init array "best" to major,-1,-1 so that any alternative is better (major is
- # major version number of needed). give it a nonexistent index.
- declare -a best
- best=( 0 ${req[1]} -10 -10 -10 -10 -10 )
-
- # for each version number in $list:
- local x ver
- for ver in $list
- do
- # parse version number -> array "cur"
- separate-string $ver ._ cur 5
- debug-print "$FUNCNAME: for ver = $ver, we've got back a cur with contents = ${cur[*]}"
-
- # check if it satisfies the requirements. if not, pass to the next x.
- # 1. major version numer is = to that of req
- [ ${cur[1]} -eq ${req[1]} ] || continue
-
- # 2. check whether minor version and revision of cur are >= those of best
- # if = continue checking (lower levels), if > select right away, if < break
- # we typically have upto 5 levels: major, minor, revision,
- # release type (alpha, beta...), release type number (beta1, beta2...)
- for x in 2 3 4 5
- do
- debug-print "$FUNCNAME: will compare place $x. in cur: ${cur[$x]}, in best: ${best[$x]}"
- if [ "${cur[$x]}" -gt "${best[$x]}" ]; then
- debug-print "$FUNCNAME: comparison result is >"
- # set best to equal cur
- best=( "${cur[@]}" )
- continue 2 # next iteration of outer loop
- elif [ "${cur[$x]}" -lt "${best[$x]}" ]; then
- debug-print "$FUNCNAME: comparison result is <"
- continue 2 # next iteration of outer loop
- # this is all implicitly done
- else # [ ${cur[2]} -eq ${best[2]} ]
- debug-print "$FUNCNAME: comparison result is ="
- # # see if we've reached the last iteration
- # if [ "$x" = "5" ]; then
- # # this is exactly the version we need, i.e. req = cur.
- # # so we don't have to do anything at all :-)
- # fi
- # continue # next iteration of this loop
- #fi
- fi
- done
-
- done
-
- # find the coresponding "unseparated" version number in the orig. $list using
- # the indexes we planted
- local result count
- index=${best[0]}
- debug-print "$FUNCNAME: best has index number $index \
-compare with $list \
-search for it in $2"
- count=1
- for x in $2; do
- if [ "$count" = "$index" ]; then
- result=$x
- break
- fi
- let "count+=1"
- done
-
- if [ -z "$result" ]; then
- # this is probably ok as it shuold mean portage will install the needed version
- # hadnling code in kde_src_compile
- debug-print "Warning: $FUNCNAME: could not find/select a satisfying version number!
-this probably means that it hasn't yet been installed, but will be."
- result="$1"
- fi
-
- # strip all spaces
- result="${result// }"
-
- # return, tired but satisfied
- selected_version=$result
- debug-print "$FUNCNAME: final result: returning selected_version = $selected_version"
-
-}
set-kdedir() {
debug-print-function $FUNCNAME $*
- biglist="`ls -d1 /usr/lib/kdelibs-*`"
- debug-print "$FUNCNAME: \$biglist:
-${biglist}"
+ local KDEVER
+ KDEVER=$1
- # filter $biglist to create $list
- list=""
- for x in $biglist; do
- # strip path, leave version number
- x="`echo $x | sed -e 's:/usr/lib/kdelibs-::'`"
- list="$list $x"
+ # select 1st element in dot-separated string
+ IFSBACKUP=$IFS
+ IFS="."
+ KDEMAJORVER=""
+ for x in $KDEVER; do
+ [ -z "$KDEMAJORVER" ] && KDEMAJORVER=$x
done
+ IFS=$IFSBACKUP
- debug-print "$FUNCNAME: filtered \$biglist and got this \$list:
-$list"
-
- # select version
- select-version $KDEVER "$list"
-
- # check and set
- if [ -z "$selected_version" ]; then
- echo "!!! $FUNCNAME: no match returned by select-version! Please report."
- else
- export KDEDIR="/usr/lib/kdelibs-$selected_version"
- fi
+ export KDEDIR="/usr/kde/$KDEMAJORVER"
}
-need-kde() {
+need-qt() {
- KDEVER="$1"
debug-print-function $FUNCNAME $*
- debug-print "$FUNCNAME: version number is $KDEVER"
-
- separate-string $KDEVER ._ KDEVER 5
-
- KDEMAJORVER=KDEVER[0]
-
- newdepend ">=kde-base/kdelibs-$KDEVER"
-
- set-kdedir
-
- qtver-from-kdever $KDEVER
- need-qt $matching_qt_ver
+ QTVER="$1"
+ newdepend ">=x11-libs/qt-$QTVER"
+ set-qtdir $QTVER
}
+
set-qtdir() {
debug-print-function $FUNCNAME $*
- biglist="`ls -d1 /usr/lib/qt-x11-*`"
- debug-print "$FUNCNAME: \$biglist:
-${biglist}"
+ local QTVER
+ QTVER=$1
- # filter $biglist to create $list
- list=""
- for x in $biglist; do
- # strip path, leave version number
- x="`echo $x | sed -e 's:/usr/lib/qt-x11-::'`"
- list="$list $x"
+ # select 1st element in dot-separated string
+ IFSBACKUP=$IFS
+ IFS="."
+ QTMAJORVER=""
+ for x in $QTVER; do
+ [ -z "$QTMAJORVER" ] && QTMAJORVER=$x
done
+ IFS=$IFSBACKUP
- debug-print "$FUNCNAME: filtered \$biglist and got this \$list:
-$list"
-
- # select version
- select-version $QTVER "$list"
-
- # check and set
- if [ -z "$selected_version" ]; then
- echo "!!! $FUNCNAME: no match returned by select-version! Please report."
- else
- export QTDIR="/usr/lib/qt-x11-$selected_version"
- fi
+ export QTDIR="/usr/qt/$QTMAJORVER"
}
-need-qt() {
+# returns minimal qt version needed for specified kde version
+qtver-from-kdever() {
- QTVER="$1"
- debug-print-function $FUNCNAME $*
- debug-print "$FUNCNAME: version number is $QTVER"
+ local ver
- separate-string $QTVER ._ QTVER 5
+ case $1 in
+ 2*) ver=2.3.1;;
+ 3.0*) ver=3.0.1;;
+ *) echo "!!! error: qtver-from-kdever() (kde.eclass) called with invalid parameter: \"$1\", please report bug" && exit 1;;
+ esac
- QTMAJORVER=QTVER[0]
+ selected_version="$ver"
- newdepend ">=x11-libs/qt-x11-$QTVER"
+}
- set-qtdir
-}