aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--conf/generic.mkSlackBuild.new224
-rwxr-xr-xutils/mkslackbuild46
2 files changed, 256 insertions, 14 deletions
diff --git a/conf/generic.mkSlackBuild.new b/conf/generic.mkSlackBuild.new
new file mode 100644
index 0000000..e8c432a
--- /dev/null
+++ b/conf/generic.mkSlackBuild.new
@@ -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>
diff --git a/utils/mkslackbuild b/utils/mkslackbuild
index 6a28520..daefef0 100755
--- a/utils/mkslackbuild
+++ b/utils/mkslackbuild
@@ -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