diff options
author | Dan Armak <danarmak@gentoo.org> | 2001-12-29 17:41:37 +0000 |
---|---|---|
committer | Dan Armak <danarmak@gentoo.org> | 2001-12-29 17:41:37 +0000 |
commit | 31ea401556c658c3b023797bba71370f471437d6 (patch) | |
tree | 8675242200fdcbca6ae10a94064e5ff3fbe4c818 /eclass | |
parent | unmasked fam (diff) | |
download | gentoo-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.txt | 31 | ||||
-rw-r--r-- | eclass/kde-i18n.eclass | 12 | ||||
-rw-r--r-- | eclass/kde.eclass | 313 |
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 -} |