X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/4ad9321b5799aae68df21f77e7e788d897c3f015..63621a81d16ab743de6b57d47578a9a2c670ad22:/etc/mhn.defaults.sh diff --git a/etc/mhn.defaults.sh b/etc/mhn.defaults.sh index 0111dbd3..0253f283 100755 --- a/etc/mhn.defaults.sh +++ b/etc/mhn.defaults.sh @@ -1,4 +1,4 @@ -#!/bin/sh +#! /bin/sh # # mhn.defaults.sh -- create extra profile file for MIME handling # @@ -9,7 +9,7 @@ if [ -n "$1" ]; then SEARCHPATH=$1 else - SEARCHPATH="$PATH:/usr/demo/SOUND" + SEARCHPATH="$PATH" fi # If a search program is passed to the script, we @@ -25,187 +25,353 @@ fi TMP=/tmp/nmh_temp.$$ trap "rm -f $TMP" 0 1 2 3 13 15 -echo "mhstore-store-text: %m%P.txt" >> $TMP -echo "mhstore-store-text/richtext: %m%P.rt" >> $TMP -echo "mhstore-store-video/mpeg: %m%P.mpg" >> $TMP -echo "mhstore-store-application/PostScript: %m%P.ps" >> $TMP +if [ ! -z `$SEARCHPROG "$SEARCHPATH" par` ]; then + #### The widths here correspond to those for the text browsers below. + textfmt=' | par 64' + replfmt=" | sed 's/^\(.\)/> \1/; s/^$/>/;' | par 64" +elif [ ! -z `$SEARCHPROG "$SEARCHPATH" fmt` ]; then + textfmt=' | fmt' + replfmt=" | fmt | sed 's/^\(.\)/> \1/; s/^$/>/;'" +else + textfmt= + replfmt= +fi +[ ! -z `$SEARCHPROG "$SEARCHPATH" iconv` ] && + charsetconv=' | iconv -f ${charset:-us-ascii} -t utf-8'"${textfmt}" || + charsetconv= + +cat >>"$TMP" <<'EOF' +mhstore-store-text: %m%P.txt +mhstore-store-text/calendar: %m%P.ics +mhstore-store-text/html: %m%P.html +mhstore-store-text/richtext: %m%P.rt +mhstore-store-video/mpeg: %m%P.mpg +mhstore-store-application/PostScript: %m%P.ps +EOF -PGM="`$SEARCHPROG $SEARCHPATH xwud`" +PGM=`$SEARCHPROG "$SEARCHPATH" xwud` if [ ! -z "$PGM" ]; then XWUD="$PGM" X11DIR="`echo $PGM | awk -F/ '{ for(i=2;i> $TMP -elif [ ! -z $"PBM" -a ! -z "$XWUD" ]; then - echo "mhshow-show-image/gif: %p${PBMDIR}giftoppm | ${PBMDIR}ppmtopgm | ${PBMDIR}pgmtopbm | ${PBMDIR}pbmtoxwd | $XWUD -geometry =-0+0" >> $TMP - echo "mhshow-show-image/x-pbm: %p${PBMDIR}pbmtoxwd | $XWUD -geometry =-0+0" >> $TMP - echo "mhshow-show-image/x-pgm: %p${PBMDIR}pgmtopbm | ${PBMDIR}pbmtoxwd | $XWUD -geometry =-0+0" >> $TMP - echo "mhshow-show-image/x-ppm: %p${PBMDIR}ppmtopgm | ${PBMDIR}pgmtopbm | ${PBMDIR}pbmtoxwd | $XWUD -geometry =-0+0" >> $TMP - echo "mhshow-show-image/x-xwd: %p$XWUD -geometry =-0+0" >> $TMP - - PGM="`$SEARCHPROG $SEARCHPATH djpeg`" + echo "mhshow-show-image: %l$PGM -geometry =-0+0 %f" >> $TMP +elif [ ! -z $"NETPBM" -a ! -z "$XWUD" ]; then + echo "mhshow-show-image/gif: %l${NETPBMDIR}giftopnm | ${NETPBMDIR}ppmtopgm | ${NETPBMDIR}pgmtopbm | ${NETPBMDIR}pnmtoxwd | $XWUD -geometry =-0+0" >> $TMP + echo "mhshow-show-image/x-pnm: %l${NETPBMDIR}pnmtoxwd | $XWUD -geometry =-0+0" >> $TMP + echo "mhshow-show-image/x-pgm: %l${NETPBMDIR}pgmtopbm | ${NETPBMDIR}pnmtoxwd | $XWUD -geometry =-0+0" >> $TMP + echo "mhshow-show-image/x-ppm: %l${NETPBMDIR}ppmtopgm | ${NETPBMDIR}pgmtopbm | ${NETPBMDIR}pnmtoxwd | $XWUD -geometry =-0+0" >> $TMP + echo "mhshow-show-image/x-xwd: %l$XWUD -geometry =-0+0" >> $TMP + + PGM=`$SEARCHPROG "$SEARCHPATH" djpeg` if [ ! -z "$PGM" ]; then - echo "mhshow-show-image/jpeg: %p$PGM -Pg | ${PBMDIR}ppmtopgm | ${PBMDIR}pgmtopbm | ${PBMDIR}pbmtoxwd | $XWUD -geometry =-0+0" >> $TMP + echo "mhshow-show-image/jpeg: %l$PGM -Pg | ${NETPBMDIR}ppmtopgm | ${NETPBMDIR}pgmtopbm | ${NETPBMDIR}pnmtoxwd | $XWUD -geometry =-0+0" >> $TMP fi fi if [ -f "/dev/audioIU" ]; then - PGM="`$SEARCHPROG $SEARCHPATH recorder`" + PGM=`$SEARCHPROG "$SEARCHPATH" recorder` if [ ! -z "$PGM" ]; then echo "mhstore-store-audio/basic: %m%P.au" >> $TMP - echo "mhbuild-compose-audio/basic: ${AUDIODIR}recorder '%f' -au -pause > /dev/tty" >> $TMP - echo "mhshow-show-audio/basic: %p${AUDIODIR}splayer -au" >> $TMP + echo "mhbuild-compose-audio/basic: ${AUDIODIR}recorder %f -au -pause > /dev/tty" >> $TMP + echo "mhshow-show-audio/basic: %l${AUDIODIR}splayer -au" >> $TMP fi elif [ -f "/dev/audio" ]; then - PGM="`$SEARCHPROG $SEARCHPATH raw2audio`" + PGM=`$SEARCHPROG "$SEARCHPATH" raw2audio` if [ ! -z "$PGM" ]; then AUDIODIR="`echo $PGM | awk -F/ '{ for(i=2;i %m%P.au" >> $TMP echo "mhstore-store-audio/x-next: %m%P.au" >> $TMP - AUDIOTOOL="`$SEARCHPROG $SEARCHPATH audiotool`" + AUDIOTOOL=`$SEARCHPROG "$SEARCHPATH" audiotool` if [ ! -z "$AUDIOTOOL" ]; then - echo "mhbuild-compose-audio/basic: $AUDIOTOOL '%f' && ${AUDIODIR}raw2audio -F < '%f'" >> $TMP + echo "mhbuild-compose-audio/basic: $AUDIOTOOL %f && ${AUDIODIR}raw2audio -F < %f" >> $TMP else echo "mhbuild-compose-audio/basic: trap \"exit 0\" 2 && ${AUDIODIR}record | ${AUDIODIR}raw2audio -F" >> $TMP fi - echo "mhshow-show-audio/basic: %p${AUDIODIR}raw2audio 2>/dev/null | ${AUDIODIR}play" >> $TMP + echo "mhshow-show-audio/basic: %l${AUDIODIR}raw2audio 2>/dev/null | ${AUDIODIR}play" >> $TMP - PGM="`$SEARCHPROG $SEARCHPATH adpcm_enc`" + PGM=`$SEARCHPROG "$SEARCHPATH" adpcm_enc` if [ ! -z "$PGM" ]; then DIR="`echo $PGM | awk -F/ '{ for(i=2;i> $TMP + echo "mhbuild-compose-audio/x-next: $AUDIOTOOL %f && ${DIR}adpcm_enc < %f" >> $TMP else echo "mhbuild-compose-audio/x-next: ${AUDIODIR}record | ${DIR}adpcm_enc" >> $TMP fi - echo "mhshow-show-audio/x-next: %p${DIR}adpcm_dec | ${AUDIODIR}play" >> $TMP + echo "mhshow-show-audio/x-next: %l${DIR}adpcm_dec | ${AUDIODIR}play" >> $TMP else if [ ! -z "$AUDIOTOOL" ]; then - echo "mhbuild-compose-audio/x-next: $AUDIOTOOL '%f'" >> $TMP + echo "mhbuild-compose-audio/x-next: $AUDIOTOOL %f" >> $TMP else echo "mhbuild-compose-audio/x-next: ${AUDIODIR}record" >> $TMP fi - echo "mhshow-show-audio/x-next: %p${AUDIODIR}play" >> $TMP + echo "mhshow-show-audio/x-next: %l${AUDIODIR}play" >> $TMP fi else echo "mhbuild-compose-audio/basic: cat < /dev/audio" >> $TMP - echo "mhshow-show-audio/basic: %pcat > /dev/audio" >> $TMP + echo "mhshow-show-audio/basic: %lcat > /dev/audio" >> $TMP fi fi -PGM="`$SEARCHPROG $SEARCHPATH mpeg_play`" +#### +#### mhbuild-disposition-[/] entries are used by the +#### WhatNow attach for deciding whether the Content-Disposition +#### should be 'attachment' or 'inline'. Only those values are +#### supported. mhbuild-convert-text/html is defined below. +#### +cat <>${TMP} +mhbuild-convert-text/calendar: mhical -infile %F -contenttype +mhbuild-convert-text: charset=%{charset}; iconv -f \${charset:-us-ascii} -t utf-8 %F${replfmt} +mhbuild-disposition-text/calendar: inline +mhbuild-disposition-message/rfc822: inline +EOF + +PGM=`$SEARCHPROG "$SEARCHPATH" mpeg_play` if [ ! -z "$PGM" ]; then - echo "mhshow-show-video/mpeg: %p$PGM '%f'" >> $TMP + echo "mhshow-show-video/mpeg: %l$PGM %f" >> $TMP fi -PGM="`$SEARCHPROG $SEARCHPATH lpr`" +PGM=`$SEARCHPROG "$SEARCHPATH" okular` if [ ! -z "$PGM" ]; then - echo "mhshow-show-application/PostScript: %plpr -Pps" >> $TMP + echo "mhshow-show-application/PostScript: %l$PGM %F" >> $TMP else - PGM="`$SEARCHPROG $SEARCHPATH lp`" - if [ ! -z "$PGM" ]; then - echo "mhshow-show-application/PostScript: %plp -dps" >> $TMP + PGM=`$SEARCHPROG "$SEARCHPATH" evince` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/PostScript: %l$PGM %F" >> $TMP + else + PGM=`$SEARCHPROG "$SEARCHPATH" gv` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/PostScript: %l$PGM %F" >> $TMP + fi fi fi -PGM="`$SEARCHPROG $SEARCHPATH ivs_replay`" +PGM=`$SEARCHPROG "$SEARCHPATH" acroread` if [ ! -z "$PGM" ]; then - echo "mhshow-show-application/x-ivs: %p$PGM -o '%F'" >> $TMP + echo "mhshow-show-application/pdf: %l$PGM %F" >> $TMP +else + PGM=`$SEARCHPROG "$SEARCHPATH" okular` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/pdf: %l$PGM %F" >> $TMP + else + PGM=`$SEARCHPROG "$SEARCHPATH" evince` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/pdf: %l$PGM %F" >> $TMP + else + PGM=`$SEARCHPROG "$SEARCHPATH" xpdf` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/pdf: %l$PGM %F" >> $TMP + else + PGM=`$SEARCHPROG "$SEARCHPATH" gv` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/pdf: %l$PGM %F" >> $TMP + fi + fi + fi + fi fi +echo "mhshow-show-text/calendar: mhical -infile %F" >> $TMP +echo "mhshow-show-application/ics: mhical -infile %F" >> $TMP +echo "mhfixmsg-format-text/calendar: mhical -infile %F" >> $TMP +echo "mhfixmsg-format-application/ics: mhical -infile %F" >> $TMP + +PGM=`$SEARCHPROG "$SEARCHPATH" ivs_replay` +if [ ! -z "$PGM" ]; then + echo "mhshow-show-application/x-ivs: %l$PGM -o %F" >> $TMP +fi + +# The application/vnd.openxmlformats-officedocument.wordprocessingml.document +# through application/onenote associations are from +# http://technet.microsoft.com/en-us/library/cc179224.aspx + cat <> ${TMP} -mhshow-suffix-text/html: .html -mhshow-suffix-text/xml: .xml +mhshow-suffix-application/msword: .doc +mhshow-suffix-application/ogg: .ogg mhshow-suffix-application/pdf: .pdf mhshow-suffix-application/postscript: .ps -mhshow-suffix-application/msword: .doc -mhshow-suffix-application/msword: .docx -mhshow-suffix-application/vnd.ms-excel: xls -mhshow-suffix-application/vnd.ms-excel: xlc -mhshow-suffix-application/vnd.ms-excel: xll -mhshow-suffix-application/vnd.ms-excel: xlm -mhshow-suffix-application/vnd.ms-excel: xlw -mhshow-suffix-application/vnd.ms-excel: xla -mhshow-suffix-application/vnd.ms-excel: xlt -mhshow-suffix-application/vnd.ms-excel: xld -mhshow-suffix-application/vnd.ms-powerpoint: ppz -mhshow-suffix-application/vnd.ms-powerpoint: ppt -mhshow-suffix-application/vnd.ms-powerpoint: pps -mhshow-suffix-application/vnd.ms-powerpoint: pot +mhshow-suffix-application/rtf: .rtf +mhshow-suffix-application/vnd.ms-excel: .xla +mhshow-suffix-application/vnd.ms-excel: .xlc +mhshow-suffix-application/vnd.ms-excel: .xld +mhshow-suffix-application/vnd.ms-excel: .xll +mhshow-suffix-application/vnd.ms-excel: .xlm +mhshow-suffix-application/vnd.ms-excel: .xls +mhshow-suffix-application/vnd.ms-excel: .xlt +mhshow-suffix-application/vnd.ms-excel: .xlw +mhshow-suffix-application/vnd.ms-powerpoint: .pot +mhshow-suffix-application/vnd.ms-powerpoint: .pps +mhshow-suffix-application/vnd.ms-powerpoint: .ppt +mhshow-suffix-application/vnd.ms-powerpoint: .ppz +mhshow-suffix-application/vnd.openxmlformats-officedocument.wordprocessingml.document: .docx +mhshow-suffix-application/vnd.ms-word.document.macroEnabled.12: .docm +mhshow-suffix-application/vnd.openxmlformats-officedocument.wordprocessingml.template: .dotx +mhshow-suffix-application/vnd.ms-word.template.macroEnabled.12: .dotm +mhshow-suffix-application/vnd.openxmlformats-officedocument.spreadsheetml.sheet: .xlsx +mhshow-suffix-application/vnd.ms-excel.sheet.macroEnabled.12: .xlsm +mhshow-suffix-application/vnd.openxmlformats-officedocument.spreadsheetml.template: .xltx +mhshow-suffix-application/vnd.ms-excel.template.macroEnabled.12: .xltm +mhshow-suffix-application/vnd.ms-excel.sheet.binary.macroEnabled.12: .xlsb +mhshow-suffix-application/vnd.ms-excel.addin.macroEnabled.12: .xlam +mhshow-suffix-application/vnd.openxmlformats-officedocument.presentationml.presentation: .pptx +mhshow-suffix-application/vnd.ms-powerpoint.presentation.macroEnabled.12: .pptm +mhshow-suffix-application/vnd.openxmlformats-officedocument.presentationml.slideshow: .ppsx +mhshow-suffix-application/vnd.ms-powerpoint.slideshow.macroEnabled.12: .ppsm +mhshow-suffix-application/vnd.openxmlformats-officedocument.presentationml.template: .potx +mhshow-suffix-application/vnd.ms-powerpoint.template.macroEnabled.12: .potm +mhshow-suffix-application/vnd.ms-powerpoint.addin.macroEnabled.12: .ppam +mhshow-suffix-application/vnd.openxmlformats-officedocument.presentationml.slide: .sldx +mhshow-suffix-application/vnd.ms-powerpoint.slide.macroEnabled.12: .sldm +mhshow-suffix-application/onenote: .onetoc +mhshow-suffix-application/onenote: .onetoc2 +mhshow-suffix-application/onenote: .onetmp +mhshow-suffix-application/onenote: .onepkg +mhshow-suffix-application/x-bzip2: .bz2 +mhshow-suffix-application/x-cpio: .cpio +mhshow-suffix-application/x-dvi: .dvi +mhshow-suffix-application/x-gzip: .gz +mhshow-suffix-application/x-java-archive: .jar +mhshow-suffix-application/x-javascript: .js +mhshow-suffix-application/x-latex: .latex +mhshow-suffix-application/x-sh: .sh +mhshow-suffix-application/x-tar: .tar +mhshow-suffix-application/x-texinfo: .texinfo +mhshow-suffix-application/x-tex: .tex +mhshow-suffix-application/x-troff-man: .man +mhshow-suffix-application/x-troff-me: .me +mhshow-suffix-application/x-troff-ms: .ms +mhshow-suffix-application/x-troff: .t +mhshow-suffix-application/zip: .zip +mhshow-suffix-audio/basic: .au +mhshow-suffix-audio/midi: .midi mhshow-suffix-audio/mpeg: .mp3 +mhshow-suffix-audio/mpeg: .mpg +mhshow-suffix-audio/x-ms-wma: .wma +mhshow-suffix-audio/x-wav: .wav mhshow-suffix-image/gif: .gif mhshow-suffix-image/jpeg: .jpeg mhshow-suffix-image/jpeg: .jpg mhshow-suffix-image/png: .png mhshow-suffix-image/tiff: .tif mhshow-suffix-image/tiff: .tiff +mhshow-suffix-text: .txt +mhshow-suffix-text/calendar: .ics +mhshow-suffix-text/css: .css +mhshow-suffix-text/html: .html +mhshow-suffix-text/rtf: .rtf +mhshow-suffix-text/sgml: .sgml +mhshow-suffix-text/xml: .xml mhshow-suffix-video/mpeg: .mpeg mhshow-suffix-video/mpeg: .mpg -mhshow-suffix-video/mpeg: .mpg -mhshow-suffix-video/quicktime: .qt -mhshow-suffix-video/quicktime: .mov mhshow-suffix-video/quicktime: .moov +mhshow-suffix-video/quicktime: .mov +mhshow-suffix-video/quicktime: .qt mhshow-suffix-video/quicktime: .qtvr +mhshow-suffix-video/x-msvideo: .avi +mhshow-suffix-video/x-ms-wmv: .wmv EOF # I'd like to check if netscape is available and use it preferentially to lynx, # but only once I've added a new %-escape that makes more permanent temp files, # so netscape -remote can be used (without -remote you get a complaint dialog # that another netscape is already running and certain things can't be done). -PGM="`$SEARCHPROG $SEARCHPATH lynx`" +PGM=`$SEARCHPROG "$SEARCHPATH" w3m` if [ ! -z "$PGM" ]; then - echo "mhshow-show-text/html: %p$PGM '%F'" >> $TMP + echo 'mhshow-show-text/html: charset=%{charset}; '"\ +%l$PGM"' -dump ${charset:+-I} ${charset:+"$charset"} -T text/html %F' >> $TMP + echo 'mhfixmsg-format-text/html: charset=%{charset}; '"\ +$PGM "'-dump ${charset:+-I} ${charset:+"$charset"} -O utf-8 -T text/html %F' \ + >> $TMP + echo 'mhbuild-convert-text/html: charset=%{charset}; '"\ +$PGM "'-dump ${charset:+-I} ${charset:+"$charset"} -O utf-8 -T text/html %F '"\ +${replfmt}" >> $TMP +else + PGM=`$SEARCHPROG "$SEARCHPATH" lynx` + if [ ! -z "$PGM" ]; then + echo 'mhshow-show-text/html: charset=%{charset}; '"\ +%l$PGM"' -child -dump -force-html ${charset:+--assume_charset} ${charset:+"$charset"} %F' >> $TMP + #### lynx indents with 3 spaces, remove them and any trailing spaces. + echo 'mhfixmsg-format-text/html: charset=%{charset}; '"\ +$PGM "'-child -dump -force_html ${charset:+--assume_charset} ${charset:+"$charset"} %F | '"\ +expand | sed -e 's/^ //' -e 's/ *$//'" >> $TMP + echo 'mhbuild-convert-text/html: charset=%{charset}; '"\ +$PGM "'-child -dump -force_html ${charset:+--assume_charset} ${charset:+"$charset"} '"\ +%F${replfmt}" >> $TMP + else + PGM=`$SEARCHPROG "$SEARCHPATH" elinks` + if [ ! -z "$PGM" ]; then + echo "mhshow-show-text/html: %l$PGM -dump -force-html \ +-eval 'set document.browse.margin_width = 0' %F" >> $TMP + echo "mhfixmsg-format-text/html: $PGM -dump -force-html \ +-no-numbering -eval 'set document.browse.margin_width = 0' %F" >> $TMP + echo "mhbuild-convert-text/html: $PGM -dump -force-html \ +-no-numbering -eval 'set document.browse.margin_width = 0' %F${replfmt}" >> $TMP + else + echo 'mhbuild-convert-text/html: cat %F' >> $TMP + fi + fi fi -PGM="`$SEARCHPROG $SEARCHPATH richtext`" +PGM=`$SEARCHPROG "$SEARCHPATH" richtext` if [ ! -z "$PGM" ]; then - echo "mhshow-show-text/richtext: %p$PGM -p '%F'" >> $TMP + echo "mhshow-show-text/richtext: %l$PGM -p %F" >> $TMP else - PGM="`$SEARCHPROG $SEARCHPATH rt2raw`" + PGM=`$SEARCHPROG "$SEARCHPATH" rt2raw` if [ ! -z "$PGM" ]; then - echo "mhshow-show-text/richtext: %p$PGM < '%f' | fmt -78 | more" >> $TMP + echo "mhshow-show-text/richtext: %l$PGM < %f | fmt -78 | more" >> $TMP fi fi # staroffice to read .doc files -PGM="`$SEARCHPROG $SEARCHPATH soffice`" +PGM=`$SEARCHPROG "$SEARCHPATH" soffice` if [ ! -z "$PGM" ]; then - echo "mhshow-show-application/msword: %psoffice '%F'" >> $TMP - echo "mhshow-suffix-application/msword: .doc" >> $TMP + echo "mhshow-show-application/msword: %l$PGM %F" >> $TMP fi -# output a sorted version of the file -sort < $TMP +# This entry is used to retrieve external-body types that use a "url" +# access-type. +case "`uname`" in + FreeBSD) + echo "nmh-access-url: fetch -o -" >> $TMP + ;; + *) + PGM=`$SEARCHPROG "$SEARCHPATH" curl` + if [ ! -z "$PGM" ]; then + echo "nmh-access-url: $PGM -L" >> $TMP + fi + ;; +esac + +# Output a sorted version of the file, along with some comments in +# appropriate places. +echo '#: This file was generated by mhn.defaults.sh.' +sort < $TMP | \ + sed -e 's|^\(mhshow-show-application/ics:.*\)|#: might need -notextonly -noinlineonly or -part/-type to show application/ics parts\n\1|' exit 0 -: not until we get a "safe" postscript environment... -PGM="`$SEARCHPROG $SEARCHPATH pageview`" -if [ "$DISPLAY" = "unix:0.0" -a ! -z "$PGM" ]; then - echo "mhshow-show-application/PostScript: %p$PGM -" >> $TMP -else - PGM="`$SEARCHPROG $SEARCHPATH gs`" - if [ ! -z "$PGM" ]; then - echo "mhshow-show-application/PostScript: %p$PGM -- '%F'" >> $TMP - echo "mhshow-suffix-application/PostScript: .ps" >> $TMP - fi -fi +############################################################################### +############################################################################### +#### +#### Note the exit 0 above; everything below is unused. +#### +############################################################################### +############################################################################### : have to experiment more with this -PGM="`$SEARCHPROG $SEARCHPATH ivs_record`" +PGM=`$SEARCHPROG "$SEARCHPATH" ivs_record` if [ ! -z "$PGM" ]; then - echo "mhbuild-compose-application/x-ivs: $PGM -u localhost '%F'" >> $TMP + echo "mhbuild-compose-application/x-ivs: $PGM -u localhost %F" >> $TMP fi