Magellan Linux

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 351 by niro, Wed Mar 22 17:45:49 2006 UTC revision 880 by niro, Mon Jun 29 18:53:00 2009 UTC
# Line 4  Line 4 
4  # needs pkgbuild_dir (mage)  # needs pkgbuild_dir (mage)
5    
6  # SMAGE2  # SMAGE2
7  # $Header: /home/cvsd/magellan-cvs/magellan-src/mage/usr/lib/mage/smage2.sh,v 1.42 2006-03-22 17:45:49 niro Exp $  # $Header: /home/cvsd/magellan-cvs/magellan-src/mage/usr/lib/mage/smage2.sh,v 1.62 2007-11-28 10:47:50 niro Exp $
8    
9  #01.10.2004  #01.10.2004
10  # added ccache support  # added ccache support
11  # added distcc support  # added distcc support
12    
13    # set default user mage.rc
14    : ${MAGERC="/etc/mage.rc"}
15    
16  ## setup ##  ## setup ##
17  PKGSUFFIX="mpk"  PKGSUFFIX="mpk"
18    SRCPKGSUFFIX="mpks"
19  SMAGENAME="$1"  SMAGENAME="$1"
20  SMAGESUFFIX="smage2"  SMAGESUFFIX="smage2"
21  MLIBDIR=/usr/lib/mage  MLIBDIR=/usr/lib/mage
22  SMAGEVERSION="$( < ${MLIBDIR}/version)"  SMAGEVERSION="$( < ${MLIBDIR}/version)"
23    SMAGE_LOG_CMD="tee -a /var/log/smage/${PKGNAME}.log"
24    
25    
26  ## only for tests -> normally in /etc/rc.d/init.d/functions  ## only for tests -> normally in /etc/rc.d/init.d/functions
27  COLRED="\033[1;6m\033[31m"  COLRED="\033[1;6m\033[31m"
# Line 44  fi Line 50  fi
50  # export default C locale  # export default C locale
51  export LC_ALL=C  export LC_ALL=C
52    
53  source /etc/mage.rc  source /etc/mage.rc.global
54    source ${MAGERC}
55    
56  # set PKGDIR and BUILDDIR and BINDIR to MROOT  # set PKGDIR and BUILDDIR and BINDIR to MROOT
57  if [[ -n ${MROOT} ]]  if [[ -n ${MROOT} ]]
# Line 63  showversion() Line 70  showversion()
70  die()  die()
71  {  {
72   xtitleclean   xtitleclean
73     echo -e ${COLRED}"Exited ${BASH_SOURCE} at line no ${BASH_LINENO}."${COLDEFAULT}
74   echo "SMAGE failed: $@"   echo "SMAGE failed: $@"
75   exit 1   exit 1
76  }  }
# Line 91  syncsmage2() Line 99  syncsmage2()
99   local i   local i
100   for i in ${SMAGE2RSYNC}   for i in ${SMAGE2RSYNC}
101   do   do
102   rsync \   rsync ${RSYNC_FETCH_OPTIONS} ${i} ${SMAGESCRIPTSDIR}
  --recursive \  
  --links \  
  --perms \  
  --times \  
  --devices \  
  --timeout=600 \  
  --verbose \  
  --compress \  
  --progress \  
  --stats \  
  --delete \  
  --delete-after \  
  ${i} ${SMAGESCRIPTSDIR}  
   
103   if [[ $? = 0 ]]   if [[ $? = 0 ]]
104   then   then
105   break   break
106   else   else
107   continue   continue
108   fi   fi
   
109   done   done
110    
111   # clean up backup files (foo~)   # clean up backup files (foo~)
# Line 158  download_sources() Line 151  download_sources()
151   ( cd ${SOURCEDIR}/${PNAME}; md5sum --check ${DB_MD5_SUM_FILE} &> /dev/null )   ( cd ${SOURCEDIR}/${PNAME}; md5sum --check ${DB_MD5_SUM_FILE} &> /dev/null )
152   if [[ $? = 0 ]]   if [[ $? = 0 ]]
153   then   then
154   # md5's ok, not fetching needed   # md5's ok, no fetching needed
155   FETCHING=false   FETCHING=false
156   else   else
157   FETCHING=true   FETCHING=true
# Line 181  download_sources() Line 174  download_sources()
174   fi   fi
175    
176   # if an mirrored file than replace first the mirror uri   # if an mirrored file than replace first the mirror uri
177   if [ -n "$(echo ${my_SRC_URI} | grep 'mirror://')" ]   if [[ -n $(echo ${my_SRC_URI} | grep 'mirror://') ]]
178   then   then
179   for mirror in ${MIRRORS}   for mirror in ${MIRRORS}
180   do   do
# Line 189  download_sources() Line 182  download_sources()
182    
183   if [[ ${FETCHING} = true ]]   if [[ ${FETCHING} = true ]]
184   then   then
185   echo "==> fetching ${my_SRC_URI_MIRROR}"   echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI_MIRROR}${COLDEFAULT}"
186     wget \
187     --passive-ftp \
188     --tries 3 \
189     --continue \
190     --progress bar \
191     --directory-prefix="${my_SOURCEDIR}" \
192     "${my_SRC_URI_MIRROR}"
193     if [[ $? = 0 ]]
194     then
195     break
196     else
197     continue
198     fi
199     fi
200     done
201     elif [[ -n $(echo ${my_SRC_URI} | grep 'sourceforge://') ]]
202     then
203     for mirror in ${SOURCEFORGE_MIRRORS}
204     do
205     my_SRC_URI_MIRROR="$(echo ${my_SRC_URI} | sed "s|sourceforge:/|${mirror}|g")"
206    
207     if [[ ${FETCHING} = true ]]
208     then
209     echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI_MIRROR}${COLDEFAULT}"
210     wget \
211     --passive-ftp \
212     --tries 3 \
213     --continue \
214     --progress bar \
215     --directory-prefix="${my_SOURCEDIR}" \
216     "${my_SRC_URI_MIRROR}"
217     if [[ $? = 0 ]]
218     then
219     break
220     else
221     continue
222     fi
223     fi
224     done
225     elif [[ -n $(echo ${my_SRC_URI} | grep 'gnu://') ]]
226     then
227     for mirror in ${GNU_MIRRORS}
228     do
229     my_SRC_URI_MIRROR="$(echo ${my_SRC_URI} | sed "s|gnu:/|${mirror}|g")"
230    
231     if [[ ${FETCHING} = true ]]
232     then
233     echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI_MIRROR}${COLDEFAULT}"
234     wget \
235     --passive-ftp \
236     --tries 3 \
237     --continue \
238     --progress bar \
239     --directory-prefix="${my_SOURCEDIR}" \
240     "${my_SRC_URI_MIRROR}"
241     if [[ $? = 0 ]]
242     then
243     break
244     else
245     continue
246     fi
247     fi
248     done
249     elif [[ -n $(echo ${my_SRC_URI} | grep 'kde://') ]]
250     then
251     for mirror in ${KDE_MIRRORS}
252     do
253     my_SRC_URI_MIRROR="$(echo ${my_SRC_URI} | sed "s|kde:/|${mirror}|g")"
254    
255     if [[ ${FETCHING} = true ]]
256     then
257     echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI_MIRROR}${COLDEFAULT}"
258     wget \
259     --passive-ftp \
260     --tries 3 \
261     --continue \
262     --progress bar \
263     --directory-prefix="${my_SOURCEDIR}" \
264     "${my_SRC_URI_MIRROR}"
265     if [[ $? = 0 ]]
266     then
267     break
268     else
269     continue
270     fi
271     fi
272     done
273     elif [[ -n $(echo ${my_SRC_URI} | grep 'gnome://') ]]
274     then
275     for mirror in ${GNOME_MIRRORS}
276     do
277     my_SRC_URI_MIRROR="$(echo ${my_SRC_URI} | sed "s|gnome:/|${mirror}|g")"
278    
279     if [[ ${FETCHING} = true ]]
280     then
281     echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI_MIRROR}${COLDEFAULT}"
282   wget \   wget \
283   --passive-ftp \   --passive-ftp \
284   --tries 3 \   --tries 3 \
# Line 208  download_sources() Line 297  download_sources()
297   else   else
298   if [[ ${FETCHING} = true ]]   if [[ ${FETCHING} = true ]]
299   then   then
300   echo "==> fetching ${my_SRC_URI}"   echo -e "${COLBLUE}==>${COLGREEN} fetching ${my_SRC_URI}${COLDEFAULT}"
301   wget \   wget \
302   --passive-ftp \   --passive-ftp \
303   --tries 3 \   --tries 3 \
# Line 228  download_sources() Line 317  download_sources()
317    
318   # recheck md5 sums   # recheck md5 sums
319   echo   echo
320   echo ">== Checking MD5 sums:"   echo -e "${COLBLUE}===${COLGREEN} Checking MD5 sums:${COLDEFAULT}"
321   ( cd ${SOURCEDIR}/${PNAME}; md5sum --check ${DB_MD5_SUM_FILE} ) || die "md5 failed"   ( cd ${SOURCEDIR}/${PNAME}; md5sum --check ${DB_MD5_SUM_FILE} ) || die "md5 failed"
322   echo   echo
323    
# Line 275  mconfigure() Line 364  mconfigure()
364   ./configure \   ./configure \
365   --prefix=/usr \   --prefix=/usr \
366   --host=${CHOST} \   --host=${CHOST} \
367     --build=${CHOST} \
368   --mandir=/usr/share/man \   --mandir=/usr/share/man \
369   --infodir=/usr/share/info \   --infodir=/usr/share/info \
370   --datadir=/usr/share \   --datadir=/usr/share \
# Line 318  munpack() Line 408  munpack()
408    
409   SRCFILE=$1   SRCFILE=$1
410    
411   if [ -z "$2" ]   if [[ -z $2 ]]
412   then   then
413   DEST=${BUILDDIR}   DEST=${BUILDDIR}
414   else   else
415   DEST=$2   DEST=$2
416   fi   fi
417    
418     [[ ! -d ${DEST} ]] && install -d ${DEST}
419    
420   case "${SRCFILE##*.}" in   case "${SRCFILE##*.}" in
421   bz2)   bz2)
422   IFTAR="$(basename $SRCFILE .bz2)"   IFTAR="$(basename $SRCFILE .bz2)"
423   IFTAR="${IFTAR##*.}"   IFTAR="${IFTAR##*.}"
424   if [[ ${IFTAR} = tar ]]   if [[ ${IFTAR} = tar ]]
425   then   then
426   tar --no-same-owner -xvjf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST}   tar --no-same-owner -xvjf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST} || die ".tar.bz2 unpack failed."
427     else
428     pushd ${DEST} > /dev/null
429     bzcat ${SOURCEDIR}/${PNAME}/${SRCFILE} > ${DEST}/$(basename ${SRCFILE} .bz2) || die ".bz2 unpack failed."
430     popd > /dev/null
431   fi   fi
432   ;;   ;;
433   gz)   gz)
# Line 339  munpack() Line 435  munpack()
435   IFTAR="${IFTAR##*.}"   IFTAR="${IFTAR##*.}"
436   if [[ ${IFTAR} = tar ]]   if [[ ${IFTAR} = tar ]]
437   then   then
438   tar --no-same-owner -xvzf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST}   tar --no-same-owner -xvzf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST} || die ".tar.gz unpack failed."
439     else
440     pushd ${DEST} > /dev/null
441     zcat ${SOURCEDIR}/${PNAME}/${SRCFILE} > ${DEST}/$(basename ${SRCFILE} .gz) || die ".gz unpack failed."
442     popd > /dev/null
443   fi   fi
444   ;;   ;;
445   tbz2)   tbz2|mpks|mpk)
446   tar --no-same-owner -xvjf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST}   tar --no-same-owner -xvjf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST} || die ".tbz2 unpack failed."
447   ;;   ;;
448   tgz)   tgz)
449   tar --no-same-owner -xvzf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST}   tar --no-same-owner -xvzf ${SOURCEDIR}/${PNAME}/${SRCFILE} -C ${DEST} || die ".tgz unpack failed."
450     ;;
451     rar)
452     unrar x ${SOURCEDIR}/${PNAME}/${SRCFILE} ${DEST}  || die ".rar unpack failed."
453     ;;
454     zip|xpi)
455     unzip ${SOURCEDIR}/${PNAME}/${SRCFILE} -d ${DEST} || die ".zip unpack failed."
456     ;;
457     rpm)
458     pushd ${DEST} > /dev/null
459     rpm2targz ${SOURCEDIR}/${PNAME}/${SRCFILE} || die "rpm2targz: .rpm unpack failed."
460     tar --no-same-owner -xvzf ${SRCFILE/.rpm/.tar.gz} || die "tar: .rpm unpack failed."
461     if [[ -f ${DEST}/${SRCFILE/.rpm/.tar.gz} ]]
462     then
463     rm ${DEST}/${SRCFILE/.rpm/.tar.gz}
464     fi
465   ;;   ;;
466   *)   *)
467   die "munpack failed"   die "munpack failed"
# Line 358  mpatch() Line 473  mpatch()
473  {  {
474   local PATCHOPTS   local PATCHOPTS
475   local PATCHFILE   local PATCHFILE
476     local i
477    
478   PATCHOPTS=$1   PATCHOPTS=$1
479   PATCHFILE=$2   PATCHFILE=$2
480    
481     if [[ -z $2 ]]
482     then
483     PATCHFILE=$1
484    
485     ## patch level auto-detection, get patch level
486     for ((i=0; i < 10; i++))
487     do
488     patch --dry-run -Np${i} -i ${SOURCEDIR}/${PNAME}/${PATCHFILE} > /dev/null
489     if [[ $? = 0 ]]
490     then
491     PATCHOPTS="-Np${i}"
492     break
493     fi
494     done
495     fi
496    
497     echo -e "${COLBLUE}*** ${COLGREEN}Applying patch '${PATCHFILE}'${COLDEFAULT}"
498   patch "${PATCHOPTS}" -i ${SOURCEDIR}/${PNAME}/${PATCHFILE}   patch "${PATCHOPTS}" -i ${SOURCEDIR}/${PNAME}/${PATCHFILE}
499  }  }
500    
501    mlibtoolize()
502    {
503     local opts="$@"
504     [[ -z ${opts} ]] && opts="--copy --force"
505    
506     libtoolize ${opts} || die "running: mlibtoolize ${opts}"
507    }
508    
509  minstalldocs()  minstalldocs()
510  {  {
# Line 419  setup_distcc_environment() Line 559  setup_distcc_environment()
559  {  {
560   if [ -x /usr/bin/distcc ]   if [ -x /usr/bin/distcc ]
561   then   then
562   echo "Using DistCC for compilation ..."   echo -e "${COLBLUE}---${COLGREEN} Using DistCC for compilation ...${COLDEFAULT}"
563   export PATH=/usr/$(mlibdir)/distcc/bin:${PATH} || die "distcc: could not export new $PATH"   export PATH=/usr/$(mlibdir)/distcc/bin:${PATH} || die "distcc: could not export new $PATH"
564    
565   export DISTCC_DIR="${DISTCC_DIR}" || die "distcc_dir export failed"   export DISTCC_DIR="${DISTCC_DIR}" || die "distcc_dir export failed"
# Line 434  setup_ccache_environment() Line 574  setup_ccache_environment()
574  {  {
575   if [ -x /usr/bin/ccache ]   if [ -x /usr/bin/ccache ]
576   then   then
577   echo "Using CCache for compilation ..."   echo -e "${COLBLUE}---${COLGREEN} Using CCache for compilation ...${COLDEFAULT}"
578   export PATH=/usr/$(mlibdir)/ccache/bin:${PATH} || die "ccache: could not export new $PATH"   export PATH=/usr/$(mlibdir)/ccache/bin:${PATH} || die "ccache: could not export new $PATH"
579   fi   fi
580  }  }
# Line 458  fix_mage_deps() Line 598  fix_mage_deps()
598   # fix DEPEND   # fix DEPEND
599   while read sym dep   while read sym dep
600   do   do
601     # ignore empty lines
602     [[ -z ${dep} ]] && continue
603    
604   cat="$(dirname ${dep})"   cat="$(dirname ${dep})"
605   # change if not virtual   # change if not virtual
606   if [[ ${cat} = virtual ]]   if [[ ${cat} = virtual ]]
# Line 510  EOF Line 653  EOF
653  # special tags:  # special tags:
654  #   PKGTYPE               type of pkg  #   PKGTYPE               type of pkg
655  #   INHERITS              which functions get included  #   INHERITS              which functions get included
656  #   SPECIAL_FUNCTIONS     special functions wich should also be added  #   SPECIAL_FUNCTIONS     special functions which should also be added
657  #                         warning: they get killed before the build starts !  #                         warning: they get killed before the build starts !
658  #  #
659  #   MAGE_TREE_DEST        target destination of the generated tree  #   MAGE_TREE_DEST        target destination of the generated tree
# Line 538  build_mage_script() Line 681  build_mage_script()
681   dest="${MAGE_TREE_DEST}/${PCATEGORIE}/${PNAME}${target}/${magefile}"   dest="${MAGE_TREE_DEST}/${PCATEGORIE}/${PNAME}${target}/${magefile}"
682    
683   # show what we are doing   # show what we are doing
684   echo "Generating Mage file:"   echo -e "${COLBLUE}===${COLGREEN} generating mage file:${COLDEFAULT}"
685   echo "  ${dest}"   echo "${dest}"
686    
687   install -d "$(dirname ${dest})"   install -d "$(dirname ${dest})"
688   # now build the mage file   # now build the mage file
689   > ${dest}   > ${dest}
690    
691   # header   # header
692   echo '# $Header: /home/cvsd/magellan-cvs/magellan-src/mage/usr/lib/mage/smage2.sh,v 1.42 2006-03-22 17:45:49 niro Exp $' >> ${dest}   echo '# $Header: /home/cvsd/magellan-cvs/magellan-src/mage/usr/lib/mage/smage2.sh,v 1.62 2007-11-28 10:47:50 niro Exp $' >> ${dest}
693   echo  >> ${dest}   echo  >> ${dest}
694    
695   # pgkname and state   # pgkname and state
# Line 654  regen_mage_tree() Line 797  regen_mage_tree()
797   # now unset all uneeded vars to be safe   # now unset all uneeded vars to be safe
798   # unset PKGNAME <-- don't do that; smage needs this var   # unset PKGNAME <-- don't do that; smage needs this var
799   # unset to be safe (quotes needed !)   # unset to be safe (quotes needed !)
800   for i in ${SPECIAL_FUNCTIONS}  # for i in ${SPECIAL_FUNCTIONS}
801   do  # do
802   unset "${i}"  # unset "${i}"
803   done  # done
804   unset SPECIAL_FUNCTIONS   unset SPECIAL_FUNCTIONS
805   for i in ${SPECIAL_VARS}  # for i in ${SPECIAL_VARS}
806   do  # do
807   unset "${i}"  # unset "${i}"
808   done  # done
809   unset SPECIAL_VARS   unset SPECIAL_VARS
810   unset STATE   unset STATE
811   unset DESCRIPTION   unset DESCRIPTION
# Line 745  generate_package_md5sum() Line 888  generate_package_md5sum()
888   # build pkg-md5-sum only if requested   # build pkg-md5-sum only if requested
889   if [[ ${REGEN_MAGE_TREE} = true ]]   if [[ ${REGEN_MAGE_TREE} = true ]]
890   then   then
891   echo -n "Generating a md5sum for ${pkgname}.${PKGSUFFIX} ... "   echo -ne "${COLBLUE}===${COLGREEN} generating md5's for ${pkgname}.${PKGSUFFIX} ... ${COLDEFAULT}"
892    
893   # abort if not exist   # abort if not exist
894   if [ ! -f ${PKGDIR}/${pkgname}.${PKGSUFFIX} ]   if [ ! -f ${PKGDIR}/${pkgname}.${PKGSUFFIX} ]
895   then   then
896   echo "! exists"   echo -e "${COLRED}! exists${COLDEFAULT}"
897   return 0   return 0
898   fi   fi
899    
# Line 764  generate_package_md5sum() Line 907  generate_package_md5sum()
907   # gen md5sum   # gen md5sum
908   ( cd ${PKGDIR}; md5sum "${pkgname}.${PKGSUFFIX}" ) \   ( cd ${PKGDIR}; md5sum "${pkgname}.${PKGSUFFIX}" ) \
909   > ${dest}/${pkgname}.md5   > ${dest}/${pkgname}.md5
910   echo "done"   echo -e "${COLGREEN}done${COLDEFAULT}"
911     fi
912    }
913    
914    source_pkg_build()
915    {
916     if [[ ${PKGTYPE} = virtual ]]
917     then
918     echo "Virtual package detected; src-pkg-tarball not necessary ..."
919     return 0
920   fi   fi
921    
922     if [[ ! -d ${SOURCEDIR}/${PNAME} ]]
923     then
924     echo "No SRC_URI defined; src-pkg-tarball not necessary ..."
925     return 0
926     fi
927    
928     [ -z "${SRCPKGDIR}" ] && die "\$SRCPKGDIR not found. Please setup your ${MAGERC} correctly."
929    
930     echo -e "${COLGREEN}Creating source package tarball ... ${COLDEFAULT}"
931    
932     # include the smage2 file
933     cp ${SMAGENAME} ${SOURCEDIR}/${PNAME}
934    
935     ( cd ${SOURCEDIR}; tar cvjf ${BUILDDIR}/${PNAME}-${PVER}-${PBUILD}.tar.bz2 ${PNAME}; )
936     [[ ! -d ${SRCPKGDIR} ]] && install -d ${SRCPKGDIR}
937     mv ${BUILDDIR}/${PNAME}-${PVER}-${PBUILD}.tar.bz2 ${SRCPKGDIR}/${PNAME}-${PVER}-${PBUILD}.${SRCPKGSUFFIX}
938    
939     echo -e "${COLGREEN}Source package ${COLBLUE}${PNAME}-${PVER}-${PBUILD}.${SRCPKGSUFFIX} ${COLGREEN}successfully builded.${COLDEFAULT}"
940  }  }
941    
942    step_by_step()
943    {
944     if [[ ${STEP_BY_STEP} = true ]]
945     then
946     echo "${COLRED}Step-by-step enabled! Paused after $1.${COLDEFAULT}"
947     echo "Press [enter] to continue"
948     read
949     fi
950    }
951    
952    
953  # print out our version  # print out our version
954  showversion  showversion
955  echo  echo
# Line 899  then Line 1081  then
1081   exit 0   exit 0
1082  fi  fi
1083    
1084    if [ "$1" == "--create-src-tarball" -a -n "$2" ]
1085    then
1086     # set correct SMAGENAME
1087     SMAGENAME="$2"
1088     MD5DIR="$(dirname ${SMAGENAME})/md5"
1089    
1090     echo -e "${COLGREEN}create-src-tarball called for ${COLBLUE}${SMAGENAME}${COLGREEN} ...${COLDEFAULT}"
1091    
1092     source ${SMAGENAME} || die "regen: smage2 not found"
1093    
1094     if [[ -d ${SOURCEDIR}/${PNAME} ]]
1095     then
1096     echo -e "${COLGREEN}Deleting old sourcefiles ${COLBLUE}${SOURCEDIR}/${PNAME}${COLGREEN} ...${COLDEFAULT}"
1097     rm -rf ${SOURCEDIR}/${PKGNAME}
1098     fi
1099    
1100     download_sources
1101     source_pkg_build ${SMAGENAME}
1102     exit 0
1103    fi
1104    
1105    if [ "$1" == "--src-tarball" -a -n "$2" ] || [ "$1" == "-st" -a -n "$2" ]
1106    then
1107     SRCPKGTARBALL="${2}"
1108     USE_SRC_PKG_TARBALL=true
1109    
1110     # abort if given file is not a source pkg
1111     [[ ${SRCPKGTARBALL##*.} != ${SRCPKGSUFFIX} ]] && die "${SRCPKGTARBALL} is not a valid src-pkg file."
1112    
1113     # set correct SMAGENAME; use the one that the src_pkg provide
1114     # /path/to/SOURCEDIR/PNAME/SMAGENAME
1115     SMAGENAME="${SOURCEDIR}/$(basename ${SRCPKGTARBALL%-*-*})/$(basename ${SRCPKGTARBALL} .${SRCPKGSUFFIX}).${SMAGESUFFIX}"
1116    
1117     echo -e "${COLGREEN}Using src-tarball ${COLBLUE}${SRCPKGTARBALL}${COLGREEN} ...${COLDEFAULT}"
1118    
1119     [[ ! -d ${SOURCEDIR} ]] && install -d ${SOURCEDIR}
1120    
1121     # unpack srctarball
1122     [[ ! -f ${SRCPKGTARBALL} ]] && die "Error: ${SRCPKGTARBALL} does not exist. Aborting."
1123    
1124     tar xvjf ${SRCPKGTARBALL} -C ${SOURCEDIR} || die  "Error unpackung src-tarball ${SRCPKGTARBALL}"
1125    
1126     [[ ! -f ${SMAGENAME} ]] && die "Included smage2 file in src-tarball not found: ${SMAGENAME}"
1127    fi
1128    
1129    
1130  [ ! -e ${MLIBDIR}/pkgbuild_dir.sh ] && die "Error: ${MLIBDIR}/pkgbuild_dir.sh not found. Aborting."  [ ! -e ${MLIBDIR}/pkgbuild_dir.sh ] && die "Error: ${MLIBDIR}/pkgbuild_dir.sh not found. Aborting."
1131  [ -z "$(basename ${SMAGENAME} | grep .${SMAGESUFFIX})" ] &&  [ -z "$(basename ${SMAGENAME} | grep .${SMAGESUFFIX})" ] &&
1132   die "File '$(basename ${SMAGENAME})' is not a sMage v${SMAGEVERSION} file. Aborting."   die "File '$(basename ${SMAGENAME})' is not a sMage v${SMAGEVERSION} file. Aborting."
1133  [ -z "${SOURCEDIR}" ] && die "\$SOURCEDIR not found. Please setup your mage.rc correctly."  [ -z "${SOURCEDIR}" ] && die "\$SOURCEDIR not found. Please setup your ${MAGERC} correctly."
1134  [ -z "${SMAGESCRIPTSDIR}" ] && die "\$SMAGESCRIPTSDIR not found. Please setup your mage.rc correctly."  [ -z "${SMAGESCRIPTSDIR}" ] && die "\$SMAGESCRIPTSDIR not found. Please setup your ${MAGERC} correctly."
1135  [ -z "${SMAGE2RSYNC}" ] && die "\$SMAGE2RSYNC not found. Please setup your mage.rc correctly."  [ -z "${SMAGE2RSYNC}" ] && die "\$SMAGE2RSYNC not found. Please setup your ${MAGERC} correctly."
1136  [ -z "${BINDIR}" ] && die "no BINDIR variable found in /etc/mage.rc"  [ -z "${BINDIR}" ] && die "no BINDIR variable found in ${MAGERC}"
1137  [ -z "${CHOST}" ] && die "no CHOST variable found in /etc/mage.rc"  [ -z "${CHOST}" ] && die "no CHOST variable found in ${MAGERC}"
1138  [ -z "${CFLAGS}" ] && die "no CFLAGS variable found in /etc/mage.rc"  [ -z "${CFLAGS}" ] && die "no CFLAGS variable found in ${MAGERC}"
1139  [ -z "${CXXFLAGS}" ] && die "no CXXFLAGS variable found in /etc/mage.rc"  [ -z "${CXXFLAGS}" ] && die "no CXXFLAGS variable found in ${MAGERC}"
1140    
1141  source ${SMAGENAME} || die "source failed"  source ${SMAGENAME} || die "source failed"
1142  PKGNAME="${PNAME}-${PVER}-${ARCH}-${PBUILD}"  PKGNAME="${PNAME}-${PVER}-${ARCH}-${PBUILD}"
1143  MD5DIR="$(dirname ${SMAGENAME})/md5"  MD5DIR="$(dirname ${SMAGENAME})/md5"
1144    
1145  xtitle "Compiling ${PKGNAME}"  xtitle "Compiling ${PKGNAME}"
1146  echo "Compiling ${PKGNAME}"  echo -e "${COLGREEN}Compiling ${PKGNAME}${COLDEFAULT}"
1147    
1148  # auto regen mage tree if requested  # auto regen mage tree if requested
1149  regen_mage_tree  regen_mage_tree
1150    
1151    if [[ ${CREATE_SRC_PKG_TARBALL} = true ]]
1152    then
1153     if [[ -d ${SOURCEDIR}/${PNAME} ]]
1154     then
1155     echo -e "${COLBLUE}===${COLGREEN} deleting old sourcefiles ${COLBLUE}${SOURCEDIR}/${PNAME}${COLGREEN} ...${COLDEFAULT}"
1156     rm -rf ${SOURCEDIR}/${PNAME}
1157     fi
1158    fi
1159    
1160  # download sources  # download sources
1161  download_sources  [[ ${USE_SRC_PKG_TARBALL} != true ]] && download_sources
1162    
1163  # fixes some issues with these functions  # fixes some issues with these functions
1164  export -f src_prepare || die "src_prepare export failed"  export -f src_prepare || die "src_prepare export failed"
# Line 978  then Line 1215  then
1215   mage rmstamp   mage rmstamp
1216  fi  fi
1217    
1218  src_prepare || die "src_prepare failed"  # setup build loggins
1219  src_compile || die "src_compile failed"  [[ ! -d /var/log/smage ]] && install -d /var/log/smage
1220  src_install || die "src_install failed"  echo -e "### Build started on $(date) ###\n" > /var/log/smage/${PKGNAME}.log
1221    
1222    src_prepare || die "src_prepare failed" | ${SMAGE_LOG_CMD}
1223    step_by_step $_
1224    src_compile || die "src_compile failed" | ${SMAGE_LOG_CMD}
1225    step_by_step $_
1226    src_install || die "src_install failed" | ${SMAGE_LOG_CMD}
1227    step_by_step $_
1228    
1229    
1230  # compressing doc, info & man files  # compressing doc, info & man files
 echo -e "Compressing man-pages ..."  
1231  if [ -d ${BUILDDIR}/builded/usr/share/man ]  if [ -d ${BUILDDIR}/builded/usr/share/man ]
1232  then  then
1233     echo -e "${COLBLUE}===${COLGREEN} compressing man-pages ...${COLDEFAULT}"
1234   ${MLIBDIR}/compressdoc -g -9 ${BUILDDIR}/builded/usr/share/man   ${MLIBDIR}/compressdoc -g -9 ${BUILDDIR}/builded/usr/share/man
1235  fi  fi
1236    
 echo -e "Compressing info-pages ..."  
1237  if [ -d ${BUILDDIR}/builded/usr/share/info ]  if [ -d ${BUILDDIR}/builded/usr/share/info ]
1238  then  then
1239     echo -e "${COLBLUE}===${COLGREEN} compressing info-pages ...${COLDEFAULT}"
1240   ${MLIBDIR}/compressdoc -g -9 ${BUILDDIR}/builded/usr/share/info   ${MLIBDIR}/compressdoc -g -9 ${BUILDDIR}/builded/usr/share/info
1241  fi  fi
1242    
# Line 1002  case ${NOSTRIP} in Line 1246  case ${NOSTRIP} in
1246   echo -e "NOSTRIP=true detected; Package will not be stripped ..."   echo -e "NOSTRIP=true detected; Package will not be stripped ..."
1247   ;;   ;;
1248   *)   *)
1249   echo -e "Stripping binaries ..."   echo -e "${COLBLUE}===${COLGREEN} stripping binaries ...${COLDEFAULT}"
1250   mstripbins ${BINDIR}   mstripbins ${BINDIR}
1251   echo -e "Stripping libraries ..."   echo -e "${COLBLUE}===${COLGREEN} stripping libraries ...${COLDEFAULT}"
1252   mstriplibs ${BINDIR}   mstriplibs ${BINDIR}
1253   ;;   ;;
1254  esac  esac
# Line 1040  case ${NOPKGBUILD} in Line 1284  case ${NOPKGBUILD} in
1284   --parch "${ARCH}" \   --parch "${ARCH}" \
1285   --target "${target}"   --target "${target}"
1286    
1287   echo -e "\nPackage ${PNAME}-${target}-${PVER}-${ARCH}-${PBUILD} successfully builded.\n"   echo -e "${COLGREEN}\nPackage ${PNAME}-${target}-${PVER}-${ARCH}-${PBUILD} successfully builded.\n${COLDEFAULT}"
1288   done   done
1289   else   else
1290   ${MLIBDIR}/pkgbuild_dir.sh ${PKGNAME} ${BINDIR} || die "package-build failed"   ${MLIBDIR}/pkgbuild_dir.sh ${PKGNAME} ${BINDIR} || die "package-build failed"
# Line 1053  case ${NOPKGBUILD} in Line 1297  case ${NOPKGBUILD} in
1297   --pbuild "${PBUILD}" \   --pbuild "${PBUILD}" \
1298   --parch "${ARCH}"   --parch "${ARCH}"
1299    
1300   echo -e "\nPackage ${PKGNAME} successfully builded.\n"   echo -e "${COLGREEN}\nPackage ${PKGNAME} successfully builded.\n${COLDEFAULT}"
1301   fi   fi
1302    
1303     # build src-pkg-tarball if requested
1304     [[ ${CREATE_SRC_PKG_TARBALL} = true ]] && source_pkg_build ${SMAGENAME}
1305   ;;   ;;
1306  esac  esac
1307    
1308    if [[ ${SMAGE_BUILD_LOGGING} != false ]]
1309    then
1310     bzip2 -9f /var/log/smage/${PKGNAME}.log
1311    else
1312     [[ -f /var/log/smage/${PKGNAME}.log ]] && rm /var/log/smage/${PKGNAME}.log
1313    fi
1314    
1315  # for sure  # for sure
1316  unset NOPKGBUILD  unset NOPKGBUILD
1317  unset NOSTRIP  unset NOSTRIP

Legend:
Removed from v.351  
changed lines
  Added in v.880