#!/bin/bash # Slackware build script for cc65 # Written by B. Watson (urchlay@slackware.uk) # Licensed under the WTFPL. See http://www.wtfpl.net/txt/copying/ for details. # 20220405 bkw: BUILD=2, add .SlackBuild to doc dir. # 20210317 bkw: # - Update for 2.19 release. Script also tested with 2.18 and # 2.17_20180906, in case someone needs one of those versions. # - Use 'make html' to build the docs instead of pregenerating (tested # on -current too). # - Add optional info docs to package. # - Use USER_CFLAGS instead of sed to support SLKCFLAGS. # - TODO: look at making good man pages for at least the executables. # 20180907 bkw: # - Update for 2.17_20180906, git commit b6ccd4d. # - Rename git2targz.sh => git2tarxz.sh. # - Add option to git2tarxz.sh to use a specific tag/commit. # - Add README_SBo.txt documenting the use of git2tarxz.sh. # 20180103 bkw: # - Update for 2.16_20180102, git commit 040134e7. # - "prefix" renamed to "PREFIX" in src/Makefile. For now, set both in # the make command, so this script can still build the previous version # if someone needs it. # 20170703 bkw: # - Update for 2.16_20170630. Upstream still hasn't done a release, but # again there's lots of development. # - My self-hosted source tarball now includes the HTML documentation. This # script used to build it, but -current's linuxdoc-tools chokes on it, # and fixing it would require me a week or two probably. So, for now # anyway, the tarball includes docs that were built on 14.2. # 20170129 bkw: # - Update for v2.15_20170126, aka git 6878ede. Upstream hasn't done # a release since 2013 or so, but there's been lots of development. # Script modified enough that it can no longer build v2.13.3; use # the one from SBo's 14.1 repo if you need the old version for some # reason. Source is created from a git checkout, see git2targz.sh. cd $(dirname $0) ; CWD=$(pwd) PRGNAM=cc65 VERSION=${VERSION:-2.19} BUILD=${BUILD:-2} TAG=${TAG:-_SBo} PKGTYPE=${PKGTYPE:-tgz} if [ -z "$ARCH" ]; then case "$( uname -m )" in i?86) ARCH=i586 ;; arm*) ARCH=arm ;; *) ARCH=$( uname -m ) ;; esac fi if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE" exit 0 fi TMP=${TMP:-/tmp/SBo} PKG=$TMP/package-$PRGNAM OUTPUT=${OUTPUT:-/tmp} if [ "$ARCH" = "i586" ]; then SLKCFLAGS="-O2 -march=i586 -mtune=i686" elif [ "$ARCH" = "i686" ]; then SLKCFLAGS="-O2 -march=i686 -mtune=i686" elif [ "$ARCH" = "x86_64" ]; then SLKCFLAGS="-O2 -fPIC" else SLKCFLAGS="-O2" fi set -e rm -rf $PKG mkdir -p $TMP $PKG $OUTPUT $PKG/usr/doc/$PRGNAM-$VERSION cd $TMP rm -rf $PRGNAM-$VERSION tar xvf $CWD/$PRGNAM-$VERSION.tar.?z cd $PRGNAM-$VERSION chown -R root:root . find . -type f -print0 | xargs -0 chmod 644 find . -type d -print0 | xargs -0 chmod 755 # v2.19 binaries report themselves as v2.18. upstream fixed this in # git commit cffcbce60, I'll just sed it. [ "$VERSION" = "2.19" ] && sed -i '/#define VER_MINOR/s,18U,19U,' src/common/version.c # HTML docs are always created and installed. If the user really # wants to, the same docs can be installed as .info files. They're not # enabled by default because they include .info files with names like # "index", "coding", "using-make" and even "lynx". It's not obvious # they belong to cc65, when they're sitting in the same /usr/info # dir as all the other .info files. Plus, the internal links between # the documents don't work when converted to .info, whereas the HTML # ones do. INFO="${INFO:-no}" PKGDOC=$PKG/usr/doc/$PRGNAM-$VERSION make all PREFIX=/usr prefix=/usr LDFLAGS=-Wl,-s USER_CFLAGS="$SLKCFLAGS" make -C doc html [ "$INFO" = "yes" ] && make -C doc html info make install \ PREFIX=$PKG/usr prefix=$PKG/usr \ infodir=$PKG/usr/info htmldir=$PKGDOC \ samplesdir=$PKGDOC/samples # Binaries already stripped, no man pages, but there might be info # pages that needs to be gzipped. Note that the the info files can be # read with e.g. "info cc65", but won't show up in the info directory: # the generated docs lack sections and descriptions, so using # install-info in doinst.sh doesn't do anything. I also tried using # "linuxdoc -B txt --manpage" on the SGML doc sources, but the results # are ugly and have screwed-up formatting. If I want man pages, I'll # probably have to make them manually (pun intended). [ "$INFO" = "yes" ] && gzip $PKG/usr/info/* mkdir -p $PKGDOC cp -a README* LICENSE $PKGDOC cat $CWD/$PRGNAM.SlackBuild > $PKGDOC/$PRGNAM.SlackBuild mkdir -p $PKG/install cat $CWD/slack-desc > $PKG/install/slack-desc cd $PKG /sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE