15 |
export LC_ALL=C |
export LC_ALL=C |
16 |
|
|
17 |
# first of all include common functions |
# first of all include common functions |
18 |
source ${MLIBDIR}/common.functions.sh |
source ${MLIBDIR}/common.functions.sh || exit 1 |
19 |
source @@SYSCONFDIR@@/mage.rc.global |
source @@SYSCONFDIR@@/mage.rc.global || die "@@SYSCONFDIR@@/mage.rc.global missing." |
20 |
source ${MAGERC} |
source ${MAGERC} || die "${MAGERC} missing." |
21 |
source ${MLIBDIR}/mage4.functions.sh |
source ${MLIBDIR}/mage4.functions.sh || die "${MLIBDIR}/mage4.functions.sh missing." |
22 |
source ${MLIBDIR}/smage2.functions.sh |
source ${MLIBDIR}/smage2.functions.sh || die "${MLIBDIR}/smage2.functions.sh missing." |
23 |
|
|
24 |
# export default path |
# export default path |
25 |
export PATH="${PATH}:${MLIBDIR}" |
export PATH="${PATH}:${MLIBDIR}" |
26 |
|
|
27 |
|
print_usage() |
28 |
|
{ |
29 |
|
echo "Usage: $(basename $0) [option] pkgname ..." |
30 |
|
echo "Options:" |
31 |
|
echo "--smage" |
32 |
|
echo "--src-tarball" |
33 |
|
echo "--calc" |
34 |
|
echo "--update" |
35 |
|
echo "--download" |
36 |
|
echo "--regen" |
37 |
|
echo "--create-src-tarball" |
38 |
|
echo "--resume" |
39 |
|
echo |
40 |
|
echo "Environment variables::" |
41 |
|
echo " NOCOLORS=true $(basename $0) [src]install PACKAGE" |
42 |
|
echo " Disables all colors in the messages." |
43 |
|
echo |
44 |
|
} |
45 |
|
|
46 |
|
# very basic getops |
47 |
|
for i in $* |
48 |
|
do |
49 |
|
case $1 in |
50 |
|
--smage|*.${SMAGESUFFIX}) shift; SMAGENAME="$1" ;; |
51 |
|
--src-tarball) shift; SRCPKGTARBALL="$1" ;; |
52 |
|
--calc) shift; SMAGENAME="$1" ;; |
53 |
|
--update) ;; |
54 |
|
--download) shift; SMAGENAME="$1" ;; |
55 |
|
--regen) shift; SMAGENAME="$1" ;; |
56 |
|
--create-src-tarball) shift; SMAGENAME="$1" ;; |
57 |
|
--resume) ;; |
58 |
|
esac |
59 |
|
shift |
60 |
|
done |
61 |
|
|
62 |
## setup ## |
## setup ## |
63 |
SMAGENAME="$1" |
SMAGENAME="$1" |
64 |
|
|
286 |
SMAGENAME="$2" |
SMAGENAME="$2" |
287 |
fi |
fi |
288 |
|
|
289 |
[ ! -e ${MLIBDIR}/pkgbuild_dir.sh ] && die "Error: ${MLIBDIR}/pkgbuild_dir.sh not found. Aborting." |
[ ! -e ${MLIBDIR}/pkgbuild_dir ] && die "Error: ${MLIBDIR}/pkgbuild_dir not found. Aborting." |
290 |
[ -z "$(basename ${SMAGENAME} | grep .${SMAGESUFFIX})" ] && |
[ -z "$(basename ${SMAGENAME} | grep .${SMAGESUFFIX})" ] && |
291 |
die "File '$(basename ${SMAGENAME})' is not a sMage v${SMAGEVERSION} file. Aborting." |
die "File '$(basename ${SMAGENAME})' is not a sMage v${SMAGEVERSION} file. Aborting." |
292 |
[ -z "${SOURCEDIR}" ] && die "\$SOURCEDIR not found. Please setup your ${MAGERC} correctly." |
[ -z "${SOURCEDIR}" ] && die "\$SOURCEDIR not found. Please setup your ${MAGERC} correctly." |
300 |
smagesource ${SMAGENAME} || die "source failed" |
smagesource ${SMAGENAME} || die "source failed" |
301 |
PKGNAME="${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" |
PKGNAME="${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" |
302 |
MD5DIR="$(dirname ${SMAGENAME})/md5" |
MD5DIR="$(dirname ${SMAGENAME})/md5" |
303 |
SMAGE_LOG_CMD="tee -a /var/log/smage/${PKGNAME}.log" |
SMAGE_LOG_CMD="tee -a ${SMAGELOGDIR}/${PKGNAME}.log" |
304 |
|
|
305 |
xtitle "Compiling ${PKGNAME}" |
xtitle "Compiling ${PKGNAME}" |
306 |
echo -e "${COLGREEN}Compiling ${PKGNAME}${COLDEFAULT}" |
echo -e "${COLGREEN}Compiling ${PKGNAME}${COLDEFAULT}" |
318 |
mqueryfeature "srcpkgtarball" || download_sources |
mqueryfeature "srcpkgtarball" || download_sources |
319 |
|
|
320 |
# fixes some issues with these functions |
# fixes some issues with these functions |
321 |
|
export -f pkg_setup || die "pkg_setup export failed" |
322 |
export -f src_prepare || die "src_prepare export failed" |
export -f src_prepare || die "src_prepare export failed" |
323 |
export -f src_compile || die "src_compile export failed" |
export -f src_compile || die "src_compile export failed" |
324 |
export -f src_check || die "src_check export failed" |
export -f src_check || die "src_check export failed" |
326 |
|
|
327 |
# fixes some compile issues |
# fixes some compile issues |
328 |
export CHOST="${CHOST}" || die "CHOST export failed" |
export CHOST="${CHOST}" || die "CHOST export failed" |
329 |
|
export CPPFLAGS="${CPPFLAGS}" || die "CPPFLAGS export failed" |
330 |
export CFLAGS="${CFLAGS}" || die "CFLAGS export failed" |
export CFLAGS="${CFLAGS}" || die "CFLAGS export failed" |
331 |
if [[ -z ${CXXFLAGS} ]] |
if [[ -z ${CXXFLAGS} ]] |
332 |
then |
then |
354 |
echo -e "${COLMAGENTA}Resume requested; continuing previous build${COLDEFAULT}" |
echo -e "${COLMAGENTA}Resume requested; continuing previous build${COLDEFAULT}" |
355 |
|
|
356 |
# setup build logging |
# setup build logging |
357 |
[[ ! -d /var/log/smage ]] && install -d /var/log/smage |
[[ ! -d ${SMAGELOGDIR} ]] && install -d ${SMAGELOGDIR} |
358 |
if [[ -f /var/log/smage/${PKGNAME}.log.bz2 ]] |
if [[ -f ${SMAGELOGDIR}/${PKGNAME}.log.bz2 ]] |
359 |
then |
then |
360 |
bunzip2 -f /var/log/smage/${PKGNAME}.log.bz2 |
bunzip2 -f ${SMAGELOGDIR}/${PKGNAME}.log.bz2 |
361 |
fi |
fi |
362 |
echo -e "### Resume started on $(date) ###\n" >> /var/log/smage/${PKGNAME}.log |
echo -e "### Resume started on $(date) ###\n" >> ${SMAGELOGDIR}/${PKGNAME}.log |
363 |
|
|
364 |
else |
else |
365 |
# clean up builddir if a previously one exist |
# clean up builddir if a previously one exist |
395 |
fi |
fi |
396 |
|
|
397 |
# setup build logging |
# setup build logging |
398 |
[[ ! -d /var/log/smage ]] && install -d /var/log/smage |
[[ ! -d ${SMAGELOGDIR} ]] && install -d ${SMAGELOGDIR} |
399 |
echo -e "### Build started on $(date) ###\n" > /var/log/smage/${PKGNAME}.log |
echo -e "### Build started on $(date) ###\n" > ${SMAGELOGDIR}/${PKGNAME}.log |
400 |
fi |
fi |
401 |
|
|
402 |
if [[ ${PKGTYPE} = virtual ]] |
if [[ ${PKGTYPE} = virtual ]] |
405 |
# automatically set !pkgbuild here too |
# automatically set !pkgbuild here too |
406 |
msetfeature "!pkgbuild" |
msetfeature "!pkgbuild" |
407 |
else |
else |
408 |
( run_resume src_prepare || src_prepare ) | ${SMAGE_LOG_CMD} |
( run_resume pkg_setup || pkg_setup ) |& ${SMAGE_LOG_CMD} |
409 |
|
die_pipestatus 0 "pkg_setup failed" |
410 |
|
resume_stamp pkg_setup |
411 |
|
step_by_step pkg_setup |
412 |
|
|
413 |
|
( run_resume src_prepare || src_prepare ) |& ${SMAGE_LOG_CMD} |
414 |
die_pipestatus 0 "src_prepare failed" |
die_pipestatus 0 "src_prepare failed" |
415 |
resume_stamp src_prepare |
resume_stamp src_prepare |
416 |
step_by_step src_prepare |
step_by_step src_prepare |
417 |
|
|
418 |
( run_resume src_compile || src_compile ) | ${SMAGE_LOG_CMD} |
( run_resume src_compile || src_compile ) |& ${SMAGE_LOG_CMD} |
419 |
die_pipestatus 0 "src_compile failed" |
die_pipestatus 0 "src_compile failed" |
420 |
resume_stamp src_compile |
resume_stamp src_compile |
421 |
step_by_step src_compile |
step_by_step src_compile |
423 |
# only run checks if requested |
# only run checks if requested |
424 |
if mqueryfeature "!check" |
if mqueryfeature "!check" |
425 |
then |
then |
426 |
echo "!check detected; src_check() will not be run!" | ${SMAGE_LOG_CMD} |
echo "!check detected; src_check() will not be run!" |& ${SMAGE_LOG_CMD} |
427 |
else |
else |
428 |
( run_resume src_check || src_check ) | ${SMAGE_LOG_CMD} |
( run_resume src_check || src_check ) |& ${SMAGE_LOG_CMD} |
429 |
die_pipestatus 0 "src_check failed" |
die_pipestatus 0 "src_check failed" |
430 |
resume_stamp src_check |
resume_stamp src_check |
431 |
fi |
fi |
466 |
echo -en " for subpkg: ${COLBLUE}${PNAME}${COLDEFAULT}" |
echo -en " for subpkg: ${COLBLUE}${PNAME}${COLDEFAULT}" |
467 |
echo -e " - basepkg: ${COLBLUE}${SPLIT_PACKAGE_BASE}${COLDEFAULT} ..." |
echo -e " - basepkg: ${COLBLUE}${SPLIT_PACKAGE_BASE}${COLDEFAULT} ..." |
468 |
|
|
469 |
( run_resume src_install_${subpackage} || src_install_${subpackage} ) | ${SMAGE_LOG_CMD} |
( run_resume src_install_${subpackage} || src_install_${subpackage} ) |& ${SMAGE_LOG_CMD} |
470 |
die_pipestatus 0 "src_install_${subpackage} failed" |
die_pipestatus 0 "src_install_${subpackage} failed" |
471 |
resume_stamp src_install_${subpackage} |
resume_stamp src_install_${subpackage} |
472 |
step_by_step src_install_${subpackage} |
step_by_step src_install_${subpackage} |
478 |
# unset all saved smage variables |
# unset all saved smage variables |
479 |
split_unset_variables |
split_unset_variables |
480 |
else |
else |
481 |
( run_resume src_install || src_install ) | ${SMAGE_LOG_CMD} |
( run_resume src_install || src_install ) |& ${SMAGE_LOG_CMD} |
482 |
die_pipestatus 0 "src_install failed" |
die_pipestatus 0 "src_install failed" |
483 |
resume_stamp src_install |
resume_stamp src_install |
484 |
step_by_step src_install |
step_by_step src_install |
515 |
echo -e "!compressdoc detected; documentation of '${subpackage}' will not be compressed ..." |
echo -e "!compressdoc detected; documentation of '${subpackage}' will not be compressed ..." |
516 |
elif mqueryfeature "!pkgbuild" |
elif mqueryfeature "!pkgbuild" |
517 |
then |
then |
518 |
echo "!pkgbuild detected; skipping documentation compression for '${subpackage}' ..." |
echo "!pkgbuild detected; skipping documentation compression for '${subpackage}' ..." |
519 |
else |
else |
520 |
run_resume post-mcompressdoc_${subpackage} || mcompressdocs ${BINDIR}_${subpackage} |
run_resume post-mcompressdoc_${subpackage} || mcompressdocs ${BINDIR}_${subpackage} |
521 |
resume_stamp post-mcompressdoc_${subpackage} |
resume_stamp post-mcompressdoc_${subpackage} |
522 |
fi |
fi |
523 |
# restore smage environment |
# restore smage environment |
524 |
split_restore_variables |
split_restore_variables |
763 |
resume_stamp post-${PNAME}_pkgbuild |
resume_stamp post-${PNAME}_pkgbuild |
764 |
fi |
fi |
765 |
# now create the target package |
# now create the target package |
766 |
run_resume post-pkg_builddir_${PNAME} || ${MLIBDIR}/pkgbuild_dir.sh \ |
run_resume post-pkg_builddir_${PNAME} || ${MLIBDIR}/pkgbuild_dir \ |
767 |
"${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \ |
"${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \ |
768 |
"${BINDIR}_${PNAME}" || die "split_package: ${PNAME} package-build failed" |
"${BINDIR}_${PNAME}" || die "split_package: ${PNAME} package-build failed" |
769 |
resume_stamp post-pkg_builddir_${PNAME} |
resume_stamp post-pkg_builddir_${PNAME} |
786 |
split_unset_variables |
split_unset_variables |
787 |
|
|
788 |
else |
else |
789 |
run_resume post-pkg_builddir || ${MLIBDIR}/pkgbuild_dir.sh ${PKGNAME} ${BINDIR} || die "package-build failed" |
run_resume post-pkg_builddir || ${MLIBDIR}/pkgbuild_dir ${PKGNAME} ${BINDIR} || die "package-build failed" |
790 |
resume_stamp post-pkg_builddir |
resume_stamp post-pkg_builddir |
791 |
|
|
792 |
# build pkg-md5-sum if requested |
# build pkg-md5-sum if requested |
814 |
|
|
815 |
if mqueryfeature "buildlog" |
if mqueryfeature "buildlog" |
816 |
then |
then |
817 |
bzip2 -9f /var/log/smage/${PKGNAME}.log |
bzip2 -9f ${SMAGELOGDIR}/${PKGNAME}.log |
818 |
else |
else |
819 |
[[ -f /var/log/smage/${PKGNAME}.log ]] && rm /var/log/smage/${PKGNAME}.log |
[[ -f ${SMAGELOGDIR}/${PKGNAME}.log ]] && rm ${SMAGELOGDIR}/${PKGNAME}.log |
820 |
fi |
fi |
821 |
|
|
822 |
xtitleclean |
xtitleclean |