diff options
Diffstat (limited to 'eclass/kde.eclass')
-rw-r--r-- | eclass/kde.eclass | 306 |
1 files changed, 301 insertions, 5 deletions
diff --git a/eclass/kde.eclass b/eclass/kde.eclass index a3cdce6ed62d..044d2a612e1b 100644 --- a/eclass/kde.eclass +++ b/eclass/kde.eclass @@ -1,9 +1,9 @@ # 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.21 2001/12/23 14:25:28 danarmak Exp $ +# $Header: /var/cvsroot/gentoo-x86/eclass/kde.eclass,v 1.22 2001/12/23 21:35:15 danarmak Exp $ # The kde eclass is inherited by all kde-* eclasses. Few ebuilds inherit straight from here. -inherit autoconf base depend || die +inherit autoconf base || die ECLASS=kde DESCRIPTION="Based on the $ECLASS eclass" @@ -14,6 +14,26 @@ DEPEND="$DEPEND kde-base/kdelibs objprelink? ( >=dev-util/objprelink-0-r1 )" RDEPEND="$RDEPEND kde-base/kdelibs" +# 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-objprelink-patch() { debug-print-function $FUNCNAME $* if [ "`use objprelink`" ]; then @@ -48,8 +68,6 @@ kde_src_compile() { case $1 in myconf) debug-print-section myconf - set-kdedir $kde_version - set-qtdir $qt_version myconf="$myconf --host=${CHOST} --with-x --enable-mitshm --with-xinerama --prefix=/usr --with-qt-dir=${QTDIR}" use qtmt && myconf="$myconf --enable-mt" use objprelink && myconf="$myconf --enable-objprelink" || myconf="$myconf --disable-objprelink" @@ -57,7 +75,7 @@ kde_src_compile() { ;; configure) debug-print-section configure - debug-print "configure: myconf=$myconf" + debug-print "$FUNCNAME::configure: myconf=$myconf" ./configure ${myconf} || die ;; make) @@ -104,7 +122,285 @@ kde_src_install() { EXPORT_FUNCTIONS src_compile src_install +# This used to be depend.eclass. At some point I realized it might as well be called kd-depend.eclass. And then +# because functions fom there needed functions from here and vice versa I merged them. + +#--------------- + +# 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 + + debug-print + + IFS=$IFSBACKUP + +} + +# 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 + # we're in serious troble + echo "!!! Error: $FUNCNAME could not find/select a satisfying version number! +!!! If this surprises you, it shouldn't have happened. If you're using +!!! the prerelease kde3 ebuilds make sure you have the latest kdelibs3 +!!! and qt3 emerged. If you do have them, or don't know what i'm talking +!!! about, report this as a bug." + exit 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}" + + # 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" + done + + 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 + +} + +need-kde() { + + 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 + +} + +set-qtdir() { + + debug-print-function $FUNCNAME $* + + biglist="`ls -d1 /usr/lib/qt-x11-*`" + debug-print "$FUNCNAME: \$biglist: +${biglist}" + + # 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" + done + + 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 + +} + +need-qt() { + + QTVER="$1" + debug-print-function $FUNCNAME $* + debug-print "$FUNCNAME: version number is $QTVER" + + separate-string $QTVER ._ QTVER 5 + + QTMAJORVER=QTVER[0] + + newdepend ">=x11-libs/qt-x11-$QTVER" + + set-qtdir + +} |