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

Contents of /eclass/eutils.eclass

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.93 - (hide annotations) (download)
Tue Aug 10 01:11:14 2004 UTC (10 years, 2 months ago) by vapier
Branch: MAIN
Changes since 1.92: +5 -1 lines
support compressed makeself files

1 vapier 1.90 # Copyright 1999-2004 Gentoo Foundation
2 azarah 1.1 # Distributed under the terms of the GNU General Public License v2
3 vapier 1.93 # $Header: /var/cvsroot/gentoo-x86/eclass/eutils.eclass,v 1.92 2004/08/03 17:24:52 vapier Exp $
4 vapier 1.18 #
5 azarah 1.1 # Author: Martin Schlemmer <azarah@gentoo.org>
6 vapier 1.18 #
7 azarah 1.1 # This eclass is for general purpose functions that most ebuilds
8 vapier 1.7 # have to implement themselves.
9 azarah 1.1 #
10     # NB: If you add anything, please comment it!
11    
12     ECLASS=eutils
13     INHERITED="$INHERITED $ECLASS"
14    
15 vapier 1.83 DEPEND="!bootstrap? ( sys-devel/patch )"
16 azarah 1.1
17 vapier 1.22 DESCRIPTION="Based on the ${ECLASS} eclass"
18 azarah 1.1
19     # This function generate linker scripts in /usr/lib for dynamic
20     # 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
22     # in some cases when linking dynamic, the .a in /usr/lib is used
23     # instead of the .so in /lib due to gcc/libtool tweaking ld's
24     # library search path. This cause many builds to fail.
25     # See bug #4411 for more info.
26     #
27     # To use, simply call:
28     #
29     # gen_usr_ldscript libfoo.so
30     #
31     # Note that you should in general use the unversioned name of
32     # the library, as ldconfig should usually update it correctly
33     # to point to the latest version of the library present.
34     #
35     # <azarah@gentoo.org> (26 Oct 2002)
36     #
37     gen_usr_ldscript() {
38    
39     # Just make sure it exists
40     dodir /usr/lib
41 danarmak 1.32
42 azarah 1.1 cat > ${D}/usr/lib/$1 <<"END_LDSCRIPT"
43     /* GNU ld script
44     Because Gentoo have critical dynamic libraries
45     in /lib, and the static versions in /usr/lib, we
46     need to have a "fake" dynamic lib in /usr/lib,
47     otherwise we run into linking problems.
48     See bug #4411 on http://bugs.gentoo.org/ for
49     more info. */
50     GROUP ( /lib/libxxx )
51     END_LDSCRIPT
52    
53     dosed "s:libxxx:$1:" /usr/lib/$1
54 azarah 1.5
55     return 0
56 azarah 1.2 }
57    
58 azarah 1.5 # Simple function to draw a line consisting of '=' the same length as $*
59     #
60     # <azarah@gentoo.org> (11 Nov 2002)
61     #
62     draw_line() {
63     local i=0
64     local str_length=""
65    
66     # Handle calls that do not have args, or wc not being installed ...
67     if [ -z "$1" -o ! -x "$(which wc 2>/dev/null)" ]
68     then
69     echo "==============================================================="
70     return 0
71     fi
72    
73     # Get the length of $*
74     str_length="$(echo -n "$*" | wc -m)"
75 danarmak 1.32
76 azarah 1.5 while [ "$i" -lt "${str_length}" ]
77     do
78     echo -n "="
79 danarmak 1.32
80 azarah 1.5 i=$((i + 1))
81     done
82    
83     echo
84    
85     return 0
86     }
87 azarah 1.2
88     # Default directory where patches are located
89     EPATCH_SOURCE="${WORKDIR}/patch"
90     # Default extension for patches
91     EPATCH_SUFFIX="patch.bz2"
92     # Default options for patch
93 solar 1.55 # Set -g0 to keep RCS, ClearCase, Perforce and SCCS happy. Bug #24571
94     EPATCH_OPTS="-g0"
95 azarah 1.6 # List of patches not to apply. Not this is only file names,
96     # and not the full path ..
97     EPATCH_EXCLUDE=""
98 azarah 1.9 # Change the printed message for a single patch.
99     EPATCH_SINGLE_MSG=""
100 azarah 1.29 # Force applying bulk patches even if not following the style:
101     #
102     # ??_${ARCH}_foo.${EPATCH_SUFFIX}
103     #
104     EPATCH_FORCE="no"
105 azarah 1.2
106     # This function is for bulk patching, or in theory for just one
107     # or two patches.
108     #
109     # It should work with .bz2, .gz, .zip and plain text patches.
110     # Currently all patches should be the same format.
111     #
112     # You do not have to specify '-p' option to patch, as it will
113     # try with -p0 to -p5 until it succeed, or fail at -p5.
114     #
115     # Above EPATCH_* variables can be used to control various defaults,
116     # bug they should be left as is to ensure an ebuild can rely on
117     # them for.
118     #
119 azarah 1.3 # Patches are applied in current directory.
120     #
121     # Bulk Patches should preferibly have the form of:
122 azarah 1.2 #
123     # ??_${ARCH}_foo.${EPATCH_SUFFIX}
124     #
125     # For example:
126     #
127     # 01_all_misc-fix.patch.bz2
128     # 02_sparc_another-fix.patch.bz2
129     #
130     # This ensures that there are a set order, and you can have ARCH
131     # specific patches.
132     #
133 azarah 1.3 # If you however give an argument to epatch(), it will treat it as a
134     # single patch that need to be applied if its a file. If on the other
135     # hand its a directory, it will set EPATCH_SOURCE to this.
136     #
137 azarah 1.2 # <azarah@gentoo.org> (10 Nov 2002)
138     #
139     epatch() {
140     local PIPE_CMD=""
141     local STDERR_TARGET="${T}/$$.out"
142 azarah 1.8 local PATCH_TARGET="${T}/$$.patch"
143     local PATCH_SUFFIX=""
144 azarah 1.3 local SINGLE_PATCH="no"
145 azarah 1.4 local x=""
146 azarah 1.3
147     if [ "$#" -gt 1 ]
148     then
149     eerror "Invalid arguments to epatch()"
150     die "Invalid arguments to epatch()"
151     fi
152    
153     if [ -n "$1" -a -f "$1" ]
154     then
155     SINGLE_PATCH="yes"
156 danarmak 1.32
157 azarah 1.4 local EPATCH_SOURCE="$1"
158     local EPATCH_SUFFIX="${1##*\.}"
159 danarmak 1.32
160 azarah 1.3 elif [ -n "$1" -a -d "$1" ]
161     then
162 azarah 1.29 # Allow no extension if EPATCH_FORCE=yes ... used by vim for example ...
163     if [ "${EPATCH_FORCE}" = "yes" ] && [ -z "${EPATCH_SUFFIX}" ]
164     then
165     local EPATCH_SOURCE="$1/*"
166     else
167     local EPATCH_SOURCE="$1/*.${EPATCH_SUFFIX}"
168     fi
169 azarah 1.3 else
170 azarah 1.8 if [ ! -d ${EPATCH_SOURCE} ]
171     then
172 azarah 1.19 if [ -n "$1" -a "${EPATCH_SOURCE}" = "${WORKDIR}/patch" ]
173     then
174     EPATCH_SOURCE="$1"
175     fi
176    
177 azarah 1.8 echo
178 azarah 1.11 eerror "Cannot find \$EPATCH_SOURCE! Value for \$EPATCH_SOURCE is:"
179     eerror
180     eerror " ${EPATCH_SOURCE}"
181 azarah 1.8 echo
182     die "Cannot find \$EPATCH_SOURCE!"
183     fi
184 danarmak 1.32
185 azarah 1.4 local EPATCH_SOURCE="${EPATCH_SOURCE}/*.${EPATCH_SUFFIX}"
186 azarah 1.3 fi
187 azarah 1.2
188     case ${EPATCH_SUFFIX##*\.} in
189     bz2)
190     PIPE_CMD="bzip2 -dc"
191 azarah 1.8 PATCH_SUFFIX="bz2"
192 azarah 1.2 ;;
193 azarah 1.6 gz|Z|z)
194 azarah 1.2 PIPE_CMD="gzip -dc"
195 azarah 1.8 PATCH_SUFFIX="gz"
196 azarah 1.2 ;;
197 azarah 1.6 ZIP|zip)
198 azarah 1.2 PIPE_CMD="unzip -p"
199 azarah 1.8 PATCH_SUFFIX="zip"
200 azarah 1.2 ;;
201     *)
202     PIPE_CMD="cat"
203 azarah 1.8 PATCH_SUFFIX="patch"
204 azarah 1.2 ;;
205     esac
206    
207 azarah 1.3 if [ "${SINGLE_PATCH}" = "no" ]
208     then
209     einfo "Applying various patches (bugfixes/updates)..."
210     fi
211     for x in ${EPATCH_SOURCE}
212 azarah 1.2 do
213     # New ARCH dependant patch naming scheme...
214     #
215     # ???_arch_foo.patch
216     #
217     if [ -f ${x} ] && \
218 azarah 1.29 ([ "${SINGLE_PATCH}" = "yes" -o "${x/_all_}" != "${x}" -o "`eval echo \$\{x/_${ARCH}_\}`" != "${x}" ] || \
219     [ "${EPATCH_FORCE}" = "yes" ])
220 azarah 1.2 then
221     local count=0
222     local popts="${EPATCH_OPTS}"
223 azarah 1.6
224     if [ -n "${EPATCH_EXCLUDE}" ]
225     then
226 azarah 1.9 if [ "`eval echo \$\{EPATCH_EXCLUDE/${x##*/}\}`" != "${EPATCH_EXCLUDE}" ]
227 azarah 1.6 then
228     continue
229     fi
230     fi
231 danarmak 1.32
232 azarah 1.3 if [ "${SINGLE_PATCH}" = "yes" ]
233     then
234 azarah 1.9 if [ -n "${EPATCH_SINGLE_MSG}" ]
235     then
236     einfo "${EPATCH_SINGLE_MSG}"
237     else
238     einfo "Applying ${x##*/}..."
239     fi
240 azarah 1.3 else
241     einfo " ${x##*/}..."
242     fi
243 azarah 1.2
244 azarah 1.8 echo "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
245     echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
246 azarah 1.2
247     # Allow for prefix to differ ... im lazy, so shoot me :/
248     while [ "${count}" -lt 5 ]
249     do
250 azarah 1.5 # Generate some useful debug info ...
251 azarah 1.8 draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
252     echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
253    
254     if [ "${PATCH_SUFFIX}" != "patch" ]
255     then
256     echo -n "PIPE_COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
257     echo "${PIPE_CMD} ${x} > ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
258     else
259     PATCH_TARGET="${x}"
260     fi
261 danarmak 1.32
262 azarah 1.8 echo -n "PATCH COMMAND: " >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
263 vapier 1.88 echo "patch -p${count} ${popts} < ${PATCH_TARGET}" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
264 danarmak 1.32
265 azarah 1.8 echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
266     draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
267    
268     if [ "${PATCH_SUFFIX}" != "patch" ]
269     then
270     if ! (${PIPE_CMD} ${x} > ${PATCH_TARGET}) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
271     then
272     echo
273     eerror "Could not extract patch!"
274     #die "Could not extract patch!"
275     count=5
276     break
277     fi
278     fi
279 danarmak 1.32
280 vapier 1.88 if (cat ${PATCH_TARGET} | patch -p${count} ${popts} --dry-run -f) >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/} 2>&1
281 azarah 1.2 then
282 azarah 1.8 draw_line "***** ${x##*/} *****" > ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
283     echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
284     echo "ACTUALLY APPLYING ${x##*/}..." >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
285     echo >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
286     draw_line "***** ${x##*/} *****" >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
287    
288 vapier 1.88 cat ${PATCH_TARGET} | patch -p${count} ${popts} >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real 2>&1
289 azarah 1.8
290     if [ "$?" -ne 0 ]
291     then
292     cat ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real >> ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
293     echo
294     eerror "A dry-run of patch command succeeded, but actually"
295     eerror "applying the patch failed!"
296     #die "Real world sux compared to the dreamworld!"
297     count=5
298     fi
299    
300     rm -f ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}.real
301 danarmak 1.32
302 azarah 1.2 break
303     fi
304    
305     count=$((count + 1))
306     done
307    
308 azarah 1.8 if [ "${PATCH_SUFFIX}" != "patch" ]
309     then
310     rm -f ${PATCH_TARGET}
311     fi
312    
313 azarah 1.2 if [ "${count}" -eq 5 ]
314     then
315 azarah 1.8 echo
316 azarah 1.2 eerror "Failed Patch: ${x##*/}!"
317     eerror
318     eerror "Include in your bugreport the contents of:"
319     eerror
320 azarah 1.8 eerror " ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}"
321     echo
322 azarah 1.2 die "Failed Patch: ${x##*/}!"
323     fi
324 azarah 1.8
325     rm -f ${STDERR_TARGET%/*}/${x##*/}-${STDERR_TARGET##*/}
326 azarah 1.3
327     eend 0
328 azarah 1.2 fi
329     done
330 azarah 1.3 if [ "${SINGLE_PATCH}" = "no" ]
331     then
332     einfo "Done with patching"
333 azarah 1.10 fi
334 azarah 1.26 }
335    
336     # This function return true if we are using the NPTL pthreads
337     # implementation.
338     #
339     # <azarah@gentoo.org> (06 March 2003)
340     #
341    
342     have_NPTL() {
343    
344     cat > ${T}/test-nptl.c <<-"END"
345     #define _XOPEN_SOURCE
346     #include <unistd.h>
347     #include <stdio.h>
348    
349     int main()
350     {
351     char buf[255];
352     char *str = buf;
353    
354     confstr(_CS_GNU_LIBPTHREAD_VERSION, str, 255);
355     if (NULL != str) {
356     printf("%s\n", str);
357     if (NULL != strstr(str, "NPTL"))
358     return 0;
359     }
360    
361     return 1;
362     }
363     END
364    
365     einfon "Checking for _CS_GNU_LIBPTHREAD_VERSION support in glibc ... "
366     if gcc -o ${T}/nptl ${T}/test-nptl.c &> /dev/null
367     then
368     echo "yes"
369     einfon "Checking what PTHREADS implementation we have ... "
370     if ${T}/nptl
371     then
372     return 0
373     else
374     return 1
375     fi
376     else
377     echo "no"
378     fi
379    
380     return 1
381 azarah 1.10 }
382    
383     # This function check how many cpu's are present, and then set
384     # -j in MAKEOPTS accordingly.
385     #
386     # Thanks to nall <nall@gentoo.org> for this.
387     #
388     get_number_of_jobs() {
389 azarah 1.13 local jobs=0
390    
391 azarah 1.10 if [ ! -r /proc/cpuinfo ]
392     then
393     return 1
394     fi
395    
396 azarah 1.14 # This bit is from H?kan Wessberg <nacka-gentoo@refug.org>, bug #13565.
397     if [ "`egrep "^[[:space:]]*MAKEOPTS=" /etc/make.conf | wc -l`" -gt 0 ]
398     then
399     ADMINOPTS="`egrep "^[[:space:]]*MAKEOPTS=" /etc/make.conf | cut -d= -f2 | sed 's/\"//g'`"
400 azarah 1.17 ADMINPARAM="`echo ${ADMINOPTS} | gawk '{match($0, /-j *[0-9]*/, opt); print opt[0]}'`"
401     ADMINPARAM="${ADMINPARAM/-j}"
402 azarah 1.14 fi
403    
404 azarah 1.17 export MAKEOPTS="`echo ${MAKEOPTS} | sed -e 's:-j *[0-9]*::g'`"
405 danarmak 1.32
406 drobbins 1.35 if [ "${ARCH}" = "amd64" -o "${ARCH}" = "x86" -o "${ARCH}" = "hppa" -o \
407 avenj 1.54 "${ARCH}" = "arm" -o "${ARCH}" = "mips" -o "${ARCH}" = "ia64" ]
408 azarah 1.10 then
409 zwelch 1.21 # these archs will always have "[Pp]rocessor"
410     jobs="$((`grep -c ^[Pp]rocessor /proc/cpuinfo` * 2))"
411 danarmak 1.32
412 azarah 1.10 elif [ "${ARCH}" = "sparc" -o "${ARCH}" = "sparc64" ]
413     then
414     # sparc always has "ncpus active"
415 azarah 1.13 jobs="$((`grep "^ncpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
416 danarmak 1.32
417 azarah 1.10 elif [ "${ARCH}" = "alpha" ]
418     then
419     # alpha has "cpus active", but only when compiled with SMP
420 azarah 1.13 if [ "`grep -c "^cpus active" /proc/cpuinfo`" -eq 1 ]
421 azarah 1.10 then
422 azarah 1.13 jobs="$((`grep "^cpus active" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
423 azarah 1.10 else
424 azarah 1.13 jobs=2
425 azarah 1.10 fi
426 danarmak 1.32
427 brad_mssw 1.78 elif [ "${ARCH}" = "ppc" -o "${ARCH}" = "ppc64" ]
428 azarah 1.10 then
429     # ppc has "processor", but only when compiled with SMP
430 azarah 1.13 if [ "`grep -c "^processor" /proc/cpuinfo`" -eq 1 ]
431 azarah 1.10 then
432 azarah 1.13 jobs="$((`grep -c ^processor /proc/cpuinfo` * 2))"
433 azarah 1.10 else
434 azarah 1.13 jobs=2
435 azarah 1.10 fi
436 iggy 1.87 elif [ "${ARCH}" = "s390" ]
437     then
438     # s390 has "# processors : "
439     jobs="$((`grep "^\# processors" /proc/cpuinfo | sed -e "s/^.*: //"` * 2))"
440 azarah 1.10 else
441 azarah 1.13 jobs="$((`grep -c ^cpu /proc/cpuinfo` * 2))"
442 azarah 1.10 die "Unknown ARCH -- ${ARCH}!"
443 azarah 1.3 fi
444 azarah 1.13
445     # Make sure the number is valid ...
446     if [ "${jobs}" -lt 1 ]
447     then
448     jobs=1
449     fi
450 danarmak 1.32
451 azarah 1.15 if [ -n "${ADMINPARAM}" ]
452 azarah 1.14 then
453 azarah 1.15 if [ "${jobs}" -gt "${ADMINPARAM}" ]
454     then
455     einfo "Setting make jobs to \"-j${ADMINPARAM}\" to ensure successful merge..."
456     export MAKEOPTS="${MAKEOPTS} -j${ADMINPARAM}"
457     else
458     einfo "Setting make jobs to \"-j${jobs}\" to ensure successful merge..."
459     export MAKEOPTS="${MAKEOPTS} -j${jobs}"
460     fi
461 azarah 1.14 fi
462 azarah 1.1 }
463    
464 vapier 1.52 # Cheap replacement for when debianutils (and thus mktemp)
465 vapier 1.80 # does not exist on the users system
466 vapier 1.52 # vapier@gentoo.org
467     #
468     # Takes just 1 parameter (the directory to create tmpfile in)
469     mymktemp() {
470 azarah 1.59 local topdir="$1"
471    
472 vapier 1.52 [ -z "${topdir}" ] && topdir=/tmp
473 azarah 1.59 if [ "`which mktemp 2>/dev/null`" ]
474     then
475 vapier 1.52 mktemp -p ${topdir}
476     else
477     local tmp="${topdir}/tmp.${RANDOM}.${RANDOM}.${RANDOM}"
478     touch ${tmp}
479     echo ${tmp}
480     fi
481     }
482    
483 usata 1.91 # Small wrapper for getent (Linux) and nidump (Mac OS X)
484     # used in enewuser()/enewgroup()
485     # Joe Jezak <josejx@gmail.com> and usata@gentoo.org
486     #
487     # egetent(database, key)
488     egetent() {
489     if [ "${ARCH}" == "macos" ] ; then
490     case "$2" in
491     *[!0-9]*) # Non numeric
492     nidump $1 . | awk -F":" "{ if (\$1 ~ /^$2$/) {print \$0;exit;} }"
493     ;;
494     *) # Numeric
495     nidump $1 . | awk -F":" "{ if (\$3 == $2) {print \$0;exit;} }"
496     ;;
497     esac
498     else
499     getent $1 $2
500     fi
501     }
502    
503 vapier 1.23 # Simplify/standardize adding users to the system
504     # vapier@gentoo.org
505     #
506     # enewuser(username, uid, shell, homedir, groups, extra options)
507     #
508     # Default values if you do not specify any:
509     # username: REQUIRED !
510     # uid: next available (see useradd(8))
511 vapier 1.27 # note: pass -1 to get default behavior
512 vapier 1.23 # shell: /bin/false
513     # homedir: /dev/null
514     # groups: none
515     # extra: comment of 'added by portage for ${PN}'
516     enewuser() {
517     # get the username
518     local euser="$1"; shift
519 azarah 1.59 if [ -z "${euser}" ]
520     then
521 vapier 1.23 eerror "No username specified !"
522     die "Cannot call enewuser without a username"
523     fi
524    
525 vapier 1.84 # lets see if the username already exists
526 usata 1.91 if [ "${euser}" == "`egetent passwd \"${euser}\" | cut -d: -f1`" ]
527 azarah 1.59 then
528 vapier 1.23 return 0
529     fi
530 wolf31o2 1.44 einfo "Adding user '${euser}' to your system ..."
531 vapier 1.23
532     # options to pass to useradd
533 azarah 1.59 local opts=
534 vapier 1.23
535     # handle uid
536     local euid="$1"; shift
537 azarah 1.59 if [ ! -z "${euid}" ] && [ "${euid}" != "-1" ]
538     then
539     if [ "${euid}" -gt 0 ]
540     then
541 usata 1.91 if [ ! -z "`egetent passwd ${euid}`" ]
542 vapier 1.82 then
543 vapier 1.84 euid="next"
544 vapier 1.82 fi
545 vapier 1.23 else
546     eerror "Userid given but is not greater than 0 !"
547     die "${euid} is not a valid UID"
548     fi
549     else
550 vapier 1.84 euid="next"
551     fi
552     if [ "${euid}" == "next" ]
553     then
554 usata 1.91 local pwrange
555     if [ "${ARCH}" == "macos" ] ; then
556     pwrange="`jot 898 101`"
557     else
558     pwrange="`seq 101 999`"
559     fi
560     for euid in ${pwrange} ; do
561     [ -z "`egetent passwd ${euid}`" ] && break
562 vapier 1.84 done
563 vapier 1.23 fi
564 vapier 1.84 opts="${opts} -u ${euid}"
565 vapier 1.23 einfo " - Userid: ${euid}"
566    
567     # handle shell
568     local eshell="$1"; shift
569 vapier 1.67 if [ ! -z "${eshell}" ] && [ "${eshell}" != "-1" ]
570 azarah 1.59 then
571     if [ ! -e "${eshell}" ]
572     then
573 vapier 1.23 eerror "A shell was specified but it does not exist !"
574     die "${eshell} does not exist"
575     fi
576     else
577 azarah 1.59 eshell="/bin/false"
578 vapier 1.23 fi
579     einfo " - Shell: ${eshell}"
580     opts="${opts} -s ${eshell}"
581    
582     # handle homedir
583     local ehome="$1"; shift
584 vapier 1.67 if [ -z "${ehome}" ] && [ "${eshell}" != "-1" ]
585 azarah 1.59 then
586     ehome="/dev/null"
587 vapier 1.23 fi
588     einfo " - Home: ${ehome}"
589     opts="${opts} -d ${ehome}"
590    
591     # handle groups
592     local egroups="$1"; shift
593 azarah 1.59 if [ ! -z "${egroups}" ]
594     then
595 vapier 1.23 local oldifs="${IFS}"
596     export IFS=","
597 azarah 1.59 for g in ${egroups}
598     do
599 usata 1.91 if [ -z "`egetent group \"${g}\"`" ]
600 azarah 1.59 then
601 vapier 1.85 eerror "You must add group ${g} to the system first"
602 vapier 1.23 die "${g} is not a valid GID"
603     fi
604     done
605     export IFS="${oldifs}"
606     opts="${opts} -g ${egroups}"
607     else
608     egroups="(none)"
609     fi
610     einfo " - Groups: ${egroups}"
611    
612     # handle extra and add the user
613     local eextra="$@"
614 azarah 1.59 local oldsandbox="${SANDBOX_ON}"
615 vapier 1.23 export SANDBOX_ON="0"
616 usata 1.91 if [ "${ARCH}" == "macos" ];
617 azarah 1.59 then
618 usata 1.91 ### Make the user
619     if [ -z "${eextra}" ]
620     then
621     dscl . create /users/${euser} uid ${euid}
622     dscl . create /users/${euser} shell ${eshell}
623     dscl . create /users/${euser} home ${ehome}
624     dscl . create /users/${euser} realname "added by portage for ${PN}"
625     ### Add the user to the groups specified
626     for g in ${egroups}
627     do
628     dscl . merge /groups/${g} users ${euser}
629     done
630     else
631     einfo "Extra options are not supported on macos yet"
632     einfo "Please report the ebuild along with the info below"
633     einfo "eextra: ${eextra}"
634     die "Required function missing"
635     fi
636 vapier 1.23 else
637 usata 1.91 if [ -z "${eextra}" ]
638     then
639     useradd ${opts} ${euser} \
640     -c "added by portage for ${PN}" \
641     || die "enewuser failed"
642     else
643     einfo " - Extra: ${eextra}"
644     useradd ${opts} ${euser} ${eextra} \
645     || die "enewuser failed"
646     fi
647 vapier 1.23 fi
648     export SANDBOX_ON="${oldsandbox}"
649    
650 azarah 1.59 if [ ! -e "${ehome}" ] && [ ! -e "${D}/${ehome}" ]
651     then
652 vapier 1.23 einfo " - Creating ${ehome} in ${D}"
653     dodir ${ehome}
654 vapier 1.37 fowners ${euser} ${ehome}
655 vapier 1.38 fperms 755 ${ehome}
656 vapier 1.23 fi
657     }
658    
659     # Simplify/standardize adding groups to the system
660     # vapier@gentoo.org
661     #
662     # enewgroup(group, gid)
663     #
664     # Default values if you do not specify any:
665     # groupname: REQUIRED !
666     # gid: next available (see groupadd(8))
667     # extra: none
668     enewgroup() {
669     # get the group
670     local egroup="$1"; shift
671 azarah 1.59 if [ -z "${egroup}" ]
672     then
673 vapier 1.23 eerror "No group specified !"
674     die "Cannot call enewgroup without a group"
675     fi
676    
677     # see if group already exists
678 usata 1.91 if [ "${egroup}" == "`egetent group \"${egroup}\" | cut -d: -f1`" ]
679 azarah 1.59 then
680 vapier 1.23 return 0
681     fi
682 wolf31o2 1.44 einfo "Adding group '${egroup}' to your system ..."
683 vapier 1.23
684     # options to pass to useradd
685 azarah 1.59 local opts=
686 vapier 1.23
687     # handle gid
688     local egid="$1"; shift
689 azarah 1.59 if [ ! -z "${egid}" ]
690     then
691     if [ "${egid}" -gt 0 ]
692     then
693 usata 1.91 if [ -z "`egetent group ${egid}`" ]
694 vapier 1.83 then
695 usata 1.91 if [ "${ARCH}" == "macos" ] ; then
696     opts="${opts} ${egid}"
697     else
698     opts="${opts} -g ${egid}"
699     fi
700 vapier 1.83 else
701 vapier 1.84 egid="next available; requested gid taken"
702 vapier 1.83 fi
703 vapier 1.23 else
704     eerror "Groupid given but is not greater than 0 !"
705     die "${egid} is not a valid GID"
706     fi
707     else
708     egid="next available"
709     fi
710     einfo " - Groupid: ${egid}"
711    
712     # handle extra
713     local eextra="$@"
714     opts="${opts} ${eextra}"
715    
716     # add the group
717 azarah 1.59 local oldsandbox="${SANDBOX_ON}"
718 vapier 1.23 export SANDBOX_ON="0"
719 usata 1.91 if [ "${ARCH}" == "macos" ];
720     then
721     if [ ! -z "${eextra}" ];
722     then
723     einfo "Extra options are not supported on macos yet"
724     einfo "Please report the ebuild along with the info below"
725     einfo "eextra: ${eextra}"
726     die "Required function missing"
727     fi
728    
729     # If we need the next available
730     case ${egid} in
731     *[!0-9]*) # Non numeric
732     for egid in `jot 898 101`; do
733     [ -z "`egetent group ${egid}`" ] && break
734     done
735     esac
736     dscl . create /groups/${egroup} gid ${egid}
737     dscl . create /groups/${egroup} passwd '*'
738     else
739     groupadd ${opts} ${egroup} || die "enewgroup failed"
740     fi
741 vapier 1.23 export SANDBOX_ON="${oldsandbox}"
742 vapier 1.24 }
743    
744     # Simple script to replace 'dos2unix' binaries
745     # vapier@gentoo.org
746     #
747     # edos2unix(file, <more files>...)
748     edos2unix() {
749 vapier 1.61 for f in "$@"
750 azarah 1.59 do
751 vapier 1.61 cp "${f}" ${T}/edos2unix
752     sed 's/\r$//' ${T}/edos2unix > "${f}"
753 vapier 1.24 done
754 vapier 1.39 }
755    
756     # Make a desktop file !
757     # Great for making those icons in kde/gnome startmenu !
758     # Amaze your friends ! Get the women ! Join today !
759     # gnome2 /usr/share/applications
760     # gnome1 /usr/share/gnome/apps/
761     # KDE ${KDEDIR}/share/applnk /usr/share/applnk
762     #
763     # make_desktop_entry(<binary>, [name], [icon], [type], [path])
764     #
765     # binary: what binary does the app run with ?
766     # name: the name that will show up in the menu
767     # icon: give your little like a pretty little icon ...
768     # this can be relative (to /usr/share/pixmaps) or
769     # a full path to an icon
770     # type: what kind of application is this ? for categories:
771 vapier 1.89 # http://www.freedesktop.org/standards/menu-spec/
772 vapier 1.39 # path: if your app needs to startup in a specific dir
773     make_desktop_entry() {
774     [ -z "$1" ] && eerror "You must specify the executable" && return 1
775    
776 azarah 1.59 local exec="${1}"
777     local name="${2:-${PN}}"
778     local icon="${3:-${PN}.png}"
779     local type="${4}"
780 vapier 1.81 local subdir="${6}"
781 azarah 1.59 local path="${5:-${GAMES_PREFIX}}"
782     if [ -z "${type}" ]
783     then
784 vapier 1.39 case ${CATEGORY} in
785 azarah 1.59 "app-emulation")
786     type=Emulator
787 vapier 1.86 subdir="Emulation"
788 azarah 1.59 ;;
789     "games-"*)
790     type=Game
791 vapier 1.81 subdir="Games"
792 wolf31o2 1.65 ;;
793     "net-"*)
794 vapier 1.81 type=Network
795     subdir="${type}"
796 azarah 1.59 ;;
797     *)
798     type=
799 vapier 1.81 subdir=
800 azarah 1.59 ;;
801 vapier 1.39 esac
802     fi
803 azarah 1.59 local desktop="${T}/${exec}.desktop"
804 vapier 1.39
805     echo "[Desktop Entry]
806     Encoding=UTF-8
807     Version=0.9.2
808     Name=${name}
809     Type=Application
810     Comment=${DESCRIPTION}
811     Exec=${exec}
812     Path=${path}
813     Icon=${icon}
814 vapier 1.40 Categories=Application;${type};" > ${desktop}
815 vapier 1.39
816 azarah 1.59 if [ -d "/usr/share/applications" ]
817     then
818 vapier 1.39 insinto /usr/share/applications
819 vapier 1.40 doins ${desktop}
820 vapier 1.39 fi
821    
822 azarah 1.59 #if [ -d "/usr/share/gnome/apps" ]
823     #then
824 vapier 1.40 # insinto /usr/share/gnome/apps/Games
825     # doins ${desktop}
826     #fi
827    
828 azarah 1.59 #if [ ! -z "`ls /usr/kde/* 2>/dev/null`" ]
829     #then
830     # for ver in /usr/kde/*
831     # do
832 vapier 1.40 # insinto ${ver}/share/applnk/Games
833     # doins ${desktop}
834     # done
835     #fi
836 vapier 1.39
837 azarah 1.59 if [ -d "/usr/share/applnk" ]
838     then
839 vapier 1.81 insinto /usr/share/applnk/${subdir}
840 vapier 1.40 doins ${desktop}
841 vapier 1.39 fi
842    
843     return 0
844 danarmak 1.32 }
845    
846 vapier 1.70 # for internal use only (unpack_pdv and unpack_makeself)
847     find_unpackable_file() {
848 azarah 1.59 local src="$1"
849     if [ -z "${src}" ]
850     then
851 vapier 1.50 src="${DISTDIR}/${A}"
852     else
853 azarah 1.59 if [ -e "${DISTDIR}/${src}" ]
854     then
855 vapier 1.50 src="${DISTDIR}/${src}"
856 azarah 1.59 elif [ -e "${PWD}/${src}" ]
857     then
858 vapier 1.50 src="${PWD}/${src}"
859 azarah 1.59 elif [ -e "${src}" ]
860     then
861 vapier 1.50 src="${src}"
862     fi
863     fi
864 vapier 1.70 [ ! -e "${src}" ] && die "Could not find requested archive ${src}"
865     echo "${src}"
866     }
867    
868     # Unpack those pesky pdv generated files ...
869     # They're self-unpacking programs with the binary package stuffed in
870     # the middle of the archive. Valve seems to use it a lot ... too bad
871     # it seems to like to segfault a lot :(. So lets take it apart ourselves.
872     #
873     # Usage: unpack_pdv [file to unpack] [size of off_t]
874     # - you have to specify the off_t size ... i have no idea how to extract that
875     # information out of the binary executable myself. basically you pass in
876     # the size of the off_t type (in bytes) on the machine that built the pdv
877     # archive. one way to determine this is by running the following commands:
878     # strings <pdv archive> | grep lseek
879     # strace -elseek <pdv archive>
880     # basically look for the first lseek command (we do the strings/grep because
881     # sometimes the function call is _llseek or something) and steal the 2nd
882     # parameter. here is an example:
883     # root@vapier 0 pdv_unpack # strings hldsupdatetool.bin | grep lseek
884     # lseek
885     # root@vapier 0 pdv_unpack # strace -elseek ./hldsupdatetool.bin
886     # lseek(3, -4, SEEK_END) = 2981250
887     # thus we would pass in the value of '4' as the second parameter.
888     unpack_pdv() {
889     local src="`find_unpackable_file $1`"
890     local sizeoff_t="$2"
891    
892     [ -z "${sizeoff_t}" ] && die "No idea what off_t size was used for this pdv :("
893    
894     local shrtsrc="`basename ${src}`"
895     echo ">>> Unpacking ${shrtsrc} to ${PWD}"
896     local metaskip=`tail -c ${sizeoff_t} ${src} | hexdump -e \"%i\"`
897     local tailskip=`tail -c $((${sizeoff_t}*2)) ${src} | head -c ${sizeoff_t} | hexdump -e \"%i\"`
898    
899     # grab metadata for debug reasons
900     local metafile="`mymktemp ${T}`"
901     tail -c +$((${metaskip}+1)) ${src} > ${metafile}
902    
903     # rip out the final file name from the metadata
904     local datafile="`tail -c +$((${metaskip}+1)) ${src} | strings | head -n 1`"
905     datafile="`basename ${datafile}`"
906    
907 vapier 1.71 # now lets uncompress/untar the file if need be
908 vapier 1.70 local tmpfile="`mymktemp ${T}`"
909     tail -c +$((${tailskip}+1)) ${src} 2>/dev/null | head -c 512 > ${tmpfile}
910 vapier 1.71
911     local iscompressed="`file -b ${tmpfile}`"
912     if [ "${iscompressed:0:8}" == "compress" ] ; then
913     iscompressed=1
914     mv ${tmpfile}{,.Z}
915     gunzip ${tmpfile}
916     else
917     iscompressed=0
918     fi
919     local istar="`file -b ${tmpfile}`"
920     if [ "${istar:0:9}" == "POSIX tar" ] ; then
921     istar=1
922     else
923     istar=0
924     fi
925    
926     #for some reason gzip dies with this ... dd cant provide buffer fast enough ?
927     #dd if=${src} ibs=${metaskip} count=1 \
928     # | dd ibs=${tailskip} skip=1 \
929     # | gzip -dc \
930     # > ${datafile}
931     if [ ${iscompressed} -eq 1 ] ; then
932     if [ ${istar} -eq 1 ] ; then
933     tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
934     | head -c $((${metaskip}-${tailskip})) \
935     | tar -xzf -
936     else
937 vapier 1.70 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
938     | head -c $((${metaskip}-${tailskip})) \
939     | gzip -dc \
940     > ${datafile}
941 vapier 1.71 fi
942     else
943     if [ ${istar} -eq 1 ] ; then
944     tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
945     | head -c $((${metaskip}-${tailskip})) \
946 vapier 1.73 | tar --no-same-owner -xf -
947 vapier 1.71 else
948 vapier 1.70 tail -c +$((${tailskip}+1)) ${src} 2>/dev/null \
949     | head -c $((${metaskip}-${tailskip})) \
950     > ${datafile}
951 vapier 1.71 fi
952     fi
953     true
954     #[ -s "${datafile}" ] || die "failure unpacking pdv ('${metaskip}' '${tailskip}' '${datafile}')"
955 vapier 1.70 #assert "failure unpacking pdv ('${metaskip}' '${tailskip}' '${datafile}')"
956     }
957    
958     # Unpack those pesky makeself generated files ...
959     # They're shell scripts with the binary package tagged onto
960     # the end of the archive. Loki utilized the format as does
961     # many other game companies.
962     #
963     # Usage: unpack_makeself [file to unpack] [offset]
964     # - If the file is not specified then unpack will utilize ${A}.
965     # - If the offset is not specified then we will attempt to extract
966     # the proper offset from the script itself.
967     unpack_makeself() {
968     local src="`find_unpackable_file $1`"
969     local skip="$2"
970 vapier 1.50
971 azarah 1.59 local shrtsrc="`basename ${src}`"
972 vapier 1.41 echo ">>> Unpacking ${shrtsrc} to ${PWD}"
973 azarah 1.59 if [ -z "${skip}" ]
974     then
975 vapier 1.41 local ver="`grep -a '#.*Makeself' ${src} | awk '{print $NF}'`"
976     local skip=0
977     case ${ver} in
978     1.5.*) # tested 1.5.{3,4,5} ... guessing 1.5.x series is same
979     skip=`grep -a ^skip= ${src} | cut -d= -f2`
980     ;;
981     2.0|2.0.1)
982     skip=`grep -a ^$'\t'tail ${src} | awk '{print $2}' | cut -b2-`
983     ;;
984 wolf31o2 1.48 2.1.1)
985 vapier 1.41 skip=`grep -a ^offset= ${src} | awk '{print $2}' | cut -b2-`
986 wolf31o2 1.48 let skip="skip + 1"
987     ;;
988 vapier 1.49 2.1.2)
989     skip=`grep -a ^offset= ${src} | awk '{print $3}' | head -n 1`
990     let skip="skip + 1"
991     ;;
992 wolf31o2 1.48 2.1.3)
993     skip=`grep -a ^offset= ${src} | awk '{print $3}'`
994 vapier 1.41 let skip="skip + 1"
995     ;;
996     *)
997     eerror "I'm sorry, but I was unable to support the Makeself file."
998     eerror "The version I detected was '${ver}'."
999     eerror "Please file a bug about the file ${shrtsrc} at"
1000     eerror "http://bugs.gentoo.org/ so that support can be added."
1001     die "makeself version '${ver}' not supported"
1002     ;;
1003     esac
1004     debug-print "Detected Makeself version ${ver} ... using ${skip} as offset"
1005     fi
1006    
1007 vapier 1.68 # lets grab the first few bytes of the file to figure out what kind of archive it is
1008     local tmpfile="`mymktemp ${T}`"
1009     tail -n +${skip} ${src} 2>/dev/null | head -c 512 > ${tmpfile}
1010     local filetype="`file -b ${tmpfile}`"
1011     case ${filetype} in
1012     *tar\ archive)
1013 vapier 1.73 tail -n +${skip} ${src} | tar --no-same-owner -xf -
1014 vapier 1.68 ;;
1015     bzip2*)
1016 vapier 1.73 tail -n +${skip} ${src} | bzip2 -dc | tar --no-same-owner -xf -
1017 mr_bones_ 1.69 ;;
1018 vapier 1.68 gzip*)
1019 vapier 1.73 tail -n +${skip} ${src} | tar --no-same-owner -xzf -
1020 vapier 1.68 ;;
1021 vapier 1.93 compress*)
1022     tail -n +${skip} ${src} | gunzip | tar --no-same-owner -xf -
1023     ;;
1024 vapier 1.68 *)
1025 vapier 1.93 eerror "Unknown filetype \"${filetype}\" ?"
1026 vapier 1.68 false
1027     ;;
1028     esac
1029     assert "failure unpacking (${filetype}) makeself ${shrtsrc} ('${ver}' +${skip})"
1030 wolf31o2 1.56 }
1031    
1032     # Display a license for user to accept.
1033     #
1034     # Usage: check_license [license]
1035     # - If the file is not specified then ${LICENSE} is used.
1036     check_license() {
1037 vapier 1.60 local lic=$1
1038     if [ -z "${lic}" ] ; then
1039     lic="${PORTDIR}/licenses/${LICENSE}"
1040 wolf31o2 1.56 else
1041 vapier 1.60 if [ -e "${PORTDIR}/licenses/${src}" ] ; then
1042     lic="${PORTDIR}/licenses/${src}"
1043     elif [ -e "${PWD}/${src}" ] ; then
1044     lic="${PWD}/${src}"
1045     elif [ -e "${src}" ] ; then
1046     lic="${src}"
1047 wolf31o2 1.56 fi
1048     fi
1049 vapier 1.60 [ ! -f "${lic}" ] && die "Could not find requested license ${src}"
1050 vapier 1.64 local l="`basename ${lic}`"
1051 wolf31o2 1.56
1052 vapier 1.60 # here is where we check for the licenses the user already
1053     # accepted ... if we don't find a match, we make the user accept
1054     local alic
1055 vapier 1.74 for alic in "${ACCEPT_LICENSE}" ; do
1056 vapier 1.60 [ "${alic}" == "*" ] && return 0
1057 vapier 1.64 [ "${alic}" == "${l}" ] && return 0
1058 vapier 1.60 done
1059    
1060     local licmsg="`mymktemp ${T}`"
1061     cat << EOF > ${licmsg}
1062     **********************************************************
1063     The following license outlines the terms of use of this
1064     package. You MUST accept this license for installation to
1065     continue. When you are done viewing, hit 'q'. If you
1066     CTRL+C out of this, the install will not run!
1067     **********************************************************
1068    
1069     EOF
1070     cat ${lic} >> ${licmsg}
1071     ${PAGER:-less} ${licmsg} || die "Could not execute pager (${PAGER}) to accept ${lic}"
1072 vapier 1.64 einfon "Do you accept the terms of this license (${l})? [yes/no] "
1073 vapier 1.60 read alic
1074     case ${alic} in
1075     yes|Yes|y|Y)
1076     return 0
1077     ;;
1078     *)
1079     echo;echo;echo
1080     eerror "You MUST accept the license to continue! Exiting!"
1081     die "Failed to accept license"
1082     ;;
1083     esac
1084 vapier 1.23 }
1085 vapier 1.75
1086     # Aquire cd(s) for those lovely cd-based emerges. Yes, this violates
1087     # the whole 'non-interactive' policy, but damnit I want CD support !
1088     #
1089     # with these cdrom functions we handle all the user interaction and
1090     # standardize everything. all you have to do is call cdrom_get_cds()
1091     # and when the function returns, you can assume that the cd has been
1092     # found at CDROM_ROOT.
1093     #
1094     # normally the cdrom functions will refer to the cds as 'cd #1', 'cd #2',
1095     # etc... if you want to give the cds better names, then just export
1096     # the CDROM_NAME_X variables before calling cdrom_get_cds().
1097     #
1098     # for those multi cd ebuilds, see the cdrom_load_next_cd() below.
1099     #
1100     # Usage: cdrom_get_cds <file on cd1> [file on cd2] [file on cd3] [...]
1101     # - this will attempt to locate a cd based upon a file that is on
1102     # the cd ... the more files you give this function, the more cds
1103     # the cdrom functions will handle
1104     cdrom_get_cds() {
1105     # first we figure out how many cds we're dealing with by
1106     # the # of files they gave us
1107     local cdcnt=0
1108     local f=
1109     for f in "$@" ; do
1110     cdcnt=$((cdcnt + 1))
1111     export CDROM_CHECK_${cdcnt}="$f"
1112     done
1113     export CDROM_TOTAL_CDS=${cdcnt}
1114     export CDROM_CURRENT_CD=1
1115    
1116     # now we see if the user gave use CD_ROOT ...
1117     # if they did, let's just believe them that it's correct
1118     if [ ! -z "${CD_ROOT}" ] ; then
1119     export CDROM_ROOT="${CD_ROOT}"
1120     einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1121     return
1122     fi
1123     # do the same for CD_ROOT_X
1124     if [ ! -z "${CD_ROOT_1}" ] ; then
1125     local var=
1126     cdcnt=0
1127     while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1128     cdcnt=$((cdcnt + 1))
1129     var="CD_ROOT_${cdcnt}"
1130     if [ -z "${!var}" ] ; then
1131     eerror "You must either use just the CD_ROOT"
1132     eerror "or specify ALL the CD_ROOT_X variables."
1133     eerror "In this case, you will need ${CDROM_TOTAL_CDS} CD_ROOT_X variables."
1134     die "could not locate CD_ROOT_${cdcnt}"
1135     fi
1136     export CDROM_ROOTS_${cdcnt}="${!var}"
1137     done
1138     export CDROM_ROOT=${CDROM_ROOTS_1}
1139     einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1140     return
1141     fi
1142    
1143     if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1144     einfon "This ebuild will need the "
1145     if [ -z "${CDROM_NAME}" ] ; then
1146     echo "cdrom for ${PN}."
1147     else
1148     echo "${CDROM_NAME}."
1149     fi
1150     echo
1151     einfo "If you do not have the CD, but have the data files"
1152     einfo "mounted somewhere on your filesystem, just export"
1153     einfo "the variable CD_ROOT so that it points to the"
1154     einfo "directory containing the files."
1155     echo
1156     else
1157     einfo "This package will need access to ${CDROM_TOTAL_CDS} cds."
1158     cdcnt=0
1159     while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1160     cdcnt=$((cdcnt + 1))
1161     var="CDROM_NAME_${cdcnt}"
1162     [ ! -z "${!var}" ] && einfo " CD ${cdcnt}: ${!var}"
1163     done
1164     echo
1165     einfo "If you do not have the CDs, but have the data files"
1166     einfo "mounted somewhere on your filesystem, just export"
1167     einfo "the following variables so they point to the right place:"
1168     einfon ""
1169     cdcnt=0
1170     while [ ${cdcnt} -lt ${CDROM_TOTAL_CDS} ] ; do
1171     cdcnt=$((cdcnt + 1))
1172     echo -n " CD_ROOT_${cdcnt}"
1173     done
1174     echo
1175     einfo "Or, if you have all the files in the same place, or"
1176     einfo "you only have one cdrom, you can export CD_ROOT"
1177     einfo "and that place will be used as the same data source"
1178     einfo "for all the CDs."
1179     echo
1180     fi
1181     export CDROM_CURRENT_CD=0
1182     cdrom_load_next_cd
1183     }
1184    
1185     # this is only used when you need access to more than one cd.
1186     # when you have finished using the first cd, just call this function.
1187     # when it returns, CDROM_ROOT will be pointing to the second cd.
1188     # remember, you can only go forward in the cd chain, you can't go back.
1189     cdrom_load_next_cd() {
1190     export CDROM_CURRENT_CD=$((CDROM_CURRENT_CD + 1))
1191     local var=
1192    
1193 vapier 1.79 if [ ! -z "${CD_ROOT}" ] ; then
1194     einfo "Using same root as before for CD #${CDROM_CURRENT_CD}"
1195     return
1196     fi
1197    
1198 vapier 1.75 unset CDROM_ROOT
1199     var=CDROM_ROOTS_${CDROM_CURRENT_CD}
1200     if [ -z "${!var}" ] ; then
1201     var="CDROM_CHECK_${CDROM_CURRENT_CD}"
1202     cdrom_locate_file_on_cd ${!var}
1203     else
1204     export CDROM_ROOT="${!var}"
1205     fi
1206    
1207     einfo "Found CD #${CDROM_CURRENT_CD} root at ${CDROM_ROOT}"
1208     }
1209    
1210     # this is used internally by the cdrom_get_cds() and cdrom_load_next_cd()
1211     # functions. this should *never* be called from an ebuild.
1212     # all it does is try to locate a give file on a cd ... if the cd isn't
1213     # found, then a message asking for the user to insert the cdrom will be
1214     # displayed and we'll hang out here until:
1215     # (1) the file is found on a mounted cdrom
1216     # (2) the user hits CTRL+C
1217     cdrom_locate_file_on_cd() {
1218     while [ -z "${CDROM_ROOT}" ] ; do
1219     local dir="$(dirname ${@})"
1220     local file="$(basename ${@})"
1221     local mline=""
1222     local showedmsg=0
1223    
1224     for mline in `mount | egrep -e '(iso|cdrom)' | awk '{print $3}'` ; do
1225     [ -d "${mline}/${dir}" ] || continue
1226     [ ! -z "$(find ${mline}/${dir} -iname ${file} -maxdepth 1)" ] \
1227     && export CDROM_ROOT=${mline}
1228     done
1229    
1230     if [ -z "${CDROM_ROOT}" ] ; then
1231     echo
1232     if [ ${showedmsg} -eq 0 ] ; then
1233     if [ ${CDROM_TOTAL_CDS} -eq 1 ] ; then
1234     if [ -z "${CDROM_NAME}" ] ; then
1235     einfo "Please insert the cdrom for ${PN} now !"
1236     else
1237     einfo "Please insert the ${CDROM_NAME} cdrom now !"
1238     fi
1239     else
1240     if [ -z "${CDROM_NAME_1}" ] ; then
1241     einfo "Please insert cd #${CDROM_CURRENT_CD} for ${PN} now !"
1242     else
1243     local var="CDROM_NAME_${CDROM_CURRENT_CD}"
1244     einfo "Please insert+mount the ${!var} cdrom now !"
1245     fi
1246     fi
1247     showedmsg=1
1248     fi
1249     einfo "Press return to scan for the cd again"
1250     einfo "or hit CTRL+C to abort the emerge."
1251     read
1252     fi
1253     done
1254     }
1255 vapier 1.92
1256     # Make sure that LINGUAS only contains languages that
1257     # a package can support
1258     #
1259     # usage: strip-linguas <allow LINGUAS>
1260     # strip-linguas -i <directories of .po files>
1261     # strip-linguas -u <directories of .po files>
1262     #
1263     # The first form allows you to specify a list of LINGUAS.
1264     # The -i builds a list of po files found in all the
1265     # directories and uses the intersection of the lists.
1266     # The -u builds a list of po files found in all the
1267     # directories and uses the union of the lists.
1268     strip-linguas() {
1269     local ls newls
1270     if [ "$1" == "-i" ] || [ "$1" == "-u" ] ; then
1271     local op="$1"; shift
1272     ls=" $(find "$1" -name '*.po' -printf '%f ') "; shift
1273     local d f
1274     for d in "$@" ; do
1275     if [ "${op}" == "-u" ] ; then
1276     newls="${ls}"
1277     else
1278     newls=""
1279     fi
1280     for f in $(find "$d" -name '*.po' -printf '%f ') ; do
1281     if [ "${op}" == "-i" ] ; then
1282     [ "${ls/ ${f} /}" != "${ls}" ] && newls="${newls} ${f}"
1283     else
1284     [ "${ls/ ${f} /}" == "${ls}" ] && newls="${newls} ${f}"
1285     fi
1286     done
1287     ls="${newls}"
1288     done
1289     ls="${ls//.po}"
1290     else
1291     ls="$@"
1292     fi
1293    
1294     ls=" ${ls} "
1295     newls=""
1296     for f in ${LINGUAS} ; do
1297     if [ "${ls/ ${f} /}" != "${ls}" ] ; then
1298     nl="${newls} ${f}"
1299     else
1300     ewarn "Sorry, but ${PN} does not support the ${f} LINGUA"
1301     fi
1302     done
1303     if [ -z "${newls}" ] ; then
1304     unset LINGUAS
1305     else
1306     export LINGUAS="${newls}"
1307     fi
1308     }

  ViewVC Help
Powered by ViewVC 1.1.20