CRUX-ARM : Home

Home :: Documentation :: Download :: Development :: Community :: Ports :: Packages :: Bugs :: Links :: About :: Donors
Updated to 5.35.1
[pkgutils-cross.git] / src / pkgmk.in
CommitLineData
a0a63413
JB
1#!/bin/bash
2#
3# pkgutils
4#
5# Copyright (c) 2000-2005 Per Liden
0a6aa15d 6# Copyright (c) 2006-2010 by CRUX team (http://crux.nu)
294b104f 7# Patches for crosscompilation by Jose V Beneyto <sepen@crux.nu>
0a6aa15d 8# (CRUX-ARM System Team <devel@crux-arm.nu>)
a0a63413
JB
9#
10# This program is free software; you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation; either version 2 of the License, or
13# (at your option) any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with this program; if not, write to the Free Software
22# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
23# USA.
24#
25
0a6aa15d
VM
26##
27# error codes
28E_GENERAL=1
29E_PKGFILE=2 # invalid Pkgfile
30E_DIR_PERM=3 # (source/build) directory missing or missing read/write permission
31E_DOWNLOAD=4 # error during download
32E_UNPACK=5 # error during unpacking of source file(s)
33E_MD5=6 # md5sum verification failed
34E_FOOTPRINT=7 # footprint check failure
35E_BUILD=8 # error while running 'build()'
36E_INSTALL=9 # error while installing the package via 'pkgadd'
37
a0a63413
JB
38info() {
39 echo "=======> $1"
40}
41
42warning() {
43 info "WARNING: $1" >&2
44}
45
46error() {
47 info "ERROR: $1" >&2
48}
49
50get_filename() {
51 if [[ $1 =~ ^(http|https|ftp|file)://.*/(.+) ]]; then
52 echo "$PKGMK_SOURCE_DIR/${BASH_REMATCH[2]}"
53 else
54 echo $1
55 fi
56}
57
58get_basename() {
59 local FILE="`echo $1 | sed 's|^.*://.*/||g'`"
60 echo $FILE
61}
62
63check_pkgfile() {
64 if [ ! "$name" ]; then
65 error "Variable 'name' not specified in $PKGMK_PKGFILE."
0a6aa15d 66 exit $E_PKGFILE
a0a63413
JB
67 elif [ ! "$version" ]; then
68 error "Variable 'version' not specified in $PKGMK_PKGFILE."
0a6aa15d 69 exit $E_PKGFILE
a0a63413
JB
70 elif [ ! "$release" ]; then
71 error "Variable 'release' not specified in $PKGMK_PKGFILE."
0a6aa15d 72 exit $E_PKGFILE
a0a63413
JB
73 elif [ "`type -t build`" != "function" ]; then
74 error "Function 'build' not specified in $PKGMK_PKGFILE."
0a6aa15d 75 exit $E_PKGFILE
a0a63413
JB
76 fi
77}
78
79check_directory() {
80 if [ ! -d $1 ]; then
81 error "Directory '$1' does not exist."
0a6aa15d 82 exit $E_DIR_PERM
a0a63413
JB
83 elif [ ! -w $1 ]; then
84 error "Directory '$1' not writable."
0a6aa15d 85 exit $E_DIR_PERM
a0a63413
JB
86 elif [ ! -x $1 ] || [ ! -r $1 ]; then
87 error "Directory '$1' not readable."
0a6aa15d 88 exit $E_DIR_PERM
a0a63413
JB
89 fi
90}
91
92check_file() {
93 if [ -e $1 ] && [ ! -w $1 ]; then
94 error "File '$1' is not writable."
95 exit 1
96 fi
97}
98
99download_file() {
100 info "Downloading '$1'."
101
102 if [ ! "`type -p wget`" ]; then
103 error "Command 'wget' not found."
0a6aa15d 104 exit $E_GENERAL
a0a63413
JB
105 fi
106
107 LOCAL_FILENAME=`get_filename $1`
108 LOCAL_FILENAME_PARTIAL="$LOCAL_FILENAME.partial"
109 DOWNLOAD_OPTS="--passive-ftp --no-directories --tries=3 --waitretry=3 \
110 --directory-prefix=$PKGMK_SOURCE_DIR \
111 --output-document=$LOCAL_FILENAME_PARTIAL --no-check-certificate"
112
113 if [ -f "$LOCAL_FILENAME_PARTIAL" ]; then
114 info "Partial download found, trying to resume"
115 RESUME_CMD="-c"
116 fi
117
118 error=1
119
120 BASENAME=`get_basename $1`
121 for REPO in ${PKGMK_SOURCE_MIRRORS[@]}; do
122 REPO="`echo $REPO | sed 's|/$||'`"
123 wget $RESUME_CMD $DOWNLOAD_OPTS $PKGMK_WGET_OPTS $REPO/$BASENAME
124 error=$?
125 if [ $error == 0 ]; then
126 break
127 fi
128 done
129
130 if [ $error != 0 ]; then
131 while true; do
132 wget $RESUME_CMD $DOWNLOAD_OPTS $PKGMK_WGET_OPTS $1
133 error=$?
134 if [ $error != 0 ] && [ "$RESUME_CMD" ]; then
135 info "Partial download failed, restarting"
136 rm -f "$LOCAL_FILENAME_PARTIAL"
137 RESUME_CMD=""
138 else
139 break
140 fi
141 done
142 fi
143
144 if [ $error != 0 ]; then
145 error "Downloading '$1' failed."
0a6aa15d 146 exit $E_DOWNLOAD
a0a63413
JB
147 fi
148
149 mv -f "$LOCAL_FILENAME_PARTIAL" "$LOCAL_FILENAME"
150}
151
152download_source() {
153 local FILE LOCAL_FILENAME
154
155 for FILE in ${source[@]}; do
156 LOCAL_FILENAME=`get_filename $FILE`
157 if [ ! -e $LOCAL_FILENAME ]; then
158 if [ "$LOCAL_FILENAME" = "$FILE" ]; then
159 error "Source file '$LOCAL_FILENAME' not found (can not be downloaded, URL not specified)."
0a6aa15d 160 exit $E_DOWNLOAD
a0a63413
JB
161 else
162 if [ "$PKGMK_DOWNLOAD" = "yes" ]; then
163 download_file $FILE
164 else
165 error "Source file '$LOCAL_FILENAME' not found (use option -d to download)."
0a6aa15d 166 exit $E_DOWNLOAD
a0a63413
JB
167 fi
168 fi
169 fi
170 done
171}
172
173unpack_source() {
174 local FILE LOCAL_FILENAME COMMAND
175
176 for FILE in ${source[@]}; do
177 LOCAL_FILENAME=`get_filename $FILE`
178 case $LOCAL_FILENAME in
0a6aa15d 179 *.tar.gz|*.tar.Z|*.tgz|*.tar.bz2|*.tbz2|*.tar.xz|*.txz|*.tar.lzma|*.zip|*.rpm)
efcfa70d 180 COMMAND="bsdtar -p -o -C $SRC -xf $LOCAL_FILENAME" ;;
a0a63413
JB
181 *)
182 COMMAND="cp $LOCAL_FILENAME $SRC" ;;
183 esac
184
185 echo "$COMMAND"
186
187 $COMMAND
188
189 if [ $? != 0 ]; then
190 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
191 rm -rf $PKGMK_WORK_DIR
192 fi
193 error "Building '$TARGET' failed."
0a6aa15d 194 exit $E_UNPACK
a0a63413
JB
195 fi
196 done
197}
198
199make_md5sum() {
200 local FILE LOCAL_FILENAMES
201
202 if [ "$source" ]; then
203 for FILE in ${source[@]}; do
204 LOCAL_FILENAMES="$LOCAL_FILENAMES `get_filename $FILE`"
205 done
206
207 md5sum $LOCAL_FILENAMES | sed -e 's| .*/| |' | sort -k 2
208 fi
209}
210
211make_footprint() {
212 pkginfo --footprint $TARGET | \
213 sed "s|\tlib/modules/`uname -r`/|\tlib/modules/<kernel-version>/|g" | \
214 sort -k 3
215}
216
217check_md5sum() {
218 local FILE="$PKGMK_WORK_DIR/.tmp"
219
220 cd $PKGMK_ROOT
221
222 if [ -f $PKGMK_MD5SUM ]; then
223 make_md5sum > $FILE.md5sum
224 sort -k 2 $PKGMK_MD5SUM > $FILE.md5sum.orig
225 diff -w -t -U 0 $FILE.md5sum.orig $FILE.md5sum | \
226 sed '/^@@/d' | \
227 sed '/^+++/d' | \
228 sed '/^---/d' | \
229 sed 's/^+/NEW /g' | \
230 sed 's/^-/MISSING /g' > $FILE.md5sum.diff
231 if [ -s $FILE.md5sum.diff ]; then
232 error "Md5sum mismatch found:"
233 cat $FILE.md5sum.diff >&2
234
235 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
236 rm -rf $PKGMK_WORK_DIR
237 fi
238
239 if [ "$PKGMK_CHECK_MD5SUM" = "yes" ]; then
240 error "Md5sum not ok."
0a6aa15d 241 exit $E_MD5
a0a63413
JB
242 fi
243
244 error "Building '$TARGET' failed."
0a6aa15d 245 exit $E_MD5
a0a63413
JB
246 fi
247 else
248 if [ "$PKGMK_CHECK_MD5SUM" = "yes" ]; then
249 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
250 rm -rf $PKGMK_WORK_DIR
251 fi
252 info "Md5sum not found."
0a6aa15d 253 exit $E_MD5
a0a63413
JB
254 fi
255
256 warning "Md5sum not found, creating new."
257 make_md5sum > $PKGMK_MD5SUM
258 fi
259
260 if [ "$PKGMK_CHECK_MD5SUM" = "yes" ]; then
261 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
262 rm -rf $PKGMK_WORK_DIR
263 fi
264 info "Md5sum ok."
265 exit 0
266 fi
267}
268
269strip_files() {
270 local FILE FILTER
271
272 cd $PKG
273
274 if [ -f $PKGMK_ROOT/$PKGMK_NOSTRIP ]; then
275 FILTER="grep -v -f $PKGMK_ROOT/$PKGMK_NOSTRIP"
276 else
277 FILTER="cat"
278 fi
279
280 find . -type f -printf "%P\n" | $FILTER | while read FILE; do
281 case $(file -b "$FILE") in
282 *ELF*executable*not\ stripped)
294b104f 283 $STRIP_CMD --strip-all "$FILE"
a0a63413
JB
284 ;;
285 *ELF*shared\ object*not\ stripped)
294b104f 286 $STRIP_CMD --strip-unneeded "$FILE"
a0a63413
JB
287 ;;
288 current\ ar\ archive)
294b104f 289 $STRIP_CMD --strip-debug "$FILE"
a0a63413
JB
290 esac
291 done
292}
293
294compress_manpages() {
295 local FILE DIR TARGET
296
297 cd $PKG
298
299 find . -type f -path "*/man/man*/*" | while read FILE; do
300 if [ "$FILE" = "${FILE%%.gz}" ]; then
301 gzip -9 "$FILE"
302 fi
303 done
304
305 find . -type l -path "*/man/man*/*" | while read FILE; do
306 TARGET=`readlink -n "$FILE"`
307 TARGET="${TARGET##*/}"
308 TARGET="${TARGET%%.gz}.gz"
309 rm -f "$FILE"
310 FILE="${FILE%%.gz}.gz"
311 DIR=`dirname "$FILE"`
312
313 if [ -e "$DIR/$TARGET" ]; then
314 ln -sf "$TARGET" "$FILE"
315 fi
316 done
317}
318
319check_footprint() {
320 local FILE="$PKGMK_WORK_DIR/.tmp"
321
322 cd $PKGMK_ROOT
323
324 if [ -f $TARGET ]; then
325 make_footprint > $FILE.footprint
326 if [ -f $PKGMK_FOOTPRINT ]; then
327 sort -k 3 $PKGMK_FOOTPRINT > $FILE.footprint.orig
328 diff -w -t -U 0 $FILE.footprint.orig $FILE.footprint | \
329 sed '/^@@/d' | \
330 sed '/^+++/d' | \
331 sed '/^---/d' | \
332 sed 's/^+/NEW /g' | \
333 sed 's/^-/MISSING /g' > $FILE.footprint.diff
334 if [ -s $FILE.footprint.diff ]; then
0a6aa15d
VM
335 if [ "$PKGMK_IGNORE_NEW" = "yes" ] && \
336 [ -z "$(egrep -l ^MISSING $FILE.footprint.diff)" ] ; then
337 info "New files found:"
338 else
339 error "Footprint mismatch found:"
340 BUILD_SUCCESSFUL="no"
341 fi
a0a63413 342 cat $FILE.footprint.diff >&2
a0a63413
JB
343 fi
344 else
345 warning "Footprint not found, creating new."
346 mv $FILE.footprint $PKGMK_FOOTPRINT
347 fi
348 else
349 error "Package '$TARGET' was not found."
350 BUILD_SUCCESSFUL="no"
351 fi
352}
353
354make_work_dir() {
355 export PKG="$PKGMK_WORK_DIR/pkg"
356 export SRC="$PKGMK_WORK_DIR/src"
357 umask 022
358
359 cd $PKGMK_ROOT
360 remove_work_dir
361 mkdir -p $SRC $PKG
362
363 if [ "$PKGMK_IGNORE_MD5SUM" = "no" ]; then
364 check_md5sum
365 fi
366}
367
368remove_work_dir() {
369 rm -rf $PKGMK_WORK_DIR
370}
371
372
373build_package() {
374 local BUILD_SUCCESSFUL="no"
0a6aa15d 375 local COMPRESSION
a0a63413
JB
376
377 check_file "$TARGET"
378 make_work_dir
379
380 if [ "$UID" != "0" ]; then
381 warning "Packages should be built as root."
382 fi
383
384 info "Building '$TARGET'."
385
386 unpack_source
387
388 cd $SRC
389 (set -e -x ; build)
390
391 if [ $? = 0 ]; then
392 if [ "$PKGMK_NO_STRIP" = "no" ]; then
393 strip_files
394 fi
395
396 compress_manpages
397
398 cd $PKG
399 info "Build result:"
0a6aa15d
VM
400
401 case $PKGMK_COMPRESSION_MODE in
402 gz) COMPRESSION="-z" ;;
403 bz2) COMPRESSION="-j" ;;
404 xz) COMPRESSION="-J" ;;
405 esac
406 bsdtar -c $COMPRESSION -f $TARGET * && bsdtar -t -v -f $TARGET
407
a0a63413
JB
408 if [ $? = 0 ]; then
409 BUILD_SUCCESSFUL="yes"
410
411 if [ "$PKGMK_IGNORE_FOOTPRINT" = "yes" ]; then
412 warning "Footprint ignored."
413 else
414 check_footprint
415 fi
416 fi
417 fi
418
419 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
420 remove_work_dir
421 fi
422
423 if [ "$BUILD_SUCCESSFUL" = "yes" ]; then
424 info "Building '$TARGET' succeeded."
425 else
426 if [ -f $TARGET ]; then
427 touch -r $PKGMK_ROOT/$PKGMK_PKGFILE $TARGET &> /dev/null
428 fi
429 error "Building '$TARGET' failed."
430 exit 1
431 fi
432}
433
434install_package() {
435 local COMMAND
436
437 info "Installing '$TARGET'."
438
439 if [ "$PKGMK_INSTALL" = "install" ]; then
440 COMMAND="pkgadd $TARGET"
441 else
442 COMMAND="pkgadd -u $TARGET"
443 fi
444
445 cd $PKGMK_ROOT
446 echo "$COMMAND"
447 $COMMAND
448
449 if [ $? = 0 ]; then
450 info "Installing '$TARGET' succeeded."
451 else
452 error "Installing '$TARGET' failed."
453 exit 1
454 fi
455}
456
457recursive() {
458 local ARGS FILE DIR
459
460 ARGS=`echo "$@" | sed -e "s/--recursive//g" -e "s/-r//g"`
461
462 for FILE in `find $PKGMK_ROOT -name $PKGMK_PKGFILE | sort`; do
463 DIR="`dirname $FILE`/"
464 if [ -d $DIR ]; then
465 info "Entering directory '$DIR'."
466 (cd $DIR && $PKGMK_COMMAND $ARGS)
467 info "Leaving directory '$DIR'."
468 fi
469 done
470}
471
472clean() {
473 local FILE LOCAL_FILENAME
474
475 if [ -f $TARGET ]; then
476 info "Removing $TARGET"
477 rm -f $TARGET
478 fi
479
480 for FILE in ${source[@]}; do
481 LOCAL_FILENAME=`get_filename $FILE`
482 if [ -e $LOCAL_FILENAME ] && [ "$LOCAL_FILENAME" != "$FILE" ]; then
483 info "Removing $LOCAL_FILENAME"
484 rm -f $LOCAL_FILENAME
485 fi
486 done
487}
488
489update_footprint() {
490 if [ ! -f $TARGET ]; then
491 error "Unable to update footprint. File '$TARGET' not found."
492 exit 1
493 fi
494
495 check_file "$PKGMK_FOOTPRINT"
496 make_footprint > $PKGMK_FOOTPRINT
497 touch $TARGET
498
499 info "Footprint updated."
500}
501
502build_needed() {
503 local FILE RESULT
504
505 RESULT="yes"
506 if [ -f $TARGET ]; then
507 RESULT="no"
508 for FILE in $PKGMK_PKGFILE ${source[@]}; do
509 FILE=`get_filename $FILE`
510 if [ ! -e $FILE ] || [ ! $TARGET -nt $FILE ]; then
511 RESULT="yes"
512 break
513 fi
514 done
515 fi
516
517 echo $RESULT
518}
519
520interrupted() {
521 echo ""
522 error "Interrupted."
523
524 if [ "$PKGMK_KEEP_WORK" = "no" ]; then
525 rm -rf $PKGMK_WORK_DIR
526 fi
527
528 exit 1
529}
530
531print_help() {
532 echo "usage: `basename $PKGMK_COMMAND` [options]"
533 echo "options:"
534 echo " -i, --install build and install package"
535 echo " -u, --upgrade build and install package (as upgrade)"
536 echo " -r, --recursive search for and build packages recursively"
537 echo " -d, --download download missing source file(s)"
538 echo " -do, --download-only do not build, only download missing source file(s)"
539 echo " -eo, --extract-only do not build, only extract source file(s)"
540 echo " -utd, --up-to-date do not build, only check if package is up to date"
541 echo " -uf, --update-footprint update footprint using result from last build"
542 echo " -if, --ignore-footprint build package without checking footprint"
0a6aa15d 543 echo " -in, --ignore-new build package, ignore new files in a footprint missmatch"
a0a63413
JB
544 echo " -um, --update-md5sum update md5sum"
545 echo " -im, --ignore-md5sum build package without checking md5sum"
546 echo " -cm, --check-md5sum do not build, only check md5sum"
547 echo " -ns, --no-strip do not strip executable binaries or libraries"
548 echo " -f, --force build package even if it appears to be up to date"
549 echo " -c, --clean remove package and downloaded files"
550 echo " -kw, --keep-work keep temporary working directory"
551 echo " -cf, --config-file <file> use alternative configuration file"
552 echo " -v, --version print version and exit "
553 echo " -h, --help print help and exit"
554}
555
556parse_options() {
557 while [ "$1" ]; do
558 case $1 in
559 -i|--install)
560 PKGMK_INSTALL="install" ;;
561 -u|--upgrade)
562 PKGMK_INSTALL="upgrade" ;;
563 -r|--recursive)
564 PKGMK_RECURSIVE="yes" ;;
565 -d|--download)
566 PKGMK_DOWNLOAD="yes" ;;
567 -do|--download-only)
568 PKGMK_DOWNLOAD="yes"
569 PKGMK_DOWNLOAD_ONLY="yes" ;;
570 -eo|--extract-only)
571 PKGMK_EXTRACT_ONLY="yes" ;;
572 -utd|--up-to-date)
573 PKGMK_UP_TO_DATE="yes" ;;
574 -uf|--update-footprint)
575 PKGMK_UPDATE_FOOTPRINT="yes" ;;
576 -if|--ignore-footprint)
577 PKGMK_IGNORE_FOOTPRINT="yes" ;;
0a6aa15d
VM
578 -in|--ignore-new)
579 PKGMK_IGNORE_NEW="yes" ;;
a0a63413
JB
580 -um|--update-md5sum)
581 PKGMK_UPDATE_MD5SUM="yes" ;;
582 -im|--ignore-md5sum)
583 PKGMK_IGNORE_MD5SUM="yes" ;;
584 -cm|--check-md5sum)
585 PKGMK_CHECK_MD5SUM="yes" ;;
586 -ns|--no-strip)
587 PKGMK_NO_STRIP="yes" ;;
588 -f|--force)
589 PKGMK_FORCE="yes" ;;
590 -c|--clean)
591 PKGMK_CLEAN="yes" ;;
592 -kw|--keep-work)
593 PKGMK_KEEP_WORK="yes" ;;
594 -cf|--config-file)
595 if [ ! "$2" ]; then
596 echo "`basename $PKGMK_COMMAND`: option $1 requires an argument"
597 exit 1
598 fi
599 PKGMK_CONFFILE="$2"
600 shift ;;
601 -v|--version)
602 echo "`basename $PKGMK_COMMAND` (pkgutils) $PKGMK_VERSION"
603 exit 0 ;;
604 -h|--help)
605 print_help
606 exit 0 ;;
607 *)
608 echo "`basename $PKGMK_COMMAND`: invalid option $1"
609 exit 1 ;;
610 esac
611 shift
612 done
613}
614
615main() {
616 local FILE TARGET
617
618 parse_options "$@"
619
620 if [ "$PKGMK_RECURSIVE" = "yes" ]; then
621 recursive "$@"
622 exit 0
623 fi
624
625 for FILE in $PKGMK_PKGFILE $PKGMK_CONFFILE; do
626 if [ ! -f $FILE ]; then
627 error "File '$FILE' not found."
628 exit 1
629 fi
630 . $FILE
631 done
632
633 check_directory "$PKGMK_SOURCE_DIR"
634 check_directory "$PKGMK_PACKAGE_DIR"
635 check_directory "`dirname $PKGMK_WORK_DIR`"
636
637 check_pkgfile
0a6aa15d
VM
638
639 case $PKGMK_COMPRESSION_MODE in
640 gz|bz2|xz)
641 TARGET="$PKGMK_PACKAGE_DIR/$name#$version-$release.pkg.tar.$PKGMK_COMPRESSION_MODE"
642 ;;
643 *)
644 error "Compression mode '$PKGMK_COMPRESSION_MODE' not supported"
645 exit 1
646 ;;
647 esac
648
a0a63413
JB
649 if [ "$PKGMK_CLEAN" = "yes" ]; then
650 clean
651 exit 0
652 fi
653
654 if [ "$PKGMK_UPDATE_FOOTPRINT" = "yes" ]; then
655 update_footprint
656 exit 0
657 fi
658
659 if [ "$PKGMK_UPDATE_MD5SUM" = "yes" ]; then
660 download_source
661 check_file "$PKGMK_MD5SUM"
662 make_md5sum > $PKGMK_MD5SUM
663 info "Md5sum updated."
664 exit 0
665 fi
666
667 if [ "$PKGMK_DOWNLOAD_ONLY" = "yes" ]; then
668 download_source
669 exit 0
670 fi
671
672 if [ "$PKGMK_EXTRACT_ONLY" = "yes" ]; then
673 download_source
674 make_work_dir
675 info "Extracting sources of package '$name-$version'."
676 unpack_source
677 exit 0
678 fi
679
680 if [ "$PKGMK_UP_TO_DATE" = "yes" ]; then
681 if [ "`build_needed`" = "yes" ]; then
682 info "Package '$TARGET' is not up to date."
683 else
684 info "Package '$TARGET' is up to date."
685 fi
686 exit 0
687 fi
688
689 if [ "`build_needed`" = "no" ] && [ "$PKGMK_FORCE" = "no" ] && [ "$PKGMK_CHECK_MD5SUM" = "no" ]; then
690 info "Package '$TARGET' is up to date."
691 else
692 download_source
693 build_package
694 fi
695
696 if [ "$PKGMK_INSTALL" != "no" ]; then
697 install_package
698 fi
699
700 exit 0
701}
702
703trap "interrupted" SIGHUP SIGINT SIGQUIT SIGTERM
704
705export LC_ALL=POSIX
706
707readonly PKGMK_VERSION="#VERSION#"
708readonly PKGMK_COMMAND="$0"
709readonly PKGMK_ROOT="$PWD"
710
711PKGMK_CONFFILE="/etc/pkgmk.conf"
712PKGMK_PKGFILE="Pkgfile"
713PKGMK_FOOTPRINT=".footprint"
714PKGMK_MD5SUM=".md5sum"
715PKGMK_NOSTRIP=".nostrip"
716
717PKGMK_SOURCE_MIRRORS=()
718PKGMK_SOURCE_DIR="$PWD"
719PKGMK_PACKAGE_DIR="$PWD"
720PKGMK_WORK_DIR="$PWD/work"
721
0a6aa15d
VM
722PKGMK_COMPRESSION_MODE="gz"
723
a0a63413
JB
724PKGMK_INSTALL="no"
725PKGMK_RECURSIVE="no"
726PKGMK_DOWNLOAD="no"
727PKGMK_DOWNLOAD_ONLY="no"
728PKGMK_EXTRACT_ONLY="no"
729PKGMK_UP_TO_DATE="no"
730PKGMK_UPDATE_FOOTPRINT="no"
731PKGMK_IGNORE_FOOTPRINT="no"
0a6aa15d 732PKGMK_IGNORE_NEW="no"
a0a63413
JB
733PKGMK_FORCE="no"
734PKGMK_KEEP_WORK="no"
735PKGMK_UPDATE_MD5SUM="no"
736PKGMK_IGNORE_MD5SUM="no"
737PKGMK_CHECK_MD5SUM="no"
738PKGMK_NO_STRIP="no"
739PKGMK_CLEAN="no"
740
741main "$@"
742
743# End of file