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

Diff of /eclass/eutils.eclass

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

Revision 1.106 Revision 1.143
1# Copyright 1999-2004 Gentoo Foundation 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.106 2004/09/21 17:34:33 wolf31o2 Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.143 2005/01/26 16:19:12 ka0ttic 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.
9# 9#
10# NB: If you add anything, please comment it! 10# NB: If you add anything, please comment it!
11 11
12inherit multilib
12ECLASS=eutils 13ECLASS=eutils
13INHERITED="$INHERITED $ECLASS" 14INHERITED="$INHERITED $ECLASS"
14 15
15DEPEND="!bootstrap? ( sys-devel/patch )" 16DEPEND="!bootstrap? ( sys-devel/patch )"
16 17
41 sleep 1 42 sleep 1
42 done 43 done
43 fi 44 fi
44} 45}
45 46
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 LIBDIR_TEST=$(type econf)
55 if [ ! -z "${CONF_LIBDIR_OVERRIDE}" ] ; then
56 # if there is an override, we want to use that... always.
57 CONF_LIBDIR="${CONF_LIBDIR_OVERRIDE}"
58 # We don't need to know the verison of portage. We only need to know
59 # if there is support for CONF_LIBDIR in econf and co.
60 # Danny van Dyk <kugelfang@gentoo.org> 2004/17/09
61 #elif portageq has_version / '<sys-apps/portage-2.0.51_pre20' ; then
62 # # and if there isnt an override, and we're using a version of
63 # # portage without CONF_LIBDIR support, force the use of lib. dolib
64 # # and friends from portage 2.0.50 wont be too happy otherwise.
65 # CONF_LIBDIR="lib"
66 #fi
67 elif [ "${LIBDIR_TEST/CONF_LIBDIR}" == "${LIBDIR_TEST}" ]; then # we don't have CONF_LIBDIR support
68 # will be <portage-2.0.51_pre20
69 CONF_LIBDIR="lib"
70 fi
71 # and of course, default to lib if CONF_LIBDIR isnt set
72 echo ${CONF_LIBDIR:=lib}
73 unset LIBDIR_TEST
74}
75
76
77get_multilibdir() {
78 echo ${CONF_MULTILIBDIR:=lib32}
79}
80
81
82# Sometimes you need to override the value returned by get_libdir. A good
83# example of this is xorg-x11, where lib32 isnt a supported configuration,
84# and where lib64 -must- be used on amd64 (for applications that need lib
85# to be 32bit, such as adobe acrobat). Note that this override also bypasses
86# portage version sanity checking.
87# get_libdir_override expects one argument, the result get_libdir should
88# return:
89#
90# get_libdir_override lib64
91#
92# Travis Tilley <lv@gentoo.org> (31 Aug 2004)
93get_libdir_override() {
94 CONF_LIBDIR="$1"
95 CONF_LIBDIR_OVERRIDE="$1"
96}
97
98# This function generate linker scripts in /usr/lib for dynamic 47# This function generate linker scripts in /usr/lib for dynamic
99# libs in /lib. This is to fix linking problems when you have 48# libs in /lib. This is to fix linking problems when you have
100# the .so in /lib, and the .a in /usr/lib. What happens is that 49# the .so in /lib, and the .a in /usr/lib. What happens is that
101# in some cases when linking dynamic, the .a in /usr/lib is used 50# in some cases when linking dynamic, the .a in /usr/lib is used
102# instead of the .so in /lib due to gcc/libtool tweaking ld's 51# instead of the .so in /lib due to gcc/libtool tweaking ld's
112# to point to the latest version of the library present. 61# to point to the latest version of the library present.
113# 62#
114# <azarah@gentoo.org> (26 Oct 2002) 63# <azarah@gentoo.org> (26 Oct 2002)
115# 64#
116gen_usr_ldscript() { 65gen_usr_ldscript() {
66 local libdir="$(get_libdir)"
117 # Just make sure it exists 67 # Just make sure it exists
118 dodir /usr/$(get_libdir) 68 dodir /usr/${libdir}
119 69
120 cat > "${D}/usr/$(get_libdir)/$1" << END_LDSCRIPT 70 cat > "${D}/usr/${libdir}/${1}" << END_LDSCRIPT
121/* GNU ld script 71/* GNU ld script
122 Because Gentoo have critical dynamic libraries 72 Because Gentoo have critical dynamic libraries
123 in /lib, and the static versions in /usr/lib, we 73 in /lib, and the static versions in /usr/lib, we
124 need to have a "fake" dynamic lib in /usr/lib, 74 need to have a "fake" dynamic lib in /usr/lib,
125 otherwise we run into linking problems. 75 otherwise we run into linking problems.
126 See bug #4411 on http://bugs.gentoo.org/ for 76 See bug #4411 on http://bugs.gentoo.org/ for
127 more info. */ 77 more info. */
128GROUP ( /$(get_libdir)/$1 ) 78GROUP ( /${libdir}/${1} )
129END_LDSCRIPT 79END_LDSCRIPT
80 fperms a+x "/usr/${libdir}/${1}"
130} 81}
131 82
132# Simple function to draw a line consisting of '=' the same length as $* 83# Simple function to draw a line consisting of '=' the same length as $*
133# 84#
134# <azarah@gentoo.org> (11 Nov 2002) 85# <azarah@gentoo.org> (11 Nov 2002)
219 local x="" 170 local x=""
220 171
221 if [ "$#" -gt 1 ] 172 if [ "$#" -gt 1 ]
222 then 173 then
223 local m="" 174 local m=""
224 einfo "${#} patches to apply..." 175 einfo "${#} patches to apply ..."
225 for m in "$@" ; do 176 for m in "$@" ; do
226 epatch "${m}" 177 epatch "${m}"
227 done 178 done
228 return 0 179 return 0
229 fi 180 fi
243 local EPATCH_SOURCE="$1/*" 194 local EPATCH_SOURCE="$1/*"
244 else 195 else
245 local EPATCH_SOURCE="$1/*.${EPATCH_SUFFIX}" 196 local EPATCH_SOURCE="$1/*.${EPATCH_SUFFIX}"
246 fi 197 fi
247 else 198 else
248 if [ ! -d ${EPATCH_SOURCE} ] 199 if [ ! -d ${EPATCH_SOURCE} ] || [ -n "$1" ]
249 then 200 then
250 if [ -n "$1" -a "${EPATCH_SOURCE}" = "${WORKDIR}/patch" ] 201 if [ -n "$1" -a "${EPATCH_SOURCE}" = "${WORKDIR}/patch" ]
251 then 202 then
252 EPATCH_SOURCE="$1" 203 EPATCH_SOURCE="$1"
253 fi 204 fi
254 205
255 echo 206 echo
256 eerror "Cannot find \$EPATCH_SOURCE! Value for \$EPATCH_SOURCE is:" 207 eerror "Cannot find \$EPATCH_SOURCE! Value for \$EPATCH_SOURCE is:"
257 eerror 208 eerror
258 eerror " ${EPATCH_SOURCE}" 209 eerror " ${EPATCH_SOURCE}"
210 eerror " ( ${EPATCH_SOURCE##*/} )"
259 echo 211 echo
260 die "Cannot find \$EPATCH_SOURCE!" 212 die "Cannot find \$EPATCH_SOURCE!"
261 fi 213 fi
262 214
263 local EPATCH_SOURCE="${EPATCH_SOURCE}/*.${EPATCH_SUFFIX}" 215 local EPATCH_SOURCE="${EPATCH_SOURCE}/*.${EPATCH_SUFFIX}"
282 ;; 234 ;;
283 esac 235 esac
284 236
285 if [ "${SINGLE_PATCH}" = "no" ] 237 if [ "${SINGLE_PATCH}" = "no" ]
286 then 238 then
287 einfo "Applying various patches (bugfixes/updates)..." 239 einfo "Applying various patches (bugfixes/updates) ..."
288 fi 240 fi
289 for x in ${EPATCH_SOURCE} 241 for x in ${EPATCH_SOURCE}
290 do 242 do
291 # New ARCH dependant patch naming scheme... 243 # New ARCH dependant patch naming scheme ...
292 # 244 #
293 # ???_arch_foo.patch 245 # ???_arch_foo.patch
294 # 246 #
295 if [ -f ${x} ] && \ 247 if [ -f ${x} ] && \
296 ([ "${SINGLE_PATCH}" = "yes" -o "${x/_all_}" != "${x}" -o "`eval echo \$\{x/_${ARCH}_\}`" != "${x}" ] || \ 248 ([ "${SINGLE_PATCH}" = "yes" -o "${x/_all_}" != "${x}" -o "`eval echo \$\{x/_${ARCH}_\}`" != "${x}" ] || \
311 then 263 then
312 if [ -n "${EPATCH_SINGLE_MSG}" ] 264 if [ -n "${EPATCH_SINGLE_MSG}" ]
313 then 265 then
314 einfo "${EPATCH_SINGLE_MSG}" 266 einfo "${EPATCH_SINGLE_MSG}"
315 else 267 else
316 einfo "Applying ${x##*/}..." 268 einfo "Applying ${x##*/} ..."
317 fi 269 fi
318 else 270 else
319 einfo " ${x##*/}..." 271 einfo " ${x##*/} ..."
320 fi 272 fi
321 273
322 echo "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 274 echo "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
323 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 275 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
324 276
357 309
358 if (cat ${PATCH_TARGET} | patch -p${count} ${popts} --dry-run -f) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1 310 if (cat ${PATCH_TARGET} | patch -p${count} ${popts} --dry-run -f) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
359 then 311 then
360 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 312 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
361 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 313 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
362 echo "ACTUALLY APPLYING ${x##*/}..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 314 echo "ACTUALLY APPLYING ${x##*/} ..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
363 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 315 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
364 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 316 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
365 317
366 cat ${PATCH_TARGET} | patch -p${count} ${popts} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1 318 cat ${PATCH_TARGET} | patch -p${count} ${popts} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1
367 319
436 388
437 return 1; 389 return 1;
438 } 390 }
439 END 391 END
440 392
441 einfon "Checking for _CS_GNU_LIBPTHREAD_VERSION support in glibc ... " 393 einfon "Checking for _CS_GNU_LIBPTHREAD_VERSION support in glibc ..."
442 if gcc -o ${T}/nptl ${T}/test-nptl.c &> /dev/null 394 if gcc -o ${T}/nptl ${T}/test-nptl.c &> /dev/null
443 then 395 then
444 echo "yes" 396 echo "yes"
445 einfon "Checking what PTHREADS implementation we have ... " 397 einfon "Checking what PTHREADS implementation we have ..."
446 if ${T}/nptl 398 if ${T}/nptl
447 then 399 then
448 return 0 400 return 0
449 else 401 else
450 return 1 402 return 1
526 478
527 if [ -n "${ADMINPARAM}" ] 479 if [ -n "${ADMINPARAM}" ]
528 then 480 then
529 if [ "${jobs}" -gt "${ADMINPARAM}" ] 481 if [ "${jobs}" -gt "${ADMINPARAM}" ]
530 then 482 then
531 einfo "Setting make jobs to \"-j${ADMINPARAM}\" to ensure successful merge..." 483 einfo "Setting make jobs to \"-j${ADMINPARAM}\" to ensure successful merge ..."
532 export MAKEOPTS="${MAKEOPTS} -j${ADMINPARAM}" 484 export MAKEOPTS="${MAKEOPTS} -j${ADMINPARAM}"
533 else 485 else
534 einfo "Setting make jobs to \"-j${jobs}\" to ensure successful merge..." 486 einfo "Setting make jobs to \"-j${jobs}\" to ensure successful merge ..."
535 export MAKEOPTS="${MAKEOPTS} -j${jobs}" 487 export MAKEOPTS="${MAKEOPTS} -j${jobs}"
536 fi 488 fi
537 fi 489 fi
538} 490}
539 491
540# Cheap replacement for when debianutils (and thus mktemp) 492# Cheap replacement for when debianutils (and thus mktemp)
541# does not exist on the users system 493# does not exist on the users system
542# vapier@gentoo.org 494# vapier@gentoo.org
543# 495#
544# Takes just 1 parameter (the directory to create tmpfile in) 496# Takes just 1 optional parameter (the directory to create tmpfile in)
545mymktemp() { 497emktemp() {
498 local exe="touch"
499 [ "$1" == "-d" ] && exe="mkdir" && shift
546 local topdir="$1" 500 local topdir="$1"
547 501
548 [ -z "${topdir}" ] && topdir=/tmp 502 if [ -z "${topdir}" ]
549 if [ "`which mktemp 2>/dev/null`" ]
550 then 503 then
551 mktemp -p ${topdir} 504 [ -z "${T}" ] \
552 else 505 && topdir="/tmp" \
506 || topdir="${T}"
507 fi
508
509 if [ -z "$(type -p mktemp)" ]
510 then
511 local tmp=/
512 while [ -e "${tmp}" ] ; do
553 local tmp="${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM}" 513 tmp="${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM}"
554 touch ${tmp} 514 done
515 ${exe} "${tmp}"
555 echo ${tmp} 516 echo "${tmp}"
517 else
518 [ "${exe}" == "touch" ] \
519 && exe="-p" \
520 || exe="-d"
521 mktemp ${exe} "${topdir}"
556 fi 522 fi
557} 523}
558 524
559# Small wrapper for getent (Linux) and nidump (Mac OS X) 525# Small wrapper for getent (Linux), nidump (Mac OS X),
560# used in enewuser()/enewgroup() 526# and pw (FreeBSD) used in enewuser()/enewgroup()
561# Joe Jezak <josejx@gmail.com> and usata@gentoo.org 527# Joe Jezak <josejx@gmail.com> and usata@gentoo.org
528# FBSD stuff: Aaron Walker <ka0ttic@gentoo.org>
562# 529#
563# egetent(database, key) 530# egetent(database, key)
564egetent() { 531egetent() {
565 if use macos || use ppc-macos ; then 532 if useq ppc-macos ; then
566 case "$2" in 533 case "$2" in
567 *[!0-9]*) # Non numeric 534 *[!0-9]*) # Non numeric
568 nidump $1 . | awk -F":" "{ if (\$1 ~ /^$2$/) {print \$0;exit;} }" 535 nidump $1 . | awk -F":" "{ if (\$1 ~ /^$2$/) {print \$0;exit;} }"
569 ;; 536 ;;
570 *) # Numeric 537 *) # Numeric
571 nidump $1 . | awk -F":" "{ if (\$3 == $2) {print \$0;exit;} }" 538 nidump $1 . | awk -F":" "{ if (\$3 == $2) {print \$0;exit;} }"
572 ;; 539 ;;
573 esac 540 esac
541 elif useq x86-fbsd ; then
542 local action
543 if [ "$1" == "passwd" ]
544 then
545 action="user"
574 else 546 else
547 action="group"
548 fi
549 pw show "${action}" "$2" -q
550 else
551 which nscd >& /dev/null && nscd -i "$1"
575 getent $1 $2 552 getent "$1" "$2"
576 fi 553 fi
577} 554}
578 555
579# Simplify/standardize adding users to the system 556# Simplify/standardize adding users to the system
580# vapier@gentoo.org 557# vapier@gentoo.org
626 euid="next" 603 euid="next"
627 fi 604 fi
628 if [ "${euid}" == "next" ] 605 if [ "${euid}" == "next" ]
629 then 606 then
630 local pwrange 607 local pwrange
631 if use macos || use ppc-macos ; then 608 if [ "${USERLAND}" == "BSD" ] ; then
632 pwrange="`jot 898 101`" 609 pwrange="`jot 898 101`"
633 else 610 else
634 pwrange="`seq 101 999`" 611 pwrange="`seq 101 999`"
635 fi 612 fi
636 for euid in ${pwrange} ; do 613 for euid in ${pwrange} ; do
648 then 625 then
649 eerror "A shell was specified but it does not exist !" 626 eerror "A shell was specified but it does not exist !"
650 die "${eshell} does not exist" 627 die "${eshell} does not exist"
651 fi 628 fi
652 else 629 else
630 if [ "${USERLAND}" == "BSD" ]
631 then
632 eshell="/usr/bin/false"
633 else
653 eshell="/bin/false" 634 eshell="/bin/false"
635 fi
654 fi 636 fi
655 einfo " - Shell: ${eshell}" 637 einfo " - Shell: ${eshell}"
656 opts="${opts} -s ${eshell}" 638 opts="${opts} -s ${eshell}"
657 639
658 # handle homedir 640 # handle homedir
667 # handle groups 649 # handle groups
668 local egroups="$1"; shift 650 local egroups="$1"; shift
669 if [ ! -z "${egroups}" ] 651 if [ ! -z "${egroups}" ]
670 then 652 then
671 local oldifs="${IFS}" 653 local oldifs="${IFS}"
654 local defgroup="" exgroups=""
655
672 export IFS="," 656 export IFS=","
673 for g in ${egroups} 657 for g in ${egroups}
674 do 658 do
659 export IFS="${oldifs}"
675 if [ -z "`egetent group \"${g}\"`" ] 660 if [ -z "`egetent group \"${g}\"`" ]
676 then 661 then
677 eerror "You must add group ${g} to the system first" 662 eerror "You must add group ${g} to the system first"
678 die "${g} is not a valid GID" 663 die "${g} is not a valid GID"
679 fi 664 fi
665 if [ -z "${defgroup}" ]
666 then
667 defgroup="${g}"
668 else
669 exgroups="${exgroups},${g}"
670 fi
671 export IFS=","
680 done 672 done
681 export IFS="${oldifs}" 673 export IFS="${oldifs}"
674
682 opts="${opts} -g ${egroups}" 675 opts="${opts} -g ${defgroup}"
676 if [ ! -z "${exgroups}" ]
677 then
678 opts="${opts} -G ${exgroups:1}"
679 fi
683 else 680 else
684 egroups="(none)" 681 egroups="(none)"
685 fi 682 fi
686 einfo " - Groups: ${egroups}" 683 einfo " - Groups: ${egroups}"
687 684
688 # handle extra and add the user 685 # handle extra and add the user
689 local eextra="$@" 686 local eextra="$@"
690 local oldsandbox="${SANDBOX_ON}" 687 local oldsandbox="${SANDBOX_ON}"
691 export SANDBOX_ON="0" 688 export SANDBOX_ON="0"
692 if use macos || use ppc-macos ; 689 if useq ppc-macos
693 then 690 then
694 ### Make the user 691 ### Make the user
695 if [ -z "${eextra}" ] 692 if [ -z "${eextra}" ]
696 then 693 then
697 dscl . create /users/${euser} uid ${euid} 694 dscl . create /users/${euser} uid ${euid}
698 dscl . create /users/${euser} shell ${eshell} 695 dscl . create /users/${euser} shell ${eshell}
699 dscl . create /users/${euser} home ${ehome} 696 dscl . create /users/${euser} home ${ehome}
700 dscl . create /users/${euser} realname "added by portage for ${PN}" 697 dscl . create /users/${euser} realname "added by portage for ${PN}"
701 ### Add the user to the groups specified 698 ### Add the user to the groups specified
699 local oldifs="${IFS}"
700 export IFS=","
702 for g in ${egroups} 701 for g in ${egroups}
703 do 702 do
704 dscl . merge /groups/${g} users ${euser} 703 dscl . merge /groups/${g} users ${euser}
705 done 704 done
705 export IFS="${oldifs}"
706 else 706 else
707 einfo "Extra options are not supported on macos yet" 707 einfo "Extra options are not supported on macos yet"
708 einfo "Please report the ebuild along with the info below" 708 einfo "Please report the ebuild along with the info below"
709 einfo "eextra: ${eextra}" 709 einfo "eextra: ${eextra}"
710 die "Required function missing" 710 die "Required function missing"
711 fi
712 elif use x86-fbsd ; then
713 if [ -z "${eextra}" ]
714 then
715 pw useradd ${euser} ${opts} \
716 -c "added by portage for ${PN}" \
717 die "enewuser failed"
718 else
719 einfo " - Extra: ${eextra}"
720 pw useradd ${euser} ${opts} \
721 -c ${eextra} || die "enewuser failed"
711 fi 722 fi
712 else 723 else
713 if [ -z "${eextra}" ] 724 if [ -z "${eextra}" ]
714 then 725 then
715 useradd ${opts} ${euser} \ 726 useradd ${opts} ${euser} \
766 then 777 then
767 if [ "${egid}" -gt 0 ] 778 if [ "${egid}" -gt 0 ]
768 then 779 then
769 if [ -z "`egetent group ${egid}`" ] 780 if [ -z "`egetent group ${egid}`" ]
770 then 781 then
771 if use macos || use ppc-macos ; then 782 if useq ppc-macos ; then
772 opts="${opts} ${egid}" 783 opts="${opts} ${egid}"
773 else 784 else
774 opts="${opts} -g ${egid}" 785 opts="${opts} -g ${egid}"
775 fi 786 fi
776 else 787 else
790 opts="${opts} ${eextra}" 801 opts="${opts} ${eextra}"
791 802
792 # add the group 803 # add the group
793 local oldsandbox="${SANDBOX_ON}" 804 local oldsandbox="${SANDBOX_ON}"
794 export SANDBOX_ON="0" 805 export SANDBOX_ON="0"
795 if use macos || use ppc-macos ; 806 if useq ppc-macos ; then
796 then
797 if [ ! -z "${eextra}" ]; 807 if [ ! -z "${eextra}" ];
798 then 808 then
799 einfo "Extra options are not supported on macos yet" 809 einfo "Extra options are not supported on macos yet"
800 einfo "Please report the ebuild along with the info below" 810 einfo "Please report the ebuild along with the info below"
801 einfo "eextra: ${eextra}" 811 einfo "eextra: ${eextra}"
809 [ -z "`egetent group ${egid}`" ] && break 819 [ -z "`egetent group ${egid}`" ] && break
810 done 820 done
811 esac 821 esac
812 dscl . create /groups/${egroup} gid ${egid} 822 dscl . create /groups/${egroup} gid ${egid}
813 dscl . create /groups/${egroup} passwd '*' 823 dscl . create /groups/${egroup} passwd '*'
824 elif use x86-fbsd ; then
825 case ${egid} in
826 *[!0-9]*) # Non numeric
827 for egid in `jot 898 101`; do
828 [ -z "`egetent group ${egid}`" ] && break
829 done
830 esac
831 pw groupadd ${egroup} -g ${egid} || die "enewgroup failed"
814 else 832 else
815 groupadd ${opts} ${egroup} || die "enewgroup failed" 833 groupadd ${opts} ${egroup} || die "enewgroup failed"
816 fi 834 fi
817 export SANDBOX_ON="${oldsandbox}" 835 export SANDBOX_ON="${oldsandbox}"
818} 836}
819 837
820# Simple script to replace 'dos2unix' binaries 838# Simple script to replace 'dos2unix' binaries
821# vapier@gentoo.org 839# vapier@gentoo.org
822# 840#
823# edos2unix(file, <more files>...) 841# edos2unix(file, <more files> ...)
824edos2unix() { 842edos2unix() {
825 for f in "$@" 843 for f in "$@"
826 do 844 do
827 cp "${f}" ${T}/edos2unix 845 cp "${f}" ${T}/edos2unix
828 sed 's/\r$//' ${T}/edos2unix > "${f}" 846 sed 's/\r$//' ${T}/edos2unix > "${f}"
829 done 847 done
830} 848}
831 849
850
851##############################################################
852# START: Handle .desktop files and menu entries #
853# maybe this should be separated into a new eclass some time #
854# lanius@gentoo.org #
855##############################################################
856
832# Make a desktop file ! 857# Make a desktop file !
833# Great for making those icons in kde/gnome startmenu ! 858# Great for making those icons in kde/gnome startmenu !
834# Amaze your friends ! Get the women ! Join today ! 859# Amaze your friends ! Get the women ! Join today !
835# gnome2 /usr/share/applications
836# gnome1 /usr/share/gnome/apps/
837# KDE ${KDEDIR}/share/applnk /usr/share/applnk
838# 860#
839# make_desktop_entry(<binary>, [name], [icon], [type], [path]) 861# make_desktop_entry(<binary>, [name], [icon], [type], [path])
840# 862#
841# binary: what binary does the app run with ? 863# binary: what binary does the app run with ?
842# name: the name that will show up in the menu 864# name: the name that will show up in the menu
843# icon: give your little like a pretty little icon ... 865# icon: give your little like a pretty little icon ...
844# this can be relative (to /usr/share/pixmaps) or 866# this can be relative (to /usr/share/pixmaps) or
845# a full path to an icon 867# a full path to an icon
846# type: what kind of application is this ? for categories: 868# type: what kind of application is this ? for categories:
847# http://www.freedesktop.org/standards/menu-spec/ 869# http://www.freedesktop.org/standards/menu-spec/
848# path: if your app needs to startup in a specific dir 870# path: if your app needs to startup in a specific dir
849make_desktop_entry() { 871make_desktop_entry() {
850 [ -z "$1" ] && eerror "You must specify the executable" && return 1 872 [ -z "$1" ] && eerror "make_desktop_entry: You must specify the executable" && return 1
851 873
852 local exec="${1}" 874 local exec="${1}"
853 local name="${2:-${PN}}" 875 local name="${2:-${PN}}"
854 local icon="${3:-${PN}.png}" 876 local icon="${3:-${PN}.png}"
855 local type="${4}" 877 local type="${4}"
887Exec=${exec} 909Exec=${exec}
888Path=${path} 910Path=${path}
889Icon=${icon} 911Icon=${icon}
890Categories=Application;${type};" > "${desktop}" 912Categories=Application;${type};" > "${desktop}"
891 913
892 if [ -d "/usr/share/applications" ]
893 then
894 insinto /usr/share/applications 914 insinto /usr/share/applications
895 doins "${desktop}" 915 doins "${desktop}"
896 fi
897
898 #if [ -d "/usr/share/gnome/apps" ]
899 #then
900 # insinto /usr/share/gnome/apps/Games
901 # doins ${desktop}
902 #fi
903
904 #if [ ! -z "`ls /usr/kde/* 2>/dev/null`" ]
905 #then
906 # for ver in /usr/kde/*
907 # do
908 # insinto ${ver}/share/applnk/Games
909 # doins ${desktop}
910 # done
911 #fi
912
913 if [ -d "/usr/share/applnk" ]
914 then
915 insinto /usr/share/applnk/${subdir}
916 doins "${desktop}"
917 fi
918 916
919 return 0 917 return 0
920} 918}
919
920# Make a GDM/KDM Session file
921#
922# make_desktop_entry(<title>, <command>)
923# title: File to execute to start the Window Manager
924# command: Name of the Window Manager
925
926make_session_desktop() {
927
928 [ -z "$1" ] && eerror "make_session_desktop: You must specify the title" && return 1
929 [ -z "$2" ] && eerror "make_session_desktop: You must specify the command" && return 1
930
931 local title="${1}"
932 local command="${2}"
933 local desktop="${T}/${wm}.desktop"
934
935echo "[Desktop Entry]
936Encoding=UTF-8
937Name=${title}
938Comment=This session logs you into ${title}
939Exec=${command}
940TryExec=${command}
941Type=Application" > "${desktop}"
942
943 insinto /usr/share/xsessions
944 doins "${desktop}"
945
946 return 0
947}
948
949domenu() {
950 local i
951 local j
952 insinto /usr/share/applications
953 for i in ${@}
954 do
955 if [ -f "${i}" ];
956 then
957 doins ${i}
958 elif [ -d "${i}" ];
959 then
960 for j in ${i}/*.desktop
961 do
962 doins ${j}
963 done
964 fi
965 done
966}
967
968doicon() {
969 local i
970 local j
971 insinto /usr/share/pixmaps
972 for i in ${@}
973 do
974 if [ -f "${i}" ];
975 then
976 doins ${i}
977 elif [ -d "${i}" ];
978 then
979 for j in ${i}/*.png
980 do
981 doins ${j}
982 done
983 fi
984 done
985}
986
987##############################################################
988# END: Handle .desktop files and menu entries #
989##############################################################
990
921 991
922# for internal use only (unpack_pdv and unpack_makeself) 992# for internal use only (unpack_pdv and unpack_makeself)
923find_unpackable_file() { 993find_unpackable_file() {
924 local src="$1" 994 local src="$1"
925 if [ -z "${src}" ] 995 if [ -z "${src}" ]
971 echo ">>> Unpacking ${shrtsrc} to ${PWD}" 1041 echo ">>> Unpacking ${shrtsrc} to ${PWD}"
972 local metaskip=`tail -c ${sizeoff_t} ${src} | hexdump -e \"%i\"` 1042 local metaskip=`tail -c ${sizeoff_t} ${src} | hexdump -e \"%i\"`
973 local tailskip=`tail -c $((${sizeoff_t}*2)) ${src} | head -c ${sizeoff_t} | hexdump -e \"%i\"` 1043 local tailskip=`tail -c $((${sizeoff_t}*2)) ${src} | head -c ${sizeoff_t} | hexdump -e \"%i\"`
974 1044
975 # grab metadata for debug reasons 1045 # grab metadata for debug reasons
976 local metafile="`mymktemp ${T}`" 1046 local metafile="$(emktemp)"
977 tail -c +$((${metaskip}+1)) ${src} > ${metafile} 1047 tail -c +$((${metaskip}+1)) ${src} > ${metafile}
978 1048
979 # rip out the final file name from the metadata 1049 # rip out the final file name from the metadata
980 local datafile="`tail -c +$((${metaskip}+1)) ${src} | strings | head -n 1`" 1050 local datafile="`tail -c +$((${metaskip}+1)) ${src} | strings | head -n 1`"
981 datafile="`basename ${datafile}`" 1051 datafile="`basename ${datafile}`"
982 1052
983 # now lets uncompress/untar the file if need be 1053 # now lets uncompress/untar the file if need be
984 local tmpfile="`mymktemp ${T}`" 1054 local tmpfile="$(emktemp)"
985 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null | head -c 512 > ${tmpfile} 1055 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null | head -c 512 > ${tmpfile}
986 1056
987 local iscompressed="`file -b ${tmpfile}`" 1057 local iscompressed="`file -b ${tmpfile}`"
988 if [ "${iscompressed:0:8}" == "compress" ] ; then 1058 if [ "${iscompressed:0:8}" == "compress" ] ; then
989 iscompressed=1 1059 iscompressed=1
1034# Unpack those pesky makeself generated files ... 1104# Unpack those pesky makeself generated files ...
1035# They're shell scripts with the binary package tagged onto 1105# They're shell scripts with the binary package tagged onto
1036# the end of the archive. Loki utilized the format as does 1106# the end of the archive. Loki utilized the format as does
1037# many other game companies. 1107# many other game companies.
1038# 1108#
1039# Usage: unpack_makeself [file to unpack] [offset] 1109# Usage: unpack_makeself [file to unpack] [offset] [tail|dd]
1040# - If the file is not specified then unpack will utilize ${A}. 1110# - If the file is not specified then unpack will utilize ${A}.
1041# - If the offset is not specified then we will attempt to extract 1111# - If the offset is not specified then we will attempt to extract
1042# the proper offset from the script itself. 1112# the proper offset from the script itself.
1043unpack_makeself() { 1113unpack_makeself() {
1044 local src="`find_unpackable_file $1`" 1114 local src="$(find_unpackable_file "$1")"
1045 local skip="$2" 1115 local skip="$2"
1116 local exe="$3"
1046 1117
1047 local shrtsrc="`basename ${src}`" 1118 local shrtsrc="$(basename "${src}")"
1048 echo ">>> Unpacking ${shrtsrc} to ${PWD}" 1119 echo ">>> Unpacking ${shrtsrc} to ${PWD}"
1049 if [ -z "${skip}" ] 1120 if [ -z "${skip}" ]
1050 then 1121 then
1051 local ver="`grep -a '#.*Makeself' ${src} | awk '{print $NF}'`" 1122 local ver="`grep -a '#.*Makeself' ${src} | awk '{print $NF}'`"
1052 local skip=0 1123 local skip=0
1124 exe=tail
1053 case ${ver} in 1125 case ${ver} in
1054 1.5.*) # tested 1.5.{3,4,5} ... guessing 1.5.x series is same 1126 1.5.*) # tested 1.5.{3,4,5} ... guessing 1.5.x series is same
1055 skip=`grep -a ^skip= ${src} | cut -d= -f2` 1127 skip=$(grep -a ^skip= "${src}" | cut -d= -f2)
1056 ;; 1128 ;;
1057 2.0|2.0.1) 1129 2.0|2.0.1)
1058 skip=`grep -a ^$'\t'tail ${src} | awk '{print $2}' | cut -b2-` 1130 skip=$(grep -a ^$'\t'tail "${src}" | awk '{print $2}' | cut -b2-)
1059 ;; 1131 ;;
1060 2.1.1) 1132 2.1.1)
1061 skip=`grep -a ^offset= ${src} | awk '{print $2}' | cut -b2-` 1133 skip=$(grep -a ^offset= "${src}" | awk '{print $2}' | cut -b2-)
1062 let skip="skip + 1" 1134 let skip="skip + 1"
1063 ;; 1135 ;;
1064 2.1.2) 1136 2.1.2)
1065 skip=`grep -a ^offset= ${src} | awk '{print $3}' | head -n 1` 1137 skip=$(grep -a ^offset= "${src}" | awk '{print $3}' | head -n 1)
1066 let skip="skip + 1" 1138 let skip="skip + 1"
1067 ;; 1139 ;;
1068 2.1.3) 1140 2.1.3)
1069 skip=`grep -a ^offset= ${src} | awk '{print $3}'` 1141 skip=`grep -a ^offset= "${src}" | awk '{print $3}'`
1070 let skip="skip + 1" 1142 let skip="skip + 1"
1143 ;;
1144 2.1.4)
1145 skip=$(grep -a offset=.*head.*wc "${src}" | awk '{print $3}' | head -n 1)
1146 skip=$(head -n ${skip} "${src}" | wc -c)
1147 exe="dd"
1071 ;; 1148 ;;
1072 *) 1149 *)
1073 eerror "I'm sorry, but I was unable to support the Makeself file." 1150 eerror "I'm sorry, but I was unable to support the Makeself file."
1074 eerror "The version I detected was '${ver}'." 1151 eerror "The version I detected was '${ver}'."
1075 eerror "Please file a bug about the file ${shrtsrc} at" 1152 eerror "Please file a bug about the file ${shrtsrc} at"
1077 die "makeself version '${ver}' not supported" 1154 die "makeself version '${ver}' not supported"
1078 ;; 1155 ;;
1079 esac 1156 esac
1080 debug-print "Detected Makeself version ${ver} ... using ${skip} as offset" 1157 debug-print "Detected Makeself version ${ver} ... using ${skip} as offset"
1081 fi 1158 fi
1159 case ${exe} in
1160 tail) exe="tail -n +${skip} '${src}'";;
1161 dd) exe="dd ibs=${skip} skip=1 obs=1024 conv=sync if='${src}'";;
1162 *) die "makeself cant handle exe '${exe}'"
1163 esac
1082 1164
1083 # lets grab the first few bytes of the file to figure out what kind of archive it is 1165 # lets grab the first few bytes of the file to figure out what kind of archive it is
1084 local tmpfile="`mymktemp ${T}`" 1166 local tmpfile="$(emktemp)"
1085 tail -n +${skip} ${src} 2>/dev/null | head -c 512 > ${tmpfile} 1167 eval ${exe} 2>/dev/null | head -c 512 > "${tmpfile}"
1086 local filetype="`file -b ${tmpfile}`" 1168 local filetype="$(file -b "${tmpfile}")"
1087 case ${filetype} in 1169 case ${filetype} in
1088 *tar\ archive) 1170 *tar\ archive)
1089 tail -n +${skip} ${src} | tar --no-same-owner -xf - 1171 eval ${exe} | tar --no-same-owner -xf -
1090 ;; 1172 ;;
1091 bzip2*) 1173 bzip2*)
1092 tail -n +${skip} ${src} | bzip2 -dc | tar --no-same-owner -xf - 1174 eval ${exe} | bzip2 -dc | tar --no-same-owner -xf -
1093 ;; 1175 ;;
1094 gzip*) 1176 gzip*)
1095 tail -n +${skip} ${src} | tar --no-same-owner -xzf - 1177 eval ${exe} | tar --no-same-owner -xzf -
1096 ;; 1178 ;;
1097 compress*) 1179 compress*)
1098 tail -n +${skip} ${src} | gunzip | tar --no-same-owner -xf - 1180 eval ${exe} | gunzip | tar --no-same-owner -xf -
1099 ;; 1181 ;;
1100 *) 1182 *)
1101 eerror "Unknown filetype \"${filetype}\" ?" 1183 eerror "Unknown filetype \"${filetype}\" ?"
1102 false 1184 false
1103 ;; 1185 ;;
1136 return 0 1218 return 0
1137 fi 1219 fi
1138 done 1220 done
1139 set +o noglob; set -$shopts #reset old shell opts 1221 set +o noglob; set -$shopts #reset old shell opts
1140 1222
1141 local licmsg="`mymktemp ${T}`" 1223 local licmsg="$(emktemp)"
1142 cat << EOF > ${licmsg} 1224 cat << EOF > ${licmsg}
1143********************************************************** 1225**********************************************************
1144The following license outlines the terms of use of this 1226The following license outlines the terms of use of this
1145package. You MUST accept this license for installation to 1227package. You MUST accept this license for installation to
1146continue. When you are done viewing, hit 'q'. If you 1228continue. When you are done viewing, hit 'q'. If you
1194 export CDROM_TOTAL_CDS=${cdcnt} 1276 export CDROM_TOTAL_CDS=${cdcnt}
1195 export CDROM_CURRENT_CD=1 1277 export CDROM_CURRENT_CD=1
1196 1278
1197 # now we see if the user gave use CD_ROOT ... 1279 # now we see if the user gave use CD_ROOT ...
1198 # if they did, let's just believe them that it's correct 1280 # if they did, let's just believe them that it's correct
1199 if [ ! -z "${CD_ROOT}" ] ; then 1281 if [[ ! -z ${CD_ROOT} ]] ; then
1200 export CDROM_ROOT="${CD_ROOT}" 1282 export CDROM_ROOT=${CD_ROOT}
1201 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}" 1283 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1202 return 1284 return
1203 fi 1285 fi
1204 # do the same for CD_ROOT_X 1286 # do the same for CD_ROOT_X
1205 if [ ! -z "${CD_ROOT_1}" ] ; then 1287 if [[ ! -z ${CD_ROOT_1} ]] ; then
1206 local var= 1288 local var=
1207 cdcnt=0 1289 cdcnt=0
1208 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do 1290 while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]] ; do
1209 cdcnt=$((cdcnt + 1)) 1291 cdcnt=$((cdcnt + 1))
1210 var="CD_ROOT_${cdcnt}" 1292 var="CD_ROOT_${cdcnt}"
1211 if [ -z "${!var}" ] ; then 1293 if [[ -z ${!var} ]] ; then
1212 eerror "You must either use just the CD_ROOT" 1294 eerror "You must either use just the CD_ROOT"
1213 eerror "or specify ALL the CD_ROOT_X variables." 1295 eerror "or specify ALL the CD_ROOT_X variables."
1214 eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables." 1296 eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables."
1215 die "could not locate CD_ROOT_${cdcnt}" 1297 die "could not locate CD_ROOT_${cdcnt}"
1216 fi 1298 fi
1219 export CDROM_ROOT=${CDROM_ROOTS_1} 1301 export CDROM_ROOT=${CDROM_ROOTS_1}
1220 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}" 1302 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1221 return 1303 return
1222 fi 1304 fi
1223 1305
1224 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then 1306 if [[ ${CDROM_TOTAL_CDS} -eq 1 ]] ; then
1225 einfon "This ebuild will need the " 1307 einfon "This ebuild will need the "
1226 if [ -z "${CDROM_NAME}" ] ; then 1308 if [[ -z ${CDROM_NAME} ]] ; then
1227 echo "cdrom for ${PN}." 1309 echo "cdrom for ${PN}."
1228 else 1310 else
1229 echo "${CDROM_NAME}." 1311 echo "${CDROM_NAME}."
1230 fi 1312 fi
1231 echo 1313 echo
1232 einfo "If you do not have the CD, but have the data files" 1314 einfo "If you do not have the CD, but have the data files"
1233 einfo "mounted somewhere on your filesystem, just export" 1315 einfo "mounted somewhere on your filesystem, just export"
1234 einfo "the variable CD_ROOT so that it points to the" 1316 einfo "the variable CD_ROOT so that it points to the"
1235 einfo "directory containing the files." 1317 einfo "directory containing the files."
1236 echo 1318 echo
1319 einfo "For example:"
1320 einfo "export CD_ROOT=/mnt/cdrom"
1321 echo
1237 else 1322 else
1238 einfo "This package will need access to ${CDROM_TOTAL_CDS} cds." 1323 einfo "This package will need access to ${CDROM_TOTAL_CDS} cds."
1239 cdcnt=0 1324 cdcnt=0
1240 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do 1325 while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]] ; do
1241 cdcnt=$((cdcnt + 1)) 1326 cdcnt=$((cdcnt + 1))
1242 var="CDROM_NAME_${cdcnt}" 1327 var="CDROM_NAME_${cdcnt}"
1243 [ ! -z "${!var}" ] && einfo " CD ${cdcnt}: ${!var}" 1328 [[ ! -z ${!var} ]] && einfo " CD ${cdcnt}: ${!var}"
1244 done 1329 done
1245 echo 1330 echo
1246 einfo "If you do not have the CDs, but have the data files" 1331 einfo "If you do not have the CDs, but have the data files"
1247 einfo "mounted somewhere on your filesystem, just export" 1332 einfo "mounted somewhere on your filesystem, just export"
1248 einfo "the following variables so they point to the right place:" 1333 einfo "the following variables so they point to the right place:"
1249 einfon "" 1334 einfon ""
1250 cdcnt=0 1335 cdcnt=0
1251 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do 1336 while [[ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ]] ; do
1252 cdcnt=$((cdcnt + 1)) 1337 cdcnt=$((cdcnt + 1))
1253 echo -n " CD_ROOT_${cdcnt}" 1338 echo -n " CD_ROOT_${cdcnt}"
1254 done 1339 done
1255 echo 1340 echo
1256 einfo "Or, if you have all the files in the same place, or" 1341 einfo "Or, if you have all the files in the same place, or"
1257 einfo "you only have one cdrom, you can export CD_ROOT" 1342 einfo "you only have one cdrom, you can export CD_ROOT"
1258 einfo "and that place will be used as the same data source" 1343 einfo "and that place will be used as the same data source"
1259 einfo "for all the CDs." 1344 einfo "for all the CDs."
1260 echo 1345 echo
1346 einfo "For example:"
1347 einfo "export CD_ROOT_1=/mnt/cdrom"
1348 echo
1261 fi 1349 fi
1262 export CDROM_CURRENT_CD=0 1350 export CDROM_CURRENT_CD=0
1263 cdrom_load_next_cd 1351 cdrom_load_next_cd
1264} 1352}
1265 1353
1269# remember, you can only go forward in the cd chain, you can't go back. 1357# remember, you can only go forward in the cd chain, you can't go back.
1270cdrom_load_next_cd() { 1358cdrom_load_next_cd() {
1271 export CDROM_CURRENT_CD=$((CDROM_CURRENT_CD + 1)) 1359 export CDROM_CURRENT_CD=$((CDROM_CURRENT_CD + 1))
1272 local var= 1360 local var=
1273 1361
1274 if [ ! -z "${CD_ROOT}" ] ; then 1362 if [[ ! -z ${CD_ROOT} ]] ; then
1275 einfo "Using same root as before for CD #${CDROM_CURRENT_CD}" 1363 einfo "Using same root as before for CD #${CDROM_CURRENT_CD}"
1276 return 1364 return
1277 fi 1365 fi
1278 1366
1279 unset CDROM_ROOT 1367 unset CDROM_ROOT
1280 var=CDROM_ROOTS_${CDROM_CURRENT_CD} 1368 var=CDROM_ROOTS_${CDROM_CURRENT_CD}
1281 if [ -z "${!var}" ] ; then 1369 if [[ -z ${!var} ]] ; then
1282 var="CDROM_CHECK_${CDROM_CURRENT_CD}" 1370 var="CDROM_CHECK_${CDROM_CURRENT_CD}"
1283 cdrom_locate_file_on_cd ${!var} 1371 cdrom_locate_file_on_cd ${!var}
1284 else 1372 else
1285 export CDROM_ROOT="${!var}" 1373 export CDROM_ROOT=${!var}
1286 fi 1374 fi
1287 1375
1288 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}" 1376 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1289} 1377}
1290 1378
1294# found, then a message asking for the user to insert the cdrom will be 1382# found, then a message asking for the user to insert the cdrom will be
1295# displayed and we'll hang out here until: 1383# displayed and we'll hang out here until:
1296# (1) the file is found on a mounted cdrom 1384# (1) the file is found on a mounted cdrom
1297# (2) the user hits CTRL+C 1385# (2) the user hits CTRL+C
1298cdrom_locate_file_on_cd() { 1386cdrom_locate_file_on_cd() {
1299 while [ -z "${CDROM_ROOT}" ] ; do 1387 while [[ -z ${CDROM_ROOT} ]] ; do
1300 local dir="$(dirname ${@})" 1388 local dir="$(dirname ${@})"
1301 local file="$(basename ${@})" 1389 local file="$(basename ${@})"
1302 local mline="" 1390 local mline=""
1303 local showedmsg=0 1391 local showedmsg=0
1304 1392
1305 for mline in `mount | egrep -e '(iso|cdrom)' | awk '{print $3}'` ; do 1393 for mline in $(mount | egrep -e '(iso|cdrom)' | awk '{print $3}') ; do
1306 [ -d "${mline}/${dir}" ] || continue 1394 [[ -d ${mline}/${dir} ]] || continue
1307 [ ! -z "$(find ${mline}/${dir} -iname ${file} -maxdepth 1)" ] \ 1395 [[ ! -z $(find ${mline}/${dir} -iname ${file} -maxdepth 1) ]] \
1308 && export CDROM_ROOT=${mline} 1396 && export CDROM_ROOT=${mline}
1309 done 1397 done
1310 1398
1311 if [ -z "${CDROM_ROOT}" ] ; then 1399 if [[ -z ${CDROM_ROOT} ]] ; then
1312 echo 1400 echo
1313 if [ ${showedmsg} -eq 0 ] ; then 1401 if [[ ${showedmsg} -eq 0 ]] ; then
1314 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then 1402 if [[ ${CDROM_TOTAL_CDS} -eq 1 ]] ; then
1315 if [ -z "${CDROM_NAME}" ] ; then 1403 if [[ -z ${CDROM_NAME} ]] ; then
1316 einfo "Please insert the cdrom for ${PN} now !" 1404 einfo "Please insert the cdrom for ${PN} now !"
1317 else 1405 else
1318 einfo "Please insert the ${CDROM_NAME} cdrom now !" 1406 einfo "Please insert the ${CDROM_NAME} cdrom now !"
1319 fi 1407 fi
1320 else 1408 else
1321 if [ -z "${CDROM_NAME_1}" ] ; then 1409 if [[ -z ${CDROM_NAME_1} ]] ; then
1322 einfo "Please insert cd #${CDROM_CURRENT_CD} for ${PN} now !" 1410 einfo "Please insert cd #${CDROM_CURRENT_CD} for ${PN} now !"
1323 else 1411 else
1324 local var="CDROM_NAME_${CDROM_CURRENT_CD}" 1412 local var="CDROM_NAME_${CDROM_CURRENT_CD}"
1325 einfo "Please insert+mount the ${!var} cdrom now !" 1413 einfo "Please insert+mount the ${!var} cdrom now !"
1326 fi 1414 fi
1374 1462
1375 ls=" ${ls} " 1463 ls=" ${ls} "
1376 newls="" 1464 newls=""
1377 for f in ${LINGUAS} ; do 1465 for f in ${LINGUAS} ; do
1378 if [ "${ls/ ${f} /}" != "${ls}" ] ; then 1466 if [ "${ls/ ${f} /}" != "${ls}" ] ; then
1379 nl="${newls} ${f}" 1467 newls="${newls} ${f}"
1380 else 1468 else
1381 ewarn "Sorry, but ${PN} does not support the ${f} LINGUA" 1469 ewarn "Sorry, but ${PN} does not support the ${f} LINGUA"
1382 fi 1470 fi
1383 done 1471 done
1384 if [ -z "${newls}" ] ; then 1472 if [ -z "${newls}" ] ; then
1385 unset LINGUAS 1473 unset LINGUAS
1386 else 1474 else
1387 export LINGUAS="${newls}" 1475 export LINGUAS="${newls}"
1388 fi 1476 fi
1389} 1477}
1478
1479# moved from kernel.eclass since they are generally useful outside of
1480# kernel.eclass -iggy (20041002)
1481
1482# the following functions are useful in kernel module ebuilds, etc.
1483# for an example see ivtv or drbd ebuilds
1484
1485# set's ARCH to match what the kernel expects
1486set_arch_to_kernel() {
1487 i=10
1488 while ((i--)) ; do
1489 ewarn "PLEASE UPDATE TO YOUR PACKAGE TO USE linux-info.eclass"
1490 done
1491 export EUTILS_ECLASS_PORTAGE_ARCH="${ARCH}"
1492 case ${ARCH} in
1493 x86) export ARCH="i386";;
1494 amd64) export ARCH="x86_64";;
1495 hppa) export ARCH="parisc";;
1496 mips) export ARCH="mips";;
1497 sparc) export ARCH="$(tc-arch-kernel)";; # Yeah this is ugly, but it's even WORSE if you don't do this. linux-info.eclass's set_arch_to_kernel is fixed, but won't get used over this one!
1498 *) export ARCH="${ARCH}";;
1499 esac
1500}
1501
1502# set's ARCH back to what portage expects
1503set_arch_to_portage() {
1504 i=10
1505 while ((i--)) ; do
1506 ewarn "PLEASE UPDATE TO YOUR PACKAGE TO USE linux-info.eclass"
1507 done
1508 export ARCH="${EUTILS_ECLASS_PORTAGE_ARCH}"
1509}
1510
1511# Jeremy Huddleston <eradicator@gentoo.org>:
1512# preserve_old_lib /path/to/libblah.so.0
1513# preserve_old_lib_notify /path/to/libblah.so.0
1514#
1515# These functions are useful when a lib in your package changes --soname. Such
1516# an example might be from libogg.so.0 to libogg.so.1. Removing libogg.so.0
1517# would break packages that link against it. Most people get around this
1518# by using the portage SLOT mechanism, but that is not always a relevant
1519# solution, so instead you can add the following to your ebuilds:
1520#
1521# src_install() {
1522# ...
1523# preserve_old_lib /usr/$(get_libdir)/libogg.so.0
1524# ...
1525# }
1526#
1527# pkg_postinst() {
1528# ...
1529# preserve_old_lib_notify /usr/$(get_libdir)/libogg.so.0
1530# ...
1531# }
1532
1533preserve_old_lib() {
1534 LIB=$1
1535
1536 if [ -n "${LIB}" -a -f "${ROOT}${LIB}" ]; then
1537 SONAME=`basename ${LIB}`
1538 DIRNAME=`dirname ${LIB}`
1539
1540 dodir ${DIRNAME}
1541 cp ${ROOT}${LIB} ${D}${DIRNAME}
1542 touch ${D}${LIB}
1543 fi
1544}
1545
1546preserve_old_lib_notify() {
1547 LIB=$1
1548
1549 if [ -n "${LIB}" -a -f "${ROOT}${LIB}" ]; then
1550 SONAME=`basename ${LIB}`
1551
1552 einfo "An old version of an installed library was detected on your system."
1553 einfo "In order to avoid breaking packages that link against is, this older version"
1554 einfo "is not being removed. In order to make full use of this newer version,"
1555 einfo "you will need to execute the following command:"
1556 einfo " revdep-rebuild --soname ${SONAME}"
1557 einfo
1558 einfo "After doing that, you can safely remove ${LIB}"
1559 einfo "Note: 'emerge gentoolkit' to get revdep-rebuild"
1560 fi
1561}
1562
1563# Hack for people to figure out if a package was built with
1564# certain USE flags
1565#
1566# Usage: built_with_use [-a|-o] <DEPEND ATOM> <List of USE flags>
1567# ex: built_with_use xchat gtk2
1568#
1569# Flags: -a all USE flags should be utilized
1570# -o at least one USE flag should be utilized
1571# Note: the default flag is '-a'
1572built_with_use() {
1573 local opt=$1
1574 [[ ${opt:0:1} = "-" ]] && shift || opt="-a"
1575
1576 local PKG=$(best_version $1)
1577 shift
1578
1579 local USEFILE="${ROOT}/var/db/pkg/${PKG}/USE"
1580 [[ ! -e ${USEFILE} ]] && return 1
1581
1582 local USE_BUILT=$(<${USEFILE})
1583 while [[ $# -gt 0 ]] ; do
1584 if [[ ${opt} = "-o" ]] ; then
1585 has $1 ${USE_BUILT} && return 0
1586 else
1587 has $1 ${USE_BUILT} || return 1
1588 fi
1589 shift
1590 done
1591 [[ ${opt} = "-a" ]]
1592}
1593
1594# Many configure scripts wrongly bail when a C++ compiler
1595# could not be detected. #73450
1596epunt_cxx() {
1597 local dir=$1
1598 [[ -z ${dir} ]] && dir=${S}
1599 ebegin "Removing useless C++ checks"
1600 local f
1601 for f in $(find ${dir} -name configure) ; do
1602 patch -p0 "${f}" "${PORTDIR}/eclass/ELT-patches/nocxx/nocxx.patch" > /dev/null
1603 done
1604 eend 0
1605}
1606
1607# dopamd [ file ] [ new file ]
1608#
1609# Install pam auth config file in /etc/pam.d
1610#
1611# The first argument, 'file' is required. Install as 'new file', if
1612# specified.
1613
1614dopamd() {
1615 local pamd="$1" newpamd="${2:-$1}"
1616 [[ -z "$1" ]] && die "dopamd requires at least one argument."
1617
1618 use pam || return 0
1619
1620 insinto /etc/pam.d
1621 # these are the default doins options, but be explicit just in case
1622 insopts -m 0644 -o root -g root
1623 newins ${pamd} ${newpamd} || die "failed to install ${newpamd}"
1624}

Legend:
Removed from v.1.106  
changed lines
  Added in v.1.143

  ViewVC Help
Powered by ViewVC 1.1.20