;;; -*- Mode:Lisp; Readtable:CL; Package:USER; Base:10; Patch-File:T -*- ;;; Patch file for Tape version 22.3 ;;; Reason: ;;; TAPE:SELECT-FORMAT accepts the string name *or* flavor symbol ;;; of a tape format. ;;; Written 28-Apr-88 17:43:12 by keith at site Gigamos Cambridge ;;; while running on Azathoth from band 3 ;;; with Experimental System 123.246, Experimental Local-File 73.4, Experimental FILE-Server 22.2, Experimental Unix-Interface 11.0, Experimental KERMIT 34.3, Experimental ZMail 71.0, Experimental Lambda-Diag 15.0, Experimental Tape 22.2, Experimental Serial-IP 1.0, microcode 1756, SDU Boot Tape 3.14, SDU ROM 8, the old ones. ; From modified file DJ: L.TAPE; USER.LISP#99 at 28-Apr-88 17:43:12 #10R TAPE#: (COMPILER-LET ((*PACKAGE* (PKG-FIND-PACKAGE "TAPE"))) (COMPILER::PATCH-SOURCE-FILE "SYS: TAPE; USER  " (defun select-format (&optional format-spec &rest init-options) "Selects a format to be *selected-format*. FORMAT-SPEC must be a format flavor symbol or NIL in which case a menu of available formats will be popped up. INIT-OPTIONS can be used to setup the initial options of the format." (let ((flavor (or (cdr (ass 'string-equal format-spec *tape-format-alist*)) (cdr (rass 'string-equal format-spec *tape-format-alist*)) (let ((alist (mapcar 'cdr *tape-format-alist*))) (tv:mouse-warp (floor (send tv:default-screen :width) 2) (floor (send tv:default-screen :height) 2)) (tv:menu-choose alist '(:string "Tape Formats Supported" :font fonts:tr12b) '(:mouse) (or (cdr(rass 'string-equal (car *default-format*) *tape-format-alist*)) (car alist))))))) (when flavor (setq *selected-format* (parse-format flavor)) (let((*print-base* 10.) (*read-base* 10.)) (if (null init-options) (send *selected-format* :set-options) (lexpr-send *selected-format* :set-options init-options))) *selected-format*))) ))