#!/bin/sh # bz64wrap - the sending side of a bzip2 | base64 stream # Andreas Dilger <adilger@clusterfs.com> Jan 2002 PATH=$PATH:/usr/bin:/usr/local/bin:/usr/freeware/bin # A program to generate base64 encoding on stdout BASE64_ENCODE="uuencode -m /dev/stdout" BASE64_BEGIN= BASE64_END= BZIP=NO BASE64=NO # Test if we have the bzip program installed bzip2 -c /dev/null > /dev/null 2>&1 && BZIP=YES # Test if uuencode can handle the -m (MIME) encoding option $BASE64_ENCODE < /dev/null > /dev/null 2>&1 && BASE64=YES if [ $BASE64 = NO ]; then BASE64_ENCODE=mimencode BASE64_BEGIN="begin-base64 644 -" BASE64_END="====" $BASE64_ENCODE < /dev/null > /dev/null 2>&1 && BASE64=YES fi if [ $BZIP = NO -o $BASE64 = NO ]; then echo "$0: can't use bz64 encoding: bzip2=$BZIP, $BASE64_ENCODE=$BASE64" exit 1 fi # Sadly, mimencode does not appear to have good "begin" and "end" markers # like uuencode does, and it is picky about getting the right start/end of # the base64 stream, so we handle this internally. echo "$BASE64_BEGIN" bzip2 -9 | $BASE64_ENCODE echo "$BASE64_END"