/[gentoo-x86]/eclass/eutils.eclass
Gentoo

Diff of /eclass/eutils.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.56 Revision 1.99
1# Copyright 1999-2003 Gentoo Technologies, Inc. 1# Copyright 1999-2004 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.56 2003/09/22 21:08:27 wolf31o2 Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.99 2004/09/07 11:41:29 vapier Exp $
4# 4#
5# Author: Martin Schlemmer <azarah@gentoo.org> 5# Author: Martin Schlemmer <azarah@gentoo.org>
6# 6#
7# This eclass is for general purpose functions that most ebuilds 7# This eclass is for general purpose functions that most ebuilds
8# have to implement themselves. 8# have to implement themselves.
10# NB: If you add anything, please comment it! 10# NB: If you add anything, please comment it!
11 11
12ECLASS=eutils 12ECLASS=eutils
13INHERITED="$INHERITED $ECLASS" 13INHERITED="$INHERITED $ECLASS"
14 14
15newdepend "!bootstrap? ( sys-devel/patch )" 15DEPEND="!bootstrap? ( sys-devel/patch )"
16 16
17DESCRIPTION="Based on the ${ECLASS} eclass" 17DESCRIPTION="Based on the ${ECLASS} eclass"
18
19# Wait for the supplied number of seconds. If no argument is supplied, defaults
20# to five seconds. If the EPAUSE_IGNORE env var is set, don't wait. If we're not
21# outputting to a terminal, don't wait. For compatability purposes, the argument
22# must be an integer greater than zero.
23# Bug 62950, Ciaran McCreesh <ciaranm@gentoo.org> (05 Sep 2004)
24epause() {
25 if [ -z "$EPAUSE_IGNORE" ] && [ -t 1 ] ; then
26 sleep ${1:-5}
27 fi
28}
29
30# Beep the specified number of times (defaults to five). If our output
31# is not a terminal, don't beep. If the EBEEP_IGNORE env var is set,
32# don't beep.
33# Bug 62950, Ciaran McCreesh <ciaranm@gentoo.org> (05 Sep 2004)
34ebeep() {
35 local n
36 if [ -z "$EBEEP_IGNORE" ] && [ -t 1 ] ; then
37 for ((n=1 ; n <= ${1:-5} ; n++)) ; do
38 echo -ne "\a"
39 sleep 0.1 &>/dev/null ; sleep 0,1 &>/dev/null
40 echo -ne "\a"
41 sleep 1
42 done
43 fi
44}
45
46# This function simply returns the desired lib directory. With portage
47# 2.0.51, we now have support for installing libraries to lib32/lib64
48# to accomidate the needs of multilib systems. It's no longer a good idea
49# to assume all libraries will end up in lib. Replace any (sane) instances
50# where lib is named directly with $(get_libdir) if possible.
51#
52# Travis Tilley <lv@gentoo.org> (24 Aug 2004)
53get_libdir() {
54 if [ ! -z "${CONF_LIBDIR_OVERRIDE}" ] ; then
55 # if there is an override, we want to use that... always.
56 CONF_LIBDIR="${CONF_LIBDIR_OVERRIDE}"
57 elif portageq has_version / '<sys-apps/portage-2.0.51_pre20' ; then
58 # and if there isnt an override, and we're using a version of
59 # portage without CONF_LIBDIR support, force the use of lib. dolib
60 # and friends from portage 2.0.50 wont be too happy otherwise.
61 CONF_LIBDIR="lib"
62 fi
63 # and of course, default to lib if CONF_LIBDIR isnt set
64 echo ${CONF_LIBDIR:=lib}
65}
66
67# Sometimes you need to override the value returned by get_libdir. A good
68# example of this is xorg-x11, where lib32 isnt a supported configuration,
69# and where lib64 -must- be used on amd64 (for applications that need lib
70# to be 32bit, such as adobe acrobat). Note that this override also bypasses
71# portage version sanity checking.
72# get_libdir_override expects one argument, the result get_libdir should
73# return:
74#
75# get_libdir_override lib64
76#
77# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
78get_libdir_override() {
79 CONF_LIBDIR="$1"
80 CONF_LIBDIR_OVERRIDE="$1"
81}
18 82
19# This function generate linker scripts in /usr/lib for dynamic 83# This function generate linker scripts in /usr/lib for dynamic
20# libs in /lib. This is to fix linking problems when you have 84# libs in /lib. This is to fix linking problems when you have
21# the .so in /lib, and the .a in /usr/lib. What happens is that 85# the .so in /lib, and the .a in /usr/lib. What happens is that
22# in some cases when linking dynamic, the .a in /usr/lib is used 86# in some cases when linking dynamic, the .a in /usr/lib is used
33# to point to the latest version of the library present. 97# to point to the latest version of the library present.
34# 98#
35# <azarah@gentoo.org> (26 Oct 2002) 99# <azarah@gentoo.org> (26 Oct 2002)
36# 100#
37gen_usr_ldscript() { 101gen_usr_ldscript() {
38
39 # Just make sure it exists 102 # Just make sure it exists
40 dodir /usr/lib 103 dodir /usr/$(get_libdir)
41 104
42 cat > ${D}/usr/lib/$1 <<"END_LDSCRIPT" 105 cat > ${D}/usr/$(get_libdir)/$1 <<"END_LDSCRIPT"
43/* GNU ld script 106/* GNU ld script
44 Because Gentoo have critical dynamic libraries 107 Because Gentoo have critical dynamic libraries
45 in /lib, and the static versions in /usr/lib, we 108 in /lib, and the static versions in /usr/lib, we
46 need to have a "fake" dynamic lib in /usr/lib, 109 need to have a "fake" dynamic lib in /usr/lib,
47 otherwise we run into linking problems. 110 otherwise we run into linking problems.
48 See bug #4411 on http://bugs.gentoo.org/ for 111 See bug #4411 on http://bugs.gentoo.org/ for
49 more info. */ 112 more info. */
50GROUP ( /lib/libxxx )
51END_LDSCRIPT 113END_LDSCRIPT
52 114
115 echo "GROUP ( /$(get_libdir)/libxxx )" >> ${D}/usr/$(get_libdir)/$1
53 dosed "s:libxxx:$1:" /usr/lib/$1 116 dosed "s:libxxx:$1:" /usr/$(get_libdir)/$1
54 117
55 return 0 118 return 0
56} 119}
57 120
58# Simple function to draw a line consisting of '=' the same length as $* 121# Simple function to draw a line consisting of '=' the same length as $*
144 local SINGLE_PATCH="no" 207 local SINGLE_PATCH="no"
145 local x="" 208 local x=""
146 209
147 if [ "$#" -gt 1 ] 210 if [ "$#" -gt 1 ]
148 then 211 then
149 eerror "Invalid arguments to epatch()" 212 local m=""
150 die "Invalid arguments to epatch()" 213 einfo "${#} patches to apply..."
214 for m in "$@" ; do
215 epatch "${m}"
216 done
217 return 0
151 fi 218 fi
152 219
153 if [ -n "$1" -a -f "$1" ] 220 if [ -n "$1" -a -f "$1" ]
154 then 221 then
155 SINGLE_PATCH="yes" 222 SINGLE_PATCH="yes"
258 else 325 else
259 PATCH_TARGET="${x}" 326 PATCH_TARGET="${x}"
260 fi 327 fi
261 328
262 echo -n "PATCH COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 329 echo -n "PATCH COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
263 echo "patch ${popts} -p${count} < ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 330 echo "patch -p${count} ${popts} < ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
264 331
265 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 332 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
266 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 333 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
267 334
268 if [ "${PATCH_SUFFIX}" != "patch" ] 335 if [ "${PATCH_SUFFIX}" != "patch" ]
275 count=5 342 count=5
276 break 343 break
277 fi 344 fi
278 fi 345 fi
279 346
280 if (cat ${PATCH_TARGET} | patch ${popts} --dry-run -f -p${count}) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1 347 if (cat ${PATCH_TARGET} | patch -p${count} ${popts} --dry-run -f) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
281 then 348 then
282 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 349 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
283 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 350 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
284 echo "ACTUALLY APPLYING ${x##*/}..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 351 echo "ACTUALLY APPLYING ${x##*/}..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
285 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 352 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
286 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 353 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
287 354
288 cat ${PATCH_TARGET} | patch ${popts} -p${count} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1 355 cat ${PATCH_TARGET} | patch -p${count} ${popts} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1
289 356
290 if [ "$?" -ne 0 ] 357 if [ "$?" -ne 0 ]
291 then 358 then
292 cat ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 359 cat ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
293 echo 360 echo
422 jobs="$((`grep "^cpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))" 489 jobs="$((`grep "^cpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
423 else 490 else
424 jobs=2 491 jobs=2
425 fi 492 fi
426 493
427 elif [ "${ARCH}" = "ppc" ] 494 elif [ "${ARCH}" = "ppc" -o "${ARCH}" = "ppc64" ]
428 then 495 then
429 # ppc has "processor", but only when compiled with SMP 496 # ppc has "processor", but only when compiled with SMP
430 if [ "`grep -c "^processor" /proc/cpuinfo`" -eq 1 ] 497 if [ "`grep -c "^processor" /proc/cpuinfo`" -eq 1 ]
431 then 498 then
432 jobs="$((`grep -c ^processor /proc/cpuinfo` * 2))" 499 jobs="$((`grep -c ^processor /proc/cpuinfo` * 2))"
433 else 500 else
434 jobs=2 501 jobs=2
435 fi 502 fi
503 elif [ "${ARCH}" = "s390" ]
504 then
505 # s390 has "# processors : "
506 jobs="$((`grep "^\# processors" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
436 else 507 else
437 jobs="$((`grep -c ^cpu /proc/cpuinfo` * 2))" 508 jobs="$((`grep -c ^cpu /proc/cpuinfo` * 2))"
438 die "Unknown ARCH -- ${ARCH}!" 509 die "Unknown ARCH -- ${ARCH}!"
439 fi 510 fi
440 511
456 fi 527 fi
457 fi 528 fi
458} 529}
459 530
460# Cheap replacement for when debianutils (and thus mktemp) 531# Cheap replacement for when debianutils (and thus mktemp)
461# do not exist on the users system 532# does not exist on the users system
462# vapier@gentoo.org 533# vapier@gentoo.org
463# 534#
464# Takes just 1 parameter (the directory to create tmpfile in) 535# Takes just 1 parameter (the directory to create tmpfile in)
465mymktemp() { 536mymktemp() {
466 local topdir=$1 537 local topdir="$1"
538
467 [ -z "${topdir}" ] && topdir=/tmp 539 [ -z "${topdir}" ] && topdir=/tmp
468 if [ `which mktemp 2>/dev/null` ] ; then 540 if [ "`which mktemp 2>/dev/null`" ]
541 then
469 mktemp -p ${topdir} 542 mktemp -p ${topdir}
470 else 543 else
471 local tmp="${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM}" 544 local tmp="${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM}"
472 touch ${tmp} 545 touch ${tmp}
473 echo ${tmp} 546 echo ${tmp}
547 fi
548}
549
550# Small wrapper for getent (Linux) and nidump (Mac OS X)
551# used in enewuser()/enewgroup()
552# Joe Jezak <josejx@gmail.com> and usata@gentoo.org
553#
554# egetent(database, key)
555egetent() {
556 if [ "${ARCH}" == "macos" ] ; then
557 case "$2" in
558 *[!0-9]*) # Non numeric
559 nidump $1 . | awk -F":" "{ if (\$1 ~ /^$2$/) {print \$0;exit;} }"
560 ;;
561 *) # Numeric
562 nidump $1 . | awk -F":" "{ if (\$3 == $2) {print \$0;exit;} }"
563 ;;
564 esac
565 else
566 getent $1 $2
474 fi 567 fi
475} 568}
476 569
477# Simplify/standardize adding users to the system 570# Simplify/standardize adding users to the system
478# vapier@gentoo.org 571# vapier@gentoo.org
488# groups: none 581# groups: none
489# extra: comment of 'added by portage for ${PN}' 582# extra: comment of 'added by portage for ${PN}'
490enewuser() { 583enewuser() {
491 # get the username 584 # get the username
492 local euser="$1"; shift 585 local euser="$1"; shift
493 if [ -z "${euser}" ] ; then 586 if [ -z "${euser}" ]
587 then
494 eerror "No username specified !" 588 eerror "No username specified !"
495 die "Cannot call enewuser without a username" 589 die "Cannot call enewuser without a username"
496 fi 590 fi
497 591
498 # setup a file for testing usernames/groups
499 local tmpfile="`mymktemp ${T}`"
500 chown ${euser} ${tmpfile} >& /dev/null
501 local realuser="`ls -l ${tmpfile} | awk '{print $3}'`"
502
503 # see if user already exists 592 # lets see if the username already exists
504 if [ "${euser}" == "${realuser}" ] ; then 593 if [ "${euser}" == "`egetent passwd \"${euser}\" | cut -d: -f1`" ]
594 then
505 return 0 595 return 0
506 fi 596 fi
507 einfo "Adding user '${euser}' to your system ..." 597 einfo "Adding user '${euser}' to your system ..."
508 598
509 # options to pass to useradd 599 # options to pass to useradd
510 local opts="" 600 local opts=
511 601
512 # handle uid 602 # handle uid
513 local euid="$1"; shift 603 local euid="$1"; shift
514 if [ ! -z "${euid}" ] && [ "${euid}" != "-1" ] ; then 604 if [ ! -z "${euid}" ] && [ "${euid}" != "-1" ]
605 then
515 if [ ${euid} -gt 0 ] ; then 606 if [ "${euid}" -gt 0 ]
516 opts="${opts} -u ${euid}" 607 then
608 if [ ! -z "`egetent passwd ${euid}`" ]
609 then
610 euid="next"
611 fi
517 else 612 else
518 eerror "Userid given but is not greater than 0 !" 613 eerror "Userid given but is not greater than 0 !"
519 die "${euid} is not a valid UID" 614 die "${euid} is not a valid UID"
520 fi 615 fi
521 else 616 else
522 euid="next available" 617 euid="next"
618 fi
619 if [ "${euid}" == "next" ]
620 then
621 local pwrange
622 if [ "${ARCH}" == "macos" ] ; then
623 pwrange="`jot 898 101`"
624 else
625 pwrange="`seq 101 999`"
523 fi 626 fi
627 for euid in ${pwrange} ; do
628 [ -z "`egetent passwd ${euid}`" ] && break
629 done
630 fi
631 opts="${opts} -u ${euid}"
524 einfo " - Userid: ${euid}" 632 einfo " - Userid: ${euid}"
525 633
526 # handle shell 634 # handle shell
527 local eshell="$1"; shift 635 local eshell="$1"; shift
528 if [ ! -z "${eshell}" ] ; then 636 if [ ! -z "${eshell}" ] && [ "${eshell}" != "-1" ]
637 then
529 if [ ! -e ${eshell} ] ; then 638 if [ ! -e "${eshell}" ]
639 then
530 eerror "A shell was specified but it does not exist !" 640 eerror "A shell was specified but it does not exist !"
531 die "${eshell} does not exist" 641 die "${eshell} does not exist"
532 fi 642 fi
533 else 643 else
534 eshell=/bin/false 644 eshell="/bin/false"
535 fi 645 fi
536 einfo " - Shell: ${eshell}" 646 einfo " - Shell: ${eshell}"
537 opts="${opts} -s ${eshell}" 647 opts="${opts} -s ${eshell}"
538 648
539 # handle homedir 649 # handle homedir
540 local ehome="$1"; shift 650 local ehome="$1"; shift
541 if [ -z "${ehome}" ] ; then 651 if [ -z "${ehome}" ] && [ "${eshell}" != "-1" ]
652 then
542 ehome=/dev/null 653 ehome="/dev/null"
543 fi 654 fi
544 einfo " - Home: ${ehome}" 655 einfo " - Home: ${ehome}"
545 opts="${opts} -d ${ehome}" 656 opts="${opts} -d ${ehome}"
546 657
547 # handle groups 658 # handle groups
548 local egroups="$1"; shift 659 local egroups="$1"; shift
549 if [ ! -z "${egroups}" ] ; then 660 if [ ! -z "${egroups}" ]
550 local realgroup 661 then
551 local oldifs="${IFS}" 662 local oldifs="${IFS}"
552 export IFS="," 663 export IFS=","
553 for g in ${egroups} ; do 664 for g in ${egroups}
554 chgrp ${g} ${tmpfile} >& /dev/null 665 do
555 realgroup="`ls -l ${tmpfile} | awk '{print $4}'`" 666 if [ -z "`egetent group \"${g}\"`" ]
556 if [ "${g}" != "${realgroup}" ] ; then 667 then
557 eerror "You must add ${g} to the system first" 668 eerror "You must add group ${g} to the system first"
558 die "${g} is not a valid GID" 669 die "${g} is not a valid GID"
559 fi 670 fi
560 done 671 done
561 export IFS="${oldifs}" 672 export IFS="${oldifs}"
562 opts="${opts} -g ${egroups}" 673 opts="${opts} -g ${egroups}"
565 fi 676 fi
566 einfo " - Groups: ${egroups}" 677 einfo " - Groups: ${egroups}"
567 678
568 # handle extra and add the user 679 # handle extra and add the user
569 local eextra="$@" 680 local eextra="$@"
570 local oldsandbox=${SANDBOX_ON} 681 local oldsandbox="${SANDBOX_ON}"
571 export SANDBOX_ON="0" 682 export SANDBOX_ON="0"
683 if [ "${ARCH}" == "macos" ];
684 then
685 ### Make the user
572 if [ -z "${eextra}" ] ; then 686 if [ -z "${eextra}" ]
687 then
688 dscl . create /users/${euser} uid ${euid}
689 dscl . create /users/${euser} shell ${eshell}
690 dscl . create /users/${euser} home ${ehome}
691 dscl . create /users/${euser} realname "added by portage for ${PN}"
692 ### Add the user to the groups specified
693 for g in ${egroups}
694 do
695 dscl . merge /groups/${g} users ${euser}
696 done
697 else
698 einfo "Extra options are not supported on macos yet"
699 einfo "Please report the ebuild along with the info below"
700 einfo "eextra: ${eextra}"
701 die "Required function missing"
702 fi
703 else
704 if [ -z "${eextra}" ]
705 then
573 useradd ${opts} ${euser} \ 706 useradd ${opts} ${euser} \
574 -c "added by portage for ${PN}" \ 707 -c "added by portage for ${PN}" \
575 || die "enewuser failed" 708 || die "enewuser failed"
576 else 709 else
577 einfo " - Extra: ${eextra}" 710 einfo " - Extra: ${eextra}"
578 useradd ${opts} ${euser} ${eextra} \ 711 useradd ${opts} ${euser} ${eextra} \
579 || die "enewuser failed" 712 || die "enewuser failed"
713 fi
580 fi 714 fi
581 export SANDBOX_ON="${oldsandbox}" 715 export SANDBOX_ON="${oldsandbox}"
582 716
583 if [ ! -e ${ehome} ] && [ ! -e ${D}/${ehome} ] ; then 717 if [ ! -e "${ehome}" ] && [ ! -e "${D}/${ehome}" ]
718 then
584 einfo " - Creating ${ehome} in ${D}" 719 einfo " - Creating ${ehome} in ${D}"
585 dodir ${ehome} 720 dodir ${ehome}
586 fowners ${euser} ${ehome} 721 fowners ${euser} ${ehome}
587 fperms 755 ${ehome} 722 fperms 755 ${ehome}
588 fi 723 fi
598# gid: next available (see groupadd(8)) 733# gid: next available (see groupadd(8))
599# extra: none 734# extra: none
600enewgroup() { 735enewgroup() {
601 # get the group 736 # get the group
602 local egroup="$1"; shift 737 local egroup="$1"; shift
603 if [ -z "${egroup}" ] ; then 738 if [ -z "${egroup}" ]
739 then
604 eerror "No group specified !" 740 eerror "No group specified !"
605 die "Cannot call enewgroup without a group" 741 die "Cannot call enewgroup without a group"
606 fi 742 fi
607 743
608 # setup a file for testing groupname
609 local tmpfile="`mymktemp ${T}`"
610 chgrp ${egroup} ${tmpfile} >& /dev/null
611 local realgroup="`ls -l ${tmpfile} | awk '{print $4}'`"
612
613 # see if group already exists 744 # see if group already exists
614 if [ "${egroup}" == "${realgroup}" ] ; then 745 if [ "${egroup}" == "`egetent group \"${egroup}\" | cut -d: -f1`" ]
746 then
615 return 0 747 return 0
616 fi 748 fi
617 einfo "Adding group '${egroup}' to your system ..." 749 einfo "Adding group '${egroup}' to your system ..."
618 750
619 # options to pass to useradd 751 # options to pass to useradd
620 local opts="" 752 local opts=
621 753
622 # handle gid 754 # handle gid
623 local egid="$1"; shift 755 local egid="$1"; shift
624 if [ ! -z "${egid}" ] ; then 756 if [ ! -z "${egid}" ]
757 then
625 if [ ${egid} -gt 0 ] ; then 758 if [ "${egid}" -gt 0 ]
759 then
760 if [ -z "`egetent group ${egid}`" ]
761 then
762 if [ "${ARCH}" == "macos" ] ; then
763 opts="${opts} ${egid}"
764 else
626 opts="${opts} -g ${egid}" 765 opts="${opts} -g ${egid}"
766 fi
767 else
768 egid="next available; requested gid taken"
769 fi
627 else 770 else
628 eerror "Groupid given but is not greater than 0 !" 771 eerror "Groupid given but is not greater than 0 !"
629 die "${egid} is not a valid GID" 772 die "${egid} is not a valid GID"
630 fi 773 fi
631 else 774 else
636 # handle extra 779 # handle extra
637 local eextra="$@" 780 local eextra="$@"
638 opts="${opts} ${eextra}" 781 opts="${opts} ${eextra}"
639 782
640 # add the group 783 # add the group
641 local oldsandbox=${SANDBOX_ON} 784 local oldsandbox="${SANDBOX_ON}"
642 export SANDBOX_ON="0" 785 export SANDBOX_ON="0"
786 if [ "${ARCH}" == "macos" ];
787 then
788 if [ ! -z "${eextra}" ];
789 then
790 einfo "Extra options are not supported on macos yet"
791 einfo "Please report the ebuild along with the info below"
792 einfo "eextra: ${eextra}"
793 die "Required function missing"
794 fi
795
796 # If we need the next available
797 case ${egid} in
798 *[!0-9]*) # Non numeric
799 for egid in `jot 898 101`; do
800 [ -z "`egetent group ${egid}`" ] && break
801 done
802 esac
803 dscl . create /groups/${egroup} gid ${egid}
804 dscl . create /groups/${egroup} passwd '*'
805 else
643 groupadd ${opts} ${egroup} || die "enewgroup failed" 806 groupadd ${opts} ${egroup} || die "enewgroup failed"
807 fi
644 export SANDBOX_ON="${oldsandbox}" 808 export SANDBOX_ON="${oldsandbox}"
645} 809}
646 810
647# Simple script to replace 'dos2unix' binaries 811# Simple script to replace 'dos2unix' binaries
648# vapier@gentoo.org 812# vapier@gentoo.org
649# 813#
650# edos2unix(file, <more files>...) 814# edos2unix(file, <more files>...)
651edos2unix() { 815edos2unix() {
652 for f in $@ ; do 816 for f in "$@"
817 do
653 cp ${f} ${T}/edos2unix 818 cp "${f}" ${T}/edos2unix
654 sed 's/\r$//' ${T}/edos2unix > ${f} 819 sed 's/\r$//' ${T}/edos2unix > "${f}"
655 done 820 done
656} 821}
657 822
658# Make a desktop file ! 823# Make a desktop file !
659# Great for making those icons in kde/gnome startmenu ! 824# Great for making those icons in kde/gnome startmenu !
668# name: the name that will show up in the menu 833# name: the name that will show up in the menu
669# icon: give your little like a pretty little icon ... 834# icon: give your little like a pretty little icon ...
670# this can be relative (to /usr/share/pixmaps) or 835# this can be relative (to /usr/share/pixmaps) or
671# a full path to an icon 836# a full path to an icon
672# type: what kind of application is this ? for categories: 837# type: what kind of application is this ? for categories:
673# http://www.freedesktop.org/standards/menu/draft/menu-spec/menu-spec.html 838# http://www.freedesktop.org/standards/menu-spec/
674# path: if your app needs to startup in a specific dir 839# path: if your app needs to startup in a specific dir
675make_desktop_entry() { 840make_desktop_entry() {
676 [ -z "$1" ] && eerror "You must specify the executable" && return 1 841 [ -z "$1" ] && eerror "You must specify the executable" && return 1
677 842
678 local exec=${1} 843 local exec="${1}"
679 local name=${2:-${PN}} 844 local name="${2:-${PN}}"
680 local icon=${3:-${PN}.png} 845 local icon="${3:-${PN}.png}"
681 local type=${4} 846 local type="${4}"
847 local subdir="${6}"
682 local path=${5:-${GAMES_PREFIX}} 848 local path="${5:-${GAMES_PREFIX}}"
683 if [ -z "${type}" ] ; then 849 if [ -z "${type}" ]
850 then
684 case ${CATEGORY} in 851 case ${CATEGORY} in
685 app-emulation) type=Emulator ;; 852 "app-emulation")
686 games-*) type=Game ;; 853 type=Emulator
687 *) type="" ;; 854 subdir="Emulation"
855 ;;
856 "games-"*)
857 type=Game
858 subdir="Games"
859 ;;
860 "net-"*)
861 type=Network
862 subdir="${type}"
863 ;;
864 *)
865 type=
866 subdir=
867 ;;
688 esac 868 esac
689 fi 869 fi
690 local desktop=${T}/${exec}.desktop 870 local desktop="${T}/${exec}.desktop"
691 871
692echo "[Desktop Entry] 872echo "[Desktop Entry]
693Encoding=UTF-8 873Encoding=UTF-8
694Version=0.9.2 874Version=0.9.2
695Name=${name} 875Name=${name}
696Type=Application 876Type=Application
697Comment=${DESCRIPTION} 877Comment=${DESCRIPTION}
698Exec=${exec} 878Exec=${exec}
699Path=${path} 879Path=${path}
700Icon=${icon} 880Icon=${icon}
701Categories=Application;${type};" > ${desktop} 881Categories=Application;${type};" > "${desktop}"
702 882
703 if [ -d /usr/share/applications ] ; then 883 if [ -d "/usr/share/applications" ]
884 then
704 insinto /usr/share/applications 885 insinto /usr/share/applications
705 doins ${desktop} 886 doins "${desktop}"
706 fi 887 fi
707 888
708 #if [ -d /usr/share/gnome/apps ] ; then 889 #if [ -d "/usr/share/gnome/apps" ]
890 #then
709 # insinto /usr/share/gnome/apps/Games 891 # insinto /usr/share/gnome/apps/Games
710 # doins ${desktop} 892 # doins ${desktop}
711 #fi 893 #fi
712 894
713 #if [ ! -z "`ls /usr/kde/* 2>/dev/null`" ] ; then 895 #if [ ! -z "`ls /usr/kde/* 2>/dev/null`" ]
896 #then
714 # for ver in /usr/kde/* ; do 897 # for ver in /usr/kde/*
898 # do
715 # insinto ${ver}/share/applnk/Games 899 # insinto ${ver}/share/applnk/Games
716 # doins ${desktop} 900 # doins ${desktop}
717 # done 901 # done
718 #fi 902 #fi
719 903
720 if [ -d /usr/share/applnk ] ; then 904 if [ -d "/usr/share/applnk" ]
905 then
721 insinto /usr/share/applnk/${type} 906 insinto /usr/share/applnk/${subdir}
722 doins ${desktop} 907 doins "${desktop}"
723 fi 908 fi
724 909
725 return 0 910 return 0
726} 911}
727 912
728# new convenience patch wrapper function to eventually replace epatch(), 913# for internal use only (unpack_pdv and unpack_makeself)
729# $PATCHES, $PATCHES1, src_unpack:patch, src_unpack:autopatch and 914find_unpackable_file() {
730# /usr/bin/patch
731# Features:
732# - bulk patch handling similar to epatch()'s
733# - automatic patch level detection like epatch()'s
734# - automatic patch uncompression like epatch()'s
735# - doesn't have the --dry-run overhead of epatch() - inspects patchfiles
736# manually instead
737# - once I decide it's production-ready, it'll be called from base_src_unpack
738# to handle $PATCHES to avoid defining src_unpack just to use xpatch
739
740# accepts zero or more parameters specifying patchfiles and/or patchdirs
741
742# known issues:
743# - only supports unified style patches (does anyone _really_ use anything
744# else?)
745# - because it doesn't use --dry-run there is a risk of it failing
746# to find the files to patch, ie detect the patchlevel, properly. It doesn't use
747# any of the backup heuristics that patch employs to discover a filename.
748# however, this isn't dangerous because if it works for the developer who's
749# writing the ebuild, it'll always work for the users, and if it doesn't,
750# then we'll fix it :-)
751# - no support as yet for patches applying outside $S (and not directly in $WORKDIR).
752xpatch() {
753
754 debug-print-function $FUNCNAME $*
755
756 local list="" 915 local src="$1"
757 local list2="" 916 if [ -z "${src}" ]
758 declare -i plevel 917 then
759 918 src="${DISTDIR}/${A}"
760 # parse patch sources 919 else
761 for x in $*; do 920 if [ -e "${DISTDIR}/${src}" ]
762 debug-print "$FUNCNAME: parsing parameter $x" 921 then
763 if [ -f "$x" ]; then 922 src="${DISTDIR}/${src}"
764 list="$list $x" 923 elif [ -e "${PWD}/${src}" ]
765 elif [ -d "$x" ]; then 924 then
766 # handles patchdirs like epatch() for now: no recursion. 925 src="${PWD}/${src}"
767 # patches are sorted by filename, so with an xy_foo naming scheme you'll get the right order. 926 elif [ -e "${src}" ]
768 # only patches with _$ARCH_ or _all_ in their filenames are applied. 927 then
769 for file in `ls -A $x`; do 928 src="${src}"
770 debug-print "$FUNCNAME: parsing in subdir: file $file"
771 if [ -f "$x/$file" ] && [ "${file}" != "${file/_all_}" -o "${file}" != "${file/_$ARCH_}" ]; then
772 list2="$list2 $x/$file"
773 fi 929 fi
774 done 930 fi
775 list="`echo $list2 | sort` $list" 931 [ ! -e "${src}" ] && die "Could not find requested archive ${src}"
932 echo "${src}"
933}
934
935# Unpack those pesky pdv generated files ...
936# They're self-unpacking programs with the binary package stuffed in
937# the middle of the archive. Valve seems to use it a lot ... too bad
938# it seems to like to segfault a lot :(. So lets take it apart ourselves.
939#
940# Usage: unpack_pdv [file to unpack] [size of off_t]
941# - you have to specify the off_t size ... i have no idea how to extract that
942# information out of the binary executable myself. basically you pass in
943# the size of the off_t type (in bytes) on the machine that built the pdv
944# archive. one way to determine this is by running the following commands:
945# strings <pdv archive> | grep lseek
946# strace -elseek <pdv archive>
947# basically look for the first lseek command (we do the strings/grep because
948# sometimes the function call is _llseek or something) and steal the 2nd
949# parameter. here is an example:
950# root@vapier 0 pdv_unpack # strings hldsupdatetool.bin | grep lseek
951# lseek
952# root@vapier 0 pdv_unpack # strace -elseek ./hldsupdatetool.bin
953# lseek(3, -4, SEEK_END) = 2981250
954# thus we would pass in the value of '4' as the second parameter.
955unpack_pdv() {
956 local src="`find_unpackable_file $1`"
957 local sizeoff_t="$2"
958
959 [ -z "${sizeoff_t}" ] && die "No idea what off_t size was used for this pdv :("
960
961 local shrtsrc="`basename ${src}`"
962 echo ">>> Unpacking ${shrtsrc} to ${PWD}"
963 local metaskip=`tail -c ${sizeoff_t} ${src} | hexdump -e \"%i\"`
964 local tailskip=`tail -c $((${sizeoff_t}*2)) ${src} | head -c ${sizeoff_t} | hexdump -e \"%i\"`
965
966 # grab metadata for debug reasons
967 local metafile="`mymktemp ${T}`"
968 tail -c +$((${metaskip}+1)) ${src} > ${metafile}
969
970 # rip out the final file name from the metadata
971 local datafile="`tail -c +$((${metaskip}+1)) ${src} | strings | head -n 1`"
972 datafile="`basename ${datafile}`"
973
974 # now lets uncompress/untar the file if need be
975 local tmpfile="`mymktemp ${T}`"
976 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null | head -c 512 > ${tmpfile}
977
978 local iscompressed="`file -b ${tmpfile}`"
979 if [ "${iscompressed:0:8}" == "compress" ] ; then
980 iscompressed=1
981 mv ${tmpfile}{,.Z}
982 gunzip ${tmpfile}
983 else
984 iscompressed=0
985 fi
986 local istar="`file -b ${tmpfile}`"
987 if [ "${istar:0:9}" == "POSIX tar" ] ; then
988 istar=1
989 else
990 istar=0
991 fi
992
993 #for some reason gzip dies with this ... dd cant provide buffer fast enough ?
994 #dd if=${src} ibs=${metaskip} count=1 \
995 # | dd ibs=${tailskip} skip=1 \
996 # | gzip -dc \
997 # > ${datafile}
998 if [ ${iscompressed} -eq 1 ] ; then
999 if [ ${istar} -eq 1 ] ; then
1000 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
1001 | head -c $((${metaskip}-${tailskip})) \
1002 | tar -xzf -
776 else 1003 else
777 die "Couldn't find $x" 1004 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
1005 | head -c $((${metaskip}-${tailskip})) \
1006 | gzip -dc \
1007 > ${datafile}
1008 fi
1009 else
1010 if [ ${istar} -eq 1 ] ; then
1011 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
1012 | head -c $((${metaskip}-${tailskip})) \
1013 | tar --no-same-owner -xf -
1014 else
1015 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
1016 | head -c $((${metaskip}-${tailskip})) \
1017 > ${datafile}
1018 fi
778 fi 1019 fi
779 done 1020 true
780 1021 #[ -s "${datafile}" ] || die "failure unpacking pdv ('${metaskip}' '${tailskip}' '${datafile}')"
781 debug-print "$FUNCNAME: final list of patches: $list" 1022 #assert "failure unpacking pdv ('${metaskip}' '${tailskip}' '${datafile}')"
782
783 for x in $list; do
784 debug-print "$FUNCNAME: processing $x"
785 # deal with compressed files. /usr/bin/file is in the system profile, or should be.
786 case "`/usr/bin/file -b $x`" in
787 *gzip*) patchfile="${T}/current.patch"; ungzip -c "$x" > "${patchfile}";;
788 *bzip2*) patchfile="${T}/current.patch"; bunzip2 -c "$x" > "${patchfile}";;
789 *text*) patchfile="$x";;
790 *) die "Could not determine filetype of patch $x";;
791 esac
792 debug-print "$FUNCNAME: patchfile=$patchfile"
793
794 # determine patchlevel. supports p0 and higher with either $S or $WORKDIR as base.
795 target="`/bin/grep -m 1 '^+++ ' $patchfile`"
796 debug-print "$FUNCNAME: raw target=$target"
797 # strip target down to the path/filename, remove leading +++
798 target="${target/+++ }"; target="${target%% *}"
799 # duplicate slashes are discarded by patch wrt the patchlevel. therefore we need
800 # to discard them as well to calculate the correct patchlevel.
801 target="${target//\/\//\/}"
802 debug-print "$FUNCNAME: stripped target=$target"
803
804 # look for target
805 for basedir in "$S" "$WORKDIR" "${PWD}"; do
806 debug-print "$FUNCNAME: looking in basedir=$basedir"
807 cd "$basedir"
808
809 # try stripping leading directories
810 target2="$target"
811 plevel=0
812 debug-print "$FUNCNAME: trying target2=$target2, plevel=$plevel"
813 while [ ! -f "$target2" ]; do
814 target2="${target2#*/}" # removes piece of target2 upto the first occurence of /
815 plevel=plevel+1
816 debug-print "$FUNCNAME: trying target2=$target2, plevel=$plevel"
817 [ "$target2" == "${target2/\/}" ] && break
818 done
819 test -f "$target2" && break
820
821 # try stripping filename - needed to support patches creating new files
822 target2="${target%/*}"
823 plevel=0
824 debug-print "$FUNCNAME: trying target2=$target2, plevel=$plevel"
825 while [ ! -d "$target2" ]; do
826 target2="${target2#*/}" # removes piece of target2 upto the first occurence of /
827 plevel=plevel+1
828 debug-print "$FUNCNAME: trying target2=$target2, plevel=$plevel"
829 [ "$target2" == "${target2/\/}" ] && break
830 done
831 test -d "$target2" && break
832
833 done
834
835 test -f "${basedir}/${target2}" || test -d "${basedir}/${target2}" || die "Could not determine patchlevel for $x"
836 debug-print "$FUNCNAME: determined plevel=$plevel"
837 # do the patching
838 ebegin "Applying patch ${x##*/}..."
839 /usr/bin/patch -p$plevel < "$patchfile" > /dev/null || die "Failed to apply patch $x"
840 eend $?
841
842 done
843
844} 1023}
845 1024
846# Unpack those pesky makeself generated files ... 1025# Unpack those pesky makeself generated files ...
847# They're shell scripts with the binary package tagged onto 1026# They're shell scripts with the binary package tagged onto
848# the end of the archive. Loki utilized the format as does 1027# the end of the archive. Loki utilized the format as does
851# Usage: unpack_makeself [file to unpack] [offset] 1030# Usage: unpack_makeself [file to unpack] [offset]
852# - If the file is not specified then unpack will utilize ${A}. 1031# - If the file is not specified then unpack will utilize ${A}.
853# - If the offset is not specified then we will attempt to extract 1032# - If the offset is not specified then we will attempt to extract
854# the proper offset from the script itself. 1033# the proper offset from the script itself.
855unpack_makeself() { 1034unpack_makeself() {
856 local src=$1 1035 local src="`find_unpackable_file $1`"
857 local skip=$2 1036 local skip="$2"
858 1037
859 if [ -z "${src}" ] ; then
860 src="${DISTDIR}/${A}"
861 else
862 if [ -e "${DISTDIR}/${src}" ] ; then
863 src="${DISTDIR}/${src}"
864 elif [ -e "${PWD}/${src}" ] ; then
865 src="${PWD}/${src}"
866 elif [ -e "${src}" ] ; then
867 src="${src}"
868 fi
869 fi
870 [ ! -e "${src}" ] && die "Could not find requested makeself archive ${src}"
871
872 local shrtsrc=`basename ${src}` 1038 local shrtsrc="`basename ${src}`"
873 echo ">>> Unpacking ${shrtsrc} to ${PWD}" 1039 echo ">>> Unpacking ${shrtsrc} to ${PWD}"
874 if [ -z "${skip}" ] ; then 1040 if [ -z "${skip}" ]
1041 then
875 local ver="`grep -a '#.*Makeself' ${src} | awk '{print $NF}'`" 1042 local ver="`grep -a '#.*Makeself' ${src} | awk '{print $NF}'`"
876 local skip=0 1043 local skip=0
877 case ${ver} in 1044 case ${ver} in
878 1.5.*) # tested 1.5.{3,4,5} ... guessing 1.5.x series is same 1045 1.5.*) # tested 1.5.{3,4,5} ... guessing 1.5.x series is same
879 skip=`grep -a ^skip= ${src} | cut -d= -f2` 1046 skip=`grep -a ^skip= ${src} | cut -d= -f2`
902 ;; 1069 ;;
903 esac 1070 esac
904 debug-print "Detected Makeself version ${ver} ... using ${skip} as offset" 1071 debug-print "Detected Makeself version ${ver} ... using ${skip} as offset"
905 fi 1072 fi
906 1073
907 # we do this because otherwise a failure in gzip will cause 0 bytes to be sent 1074 # lets grab the first few bytes of the file to figure out what kind of archive it is
908 # to tar which will make tar not extract anything and exit with 0 1075 local tmpfile="`mymktemp ${T}`"
909 tail -n +${skip} ${src} | gzip -cd | tar -x --no-same-owner -f - 2>/dev/null 1076 tail -n +${skip} ${src} 2>/dev/null | head -c 512 > ${tmpfile}
910 local pipestatus="${PIPESTATUS[*]}" 1077 local filetype="`file -b ${tmpfile}`"
911 pipestatus="${pipestatus// }" 1078 case ${filetype} in
912 if [ "${pipestatus//0}" != "" ] ; then 1079 *tar\ archive)
913 # maybe it isnt gzipped ... they usually are, but not always ...
914 tail -n +${skip} ${src} | tar -x --no-same-owner -f - \ 1080 tail -n +${skip} ${src} | tar --no-same-owner -xf -
1081 ;;
1082 bzip2*)
1083 tail -n +${skip} ${src} | bzip2 -dc | tar --no-same-owner -xf -
1084 ;;
1085 gzip*)
1086 tail -n +${skip} ${src} | tar --no-same-owner -xzf -
1087 ;;
1088 compress*)
1089 tail -n +${skip} ${src} | gunzip | tar --no-same-owner -xf -
1090 ;;
1091 *)
1092 eerror "Unknown filetype \"${filetype}\" ?"
1093 false
1094 ;;
1095 esac
915 || die "failure unpacking makeself ${shrtsrc} ('${ver}' +${skip})" 1096 assert "failure unpacking (${filetype}) makeself ${shrtsrc} ('${ver}' +${skip})"
916 fi
917} 1097}
918 1098
919# Display a license for user to accept. 1099# Display a license for user to accept.
920# 1100#
921# Usage: check_license [license] 1101# Usage: check_license [license]
922# - If the file is not specified then ${LICENSE} is used. 1102# - If the file is not specified then ${LICENSE} is used.
923check_license() { 1103check_license() {
924 local src=$1 1104 local lic=$1
925 if [ -z "${src}" ] ; then 1105 if [ -z "${lic}" ] ; then
926 src="${PORTDIR}/licenses/${LICENSE}" 1106 lic="${PORTDIR}/licenses/${LICENSE}"
927 else 1107 else
928 if [ -e "${PORTDIR}/licenses/${src}" ] ; then 1108 if [ -e "${PORTDIR}/licenses/${src}" ] ; then
929 src="${PORTDIR}/licenses/${src}" 1109 lic="${PORTDIR}/licenses/${src}"
930 elif [ -e "${PWD}/${src}" ] ; then 1110 elif [ -e "${PWD}/${src}" ] ; then
931 src="${PWD}/${src}" 1111 lic="${PWD}/${src}"
932 elif [ -e "${src}" ] ; then 1112 elif [ -e "${src}" ] ; then
933 src="${src}" 1113 lic="${src}"
934 fi
935 fi 1114 fi
1115 fi
936 [ ! -e "${src}" ] && die "Could not find requested license ${src}" 1116 [ ! -f "${lic}" ] && die "Could not find requested license ${src}"
1117 local l="`basename ${lic}`"
937 1118
938 # here is where we check for the license... 1119 # here is where we check for the licenses the user already
939 # if we don't find one, we ask the user for it 1120 # accepted ... if we don't find a match, we make the user accept
940 if [ -f /usr/share/licenses/${LICENSE} ]; then 1121 local alic
941 einfo "The license for this application has already been accepted." 1122 for alic in "${ACCEPT_LICENSE}" ; do
1123 [ "${alic}" == "*" ] && return 0
1124 [ "${alic}" == "${l}" ] && return 0
1125 done
1126
1127 local licmsg="`mymktemp ${T}`"
1128 cat << EOF > ${licmsg}
1129**********************************************************
1130The following license outlines the terms of use of this
1131package. You MUST accept this license for installation to
1132continue. When you are done viewing, hit 'q'. If you
1133CTRL+C out of this, the install will not run!
1134**********************************************************
1135
1136EOF
1137 cat ${lic} >> ${licmsg}
1138 ${PAGER:-less} ${licmsg} || die "Could not execute pager (${PAGER}) to accept ${lic}"
1139 einfon "Do you accept the terms of this license (${l})? [yes/no] "
1140 read alic
1141 case ${alic} in
1142 yes|Yes|y|Y)
1143 return 0
1144 ;;
1145 *)
1146 echo;echo;echo
1147 eerror "You MUST accept the license to continue! Exiting!"
1148 die "Failed to accept license"
1149 ;;
1150 esac
1151}
1152
1153# Aquire cd(s) for those lovely cd-based emerges. Yes, this violates
1154# the whole 'non-interactive' policy, but damnit I want CD support !
1155#
1156# with these cdrom functions we handle all the user interaction and
1157# standardize everything. all you have to do is call cdrom_get_cds()
1158# and when the function returns, you can assume that the cd has been
1159# found at CDROM_ROOT.
1160#
1161# normally the cdrom functions will refer to the cds as 'cd #1', 'cd #2',
1162# etc... if you want to give the cds better names, then just export
1163# the CDROM_NAME_X variables before calling cdrom_get_cds().
1164#
1165# for those multi cd ebuilds, see the cdrom_load_next_cd() below.
1166#
1167# Usage: cdrom_get_cds <file on cd1> [file on cd2] [file on cd3] [...]
1168# - this will attempt to locate a cd based upon a file that is on
1169# the cd ... the more files you give this function, the more cds
1170# the cdrom functions will handle
1171cdrom_get_cds() {
1172 # first we figure out how many cds we're dealing with by
1173 # the # of files they gave us
1174 local cdcnt=0
1175 local f=
1176 for f in "$@" ; do
1177 cdcnt=$((cdcnt + 1))
1178 export CDROM_CHECK_${cdcnt}="$f"
1179 done
1180 export CDROM_TOTAL_CDS=${cdcnt}
1181 export CDROM_CURRENT_CD=1
1182
1183 # now we see if the user gave use CD_ROOT ...
1184 # if they did, let's just believe them that it's correct
1185 if [ ! -z "${CD_ROOT}" ] ; then
1186 export CDROM_ROOT="${CD_ROOT}"
1187 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1188 return
1189 fi
1190 # do the same for CD_ROOT_X
1191 if [ ! -z "${CD_ROOT_1}" ] ; then
1192 local var=
1193 cdcnt=0
1194 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1195 cdcnt=$((cdcnt + 1))
1196 var="CD_ROOT_${cdcnt}"
1197 if [ -z "${!var}" ] ; then
1198 eerror "You must either use just the CD_ROOT"
1199 eerror "or specify ALL the CD_ROOT_X variables."
1200 eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables."
1201 die "could not locate CD_ROOT_${cdcnt}"
1202 fi
1203 export CDROM_ROOTS_${cdcnt}="${!var}"
1204 done
1205 export CDROM_ROOT=${CDROM_ROOTS_1}
1206 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1207 return
1208 fi
1209
1210 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1211 einfon "This ebuild will need the "
1212 if [ -z "${CDROM_NAME}" ] ; then
1213 echo "cdrom for ${PN}."
942 else 1214 else
943 ewarn "You MUST accept this license for installation to continue." 1215 echo "${CDROM_NAME}."
944 eerror "If you CTRL+C out of this, the install will not run!" 1216 fi
945 echo 1217 echo
1218 einfo "If you do not have the CD, but have the data files"
1219 einfo "mounted somewhere on your filesystem, just export"
1220 einfo "the variable CD_ROOT so that it points to the"
1221 einfo "directory containing the files."
1222 echo
1223 else
1224 einfo "This package will need access to ${CDROM_TOTAL_CDS} cds."
1225 cdcnt=0
1226 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1227 cdcnt=$((cdcnt + 1))
1228 var="CDROM_NAME_${cdcnt}"
1229 [ ! -z "${!var}" ] && einfo " CD ${cdcnt}: ${!var}"
1230 done
1231 echo
1232 einfo "If you do not have the CDs, but have the data files"
1233 einfo "mounted somewhere on your filesystem, just export"
1234 einfo "the following variables so they point to the right place:"
1235 einfon ""
1236 cdcnt=0
1237 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1238 cdcnt=$((cdcnt + 1))
1239 echo -n " CD_ROOT_${cdcnt}"
1240 done
1241 echo
1242 einfo "Or, if you have all the files in the same place, or"
1243 einfo "you only have one cdrom, you can export CD_ROOT"
1244 einfo "and that place will be used as the same data source"
1245 einfo "for all the CDs."
1246 echo
1247 fi
1248 export CDROM_CURRENT_CD=0
1249 cdrom_load_next_cd
1250}
946 1251
947 ${PAGER} ${src} || die "Could not execute ${PAGER} ${src} 1252# this is only used when you need access to more than one cd.
948 einfo "Do you accept the terms of this license? [yes/no]" 1253# when you have finished using the first cd, just call this function.
949 read ACCEPT_TERMS 1254# when it returns, CDROM_ROOT will be pointing to the second cd.
950 case ${ACCEPT_TERMS} in 1255# remember, you can only go forward in the cd chain, you can't go back.
951 yes|Yes|y|Y) 1256cdrom_load_next_cd() {
952 cp ${src} /usr/share/licenses 1257 export CDROM_CURRENT_CD=$((CDROM_CURRENT_CD + 1))
953 exit 0 1258 local var=
954 ;; 1259
955 *) 1260 if [ ! -z "${CD_ROOT}" ] ; then
956 eerror "You MUST accept the license to continue! Exiting!" 1261 einfo "Using same root as before for CD #${CDROM_CURRENT_CD}"
957 die "Failed to accept license" 1262 return
958 ;; 1263 fi
959 esac 1264
1265 unset CDROM_ROOT
1266 var=CDROM_ROOTS_${CDROM_CURRENT_CD}
1267 if [ -z "${!var}" ] ; then
1268 var="CDROM_CHECK_${CDROM_CURRENT_CD}"
1269 cdrom_locate_file_on_cd ${!var}
1270 else
1271 export CDROM_ROOT="${!var}"
1272 fi
1273
1274 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1275}
1276
1277# this is used internally by the cdrom_get_cds() and cdrom_load_next_cd()
1278# functions. this should *never* be called from an ebuild.
1279# all it does is try to locate a give file on a cd ... if the cd isn't
1280# found, then a message asking for the user to insert the cdrom will be
1281# displayed and we'll hang out here until:
1282# (1) the file is found on a mounted cdrom
1283# (2) the user hits CTRL+C
1284cdrom_locate_file_on_cd() {
1285 while [ -z "${CDROM_ROOT}" ] ; do
1286 local dir="$(dirname ${@})"
1287 local file="$(basename ${@})"
1288 local mline=""
1289 local showedmsg=0
1290
1291 for mline in `mount | egrep -e '(iso|cdrom)' | awk '{print $3}'` ; do
1292 [ -d "${mline}/${dir}" ] || continue
1293 [ ! -z "$(find ${mline}/${dir} -iname ${file} -maxdepth 1)" ] \
1294 && export CDROM_ROOT=${mline}
1295 done
1296
1297 if [ -z "${CDROM_ROOT}" ] ; then
1298 echo
1299 if [ ${showedmsg} -eq 0 ] ; then
1300 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1301 if [ -z "${CDROM_NAME}" ] ; then
1302 einfo "Please insert the cdrom for ${PN} now !"
1303 else
1304 einfo "Please insert the ${CDROM_NAME} cdrom now !"
1305 fi
1306 else
1307 if [ -z "${CDROM_NAME_1}" ] ; then
1308 einfo "Please insert cd #${CDROM_CURRENT_CD} for ${PN} now !"
1309 else
1310 local var="CDROM_NAME_${CDROM_CURRENT_CD}"
1311 einfo "Please insert+mount the ${!var} cdrom now !"
1312 fi
1313 fi
1314 showedmsg=1
1315 fi
1316 einfo "Press return to scan for the cd again"
1317 einfo "or hit CTRL+C to abort the emerge."
1318 read
960 fi 1319 fi
1320 done
961} 1321}
1322
1323# Make sure that LINGUAS only contains languages that
1324# a package can support
1325#
1326# usage: strip-linguas <allow LINGUAS>
1327# strip-linguas -i <directories of .po files>
1328# strip-linguas -u <directories of .po files>
1329#
1330# The first form allows you to specify a list of LINGUAS.
1331# The -i builds a list of po files found in all the
1332# directories and uses the intersection of the lists.
1333# The -u builds a list of po files found in all the
1334# directories and uses the union of the lists.
1335strip-linguas() {
1336 local ls newls
1337 if [ "$1" == "-i" ] || [ "$1" == "-u" ] ; then
1338 local op="$1"; shift
1339 ls=" $(find "$1" -name '*.po' -printf '%f ') "; shift
1340 local d f
1341 for d in "$@" ; do
1342 if [ "${op}" == "-u" ] ; then
1343 newls="${ls}"
1344 else
1345 newls=""
1346 fi
1347 for f in $(find "$d" -name '*.po' -printf '%f ') ; do
1348 if [ "${op}" == "-i" ] ; then
1349 [ "${ls/ ${f} /}" != "${ls}" ] && newls="${newls} ${f}"
1350 else
1351 [ "${ls/ ${f} /}" == "${ls}" ] && newls="${newls} ${f}"
1352 fi
1353 done
1354 ls="${newls}"
1355 done
1356 ls="${ls//.po}"
1357 else
1358 ls="$@"
1359 fi
1360
1361 ls=" ${ls} "
1362 newls=""
1363 for f in ${LINGUAS} ; do
1364 if [ "${ls/ ${f} /}" != "${ls}" ] ; then
1365 nl="${newls} ${f}"
1366 else
1367 ewarn "Sorry, but ${PN} does not support the ${f} LINGUA"
1368 fi
1369 done
1370 if [ -z "${newls}" ] ; then
1371 unset LINGUAS
1372 else
1373 export LINGUAS="${newls}"
1374 fi
1375}

Legend:
Removed from v.1.56  
changed lines
  Added in v.1.99

  ViewVC Help
Powered by ViewVC 1.1.20