]> gitweb.fluxo.info Git - simplepkg.git/commitdiff
mkslackbuild e generic.mkslackbuild: atualizando...
authorrudson <rudson@04377dda-e619-0410-9926-eae83683ac58>
Sat, 10 Feb 2007 14:24:23 +0000 (14:24 +0000)
committerrudson <rudson@04377dda-e619-0410-9926-eae83683ac58>
Sat, 10 Feb 2007 14:24:23 +0000 (14:24 +0000)
git-svn-id: svn+slack://slack.fluxo.info/var/svn/simplepkg@179 04377dda-e619-0410-9926-eae83683ac58

conf/generic.mkSlackBuild.new [new file with mode: 0644]
utils/mkslackbuild

diff --git a/conf/generic.mkSlackBuild.new b/conf/generic.mkSlackBuild.new
new file mode 100644 (file)
index 0000000..e8c432a
--- /dev/null
@@ -0,0 +1,224 @@
+###################################################
+## Generic template for SlackBuilds
+##
+## Version 0.3.3 - Luis ( luis at riseup d0t net)
+##
+###################################################
+<head> all
+#!/bin/bash
+#
+# SlackBuild for [[PROGRAM NAME]]
+# [[PROGRAM URL]]
+#
+# Author: [[SLACKBUILD AUTHOR]]
+#
+</head>
+
+<slackbuildrc> all
+# Look for slackbuildrc
+if [ -f ~/.slackbuildrc ]; then
+  source ~/.slackbuildrc
+elif [ -f /etc/slackbuildrc ]; then
+  source /etc/slackbuildrc
+fi
+</slackbuildrc>
+
+<set_variables> all
+# Set variables
+CWD=`pwd`
+SRC_NAME="[[SOURCE NAME]]"
+PKG_NAME="[[PACKAGE NAME]]"
+ARCH=${ARCH:=[[ARCH]]}
+VERSION=${VERSION:=[[VERSION]]}
+BUILD=${BUILD:=1[[SLACKBUILD AUTHOR INITIALS]]}
+SRC_DIR=${SRC_DIR:=$CWD}
+TMP=${TMP:=/tmp}
+PKG=${PKG:=$TMP/package-$PKG_NAME}
+REPOS=${REPOS:=$TMP}
+PREFIX=${PREFIX:=[[PREFIX]]}
+PKG_SRC="$SRC_DIR/$SRC_NAME-$VERSION"
+</set_variables>
+
+<slkflags> all
+# Set system libraries' path and optmization flags based on $ARCH
+LIBDIR="$PREFIX/lib"
+
+if [ "$ARCH" = "i386" ]; then
+  SLKCFLAGS="-O2 -march=i386 -mcpu=i686"
+elif [ "$ARCH" = "i486" ]; then
+  SLKCFLAGS="-O2 -march=i486 -mcpu=i686"
+elif [ "$ARCH" = "i686" ]; then
+  SLKCFLAGS="-O2 -march=i686"
+elif [ "$ARCH" = "s390" ]; then
+  SLKCFLAGS="-O2"
+elif [ "$ARCH" = "x86_64" ]; then
+  SLKCFLAGS="-O2"
+  LIBDIR="$PREFIX/lib64"
+fi
+</slkflags>
+
+<error_codes> on
+# Set error codes (used by createpkg)
+ERROR_WGET=31;      ERROR_MAKE=32;      ERROR_INSTALL=33
+ERROR_MD5=34;       ERROR_CONF=35;      ERROR_HELP=36
+ERROR_TAR=37;       ERROR_MKPKG=38;     ERROR_GPG=39
+ERROR_PATCH=40;     ERROR_VCS=41;       ERROR_MKDIR=42
+</error_codes>
+
+<start_structure> all
+# Clean up any leftovers of previous builds
+rm -rf "$PKG_SRC" 2> /dev/null
+rm -rf "$PKG" 2> /dev/null
+
+# Create directories, if necessary
+mkdir -p "$SRC_DIR" || exit $ERROR_MKDIR
+mkdir -p "$PKG" || exit $ERROR_MKDIR
+mkdir -p "$REPOS" || exit $ERROR_MKDIR
+</start_structure>
+
+<import_gpg_signing> off
+# Import (minimized) signing key from
+# [[SIGNING KEY URL]]
+gpg --import << EOKEY || exit $ERROR_GPG
+[[SIGNING KEY]]
+EOKEY
+</import_gpg_signing>
+
+<download_source> on
+# Dowload source and its signature, if necessary
+SRC="$SRC_NAME-$VERSION.tar.[[SOURCE EXTENSION]]"
+URL="[[DOWNLOAD FOLDER URL]]/$SRC"
+
+if [ ! -f "$SRC_DIR/$SRC" ] || ! [[DECOMPRESSOR]] [[DECOMPRESSOR TEST FLAG]] "$SRC_DIR/$SRC" 2> /dev/null; then
+  wget "$URL" -O "$SRC_DIR/$SRC" || exit $ERROR_WGET
+fi
+</download_source>
+
+<download_signature_and_check> off
+if [ ! -f "$SRC_DIR/$SRC.sig" ]; then
+  wget "$URL.sig" -O "$SRC_DIR/$SRC.sig" || exit $ERROR_WGET
+fi
+
+# Check source's signature
+gpg --verify "$SRC_DIR/$SRC.sig" "$SRC_DIR/$SRC" || exit $ERROR_GPG
+</download_signature_and_check>
+
+<untar_source> all
+# Untar, patch, configure, compile and install
+cd "$SRC_DIR"
+tar --no-same-owner --no-same-permissions -xvf "$SRC_DIR/$SRC" || exit $ERROR_TAR
+cd "$PKG_SRC"
+</untar_source>
+
+<path_source> off
+patch -Np[[NUMBER OF PREFIX SLASHES TO STRIP]] < "$CWD/[[PATCH FILE]]"
+</path_source>
+
+<configure> on
+CFLAGS="$SLKCFLAGS" \
+  CXXFLAGS="$SLKCFLAGS" \
+  ./configure \
+  --prefix="$PREFIX" --libdir="$LIBDIR" [[OTHER CONFIGURE ARGS]] || exit $ERROR_CONF
+</configure>
+
+<make_package> all
+make || exit $ERROR_MAKE
+</make_package>
+
+<install_package> all
+make install DESTDIR="$PKG" || exit $ERROR_INSTALL
+</install_package>
+
+<strip_binaries> all
+# Strip binaries
+( cd "$PKG"
+  find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | \
+    xargs strip --strip-unneeded 2> /dev/null
+  find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | \
+    xargs strip --strip-unneeded 2> /dev/null
+)
+</strip_binaries>
+
+<compress_manpages> off
+# Compress and link manpages
+if [ -d "$PKG/$PREFIX/man" ]; then
+  ( cd "$PKG/$PREFIX/man"
+    for manpagedir in $(find . -type d -name "man*") ; do
+      ( cd $manpagedir
+        for eachpage in $( find . -type l -maxdepth 1) ; do
+          ln -s $( readlink $eachpage ).gz $eachpage.gz
+          rm $eachpage
+        done
+        gzip -9 *.?
+      )
+    done
+  )
+fi
+</compress_manpages>
+
+<compress_info_files> off
+# Compress info files
+if [ -d "$PKG/$PREFIX/info" ]; then
+  ( cd "$PKG/$PREFIX/info"
+    rm -f dir
+    gzip -9 *
+  )
+fi
+</compress_info_files>
+
+<install_documentation> on
+# Install documentation
+DOCS="[[DOCUMENTATION FILES]]"
+mkdir -p "$PKG/$PREFIX/doc/$PKG_NAME-$VERSION" || exit $ERROR_MKDIR
+cp -a $DOCS "$PKG/$PREFIX/doc/$PKG_NAME-$VERSION"
+</install_documentation>
+
+<slackdesc> on
+# Add package description (slack-desc)
+mkdir -p "$PKG/install" || exit $ERROR_MKDIR
+cat << EODESC > "$PKG/install/slack-desc"
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description.  Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in.  You must
+# make exactly 11 lines for the formatting to be correct.  It's also
+# customary to leave one space after the ':'.
+
+        |-----handy-ruler------------------------------------------------------|
+[[SLACK-DESC]]
+EODESC
+</slackdesc>
+
+<postinstall_script> off
+# Add a post-installation script (doinst.sh)
+cat << EOSCRIPT > "$PKG/install/doinst.sh"
+config() {
+  NEW="\$1"
+  OLD="\$(dirname \$NEW)/\$(basename \$NEW .new)"
+  # If there's no config file by that name, mv it over:
+  if [ ! -r \$OLD ]; then
+    mv \$NEW \$OLD
+  elif [ "\$(cat \$OLD | md5sum)" = "\$(cat \$NEW | md5sum)" ]; then
+    # toss the redundant copy
+    rm \$NEW
+  fi
+  # Otherwise, we leave the .new copy for the admin to consider...
+}
+
+config path/to/config_file.new
+[[REST OF DOINST.SH]]
+EOSCRIPT
+</postinstall_script>
+
+<build_package> all
+# Build the package
+cd "$PKG"
+makepkg -l y -c n "$REPOS/$PKG_NAME-$VERSION-$ARCH-$BUILD.tgz" || exit $ERROR_MKPKG
+</build_package>
+
+<clean_builds> on
+# Delete source and build directories, if requested
+if [ "$CLEANUP" == "yes" ]; then
+  rm -rf "$PKG_SRC" "$PKG"
+fi
+</clean_builds>
index 6a2852061ecaccf384aaadf02bf4a99e1a7037e9..daefef024506e9458718fdd6303975fcaf33afb0 100755 (executable)
@@ -9,7 +9,7 @@
 # Slackbuilds são scripts utilizados no Slackware para gerar
 # pacotes tgz.
 #
-# Version 0.9.0
+# Version 0.9.1
 #
 #--------------------------------------------------------------------
 # Functions
@@ -23,6 +23,9 @@ function config_help()
 # Exit function
 function mk_exit()
 {
+    [ ! -z $SLACKBUILD ] && [ -e $SLACKBUILD ] && echo "SlackBuild save in $SLACKBUILD"
+    [ ! -z $MKSLACKBUILD ] && [ -e $MKSLACKBUILD ] && echo "mkSlackBuild save in $SLACKBUILD"
+
     clean_all
     exit $1
 }
@@ -275,7 +278,13 @@ function edit_docfiles()
         SELECTDOCS=`eval "dialog --stdout --separate-output --backtitle \"mkSlackBuild $PROG_VERSION [$MK_PKGNAME]\" --title \" Documentations files \" --checklist \"Select documentation files below:\" 20 45 13 $DOCMENU"`
     fi
 
-    MK_DOCFILES="$SELECTDOCS"
+    MK_DOCFILES="`echo $SELECTDOCS | sed ':i; N; s/\n/ /; bi'`"
+}
+
+# Edit compiler architecture
+function edit_arch()
+{
+    MK_ARCH=`dialog --stdout --backtitle "mkSlackBuild documentation files below:" --inputbox "Set an architecture to compiler:" $MK_ARCH`
 }
 
 #--------------------------------------------------------------------
@@ -294,12 +303,13 @@ function change_strings()
 # Build initial sections
 function start_build()
 {
+    change_strings "AUTHOR" "$MK_AUTHOR"
+    change_strings "AUTHOR INITIALS" $MK_AUTHOR_INITIALS
     change_strings "SOURCE NAME" "${MK_SRCNAME//.$MK_EXTENSION}"
     change_strings "PROGRAM NAME" "$MK_PKGNAME"
     change_strings "PACKAGE NAME" "$MK_PKGNAME"
     change_strings "PROGRAM URL" "$MK_URL"
-    change_strings "AUTHOR" "$MK_AUTHOR"
-    change_strings "AUTHOR INITIALS" $MK_AUTHOR_INITIALS
+    change_strings "ARCH" "$MK_ARCH"
     change_strings "VERSION" $MK_VERSION
     change_strings "SOURCE EXTENSION" $MK_EXTENSION
     change_strings "DOWNLOAD FOLDER URL" "`dirname $MK_URL`"
@@ -311,7 +321,7 @@ function start_build()
 # Mount final SlackBuild
 function mount_slackbuild()
 {
-    dialog --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" --infobox "SlackBuild save..." 5 30
+    dialog --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" --infobox "SlackBuild save in $SLACKBUILD" 5 30
 
     rm $SLACKBUILD 2>/dev/null
     for i in `seq 0 $MAXSECTION`; do
@@ -367,6 +377,9 @@ function create_slackbuild()
     # Package name, version and extension
     edit_pkgname
 
+    # Compile arch
+    edit_arch
+
     # Get source file
     dialog --stdout --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" \
             --yesno " Download $MK_SRCNAME? " 5 50
@@ -393,6 +406,9 @@ function create_slackbuild()
     # Slackbuild script name
     SLACKBUILD=$MK_SLACKBUILDDIR/$MK_PKGNAME.Slackbuild
 
+    # mkSlackBuild script name
+    MKSLACKBUILD=$BASEDIR/$MK_PKGNAME.mkslackbuild
+
     mk_slackdesc > slackdesc_$MK_PKGNAME.mkbuild
 
     # Edit builds sections
@@ -405,35 +421,35 @@ function create_slackbuild()
 # Open mkslackbuild
 function open_mkslackbuild()
 {
-    MKFILE=`dialog --stdout --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" \
+    MKSLACKBUILD=`dialog --stdout --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" \
             --title " Select source file name (use spaces to select): " \
             --fselect "$BASEDIR/" 10 70`
     [ $? -ne 0 ] && mk_exit 1
 
-    if [ -f $MKFILE ]; then
+    if [ -f $MKSLACKBUILD ]; then
         # Start defaults variables
-        source $MKFILE
+        source $MKSLACKBUILD
 
         # SlackBuild scrit name
         SLACKBUILD=$MK_SLACKBUILDDIR/$MK_PKGNAME.Slackbuild
 
         # Create files sections
-        make_file_sections $MKFILE
+        make_file_sections $MKSLACKBUILD
 
         # Main-Menu
         edit_menu
     else
         dialog --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" \
-            --msgbox "$MKFILE most be a file" 0 0
+            --msgbox "$MKSLACKBUILD most be a file" 0 0
     fi
 }
 
 # Save mkSlackbuild
 function save_mkslackbuild()
 {
-    dialog --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" --infobox "mkSlackBuild save..." 5 30
+    dialog --backtitle "mkSlackBuild $PROG_VERSION [$MK_PKGNAME]" --infobox "mkSlackBuild save in $MKSLACKBUILD" 5 30
 
-    MKSLACKBUILD=$BASEDIR/$MK_PKGNAME.mkslackbuild
+#    MKSLACKBUILD=$BASEDIR/$MK_PKGNAME.mkslackbuild
 
     rm $MKSLACKBUILD 2>/dev/null
     echo '#!/bin/bash' > $MKSLACKBUILD
@@ -498,8 +514,8 @@ function edit_menu()
 #                        Start Program
 #--------------------------------------------------------------------
 #
-set +x
-PROG_VERSION=0.9.0
+set +x                  # turn off debug
+PROG_VERSION=0.9.1
 LANG=us
 BASEDIR=`pwd`
 AUX_TMP=`mktemp -p  /tmp/ aux_tmp.XXXXXX`
@@ -528,6 +544,7 @@ MK_AUTHOR_INITIALS="[[AUTHOR INITIALS]]"
 MK_EDITOR=[[EDITOR]]
 MK_LIMITRATE="100k"
 MK_SOURCEDIR=\`pwd\`
+MK_ARCH="i468"
 #MK_URL="ftp://localhost"
 #MK_SLACKBUILDDIR=/slackbuild-dir
 EOF
@@ -536,6 +553,7 @@ fi
 source ~/.mkslackbuild
 MK_SOURCEDIR=${MK_SOURCEDIR:=$BASEDIR}
 MK_SLACKBUILDDIR=${MK_SLACKBUILDDIR:=$BASEDIR}
+MK_ARCH=${MK_ARCH:="i486"}
 
 # Config Author
 if [ "$MK_AUTHOR" = "[[AUTHOR NAME]]" ]; then