Magellan Linux

Contents of /trunk/mage/usr/lib/mage/smage2.sh

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2043 - (show annotations) (download) (as text)
Fri Feb 1 10:19:20 2013 UTC (11 years, 2 months ago) by niro
File MIME type: application/x-sh
File size: 21811 byte(s)
-honor PKGTYPE=virtual in all split_package cases
1 #!/bin/bash
2 # $Id$
3
4 # compiles/installs .smage2 source install scripts
5 # needs pkgbuild_dir (mage)
6
7 # TODO: record dynlib, gz | xz database
8
9
10 # set default user mage.rc
11 : ${MAGERC="/etc/mage.rc"}
12
13 # export default C locale
14 export LC_ALL=C
15
16 source /etc/mage.rc.global
17 source ${MAGERC}
18 source ${MLIBDIR}/mage4.functions.sh
19 source ${MLIBDIR}/smage2.functions.sh
20
21 ## setup ##
22 SMAGENAME="$1"
23 SMAGEVERSION="$(< ${MLIBDIR}/version)"
24
25 # expand PKGDIR, BUILDDIR and BINDIR with MROOT
26 if [[ -n ${MROOT} ]]
27 then
28 export PKGDIR=${MROOT}/${PKGDIR}
29 export BUILDDIR=${MROOT}/${BUILDDIR}
30 export BINDIR=${MROOT}/${BINDIR}
31 fi
32
33 # print out our version
34 showversion
35 echo
36
37 if [[ -z ${SMAGENAME} ]]
38 then
39 echo "No .smage2 file given. Exiting."
40 echo
41 exit 1
42 fi
43
44 # load supported mage features
45 load_mage_features
46
47 # updating smage2-scripts
48 if [[ $1 = update ]]
49 then
50 if [ ! -d ${SOURCEDIR} ]
51 then
52 install -d ${SOURCEDIR}
53 fi
54 syncsmage2
55 exit 0
56 fi
57
58 # creates md5sums for smages to given dir
59 if [[ $1 = calcmd5 ]]
60 then
61 if [ $# -ge 2 ]
62 then
63 SMAGENAME="$2"
64 MD5DIR="$3"
65 [[ -z ${MD5DIR} ]] && MD5DIR="$(dirname ${SMAGENAME})/md5"
66
67 smagesource ${SMAGENAME} || die "download source failed"
68
69 # overridable sourcedir; must be declared after source of the smage2
70 CALC_SOURCEDIR="${CALC_SOURCEDIR:="${SOURCEDIR}/${PNAME}"}"
71
72 [ -z "${SRC_URI}" ] && die "Nothing declared to calculate."
73
74 # end of array
75 EOA=${#SRC_URI[*]}
76
77 [ ! -d ${MD5DIR} ] && install -d ${MD5DIR}
78
79 # clear md5sum file
80 MY_MD5_FILE="${MD5DIR}/$(basename ${SMAGENAME} .${SMAGESUFFIX}).md5"
81 echo -n > ${MY_MD5_FILE}
82
83 for ((i=0; i < EOA; i++))
84 do
85 # url to file
86 my_SRC_URI="$(echo ${SRC_URI[${i}]} | cut -d' ' -f1)"
87
88 # subdir in sources dir; the my_SRCI_URI file goes to there
89 my_SRC_URI_DEST="$(echo ${SRC_URI[${i}]} | cut -d' ' -f2)"
90
91 # if my_src_uri_dest is not equal my_src_uri; than an other dir is used
92 if [[ ${my_SRC_URI_DEST} != ${my_SRC_URI} ]]
93 then
94 MY_SRC_FILE="${my_SRC_URI_DEST}/$(basename ${SRC_URI[${i}]})"
95 else
96 MY_SRC_FILE="$(basename ${SRC_URI[${i}]})"
97 fi
98
99 if [ -e "${CALC_SOURCEDIR}/${MY_SRC_FILE}" ]
100 then
101 echo "calculating $(basename ${MY_SRC_FILE}) ..."
102 ( cd ${CALC_SOURCEDIR}; md5sum "${MY_SRC_FILE}" ) >> ${MY_MD5_FILE}
103 else
104 echo "WARNING: File '$(basename ${MY_SRC_FILE}) not found in ${CALC_SOURCEDIR}."
105 fi
106
107 # unset them to be shure
108 unset my_SRC_URI
109 unset my_SRC_URI_DEST
110 unset my_SRC_URI_MIRROR
111 unset my_SOURCEDIR
112 done
113
114 echo
115 echo "Calculating of md5 sums for '$(basename ${SMAGENAME} .${SMAGESUFFIX})' done."
116 echo
117 else
118 echo "Usage: Calculating MD5 Sums:"
119 echo " $(basename $0) calcmd5 /path/to/SMAGENAME [/path/to/MD5DIR]"
120 echo
121 echo
122 echo "Export the CALC_SOURCEDIR variable to override current SOURCEDIRs."
123 echo
124 exit 1
125 fi
126
127 exit 0
128 fi
129
130 # download sources
131 if [ "$1" == "download" -a -n "$2" ]
132 then
133 if [ ! -d ${SMAGESCRIPTSDIR} ]
134 then
135 install -d ${SMAGESCRIPTSDIR}
136 fi
137
138 # get smage
139 SMAGENAME="$2"
140 MD5DIR="$(dirname ${SMAGENAME})/md5"
141 smagesource ${SMAGENAME} || die "download source failed"
142
143 download_sources
144 exit 0
145 fi
146
147 # regen-mage-tree
148 if [ "$1" == "only-regen-tree" -a -n "$2" ]
149 then
150 # set correct SMAGENAME
151 SMAGENAME="$2"
152 MD5DIR="$(dirname ${SMAGENAME})/md5"
153 smagesource ${SMAGENAME} || die "regen: smage2 not found"
154
155 regen_mage_tree
156
157 # build several targets
158 if [[ -n ${MAGE_TARGETS} ]]
159 then
160 for target in ${MAGE_TARGETS}
161 do
162 # build md5sum for existing packages
163 generate_package_md5sum \
164 --pcat "${PCAT}" \
165 --pname "${PNAME}" \
166 --pver "${PVER}" \
167 --pbuild "${PBUILD}" \
168 --parch "${ARCH}" \
169 --target "${target}"
170 done
171
172 # build several subpackages
173 elif [[ -n ${SPLIT_PACKAGES} ]]
174 then
175 split_save_variables
176 for subpackage in ${SPLIT_PACKAGES}
177 do
178 # get the right variables for the split
179 export PNAME="${subpackage}"
180 split_info_${subpackage}
181 # fix PCATEGORIE -> PCAT
182 if [[ ! -z ${PCATEGORIE} ]]
183 then
184 PCAT="${PCATEGORIE}"
185 unset PCATEGORIE
186 fi
187 # build md5sum for existing packages
188 generate_package_md5sum \
189 --pcat "${PCAT}" \
190 --pname "${PNAME}" \
191 --pver "${PVER}" \
192 --pbuild "${PBUILD}" \
193 --parch "${ARCH}"
194 # restore smage environment
195 split_restore_variables
196 done
197 # unset all saved smage variables
198 split_unset_variables
199
200 else
201 # build md5sum for existing packages
202 generate_package_md5sum \
203 --pcat "${PCAT}" \
204 --pname "${PNAME}" \
205 --pver "${PVER}" \
206 --pbuild "${PBUILD}" \
207 --parch "${ARCH}"
208 fi
209
210 exit 0
211 fi
212
213 if [ "$1" == "--create-src-tarball" -a -n "$2" ]
214 then
215 # set correct SMAGENAME
216 SMAGENAME="$2"
217 MD5DIR="$(dirname ${SMAGENAME})/md5"
218
219 echo -e "${COLGREEN}create-src-tarball called for ${COLBLUE}${SMAGENAME}${COLGREEN} ...${COLDEFAULT}"
220
221 smagesource ${SMAGENAME} || die "regen: smage2 not found"
222
223 if [[ -d ${SOURCEDIR}/${PNAME} ]]
224 then
225 echo -e "${COLGREEN}Deleting old sourcefiles ${COLBLUE}${SOURCEDIR}/${PNAME}${COLGREEN} ...${COLDEFAULT}"
226 rm -rf ${SOURCEDIR}/${PKGNAME}
227 fi
228
229 download_sources
230 source_pkg_build ${SMAGENAME}
231 exit 0
232 fi
233
234 if [ "$1" == "--src-tarball" -a -n "$2" ] || [ "$1" == "-st" -a -n "$2" ]
235 then
236 SRCPKGTARBALL="${2}"
237 msetfeature "srcpkgtarball"
238
239 # abort if given file is not a source pkg
240 [[ ${SRCPKGTARBALL##*.} != ${SRCPKGSUFFIX} ]] && die "${SRCPKGTARBALL} is not a valid src-pkg file."
241
242 # set correct SMAGENAME; use the one that the src_pkg provide
243 # /path/to/SOURCEDIR/PNAME/SMAGENAME
244 SMAGENAME="${SOURCEDIR}/$(basename ${SRCPKGTARBALL%-*-*})/$(basename ${SRCPKGTARBALL} .${SRCPKGSUFFIX}).${SMAGESUFFIX}"
245
246 echo -e "${COLGREEN}Using src-tarball ${COLBLUE}${SRCPKGTARBALL}${COLGREEN} ...${COLDEFAULT}"
247
248 [[ ! -d ${SOURCEDIR} ]] && install -d ${SOURCEDIR}
249
250 # unpack srctarball
251 [[ ! -f ${SRCPKGTARBALL} ]] && die "Error: ${SRCPKGTARBALL} does not exist. Aborting."
252
253 tar xvjf ${SRCPKGTARBALL} -C ${SOURCEDIR} || die "Error unpackung src-tarball ${SRCPKGTARBALL}"
254
255 [[ ! -f ${SMAGENAME} ]] && die "Included smage2 file in src-tarball not found: ${SMAGENAME}"
256 fi
257
258 if [ "$1" == "--resume" -a -n "$2" ]
259 then
260 msetfeature "resume"
261 SMAGENAME="$2"
262 fi
263
264 [ ! -e ${MLIBDIR}/pkgbuild_dir.sh ] && die "Error: ${MLIBDIR}/pkgbuild_dir.sh not found. Aborting."
265 [ -z "$(basename ${SMAGENAME} | grep .${SMAGESUFFIX})" ] &&
266 die "File '$(basename ${SMAGENAME})' is not a sMage v${SMAGEVERSION} file. Aborting."
267 [ -z "${SOURCEDIR}" ] && die "\$SOURCEDIR not found. Please setup your ${MAGERC} correctly."
268 [ -z "${SMAGESCRIPTSDIR}" ] && die "\$SMAGESCRIPTSDIR not found. Please setup your ${MAGERC} correctly."
269 [ -z "${SMAGE2RSYNC}" ] && die "\$SMAGE2RSYNC not found. Please setup your ${MAGERC} correctly."
270 [ -z "${BINDIR}" ] && die "no BINDIR variable found in ${MAGERC}"
271 [ -z "${CHOST}" ] && die "no CHOST variable found in ${MAGERC}"
272 [ -z "${CFLAGS}" ] && die "no CFLAGS variable found in ${MAGERC}"
273 [ -z "${CXXFLAGS}" ] && die "no CXXFLAGS variable found in ${MAGERC}"
274
275 smagesource ${SMAGENAME} || die "source failed"
276 PKGNAME="${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}"
277 MD5DIR="$(dirname ${SMAGENAME})/md5"
278 SMAGE_LOG_CMD="tee -a /var/log/smage/${PKGNAME}.log"
279
280 xtitle "Compiling ${PKGNAME}"
281 echo -e "${COLGREEN}Compiling ${PKGNAME}${COLDEFAULT}"
282
283 # auto regen mage tree if requested
284 regen_mage_tree
285
286 if mqueryfeature "srcpkgbuild"
287 then
288 if [[ -d ${SOURCEDIR}/${PNAME} ]]
289 then
290 echo -e "${COLBLUE}===${COLGREEN} deleting old sourcefiles ${COLBLUE}${SOURCEDIR}/${PNAME}${COLGREEN} ...${COLDEFAULT}"
291 rm -rf ${SOURCEDIR}/${PNAME}
292 fi
293 fi
294
295 # download sources
296 mqueryfeature "srcpkgtarball" || download_sources
297
298 # fixes some issues with these functions
299 export -f src_prepare || die "src_prepare export failed"
300 export -f src_compile || die "src_compile export failed"
301 export -f src_check || die "src_check export failed"
302 export -f src_install || die "src_install export failed"
303
304 # fixes some compile issues
305 export CHOST="${CHOST}" || die "CHOST export failed"
306 export CFLAGS="${CFLAGS}" || die "CFLAGS export failed"
307 if [[ -z ${CXXFLAGS} ]]
308 then
309 export CXXFLAGS="${CFLAGS}" || die "CXXFLAGS export failed"
310 else
311 export CXXFLAGS="${CXXFLAGS}" || die "CXXFLAGS export failed"
312 fi
313 export LDFLAGS="${LDFLAGS}" || die "LDFLAGS export failed"
314 export BINDIR="${BINDIR}" || die "BINDIR export failed"
315 export MAKEOPTS="${MAKEOPTS}" || die "MAKEOPTS export failed"
316
317 # setup distcc
318 # setup for distcc goes *before* ccache, so ccache comes before distcc in path
319 mqueryfeature "distcc" && setup_distcc_environment
320
321 # setup ccache
322 mqueryfeature "ccache" && setup_ccache_environment
323
324 if mqueryfeature "resume"
325 then
326 echo -e "${COLMAGENTA}Resume requested; continuing previous build${COLDEFAULT}"
327
328 # setup build logging
329 [[ ! -d /var/log/smage ]] && install -d /var/log/smage
330 if [[ -f /var/log/smage/${PKGNAME}.log.bz2 ]]
331 then
332 bunzip2 -f /var/log/smage/${PKGNAME}.log.bz2
333 fi
334 echo -e "### Resume started on $(date) ###\n" >> /var/log/smage/${PKGNAME}.log
335
336 else
337 # clean up builddir if a previously one exist
338 if [ -d ${BUILDDIR} ]
339 then
340 rm -rf ${BUILDDIR}/* || die "couldn't cleanup \$BUILDDIR."
341 fi
342 install -d ${BUILDDIR} || die "couldn't create \$BUILDDIR."
343
344 # clean up srcdir if a previously unpacked one exist
345 if [ -d ${SRCDIR} ]
346 then
347 rm -rf ${SRCDIR}
348 fi
349
350 # clean up bindir if a previous build exist or create a new one
351 if [ -d ${BINDIR} ]
352 then
353 rm -rf ${BINDIR}
354 fi
355 install -d ${BINDIR} || die "couldn't create \$BINDIR."
356
357 # clean up package temp dir if a previous build exist
358 if [ -d ${BUILDDIR}/${PKGNAME} ]
359 then
360 rm -rf ${BUILDDIR}/${PKGNAME}
361 fi
362
363 # clean up stamps dir
364 if [ -d ${BUILDDIR}/.stamps ]
365 then
366 rm -rf ${BUILDDIR}/.stamps
367 fi
368
369 # setup build logging
370 [[ ! -d /var/log/smage ]] && install -d /var/log/smage
371 echo -e "### Build started on $(date) ###\n" > /var/log/smage/${PKGNAME}.log
372 fi
373
374 if [[ ${PKGTYPE} = virtual ]]
375 then
376 echo "virtual package detected; nothing will be build ..."
377 # automatically set !pkgbuild here too
378 msetfeature "!pkgbuild"
379 else
380 ( run_resume src_prepare || src_prepare ) | ${SMAGE_LOG_CMD}
381 die_pipestatus 0 "src_prepare failed"
382 resume_stamp src_prepare
383 step_by_step src_prepare
384
385 ( run_resume src_compile || src_compile ) | ${SMAGE_LOG_CMD}
386 die_pipestatus 0 "src_compile failed"
387 resume_stamp src_compile
388 step_by_step src_compile
389
390 # only run checks if requested
391 if mqueryfeature "!check"
392 then
393 echo "!check detected; src_check() will not be run!" | ${SMAGE_LOG_CMD}
394 else
395 ( run_resume src_check || src_check ) | ${SMAGE_LOG_CMD}
396 die_pipestatus 0 "src_check failed"
397 resume_stamp src_check
398 fi
399 step_by_step src_check
400
401 # build several subpackages
402 if [[ -n ${SPLIT_PACKAGES} ]]
403 then
404 # save bindir & pname
405 split_save_variables
406 export SAVED_BINDIR="${BINDIR}"
407 for subpackage in ${SPLIT_PACKAGES}
408 do
409 split_info_${subpackage}
410 if [[ ${PKGTYPE} = virtual ]]
411 then
412 echo
413 echo -en "${COLBLUE}*** ${COLDEFAULT}"
414 echo -en "Virtual package detected"
415 echo -en " for subpkg: ${COLBLUE}${PNAME}${COLDEFAULT}"
416 echo -e " - basepkg: ${COLBLUE}${SPLIT_PACKAGE_BASE}${COLDEFAULT} ..."
417
418 echo "virtual package detected; nothing will be build ..."
419 # automatically set !pkgbuild here too
420 msetfeature "!pkgbuild"
421 else
422 if typeset -f src_install_${subpackage} > /dev/null
423 then
424 # export subpackage bindir
425 export BINDIR="${SAVED_BINDIR}_${subpackage}"
426 # export PNAME, several internal function and include
427 # rely on this variable
428 export PNAME="${subpackage}"
429
430 echo
431 echo -en "${COLBLUE}*** ${COLDEFAULT}"
432 echo -en "Running ${COLGREEN}split src_install()${COLDEFAULT}"
433 echo -en " for subpkg: ${COLBLUE}${PNAME}${COLDEFAULT}"
434 echo -e " - basepkg: ${COLBLUE}${SPLIT_PACKAGE_BASE}${COLDEFAULT} ..."
435
436 ( run_resume src_install_${subpackage} || src_install_${subpackage} ) | ${SMAGE_LOG_CMD}
437 die_pipestatus 0 "src_install_${subpackage} failed"
438 resume_stamp src_install_${subpackage}
439 step_by_step src_install_${subpackage}
440 fi
441 fi
442 # restore smage environment
443 split_restore_variables
444 done
445 # unset all saved smage variables
446 split_unset_variables
447 else
448 ( run_resume src_install || src_install ) | ${SMAGE_LOG_CMD}
449 die_pipestatus 0 "src_install failed"
450 resume_stamp src_install
451 step_by_step src_install
452 fi
453 fi
454
455 # echo for sake of good-looking
456 echo
457
458 if mqueryfeature "!compressdoc"
459 then
460 echo -e "!compressdoc detected; documentation will not be compressed ..."
461 elif mqueryfeature "!pkgbuild"
462 then
463 echo "!pkgbuild detected; skipping documentation compression..."
464 else
465 # compressing doc, info & man files
466 if [[ -n ${SPLIT_PACKAGES} ]]
467 then
468 # save smage environment
469 split_save_variables
470 for subpackage in ${SPLIT_PACKAGES}
471 do
472 # honor split_info
473 split_info_${subpackage}
474 if [[ ${PKGTYPE} = virtual ]]
475 then
476 # automatically set !pkgbuild here too
477 msetfeature "!pkgbuild"
478 fi
479
480 if mqueryfeature "!compressdoc"
481 then
482 echo -e "!compressdoc detected; documentation of '${subpackage}' will not be compressed ..."
483 elif mqueryfeature "!pkgbuild"
484 then
485 echo "!pkgbuild detected; skipping documentation compression for '${subpackage}' ..."
486 else
487 run_resume post-mcompressdoc_${subpackage} || mcompressdocs ${BINDIR}_${subpackage}
488 resume_stamp post-mcompressdoc_${subpackage}
489 fi
490 # restore smage environment
491 split_restore_variables
492 done
493 # unset saved variables
494 split_unset_variables
495 else
496 run_resume post-mcompressdoc || mcompressdocs ${BINDIR}
497 resume_stamp post-mcompressdoc
498 fi
499 fi
500
501 if mqueryfeature "!libtool"
502 then
503 if mqueryfeature "!pkgbuild"
504 then
505 echo "!pkgbuild detected; skipping libtool archive stripping ..."
506 else
507 if [[ -n ${SPLIT_PACKAGES} ]]
508 then
509 # save smage environment
510 split_save_variables
511 for subpackage in ${SPLIT_PACKAGES}
512 do
513 # honor split_info
514 split_info_${subpackage}
515 if [[ ${PKGTYPE} = virtual ]]
516 then
517 # automatically set !pkgbuild here too
518 msetfeature "!pkgbuild"
519 fi
520
521 if mqueryfeature "!libtool"
522 then
523 if mqueryfeature "!pkgbuild"
524 then
525 echo "!pkgbuild detected; skipping libtool archive stripping for '${subpackage}'..."
526 else
527 echo -e "${COLBLUE}===${COLGREEN} stripping libtool archives for '${subpackage}' ...${COLDEFAULT}"
528 run_resume post-mstriplibtoolarchive_${subpackage} || mstriplibtoolarchive ${BINDIR}_${subpackage}
529 resume_stamp post-mstriplibtoolarchive_${subpackage}
530 fi
531 fi
532
533 # restore smage environment
534 split_restore_variables
535 done
536 # unset saved variables
537 split_unset_variables
538 else
539 echo -e "${COLBLUE}===${COLGREEN} stripping libtool archives ...${COLDEFAULT}"
540 run_resume post-mstriplibtoolarchive || mstriplibtoolarchive ${BINDIR}
541 resume_stamp post-mstriplibtoolarchive
542 fi
543 fi
544 fi
545
546 if mqueryfeature "purge"
547 then
548 if mqueryfeature "!pkgbuild"
549 then
550 echo "!pkgbuild detected; skipping file purgation ..."
551 else
552 if [[ -n ${SPLIT_PACKAGES} ]]
553 then
554 # save smage environment
555 split_save_variables
556 for subpackage in ${SPLIT_PACKAGES}
557 do
558 # honor split_info
559 split_info_${subpackage}
560 if [[ ${PKGTYPE} = virtual ]]
561 then
562 # automatically set !pkgbuild here too
563 msetfeature "!pkgbuild"
564 fi
565
566 if mqueryfeature "purge"
567 then
568 if mqueryfeature "!pkgbuild"
569 then
570 echo "!pkgbuild detected; skipping file purgation for '${subpackage}' ..."
571 else
572 echo -e "${COLBLUE}===${COLGREEN} purging all purge targets in '${subpackage}' ...${COLDEFAULT}"
573 run_resume post-mpurgetargets_${subpackage} || mpurgetargets ${BINDIR}_${subpackage}
574 resume_stamp post-mpurgetargets_${subpackage}
575 fi
576 fi
577
578 # restore smage environment
579 split_restore_variables
580 done
581 # unset saved variables
582 split_unset_variables
583 else
584 echo -e "${COLBLUE}===${COLGREEN} purging all purge targets ...${COLDEFAULT}"
585 run_resume post-mpurgetargets || mpurgetargets ${BINDIR}
586 resume_stamp post-mpurgetargets
587 fi
588 fi
589 fi
590
591 # stripping all bins and libs
592 if mqueryfeature "!strip"
593 then
594 echo -e "!strip detected; package will not be stripped ..."
595 elif mqueryfeature "!pkgbuild"
596 then
597 echo "!pkgbuild detected; skipping stripping of the package ..."
598 else
599 if [[ -n ${SPLIT_PACKAGES} ]]
600 then
601 # save smage environment
602 split_save_variables
603 for subpackage in ${SPLIT_PACKAGES}
604 do
605 # honor split_info
606 split_info_${subpackage}
607 if [[ ${PKGTYPE} = virtual ]]
608 then
609 # automatically set !pkgbuild here too
610 msetfeature "!pkgbuild"
611 fi
612
613 if mqueryfeature "!strip"
614 then
615 echo -e "!strip detected; package '${subpackage}' will not be stripped ..."
616 elif mqueryfeature "!pkgbuild"
617 then
618 echo "!pkgbuild detected; skipping stripping of the package '${subpackage}' ..."
619 else
620 echo -e "${COLBLUE}===${COLGREEN} stripping binaries for '${subpackage}' ...${COLDEFAULT}"
621 run_resume post-mstripbins_${subpackage} || mstripbins ${BINDIR}_${subpackage}
622 resume_stamp post-mstripbins_${subpackage}
623 echo -e "${COLBLUE}===${COLGREEN} stripping dynamic libraries for '${subpackage}' ...${COLDEFAULT}"
624 run_resume post-mstriplibs_${subpackage} || mstriplibs ${BINDIR}_${subpackage}
625 resume_stamp post-mstriplibs_${subpackage}
626 echo -e "${COLBLUE}===${COLGREEN} stripping static libraries for '${subpackage}' ...${COLDEFAULT}"
627 run_resume post-mstripstatic_${subpackage} || mstripstatic ${BINDIR}_${subpackage}
628 resume_stamp post-mstripstatic_${subpackage}
629 fi
630
631 # restore smage environment
632 split_restore_variables
633 done
634 # unset saved variables
635 split_unset_variables
636 else
637 echo -e "${COLBLUE}===${COLGREEN} stripping binaries ...${COLDEFAULT}"
638 run_resume post-mstripbins || mstripbins ${BINDIR}
639 resume_stamp post-mstripbins
640 echo -e "${COLBLUE}===${COLGREEN} stripping dynamic libraries ...${COLDEFAULT}"
641 run_resume post-mstriplibs || mstriplibs ${BINDIR}
642 resume_stamp post-mstriplibs
643 echo -e "${COLBLUE}===${COLGREEN} stripping static libraries ...${COLDEFAULT}"
644 run_resume post-mstripstatic || mstripstatic ${BINDIR}
645 resume_stamp post-mstripstatic
646 fi
647 fi
648
649 if mqueryfeature "!pkgbuild"
650 then
651 echo -e "!pkgbuild detected; Package will not be build ..."
652 else
653 # build several targets
654 if [[ -n ${MAGE_TARGETS} ]]
655 then
656 for target in ${MAGE_TARGETS}
657 do
658 # check if a special target_pkgbuild exists
659 if typeset -f ${target}_pkgbuild > /dev/null
660 then
661 # run it
662 run_resume post-${target}_pkgbuild || ${target}_pkgbuild
663 resume_stamp post-${target}_pkgbuild
664 fi
665 # now create the target package
666 run_resume post-pkg_builddir_${target} || ${MLIBDIR}/pkgbuild_dir.sh \
667 "${PNAME}-${target}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \
668 ${BINDIR} || die "target: ${target} package-build failed"
669 resume_stamp post-pkg_builddir_${target}
670
671 # build pkg-md5-sum if requested
672 run_resume post-md5sum_${target} || generate_package_md5sum \
673 --pcat "${PCAT}" \
674 --pname "${PNAME}" \
675 --pver "${PVER}" \
676 --pbuild "${PBUILD}" \
677 --parch "${ARCH}" \
678 --target "${target}"
679 resume_stamp post-md5sum_${target}
680
681 echo -e "${COLGREEN}\nPackage ${PNAME}-${target}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD} successfully builded.\n${COLDEFAULT}"
682 done
683
684 # build several subpackages
685 elif [[ -n ${SPLIT_PACKAGES} ]]
686 then
687 split_save_variables
688 for subpackage in ${SPLIT_PACKAGES}
689 do
690 # get the right variables for the split
691 export PNAME="${subpackage}"
692 split_info_${PNAME}
693 # fix PCATEGORIE -> PCAT
694 if [[ ! -z ${PCATEGORIE} ]]
695 then
696 PCAT="${PCATEGORIE}"
697 unset PCATEGORIE
698 fi
699 if [[ ${PKGTYPE} = virtual ]]
700 then
701 # automatically set !pkgbuild here too
702 msetfeature "!pkgbuild"
703 fi
704
705 # jump to next one if !pkgbuild is set in split_info
706 if mqueryfeature "!pkgbuild"
707 then
708 # restore smage environment
709 split_restore_variables
710 continue
711 fi
712
713 # check if an special subpackage_pkgbuild exists
714 if typeset -f ${PNAME}_pkgbuild > /dev/null
715 then
716 # run it
717 run_resume post-${PNAME}_pkgbuild || ${PNAME}_pkgbuild
718 resume_stamp post-${PNAME}_pkgbuild
719 fi
720 # now create the target package
721 run_resume post-pkg_builddir_${PNAME} || ${MLIBDIR}/pkgbuild_dir.sh \
722 "${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \
723 "${BINDIR}_${PNAME}" || die "split_package: ${PNAME} package-build failed"
724 resume_stamp post-pkg_builddir_${PNAME}
725
726 # build pkg-md5-sum if requested
727 run_resume post-md5sum_${PNAME} || generate_package_md5sum \
728 --pcat "${PCAT}" \
729 --pname "${PNAME}" \
730 --pver "${PVER}" \
731 --pbuild "${PBUILD}" \
732 --parch "${ARCH}"
733 resume_stamp post-md5sum_${PNAME}
734
735 echo -e "${COLGREEN}\nPackage ${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD} successfully builded.\n${COLDEFAULT}"
736
737 # restore smage environment
738 split_restore_variables
739 done
740 # unset all saved smage variables
741 split_unset_variables
742
743 else
744 run_resume post-pkg_builddir || ${MLIBDIR}/pkgbuild_dir.sh ${PKGNAME} ${BINDIR} || die "package-build failed"
745 resume_stamp post-pkg_builddir
746
747 # build pkg-md5-sum if requested
748 run_resume post-md5sum || generate_package_md5sum \
749 --pcat "${PCAT}" \
750 --pname "${PNAME}" \
751 --pver "${PVER}" \
752 --pbuild "${PBUILD}" \
753 --parch "${ARCH}"
754 resume_stamp post-md5sum
755
756 echo -e "${COLGREEN}\nPackage ${PKGNAME} successfully builded.\n${COLDEFAULT}"
757 fi
758
759 # build src-pkg-tarball if requested
760 if mqueryfeature "srcpkgbuild"
761 then
762 run_resume post-srcpkgbuild || source_pkg_build ${SMAGENAME}
763 resume_stamp post-srcpkgbuild
764 fi
765 fi
766
767 if mqueryfeature "buildlog"
768 then
769 bzip2 -9f /var/log/smage/${PKGNAME}.log
770 else
771 [[ -f /var/log/smage/${PKGNAME}.log ]] && rm /var/log/smage/${PKGNAME}.log
772 fi
773
774 xtitleclean

Properties

Name Value
svn:executable *