sbopkg/tools/sspm
slakmagik 76e6c5ddb1 make README symlinks; modify build-related files
A cluster of changes related to creating symlinks in the
  /etc/{renames,repos}.d directories that point to the corresponding
  README in sbopkg's docdir and then generally updating most
  build-related files and getting it all documented.

  * 50-default: renamed to 50-default.renames

  * NEWS: note symlink docs and rename issues

  * README-renames: update to reflect new default filename and the fact
    that the files must end in '.renames'.

  * sbopkg.conf.5, sbopkg.8: update to reflect the new renames stuff
    (and the earlier repo file/dir-related changes I forgot to document
    there).

  * sbopkg: get_new_name(), get_old_name(): have grep only look through
    *.renames files and not, say, symlinks to READMEs.

  * doinst.sh: bring into alignment with the current SBo template.

  * tools/sbopkg.SlackBuild: make links from README-repos and
    README-renames to READMEs in the corresponding /etc/sbopkg/*.d
    directories.

  * tools/slack-desc: bring into alignment with the current SBo
    template.

  * tools/sspm: update address, add printe() and use it.
2011-03-10 04:17:52 +00:00

107 lines
2.9 KiB
Bash

#!/bin/bash
# $Id$
# Written by slakmagik <slakmagik@gmail.com>
# Released under the WTFPL
script=${0##*/}
# USER-MODIFIABLE VARIABLES
# this needs to be where the checked out svn directory is.
repo="/tmp/sbopkg-read-only"
remote_repo="http://sbopkg.googlecode.com/svn/trunk/"
export OUTPUT="${OUTPUT:-/tmp}"
usage() {
cat << EOF
$script: sbopkg subversion package maker usage: $script [-b] | [-i] | [-s]
-b build a package from local subversion repository
-i install the package
-s syncs the local repo to the remote one
No arguments is equivalent to -bis: $script checks out the latest revision to
the subversion repository and builds and installs a package from it.
EOF
exit
}
printe() {
printf "$script: $@" | tr -s ' ' | fmt -sw78 >&2
exit 1
}
if (( $# == 0 )); then
build="yes"
inst="yes"
sync="yes"
else
build="no"
inst="no"
sync="no"
fi
while getopts :bis opt; do
case $opt in
b) build="yes" ;;
i) inst="yes" ;;
s) sync="yes" ;;
*) usage ;;
esac
done
# Make sure we are root.
if (( $(id -u) != 0 )); then
printe "$script must be run by the root user."
fi
if [[ $sync == yes ]]; then
if [[ -w $repo ]] || [[ ! -e $repo && -w ${repo%/*} ]]; then
svn checkout $remote_repo $repo || printe "checkout failed"
else
printe "$repo is not writable.\nChange your privileges or the \
value of the \"repo\" variable.\n"
fi
fi
# this allows for a version mismatch if someone builds a package, doesn't
# install it, then syncs their repo to a newer version, then does install the
# old package. But, as the doctor said to the guy who complained that it hurt
# when he did that, don't DO that.
if [[ $build == yes || $inst == yes ]]; then
svn_script="$repo/src/usr/sbin/sbopkg"
if [ -r $svn_script ]; then
export VERSION=svn$(svnversion $repo)
else
printe "unable to find $svn_script.\nPlease check your repository."
fi
if [[ $OUTPUT =~ "$repo/(sbopkg-$VERSION|root-tools)" ]]; then
printe "the OUTPUT variable is set to a path that will be \
removed.\nPlease alter the value of the variable.\n"
fi
output_pkg=$OUTPUT/sbopkg-$VERSION-noarch-1_cng.tgz
if [[ $build == yes ]]; then
cd $repo
if [ -d sbopkg-$VERSION ] || [ -d root-tools ]; then
printe "director(y|ies) exist(s)"
fi
cp -r src sbopkg-$VERSION
cp -r tools root-tools
tar --exclude='*.svn*' --exclude='*.rej' \
--exclude='*~' --exclude='tags' \
-czvf $repo/root-tools/sbopkg-$VERSION.tar.gz sbopkg-$VERSION
cd $repo/root-tools
sh sbopkg.SlackBuild
cd $repo
rm -rf root-tools
rm -rf sbopkg-$VERSION
fi
if [[ $inst == yes ]]; then
if [ -r $output_pkg ]; then
upgradepkg --install-new --reinstall $output_pkg
else
printe "$output_pkg not found."
fi
fi
fi