Magellan Linux

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2042 - (show annotations) (download) (as text)
Fri Feb 1 09:50:07 2013 UTC (11 years, 2 months ago) by niro
File MIME type: application/x-sh
File size: 21206 byte(s)
-improved split_package handling and honor split_info for all 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
475 if mqueryfeature "!compressdoc"
476 then
477 echo -e "!compressdoc detected; documentation of '${subpackage}' will not be compressed ..."
478 elif mqueryfeature "!pkgbuild"
479 then
480 echo "!pkgbuild detected; skipping documentation compression for '${subpackage}' ..."
481 else
482 run_resume post-mcompressdoc_${subpackage} || mcompressdocs ${BINDIR}_${subpackage}
483 resume_stamp post-mcompressdoc_${subpackage}
484 fi
485 # restore smage environment
486 split_restore_variables
487 done
488 # unset saved variables
489 split_unset_variables
490 else
491 run_resume post-mcompressdoc || mcompressdocs ${BINDIR}
492 resume_stamp post-mcompressdoc
493 fi
494 fi
495
496 if mqueryfeature "!libtool"
497 then
498 if mqueryfeature "!pkgbuild"
499 then
500 echo "!pkgbuild detected; skipping libtool archive stripping ..."
501 else
502 if [[ -n ${SPLIT_PACKAGES} ]]
503 then
504 # save smage environment
505 split_save_variables
506 for subpackage in ${SPLIT_PACKAGES}
507 do
508 # honor split_info
509 split_info_${subpackage}
510
511 if mqueryfeature "!libtool"
512 then
513 if mqueryfeature "!pkgbuild"
514 then
515 echo "!pkgbuild detected; skipping libtool archive stripping for '${subpackage}'..."
516 else
517 echo -e "${COLBLUE}===${COLGREEN} stripping libtool archives for '${subpackage}' ...${COLDEFAULT}"
518 run_resume post-mstriplibtoolarchive_${subpackage} || mstriplibtoolarchive ${BINDIR}_${subpackage}
519 resume_stamp post-mstriplibtoolarchive_${subpackage}
520 fi
521 fi
522
523 # restore smage environment
524 split_restore_variables
525 done
526 # unset saved variables
527 split_unset_variables
528 else
529 echo -e "${COLBLUE}===${COLGREEN} stripping libtool archives ...${COLDEFAULT}"
530 run_resume post-mstriplibtoolarchive || mstriplibtoolarchive ${BINDIR}
531 resume_stamp post-mstriplibtoolarchive
532 fi
533 fi
534 fi
535
536 if mqueryfeature "purge"
537 then
538 if mqueryfeature "!pkgbuild"
539 then
540 echo "!pkgbuild detected; skipping file purgation ..."
541 else
542 if [[ -n ${SPLIT_PACKAGES} ]]
543 then
544 # save smage environment
545 split_save_variables
546 for subpackage in ${SPLIT_PACKAGES}
547 do
548 # honor split_info
549 split_info_${subpackage}
550
551 if mqueryfeature "purge"
552 then
553 if mqueryfeature "!pkgbuild"
554 then
555 echo "!pkgbuild detected; skipping file purgation for '${subpackage}' ..."
556 else
557 echo -e "${COLBLUE}===${COLGREEN} purging all purge targets in '${subpackage}' ...${COLDEFAULT}"
558 run_resume post-mpurgetargets_${subpackage} || mpurgetargets ${BINDIR}_${subpackage}
559 resume_stamp post-mpurgetargets_${subpackage}
560 fi
561 fi
562
563 # restore smage environment
564 split_restore_variables
565 done
566 # unset saved variables
567 split_unset_variables
568 else
569 echo -e "${COLBLUE}===${COLGREEN} purging all purge targets ...${COLDEFAULT}"
570 run_resume post-mpurgetargets || mpurgetargets ${BINDIR}
571 resume_stamp post-mpurgetargets
572 fi
573 fi
574 fi
575
576 # stripping all bins and libs
577 if mqueryfeature "!strip"
578 then
579 echo -e "!strip detected; package will not be stripped ..."
580 elif mqueryfeature "!pkgbuild"
581 then
582 echo "!pkgbuild detected; skipping stripping of the package ..."
583 else
584 if [[ -n ${SPLIT_PACKAGES} ]]
585 then
586 # save smage environment
587 split_save_variables
588 for subpackage in ${SPLIT_PACKAGES}
589 do
590 # honor split_info
591 split_info_${subpackage}
592
593 if mqueryfeature "!strip"
594 then
595 echo -e "!strip detected; package '${subpackage}' will not be stripped ..."
596 elif mqueryfeature "!pkgbuild"
597 then
598 echo "!pkgbuild detected; skipping stripping of the package '${subpackage}' ..."
599 else
600 echo -e "${COLBLUE}===${COLGREEN} stripping binaries for '${subpackage}' ...${COLDEFAULT}"
601 run_resume post-mstripbins_${subpackage} || mstripbins ${BINDIR}_${subpackage}
602 resume_stamp post-mstripbins_${subpackage}
603 echo -e "${COLBLUE}===${COLGREEN} stripping dynamic libraries for '${subpackage}' ...${COLDEFAULT}"
604 run_resume post-mstriplibs_${subpackage} || mstriplibs ${BINDIR}_${subpackage}
605 resume_stamp post-mstriplibs_${subpackage}
606 echo -e "${COLBLUE}===${COLGREEN} stripping static libraries for '${subpackage}' ...${COLDEFAULT}"
607 run_resume post-mstripstatic_${subpackage} || mstripstatic ${BINDIR}_${subpackage}
608 resume_stamp post-mstripstatic_${subpackage}
609 fi
610
611 # restore smage environment
612 split_restore_variables
613 done
614 # unset saved variables
615 split_unset_variables
616 else
617 echo -e "${COLBLUE}===${COLGREEN} stripping binaries ...${COLDEFAULT}"
618 run_resume post-mstripbins || mstripbins ${BINDIR}
619 resume_stamp post-mstripbins
620 echo -e "${COLBLUE}===${COLGREEN} stripping dynamic libraries ...${COLDEFAULT}"
621 run_resume post-mstriplibs || mstriplibs ${BINDIR}
622 resume_stamp post-mstriplibs
623 echo -e "${COLBLUE}===${COLGREEN} stripping static libraries ...${COLDEFAULT}"
624 run_resume post-mstripstatic || mstripstatic ${BINDIR}
625 resume_stamp post-mstripstatic
626 fi
627 fi
628
629 if mqueryfeature "!pkgbuild"
630 then
631 echo -e "!pkgbuild detected; Package will not be build ..."
632 else
633 # build several targets
634 if [[ -n ${MAGE_TARGETS} ]]
635 then
636 for target in ${MAGE_TARGETS}
637 do
638 # check if a special target_pkgbuild exists
639 if typeset -f ${target}_pkgbuild > /dev/null
640 then
641 # run it
642 run_resume post-${target}_pkgbuild || ${target}_pkgbuild
643 resume_stamp post-${target}_pkgbuild
644 fi
645 # now create the target package
646 run_resume post-pkg_builddir_${target} || ${MLIBDIR}/pkgbuild_dir.sh \
647 "${PNAME}-${target}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \
648 ${BINDIR} || die "target: ${target} package-build failed"
649 resume_stamp post-pkg_builddir_${target}
650
651 # build pkg-md5-sum if requested
652 run_resume post-md5sum_${target} || generate_package_md5sum \
653 --pcat "${PCAT}" \
654 --pname "${PNAME}" \
655 --pver "${PVER}" \
656 --pbuild "${PBUILD}" \
657 --parch "${ARCH}" \
658 --target "${target}"
659 resume_stamp post-md5sum_${target}
660
661 echo -e "${COLGREEN}\nPackage ${PNAME}-${target}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD} successfully builded.\n${COLDEFAULT}"
662 done
663
664 # build several subpackages
665 elif [[ -n ${SPLIT_PACKAGES} ]]
666 then
667 split_save_variables
668 for subpackage in ${SPLIT_PACKAGES}
669 do
670 # get the right variables for the split
671 export PNAME="${subpackage}"
672 split_info_${PNAME}
673 # fix PCATEGORIE -> PCAT
674 if [[ ! -z ${PCATEGORIE} ]]
675 then
676 PCAT="${PCATEGORIE}"
677 unset PCATEGORIE
678 fi
679
680 # jump to next one if !pkgbuild is set in split_info
681 if mqueryfeature "!pkgbuild"
682 then
683 # restore smage environment
684 split_restore_variables
685 continue
686 fi
687
688 # check if an special subpackage_pkgbuild exists
689 if typeset -f ${PNAME}_pkgbuild > /dev/null
690 then
691 # run it
692 run_resume post-${PNAME}_pkgbuild || ${PNAME}_pkgbuild
693 resume_stamp post-${PNAME}_pkgbuild
694 fi
695 # now create the target package
696 run_resume post-pkg_builddir_${PNAME} || ${MLIBDIR}/pkgbuild_dir.sh \
697 "${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD}" \
698 "${BINDIR}_${PNAME}" || die "split_package: ${PNAME} package-build failed"
699 resume_stamp post-pkg_builddir_${PNAME}
700
701 # build pkg-md5-sum if requested
702 run_resume post-md5sum_${PNAME} || generate_package_md5sum \
703 --pcat "${PCAT}" \
704 --pname "${PNAME}" \
705 --pver "${PVER}" \
706 --pbuild "${PBUILD}" \
707 --parch "${ARCH}"
708 resume_stamp post-md5sum_${PNAME}
709
710 echo -e "${COLGREEN}\nPackage ${PNAME}-${PVER}-${ARCH}$(print_distrotag)-${PBUILD} successfully builded.\n${COLDEFAULT}"
711
712 # restore smage environment
713 split_restore_variables
714 done
715 # unset all saved smage variables
716 split_unset_variables
717
718 else
719 run_resume post-pkg_builddir || ${MLIBDIR}/pkgbuild_dir.sh ${PKGNAME} ${BINDIR} || die "package-build failed"
720 resume_stamp post-pkg_builddir
721
722 # build pkg-md5-sum if requested
723 run_resume post-md5sum || generate_package_md5sum \
724 --pcat "${PCAT}" \
725 --pname "${PNAME}" \
726 --pver "${PVER}" \
727 --pbuild "${PBUILD}" \
728 --parch "${ARCH}"
729 resume_stamp post-md5sum
730
731 echo -e "${COLGREEN}\nPackage ${PKGNAME} successfully builded.\n${COLDEFAULT}"
732 fi
733
734 # build src-pkg-tarball if requested
735 if mqueryfeature "srcpkgbuild"
736 then
737 run_resume post-srcpkgbuild || source_pkg_build ${SMAGENAME}
738 resume_stamp post-srcpkgbuild
739 fi
740 fi
741
742 if mqueryfeature "buildlog"
743 then
744 bzip2 -9f /var/log/smage/${PKGNAME}.log
745 else
746 [[ -f /var/log/smage/${PKGNAME}.log ]] && rm /var/log/smage/${PKGNAME}.log
747 fi
748
749 xtitleclean

Properties

Name Value
svn:executable *