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

Diff of /eclass/eutils.eclass

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

Revision 1.73 Revision 1.82
1# Copyright 1999-2003 Gentoo Technologies, Inc. 1# Copyright 1999-2004 Gentoo Technologies, Inc.
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.73 2003/12/01 20:13:00 vapier Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.82 2004/02/27 20:37:03 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.
422 jobs="$((`grep "^cpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))" 422 jobs="$((`grep "^cpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
423 else 423 else
424 jobs=2 424 jobs=2
425 fi 425 fi
426 426
427 elif [ "${ARCH}" = "ppc" ] 427 elif [ "${ARCH}" = "ppc" -o "${ARCH}" = "ppc64" ]
428 then 428 then
429 # ppc has "processor", but only when compiled with SMP 429 # ppc has "processor", but only when compiled with SMP
430 if [ "`grep -c "^processor" /proc/cpuinfo`" -eq 1 ] 430 if [ "`grep -c "^processor" /proc/cpuinfo`" -eq 1 ]
431 then 431 then
432 jobs="$((`grep -c ^processor /proc/cpuinfo` * 2))" 432 jobs="$((`grep -c ^processor /proc/cpuinfo` * 2))"
456 fi 456 fi
457 fi 457 fi
458} 458}
459 459
460# Cheap replacement for when debianutils (and thus mktemp) 460# Cheap replacement for when debianutils (and thus mktemp)
461# do not exist on the users system 461# does not exist on the users system
462# vapier@gentoo.org 462# vapier@gentoo.org
463# 463#
464# Takes just 1 parameter (the directory to create tmpfile in) 464# Takes just 1 parameter (the directory to create tmpfile in)
465mymktemp() { 465mymktemp() {
466 local topdir="$1" 466 local topdir="$1"
517 local euid="$1"; shift 517 local euid="$1"; shift
518 if [ ! -z "${euid}" ] && [ "${euid}" != "-1" ] 518 if [ ! -z "${euid}" ] && [ "${euid}" != "-1" ]
519 then 519 then
520 if [ "${euid}" -gt 0 ] 520 if [ "${euid}" -gt 0 ]
521 then 521 then
522 chown ${euid} ${tmpfile} >& /dev/null
523 realuser="`ls -l ${tmpfile} | awk '{print $3}'`"
524 if [ "${realuser//[0-9]}" != "" ]
525 then
526 euid="uid is taken; using next available"
527 else
522 opts="${opts} -u ${euid}" 528 opts="${opts} -u ${euid}"
529 fi
523 else 530 else
524 eerror "Userid given but is not greater than 0 !" 531 eerror "Userid given but is not greater than 0 !"
525 die "${euid} is not a valid UID" 532 die "${euid} is not a valid UID"
526 fi 533 fi
527 else 534 else
696 703
697 local exec="${1}" 704 local exec="${1}"
698 local name="${2:-${PN}}" 705 local name="${2:-${PN}}"
699 local icon="${3:-${PN}.png}" 706 local icon="${3:-${PN}.png}"
700 local type="${4}" 707 local type="${4}"
708 local subdir="${6}"
701 local path="${5:-${GAMES_PREFIX}}" 709 local path="${5:-${GAMES_PREFIX}}"
702 if [ -z "${type}" ] 710 if [ -z "${type}" ]
703 then 711 then
704 case ${CATEGORY} in 712 case ${CATEGORY} in
705 "app-emulation") 713 "app-emulation")
706 type=Emulator 714 type=Emulator
715 subdir="Games"
707 ;; 716 ;;
708 "games-"*) 717 "games-"*)
709 type=Game 718 type=Game
719 subdir="Games"
710 ;; 720 ;;
711 "net-"*) 721 "net-"*)
712 type=Network; 722 type=Network
723 subdir="${type}"
713 ;; 724 ;;
714 *) 725 *)
715 type= 726 type=
727 subdir=
716 ;; 728 ;;
717 esac 729 esac
718 fi 730 fi
719 local desktop="${T}/${exec}.desktop" 731 local desktop="${T}/${exec}.desktop"
720 732
750 # done 762 # done
751 #fi 763 #fi
752 764
753 if [ -d "/usr/share/applnk" ] 765 if [ -d "/usr/share/applnk" ]
754 then 766 then
755 insinto /usr/share/applnk/${type} 767 insinto /usr/share/applnk/${subdir}
756 doins ${desktop} 768 doins ${desktop}
757 fi 769 fi
758 770
759 return 0 771 return 0
760}
761
762# new convenience patch wrapper function to eventually replace epatch(),
763# $PATCHES, $PATCHES1, src_unpack:patch, src_unpack:autopatch and
764# /usr/bin/patch
765# Features:
766# - bulk patch handling similar to epatch()'s
767# - automatic patch level detection like epatch()'s
768# - automatic patch uncompression like epatch()'s
769# - doesn't have the --dry-run overhead of epatch() - inspects patchfiles
770# manually instead
771# - once I decide it's production-ready, it'll be called from base_src_unpack
772# to handle $PATCHES to avoid defining src_unpack just to use xpatch
773
774# accepts zero or more parameters specifying patchfiles and/or patchdirs
775
776# known issues:
777# - only supports unified style patches (does anyone _really_ use anything
778# else?)
779# - because it doesn't use --dry-run there is a risk of it failing
780# to find the files to patch, ie detect the patchlevel, properly. It doesn't use
781# any of the backup heuristics that patch employs to discover a filename.
782# however, this isn't dangerous because if it works for the developer who's
783# writing the ebuild, it'll always work for the users, and if it doesn't,
784# then we'll fix it :-)
785# - no support as yet for patches applying outside $S (and not directly in $WORKDIR).
786xpatch() {
787
788 debug-print-function ${FUNCNAME} $*
789
790 local list=
791 local list2=
792 declare -i plevel
793
794 # parse patch sources
795 for x in $*
796 do
797 debug-print "${FUNCNAME}: parsing parameter ${x}"
798 if [ -f "${x}" ]
799 then
800 list="${list} ${x}"
801 elif [ -d "${x}" ]
802 then
803 # handles patchdirs like epatch() for now: no recursion.
804 # patches are sorted by filename, so with an xy_foo naming scheme you'll get the right order.
805 # only patches with _$ARCH_ or _all_ in their filenames are applied.
806 for file in `ls -A ${x}`
807 do
808 debug-print "${FUNCNAME}: parsing in subdir: file ${file}"
809 if [ -f "${x}/${file}" -a "${file}" != "${file/_all_}" -o \
810 "${file}" != "${file/_$ARCH_}" ]
811 then
812 list2="${list2} ${x}/${file}"
813 fi
814 done
815 list="`echo ${list2} | sort` ${list}"
816 else
817 die "Couldn't find ${x}"
818 fi
819 done
820
821 debug-print "${FUNCNAME}: final list of patches: ${list}"
822
823 for x in ${list};
824 do
825 debug-print "${FUNCNAME}: processing ${x}"
826 # deal with compressed files. /usr/bin/file is in the system profile, or should be.
827 case "`/usr/bin/file -b ${x}`" in
828 *gzip*)
829 patchfile="${T}/current.patch"
830 ungzip -c "${x}" > "${patchfile}"
831 ;;
832 *bzip2*)
833 patchfile="${T}/current.patch"
834 bunzip2 -c "${x}" > "${patchfile}"
835 ;;
836 *text*)
837 patchfile="${x}"
838 ;;
839 *)
840 die "Could not determine filetype of patch ${x}"
841 ;;
842 esac
843 debug-print "${FUNCNAME}: patchfile=${patchfile}"
844
845 # determine patchlevel. supports p0 and higher with either $S or $WORKDIR as base.
846 target="`/bin/grep -m 1 '^+++ ' ${patchfile}`"
847 debug-print "${FUNCNAME}: raw target=${target}"
848 # strip target down to the path/filename, remove leading +++
849 target="${target/+++ }"; target="${target%% *}"
850 # duplicate slashes are discarded by patch wrt the patchlevel. therefore we need
851 # to discard them as well to calculate the correct patchlevel.
852 target="${target//\/\//\/}"
853 debug-print "${FUNCNAME}: stripped target=${target}"
854
855 # look for target
856 for basedir in "${S}" "${WORKDIR}" "${PWD}"; do
857 debug-print "${FUNCNAME}: looking in basedir=${basedir}"
858 cd "${basedir}"
859
860 # try stripping leading directories
861 target2="${target}"
862 plevel=0
863 debug-print "${FUNCNAME}: trying target2=${target2}, plevel=${plevel}"
864 while [ ! -f "${target2}" ]
865 do
866 target2="${target2#*/}" # removes piece of target2 upto the first occurence of /
867 plevel=$((plevel+1))
868 debug-print "${FUNCNAME}: trying target2=${target2}, plevel=${plevel}"
869 [ "${target2}" == "${target2/\/}" ] && break
870 done
871 test -f "${target2}" && break
872
873 # try stripping filename - needed to support patches creating new files
874 target2="${target%/*}"
875 plevel=0
876 debug-print "${FUNCNAME}: trying target2=${target2}, plevel=${plevel}"
877 while [ ! -d "${target2}" ]
878 do
879 target2="${target2#*/}" # removes piece of target2 upto the first occurence of /
880 plevel=$((plevel+1))
881 debug-print "${FUNCNAME}: trying target2=${target2}, plevel=${plevel}"
882 [ "${target2}" == "${target2/\/}" ] && break
883 done
884 test -d "${target2}" && break
885
886 done
887
888 test -f "${basedir}/${target2}" || test -d "${basedir}/${target2}" \
889 || die "Could not determine patchlevel for ${x}"
890 debug-print "${FUNCNAME}: determined plevel=${plevel}"
891 # do the patching
892 ebegin "Applying patch ${x##*/}..."
893 /usr/bin/patch -p${plevel} < "${patchfile}" > /dev/null \
894 || die "Failed to apply patch ${x}"
895 eend $?
896
897 done
898
899} 772}
900 773
901# for internal use only (unpack_pdv and unpack_makeself) 774# for internal use only (unpack_pdv and unpack_makeself)
902find_unpackable_file() { 775find_unpackable_file() {
903 local src="$1" 776 local src="$1"
1101 local l="`basename ${lic}`" 974 local l="`basename ${lic}`"
1102 975
1103 # here is where we check for the licenses the user already 976 # here is where we check for the licenses the user already
1104 # accepted ... if we don't find a match, we make the user accept 977 # accepted ... if we don't find a match, we make the user accept
1105 local alic 978 local alic
1106 for alic in ${ACCEPT_LICENSE} ; do 979 for alic in "${ACCEPT_LICENSE}" ; do
1107 [ "${alic}" == "*" ] && return 0 980 [ "${alic}" == "*" ] && return 0
1108 [ "${alic}" == "${l}" ] && return 0 981 [ "${alic}" == "${l}" ] && return 0
1109 done 982 done
1110 983
1111 local licmsg="`mymktemp ${T}`" 984 local licmsg="`mymktemp ${T}`"
1131 eerror "You MUST accept the license to continue! Exiting!" 1004 eerror "You MUST accept the license to continue! Exiting!"
1132 die "Failed to accept license" 1005 die "Failed to accept license"
1133 ;; 1006 ;;
1134 esac 1007 esac
1135} 1008}
1009
1010# Aquire cd(s) for those lovely cd-based emerges. Yes, this violates
1011# the whole 'non-interactive' policy, but damnit I want CD support !
1012#
1013# with these cdrom functions we handle all the user interaction and
1014# standardize everything. all you have to do is call cdrom_get_cds()
1015# and when the function returns, you can assume that the cd has been
1016# found at CDROM_ROOT.
1017#
1018# normally the cdrom functions will refer to the cds as 'cd #1', 'cd #2',
1019# etc... if you want to give the cds better names, then just export
1020# the CDROM_NAME_X variables before calling cdrom_get_cds().
1021#
1022# for those multi cd ebuilds, see the cdrom_load_next_cd() below.
1023#
1024# Usage: cdrom_get_cds <file on cd1> [file on cd2] [file on cd3] [...]
1025# - this will attempt to locate a cd based upon a file that is on
1026# the cd ... the more files you give this function, the more cds
1027# the cdrom functions will handle
1028cdrom_get_cds() {
1029 # first we figure out how many cds we're dealing with by
1030 # the # of files they gave us
1031 local cdcnt=0
1032 local f=
1033 for f in "$@" ; do
1034 cdcnt=$((cdcnt + 1))
1035 export CDROM_CHECK_${cdcnt}="$f"
1036 done
1037 export CDROM_TOTAL_CDS=${cdcnt}
1038 export CDROM_CURRENT_CD=1
1039
1040 # now we see if the user gave use CD_ROOT ...
1041 # if they did, let's just believe them that it's correct
1042 if [ ! -z "${CD_ROOT}" ] ; then
1043 export CDROM_ROOT="${CD_ROOT}"
1044 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1045 return
1046 fi
1047 # do the same for CD_ROOT_X
1048 if [ ! -z "${CD_ROOT_1}" ] ; then
1049 local var=
1050 cdcnt=0
1051 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1052 cdcnt=$((cdcnt + 1))
1053 var="CD_ROOT_${cdcnt}"
1054 if [ -z "${!var}" ] ; then
1055 eerror "You must either use just the CD_ROOT"
1056 eerror "or specify ALL the CD_ROOT_X variables."
1057 eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables."
1058 die "could not locate CD_ROOT_${cdcnt}"
1059 fi
1060 export CDROM_ROOTS_${cdcnt}="${!var}"
1061 done
1062 export CDROM_ROOT=${CDROM_ROOTS_1}
1063 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1064 return
1065 fi
1066
1067 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1068 einfon "This ebuild will need the "
1069 if [ -z "${CDROM_NAME}" ] ; then
1070 echo "cdrom for ${PN}."
1071 else
1072 echo "${CDROM_NAME}."
1073 fi
1074 echo
1075 einfo "If you do not have the CD, but have the data files"
1076 einfo "mounted somewhere on your filesystem, just export"
1077 einfo "the variable CD_ROOT so that it points to the"
1078 einfo "directory containing the files."
1079 echo
1080 else
1081 einfo "This package will need access to ${CDROM_TOTAL_CDS} cds."
1082 cdcnt=0
1083 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1084 cdcnt=$((cdcnt + 1))
1085 var="CDROM_NAME_${cdcnt}"
1086 [ ! -z "${!var}" ] && einfo " CD ${cdcnt}: ${!var}"
1087 done
1088 echo
1089 einfo "If you do not have the CDs, but have the data files"
1090 einfo "mounted somewhere on your filesystem, just export"
1091 einfo "the following variables so they point to the right place:"
1092 einfon ""
1093 cdcnt=0
1094 while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1095 cdcnt=$((cdcnt + 1))
1096 echo -n " CD_ROOT_${cdcnt}"
1097 done
1098 echo
1099 einfo "Or, if you have all the files in the same place, or"
1100 einfo "you only have one cdrom, you can export CD_ROOT"
1101 einfo "and that place will be used as the same data source"
1102 einfo "for all the CDs."
1103 echo
1104 fi
1105 export CDROM_CURRENT_CD=0
1106 cdrom_load_next_cd
1107}
1108
1109# this is only used when you need access to more than one cd.
1110# when you have finished using the first cd, just call this function.
1111# when it returns, CDROM_ROOT will be pointing to the second cd.
1112# remember, you can only go forward in the cd chain, you can't go back.
1113cdrom_load_next_cd() {
1114 export CDROM_CURRENT_CD=$((CDROM_CURRENT_CD + 1))
1115 local var=
1116
1117 if [ ! -z "${CD_ROOT}" ] ; then
1118 einfo "Using same root as before for CD #${CDROM_CURRENT_CD}"
1119 return
1120 fi
1121
1122 unset CDROM_ROOT
1123 var=CDROM_ROOTS_${CDROM_CURRENT_CD}
1124 if [ -z "${!var}" ] ; then
1125 var="CDROM_CHECK_${CDROM_CURRENT_CD}"
1126 cdrom_locate_file_on_cd ${!var}
1127 else
1128 export CDROM_ROOT="${!var}"
1129 fi
1130
1131 einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1132}
1133
1134# this is used internally by the cdrom_get_cds() and cdrom_load_next_cd()
1135# functions. this should *never* be called from an ebuild.
1136# all it does is try to locate a give file on a cd ... if the cd isn't
1137# found, then a message asking for the user to insert the cdrom will be
1138# displayed and we'll hang out here until:
1139# (1) the file is found on a mounted cdrom
1140# (2) the user hits CTRL+C
1141cdrom_locate_file_on_cd() {
1142 while [ -z "${CDROM_ROOT}" ] ; do
1143 local dir="$(dirname ${@})"
1144 local file="$(basename ${@})"
1145 local mline=""
1146 local showedmsg=0
1147
1148 for mline in `mount | egrep -e '(iso|cdrom)' | awk '{print $3}'` ; do
1149 [ -d "${mline}/${dir}" ] || continue
1150 [ ! -z "$(find ${mline}/${dir} -iname ${file} -maxdepth 1)" ] \
1151 && export CDROM_ROOT=${mline}
1152 done
1153
1154 if [ -z "${CDROM_ROOT}" ] ; then
1155 echo
1156 if [ ${showedmsg} -eq 0 ] ; then
1157 if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1158 if [ -z "${CDROM_NAME}" ] ; then
1159 einfo "Please insert the cdrom for ${PN} now !"
1160 else
1161 einfo "Please insert the ${CDROM_NAME} cdrom now !"
1162 fi
1163 else
1164 if [ -z "${CDROM_NAME_1}" ] ; then
1165 einfo "Please insert cd #${CDROM_CURRENT_CD} for ${PN} now !"
1166 else
1167 local var="CDROM_NAME_${CDROM_CURRENT_CD}"
1168 einfo "Please insert+mount the ${!var} cdrom now !"
1169 fi
1170 fi
1171 showedmsg=1
1172 fi
1173 einfo "Press return to scan for the cd again"
1174 einfo "or hit CTRL+C to abort the emerge."
1175 read
1176 fi
1177 done
1178}

Legend:
Removed from v.1.73  
changed lines
  Added in v.1.82

  ViewVC Help
Powered by ViewVC 1.1.20