summaryrefslogtreecommitdiffstats
path: root/ckermit
diff options
context:
space:
mode:
author Eric Hameleers <alien@slackware.com>2008-01-20 02:15:30 +0000
committer Eric Hameleers <alien@slackware.com>2008-01-20 02:15:30 +0000
commit057d48c70ff515be97a252355a2601587e2b3360 (patch)
treedad1e1f4b681ec94ebaa923e9537617c3003a598 /ckermit
parentb3472344dbc159d30c9bcab674e89d3af4d24be5 (diff)
downloadasb-057d48c70ff515be97a252355a2601587e2b3360.tar.gz
asb-057d48c70ff515be97a252355a2601587e2b3360.tar.xz
Initial revision
Diffstat (limited to 'ckermit')
-rwxr-xr-xckermit/build/ckermit.SlackBuild226
-rw-r--r--ckermit/build/ckermit_destdir.patch73
-rw-r--r--ckermit/build/ckermit_lib64.patch40
3 files changed, 339 insertions, 0 deletions
diff --git a/ckermit/build/ckermit.SlackBuild b/ckermit/build/ckermit.SlackBuild
new file mode 100755
index 00000000..6eda144b
--- /dev/null
+++ b/ckermit/build/ckermit.SlackBuild
@@ -0,0 +1,226 @@
+#!/bin/sh
+# $Id$
+# Copyright (c) 2008 Eric Hameleers <alien@slackware.com>
+# All rights reserved.
+#
+# Permission to use, copy, modify, and distribute this software for
+# any purpose with or without fee is hereby granted, provided that
+# the above copyright notice and this permission notice appear in all
+# copies.
+#
+# THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+# IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
+# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
+# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
+# OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+# SUCH DAMAGE.
+# -----------------------------------------------------------------------------
+#
+# Slackware SlackBuild script
+# ===========================
+# By: Eric Hameleers <alien@slackware.com>
+# For: ckermit
+# Descr: program implementing the kermit file-transfer protocol
+# URL: http://www.columbia.edu/kermit/
+# Needs:
+# Changelog:
+# 8.0.211-1: 20/Jan/2008 by Eric Hameleers <alien@slackware.com>
+# * Initial build.
+#
+# Run 'sh ckermit.SlackBuild --cleanup' to build a Slackware package.
+# The package (.tgz) plus descriptive .txt file are created in /tmp .
+# Install using 'installpkg'.
+#
+# -----------------------------------------------------------------------------
+
+# Set initial variables:
+
+PRGNAM=ckermit
+VERSION=${VERSION:-8.0.211}
+VMINOR=$(echo ${VERSION} | cut -d. -f3)
+ARCH=${ARCH:-i486}
+BUILD=${BUILD:-1}
+
+DOCS="*.txt COPYING.TXT"
+
+# Where do we look for sources?
+CWD=$(pwd)
+SRCDIR=$(dirname $0)
+[ "${SRCDIR:0:1}" == "." ] && SRCDIR=${CWD}/${SRCDIR}
+
+# Place to build (TMP) package (PKG) and output (OUTPUT) the program:
+TMP=${TMP:-/tmp/build}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+# Input URL: ftp://kermit.columbia.edu/kermit/archives/cku211.tar.gz
+SOURCE="$SRCDIR/cku${VMINOR}.tar.gz"
+SRCURL="ftp://kermit.columbia.edu/kermit/archives/cku${VMINOR}.tar.gz"
+
+##
+## --- with a little luck, you won't have to edit below this point --- ##
+##
+
+# Exit the script on errors:
+set -e
+trap 'echo "$0 FAILED at line ${LINENO}" | tee $OUTPUT/error-${PRGNAM}.log' ERR
+# Catch unitialized variables:
+set -u
+P1=${1:-1}
+
+# Slackware 11 and up need other option (gcc > 3.3.x)
+if [ $(gcc -dumpversion | tr -d '.' |cut -c 1-2) -gt 33 ]; then
+ MOPT=tune
+else
+ MOPT=cpu
+fi
+
+case "$ARCH" in
+ i386) SLKCFLAGS="-O2 -march=i386 -m${MOPT}=i686"
+ SLKLDFLAGS=""; LIBDIRSUFFIX=""
+ ;;
+ i486) SLKCFLAGS="-O2 -march=i486 -m${MOPT}=i686"
+ SLKLDFLAGS=""; LIBDIRSUFFIX=""
+ ;;
+ s390) SLKCFLAGS="-O2"
+ SLKLDFLAGS=""; LIBDIRSUFFIX=""
+ ;;
+ powerpc) SLKCFLAGS="-O2"
+ SLKLDFLAGS=""; LIBDIRSUFFIX=""
+ ;;
+ x86_64) SLKCFLAGS="-O2 -fPIC"
+ SLKLDFLAGS="-L/usr/lib64"; LIBDIRSUFFIX="64"
+ ;;
+ athlon-xp) SLKCFLAGS="-march=athlon-xp -O3 -pipe -fomit-frame-pointer"
+ SLKLDFLAGS=""; LIBDIRSUFFIX=""
+ ;;
+esac
+
+# Create working directories:
+mkdir -p $OUTPUT # place for the package to be saved
+mkdir -p $TMP/tmp-$PRGNAM # location to build the source
+mkdir -p $PKG # place for the package to be built
+rm -rf $PKG/* # always erase old package's contents
+if [ "$P1" != "--oldbuild" ]; then
+ # Use the "--oldbuild" parameter to keep old build files and continue;
+ # By default we remove the remnants of previous build and continue.
+ rm -rf $TMP/tmp-$PRGNAM/*
+fi
+
+# Source file availability:
+if ! [ -f ${SOURCE} ]; then
+ if ! [ "x${SRCURL}" == "x" ]; then
+ # Check if the $SRCDIR is writable at all - if not, download to $OUTPUT
+ [ -w "$SRCDIR" ] || SOURCE="$OUTPUT/$(basename $SOURCE)"
+ echo "Source '$(basename ${SOURCE})' not available yet..."
+ echo "Will download file to $(dirname $SOURCE)"
+ wget -nv -T 20 -O "${SOURCE}" "${SRCURL}" || true
+ if [ $? -ne 0 -o ! -s "${SOURCE}" ]; then
+ echo "Downloading '$(basename ${SOURCE})' failed... aborting the build."
+ mv -f "${SOURCE}" "${SOURCE}".FAIL
+ exit 1
+ fi
+ else
+ echo "File '$(basename ${SOURCE})' not available... aborting the build."
+ exit 1
+ fi
+fi
+
+if [ "$P1" == "--download" ]; then
+ echo "Download complete."
+ exit 0
+fi
+
+# --- PACKAGE BUILDING ---
+
+echo "++"
+echo "|| $PRGNAM-$VERSION"
+echo "++"
+
+cd $TMP/tmp-$PRGNAM
+mkdir $PRGNAM-$VERSION
+cd $PRGNAM-$VERSION
+echo "Extracting the source archive(s) for $PRGNAM..."
+if $(file ${SOURCE} | grep -q ": bzip2"); then
+ tar -xjvf ${SOURCE}
+elif $(file ${SOURCE} | grep -q ": gzip"); then
+ tar -xzvf ${SOURCE}
+fi
+patch -p0 < $SRCDIR/${PRGNAM}_destdir.patch \
+ 2>&1 | tee $OUTPUT/patch-${PRGNAM}.log
+if [ "$ARCH" == "x86_64" ]; then
+ patch -p0 < $SRCDIR/${PRGNAM}_lib64.patch \
+ 2>&1 | tee -a $OUTPUT/patch-${PRGNAM}.log
+fi
+chown -R root:root .
+chmod -R u+w,go+r-w,a-s .
+
+echo Building ...
+export LDFLAGS="$SLKLDFLAGS"
+export CXXFLAGS="$SLKCFLAGS"
+export CFLAGS="$SLKCFLAGS"
+# Unfortunately, c-kermit is incompatible with OpenSSL > 0.9.7
+#make linux+openssl+shadow prefix=/usr KFLAGS="-DOPENSSL_097" \
+make linux prefix=/usr \
+ 2>&1 | tee $OUTPUT/make-${PRGNAM}.log
+
+# Install all the needed stuff to the package dir
+mkdir -p $PKG/usr/{bin,man}
+# Use installwatch if available, to produce a logfile of the installation
+# process that is more easily readable:
+if $(which installwatch > /dev/null 2>&1); then
+ installwatch -o $OUTPUT/install-${PRGNAM}.log \
+ make DESTDIR=$PKG prefix=/usr install
+else
+ make DESTDIR=$PKG prefix=/usr install 2>&1 |tee $OUTPUT/install-${PRGNAM}.log
+fi
+
+# Move and fix the ckermit.ini script:
+mkdir -p $PKG/usr/share/kermit
+mv $PKG/usr/bin/ckermit.ini $PKG/usr/share/kermit/
+sed -i -e "s|${PKG}/usr/bin/kermit|/usr/bin/kermit|g" $PKG/usr/share/kermit/ckermit.ini
+
+# Add documentation:
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp -a $DOCS $PKG/usr/doc/$PRGNAM-$VERSION || true
+find $PKG/usr/doc -type f -exec chmod 644 {} \;
+
+# Compress the man page(s):
+if [ -d $PKG/usr/man ]; then
+ find $PKG/usr/man -type f -name "*.?" -exec gzip -9f {} \;
+ for i in $(find $PKG/usr/man -type l -name "*.?") ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
+fi
+
+# Strip binaries:
+cd $PKG
+find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
+find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
+cd -
+
+
+# Add a package description:
+mkdir -p $PKG/install
+cat $SRCDIR/slack-desc > $PKG/install/slack-desc
+if [ -f $SRCDIR/doinst.sh ]; then
+ cat $SRCDIR/doinst.sh >> $PKG/install/doinst.sh
+fi
+
+# Build the package:
+cd $PKG
+makepkg --linkadd y --chown n $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz 2>&1 | tee $OUTPUT/makepkg-${PRGNAM}.log
+cd $OUTPUT
+md5sum ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz > ${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.tgz.md5
+cd -
+cat $PKG/install/slack-desc | grep "^${PRGNAM}" > $OUTPUT/${PRGNAM}-${VERSION}-${ARCH}-${BUILD}.txt
+
+# Clean up the extra stuff:
+if [ "$P1" = "--cleanup" ]; then
+ rm -rf $TMP/tmp-$PRGNAM
+ rm -rf $PKG
+fi
diff --git a/ckermit/build/ckermit_destdir.patch b/ckermit/build/ckermit_destdir.patch
new file mode 100644
index 00000000..4d2afd99
--- /dev/null
+++ b/ckermit/build/ckermit_destdir.patch
@@ -0,0 +1,73 @@
+--- makefile.orig 2008-01-20 02:25:18.000000000 +0100
++++ makefile 2008-01-20 02:30:19.000000000 +0100
+@@ -1018,41 +1018,41 @@
+ echo " to match the 'cu' program. See the ckuins.txt file";\
+ echo " for details.";\
+ echo;\
+- echo MANDIR=$(MANDIR);\
++ echo MANDIR=$(DESTDIR)$(MANDIR);\
+ if test -n "$(MANDIR)"; then\
+- if test -d $(MANDIR); then\
+- echo "$(MANDIR) exists...";\
++ if test -d $(DESTDIR)$(MANDIR); then\
++ echo "$(DESTDIR)$(MANDIR) exists...";\
+ else\
+- echo "Creating $(MANDIR)...";\
+- mkdir $(MANDIR) || exit 1;\
+- chmod 755 $(MANDIR) || exit 1;\
++ echo "Creating $(DESTDIR)$(MANDIR)...";\
++ mkdir $(DESTDIR)$(MANDIR) || exit 1;\
++ chmod 755 $(DESTDIR)$(MANDIR) || exit 1;\
+ fi;\
+ echo "Installing man page...";\
+- rm -f $(MANDIR)/kermit.$(MANEXT);\
+- cp ckuker.nr $(MANDIR)/kermit.$(MANEXT) || exit 1;\
+- chmod 644 $(MANDIR)/kermit.$(MANEXT) || exit 1;\
++ rm -f $(DESTDIR)$(MANDIR)/kermit.$(MANEXT);\
++ cp ckuker.nr $(DESTDIR)$(MANDIR)/kermit.$(MANEXT) || exit 1;\
++ chmod 644 $(DESTDIR)$(MANDIR)/kermit.$(MANEXT) || exit 1;\
+ echo 'set flag=f\nPrC Removing man pages' >&3;\
+- echo "RmF $(MANDIR)/kermit.$(MANEXT)" >&3;\
++ echo "RmF $(DESTDIR)$(MANDIR)/kermit.$(MANEXT)" >&3;\
+ echo 'EfM' >&3;\
+ echo;\
+ else\
+ echo "Not installing man page!\n";\
+ fi;\
+- echo CERTDIR=$(CERTDIR);\
++ echo CERTDIR=$(DESTDIR)$(CERTDIR);\
+ if test -n "$(CERTDIR)"; then\
+ if test -f ca_certs.pem; then\
+- if test -d $(CERTDIR); then\
+- echo "$(CERTDIR) exists...";\
++ if test -d $(DESTDIR)$(CERTDIR); then\
++ echo "$(DESTDIR)$(CERTDIR) exists...";\
+ else\
+- echo "Creating $(CERTDIR)...";\
+- mkdir $(CERTDIR) || exit 1;\
+- chmod 755 $(CERTDIR) || exit 1;\
++ echo "Creating $(DESTDIR)$(CERTDIR)...";\
++ mkdir $(DESTDIR)$(CERTDIR) || exit 1;\
++ chmod 755 $(DESTDIR)$(CERTDIR) || exit 1;\
+ fi;\
+ echo "Installing certificates file...";\
+- cp ca_certs.pem $(CERTDIR) || exit 1;\
++ cp ca_certs.pem $(DESTDIR)$(CERTDIR) || exit 1;\
+ echo 'set flag=f' >&3;\
+ echo 'PrC Removing certificates file' >&3;\
+- echo "RmF $(CERTDIR)/ca_certs.pem" >&3;\
++ echo "RmF $(DESTDIR)$(CERTDIR)/ca_certs.pem" >&3;\
+ echo 'EfM' >&3;\
+ echo;\
+ fi;\
+@@ -1110,8 +1110,8 @@
+ echo "RmD $(DESTDIR)$(BINDIR)" >&3;\
+ echo "RmD $(DESTDIR)$(SRCDIR)" >&3;\
+ echo "RmD $(DESTDIR)$(INFODIR)" >&3;\
+- echo "RmD $(CERTDIR)" >&3;\
+- echo "RmD $(MANDIR)" >&3;\
++ echo "RmD $(DESTDIR)$(CERTDIR)" >&3;\
++ echo "RmD $(DESTDIR)$(MANDIR)" >&3;\
+ echo "RmD $(DESTDIR)" >&3;\
+ echo "EfM" >&3;\
+ echo "PrN C-Kermit version $(CKVER) is uninstalled!" >&3;\
diff --git a/ckermit/build/ckermit_lib64.patch b/ckermit/build/ckermit_lib64.patch
new file mode 100644
index 00000000..23d24a90
--- /dev/null
+++ b/ckermit/build/ckermit_lib64.patch
@@ -0,0 +1,40 @@
+diff -ur ckermit-8.0.211.orig/makefile ckermit-8.0.211/makefile
+--- ckermit-8.0.211.orig/makefile 2004-04-18 03:52:00.000000000 +0900
++++ ckermit-8.0.211/makefile 2005-02-13 16:46:12.000000000 +0900
+@@ -5483,9 +5483,9 @@
+ `if test -f /usr/include/crypt.h; then echo -DHAVE_CRYPT_H; fi` \
+ $(KFLAGS)" \
+ "LIBS=-lncurses \
+- `if test -f /usr/lib/libresolv.a || test -f /usr/lib/libresolv.so; \
++ `if test -f /usr/lib64/libresolv.a || test -f /usr/lib64/libresolv.so; \
+ then echo -lresolv; fi` \
+- `if test -f /usr/lib/libcrypt.a || test -f /usr/lib/libcrypt.so; \
++ `if test -f /usr/lib64/libcrypt.a || test -f /usr/lib64/libcrypt.so; \
+ then echo -lcrypt; fi`" \
+ linuxa
+
+@@ -5509,8 +5509,8 @@
+ `if test -f /usr/lib/libcrypt.a; then echo -DHAVE_CRYPTH; fi` \
+ $(KFLAGS)" \
+ "LIBS=-lcurses \
+- `if test -f /usr/lib/libresolv.a; then echo -lresolv; fi` \
+- `if test -f /usr/lib/libcrypt.a; then echo -lcrypt; fi`" \
++ `if test -f /usr/lib64/libresolv.a; then echo -lresolv; fi` \
++ `if test -f /usr/lib64/libcrypt.a; then echo -lcrypt; fi`" \
+ linuxa
+
+ # As above but with with no curses support, for example because you installed
+@@ -5522,10 +5522,10 @@
+ else HAVE_PTMX=''; fi; fi ; \
+ $(MAKE) KTARGET=$${KTARGET:-$(@)} \
+ "KFLAGS= $$HAVE_PTMX \
+- `if test -f /usr/lib/libcrypt.a; then echo -DHAVE_CRYPTH; fi` \
++ `if test -f /usr/lib64/libcrypt.a; then echo -DHAVE_CRYPTH; fi` \
+ $(KFLAGS)" "LIBS= \
+- `if test -f /usr/lib/libresolv.a; then echo -lresolv; fi` \
+- `if test -f /usr/lib/libcrypt.a; then echo -lcrypt; fi`" \
++ `if test -f /usr/lib64/libresolv.a; then echo -lresolv; fi` \
++ `if test -f /usr/lib64/libcrypt.a; then echo -lcrypt; fi`" \
+ linuxa
+
+ #Sharp Zaurus SL-5500 - Linux based