From fde929a6d3bc5935b8233d2b99b86ef0faad78b0 Mon Sep 17 00:00:00 2001 From: Arun Welch Date: Sun, 13 Dec 2020 17:11:43 -0700 Subject: [PATCH] Tools to build the indexes --- docs/Documentation Tools/IMINDEX | 658 +++++ docs/Documentation Tools/IMINDEX.LCOM | Bin 0 -> 17113 bytes docs/Documentation Tools/IMINDEX.TEDIT | Bin 0 -> 26869 bytes docs/Documentation Tools/IMNAME | 754 ++++++ docs/Documentation Tools/IMNAME.LCOM | Bin 0 -> 18557 bytes docs/Documentation Tools/IMNAME.TEDIT | 1 + docs/Documentation Tools/IMTEDIT | 2434 +++++++++++++++++++ docs/Documentation Tools/IMTEDIT.LCOM | Bin 0 -> 63640 bytes docs/Documentation Tools/IMTEDIT.TEDIT | Bin 0 -> 34684 bytes docs/Documentation Tools/IMTOOLS | 1041 ++++++++ docs/Documentation Tools/IMTOOLS.LCOM | Bin 0 -> 26866 bytes docs/Documentation Tools/IMTRAN | 1270 ++++++++++ docs/Documentation Tools/IMTRAN.LCOM | Bin 0 -> 24271 bytes docs/Documentation Tools/INDEX-FORMAT.TEDIT | Bin 0 -> 1740 bytes docs/Documentation Tools/NONAME.IMPTR | 2 + 15 files changed, 6160 insertions(+) create mode 100644 docs/Documentation Tools/IMINDEX create mode 100644 docs/Documentation Tools/IMINDEX.LCOM create mode 100644 docs/Documentation Tools/IMINDEX.TEDIT create mode 100644 docs/Documentation Tools/IMNAME create mode 100644 docs/Documentation Tools/IMNAME.LCOM create mode 100644 docs/Documentation Tools/IMNAME.TEDIT create mode 100644 docs/Documentation Tools/IMTEDIT create mode 100644 docs/Documentation Tools/IMTEDIT.LCOM create mode 100644 docs/Documentation Tools/IMTEDIT.TEDIT create mode 100644 docs/Documentation Tools/IMTOOLS create mode 100644 docs/Documentation Tools/IMTOOLS.LCOM create mode 100644 docs/Documentation Tools/IMTRAN create mode 100644 docs/Documentation Tools/IMTRAN.LCOM create mode 100644 docs/Documentation Tools/INDEX-FORMAT.TEDIT create mode 100644 docs/Documentation Tools/NONAME.IMPTR diff --git a/docs/Documentation Tools/IMINDEX b/docs/Documentation Tools/IMINDEX new file mode 100644 index 00000000..1e96d387 --- /dev/null +++ b/docs/Documentation Tools/IMINDEX @@ -0,0 +1,658 @@ +(DEFINE-FILE-INFO PACKAGE "INTERLISP" READTABLE "INTERLISP" BASE 10) +(FILECREATED "12-Feb-92 12:28:48" {DSK}sybalsky>PUBS>IMINDEX.;2 37264 + + changes to%: (FNS IM.CHAP.DISPLAYFN) + + previous date%: " 8-Dec-91 15:46:22" {DSK}sybalsky>PUBS>IMINDEX.;1) + + +(* ; " +Copyright (c) 1986, 1987, 1988, 1991, 1992 by Xerox Corporation. All rights reserved. +") + +(PRETTYCOMPRINT IMINDEXCOMS) + +(RPAQQ IMINDEXCOMS + ( + (* ;; + "this file contains the functions used for creating and manipulating index image objects") + + (FNS IM.INDEX.CLOSEF IM.INDEX.COPYFN IM.INDEX.CREATEOBJ IM.INDEX.DISPLAY.STRING + IM.INDEX.DISPLAYFN IM.INDEX.EDIT IM.INDEX.LIST.FROM.STRING IM.INDEX.SIZEFN + IM.INDEX.STRING.FROM.LIST IM.INDEX.PUTFN IM.INDEX.GETFN IM.INDEX.BUTTONEVENTFN) + (FNS IM.INDEX.INIT) + (FNS IM.INDEX.MENU IM.INDEX.MENU.WHENSELECTEDFN IM.INDEX.OBJ.FREEMENU.SELECTEDFN) + (INITVARS (IM.INDEX.OBJECT.IMAGEFNS NIL) + (IM.CHAP.OBJECT.IMAGEFNS NIL) + (IM.INDEX.BUTTONEVENTFN.MENU NIL) + [IM.INDEX.OBJECT.DISPLAY.FONT (FONTCREATE '(MODERN 8 MRR 0 DISPLAY] + (IM.INDEX.DEFAULT.SUBSEC)) + (RECORDS IM.INDEX.DATA) + (VARS IM.INDEX.OBJ.FREEMENU.SPECS) + (COMS (* ; "An image object to set the chapter number, on the TEXTOBJ's proplist, on the INDEXING-CHAPTER property.") + (FNS IM.CHAP.COPYFN IM.CHAP.CREATEOBJ IM.CHAP.DISPLAYFN IM.CHAP.SIZEFN IM.CHAP.PUTFN + IM.CHAP.GETFN IM.CHAP.BUTTONEVENTFN)) + (P (ADVISE 'TEDIT.FORMAT.HARDCOPY 'AROUND '(RESETLST + (RESETSAVE NIL (LIST (FUNCTION IM.INDEX.CLOSEF + ) + STREAM)) + *)) + (IM.INDEX.INIT)))) + + + +(* ;; "this file contains the functions used for creating and manipulating index image objects") + +(DEFINEQ + +(IM.INDEX.CLOSEF + [LAMBDA (TEXTSTREAM) (* mjs " 4-Aug-86 17:02") + + (* * Closes the IMINDEX pointer file associated with the textstream TEXTSTREAM. + This is called by means of advice to TEDIT.HARDCOPY.) + + (PROG [(PTRFILE (TEXTPROP TEXTSTREAM 'IM.INDEX.PTRFILE] + (if (AND PTRFILE (OPENP PTRFILE)) + then (printout PROMPTWINDOW "Closing index pointer file: " (FULLNAME PTRFILE) + "...") + (CLOSEF PTRFILE) + (printout PROMPTWINDOW "done" T]) + +(IM.INDEX.COPYFN + [LAMBDA (OBJ SOURCE TARGET) (* mjs " 4-Aug-86 16:29") + (IM.INDEX.CREATEOBJ (COPYALL (IMAGEOBJPROP OBJ 'OBJECTDATUM]) + +(IM.INDEX.CREATEOBJ + [LAMBDA (DATA) (* mjs " 8-Aug-86 14:46") + (IMAGEOBJCREATE (if (type? IM.INDEX.DATA DATA) + then DATA + else (create IM.INDEX.DATA)) + (if IM.INDEX.OBJECT.IMAGEFNS + else (SETQ IM.INDEX.OBJECT.IMAGEFNS (IMAGEFNSCREATE (FUNCTION IM.INDEX.DISPLAYFN) + (FUNCTION IM.INDEX.SIZEFN) + (FUNCTION IM.INDEX.PUTFN) + (FUNCTION IM.INDEX.GETFN) + (FUNCTION IM.INDEX.COPYFN) + (FUNCTION IM.INDEX.BUTTONEVENTFN) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.INDEX.OBJECT]) + +(IM.INDEX.DISPLAY.STRING + [LAMBDA (OBJ) (* mjs " 5-Aug-86 12:29") + (PROG [(NAM (fetch (IM.INDEX.DATA NAME) of (IMAGEOBJPROP OBJ 'OBJECTDATUM] + (RETURN (if (ILESSP (NCHARS NAM) + 10) + then NAM + else (CONCAT (SUBATOM NAM 1 7) + '|...|]) + +(IM.INDEX.DISPLAYFN + [LAMBDA (OBJ STREAM STREAMTYPE HOSTSTREAM) (* ; "Edited 8-Dec-91 15:12 by jds") + + (* ;; "only print index if you are going to display") + + (COND + ((DISPLAYSTREAMP STREAM) + + (* ;; "display index by printing name with box around it ") + + (DSPFONT IM.INDEX.OBJECT.DISPLAY.FONT STREAM) + (LET* ((STRING (IM.INDEX.DISPLAY.STRING OBJ)) + (STRING.REGION (STRINGREGION STRING STREAM)) + (LEFT (ADD1 (fetch (REGION LEFT) of STRING.REGION))) + (BOTTOM (ADD1 (fetch (REGION BOTTOM) of STRING.REGION))) + (REGION (create REGION + LEFT _ LEFT + BOTTOM _ BOTTOM + HEIGHT _ (IPLUS (fetch (REGION HEIGHT) of STRING.REGION) + 2) + WIDTH _ (IPLUS (fetch (REGION WIDTH) of STRING.REGION) + 4))) + (TOP (fetch (REGION TOP) of REGION)) + (RIGHT (fetch (REGION RIGHT) of REGION))) + (CENTERPRINTINREGION STRING REGION STREAM) + (DRAWLINE LEFT BOTTOM LEFT (SUB1 TOP) + 1 + 'INVERT STREAM) + (DRAWLINE LEFT TOP (SUB1 RIGHT) + TOP 1 'INVERT STREAM) + (DRAWLINE RIGHT TOP RIGHT (ADD1 BOTTOM) + 1 + 'INVERT STREAM) + (DRAWLINE RIGHT BOTTOM (ADD1 LEFT) + BOTTOM 1 'INVERT STREAM) + (IMAGEOBJPROP OBJ 'REGION REGION))) + ((AND (BOUNDP 'TEXTOBJ) + (TYPENAMEP (SETQ HOSTSTREAM TEXTOBJ) + 'TEXTOBJ)) + +(* ;;; "note: have to reset HOSTSTREAM above because Koto Tedit doesn't pass HOSTSTREAM to imageobj displayfn.") + + (PROG ((*READTABLE* *TEDIT-FILE-READTABLE*) + PTRFILE PTRFILENAME TXTFILE) + (SETQ PTRFILE (TEXTPROP HOSTSTREAM 'IM.INDEX.PTRFILE)) + (COND + ((NOT (AND PTRFILE (OPENP PTRFILE))) + (SETQ PTRFILENAME (TEXTPROP HOSTSTREAM 'IM.INDEX.PTRFILENAME)) + [COND + ((NULL PTRFILENAME) + (SETQ TXTFILE (fetch (TEXTOBJ TXTFILE) of (TEXTOBJ HOSTSTREAM))) + (SETQ PTRFILENAME (PACKFILENAME 'EXTENSION 'IMPTR 'VERSION NIL 'BODY + (COND + (TXTFILE (FULLNAME TXTFILE)) + (T 'NONAME] + (SETQ PTRFILENAME (PACKFILENAME 'BODY PTRFILENAME 'BODY (DIRECTORYNAME T))) + (printout PROMPTWINDOW "Opening index pointer file: " PTRFILENAME "...") + (SETQ PTRFILE (OPENSTREAM PTRFILENAME 'OUTPUT 'NEW)) + (printout PROMPTWINDOW "done" T) + (TEXTPROP HOSTSTREAM 'IM.INDEX.PTRFILE PTRFILE))) + (replace (IM.INDEX.DATA PAGE#) of (IMAGEOBJPROP OBJ 'OBJECTDATUM) + with (fetch (PAGEFORMATTINGSTATE PAGE#) of FORMATTINGSTATE)) + + (* ;; "(OR (FETCH (IM.INDEX.DATA SUBSEC) OF (IMAGEOBJPROP OBJ 'OBJECTDATUM)) (REPLACE (IM.INDEX.DATA SUBSEC) OF (IMAGEOBJPROP OBJ 'OBJECTDATUM) WITH (LIST (TEXTPROP HOSTSTREAM 'INDEXING-CHAPTER)))") + + (* ;; "for now, always set the chapter/subsection from the document:") + + [REPLACE (IM.INDEX.DATA SUBSEC) OF (IMAGEOBJPROP OBJ 'OBJECTDATUM) + WITH (LIST (TEXTPROP HOSTSTREAM 'INDEXING-CHAPTER] + (PRIN4 (IMAGEOBJPROP OBJ 'OBJECTDATUM) + PTRFILE) + (TERPRI PTRFILE]) + +(IM.INDEX.EDIT + [LAMBDA (OBJ TEXTSTREAM) (* ; "Edited 18-Jul-88 14:10 by burns") + + (PROG* ((W (FREEMENU IM.INDEX.OBJ.FREEMENU.SPECS)) + (REGION (WINDOWREGION W)) + [TEDIT.WINDOW (CAR (fetch \WINDOW of (TEXTOBJ TEXTSTREAM] + (TEDIT.REGION (AND TEDIT.WINDOW (WINDOWREGION TEDIT.WINDOW))) + OBJ.DATA OBJ.DATA.PROPLIST) + (WINDOWPROP W 'IM.INDEX.OBJ OBJ) + (WINDOWPROP W 'IM.INDEX.TEXTSTREAM TEXTSTREAM) + (SETQ OBJ.DATA (IMAGEOBJPROP OBJ 'OBJECTDATUM)) + (SETQ OBJ.DATA.PROPLIST (fetch (IM.INDEX.DATA PROPLIST) of OBJ.DATA)) + (for ITEM in (WINDOWPROP W 'FM.ITEMS) when (EQ (FM.ITEMPROP ITEM 'TYPE) + 'EDIT) + do (FM.CHANGESTATE ITEM (with IM.INDEX.DATA OBJ.DATA + (SELECTQ (FM.ITEMPROP ITEM 'ID) + (IM.INDEX.NAME NAME) + (IM.INDEX.TYPE (IM.INDEX.STRING.FROM.LIST TYPE)) + (IM.INDEX.TEXT SAV) + (IM.INDEX.INFO (IM.INDEX.STRING.FROM.LIST INFO)) + (IM.INDEX.SUBSEC + (IM.INDEX.STRING.FROM.LIST SUBSEC)) + (IM.INDEX.PAGE PAGE#) + (IM.INDEX.SUBNAME + (LISTGET OBJ.DATA.PROPLIST 'SUBNAME)) + (IM.INDEX.SUBTYPE + (IM.INDEX.STRING.FROM.LIST (LISTGET + OBJ.DATA.PROPLIST + 'SUBTYPE))) + (IM.INDEX.SUBTEXT + (LISTGET OBJ.DATA.PROPLIST 'SUBTEXT)) + (IM.INDEX.SUBSUBNAME + (LISTGET OBJ.DATA.PROPLIST 'SUBSUBNAME)) + (IM.INDEX.SUBSUBTYPE + (IM.INDEX.STRING.FROM.LIST (LISTGET + OBJ.DATA.PROPLIST + 'SUBSUBTYPE))) + (IM.INDEX.SUBSUBTEXT + (LISTGET OBJ.DATA.PROPLIST 'SUBSUBTEXT)) + NIL)) + W)) + (AND TEDIT.WINDOW (MOVEW W (MAX (- (fetch (REGION LEFT) of TEDIT.REGION) + (fetch (REGION WIDTH) of REGION)) + 0) + (MAX (- (fetch (REGION TOP) of TEDIT.REGION) + (fetch (REGION HEIGHT) of REGION)) + 0))) + (OPENW W]) + +(IM.INDEX.LIST.FROM.STRING + [LAMBDA (STR) (* mjs " 6-Aug-86 08:21") + (if (OR (EQUAL STR "") + (EQUAL STR NIL)) + then NIL + else (PROG ((ELIST NIL) + (CLIST NIL) + C) + [for N from 1 to (NCHARS STR) + do (SETQ C (NTHCHARCODE STR N)) + (if (FMEMB C (CHARCODE (SP TAB CR))) + then (if CLIST + then (SETQ ELIST (CONS (PACKC (DREVERSE CLIST)) + ELIST)) + (SETQ CLIST NIL)) + else (SETQ CLIST (CONS C CLIST] + (RETURN (DREVERSE (if CLIST + then (CONS (PACKC (DREVERSE CLIST)) + ELIST) + else ELIST]) + +(IM.INDEX.SIZEFN + [LAMBDA (OBJ STREAM CURX RIGHTMARGIN) (* mjs " 5-Aug-86 14:49") + (if (DISPLAYSTREAMP STREAM) + then (create IMAGEBOX + XSIZE _ (IPLUS (STRINGWIDTH (IM.INDEX.DISPLAY.STRING OBJ) + IM.INDEX.OBJECT.DISPLAY.FONT) + 6) + YSIZE _ (IPLUS (FONTPROP IM.INDEX.OBJECT.DISPLAY.FONT 'HEIGHT) + 4) + YDESC _ (FONTPROP IM.INDEX.OBJECT.DISPLAY.FONT 'DESCENT) + XKERN _ 0) + else (create IMAGEBOX + XSIZE _ 0 + YSIZE _ 0 + YDESC _ 0 + XKERN _ 0]) + +(IM.INDEX.STRING.FROM.LIST + [LAMBDA (LST) (* mjs " 5-Aug-86 16:50") + (if (NULL LST) + then "" + else (CONCATLIST (CDR (for X in LST join (LIST " " X]) + +(IM.INDEX.PUTFN + [LAMBDA (OBJ STREAM) (* ; "Edited 7-Apr-87 18:44 by jds") + (PRIN4 (IMAGEOBJPROP OBJ 'OBJECTDATUM) + STREAM]) + +(IM.INDEX.GETFN + [LAMBDA (FILE TEXTSTREAM) (* mjs " 4-Aug-86 16:26") + (IM.INDEX.CREATEOBJ (READ FILE]) + +(IM.INDEX.BUTTONEVENTFN + [LAMBDA (OBJ WINDOWSTREAM SEL RELX RELY WIN HOSTSTREAM BUTTON) + (* mjs " 8-Aug-86 15:23") + (COND + ([MENU (COND + (IM.INDEX.BUTTONEVENTFN.MENU) + (T (SETQ IM.INDEX.BUTTONEVENTFN.MENU (create MENU + ITEMS _ '((Edit% Index 'Edit% Index + "Selecting this item will create a window editing the contents of this index image object." + )) + MENUOFFSET _ (CREATEPOSITION -5 -5] + (IM.INDEX.EDIT OBJ HOSTSTREAM]) +) +(DEFINEQ + +(IM.INDEX.INIT + [LAMBDA NIL (* ; "Edited 8-Dec-91 14:40 by jds") + + (* ;; "Set up the IMAGEFNS for index objects, so that TEdit will know about them.") + + [COND + ((NOT IM.INDEX.OBJECT.IMAGEFNS) + (SETQ IM.INDEX.OBJECT.IMAGEFNS (IMAGEFNSCREATE (FUNCTION IM.INDEX.DISPLAYFN) + (FUNCTION IM.INDEX.SIZEFN) + (FUNCTION IM.INDEX.PUTFN) + (FUNCTION IM.INDEX.GETFN) + (FUNCTION IM.INDEX.COPYFN) + (FUNCTION IM.INDEX.BUTTONEVENTFN) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.INDEX.OBJECT] + (COND + ((NOT IM.CHAP.OBJECT.IMAGEFNS) + (SETQ IM.CHAP.OBJECT.IMAGEFNS (IMAGEFNSCREATE (FUNCTION IM.CHAP.DISPLAYFN) + (FUNCTION IM.CHAP.SIZEFN) + (FUNCTION IM.CHAP.PUTFN) + (FUNCTION IM.CHAP.GETFN) + (FUNCTION IM.CHAP.COPYFN) + (FUNCTION IM.CHAP.BUTTONEVENTFN) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.CHAP.OBJECT]) +) +(DEFINEQ + +(IM.INDEX.MENU + [LAMBDA (WINDOW.OR.REGION) (* ; "Edited 8-Dec-91 15:22 by jds") + (PROG (MENU MENUW) + (SETQ MENU (create MENU + ITEMS _ '(("Index Selection as Term" NIL + "Add an index object indexing the current selection as a term." + ) + (>>Add% Type<< NIL + "Prompts the user to specify an IM Index type, and adds it to the menu" + ) + (|Set Chapter Number| NIL "Prompts you for the name or number of this chapter, then inserts an object to set the chapter number at hardcopy time." + ) + (>>Close% Menu<< NIL "Closes this menu.")) + WHENSELECTEDFN _ (FUNCTION IM.INDEX.MENU.WHENSELECTEDFN) + TITLE _ "IM Index menu")) + (ADDMENU MENU NIL (COND + ((REGIONP WINDOW.OR.REGION) + (CREATEPOSITION (fetch (REGION LEFT) of WINDOW.OR.REGION) + (fetch (REGION BOTTOM) of WINDOW.OR.REGION))) + (T (GETBOXPOSITION (fetch (REGION WIDTH) of (MENUREGION MENU)) + (fetch (REGION HEIGHT) of (MENUREGION MENU)) + NIL NIL NIL + "Please specify the position of the IM Index menu"]) + +(IM.INDEX.MENU.WHENSELECTEDFN + [LAMBDA (ITEM MENU MOUSEKEY) (* ; "Edited 8-Dec-91 14:56 by jds") + + (* ;; "Handle requests from the INDEX MENU.") + + (PROG* [(MENUW (WFROMMENU MENU)) + (DESTW (PROCESSPROP (TTY.PROCESS) + 'WINDOW)) + (TEXTSTREAM (WINDOWPROP DESTW 'TEXTSTREAM] + (SELECTQ (CAR ITEM) + (>>Close% Menu<< + (CLOSEW MENUW)) + (>>Add% Type<< [PROG ((WINDOW.REGION (WINDOWPROP MENUW 'REGION)) + STR) + (CLEARW PROMPTWINDOW) + (SETQ STR (if (PROMPTFORWORD "IM Index Type: " NIL NIL + PROMPTWINDOW NIL 'TTY (CHARCODE (EOL))) + else "")) + (CLOSEW MENUW) + (ADDMENU (create MENU + ITEMS _ (CONS (LIST (CONCAT "Index Selection as " + STR) + (IM.INDEX.LIST.FROM.STRING + STR)) + (fetch (MENU ITEMS) + of MENU)) + WHENSELECTEDFN _ (FUNCTION + IM.INDEX.MENU.WHENSELECTEDFN) + TITLE _ "IM Index menu") + NIL + (CREATEPOSITION (fetch (REGION LEFT) of + WINDOW.REGION + ) + (fetch (REGION BOTTOM) of WINDOW.REGION]) + (|Set Chapter Number| + (* ;; + "Create a chapter-number image object, and insert at the caret in the edit stream.") + + (COND + [TEXTSTREAM (PROG* ((SEL (TEDIT.GETSEL TEXTSTREAM)) + (FIRSTCHAR (fetch (SELECTION CH#) of SEL)) + (AFTERLASTCHAR (fetch (SELECTION CHLIM) of SEL)) + (SELPOINT (fetch (SELECTION POINT) of SEL)) + (NAM NIL) + OBJ) + (SETQ OBJ (IM.CHAP.CREATEOBJ (TEDIT.GETINPUT TEXTSTREAM + + "Chapter Number/Title:" + ))) + (* ; "turn off any pending deletion") + (TEDIT.SETSEL TEXTSTREAM FIRSTCHAR (fetch (SELECTION + DCH) + of SEL) + SELPOINT NIL) + (TEDIT.INSERT.OBJECT OBJ TEXTSTREAM (COND + ((EQ SELPOINT + 'LEFT) + FIRSTCHAR) + (T AFTERLASTCHAR] + (T (printout PROMPTWINDOW "Current window is not a Tedit textstream." T)))) + (COND + [TEXTSTREAM (PROG* ((SEL (TEDIT.GETSEL TEXTSTREAM)) + (FIRSTCHAR (fetch (SELECTION CH#) of SEL)) + (AFTERLASTCHAR (fetch (SELECTION CHLIM) of SEL)) + (SELPOINT (fetch (SELECTION POINT) of SEL)) + (NAM NIL) + OBJ) + [SETQ NAM (CAR (NLSETQ (MKATOM (TEDIT.SEL.AS.STRING TEXTSTREAM + SEL] + [SETQ OBJ (IM.INDEX.CREATEOBJ (create IM.INDEX.DATA + NAME _ (U-CASE NAM) + TYPE _ (CADR ITEM) + SAV _ (COND + ((U-CASEP + NAM) + NIL) + (T NAM] + (* ; "turn off any pending deletion") + (TEDIT.SETSEL TEXTSTREAM FIRSTCHAR (fetch (SELECTION DCH) + of SEL) + SELPOINT NIL) + (TEDIT.INSERT.OBJECT OBJ TEXTSTREAM (COND + ((EQ SELPOINT + 'LEFT) + FIRSTCHAR) + (T AFTERLASTCHAR))) + (COND + ((EQ MOUSEKEY 'MIDDLE) + (IM.INDEX.EDIT OBJ TEXTSTREAM] + (T (printout PROMPTWINDOW "Current window is not a Tedit textstream." T]) + +(IM.INDEX.OBJ.FREEMENU.SELECTEDFN + [LAMBDA (ITEM WINDOW BUTTONS) (* ; "Edited 18-Jul-88 14:14 by burns") + + (SELECTQ (FM.ITEMPROP ITEM 'LABEL) + (Close% Window (CLOSEW WINDOW)) + (Store% Props (PROG* [(STATE (FM.GETSTATE WINDOW)) + (OBJ (WINDOWPROP WINDOW 'IM.INDEX.OBJ)) + (TEXTSTREAM (WINDOWPROP WINDOW 'IM.INDEX.TEXTSTREAM)) + (OBJ.DATA (IMAGEOBJPROP OBJ 'OBJECTDATUM)) + (OBJ.DATA.PROPLIST (fetch (IM.INDEX.DATA PROPLIST) of OBJ.DATA)) + (NAME.CHANGED (NEQ (fetch (IM.INDEX.DATA NAME) of OBJ.DATA) + (MKATOM (LISTGET STATE 'IM.INDEX.NAME] + [with IM.INDEX.DATA OBJ.DATA [SETQ NAME (MKATOM (LISTGET STATE + 'IM.INDEX.NAME] + [SETQ TYPE (IM.INDEX.LIST.FROM.STRING (LISTGET STATE ' + IM.INDEX.TYPE] + [SETQ SAV (MKATOM (LISTGET STATE 'IM.INDEX.TEXT] + [SETQ INFO (IM.INDEX.LIST.FROM.STRING (LISTGET STATE ' + IM.INDEX.INFO] + [SETQ SUBSEC (SETQ IM.INDEX.DEFAULT.SUBSEC + (IM.INDEX.LIST.FROM.STRING (LISTGET STATE + 'IM.INDEX.SUBSEC] + [SETQ PAGE# (MKATOM (LISTGET STATE 'IM.INDEX.PAGE] + [SETQ PROPLIST (LIST 'SUBNAME (MKATOM (LISTGET STATE ' + IM.INDEX.SUBNAME)) + 'SUBTYPE + (IM.INDEX.LIST.FROM.STRING + (LISTGET STATE 'IM.INDEX.SUBTYPE)) + 'SUBTEXT + (MKATOM (LISTGET STATE 'IM.INDEX.SUBTEXT)) + 'SUBSUBNAME + (MKATOM (LISTGET STATE 'IM.INDEX.SUBSUBNAME)) + 'SUBSUBTYPE + (IM.INDEX.LIST.FROM.STRING + (LISTGET STATE 'IM.INDEX.SUBSUBTYPE)) + 'SUBSUBTEXT + (MKATOM (LISTGET STATE 'IM.INDEX.SUBSUBTEXT] + (SETQ PROPLIST (for X on PROPLIST by (CDDR X) + when (CADR X) join (LIST (CAR X) + (CADR X] + (if (AND NAME.CHANGED (TEXTSTREAMP TEXTSTREAM)) + then (TEDIT.OBJECT.CHANGED TEXTSTREAM OBJ)))) + NIL]) +) + +(RPAQ? IM.INDEX.OBJECT.IMAGEFNS NIL) + +(RPAQ? IM.CHAP.OBJECT.IMAGEFNS NIL) + +(RPAQ? IM.INDEX.BUTTONEVENTFN.MENU NIL) + +(RPAQ? IM.INDEX.OBJECT.DISPLAY.FONT (FONTCREATE '(MODERN 8 MRR 0 DISPLAY))) + +(RPAQ? IM.INDEX.DEFAULT.SUBSEC ) +(DECLARE%: EVAL@COMPILE + +(RECORD IM.INDEX.DATA (NAME TYPE SAV INFO SUBSEC PAGE# . PROPLIST) + SUBSEC _ IM.INDEX.DEFAULT.SUBSEC (TYPE? (AND (LISTP DATUM) + (IGEQ (LENGTH DATUM) + 6)))) +) + +(RPAQQ IM.INDEX.OBJ.FREEMENU.SPECS + (((TYPE MOMENTARY LABEL Store% Props SELECTEDFN IM.INDEX.OBJ.FREEMENU.SELECTEDFN MESSAGE + "Stores property values in index image object") + (TYPE MOMENTARY LABEL Close% Window SELECTEDFN IM.INDEX.OBJ.FREEMENU.SELECTEDFN MESSAGE + "Closes IM index editor window")) + ((TYPE DISPLAY LABEL " ")) + ((TYPE EDITSTART LABEL Name%: ITEMS (IM.INDEX.NAME)) + (TYPE EDIT ID IM.INDEX.NAME LABEL "")) + ((TYPE EDITSTART LABEL |Type():| ITEMS (IM.INDEX.TYPE)) + (TYPE EDIT ID IM.INDEX.TYPE LABEL "")) + ((TYPE EDITSTART LABEL Text%: ITEMS (IM.INDEX.TEXT)) + (TYPE EDIT ID IM.INDEX.TEXT LABEL "")) + ((TYPE EDITSTART LABEL |Info():| ITEMS (IM.INDEX.INFO)) + (TYPE EDIT ID IM.INDEX.INFO LABEL "")) + ((TYPE EDITSTART LABEL |SubSub():| ITEMS (IM.INDEX.SUBSEC)) + (TYPE EDIT ID IM.INDEX.SUBSEC LABEL "")) + ((TYPE EDITSTART LABEL Page#%: ITEMS (IM.INDEX.PAGE)) + (TYPE EDIT ID IM.INDEX.PAGE LABEL "")) + ((TYPE EDITSTART LABEL SubName%: ITEMS (IM.INDEX.SUBNAME)) + (TYPE EDIT ID IM.INDEX.SUBNAME LABEL "")) + ((TYPE EDITSTART LABEL |SubType():| ITEMS (IM.INDEX.SUBTYPE)) + (TYPE EDIT ID IM.INDEX.SUBTYPE LABEL "")) + ((TYPE EDITSTART LABEL SubText%: ITEMS (IM.INDEX.SUBTEXT)) + (TYPE EDIT ID IM.INDEX.SUBTEXT LABEL "")) + ((TYPE EDITSTART LABEL SubSubName%: ITEMS (IM.INDEX.SUBSUBNAME)) + (TYPE EDIT ID IM.INDEX.SUBSUBNAME LABEL "")) + ((TYPE EDITSTART LABEL |SubSubType():| ITEMS (IM.INDEX.SUBSUBTYPE)) + (TYPE EDIT ID IM.INDEX.SUBSUBTYPE LABEL "")) + ((TYPE EDITSTART LABEL SubSubText%: ITEMS (IM.INDEX.SUBSUBTEXT)) + (TYPE EDIT ID IM.INDEX.SUBSUBTEXT LABEL "")))) + + + +(* ; +"An image object to set the chapter number, on the TEXTOBJ's proplist, on the INDEXING-CHAPTER property." +) + +(DEFINEQ + +(IM.CHAP.COPYFN + [LAMBDA (OBJ SOURCE TARGET) (* mjs " 4-Aug-86 16:29") + (IM.INDEX.CREATEOBJ (COPYALL (IMAGEOBJPROP OBJ 'OBJECTDATUM]) + +(IM.CHAP.CREATEOBJ + [LAMBDA (DATA) (* ; "Edited 8-Dec-91 14:40 by jds") + (IMAGEOBJCREATE DATA (if IM.CHAP.OBJECT.IMAGEFNS + else (SETQ IM.CHAP.OBJECT.IMAGEFNS (IMAGEFNSCREATE + (FUNCTION IM.CHAP.DISPLAYFN) + (FUNCTION IM.CHAP.SIZEFN) + (FUNCTION IM.CHAP.PUTFN) + (FUNCTION IM.CHAP.GETFN) + (FUNCTION IM.CHAP.COPYFN) + (FUNCTION IM.CHAP.BUTTONEVENTFN) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.CHAP.OBJECT]) + +(IM.CHAP.DISPLAYFN + [LAMBDA (OBJ STREAM STREAMTYPE HOSTSTREAM) (* ; "Edited 12-Feb-92 12:28 by jds") + + (* ;; "only print CHAPTER MARKER if you are going to display") + + (COND + ((DISPLAYSTREAMP STREAM) + + (* ;; "display index by printing name with box around it ") + + (DSPFONT IM.INDEX.OBJECT.DISPLAY.FONT STREAM) + (LET* ([STRING (CONCAT "CHAPTER " (MKSTRING (IMAGEOBJPROP OBJ 'OBJECTDATUM] + (STRING.REGION (STRINGREGION STRING STREAM)) + (LEFT (ADD1 (fetch (REGION LEFT) of STRING.REGION))) + (BOTTOM (ADD1 (fetch (REGION BOTTOM) of STRING.REGION))) + (REGION (create REGION + LEFT _ LEFT + BOTTOM _ BOTTOM + HEIGHT _ (IPLUS (fetch (REGION HEIGHT) of STRING.REGION) + 2) + WIDTH _ (IPLUS (fetch (REGION WIDTH) of STRING.REGION) + 4))) + (TOP (fetch (REGION TOP) of REGION)) + (RIGHT (fetch (REGION RIGHT) of REGION))) + (CENTERPRINTINREGION STRING REGION STREAM) + (DRAWLINE LEFT BOTTOM LEFT (SUB1 TOP) + 1 + 'INVERT STREAM) + (DRAWLINE LEFT TOP (SUB1 RIGHT) + TOP 1 'INVERT STREAM) + (DRAWLINE RIGHT TOP RIGHT (ADD1 BOTTOM) + 1 + 'INVERT STREAM) + (DRAWLINE RIGHT BOTTOM (ADD1 LEFT) + BOTTOM 1 'INVERT STREAM) + (IMAGEOBJPROP OBJ 'REGION REGION))) + (T + (* ;; "HARDCOPYING; DO NOTHING BUT SET ") + + (TEXTPROP (TEXTOBJ (OR HOSTSTREAM TEXTOBJ)) + 'INDEXING-CHAPTER + (IMAGEOBJPROP OBJ 'OBJECTDATUM]) + +(IM.CHAP.SIZEFN + [LAMBDA (OBJ STREAM CURX RIGHTMARGIN) (* ; "Edited 8-Dec-91 14:38 by jds") + (if (DISPLAYSTREAMP STREAM) + then (create IMAGEBOX + XSIZE _ (IPLUS (STRINGWIDTH [CONCAT "CHAPTER " (MKSTRING (IMAGEOBJPROP + OBJ + 'OBJECTDATUM] + IM.INDEX.OBJECT.DISPLAY.FONT) + 6) + YSIZE _ (IPLUS (FONTPROP IM.INDEX.OBJECT.DISPLAY.FONT 'HEIGHT) + 4) + YDESC _ (FONTPROP IM.INDEX.OBJECT.DISPLAY.FONT 'DESCENT) + XKERN _ 0) + else (create IMAGEBOX + XSIZE _ 0 + YSIZE _ 0 + YDESC _ 0 + XKERN _ 0]) + +(IM.CHAP.PUTFN + [LAMBDA (OBJ STREAM) (* ; "Edited 7-Apr-87 18:44 by jds") + (PRIN4 (IMAGEOBJPROP OBJ 'OBJECTDATUM) + STREAM]) + +(IM.CHAP.GETFN + [LAMBDA (FILE TEXTSTREAM) (* ; "Edited 8-Dec-91 14:40 by jds") + (IM.CHAP.CREATEOBJ (READ FILE]) + +(IM.CHAP.BUTTONEVENTFN + [LAMBDA (OBJ WINDOWSTREAM SEL RELX RELY WIN HOSTSTREAM BUTTON) + (* ; "Edited 8-Dec-91 14:40 by jds") + T]) +) + +(ADVISE 'TEDIT.FORMAT.HARDCOPY 'AROUND '(RESETLST + (RESETSAVE NIL (LIST (FUNCTION IM.INDEX.CLOSEF) + STREAM)) + *)) + +(IM.INDEX.INIT) +(PUTPROPS IMINDEX COPYRIGHT ("Xerox Corporation" 1986 1987 1988 1991 1992)) +(DECLARE%: DONTCOPY + (FILEMAP (NIL (2160 15212 (IM.INDEX.CLOSEF 2170 . 2785) (IM.INDEX.COPYFN 2787 . 2972) ( +IM.INDEX.CREATEOBJ 2974 . 4320) (IM.INDEX.DISPLAY.STRING 4322 . 4743) (IM.INDEX.DISPLAYFN 4745 . 8588) + (IM.INDEX.EDIT 8590 . 12058) (IM.INDEX.LIST.FROM.STRING 12060 . 13094) (IM.INDEX.SIZEFN 13096 . 13856 +) (IM.INDEX.STRING.FROM.LIST 13858 . 14103) (IM.INDEX.PUTFN 14105 . 14294) (IM.INDEX.GETFN 14296 . +14451) (IM.INDEX.BUTTONEVENTFN 14453 . 15210)) (15213 17283 (IM.INDEX.INIT 15223 . 17281)) (17284 +29200 (IM.INDEX.MENU 17294 . 18982) (IM.INDEX.MENU.WHENSELECTEDFN 18984 . 25739) ( +IM.INDEX.OBJ.FREEMENU.SELECTEDFN 25741 . 29198)) (31736 36879 (IM.CHAP.COPYFN 31746 . 31926) ( +IM.CHAP.CREATEOBJ 31928 . 33354) (IM.CHAP.DISPLAYFN 33356 . 35316) (IM.CHAP.SIZEFN 35318 . 36320) ( +IM.CHAP.PUTFN 36322 . 36506) (IM.CHAP.GETFN 36508 . 36669) (IM.CHAP.BUTTONEVENTFN 36671 . 36877))))) +STOP diff --git a/docs/Documentation Tools/IMINDEX.LCOM b/docs/Documentation Tools/IMINDEX.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..02a963a9efa2d6e585ad232b78abf421390d784f GIT binary patch literal 17113 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 aK|yQ=U&7&Mihic?gA6c!ENqZ`-2Vo8X4#nl literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/IMINDEX.TEDIT b/docs/Documentation Tools/IMINDEX.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..956a1f05ebe0bae3dc4c894d806c2adbaede4118 GIT binary patch literal 26869 zcmeHPeQ;dGk)M?XS{;@x8!8p<95P;fL?*IgI|R$db|hPprJxU&EJJdXD}Gu%Sqr=S zHv3^o7YM?LSP&pKf!uMS5~`BFxIe-bbq<#hyo9f$3Wucb>JCRo*$G#d&nuj87f5WZ z`*qLE``Gv7wF!Y-ogY~HUca86o}QlWo}QW4uxXR*>Feq5==`|cw5g$CXv~(QskH3^ zlTNm1rLqNCq&KB(vY2x4R4Ujba@5JoWZt%lsq7wUWk;kvlH&VRcEp~Lsf@M9md@~v zcCuJ#W&{wj^Na#=8JWr!9cjrSDkn#rWGQ23i!D-KKW1k`aH(0L%2WlKv`iI7U1`{kc@Xiu+<&?@ol0yRny*p$Q#fEJqIS?sYH`!=o!7fT?6iA@KB($XV z*jYPo6@ijfoU}AFG_;S5C{fEEmhb?}R{Dh4p@pb=vXIK;(srRJ$E``K#d6F08|N=? zI)P+LOit!(nJnhhs|Muw80iHd%tBH1S~G!@V{#nQKntN3Xwx{TJL6P7=j3E5C#}Lw zRA|yExkN4QGJ3T4TImf94I(D!+9y6DVsjN&SyTY#%HoZW&dnVI_*VR*t1M2w_Q=59 zbL;jv3P3oSJ3lo0nIFx1kdy!QEob&KfBwp?E{=k{IqQSG_ATdyx%WNmmD0#_uezlS z#Qa8aSmp+Kf6C%K}((E9N6-)mD);> z$6&i=XL7~KfSqktPh>2}1Q+dmM)vpg5||tZ%sUJ!y$QMuX(^MPwDLCj4`m&Vdr+o6 zSW=rPt02dn{0RQ0ieqxvnXn7e$~z_aGSrfB%~EWg=nk7DBZ%Pd>5#DszBf;&L*~F6 z9R9lt&*S;U;ohH@iz|x2&DqPvXyTcF&t9L;Ovk)6^xg#Ebpwp}JuOb3UOac~_E!(j zy?o4d^I^o(;`fK29AA9+o=gAj<$rysa43wSAg9HtTfhCyWBW6Qp8v(68!~6W`~Bf3 zHXS>hIdtq7hh{U6%unz1+_!(vc(3oB&AdE6-rU@i>jrMW=fPvI@BR0}8S&<$;fEXf z`C(D_XOCA7=+Ar)XRlXp6TSD(9VcF@*4rrLIpWoQSBPce$7NB2f?PN*8tFDpgqB{( zAk-VfvlOz8pypycArP%z?BQLsNKEA9)|q>ouL9Y+_lVXqUP4zD^H1~k4P#^ z^cEfzaz=J^?_1j|5>h-U;@?}Fm|C(ne&>>yA20qD#{1a5M2A>DRd-Ot@4WcOVo4(Y zJJh@MMwedvfQKjB;)J&}MtHXo-UlBx_2LcH+gX#KdKu5uyBsa|=-n$M+Hprs;wrJc zO!dxiJL0+HPx1g`Bh}>|`Kgk;^-ngP6ob&M6>&MM)ruL=FFq7CB{&fg{+|%DuO6d#$9J6&M_>HWr@sH{*M8b}*nkOkH1my5 z-Z#6-2m8_2XEXZ`A9^}d0XzK3L&q{7^~%mVv!8nI)kCkOeR$@r_Z!XMRA_883K!%GhVd*bm$%VKr!c?_^SFJ00$ z(Qz=*G5ySvL@fSyFB}ke*4Lkys=fIuvSWI>Zdq*cffhaHgdSgh`Z5H+>BG}_w;7}Zn@S@6{; zrsJ2q?|owW+Wm2g59n$X`)V(_{Bkkf+kHSXM8Oivmy3Nf13uVvd^5wkePw4F+fnwm zh27I$9S3AP>bUKq{XSl%m@>sF<}z)&Fal<9=-1!{VF%=8Qiuf?5&~}M2kl)hHB5&> z)ZVtspWa_{SL@@`ZBxKfZEIVxqI=(69nVbP#vqnK+ltFSzi;s7X%B|7D`a=gVB54; z7IjcrsK(uH9pHuPNVHBDU0$XXVc*~Ac6j=3?oJ4ppPo_99&nz3jK**}mF3hV(hA0? zsMJ6+GP7wUuE|{8pz;Yj6oBkQ0SSnFW|vAEP(C7Uj}|GHT*Oe;7k-y%9JVqB1?Dm93NnF^SEjH5B_68|vhzapUu|CTFoQkkN zry^1a3(v#E*~`Fak@p)dXYakaGkE^#?x~2W?Wu@q?5T(;E8$g6PeCs<6{UJBr=5lu z!yEmcJ*>=X=l^r|@+;RpzX&B8>uN631W>jX6A{2_?^qIqwLbcT0IY82ps4-c>bg5B z%5J=~v9|mEVA&492JWkbt*-5+s_3G6>lTTPGe01*>N6xrGH#>ndsx_f6j^lUq7e!TzZ#z=QsUBnwBo}NZib{eZv z6qV}b|G;hv+6&OB_gVl!g{OKmfG?8uHUl8;rNws@VR|&x3K?3W=DQrY>eVv6WIsM; zgP%N?9=EbsX2XI#?baYJX+s7!Y`9!=Fsobd&6B?Ko{9~|mF+K11N_s4Jz zhjn%SI5nrO%rak`n$uGof|={JH|nJn68U-qnVb8Kh)2MFKJk}Ne|6>|-@NAHUtcP( zSTWMM%m-TK>Oxu9HTYnz zYk0qA|CDkUe+<{KFv2w~if|2!&(bw4F6*}WT*Kny5ikw%yO4&dFkXEG%jL;$?cQ<27#4 zCSGlZ3Zx8S%$;=F0mdHBCO#%cqHH3y=eVoqx0>eh?{RVRmXmXb=jKknS_xl&vVZ-{ zzk8*tZ0pN!yfQi-#P>gW z_a6TqjPB-#m)+j+-|Tj^zz-E-e)!WFOybi_qS*~uwnN_LB9I`9zVF&W>-a56K1 z4`6{Vw)E-GEfVp4%UW|aU;SLevX0&2>Dnc0J7O2F=*99^O`>C_=Ha`)kN~_qy+qy| z`$=v0-2`9#M$N-B2NOd?e~E01)zo(H1D!;CD%NJ;2W1D~LvY0SA%*1zh@cXW$;FqFL8&b>ToXP{_*f#5Z|1KD|x(oa(JeVIB0D=p%~GBcZ=uR z=ypZZjE1Nmz_jXJCCQG(oR8YB5EFKiT1?JawSeRpr4{7IhBlh!Hv zaW9r9q_DPe%7xJl;B`wjHb%kYcQrPOE5rDUr$HwI9&V;qx$RVsk+GieF_#nQa>-cELuMo&P3}~oZzON=9l#OOz<{?sDI&) zW@e)G6Bto^mI04yFTumt+b92EJYk;Zk1J>oJl1&dKQ^1^ZQEPZwJ0Dfm}OsgK6`F+ za4CJ6haE*M&B*O}Cs){o^&32>H62Y-?^>mru%yFl*ffFGQDmx!iTS8pwMwSc^gq#W zW$X=fqyT9EYCv+#%I>j8)OiNA_f>_Qda;RLQ>0oLqmB0`2e9Uf5 zI|W-_kJrvPtzpsDeFjlM&7&fZa{UfA>vHOX7ULBov`H3gUJgzcfMW`$Re3jA5g8uy zY8jobAo-YW0K_Lk?HpFfCUp{ovKxVv28or9jo1Y~)_|(1`V2{27sabUvP9PpwzEnk zx&yS(Qdz9?LkT9YVOeRYPR$gOc?9eT{LxeB#xX0WCIJPTQatLA3m0=BuDp)}2x|xe z)VUjC5gl#kbJ&v%3Rp8#69L*nKtkQ1(0why9tFbWy~v5Cl?kjtmT|yK_!)!5u_crc}c$30iL9_rO#SrMLnhLmcP$0WXLDsGcNnh$D|4aess8@zuNo@6-5~MExmH&H{r5ec=+j~SGp8WKvg<0?*#W-+@BcfMA2?ymZu7&ubH^h6GTaS8SPPi-77?zmV!gBCg zr*wK%3Fn>iNvmM1yd~|fq0x?2>akR3TC2V?$6xJq(9!8trV2>=BSeHj+2>(|#Hl0}LuYz(sk<&g>qj?HKR; z2j&2%<(Zr^IqtDDCPq|&o%7D6HKQ&0lr@Y)PtDRUCPBipUo3(T!SaJ7NrJe=0VyXB z4(QZ?*HS&&WS2h2MTZ)wm6EarFbi9q47MhXG&I!v267>1Ct*}Hw_Cg0w-0p=vc=f3 zbIXp-t+ELg$Lj~|OoD~r2ElIgF*+FEESCP2En_)SOK3!!Oe;FCfPoAXl^UjjY@;>c zd}z!@b6~%yx6K(dV6v2$=%iu`rj@%l*j?lyq?Ig|$Rxs`k%@6nS}+aN;dPo$R-0V4 zaaOJshghju%omB69u;YBEmF!li$eXEb+VpJptCSlDA}kR6Of5Y ziJ{f0B#!-%ec;17N--?bwhW!3%-h@#NeWeZ)EOU^RI`hr1ec>TrP)$um^zafHtIT> z$`^{{n9zh_2Vv7FRwsO_gbJzkioO1U?d{t-Be)|a;;4y6B3ez%BBm;Vo*rAKKK9b! z-{S|Ball!z#N(diG=tl9>QEZmW@JlP(gaFt1GK^PwkJlca+QX6*hx}>?RjSyc43kk z%20rSUZB&IplB_ZfbP6j=M|m;6-EM$EgfX8; z+SsYd9b$-RHQ^vE* zU#~nV-0V0^EhNa~KLTz5VU39#_yq{AwNFPjG#FN~O<`@tRLWRJr6ll?(07D7;5=hNIhFkhXsI#+J~o1!(9=0E6JiK$ zGzZN4;R2{JtZBqj#b#~90tgk1pYq0unTEM%`FT9TqR{+9#iKAoleE*DJqjszfV`Tb zJG%4mDuZt7M#P3P)hAJw8KeeEf!P)n$jggBUW}UGu*i4UU=0tTp zGed)ejFW?o(3`&X)^tUW%)4RyhRvICCZA=sapNwttw8shD>Tz89KYvzxmt$j?Yhgz1`u3XNC}$}}RDP$K7Up#?Lu#XfSq z?C-@j^Q@O0H+i7I@A2?{d%Qm$-f^#>m3!_98s2qppuv6j1P$-JCn)}fuX&(T;l!B` z(uLNV*D*jV_TZO=SYn{=E__-;LTXS3_uXQSVN>EV09OzsELj!W4lL-XHzwq@oK*MJgP>l?qQXpvf zoB~0^ClwU5@~ncQP>v@ z&o2;kUv1?H1_KSAVbByRPB9QPe2#&j;gbvmox-2cH4ijwNB}v`yBX#`oe=OD?#xCf zWjO6S3^U9J6==GTWU+~q$%H3Md7c=nK+E-6h+8O1ca6Ny15*UC!`e$kXf`ouQ!;}e z6%Df=O@D5|^^XJU6G4=lpxqee8#IVF)yId3po?r`V3V!2_QC~~++$^!eWtQBp;WXI z+e^g+=y1Nqgk0QoPSS_M7^=!QpT<46R7DHAYWPb;j&Q5UwX48{XC*4W$=b-P7Kj0O z*tCP$yz=kr6HCat-b53|VLr;?ZXcn{`nj|nD+Qb%8BZaAQU$q9JU8VEGsFZcN?hMQ z*x%E?ZG$wzH$tU|^QNpbjtQ^-J56xa)OQr#1sWYlWnjKTt%}&#au@b#@#lN+_q135 zB|RnT=E|hLK}fk$^UH4ya&(HyE%?-T7H^(Bu^YE#19|?^N00pNZh*>1pE&x;mz)Kk ze*V3y0Xezu-ty5yzsAx2+iyJbr6-P@*qyv$mLV@5xjlR2!AFmLX}9&C#{fBch#<#i z39|dSm&z|*edMv}du|_j>By6lzb>~v|M?1@Yn~Gokl1G{A;e)Be*#wo}SZ;>B}xmFSK4LzqESI{>OwfvF=cM;e`tqTE8mKKC$Mf zkBQ93*Bx>eUij+5$zM^a&z=yOm#+S;D)mHp7LeCO=IEi{rayf3uNGQQl#e{Q=CcKn ze(=!vi;sQSx!Zauf}d~?h9PW@covI1Le9>rpr19crp-in5@p@_mHxt)Uo3DTDtnK>UVUIq zXF0h(V~dsX;m@OKCsJWU;e32wOydvCxn2ZwR;UW4p!Ap2z|s&|7fR^KVv2IpCM%~Z zq=~$bAIi7T8YU;~9Er6;%4Sh&znBLV%AhMNjxK?DF2Y}or1H3N@|cCQ%~YLjjHWjF zdRC=Y2RF#X00=ApK+CE*hgagbf(`Q19XqbQWn*v8j_qANy`4KYBemDU-*jtfX&G^{ zHl_Ejr^L6in=DJFMNW>+_kk-?RF(ENjBvA5@1cIu_;arRnl&y5ym;z0od%%#h9B|d zlNO{)5bgidldB@+CYw}VS1Yrb%Xxly>p*|M@w+SC9z|c!j8s*P3>Qm-dWfMq@2y5D zb)0X?52heS5UQN25(%#asm8}Y@mDQFogFbnK z+M7I)>LnkFj)I5*Z4L32LKFgNCyVy0#`yDu@CBh7Xf;BAY7Anb;YY$G0npl#`g#~A z^H|?a=;A7!5rOvw#y_Cuh+3(2S|ou1r|R?BNpe10DHta~!k(v+lun~yY={>$NsQ!w zkZ38$E^-5kL>HQ(Hby98r@uGJzRv`E+{sW!&<0KB1O2KO9mzepb#XG8Pjrw2K?9VILb;ToN*AzII`52>ux1CMUIU_tdJQ0Lgc;QH5MEutl0UQeBc{dB(ho6`l_SBQPQXV6N z*JLS%AeNL`djev|1`&~1C-f3{fxdlL#5xjvPeQfCbQ6Lm^MOzmTvWu?)LXRP>3(|^ z+ee!E+OH*Zq10Xu>>MJsZ|UmYCa)Xl-ASgTziU9-33f>Oe&`e1J9n(CufM@$=5{qS z1ZmOU5jGvX#6~*j4GhF{q>j3aNjFs^n>}yrW$|FG@s<^@XRuF=DLS_pO=!%dS|+vAv`Io~4M_vR1PO$x8aKr)S9^O3Mj!b*sHn>*@<#f!EQMcs#c(qQ zxW9LR>Mi2Zx*XV4t0$yY+P$g;Ibc%OyHIej!=MPS%{rz~_Bv^NHkZdG$XR(z`ZADJ zYL$B7j$GNKzhQ!G{$L-u-3z*uQDvemjIX}rm)Ll0W|+WU95_qM23?4a&7 zTFl0p`!nlEU31hbt=0%08;}R)lKtgHSEZ)>TynN z!l>92xilD7Rh+qVEdM!)0IuM9E(O#_@IIak`za7BMA7^iaq3qk>D+W_?e}S zq9Kk>LVW1RJ!!1g(iR)NEd}ieR;`ws&^kDA9&I{PU{-m}sXNaJyN3l8NV#EGm^{SI znl6mMiC^^qdJ9w=&axu3m5+JLE-gnnKq5Q0zT4A)daAc->PgS@{HZ>Weva;zq z-Q1NcF=;_$;#w~@AVwJOb{97;qnavsQI;cE6)PHbfa+{odhqRc0{xh*E*5HToX4~G`RHI!EHMufY8Ac{FldK5_BngofAlQ$RO>w#-=x7(z0 z7GSX<<~&J^T-Q*;Uq56HKoFM#(8(z@gRW?d*hA{w{1~dZ zpXdh(`AkH`*Q*g-@Eiy%+|q{+3Ab$P9O~--aO@A4La6m2!1t^1by4rT!dHmV_f{40 zBh{L+;PF3=raV!NQFTNP3RXK+$uSk>@j36?kmN#u{~;oN^$lT!06eT2I?t%VPTnd+ zYwxdY%R8drw^ZY+KK*X+6??oIU*M`jqSc4Mvz0|cH2&p`7=&J{F=CLMvXBLT8A1tA zrH41GV$gcDt8*w4`^O4Eh^SFeg%?$A?1$B8h=8g`(GY=th{UL`tmUFgfKv$|I{wz; zS_p?6hc1ZWWE6@z^d8XNm& zHKO>8;JeY-r>gN4ZtT_78e8+VYD8mI9eL~r)o6qn+fa?M*gsVzx~3{dZ#9hAO;s@# vSH-Aa3x9sijLE3s6Bf{xYSoH=u8I*D`H|KBvMLR-HW)3tu8!6J^*8?)p4iaV literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/IMNAME b/docs/Documentation Tools/IMNAME new file mode 100644 index 00000000..026d1318 --- /dev/null +++ b/docs/Documentation Tools/IMNAME @@ -0,0 +1,754 @@ +(FILECREATED "14-Jul-86 14:48:47" {ERINYES}LISP>IMNAME.;2 36556 + + changes to: (VARS IMNAMECOMS) + (FNS IMNAME.UPDATE.SEND.INFO) + + previous date: "30-Sep-85 13:02:01" {ERINYES}LISP>IMNAME.;1) + + +(* Copyright (c) 1983, 1984, 1985, 1986 by Xerox Corporation. All rights reserved.) + +(PRETTYCOMPRINT IMNAMECOMS) + +(RPAQQ IMNAMECOMS ((FNS DELETE.UNDER.MENUS DISPLAY.UNDER.MENU GET.IM.NAME.LIST IMNAME + IMNAME.UPDATE.HASHFILE IMNAME.UPDATE.REF#TOPROG IMNAME.UPDATE.REFS + IMNAME.UPDATE.SEND.INFO INSPECT.IM MAKE.IM.INSPECTOR MOVE.UNDER.MENUS + OPEN.IM.NAME.HASHFILE REDISPLAY.IM.NAME.MENU REDISPLAY.IM.REF.MENU + REDISPLAY.IM.TYPE.MENU SELECT.IM.MENU.ITEM TEDIT.IM.FILE) + [INITVARS (IM.NAME.MAX.DISPLAY 5) + (IM.NAME.DEFAULT.HASHFILE NIL) + (IM.NAME.HASHFILE.ABBREVS (QUOTE ((INTERLISP . + {ERINYES}INTERLISP.IMNAMEHASH) + (LOOPS . {INDIGO}MANUAL>LOOPS.IMNAMEHASH] + (FILES HASH) + (MACROS IMNAME.RESETSAVE.MOVD))) +(DEFINEQ + +(DELETE.UNDER.MENUS + [LAMBDA (TOP.MENU.OR.WINDOW) (* mjs "27-OCT-83 10:53") + (PROG (TOP.WINDOW UNDER.MENU UNDER.WINDOW) + (if [AND (SETQ TOP.WINDOW (if (WINDOWP TOP.MENU.OR.WINDOW) + else (WFROMMENU TOP.MENU.OR.WINDOW))) + (SETQ UNDER.MENU (WINDOWPROP TOP.WINDOW (QUOTE UNDER.MENU] + then (WINDOWPROP TOP.WINDOW (QUOTE UNDER.MENU) + NIL) + (DELETE.UNDER.MENUS UNDER.MENU) + (DELETEMENU UNDER.MENU NIL (SETQ UNDER.WINDOW (WFROMMENU UNDER.MENU))) + (CLOSEW UNDER.WINDOW]) + +(DISPLAY.UNDER.MENU + [LAMBDA (TOP.MENU NEW.MENU) (* mjs "24-Jul-85 15:19") + (PROG (NEW.WINDOW (TOP.WINDOW (WFROMMENU TOP.MENU))) + (if TOP.WINDOW + then (DELETE.UNDER.MENUS TOP.MENU) + (SETQ NEW.WINDOW (CREATEW (CREATEREGION (fetch (REGION LEFT) + of (WINDOWPROP TOP.WINDOW (QUOTE REGION) + )) + (IDIFFERENCE (fetch (REGION BOTTOM) + of (WINDOWPROP + TOP.WINDOW + (QUOTE REGION))) + (fetch (MENU IMAGEHEIGHT) + of NEW.MENU)) + (fetch (MENU IMAGEWIDTH) of NEW.MENU) + (fetch (MENU IMAGEHEIGHT) of NEW.MENU)) + NIL 0)) + (WINDOWPROP NEW.WINDOW (QUOTE UNDER.MENU) + NIL) + (ADDMENU NEW.MENU NEW.WINDOW) + (WINDOWADDPROP NEW.WINDOW (QUOTE CLOSEFN) + (FUNCTION DELETE.UNDER.MENUS)) + (WINDOWADDPROP NEW.WINDOW (QUOTE MOVEFN) + (FUNCTION MOVE.UNDER.MENUS)) + (WINDOWPROP TOP.WINDOW (QUOTE UNDER.MENU) + NEW.MENU) + else (MENU NEW.MENU]) + +(GET.IM.NAME.LIST + [LAMBDA (HASHFILE.NAME) (* mjs "16-Dec-83 14:34") + (PROG (NAME.LIST HASHFILE.PTR) + (SETQ HASHFILE.PTR (OPEN.IM.NAME.HASHFILE HASHFILE.NAME)) + (if (NULL HASHFILE.PTR) + then (RETURN)) + (SETQ NAME.LIST (GETHASHFILE (QUOTE namelist) + HASHFILE.PTR)) + (CLOSEHASHFILE HASHFILE.PTR) + (RETURN NAME.LIST]) + +(IMNAME + [LAMBDA (HASHFILE.NAME) (* mjs "15-Jan-84 17:22") + (MAKE.IM.INSPECTOR HASHFILE.NAME]) + +(IMNAME.UPDATE.HASHFILE + [LAMBDA (OLD.HASHFILE.NAME ADD.FILES DELETE.FILES FLUSH.DISAPPEARED.FLG) + (* mjs "29-Sep-85 14:08") + + (* * this function updates an IMNAME database hashfile. First, it looks at the list of files referenced in the  + hashfile , and determines which of these files have been updated, by  + searching for the files, and checking creation dates. Next, for every updated file, IMTRAN is called with several of + its subprocedures modified so it will not output anything, and only put index information into an in-core hasharray. + Finally, the entries in the old hashfile are read in, merged with info from the in-core hasharray, and written out  + to a new hashfile.) + + + + (* * OLD.HASHFILE.NAME is the name of the hashfile to be updated. . + The new hashfile will be created as the new version of the same file name. ADD.FILES is a list of files that will be + analyzed, and added to the database. DELETE.FILES is a list of files that will be deleted from the database. + ADD.FILES and DELETE.FILES can be used to "manage" a database, as new files are added to a document, and old ones  + are removed, split up,or renamed. FLUSH.DISAPPEARED.FLG determines what IMNAME.UPDATE.HASHFILE will do if it finds  + that some of the files in the database have disappeared . + If FLUSH.DISAPPEARED.FLG = T, the info for those files will simply be deleted. If FLUSH.DISAPPEARED.FLG = ERROR,  + IMNAME.UPDATE.HASHFILE will return without doing anything if files have disappeared. If FLUSH.DISAPPEARED.FLG =  + , the info on the disappeared files will simply be retained.) + + + + (* * to create a new IMNAME hashfile, pass a non-existant file name as OLD.HASHFILE.NAME, and give a list of files  + as ADD.FILES. In this case, a new hashfile will be created just from the internal hasharray info.) + + + (PROG ((DISAPPEARED.IM.FILES NIL) + (REDO.IM.FILE.NAMES NIL) + (FLUSH.FILES NIL) + (OLD.HASHFILE NIL) + (OLD.IM.NAME.LIST NIL) + (OLD.IM.FILE.INFO NIL) + (OLD.IM.FILE.NAMES NIL) + NEW.HASHFILE.NAME NEW.HASHFILE NEW.IM.NAME.LIST NEW.IM.FILE.NAMES NEW.IM.FILE.INFO + NEW.IM.HASH DELETE.FILE.NAMES ERRFILE ERRFILE.NAME) + (DECLARE (SPECVARS ERRFILE ERRFILE.NAME)) (* make sure that IMTRAN is loaded, so that we can  + analyze updated files.) + (FILESLOAD IMTRAN) (* U-CASE all file names, because we will be comparing  + them to database file names) + (SETQ OLD.HASHFILE.NAME (U-CASE OLD.HASHFILE.NAME)) + (SETQ ADD.FILES (U-CASE ADD.FILES)) + (SETQ DELETE.FILES (U-CASE DELETE.FILES)) + (SETQ NEW.HASHFILE.NAME (PACKFILENAME (QUOTE VERSION) + NIL + (QUOTE BODY) + OLD.HASHFILE.NAME)) + (SETQ ERRFILE.NAME (PACKFILENAME (QUOTE EXTENSION) + (QUOTE IMERR) + (QUOTE BODY) + NEW.HASHFILE.NAME)) + [if (INFILEP OLD.HASHFILE.NAME) + then (* if old hashfile exists, open it and get namelist and + filelist) + (IM.WARNING "Opening old hashfile " OLD.HASHFILE.NAME) + (SETQ OLD.HASHFILE (OPENHASHFILE OLD.HASHFILE.NAME (QUOTE INPUT))) + (SETQ OLD.IM.NAME.LIST (GETHASHFILE (QUOTE namelist) + OLD.HASHFILE)) + (SETQ OLD.IM.FILE.INFO (GETHASHFILE (QUOTE fileinfo) + OLD.HASHFILE)) + (SETQ OLD.IM.FILE.NAMES (for X in OLD.IM.FILE.INFO collect (CAR X] + (if (NULL OLD.HASHFILE) + then (IM.WARNING "Will construct new hashfile named: " NEW.HASHFILE.NAME)) + (* push on REDO.IM.FILE.NAMES the full names of all  + files on ADD.FILES that can be found.) + (for FILE in ADD.FILES bind COMPLETEFILENAME + do (SETQ COMPLETEFILENAME (FINDFILE FILE T)) + (if COMPLETEFILENAME + then [SETQ FILE (PACKFILENAME (QUOTE NAME) + (FILENAMEFIELD FILE (QUOTE NAME)) + (QUOTE EXTENSION) + (FILENAMEFIELD FILE (QUOTE EXTENSION] + (push REDO.IM.FILE.NAMES FILE) + (IM.WARNING "Adding file " COMPLETEFILENAME) + (if (MEMB FILE OLD.IM.FILE.NAMES) + then (IM.WARNING "(updating version of file in old database)")) + else (IM.WARNING "Can't find file " FILE " -- ignored"))) + (* collect the normal names of all deleted files, minus + version numbers) + [SETQ DELETE.FILE.NAMES (for FILE in DELETE.FILES collect (PACKFILENAME + (QUOTE NAME) + (FILENAMEFIELD FILE + (QUOTE NAME)) + (QUOTE EXTENSION) + (FILENAMEFIELD FILE + (QUOTE EXTENSION] + + (* analyze all of the files referenced in the old hashfile. There are four cases: <1> if the file is on  + DELETE.FILE.NAMES, all references to it should be flushed; otherwise <2> if the file does not exist, put it on  + DISAPPEARED.IM.FILES; otherwise <3> if the file DOES exist, but it has a different version number, flush the old  + version of the file, and reanalyze the new version; otherwise <4> the current version of the file is correct, so you + don't have to do anything.) + + + (for FILE in OLD.IM.FILE.NAMES bind STANDARD.FILE.NAME LATEST.VERSION.FILE + do (if (MEMB FILE DELETE.FILE.NAMES) + then (* if the file is on DELETE.FILE.NAMES, just flush it) + (IM.WARNING "will delete info for: " FILE) + (push FLUSH.FILES FILE) + elseif (MEMB FILE REDO.IM.FILE.NAMES) + then (* if an old file is already on the list to redo, flush + it immediately. It must have been an added file) + (push FLUSH.FILES FILE) + elseif (NULL (SETQ LATEST.VERSION.FILE (FINDFILE FILE T))) + then (* if this file does not exist, put it on  + DISAPPEARED.IM.FILES) + (IM.WARNING "can't find old file " FILE) + (push DISAPPEARED.IM.FILES FILE) + elseif [NOT (EQUAL (GETFILEINFO LATEST.VERSION.FILE (QUOTE CREATIONDATE)) + (CDR (ASSOC FILE OLD.IM.FILE.INFO] + then (* if this file DOES exist, but it has a different  + creationdate, flush the old version of the file, and  + reanalyze the new version) + (IM.WARNING "old file " FILE " has been updated -- will re-analyze" + " [author=" + (GETFILEINFO LATEST.VERSION.FILE (QUOTE AUTHOR)) + " , date=" + (GETFILEINFO LATEST.VERSION.FILE (QUOTE CREATIONDATE)) + "]") + (push FLUSH.FILES FILE) + (push REDO.IM.FILE.NAMES FILE))) + + (* if any files referenced in the old hashfile have disappeared, take different actions depending on  + FLUSH.DISAPPEARED.FLG: If FLUSH.DISAPPEARED.FLG = T, just flush the file info. If FLUSH.DISAPPEARED.FLG = ERROR,  + close the hashfile and stop the program. Otherwise, just leave the disappeared file info intact.) + + + (if DISAPPEARED.IM.FILES + then (IM.WARNING "the following files have disappeared: " DISAPPEARED.IM.FILES) + (SELECTQ FLUSH.DISAPPEARED.FLG + (T (IM.WARNING "Will delete info for disappeared files") + (SETQ FLUSH.FILES (APPEND DISAPPEARED.IM.FILES FLUSH.FILES))) + (ERROR (IM.WARNING "--- returning ---") + (CLOSEHASHFILE OLD.HASHFILE) + (if (OPENP ERRFILE) + then (CLOSEF ERRFILE) + (IM.WARNING T "IMTRAN Error File: " (FULLNAME ERRFILE) + T)) + (RETURN)) + (IM.WARNING "Will keep info for disappeared files"))) + (* initialize new file list and name list, and in-core  + hasharray for re-analyzed file info) + (SETQ NEW.IM.FILE.NAMES (LDIFFERENCE OLD.IM.FILE.NAMES FLUSH.FILES)) + (SETQ NEW.IM.FILE.INFO (for X in OLD.IM.FILE.INFO when (MEMB (CAR X) + NEW.IM.FILE.NAMES) + collect X)) + (SETQ NEW.IM.NAME.LIST NIL) + (SETQ NEW.IM.HASH (HASHARRAY 2000)) + + (* * analyze updated IM files, by running each one through IMTRAN) + + + (RESETLST (* make sure that IMTRAN does not dump anything, or  + include any files.) + (IMNAME.RESETSAVE.MOVD (FUNCTION NILL) + (FUNCTION DUMP)) + (IMNAME.RESETSAVE.MOVD (FUNCTION NILL) + (FUNCTION INCLUDE.FILE)) + (* use modified SEND.INFO program that will dump info  + in in-core hasharray) + (IMNAME.RESETSAVE.MOVD (FUNCTION IMNAME.UPDATE.SEND.INFO) + (FUNCTION SEND.INFO)) + (IMNAME.RESETSAVE.MOVD (FUNCTION IMNAME.UPDATE.REF#TOPROG) + (FUNCTION REF#TOPROG)) + (PROG ((IMNAME.UPDATE.SEND.INFO.HASH NEW.IM.HASH) + (IMNAME.UPDATE.SEND.INFO.NEW.WORDS NIL) + IMNAME.UPDATE.SEND.INFO.FILENAME) + (DECLARE (SPECVARS UPDATE.SEND.INFO.HASH UPDATE.SEND.INFO.FILENAME)) + + (* the single file ERRFILE is used to save error messages from all invokations of IMTRAN. UPDATE.SEND.INFO.HASH and  + UPDATE.SEND.INFO.FILENAME are SPECVARS used to communicate with the special version of SEND.INFO which puts index  + info in the in-core hash array) + + + (for FILE in REDO.IM.FILE.NAMES bind COMPLETE.FILE.NAME + do (SETQ COMPLETE.FILE.NAME (FINDFILE FILE T)) + (if (NULL COMPLETE.FILE.NAME) + then (SHOULDNT "Could find file before, but not now")) + (IM.WARNING "Retranslating file: " COMPLETE.FILE.NAME) + (push NEW.IM.FILE.NAMES FILE) + [push NEW.IM.FILE.INFO (CONS FILE (GETFILEINFO FILE (QUOTE + CREATIONDATE] + (* UPDATE.SEND.INFO.FILENAME is the file name in a  + standard format ) + (SETQ IMNAME.UPDATE.SEND.INFO.FILENAME FILE) + (PROG ((GLOBAL.CHAPTER.NUMBER 0) + (IM.NOTE.FLG NIL) + (IM.REF.FLG NIL) + (IM.INDEX.FILE.FLG T)) + (DECLARE (SPECVARS GLOBAL.CHAPTER.NUMBER IM.NOTE.FLG IM.REF.FLG + IM.INDEX.FILE.FLG)) + (IMTRAN COMPLETE.FILE.NAME))) + (* set new word list to all words collected while  + reanalyzing files) + (SETQ NEW.IM.NAME.LIST IMNAME.UPDATE.SEND.INFO.NEW.WORDS))) + (SETQ NEW.IM.NAME.LIST (UNION NEW.IM.NAME.LIST OLD.IM.NAME.LIST)) + [SETQ NEW.HASHFILE (CREATEHASHFILE NEW.HASHFILE.NAME NIL NIL (TIMES 1.3 (LENGTH + NEW.IM.NAME.LIST] + (for NAM in NEW.IM.NAME.LIST bind NEW.REFS (FLUSH.IM.NAMES _ NIL) + do (if (SETQ NEW.REFS (IMNAME.UPDATE.REFS (if OLD.HASHFILE + then (GETHASHFILE NAM OLD.HASHFILE) + else NIL) + (GETHASH NAM NEW.IM.HASH) + FLUSH.FILES)) + then (PUTHASHFILE NAM NEW.REFS NEW.HASHFILE) + else (push FLUSH.IM.NAMES NAM)) + finally (SETQ NEW.IM.NAME.LIST (LDIFFERENCE NEW.IM.NAME.LIST FLUSH.IM.NAMES))) + (PUTHASHFILE (QUOTE namelist) + NEW.IM.NAME.LIST NEW.HASHFILE) + (PUTHASHFILE (QUOTE fileinfo) + NEW.IM.FILE.INFO NEW.HASHFILE) + (if OLD.HASHFILE + then (CLOSEHASHFILE OLD.HASHFILE)) + (CLOSEHASHFILE NEW.HASHFILE) + (if (OPENP ERRFILE) + then (IM.WARNING "IMTRAN Error File: " (FULLNAME ERRFILE)) + (CLOSEF ERRFILE)) + (RETURN NEW.HASHFILE.NAME]) + +(IMNAME.UPDATE.REF#TOPROG + [LAMBDA NIL (* mjs "30-Sep-85 13:01") + (PROG (FILEPTR SAV REF.STRING TYPE ARGS TEMP NAME TYPE.AS.STRING INFO.WORD NEW.HASH.INFO) + (SETQ FILEPTR (GETFILEPTR IM.INFILE)) + (SETQ SAV (SAVE.ARG)) + (SETQ TEMP (PARSE.INDEX.SPEC SAV NIL)) + (if (OR (NULL TEMP) + (NULL (CAR TEMP))) + then (IM.WARNING "null index --- ignored") + (RETURN)) + (SETQ ARGS (CAR TEMP)) + [SETQ TYPE (if (EQ TO.NAME (QUOTE FIGUREREF)) + then (* for FIGUREREF, ignore specified type --- use TAG) + (QUOTE TAG) + else (U-CASE (CDR TEMP] + [SETQ TYPE.AS.STRING (if (NLISTP TYPE) + then (MKSTRING (L-CASE TYPE T)) + else (LIST.TO.STRING (L-CASE TYPE T] + [SETQ NAME (U-CASE (MKATOM (LIST.TO.STRING ARGS] + (SETQ INFO.WORD (L-CASE TO.NAME T)) + (SETQ NEW.HASH.INFO (GETHASH NAME IMNAME.UPDATE.SEND.INFO.HASH)) + (if (NULL NEW.HASH.INFO) + then (push IMNAME.UPDATE.SEND.INFO.NEW.WORDS NAME)) + (PUTHASH NAME (CONS (LIST TYPE.AS.STRING (LIST IMNAME.UPDATE.SEND.INFO.FILENAME INFO.WORD + FILEPTR)) + NEW.HASH.INFO) + IMNAME.UPDATE.SEND.INFO.HASH]) + +(IMNAME.UPDATE.REFS + [LAMBDA (OLD.REFS NEW.REFS FLUSH.FILES) (* mjs "15-Jan-84 17:18") + (* merge the refs in OLD.REFS with the refs in NEW.REFS, + flushing any references to files on FLUSH.FILES) + (PROG [(NEW.REF NIL) + (TYPES (for X in OLD.REFS collect (CAR X] + (for X in NEW.REFS unless (MEMBER (CAR X) + TYPES) + do (push TYPES (CAR X))) + + (* * now, TYPES contains a list of all of the types in both the old and new refs) + + + [for TYPE in TYPES bind OLD.FILEREFS NEW.FILEREFS + do (* first, collect file refs from OLD.REFS, flushing  + files on FLUSH.FILES) + (SETQ OLD.FILEREFS (for X in (CDR (SASSOC TYPE OLD.REFS)) unless (MEMB (CAR X) + FLUSH.FILES) + collect X)) (* next, collect all file refs in NEW.REFS for this  + type. Note that each ref in NEW.REFS contains exactly  + one file ref) + (* implicite assumption: the files in OLD.REFS and  + NEW.REFS are completely disjoint) + (SETQ NEW.FILEREFS (for X in NEW.REFS when (EQUAL TYPE (CAR X)) collect (CADR X))) + [SETQ NEW.FILEREFS (for FILEREFS in (PARTITION.LIST NEW.FILEREFS NIL + (FUNCTION CAR)) + collect (* FILEREFS is a list of the filerefs for a single file) + (* sort FILEREFS by file pointers) + [SORT FILEREFS (FUNCTION (LAMBDA (A B) + (ILESSP (CADDR A) + (CADDR B] + (* put all of the file refs in one list, headed by the  + file name) + (CONS (CAAR FILEREFS) + (for X in FILEREFS join (CDR X] + (SETQ NEW.FILEREFS (SORT (NCONC NEW.FILEREFS OLD.FILEREFS) + T)) + (if NEW.FILEREFS + then (SETQ NEW.REF (CONS (CONS TYPE NEW.FILEREFS) + NEW.REF] (* finally, sort all of the references by type) + (RETURN (SORT NEW.REF T]) + +(IMNAME.UPDATE.SEND.INFO + [LAMBDA (NAME TYPE SAV INFO PLIST) (* mjs "14-Jul-86 14:42") + + (* * substitute version of SEND.INFO that puts index info into IMNAME.UPDATE.SEND.INFO.HASH instead of spitting out + an index object.) + + + (PROG ((FILEPTR (GETFILEPTR IM.INFILE)) + (INFO.WORD (if (MEMB (QUOTE *PRIMARY*) + INFO) + then (QUOTE Primary) + elseif (MEMB (QUOTE *DEF*) + INFO) + then (QUOTE Definition) + else NIL)) + [TYPE.AS.STRING (if (NLISTP TYPE) + then (MKSTRING (L-CASE TYPE T)) + else (LIST.TO.STRING (L-CASE TYPE T] + (NEW.HASH.INFO (GETHASH NAME IMNAME.UPDATE.SEND.INFO.HASH))) + + (* * pack index subentries and subsubentries) + + + (if (LISTGET PLIST (QUOTE SUBNAME)) + then (if (LISTGET PLIST (QUOTE SUBSUBNAME)) + then (SETQ INFO.WORD (PACK* " -> " (LISTGET PLIST (QUOTE + SUBSUBNAME)) + "/" + (LISTGET PLIST (QUOTE SUBSUBTYPE)) + "/" INFO.WORD))) + (SETQ INFO.WORD (PACK* "sub -> " (LISTGET PLIST (QUOTE SUBNAME)) + "/" + (LISTGET PLIST (QUOTE SUBTYPE)) + "/" INFO.WORD))) + (if (MEMB (QUOTE *BEGIN*) + INFO) + then (SETQ INFO.WORD (PACK* INFO.WORD "/begin"))) + (if (MEMB (QUOTE *END*) + INFO) + then (SETQ INFO.WORD (PACK* INFO.WORD "/end"))) + (if (NULL NEW.HASH.INFO) + then (push IMNAME.UPDATE.SEND.INFO.NEW.WORDS NAME)) + (PUTHASH NAME (CONS (LIST TYPE.AS.STRING (LIST IMNAME.UPDATE.SEND.INFO.FILENAME + INFO.WORD FILEPTR)) + NEW.HASH.INFO) + IMNAME.UPDATE.SEND.INFO.HASH]) + +(INSPECT.IM + [LAMBDA (NAM HASHFILE.NAME) (* mjs "27-OCT-83 18:54") + (PROG (REFS HASHFILE.PTR HASHFILE.DEFAULT.DIRECTORY TYP FILE.POS.PTR) + (SETQ HASHFILE.PTR (OPEN.IM.NAME.HASHFILE HASHFILE.NAME)) + (if (NULL HASHFILE.PTR) + then (RETURN)) + [SETQ HASHFILE.DEFAULT.DIRECTORY (PACKFILENAME (QUOTE HOST) + (FILENAMEFIELD (HASHFILENAME HASHFILE.PTR) + (QUOTE HOST)) + (QUOTE DIRECTORY) + (FILENAMEFIELD (HASHFILENAME HASHFILE.PTR) + (QUOTE DIRECTORY] + (SETQ REFS (GETHASHFILE (U-CASE NAM) + HASHFILE.PTR)) + (CLOSEHASHFILE HASHFILE.PTR) + (if (NULL REFS) + then (CLRPROMPT) + (PROMPTPRINT (CONCAT NAM " has no references")) + (RETURN)) + (REDISPLAY.IM.TYPE.MENU NIL (LIST NAM HASHFILE.DEFAULT.DIRECTORY REFS]) + +(MAKE.IM.INSPECTOR + [LAMBDA (HASHFILE.NAME MENU.REGION) (* mjs "24-Jul-85 16:55") + (PROG (HASHFILE.PTR HASHFILE.WINDOW.STRING HASHFILE.DEFAULT.DIRECTORY WINDOW MENU) + (SETQ HASHFILE.PTR (OPEN.IM.NAME.HASHFILE HASHFILE.NAME)) + (if (NULL HASHFILE.PTR) + then (RETURN)) + [SETQ HASHFILE.WINDOW.STRING (U-CASE (FILENAMEFIELD (HASHFILENAME HASHFILE.PTR) + (QUOTE NAME] + [SETQ HASHFILE.DEFAULT.DIRECTORY (PACKFILENAME (QUOTE HOST) + (FILENAMEFIELD (HASHFILENAME HASHFILE.PTR) + (QUOTE HOST)) + (QUOTE DIRECTORY) + (FILENAMEFIELD (HASHFILENAME HASHFILE.PTR) + (QUOTE DIRECTORY] + (SETQ WINDOW (CREATEW (if MENU.REGION + else (GETBOXREGION 106 37 NIL NIL NIL (CONCAT + "Please position the IM Name Inspector Window for " + + HASHFILE.WINDOW.STRING))) + NIL 0)) + (WINDOWPROP WINDOW (QUOTE UNDER.MENU) + NIL) + (WINDOWPROP WINDOW (QUOTE IM.NAME.ASSOC) + NIL) + (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE) + HASHFILE.PTR) + (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE.WINDOW.STRING) + HASHFILE.WINDOW.STRING) + (WINDOWPROP WINDOW (QUOTE IM.NAME.DEFAULT.DIRECTORY) + HASHFILE.DEFAULT.DIRECTORY) + [WINDOWADDPROP WINDOW (QUOTE CLOSEFN) + (FUNCTION (LAMBDA (WINDOW) + (CLOSEHASHFILE (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE] + (WINDOWADDPROP WINDOW (QUOTE CLOSEFN) + (FUNCTION DELETE.UNDER.MENUS)) + (WINDOWADDPROP WINDOW (QUOTE MOVEFN) + (FUNCTION MOVE.UNDER.MENUS)) + (SETQ MENU (create MENU)) + (ADDMENU MENU WINDOW) + (REDISPLAY.IM.NAME.MENU MENU]) + +(MOVE.UNDER.MENUS + [LAMBDA (TOP.MENU.OR.WINDOW NEW.POS) (* mjs "28-OCT-83 13:21") + (PROG (TOP.WINDOW UNDER.MENU UNDER.WINDOW UNDER.WINDOW.NEW.POS) + (COND + ([AND (SETQ TOP.WINDOW (if (WINDOWP TOP.MENU.OR.WINDOW) + else (WFROMMENU TOP.MENU.OR.WINDOW))) + (SETQ UNDER.MENU (WINDOWPROP TOP.WINDOW (QUOTE UNDER.MENU] + (SETQ UNDER.WINDOW (WFROMMENU UNDER.MENU)) + [SETQ UNDER.WINDOW.NEW.POS (create POSITION + XCOORD _(fetch (POSITION XCOORD) of NEW.POS) + YCOORD _(IDIFFERENCE (fetch (POSITION YCOORD) + of NEW.POS) + (fetch (REGION HEIGHT) + of (WINDOWPROP UNDER.WINDOW + (QUOTE REGION] + (MOVEW UNDER.WINDOW UNDER.WINDOW.NEW.POS]) + +(OPEN.IM.NAME.HASHFILE + [LAMBDA (HASHFILE.NAME) (* edited: "11-Jul-84 14:51") + (PROG ([DEFAULT.HASHFILE.NAME (if IM.NAME.DEFAULT.HASHFILE + elseif (EQ (FILENAMEFIELD LOGINHOST/DIR (QUOTE HOST)) + (QUOTE IVY)) + then (CDR (ASSOC (QUOTE LOOPS) + IM.NAME.HASHFILE.ABBREVS)) + else (CDR (ASSOC (QUOTE INTERLISP) + IM.NAME.HASHFILE.ABBREVS] + (ABBREV.HASHFILE.NAME (CDR (ASSOC HASHFILE.NAME IM.NAME.HASHFILE.ABBREVS))) + FULL.HASHFILE.NAME) + [SETQ FULL.HASHFILE.NAME (if ABBREV.HASHFILE.NAME + elseif (NULL HASHFILE.NAME) + then (INFILEP DEFAULT.HASHFILE.NAME) + elseif (FINDFILE HASHFILE.NAME T) + elseif (FINDFILE (PACKFILENAME (QUOTE BODY) + HASHFILE.NAME + (QUOTE EXTENSION) + (FILENAMEFIELD + DEFAULT.HASHFILE.NAME + (QUOTE EXTENSION))) + T) + else (INFILEP (PACKFILENAME (QUOTE BODY) + HASHFILE.NAME + (QUOTE BODY) + DEFAULT.HASHFILE.NAME] + (if FULL.HASHFILE.NAME + then (printout T "opening data base file " FULL.HASHFILE.NAME T) + (RETURN (OPENHASHFILE FULL.HASHFILE.NAME (QUOTE INPUT))) + else (printout T "data base file " HASHFILE.NAME " not found" T) + (RETURN NIL]) + +(REDISPLAY.IM.NAME.MENU + [LAMBDA (OLDMENU) (* mjs " 6-Aug-85 14:10") + (* updates IM name menu OLDMENU.) + (PROG ((WINDOW (WFROMMENU OLDMENU)) + NAME.ASSOC HASHFILE.PTR HASHFILE.WINDOW.STRING HASHFILE.DEFAULT.DIRECTORY MENU) + (SETQ NAME.ASSOC (WINDOWPROP WINDOW (QUOTE IM.NAME.ASSOC))) + (SETQ HASHFILE.PTR (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE))) + (SETQ HASHFILE.WINDOW.STRING (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE.WINDOW.STRING))) + (SETQ HASHFILE.DEFAULT.DIRECTORY (WINDOWPROP WINDOW (QUOTE IM.NAME.DEFAULT.DIRECTORY))) + [SETQ MENU + (create MENU + ITEMS _[PROG [(MENU.ITEMS (for X in NAME.ASSOC as C from 1 to IM.NAME.MAX.DISPLAY + collect (LIST (CAR X) + (CAR X) + "Reselect an old IM name"] + (RETURN (CONS HASHFILE.WINDOW.STRING (CONS (QUOTE (Type% an% IM% name + + Type% an% IM% name + "The user is prompted to type in a new IM name")) + MENU.ITEMS] + TITLE _ "IM Name Inspector" + MENUBORDERSIZE _ 1 + WHENSELECTEDFN _(FUNCTION (LAMBDA (ITEM MENU MOUSEKEY) + (if (LISTP ITEM) + then (SELECT.IM.MENU.ITEM + (if (EQ (CADR ITEM) + (QUOTE Type% an% IM% name)) + then (CLRPROMPT) + [MKATOM (U-CASE (PROMPTFORWORD "Type an IM name: " NIL + "Type a name to be looked up in the Interlisp Manual Index" + PROMPTWINDOW NIL NIL + (CHARCODE (EOL ESCAPE LF] + else (CADR ITEM)) + MENU] + (DELETE.UNDER.MENUS OLDMENU) + (DELETEMENU OLDMENU NIL WINDOW) + (SHAPEW WINDOW (CREATEREGION (fetch (REGION LEFT) of (WINDOWPROP WINDOW (QUOTE REGION))) + (fetch (REGION BOTTOM) of (WINDOWPROP WINDOW (QUOTE REGION))) + (fetch (MENU IMAGEWIDTH) of MENU) + (fetch (MENU IMAGEHEIGHT) of MENU))) + (ADDMENU MENU WINDOW) + (SHADEITEM HASHFILE.WINDOW.STRING MENU BLACKSHADE WINDOW) + (RETURN MENU]) + +(REDISPLAY.IM.REF.MENU + [LAMBDA (NAME.OR.TYPE.MENU TYPE.NAME.DIR.REFS) (* mjs "28-OCT-83 11:42") + (* TYPE.NAME.DIR.REFS is a list of ) + (PROG ((SELECTED.TYPE (CAR TYPE.NAME.DIR.REFS)) + (SELECTED.NAME (CADR TYPE.NAME.DIR.REFS)) + (DEFAULT.DIR (CADDR TYPE.NAME.DIR.REFS)) + (REFS (CADDDR TYPE.NAME.DIR.REFS))) + (DISPLAY.UNDER.MENU NAME.OR.TYPE.MENU + (create MENU + ITEMS _[for PTRS.TO.ONE.FILE in (CDR (ASSOC SELECTED.TYPE REFS)) + join (CONS (LIST (CONCAT "from: " (CAR + PTRS.TO.ONE.FILE)) + (CONS (PACKFILENAME (QUOTE BODY) + (CAR + PTRS.TO.ONE.FILE) + (QUOTE BODY) + DEFAULT.DIR) + NIL) + + "creates/finds TEDIT window into the file") + (for PTR on (CDR PTRS.TO.ONE.FILE) + by (CDDR PTR) + collect + (LIST (CONCAT (if (CAR PTR) + else "index") + " (" + (CADR PTR) + ")") + (CONS (PACKFILENAME + (QUOTE BODY) + (CAR PTRS.TO.ONE.FILE) + (QUOTE BODY) + DEFAULT.DIR) + (CADR PTR)) + + "creates/finds TEDIT window into the file, and positions the cursor at the selected reference"] + TITLE _(CONCAT "Refs for " SELECTED.NAME " (type " + SELECTED.TYPE ")") + MENUBORDERSIZE _ 1 + WHENSELECTEDFN _(FUNCTION (LAMBDA (ITEM MENU MOUSEKEY) + (if (NLISTP ITEM) + then NIL + else (TEDIT.IM.FILE (CAR (CADR ITEM)) + (CDR (CADR ITEM]) + +(REDISPLAY.IM.TYPE.MENU + [LAMBDA (NAME.MENU NAME.DIR.REFS) (* mjs "27-OCT-83 17:04") + (* NAME.DIR.REFS is a list of ) + (PROG ((NAME.WINDOW (WFROMMENU NAME.MENU)) + (SELECTED.NAME (CAR NAME.DIR.REFS)) + (REFS (CADDR NAME.DIR.REFS))) + (if (EQLENGTH REFS 1) + then (* if only one type, skip type menu) + (REDISPLAY.IM.REF.MENU NAME.MENU (CONS (CAAR REFS) + NAME.DIR.REFS)) + else (DISPLAY.UNDER.MENU NAME.MENU (create MENU + ITEMS _(for X in REFS + collect (LIST (CAR X) + NAME.DIR.REFS + "Select which type you want the references for")) + TITLE _(CONCAT "ref types for '" SELECTED.NAME + "'") + MENUBORDERSIZE _ 1 + WHENSELECTEDFN _(FUNCTION (LAMBDA (ITEM MENU + MOUSEKEY) + (if (NLISTP ITEM) + then NIL + else (REDISPLAY.IM.REF.MENU + MENU + (CONS (CAR ITEM) + (CADR ITEM]) + +(SELECT.IM.MENU.ITEM + [LAMBDA (NAM MENU) (* mjs "24-Jul-85 15:19") + (PROG (NAME.ASSOC WINDOW NAM.DATA REFS HASHFILE.PTR) + (SETQ WINDOW (WFROMMENU MENU)) + (SETQ NAME.ASSOC (WINDOWPROP WINDOW (QUOTE IM.NAME.ASSOC))) + (SETQ HASHFILE.PTR (WINDOWPROP WINDOW (QUOTE IM.NAME.HASHFILE))) + (if (EQ NAM (CAR (CAR NAME.ASSOC))) + then (* selected first item, so don't need to do any  + updating) + (RETURN)) + (SETQ NAM.DATA (ASSOC NAM NAME.ASSOC)) + (if NAM.DATA + then (SETQ REFS (CDR NAM.DATA)) + (SETQ NAME.ASSOC (CONS NAM.DATA (REMOVE NAM.DATA NAME.ASSOC))) + else (SETQ REFS (GETHASHFILE (U-CASE NAM) + HASHFILE.PTR)) + (if REFS + then (SETQ NAME.ASSOC (CONS (CONS NAM REFS) + NAME.ASSOC)) + else (CLRPROMPT) + (PROMPTPRINT (CONCAT NAM " has no references")) + (RETURN))) + (WINDOWPROP WINDOW (QUOTE IM.NAME.ASSOC) + NAME.ASSOC) + (SETQ MENU (REDISPLAY.IM.NAME.MENU MENU)) + (REDISPLAY.IM.TYPE.MENU MENU (LIST NAM (WINDOWPROP WINDOW (QUOTE IM.NAME.DEFAULT.DIRECTORY)) + REFS]) + +(TEDIT.IM.FILE + [LAMBDA (IM.FILE.NAME IM.FILE.PTR) (* mjs "24-Jul-85 15:26") + (PROG [(TEDIT.TEXT.OBJECT NIL) + (NORMAL.FILE.NAME (PACKFILENAME (QUOTE NAME) + (FILENAMEFIELD IM.FILE.NAME (QUOTE NAME)) + (QUOTE EXTENSION) + (FILENAMEFIELD IM.FILE.NAME (QUOTE EXTENSION] + (if (NULL IM.FILE.NAME) + then (RETURN)) + [for X in (OPENWINDOWS) bind POSS.TOBJ POSS.FILENAME when (SETQ POSS.TOBJ + (WINDOWPROP X (QUOTE TEXTOBJ))) + repeatuntil TEDIT.TEXT.OBJECT + do (SETQ POSS.FILENAME (FULLNAME (fetch (TEXTOBJ TXTFILE) of POSS.TOBJ))) + (COND + ([OR (NOT (LITATOM POSS.FILENAME)) + (NEQ (FILENAMEFIELD POSS.FILENAME (QUOTE NAME)) + (FILENAMEFIELD NORMAL.FILE.NAME (QUOTE NAME))) + (NEQ (FILENAMEFIELD POSS.FILENAME (QUOTE EXTENSION)) + (FILENAMEFIELD NORMAL.FILE.NAME (QUOTE EXTENSION] + (SETQ TEDIT.TEXT.OBJECT NIL)) + (T (SETQ TEDIT.TEXT.OBJECT POSS.TOBJ] + (if TEDIT.TEXT.OBJECT + then (if IM.FILE.PTR + then (TEDIT.SETSEL TEDIT.TEXT.OBJECT (IMAX 1 (IDIFFERENCE (ADD1 IM.FILE.PTR) + 25)) + 0 + (QUOTE LEFT)) + (TEDIT.NORMALIZECARET TEDIT.TEXT.OBJECT) + (TEDIT.SETSEL TEDIT.TEXT.OBJECT (ADD1 IM.FILE.PTR) + 0 + (QUOTE LEFT)) + (TEDIT.NORMALIZECARET TEDIT.TEXT.OBJECT)) + (TTY.PROCESS (WINDOWPROP (CAR (fetch (TEXTOBJ \WINDOW) of TEDIT.TEXT.OBJECT)) + (QUOTE PROCESS))) + else (PROG [(FULL.FILE.NAME (if (FINDFILE NORMAL.FILE.NAME T) + else (INFILEP IM.FILE.NAME] + (if (NULL FULL.FILE.NAME) + then (CLRPROMPT) + (printout PROMPTWINDOW NORMAL.FILE.NAME " not found" T) + (RETURN)) + (CLRPROMPT) + (printout PROMPTWINDOW "Please specify a TEDIT window for " FULL.FILE.NAME T) + (TEDIT FULL.FILE.NAME NIL NIL (if IM.FILE.PTR + then (LIST (QUOTE SEL) + (ADD1 IM.FILE.PTR)) + else NIL]) +) + +(RPAQ? IM.NAME.MAX.DISPLAY 5) + +(RPAQ? IM.NAME.DEFAULT.HASHFILE NIL) + +(RPAQ? IM.NAME.HASHFILE.ABBREVS (QUOTE ((INTERLISP . {ERINYES}INTERLISP.IMNAMEHASH) + (LOOPS . {INDIGO}MANUAL>LOOPS.IMNAMEHASH)))) +(FILESLOAD HASH) +(DECLARE: EVAL@COMPILE +[PUTPROPS IMNAME.RESETSAVE.MOVD MACRO (X (BQUOTE (RESETSAVE (MOVD , (CAR X) + , + (CADR X) + , + (CADDR X)) + (LIST (QUOTE [LAMBDA (FN DEF) + (PUTD FN DEF]) + , + (CADR X) + (GETD , (CADR X] +) +(PUTPROPS IMNAME COPYRIGHT ("Xerox Corporation" 1983 1984 1985 1986)) +(DECLARE: DONTCOPY + (FILEMAP (NIL (1013 35919 (DELETE.UNDER.MENUS 1023 . 1595) (DISPLAY.UNDER.MENU 1597 . 2782) ( +GET.IM.NAME.LIST 2784 . 3218) (IMNAME 3220 . 3365) (IMNAME.UPDATE.HASHFILE 3367 . 16148) ( +IMNAME.UPDATE.REF#TOPROG 16150 . 17634) (IMNAME.UPDATE.REFS 17636 . 19950) (IMNAME.UPDATE.SEND.INFO +19952 . 21829) (INSPECT.IM 21831 . 22714) (MAKE.IM.INSPECTOR 22716 . 24663) (MOVE.UNDER.MENUS 24665 . +25447) (OPEN.IM.NAME.HASHFILE 25449 . 26834) (REDISPLAY.IM.NAME.MENU 26836 . 29208) ( +REDISPLAY.IM.REF.MENU 29210 . 31019) (REDISPLAY.IM.TYPE.MENU 31021 . 32234) (SELECT.IM.MENU.ITEM 32236 + . 33632) (TEDIT.IM.FILE 33634 . 35917))))) +STOP diff --git a/docs/Documentation Tools/IMNAME.LCOM b/docs/Documentation Tools/IMNAME.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..3a20b04b70aaafe3bc3b1573be993a2296eca483 GIT binary patch literal 18557 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

c6*d_&a4Ih z@)ww0-Asd1%@I^zbe1F;+>?eqSl+1cZ+J`x*PFYY&xys(?w!sq-o5Tn?oSH%9zLS< Pf%gSc$vAqUe9!*_BOJcG literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/IMNAME.TEDIT b/docs/Documentation Tools/IMNAME.TEDIT new file mode 100644 index 00000000..2fa7cb58 --- /dev/null +++ b/docs/Documentation Tools/IMNAME.TEDIT @@ -0,0 +1 @@ + author: Michael Sannella file: {Phylum}IMNAME. (& .DCOM) loads file: {Phylum}HASH.DCOM loads file: {Phylum}IMTRAN.DCOM [loaded by IMNAME.UPDATE.HASHFILE] ****** The IMNAME Database Package ***** IM format is the text formatting language that the Interlisp Reference Manual is represented in. It is somewhat like TEX source code, in that there are keywords, and brackets are used to delimit text. However, IM format was specifically designed for representing the Interlisp Manual, so the "text objects" used are semantically meaningful objects within the manual, such as "function definition", "lisp code", "subsection". IMNAME is a package designed to help people who may frequently need to modify IM format files. Usually, a large document (such as the Interlisp Manual) is stored in a number of seperate files, and it is difficult to know which file contains a particular piece of information. IMNAME contains functions for analyzing a set of IM format files and building a database of "IM Names" (functions, variables, property names, etc) with pointers to the files where they are defined. Using this database, other functions allow the user to specify an IM name, and bring up a Tedit window on the appropriate file, with the cursor positioned at the right place. This tool has been very helpful to the people updating the Interlisp Reference Manual. ****** Using IMNAME to access IM format files. ***** The normal way of using an IMNAME database is by creating an "IM name inspector". This can be done using either of the following two functions: (MAKE.IM.INSPECTOR hashFileName) or (IMNAME hashFileName) hashFileName should be the name of the IMNAME database hashfile to use for this inspector. One can create multiple IM name inspectors point to the same hashfile, or to different hashfiles. Currently, I know of only two IMNAME hashfiles; the one for the Interlisp Manual and one for the Loops Manual. If hashFileName is the atom INTERLISP or LOOPS, this Inspector will point to the appropriate hashfile. If hashFileName is ommitted, it will assume that the Interlisp Manual hashfile is desired for people whose default host is Phylum, and the Loops Manual for people on Ivy. (Other people can set up their own default IMNAME hashfile by setting the global variable IM.NAME.DEFAULT.HASHFILE). MAKE.IM.INSPECTOR sets up an "IM Inspector Window", which contains a menu. Initially, this contains the single selection "Type an IM name", which (when buttoned) prompts the user to type a name which will be looked up in the database. If an IM name is found in the hashfile, another window will appear below the first one, containing all of the "types" that the given name is known by. For example, a name may be known as both a variable and a function. If one of these types is selected, a third menu will apear below the second, listing references to the name in different files. Selecting one of the references will move the cursor in a TEDIT window (if there exists an active TEDIT window to the appropriate file), or create a new TEDIT window to the file. [Note: If a name is only known to be of one type, the "type menu" step is ommitted.] Other functions: (INSPECT.IM imname hashFileName) This allows the searching for a single IM name, using several pop-up menus. In general, it is easier to use the IM name inspector. (GET.IM.NAME.LIST hashFileName) Returns a list of all of the IM names known within the specified hashFileName. ****** Updating an IMNAME database. ***** IMNAME works by referencing a hashfile database containing IM names and pointers to files where these names are referenced. As a set of files is modified, this information will become obsolete. In particular, simply adding a few characters to a file will invalidate all pointers to positons later in the file. This can be tolorated for awhile (it is rare that IM format files will be changed enough such that the pointers are totally off), but eventually, it is necessary to update the IMNAME database, using the following function: (IMNAME.UPDATE.HASHFILE oldHashFileName addFileList deleteFileList flushDisappearedFlg ) This function updates an IMNAME database hashfile. First, it looks at the list of files referenced in the hashfile, and determines which of these files have been updated, by comparing version numbers. Next, every updated file is reanalyzed with IMTRAN, and updated index information is stored into an in-core hasharray. Finally, the entries in the old hashfile are read in, merged with the new info, and written out to a new hashfile. oldHashFileName is the name of the hashfile to be updated (Note that this file must be named explicitly --- no file searches are done so that the user will not inadvertantly start updating the main manual database). The new hashfile will be created as the new version of the same file name. addFileList is a list of files that will be analyzed, and added to the database. deleteFileList is a list of files that will be deleted from the database. addFileList and deleteFileList can be used to "manage" a database, as new files are added to a document, and old ones are removed, split up,or renamed. flushDisappearedFlg determines what IMNAME.UPDATE.HASHFILE will do if it finds that some of the files in the database have disappeared (and they are not named on deleteFileList). If flushDisappearedFlg = T, the info for those files will simply be deleted. If flushDisappearedFlg = ERROR, IMNAME.UPDATE.HASHFILE will return without doing anything if files have disappeared. If flushDisappearedFlg = , the info on the disappeared files will simply be retained. To create a new IMNAME hashfile, pass a non-existant file name as oldHashFileName, and give a list of files as addFileList. In this case, a new hashfile will be created just from the internal hasharray info. \ No newline at end of file diff --git a/docs/Documentation Tools/IMTEDIT b/docs/Documentation Tools/IMTEDIT new file mode 100644 index 00000000..e5cb3416 --- /dev/null +++ b/docs/Documentation Tools/IMTEDIT @@ -0,0 +1,2434 @@ +(DEFINE-FILE-INFO READTABLE "INTERLISP" PACKAGE "INTERLISP") +(FILECREATED " 8-Dec-91 15:41:54" {DSK}sybalsky>PUBS>IMTEDIT.;2 116642 + + changes to%: (FNS TRANSLATE.DUMPOUT DUMP DUMP.HEADERS.FOOTERS DUMP.HRULE CHANGE.FONT + IM.BOUT.IMAGEOBJ IM.TEDIT.DUMP.COMMANDS IM.TEDIT.DUMP.FOOTNOTES + MAKE.IM.DOCUMENT PRINT.VRULES.ON.PAGE CREATE.FOLIO.OBJECT GET.FOLIO.STRING) + + previous date%: " 4-Aug-86 11:53:22" {DSK}sybalsky>PUBS>IMTEDIT.;1) + + +(* ; " +Copyright (c) 1983, 1984, 1985, 1986, 1991 by Xerox Corporation. All rights reserved. +") + +(PRETTYCOMPRINT IMTEDITCOMS) + +(RPAQQ IMTEDITCOMS + ((FNS IM.TEDIT DUMP DUMP.HEADERS.FOOTERS DUMP.HRULE CHANGE.FONT IM.BOUT.IMAGEOBJ + IM.TEDIT.DUMP.COMMANDS IM.TEDIT.DUMP.FOOTNOTES IM.TEDIT.DUMP.PARA INDEXX.PARSE.TYPE + FORMAT.DEF FORMAT.LISPWORD MAKE.IM.DOCUMENT PRINT.NOTE SEND.INFO) + (COMS (* fns for drawing vrules to the left of definition text -- an unused, never-fully + debuged feature) + (FNS IM.VRULE.DISPLAYFN CREATE.VRULE.OBJECT PRINT.VRULES.ON.PAGE) + (VARS (IM.VRULE.STATE.LIST)) + (INITVARS (IM.VRULE.OBJECT.IMAGEFNS NIL) + (IM.PRINT.VRULE.FLG NIL))) + (COMS (* fns for printing page numbers) + (FNS IM.FOLIO.DISPLAYFN IM.FOLIO.SIZEFN CREATE.FOLIO.OBJECT GET.FOLIO.STRING) + (INITVARS (IM.FOLIO.OBJECT.IMAGEFNS NIL))) + (COMS (* TOPROG functions, used to define the translating actions of IM text objects.) + (FNS ARG#TOPROG BIGLISPCODE#TOPROG BRACKET#TOPROG CHAPTER#TOPROG COMMENT#TOPROG + DEF#TOPROG FIGURE#TOPROG FN#TOPROG FNDEF#TOPROG FOOT#TOPROG INCLUDE#TOPROG + INDEX#TOPROG INDEXX#TOPROG IT#TOPROG LBRACKET#TOPROG LISP#TOPROG LISPCODE#TOPROG + LISPWORD#TOPROG LIST#TOPROG MACDEF#TOPROG NOTE#TOPROG PRINT.SPECIAL.CHARS#TOPROG + PROPDEF#TOPROG RBRACKET#TOPROG REF#TOPROG RM#TOPROG SUB#TOPROG SUBSEC#TOPROG + SUPER#TOPROG TABLE#TOPROG TAG#TOPROG TERM#TOPROG VAR#TOPROG VARDEF#TOPROG) + (VARS TO.NAME.LIST TO.SYNONYM.LIST) + (IFPROP (TO.PROG TO.ARGS TO.ARG.SYNONYMS TO.TYPE TO.ARG.TYPE) + * TO.NAME.LIST)) + [INITVARS (IM.TEDIT.FONT.DEFS '(NIL (FAMILY MODERN FACE MRR SIZE 10) + FOOTNOTE + (FAMILY MODERN FACE MRR SIZE 10) + NOTE + (FAMILY MODERN FACE MIR SIZE 8) + BOLD + (FAMILY MODERN FACE BRR SIZE 10) + ITALIC + (FAMILY MODERN FACE MIR SIZE 10) + LISP + (FAMILY MODERN FACE BRR SIZE 10) + ARG + (FAMILY MODERN FACE MIR SIZE 10] + [INITVARS (IM.CHAPTER.TITLE.FONT '(FAMILY MODERN FACE BRR SIZE 18)) + (IM.SUBSEC.ONE.TITLE.FONT '(FAMILY MODERN SIZE 14 FACE BRR)) + (IM.SUBSEC.TWO.TITLE.FONT '(FAMILY MODERN SIZE 12 FACE BRR)) + (IM.SUBSEC.THREE.TITLE.FONT '(FAMILY MODERN SIZE 10 FACE BRR)) + (IM.TEXT.FONT '(FAMILY MODERN FACE MRR SIZE 10)) + (IM.HEADER.FOOTER.FONT '(FAMILY MODERN FACE MRR SIZE 8)) + (IM.XEROX.LOGO.FONT '(FAMILY MODERN FACE BRR SIZE 30] + (COMS (* the following variables specify all of the lengths used for possitioning IM text, + headers, etc. on the page. All of these are measured with respect to the page + *margins* or with + respect to the page *edges* .) + (* Note%: The formatting and printing does not always position the image on the page + exactly as specified. It will probably be necessary to adjust any variables based on + the page edges until they come out correctly on your printer.) + (* indentation of 1st line of definitian header, measured in points from left page + margin. Also used for indentation of hrule under defn header.) + (INITVARS (IM.DEF.TITLE.1STLEFTMARGIN 75)) + (* indentation of 2nd and other overflow lines of definition header, measured in points + from left page margin.) + (INITVARS (IM.DEF.TITLE.LEFTMARGIN 204)) + (* indentation of vertical rule to the left of definition text, measured in points from + left page margin. This is a never-used, never-debugged feature.) + (INITVARS (IM.VRULE.X 194)) + (* y-pos of top-left corner of top text line, measured in points from bottom page edge. + ) + (INITVARS (IM.TEXT.TOPMARGIN 738)) + (* y-pos of bottom-left corner of bottom text line, measured in points from bottom page + edge.) + (INITVARS (IM.TEXT.BOTTOMMARGIN 54)) + (* x-pos of left edge of text, measured in points from the left page margin.) + (INITVARS (IM.TEXT.LEFTMARGIN 204)) + (* x-pos of right edge of text, measured in points from the left page margin.) + (INITVARS (IM.TEXT.RIGHTMARGIN 504)) + (* X-pos and Y-pos of the lower-left corner of the + "[This page intentionally left blank]" message printed on blank pages, measured in + points from the left and bottom page edges.) + (INITVARS (IM.BLANKPAGE.SPECIALX 258) + (IM.BLANKPAGE.SPECIALY 400)) + (* In the table of contents, indentation of first and second-level subsection headers, + measured in points from the left page margin.) + (INITVARS (IM.TOC.SUBSEC.ONE.LEFTMARGIN 120) + (IM.TOC.SUBSEC.TWO.LEFTMARGIN 216)) + (* in the index, the indentation of the first line and remaining lines of a top-level + entry, of a subentry, and of a subsubentry, measured in points from the left page + margin .) + (INITVARS (IM.INDEX.1STLEFTMARGIN 0) + (IM.INDEX.LEFTMARGIN 75) + (IM.INDEX.SUB.1STLEFTMARGIN 25) + (IM.INDEX.SUB.LEFTMARGIN 75) + (IM.INDEX.SUBSUB.1STLEFTMARGIN 50) + (IM.INDEX.SUBSUB.LEFTMARGIN 75)) + (* on the title page, the y-pos of the lower-left corner of the first line in the title + , measured in points from the bottom page margin. The X-pos + is always 0 for the XEROX logo, and the normal text indentation for the title.) + (INITVARS (IM.TITLEPAGE.TITLE.Y 258)) + (* on the title page, the y-pos of the lower-left corner of the first line in the + document number, measured in points from the bottom page margin. The Y-pos is always + the normal text indentation.) + (INITVARS (IM.TITLEPAGE.DOCNUMBER.Y 45)) + (* Tedit tab setting used for subsection heading text. "(40 . LEFT)" determines the + indentation of the title after the subsec number, measured in points from the left + page margin. "18" is the tab used if the subsec number is wider than 40 pts.) + [INITVARS (IM.SUBSEC.TITLE.TABS '(18 (40 . LEFT] + (* Tedit tab setting used for chapter titles, headers, and footers to right-justify + text. "(504 . RIGHT)" specifies a right tab at the right-hand edge of the text, + measured in points from the left page margin.) + [INITVARS (IM.RIGHT.MARGIN.TABS '(0 (504 . RIGHT] + (* Tedit tab setting used for labeled lists, numbered lists, bullet-ed lists. + "(186 . RIGHT)" right-justifies the label on the left of the center space. + "(204 . LEFT)" starts the first line of the list item with the same indentation as + normal text. Both measurements are measured in points from the left page margin.) + [INITVARS (IM.LABELED.LIST.TABS '(18 (186 . RIGHT) + (204 . LEFT] + (* left, right, top, and bottom margins of the "page region" %, measured in points from + the four edges of the page.) + (INITVARS (IM.PAGE.LEFTMARGIN 58) + (IM.PAGE.RIGHTMARGIN 54) + (IM.PAGE.TOPMARGIN 54) + (IM.PAGE.BOTTOMMARGIN 54)) + (* top margin of the page region for the first page of a chapter , measured in points from the top page edge.) + (INITVARS (IM.PAGE.FIRST.TOPMARGIN 12)) + (* top margin of the page region for the first page of the index, measured in points + from the top page edge. Note that in the case of the index, because it uses two + columns, the index title is implemented as a Tedit header, instead of as the first + paragraph of the document.) + (INITVARS (IM.INDEX.PAGE.FIRST.TOPMARGIN 144)) + (* y-pos of lower-left corner of footer text, measured in points from the bottom page + edge.) + (INITVARS (IM.FOOTER.Y 22)) + (* y-pos of the footer hrule, measured in points from the bottom page edge.) + (INITVARS (IM.FOOTER.RULE.Y 30)) + (* y-pos of lower-left corner of header text, measured in points from the bottom page + edge.) + (INITVARS (IM.HEADER.Y 761)) + (* y-pos of the header hrule, measured in points from the bottom page edge.) + (INITVARS (IM.HEADER.RULE.Y 757)) + (* y-pos of lower-left corner of bottom draft message, measured in points from the + bottom page edge.) + (INITVARS (IM.DRAFT.MESSAGE.BOTTOM.Y 5)) + (* y-pos of lower-left corner of top draft message, measured in points from the bottom + page edge.) + (INITVARS (IM.DRAFT.MESSAGE.TOP.Y 775)) + (* x-pos of lower-left corner of both top and bottom draft messages, measured in points + from the left page edge.) + (INITVARS (IM.DRAFT.MESSAGE.X 200))) + (FILES TEDIT IMTRAN HRULE IMINDEX) + (FNS TRANSLATE.DUMPOUT TRANSLATE.SAVE.DUMPOUT) + (MACROS IM.HOLD.FOOTNOTES DUMPOUT SAVE.DUMPOUT))) +(DEFINEQ + +(IM.TEDIT + [LAMBDA (INFILE.NAME OUTFILE.FLG) (* mjs " 4-Aug-86 10:53") + + (* * This function takes an IM format file, and produces a formatted Tedit text + stream. Note that the Tedit text stream is a totally different document --- + the user may edit it to clear up formatting problems before printing, but the + user must be careful not to edit this document without going back and changing + the original IM format file. INFILE.NAME is the name of an IM format file.) + + (* * If OUTFILE.FLG is NIL, the output file is just sent to the default + printer. If OUTFILE.FLG is T, the outfile textstream is simply returned. + If OUTFILE.FLG = anything else, it is taken as a file name to put the press + file which is created .) + + (PROG ((ERRFILE.NAME (PACKFILENAME 'NAME (FILENAMEFIELD INFILE.NAME 'NAME) + 'EXTENSION + 'IMERR)) + (PTRFILENAME (PACKFILENAME 'NAME (FILENAMEFIELD INFILE.NAME 'NAME) + 'EXTENSION + 'IMPTR)) + ERRFILE DOC.VAL) + (DECLARE (SPECVARS ERRFILE.NAME ERRFILE)) + (SETQ DOC.VAL (MAKE.IM.DOCUMENT '(IMTRAN INFILE.NAME) + OUTFILE.FLG NIL (CONCAT "IMTEDIT Hardcopy of " INFILE.NAME) + NIL PTRFILENAME)) + (if (OPENP ERRFILE) + then (CLOSEF ERRFILE) + (printout T "Error File: " (FULLNAME ERRFILE) + T)) + (RETURN DOC.VAL]) + +(DUMP + [LAMBDA (C) (* mjs "12-Apr-85 10:41") + + (* * this function dumps the character C into the Tedit stream. + It maps multiple CRs into a single CR, and decides when to put out paragraph + looks. If C is a list, it is treated as a special "Dump Command" which does + things such as changing fonts.) + (* printout T "flg=" IM.TEDIT.CR.FLG + ";C=" (if (AND (LISTP C) + (EQ (CAR C) (QUOTE TEXT))) then + (QUOTE TEXT) elseif + (SMALLP C) then (CONCAT C "/" + (CHARACTER C)) else C) T) + (* handle all CRs as examples of the + Dump Command CR) + (COND + [(EQ C (CHARCODE CR)) + (IM.TEDIT.DUMP.COMMANDS '(CR] + ((ZEROP C) (* flush null chars) + NIL) + ((LISTP C) (* treat lists as Dump Commands) + (IM.TEDIT.DUMP.COMMANDS C)) + [IM.TEDIT.CR.FLG (COND + ((EQ C (CHARCODE SPACE)) (* ignore spaces after a CR) + (NILL)) + ((EQ IM.TEDIT.CR.FLG 'ONE) (* if there was only one CR, put out + a space and the following char) + (BOUT IM.OUTFILE (CHARCODE SPACE)) + (SETQ IM.TEDIT.CR.FLG NIL) + (DUMP C)) + ((EQ IM.TEDIT.CR.FLG 'MANY) (* time to start a new para) + (SETQ IM.TEDIT.CR.FLG NIL) + (DUMP C] + ((SMALLP C) + (BOUT IM.OUTFILE C)) + ((IMAGEOBJP C) + (IM.BOUT.IMAGEOBJ C IM.OUTFILE)) + (T (SHOULDNT]) + +(DUMP.HEADERS.FOOTERS + [LAMBDA (HEADER.TEXT FOOTER.TEXT) (* mjs "18-Sep-85 15:40") + [COND + (HEADER.TEXT (SETQ HEADER.TEXT (U-CASE HEADER.TEXT)) + (DUMPOUT CR CR START.PARA FONT IM.HEADER.FOOTER.FONT PARALOOKS + `(TYPE PAGEHEADING SUBTYPE VERSOHEAD QUAD LEFT 1STLEFTMARGIN 0 LEFTMARGIN 0 + RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN) + DUMP.CHARS HEADER.TEXT CR CR) + (DUMP.HRULE 1 NIL `(TYPE PAGEHEADING SUBTYPE VERSOHEADRULE 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN)) + (DUMPOUT CR CR START.PARA FONT IM.HEADER.FOOTER.FONT PARALOOKS + `(TYPE PAGEHEADING SUBTYPE RECTOHEAD QUAD RIGHT 1STLEFTMARGIN 0 LEFTMARGIN 0 + RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN) + DUMP.CHARS HEADER.TEXT CR CR) + (DUMP.HRULE 1 NIL `(TYPE PAGEHEADING SUBTYPE RECTOHEADRULE 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN] + (COND + (FOOTER.TEXT (SETQ FOOTER.TEXT (U-CASE FOOTER.TEXT)) + (DUMP.HRULE 1 NIL `(TYPE PAGEHEADING SUBTYPE VERSOFOOTRULE 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN)) + (DUMPOUT CR CR START.PARA FONT IM.HEADER.FOOTER.FONT PARALOOKS + `(TYPE PAGEHEADING SUBTYPE VERSOFOOT QUAD LEFT 1STLEFTMARGIN 0 LEFTMARGIN 0 TABS + %, IM.RIGHT.MARGIN.TABS RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN) + DUMP.CHARS + (CREATE.FOLIO.OBJECT) + TAB DUMP.CHARS FOOTER.TEXT CR CR) + (DUMP.HRULE 1 NIL `(TYPE PAGEHEADING SUBTYPE RECTOFOOTRULE 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN)) + (DUMPOUT CR CR START.PARA FONT IM.HEADER.FOOTER.FONT PARALOOKS + `(TYPE PAGEHEADING SUBTYPE RECTOFOOT QUAD LEFT 1STLEFTMARGIN 0 LEFTMARGIN 0 TABS + %, IM.RIGHT.MARGIN.TABS RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN) + DUMP.CHARS FOOTER.TEXT TAB DUMP.CHARS (CREATE.FOLIO.OBJECT) + CR CR]) + +(DUMP.HRULE + [LAMBDA (RULE.WIDTH ADDITIONAL.PARA.LEADING SPECIAL.PARALOOKS) + (* mjs "18-Sep-85 15:25") + + (* * old def, used when CR at end of line caused hrule to be too far down%: + (DUMPOUT FONT (QUOTE (FAMILY MODERN FACE MRR SIZE 10)) PARALOOKS + SPECIAL.PARALOOKS PARALOOKS (LIST (QUOTE PARALEADING) + (IPLUS -10 (if ADDITIONAL.PARA.LEADING else 0)) + (QUOTE LINELEADING) 0) DUMP.CHARS (HRULE.CREATE RULE.WIDTH) CR CR)) + + (DUMPOUT FONT NIL PARALOOKS SPECIAL.PARALOOKS PARALOOKS (LIST 'PARALEADING (COND + ( + ADDITIONAL.PARA.LEADING + ) + (T 0)) + 'LINELEADING 0) + DUMP.CHARS + (HRULE.CREATE RULE.WIDTH) + CR CR]) + +(CHANGE.FONT + [LAMBDA (FONT) (* mjs "11-Apr-85 15:49") + + (* * changes all of the text between the last font change and the current + position to the current font, and changes the current font to FONT. + If the current position is the same as that of the last font change just change the current + font.) + + (PROG ((CURRENT.POS (GETFILEPTR IM.OUTFILE))) + (COND + ((NEQ IM.TEDIT.LAST.FONT.BEGIN CURRENT.POS) + (push IM.CHARLOOKS (COND + ((LISTGET IM.TEDIT.FONT.DEFS IM.TEDIT.FONT)) + (T IM.TEDIT.FONT)) + IM.TEDIT.LAST.FONT.BEGIN + (IDIFFERENCE CURRENT.POS IM.TEDIT.LAST.FONT.BEGIN)) + (* be sure to reset Tedit selection + after any formatting operation) + (SETQ IM.TEDIT.LAST.FONT.BEGIN CURRENT.POS))) + (SETQ IM.TEDIT.FONT FONT]) + +(IM.BOUT.IMAGEOBJ + [LAMBDA (OBJ FILE) (* mjs "11-Apr-85 12:09") + (COND + ((NOT (IMAGEOBJP OBJ)) + (SHOULDNT)) + (T (PROG [(CURR.CH# (ADD1 (GETFILEPTR FILE] + (TEDIT.INSERT.OBJECT OBJ FILE CURR.CH#) + (SETFILEPTR FILE CURR.CH#]) + +(IM.TEDIT.DUMP.COMMANDS + [LAMBDA (C) (* mjs " 1-Oct-85 15:14") + + (* * this function interpretes Dump Commands to IM.TEDIT.DUMP, which are always + lists whose CAR is the command name.) + + (SELECTQ (CAR C) + (TEXT (* just flush TEX output string) + NIL) + (START.PARA + + (* by setting IM.TEDIT.CR.FLG to NIL, this ensures that any following spaces + will not be swollowed because they follow a CR. + Warning%: this should only be called after a paragraph is totally ended and + finished.) + + (COND + ((NEQ IM.TEDIT.CR.FLG 'MANY) + (IM.ERROR + "START.PARA command should only be called after end of paragraph. Is called when IM.TEDIT.CR.FLG =" + IM.TEDIT.CR.FLG))) + (SETQ IM.TEDIT.CR.FLG NIL)) + (DUMP.FOOTNOTES (* dump out any footnotes without + starting new paragraph <>) + (IM.TEDIT.DUMP.FOOTNOTES)) + ((START.SUPER START.SUB) + (SETQ IM.TEDIT.SUB.SUPER.BEGIN (GETFILEPTR IM.OUTFILE))) + ((END.SUPER END.SUB) + + (* this is a very simple scheme --- currently, it does not allow nested super- + or subscripts.) + + (PROG ((CURRENT.POS (GETFILEPTR IM.OUTFILE))) + (push IM.CHARLOOKS (if (EQ (CAR C) + 'END.SUPER) + then '(SUPERSCRIPT 3) + else '(SUBSCRIPT 3)) + IM.TEDIT.SUB.SUPER.BEGIN + (IDIFFERENCE CURRENT.POS IM.TEDIT.SUB.SUPER.BEGIN)))) + (PARALOOKS (* add para looks to list for next + para) + (push IM.TEDIT.PARA.LOOKS (CDR C))) + (CR + + (* if we have recieved at least one CR before, set IM.TEDIT.CR.FLG = MANY, + otherwise this is the first CR) + + [COND + ((EQ IM.TEDIT.CR.FLG 'ONE) + (IM.TEDIT.DUMP.PARA)) + ((EQ IM.TEDIT.CR.FLG NIL) + (SETQ IM.TEDIT.CR.FLG 'ONE]) + (TAB (DUMP (CHARCODE TAB))) + (FONT (CHANGE.FONT (CDR C)) + (push FONT.STACK (CDR C))) + (INDENT (IM.ERROR "INDENT command encountered -- should be flushed")) + (UNDO (SELECTQ (CDR C) + (FONT (SETQ FONT.STACK (CDR FONT.STACK)) + (CHANGE.FONT (CAR FONT.STACK))) + (INDENT (IM.ERROR "UNDO INDENT command encountered -- should be flushed")) + NIL)) + (INVISIBLE (* print text which + should be invisable, so it shouldn't + start/stop paragraphs) + (PROG ((SAVE.CR.FLG IM.TEDIT.CR.FLG)) + (DUMP (CDR C)) + (SETQ IM.TEDIT.CR.FLG SAVE.CR.FLG))) + (SHOULDNT]) + +(IM.TEDIT.DUMP.FOOTNOTES + [LAMBDA NIL (* mjs " 4-Jun-85 15:44") + (COND + ([AND IM.TEDIT.FOOTNOTE.SAVES (NOT (GET.MY.PROP 'PASSFOOT)) + (NOT (GET.ANY.PARENT.PROP 'PASSFOOT] + (PROG ((CURRENT.FOOTNOTES IM.TEDIT.FOOTNOTE.SAVES)) + (SETQ IM.TEDIT.FOOTNOTE.SAVES NIL) + (for X in (REVERSE CURRENT.FOOTNOTES) do (IM.DUMP.CHARS X]) + +(IM.TEDIT.DUMP.PARA + [LAMBDA NIL (* mjs " 4-Jun-85 15:46") + (PROG NIL + + (* * actually end paragraph) + + (BOUT IM.OUTFILE (CHARCODE CR)) + + (* * put out current paragraph formatting) + + (for X in (REVERSE IM.TEDIT.PARA.LOOKS) do (push IM.PARALOOKS X + IM.TEDIT.LAST.PARA.BEGIN 1)) + + (* * initialize vars for next paragraph) + + (SETQ IM.TEDIT.LAST.PARA.BEGIN (GETFILEPTR IM.OUTFILE)) + (SETQ IM.TEDIT.PARA.LOOKS NIL) + (SETQ IM.TEDIT.CR.FLG 'MANY) + + (* * print out any footnotes waiting to be printed) + + (IM.TEDIT.DUMP.FOOTNOTES]) + +(INDEXX.PARSE.TYPE + [LAMBDA (SAV) (* mjs "14-Jul-86 09:01") + + (* * Parse the type information from an INDEXX type field) + + (PROG (TYPE) + (if (NULL SAV) + then (RETURN 'TERM)) + (SETQ TYPE (PARSE.LIST SAV)) + + (* if the type was specified with parenthesis at the beginning and the end, + strip them out) + + [if (AND (LISTP TYPE) + (EQ (NTHCHARCODE (CAR TYPE) + 1) + (CHARCODE %()) + (EQ (NTHCHARCODE (CAR (LAST TYPE)) + -1) + (CHARCODE %)))) + then (SETQ TYPE (CONS (SUBATOM (CAR TYPE) + 2 -1) + (CDR TYPE))) + (SETQ TYPE (REVERSE (CONS (SUBATOM (CAR (REVERSE TYPE)) + 1 -2) + (CDR (REVERSE TYPE] + [if (TRANSLATE.SPECIAL.TYPES (CAR TYPE)) + then (SETQ TYPE (TRANSLATE.SPECIAL.TYPES (CAR TYPE] + (RETURN (if TYPE + else 'TERM]) + +(FORMAT.DEF + [LAMBDA (NAME TYPE SAV TYPESTRING) (* mjs " 3-Oct-85 15:05") + + (* * prints out a formatted definition. + SAV should be a SAV-format text object which describes how the name/args should + be formatted. NAME is the index-name inder which this definition should be + grouped. if SAV is NIL, NAME is used instead TYPE is the "object-type" of the + defined object which is pased to the index. + TYPE is also printed in NIL after the function name. + If TYPESTRING is given, it is used for TYPE in the printed definition, but TYPE + is always used in the index.) + + (IM.HOLD.FOOTNOTES (DUMPOUT CR CR) + (SEND.INFO (U-CASE NAME) + TYPE SAV '(*DEF*)) + (DUMPOUT PARALOOKS + `(QUAD LEFT 1STLEFTMARGIN %, IM.DEF.TITLE.1STLEFTMARGIN LEFTMARGIN %, + IM.DEF.TITLE.LEFTMARGIN LINELEADING 0 PARALEADING 18 POSTPARALEADING 0 TABS + %, IM.RIGHT.MARGIN.TABS HEADINGKEEP ON) + DUMP.CHARS SAV DUMP.CHARS " " TAB FONT NIL DUMP.CHARS "[" DUMP.CHARS + (if TYPESTRING + else (LIST.TO.STRING TYPE)) + DUMP.CHARS "]" CR CR) + (if (EQ TO.ARG.NAME 'TEXT) + then (DUMPOUT DUMP.CHARS (CREATE.VRULE.OBJECT T))) + (DUMP.HRULE 1 NIL + `(QUAD LEFT 1STLEFTMARGIN %, IM.DEF.TITLE.1STLEFTMARGIN LEFTMARGIN %, + IM.DEF.TITLE.1STLEFTMARGIN LINELEADING 0 PARALEADING 0 POSTPARALEADING 0 + HEADINGKEEP ON)) + (if (EQ TO.ARG.NAME 'TEXT) + then (DUMPOUT CR CR PARALOOKS '(PARALEADING 0) + DUMP.ARG DUMP.CHARS (CREATE.VRULE.OBJECT) + CR CR) + (DUMP.HRULE 1 NIL) + (DUMPOUT CR CR PARALOOKS '(PARALEADING 18)) + elseif TO.ARG.NAME + then (ERROR "FORMAT.DEF called when not at {TEXT or End of TO"]) + +(FORMAT.LISPWORD + [LAMBDA (SAV) (* mjs " 2-MAY-83 18:08") + (DUMPOUT FONT LISP DUMP.CHARS SAV]) + +(MAKE.IM.DOCUMENT + [LAMBDA (FORM OUTFILE.FLG PAGE.LAYOUT OUTPUT.MESSAGE DEFAULT.PARALOOKS PTRFILENAME) + (* mjs " 4-Aug-86 10:52") + + (* * this function creates an IM output file, in XPS-compatible format. + If sets up all of the special variables needed by DUMP, evaluates FORM, and + sets all of the para and font looks) + + (* * If OUTFILE.FLG is NIL, the output file is just sent to the default + printer. If OUTFILE.FLG is T, the outfile textstream is simply returned. + If OUTFILE.FLG = anything else, it is taken as a file name to put the press + file which is created .) + + (* * if PAGE.LAYOUT is non-NIL, it should be the compound page layout to be + used.) + + (* * if OUTPUT.MESSAGE is non-NIL, it is printed on the hardcopy output) + + (* * PTRFILENAME is the name to be used if an index pointer file is generated + during hardcopy ) + + (PROG ((IM.OUTFILE (OPENTEXTSTREAM "" NIL NIL NIL (LIST 'IM.INDEX.PTRFILENAME PTRFILENAME))) + (FONT.STACK (CONS)) + (IM.TEDIT.LAST.PARA.BEGIN 1) + (IM.TEDIT.LAST.FONT.BEGIN 1) + (IM.TEDIT.PARA.LOOKS NIL) + (IM.TEDIT.LAST.PARA.LOOKS NIL) + (IM.TEDIT.FONT NIL) + (IM.TEDIT.CR.FLG 'MANY) + (IM.TEDIT.FOOTNOTE.SAVES NIL) + (IM.TEDIT.SUB.SUPER.BEGIN NIL) + IM.CHARLOOKS IM.PARALOOKS) + (DECLARE (SPECVARS IM.OUTFILE FONT.STACK IM.TEDIT.LAST.PARA.BEGIN + IM.TEDIT.LAST.FONT.BEGIN IM.TEDIT.PARA.LOOKS IM.TEDIT.LAST.PARA.LOOKS + IM.TEDIT.FONT IM.TEDIT.CR.FLG IM.TEDIT.FOOTNOTE.SAVES + IM.TEDIT.SUB.SUPER.BEGIN IM.CHARLOOKS IM.PARALOOKS)) + (SETQ IM.VRULE.STATE.LIST NIL) + (DUMP.HEADERS.FOOTERS " " " ") + (DUMPOUT CR CR START.PARA PARALOOKS + `(TYPE PAGEHEADING SUBTYPE DRAFTMESSAGE QUAD LEFT 1STLEFTMARGIN 0 LEFTMARGIN 0 + RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN) + DUMP.CHARS + (COND + (IM.DRAFT.FLG (CONCAT "***DRAFT*** " (DATE) + " ***DRAFT***")) + (T " ")) + CR CR) + (EVAL FORM) + (COND + (IM.EVEN.FLG + + (* if you must quarantee that you have an even number of pages for two-sided + copying, dump out a blank page no matter what -- + it can always be discarded) + + (DUMPOUT CR CR START.PARA PARALOOKS + `(NEWPAGEBEFORE T QUAD LEFT 1STLEFTMARGIN 0 LEFTMARGIN 0 RIGHTMARGIN %, + IM.TEXT.RIGHTMARGIN SPECIALX %, IM.BLANKPAGE.SPECIALX SPECIALY %, + IM.BLANKPAGE.SPECIALY) + DUMP.CHARS "[This page intentionally left blank]" CR CR))) + + (* after converting document, make sure that last para is formatted correctly + by changing font, ending current para, and starting new para) + + (DUMPOUT CR CR FONT NIL) + (DUMP '(START.PARA)) + + (* * set page format) + + [TEDIT.PAGEFORMAT IM.OUTFILE + (COND + (PAGE.LAYOUT) + (T (TEDIT.COMPOUND.PAGEFORMAT [TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL + IM.PAGE.LEFTMARGIN IM.PAGE.RIGHTMARGIN + IM.PAGE.FIRST.TOPMARGIN IM.PAGE.BOTTOMMARGIN + 1 NIL NIL + `((RECTOFOOT %, IM.PAGE.LEFTMARGIN %, + IM.FOOTER.Y) + (RECTOFOOTRULE %, IM.PAGE.LEFTMARGIN %, + IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.BOTTOM.Y] + [TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL IM.PAGE.LEFTMARGIN + IM.PAGE.RIGHTMARGIN IM.PAGE.TOPMARGIN IM.PAGE.BOTTOMMARGIN 1 NIL + NIL `((DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.TOP.Y) + (VERSOHEAD %, IM.PAGE.LEFTMARGIN %, IM.HEADER.Y) + (VERSOHEADRULE %, IM.PAGE.LEFTMARGIN %, IM.HEADER.RULE.Y) + (VERSOFOOT %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.Y) + (VERSOFOOTRULE %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.BOTTOM.Y] + (TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL IM.PAGE.LEFTMARGIN + IM.PAGE.RIGHTMARGIN IM.PAGE.TOPMARGIN IM.PAGE.BOTTOMMARGIN 1 NIL + NIL `((DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.TOP.Y) + (RECTOHEAD %, IM.PAGE.LEFTMARGIN %, IM.HEADER.Y) + (RECTOHEADRULE %, IM.PAGE.LEFTMARGIN %, IM.HEADER.RULE.Y) + (RECTOFOOT %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.Y) + (RECTOFOOTRULE %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.BOTTOM.Y] + + (* * dump default char and para looks for whole document -- + and looks that should be different should be specified in the fns) + + (TEDIT.LOOKS IM.OUTFILE IM.TEXT.FONT 1 (GETFILEINFO IM.OUTFILE 'LENGTH)) + (TEDIT.PARALOOKS IM.OUTFILE + [COND + (DEFAULT.PARALOOKS) + (T `(QUAD JUSTIFIED 1STLEFTMARGIN %, IM.TEXT.LEFTMARGIN LEFTMARGIN %, + IM.TEXT.LEFTMARGIN RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN LINELEADING 0 + PARALEADING 5 POSTPARALEADING 0] + 1 + (GETFILEINFO IM.OUTFILE 'LENGTH)) + + (* must reverse list because the order of some char and paragraph looks is + significant << earlier looks are overridden by later ones >>) + + (SETQ IM.CHARLOOKS (DREVERSE IM.CHARLOOKS)) + (SETQ IM.PARALOOKS (DREVERSE IM.PARALOOKS)) + [while IM.CHARLOOKS bind (LOOKS CH# LEN) + do (BLOCK) + (SETQ LEN (pop IM.CHARLOOKS)) + (SETQ CH# (ADD1 (pop IM.CHARLOOKS))) + (SETQ LOOKS (pop IM.CHARLOOKS)) + (COND + ((IGREATERP LEN 0) + (TEDIT.LOOKS IM.OUTFILE LOOKS CH# LEN] + [while IM.PARALOOKS bind (LOOKS CH# LEN) + do (BLOCK) + (SETQ LEN (pop IM.PARALOOKS)) + (SETQ CH# (ADD1 (pop IM.PARALOOKS))) + (SETQ LOOKS (pop IM.PARALOOKS)) + (COND + ((IGREATERP LEN 0) + (TEDIT.PARALOOKS IM.OUTFILE LOOKS CH# LEN] + (COND + ((NULL OUTFILE.FLG) + (TEDIT.HARDCOPY IM.OUTFILE NIL NIL OUTPUT.MESSAGE) + (TEDIT.KILL IM.OUTFILE) + (printout T "Document sent to printer" T) + (RETURN)) + ((EQ OUTFILE.FLG T) + (RETURN IM.OUTFILE)) + (T (TEDIT.HARDCOPY IM.OUTFILE (PACKFILENAME 'BODY OUTFILE.FLG 'EXTENSION 'IP) + T OUTPUT.MESSAGE) + (TEDIT.KILL IM.OUTFILE) + (printout T "Output file: " (PACKFILENAME 'BODY OUTFILE.FLG 'EXTENSION 'IP) + T) + (RETURN]) + +(PRINT.NOTE + [LAMBDA (NOTE.STRING) (* mjs "10-Apr-85 11:17") + (COND + (IM.NOTE.FLG (DUMPOUT FONT NOTE DUMP.CHARS "<<<" DUMP.CHARS NOTE.STRING DUMP.CHARS ">>>"]) + +(SEND.INFO + [LAMBDA (NAME TYPE SAV INFO PLIST) (* mjs " 4-Aug-86 09:06") + (if IM.INDEX.FILE.FLG + then (DUMP.FORMAT 'INVISIBLE (IM.INDEX.CREATEOBJ (create IM.INDEX.DATA + NAME _ NAME + TYPE _ TYPE + SAV _ (if (LISTP SAV) + then (CAR SAV) + else SAV) + INFO _ INFO + SUBSEC _ SUBSEC.COUNT.LIST + PROPLIST _ PLIST]) +) + + + +(* fns for drawing vrules to the left of definition text -- an unused, never-fully debuged feature) + +(DEFINEQ + +(IM.VRULE.DISPLAYFN + [LAMBDA (OBJ STREAM) (* mjs "19-Sep-85 15:06") + (if (NOT (DISPLAYSTREAMP STREAM)) + then (push IM.VRULE.STATE.LIST (LIST (DSPYPOSITION NIL STREAM) + (IMAGEOBJPROP OBJ 'IM.VRULE.STATE]) + +(CREATE.VRULE.OBJECT + [LAMBDA (STATE) (* mjs "11-Jul-86 12:17") + (if IM.PRINT.VRULE.FLG + then (PROG (OBJ) + [SETQ OBJ + (IMAGEOBJCREATE NIL + (if IM.VRULE.OBJECT.IMAGEFNS + else (SETQ IM.VRULE.OBJECT.IMAGEFNS + (IMAGEFNSCREATE (FUNCTION IM.VRULE.DISPLAYFN) + [FUNCTION (LAMBDA NIL + (create IMAGEBOX + XSIZE _ 0 + YSIZE _ 0 + YDESC _ 0 + XKERN _ 0] + 'NILL + (FUNCTION CREATE.VRULE.OBJECT) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.VRULE.OBJECT] + (IMAGEOBJPROP OBJ 'IM.VRULE.STATE STATE) + (RETURN OBJ)) + else ""]) + +(PRINT.VRULES.ON.PAGE + [LAMBDA (STREAM) (* mjs "23-Sep-85 14:14") + (COND + ((AND IM.PRINT.VRULE.FLG (NOT (DISPLAYSTREAMP STREAM))) + (for X in (REVERSE (SORT IM.VRULE.STATE.LIST T)) + bind (SCALED.VRULE.WIDTH _ (TIMES 1 (DSPSCALE NIL STREAM))) + (SCALED.VRULE.X _ (TIMES (PLUS IM.VRULE.X IM.PAGE.LEFTMARGIN) + (DSPSCALE NIL STREAM))) + (STATE _ NIL) + (YPOS _ NIL) + CURRENT.STATE CURRENT.YPOS + do (SETQ CURRENT.STATE (CADR X)) + (SETQ CURRENT.YPOS (CAR X)) + (COND + ((AND (NULL CURRENT.STATE) + STATE + (NUMBERP YPOS) + (NUMBERP CURRENT.YPOS)) + (DRAWLINE SCALED.VRULE.X YPOS SCALED.VRULE.X CURRENT.YPOS SCALED.VRULE.WIDTH NIL + STREAM))) + (COND + (CURRENT.STATE (SETQ STATE CURRENT.STATE) + (SETQ YPOS CURRENT.YPOS)) + (T (SETQ STATE NIL) + (SETQ YPOS NIL))) + finally (PROGN (SETQ IM.VRULE.STATE.LIST NIL) + (COND + ((AND STATE (NUMBERP YPOS)) + (DRAWLINE SCALED.VRULE.X YPOS SCALED.VRULE.X + (TIMES IM.TEXT.BOTTOMMARGIN (DSPSCALE NIL STREAM)) + SCALED.VRULE.WIDTH NIL STREAM) + (push IM.VRULE.STATE.LIST (LIST (TIMES IM.TEXT.TOPMARGIN + (DSPSCALE NIL STREAM)) + STATE]) +) + +(RPAQQ IM.VRULE.STATE.LIST NIL) + +(RPAQ? IM.VRULE.OBJECT.IMAGEFNS NIL) + +(RPAQ? IM.PRINT.VRULE.FLG NIL) + + + +(* fns for printing page numbers) + +(DEFINEQ + +(IM.FOLIO.DISPLAYFN + [LAMBDA (OBJ STREAM) (* mjs "20-Sep-85 09:45") + (PROG ((FOLIO.TEXT (GET.FOLIO.STRING OBJ STREAM)) + FONT OFONT) + (SETQ FONT (SELECTQ (IMAGESTREAMTYPE STREAM) + (DISPLAY '(MODERN 8 MRR 0 DISPLAY)) + (PRESS '(MODERN 8 MRR 0 PRESS)) + (INTERPRESS '(MODERN 8 MRR 0 INTERPRESS)) + NIL)) + (SETQ OFONT (DSPFONT FONT STREAM)) + (PRIN1 FOLIO.TEXT STREAM) + (DSPFONT OFONT STREAM) + + (* * take care of any vrules on page) + + (PRINT.VRULES.ON.PAGE STREAM]) + +(IM.FOLIO.SIZEFN + [LAMBDA (OBJ STREAM CURX RIGHTMARGIN) (* mjs " 7-Aug-85 10:27") + (* Tell the size of a menu button) + (PROG ((FOLIO.TEXT (GET.FOLIO.STRING OBJ STREAM)) + FONT BOX) + (SETQ FONT (SELECTQ (IMAGESTREAMTYPE STREAM) + (DISPLAY '(MODERN 8 MRR 0 DISPLAY)) + (PRESS '(MODERN 8 MRR 0 PRESS)) + (INTERPRESS '(MODERN 8 MRR 0 INTERPRESS)) + NIL)) + (SETQ BOX (create IMAGEBOX + XSIZE _ (STRINGWIDTH FOLIO.TEXT FONT) + YSIZE _ (FONTPROP FONT 'HEIGHT) + YDESC _ (FONTPROP FONT 'DESCENT) + XKERN _ 0)) + (RETURN BOX]) + +(CREATE.FOLIO.OBJECT + [LAMBDA NIL (* mjs "11-Jul-86 12:16") + (PROG (OBJ) + [SETQ OBJ (IMAGEOBJCREATE NIL (COND + (IM.FOLIO.OBJECT.IMAGEFNS) + (T (SETQ IM.FOLIO.OBJECT.IMAGEFNS + (IMAGEFNSCREATE (FUNCTION IM.FOLIO.DISPLAYFN) + (FUNCTION IM.FOLIO.SIZEFN) + 'NILL + (FUNCTION CREATE.FOLIO.OBJECT) + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'NILL + 'IM.FOLIO.OBJECT] + (IMAGEOBJPROP OBJ 'IM.CHAPNUM.DATA (COND + ((BOUNDP 'SUBSEC.COUNT.LIST) + (CAR (LAST SUBSEC.COUNT.LIST))) + (T NIL))) + (RETURN OBJ]) + +(GET.FOLIO.STRING + [LAMBDA (OBJ STREAM) (* mjs "19-Sep-85 14:59") + (PROG ([CHAPNUM.INFO (MKLIST (IMAGEOBJPROP OBJ 'IM.CHAPNUM.DATA] + CHAPNUM PAGENUM) + (SETQ CHAPNUM (CAR CHAPNUM.INFO)) + [SETQ PAGENUM (COND + ((DISPLAYSTREAMP STREAM) + "xx") + (T (PROG [(TEDIT.PAGE (fetch (PAGEFORMATTINGSTATE PAGE#) of + FORMATTINGSTATE + )) + (NUMBER.PAGENUMS (LENGTH (CDR CHAPNUM.INFO] + (RETURN (COND + ((NULL (CDR CHAPNUM.INFO)) + TEDIT.PAGE) + [(GREATERP TEDIT.PAGE NUMBER.PAGENUMS) + (COND + ((NUMBERP (CAR (LAST CHAPNUM.INFO))) + (IPLUS (CAR (LAST CHAPNUM.INFO)) + (IDIFFERENCE TEDIT.PAGE NUMBER.PAGENUMS))) + (T (CAR (LAST CHAPNUM.INFO] + (T (CAR (NTH (CDR CHAPNUM.INFO) + TEDIT.PAGE] + (RETURN (COND + (CHAPNUM (CONCAT CHAPNUM "." PAGENUM)) + (T (MKSTRING PAGENUM]) +) + +(RPAQ? IM.FOLIO.OBJECT.IMAGEFNS NIL) + + + +(* TOPROG functions, used to define the translating actions of IM text objects.) + +(DEFINEQ + +(ARG#TOPROG + [LAMBDA NIL (* mjs "14-APR-83 16:10") + (DUMPOUT FONT ARG DUMP.ARG]) + +(BIGLISPCODE#TOPROG + [LAMBDA NIL (* mjs " 8-Aug-85 09:24") + (DUMPOUT CR CR) + (IM.HOLD.FOOTNOTES (PROG [(SAV (SAVE.ARG)) + (NEW.LINE (CONS)) + (LISP.LINE.PARA.LOOKS '(QUAD LEFT LEFTMARGIN 0 1STLEFTMARGIN 0] + (TCONC SAV (CHARCODE CR)) + (for X in (CAR SAV) + do (TCONC NEW.LINE X) + (if (EQ X (CHARCODE CR)) + then (DUMPOUT FONT LISP PARALOOKS LISP.LINE.PARA.LOOKS + START.PARA DUMP.CHARS NEW.LINE CR CR) + (* after first line, use 0 para + leading) + (SETQ LISP.LINE.PARA.LOOKS + '(QUAD LEFT PARALEADING 0 LEFTMARGIN 0 1STLEFTMARGIN + 0)) + (SETQ NEW.LINE (CONS]) + +(BRACKET#TOPROG + [LAMBDA NIL (* mjs "11-APR-83 11:10") + (DUMPOUT DUMP.CHARS "{" DUMP.ARG DUMP.CHARS "}"]) + +(CHAPTER#TOPROG + [LAMBDA NIL (* mjs "18-Sep-85 14:54") + (SAVE.ARGS NUMBER TITLE) + (PROG ((TITLE.SAV (GET.ARG.SAV TITLE)) + (CHAP.NUM (PARSE.ATOM (GET.ARG.SAV NUMBER))) + UCASE.TITLE.STRING CHAP.NUM.STRING) + (SETQ UCASE.TITLE.STRING (U-CASE (PARSE.STRING TITLE.SAV))) + [if (NULL CHAP.NUM) + then (SETQ CHAP.NUM (if (BOUNDP 'GLOBAL.CHAPTER.NUMBER) + then GLOBAL.CHAPTER.NUMBER + else (printout T "No number specified for chapter: '" + UCASE.TITLE.STRING + "' --- please type chapter number: ") + (READ] + (SETQ SUBSEC.COUNT.LIST (CONS CHAP.NUM)) + (SETQ SUBSEC.LAST.SUB 0) + (SETQ FOOTNOTE.NUM 0) + (SETQ FIGURE.NUM 0) + + (* specify both headers and footers, in case a page break comes before the next + subsec) + + (DUMP.HEADERS.FOOTERS UCASE.TITLE.STRING UCASE.TITLE.STRING) + (SEND.INFO (MKATOM UCASE.TITLE.STRING) + 'CHAPTER TITLE.SAV) + (SETQ CHAP.NUM (MKLIST CHAP.NUM)) + (SETQ CHAP.NUM.STRING (if (CAR CHAP.NUM) + then (CONCAT (CAR CHAP.NUM) + ".") + else "")) + (DUMPOUT FONT IM.CHAPTER.TITLE.FONT PARALOOKS + `(PARALEADING 0 LINELEADING 0 QUAD LEFT TABS %, IM.RIGHT.MARGIN.TABS) + DUMP.CHARS CHAP.NUM.STRING TAB DUMP.CHARS UCASE.TITLE.STRING CR CR) + + (* we want the PARALEADING between the chapter rule and the next line to be + 108pts. ASSUMING that the next line is a normal text line, rather than a subsec + heading, this means that the next para will have a paraleading of 5pts. + Therefore, this "invisible" paragraph must take 103pts. + If the font size is 10pts and the paraleading is 93pts, this should do the + trick.) + + (DUMP.HRULE 6) + (DUMPOUT START.PARA FONT NIL PARALOOKS '(PARALEADING 93 LINELEADING 0) + DUMP.CHARS " " CR CR) + + (* theoretically, we should be able to get the space we need by using + POSTPARALEADING, but this doesn't seem to work. + Try%: (DUMP.HRULE 6 NIL (QUOTE (POSTPARALEADING 103)))) + + (if (EQ TO.ARG.NAME 'TEXT) + then (DUMPOUT DUMP.ARG CR CR]) + +(COMMENT#TOPROG + [LAMBDA NIL (* mjs " 6-Aug-85 15:15") + (PROG ((IM.INDEX.FILE.FLG NIL) + (IM.REF.FLG NIL) + (IM.SEND.IMPLICIT NIL) + (IM.CHECK.DEFS NIL)) + (DECLARE (SPECVARS IM.INDEX.FILE.FLG IM.REF.FLG IM.SEND.IMPLICIT IM.CHECK.DEFS)) + (* make sure that no ptrs are sent + from TOs in a note or comment) + (FLUSH.ARG]) + +(DEF#TOPROG + [LAMBDA NIL (* mjs " 9-Apr-85 16:00") + (SAVE.ARGS TYPE NAME PRINTNAME ARGS PARENS NOPARENS) + (PROG [[PARENS.FLG (OR (GET.ARG.SAV PARENS) + (AND (GET.ARG.SAV NAME) + (GET.ARG.SAV ARGS) + (NULL (GET.ARG.SAV NOPARENS] + [INDEX.NAME (MKATOM (LIST.TO.STRING (PARSE.LIST (GET.ARG.SAV NAME] + (PARSED.TYPE (PARSE.LIST (GET.ARG.SAV TYPE] (* if no more args, just return) + (if (TRANSLATE.SPECIAL.TYPES (CAR PARSED.TYPE)) + then (SETQ PARSED.TYPE (TRANSLATE.SPECIAL.TYPES (CAR PARSED.TYPE))) + elseif (AND (EQ (NTHCHAR (CAR PARSED.TYPE) + 1) + '%() + (EQ (NTHCHAR (CAR (LAST PARSED.TYPE)) + -1) + '%))) + then (SETQ PARSED.TYPE (CAR (GET.ARG.SAV TYPE))) + (SETQ PARSED.TYPE (CDR (MEMB (CHARCODE %() + PARSED.TYPE))) + [SETQ PARSED.TYPE (REVERSE (CDR (MEMB (CHARCODE %)) + (REVERSE PARSED.TYPE] + [SETQ PARSED.TYPE (PARSE.LIST (CONS PARSED.TYPE (LAST PARSED.TYPE] + else (IM.ERROR "bad TYPE arg given to DEF of " INDEX.NAME " '" (PARSE.STRING + PARSED.TYPE) + "' --- TERM used instead") + (SETQ PARSED.TYPE 'TERM)) + (FORMAT.DEF INDEX.NAME PARSED.TYPE + (if (GET.ARG.SAV PRINTNAME) + then (SAVE.DUMPOUT FONT LISP DUMP.CHARS (GET.ARG.SAV PRINTNAME)) + else (if (GET.ARG.SAV ARGS) + then (if PARENS.FLG + then (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" + DUMP.CHARS (GET.ARG.SAV NAME) + DUMP.CHARS " " FONT ARG DUMP.CHARS + (GET.ARG.SAV ARGS) + FONT LISP DUMP.CHARS ")") + else (SAVE.DUMPOUT FONT LISP DUMP.CHARS (GET.ARG.SAV + NAME) + DUMP.CHARS " " FONT ARG DUMP.CHARS + (GET.ARG.SAV ARGS))) + else (if PARENS.FLG + then (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" DUMP.CHARS + (GET.ARG.SAV NAME) + DUMP.CHARS ")") + else (SAVE.DUMPOUT FONT LISP DUMP.CHARS (GET.ARG.SAV + NAME]) + +(FIGURE#TOPROG + [LAMBDA NIL (* mjs "25-Jul-85 11:30") + (PROG ((DUMP.CAPTION.FLG NIL) + (CHAP.NUM (CAR (LAST SUBSEC.COUNT.LIST))) + (FIGURE.TAG.LIST NIL) + FIGURE.TAG ARG.NAME FIGURE.NUM.STRING) + (SETQ FIGURE.NUM (ADD1 FIGURE.NUM)) + (SETQ FIGURE.NUM.STRING (if (EQ CHAP.NUM 0) + then (CONCAT "Figure " FIGURE.NUM ".") + else (CONCAT "Figure " CHAP.NUM "." FIGURE.NUM "."))) + (DUMPOUT CR CR) + loop + (SELECTQ (SETQ ARG.NAME (GET.ARG)) + (TAG [SETQ FIGURE.TAG (U-CASE (PARSE.ATOM (SAVE.ARG] + (SETQ FIGURE.TAG.LIST (CONS FIGURE.TAG FIGURE.TAG.LIST)) + (SEND.INFO FIGURE.TAG 'TAG NIL (LIST '*FIGURE* FIGURE.NUM))) + (TEXT (DUMPOUT DUMP.ARG CR CR)) + (CAPTION (DUMPOUT DUMP.CHARS FIGURE.NUM.STRING DUMP.CHARS " " DUMP.ARG CR CR) + (SETQ DUMP.CAPTION.FLG T)) + (NIL (if (NOT DUMP.CAPTION.FLG) + then (DUMPOUT DUMP.CHARS FIGURE.NUM.STRING CR CR)) + (SAVE.INFILE.NOTE 'IM.FIGURE (CONS FIGURE.NUM FIGURE.TAG.LIST)) + (RETURN)) + (SHOULDNT)) + (GO loop]) + +(FN#TOPROG + [LAMBDA NIL (* mjs "13-SEP-83 17:14") + (PROG ((SAV (SAVE.ARG))) + (FORMAT.LISPWORD SAV) + (SEND.IMPLICIT (PARSE.ATOM SAV) + '(Function) + SAV) + (if [AND IM.CHECK.DEFS (NOT (GETD (PARSE.ATOM SAV] + then (SAVE.INFILE.NOTE 'UNDEF.FN (PARSE.ATOM SAV]) + +(FNDEF#TOPROG + [LAMBDA NIL (* mjs "18-Sep-85 14:57") + (SAVE.ARGS NAME ARGS TYPE) + (PROG ((NAME (PARSE.ATOM (GET.ARG.SAV NAME))) + (ARGS (PARSE.LIST (GET.ARG.SAV ARGS))) + [TYPES (U-CASE (PARSE.LIST (GET.ARG.SAV TYPE] + NEXT.ARG typestring fntype typelist) (* if no more args, just return) + (DUMPOUT CR CR) + (if IM.CHECK.DEFS + then (if (GETD NAME) + then (SETQ fntype 0) + (COND + ((FMEMB 'NLAMBDA TYPES) + (SETQ fntype 1))) + [COND + ((FMEMB 'NOSPREAD TYPES) + (SETQ fntype (IPLUS fntype 2] + (COND + ((NEQ fntype (ARGTYPE NAME)) + (SETQ typelist (SELECTQ (ARGTYPE NAME) + (0 '[LAMBDA SPREAD]) + (1 '[NLAMBDA SPREAD]) + (2 '[LAMBDA NOSPREAD]) + (3 '[NLAMBDA NOSPREAD]) + NIL)) + (DUMPOUT CR CR) + (PRINT.NOTE (CONCAT NAME " is a " typelist + " but manual def says it is a " TYPES)) + (IM.WARNING NAME " is a " typelist + " but manual def says it is a " TYPES))) + (COND + ([NOT (OR (EQUAL ARGS (MKLIST (ARGLIST NAME))) + (AND (NLISTP (ARGLIST NAME)) + (GREATERP (LENGTH ARGS) + 1] + (DUMPOUT CR CR) + (PRINT.NOTE (CONCAT NAME " has arglist: " + (MKLIST (ARGLIST NAME)) + " in Interlisp-D")) + (IM.WARNING NAME " has arglist: " (MKLIST (ARGLIST NAME))) + (IM.WARNING " but manual says: " ARGS))) + else (DUMPOUT CR CR) + (PRINT.NOTE (CONCAT "Function: " NAME + " is not defined in Interlisp-D")) + (IM.WARNING "Function: " NAME " is not defined in Interlisp-D") + (SAVE.INFILE.NOTE 'UNDEF.FN NAME))) + (DUMPOUT CR CR) + (SETQ typestring "Function") + [COND + ((FMEMB 'NOSPREAD TYPES) + (SETQ typestring (CONCAT "NoSpread " typestring] + [COND + ((FMEMB 'NLAMBDA TYPES) + (SETQ typestring (CONCAT "NLambda " typestring] + (FORMAT.DEF NAME '(Function) + (if (AND (LISTP (GET.ARG.SAV ARGS)) + (CAR (GET.ARG.SAV ARGS))) + then (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" DUMP.CHARS (GET.ARG.SAV NAME) + DUMP.CHARS " " FONT ARG DUMP.CHARS (GET.ARG.SAV ARGS) + FONT LISP DUMP.CHARS ")") + else (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" DUMP.CHARS (GET.ARG.SAV NAME) + DUMP.CHARS ")")) + typestring]) + +(FOOT#TOPROG + [LAMBDA NIL (* mjs "18-Sep-85 14:57") + (PROG (FOOT.SAV) + (SETQ FOOTNOTE.NUM (ADD1 FOOTNOTE.NUM)) + (IM.WARNING "footnote #" FOOTNOTE.NUM " --- not fully implemented") + (DUMPOUT FONT FOOTNOTE START.SUPER DUMP.CHARS FOOTNOTE.NUM END.SUPER) + (SETQ FOOT.SAV (SAVE.DUMPOUT FONT FOOTNOTE START.SUPER DUMP.CHARS FOOTNOTE.NUM END.SUPER + DUMP.ARG CR CR)) + (push IM.TEDIT.FOOTNOTE.SAVES FOOT.SAV]) + +(INCLUDE#TOPROG + [LAMBDA NIL (* mjs "25-Jul-85 10:49") + (PROG [(names (PARSE.LIST (SAVE.ARG] + (COND + ((CDR names) + (IM.ERROR "Include file name: " names " -- first name will be used"))) + (INCLUDE.FILE (CAR names]) + +(INDEX#TOPROG + [LAMBDA NIL (* mjs "23-Jul-85 11:21") + (PROG ((SAV (SAVE.ARG)) + (INFO NIL) + TYPE ARGS TEMP ARG.ATOM) + (SETQ TEMP (PARSE.INDEX.SPEC SAV T)) + (if (OR (NULL TEMP) + (NULL (CAR TEMP))) + then (IM.WARNING "null index with type=" (CDR TEMP) + " --- ignored") + (RETURN)) + (SETQ ARGS (CAR TEMP)) + (SETQ TYPE (CDR TEMP)) + (while (FMEMB (CAR ARGS) + '(*BEGIN* *END* *PRIMARY*)) do (SETQ INFO (CONS (CAR ARGS) + INFO)) + (SETQ ARGS (CDR ARGS))) + (SETQ ARG.ATOM (MKATOM (LIST.TO.STRING ARGS))) + (if (U-CASEP ARG.ATOM) + then (SEND.INFO ARG.ATOM TYPE NIL INFO) + else (SEND.INFO (U-CASE ARG.ATOM) + TYPE ARG.ATOM INFO]) + +(INDEXX#TOPROG + [LAMBDA NIL (* mjs "11-Jul-86 16:57") + (SAVE.ARGS NAME TYPE INFO TEXT SUBNAME SUBTYPE SUBTEXT SUBSUBNAME SUBSUBTYPE SUBSUBTEXT) + (PROG ((PROPLIST NIL) + [NAME (MKATOM (LIST.TO.STRING (if (PARSE.LIST (GET.ARG.SAV NAME)) + else '(NIL] + (TYPE (INDEXX.PARSE.TYPE (GET.ARG.SAV TYPE))) + (INFO (PARSE.LIST (GET.ARG.SAV INFO))) + [SUBNAME (MKATOM (LIST.TO.STRING (if (PARSE.LIST (GET.ARG.SAV SUBNAME)) + else '(NIL] + (SUBTYPE (INDEXX.PARSE.TYPE (GET.ARG.SAV SUBTYPE))) + [SUBSUBNAME (MKATOM (LIST.TO.STRING (if (PARSE.LIST (GET.ARG.SAV SUBSUBNAME)) + else '(NIL] + (SUBSUBTYPE (INDEXX.PARSE.TYPE (GET.ARG.SAV SUBSUBTYPE))) + TEXT SUBTEXT SUBSUBTEXT) + (SETQ TEXT (if (GET.ARG.SAV TEXT) + elseif (NOT (U-CASEP NAME)) + then NAME)) + (SETQ SUBTEXT (if (GET.ARG.SAV SUBTEXT) + elseif (NOT (U-CASEP SUBNAME)) + then SUBNAME)) + (SETQ SUBSUBTEXT (if (GET.ARG.SAV SUBSUBTEXT) + elseif (NOT (U-CASEP SUBSUBNAME)) + then SUBSUBNAME)) + (SETQ NAME (U-CASE NAME)) + (SETQ SUBNAME (U-CASE SUBNAME)) + (SETQ SUBSUBNAME (U-CASE SUBSUBNAME)) + [if (OR SUBNAME SUBTEXT) + then (SETQ PROPLIST (APPEND PROPLIST (LIST 'SUBNAME SUBNAME 'SUBTYPE SUBTYPE + 'SUBTEXT SUBTEXT] + [if (OR SUBSUBNAME SUBSUBTEXT) + then (SETQ PROPLIST (APPEND PROPLIST (LIST 'SUBSUBNAME SUBSUBNAME 'SUBSUBTYPE + SUBSUBTYPE 'SUBSUBTEXT SUBSUBTEXT] + (SEND.INFO NAME TYPE TEXT INFO PROPLIST]) + +(IT#TOPROG + [LAMBDA NIL (* mjs "18-APR-83 14:32") + (DUMPOUT FONT ITALIC DUMP.ARG]) + +(LBRACKET#TOPROG + [LAMBDA NIL (* mjs "10-Apr-85 09:51") + (IM.DUMP.CHARS "{") + (TRIVIAL.ARG]) + +(LISP#TOPROG + [LAMBDA NIL (* mjs "18-APR-83 14:27") + (DUMPOUT FONT LISP DUMP.ARG]) + +(LISPCODE#TOPROG + [LAMBDA NIL (* mjs " 2-Aug-85 16:27") + (DUMPOUT CR CR) + (IM.HOLD.FOOTNOTES (PROG [(SAV (SAVE.ARG)) + (NEW.LINE (CONS)) + (LISP.LINE.PARA.LOOKS '(QUAD LEFT] + (TCONC SAV (CHARCODE CR)) + (for X in (CAR SAV) + do (TCONC NEW.LINE X) + (if (EQ X (CHARCODE CR)) + then (DUMPOUT FONT LISP PARALOOKS LISP.LINE.PARA.LOOKS + START.PARA DUMP.CHARS NEW.LINE CR CR) + (* after first line, use 0 para + leading) + (SETQ LISP.LINE.PARA.LOOKS + '(QUAD LEFT PARALEADING 0)) + (SETQ NEW.LINE (CONS]) + +(LISPWORD#TOPROG + [LAMBDA NIL (* mjs "27-JUL-83 14:13") + + (* keep as seperate fn from LISP#TOPROG so can easily add hacks to check fns, + etc..) + + (PROG ((SAV (SAVE.ARG))) + (FORMAT.LISPWORD SAV) + (SEND.IMPLICIT (PARSE.ATOM SAV) + (SELECTQ TO.NAME + (ATOM '(Litatom)) + (BREAKCOM '(Break Command)) + (EDITCOM '(Editor Command)) + (FILECOM '(File Package Command)) + (MAC '(Macro)) + (PACOM '(Prog. Asst. Command)) + (PROP '(Property Name)) + 'TERM) + SAV]) + +(LIST#TOPROG + [LAMBDA NIL (* mjs "28-Jul-86 16:36") + (PROG ((LNAME.AND.NAME.LIST NIL) + (ITEM.NUMBER 0) + (LIST.PARA.LOOKS `(1STLEFTMARGIN 0 LEFTMARGIN %, IM.TEXT.LEFTMARGIN POSTPARALEADING 0 TABS + %, IM.LABELED.LIST.TABS)) + LAST.SPEC) + + (* * LNAME.AND.NAME.LIST is a list of LNAME and NAME values, where each element + of the list is of the form (LNAME . NAME)) + + (DUMPOUT CR CR) + (until (NULL (SETQ LAST.SPEC (GET.ARG))) + do + (SELECTQ LAST.SPEC + ((INDENT MAX) + (IM.WARNING "List with " LAST.SPEC (PARSE.NUMBER.OR.PERCENTAGE (SAVE.ARG) + 100 100) + " spec -- de-implemented")) + (UNINDENTED (DUMPOUT CR CR DUMP.ARG CR CR)) + (LNAME (push LNAME.AND.NAME.LIST (CONS (SAVE.ARG) + " "))) + (NAME [if [AND LNAME.AND.NAME.LIST (EQUAL " " (CDR (CAR LNAME.AND.NAME.LIST] + then (RPLACD (CAR LNAME.AND.NAME.LIST) + (SAVE.ARG)) + else (push LNAME.AND.NAME.LIST (CONS " " (SAVE.ARG]) + (ITEM (SETQ ITEM.NUMBER (ADD1 ITEM.NUMBER)) + (SELECTQ TO.NAME + (NUMBEREDLIST (DUMPOUT PARALOOKS LIST.PARA.LOOKS TAB DUMP.CHARS "(" + DUMP.CHARS ITEM.NUMBER DUMP.CHARS ")" TAB DUMP.ARG CR + CR)) + (UNNUMBEREDLIST + (DUMPOUT PARALOOKS LIST.PARA.LOOKS TAB DUMP.CHARS + (MKSTRING (CHARACTER (CHARCODE %#7))) + TAB DUMP.ARG CR CR)) + (LABELEDLIST (if LNAME.AND.NAME.LIST + then (PROG ((ALL.BUT.LAST.NAME.SPECS + (REVERSE (CDR LNAME.AND.NAME.LIST))) + (FIRST.NAME.SPEC (CAR LNAME.AND.NAME.LIST + ))) + [for LNAME.NAME in + ALL.BUT.LAST.NAME.SPECS + do + (* dump all but last name) + (DUMPOUT PARALOOKS + LIST.PARA.LOOKS DUMP.CHARS + (CAR LNAME.NAME) + TAB PARALOOKS + '(HEADINGKEEP ON) + DUMP.CHARS + (CDR LNAME.NAME) + TAB CR CR PARALOOKS + '(PARALEADING 0] + (* dump last name and item) + (DUMPOUT PARALOOKS LIST.PARA.LOOKS + DUMP.CHARS (CAR FIRST.NAME.SPEC) + TAB DUMP.CHARS (CDR FIRST.NAME.SPEC + ) + TAB DUMP.ARG CR CR)) + else (DUMPOUT DUMP.ARG CR CR)) + (SETQ LNAME.AND.NAME.LIST NIL)) + (SHOULDNT))) + (SHOULDNT]) + +(MACDEF#TOPROG + [LAMBDA NIL (* mjs " 5-AUG-83 13:31") + (SAVE.ARGS NAME ARGS TYPE) + (PROG ((NAME (PARSE.ATOM (GET.ARG.SAV NAME))) + (ARGS (PARSE.LIST (GET.ARG.SAV ARGS))) + [TYPES (U-CASE (PARSE.LIST (GET.ARG.SAV TYPE] + typestring) + + (* * will eventually check if NAME has a macro definition) + + (SETQ typestring "Macro") + [COND + ((FMEMB 'NOSPREAD TYPES) + (SETQ typestring (CONCAT "NoSpread " typestring] + [COND + ((FMEMB 'NLAMBDA TYPES) + (SETQ typestring (CONCAT "NLambda " typestring] + (FORMAT.DEF NAME '(Macro) + (if (GET.ARG.SAV ARGS) + then (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" DUMP.CHARS (GET.ARG.SAV NAME) + DUMP.CHARS " " FONT ARG DUMP.CHARS (GET.ARG.SAV ARGS) + FONT LISP DUMP.CHARS ")") + else (SAVE.DUMPOUT FONT LISP DUMP.CHARS "(" DUMP.CHARS (GET.ARG.SAV NAME) + DUMP.CHARS ")")) + typestring]) + +(NOTE#TOPROG + [LAMBDA NIL (* mjs " 6-Aug-85 15:14") + (PROG ((IM.INDEX.FILE.FLG NIL) + (IM.REF.FLG NIL) + (IM.SEND.IMPLICIT NIL) + (IM.CHECK.DEFS NIL)) + (DECLARE (SPECVARS IM.INDEX.FILE.FLG IM.REF.FLG IM.SEND.IMPLICIT IM.CHECK.DEFS)) + (* make sure that no ptrs are sent + from TOs in a note or comment) + (if IM.NOTE.FLG + then (DUMPOUT FONT NOTE DUMP.CHARS "<<<< " DUMP.ARG DUMP.CHARS " >>>>") + else (FLUSH.ARG]) + +(PRINT.SPECIAL.CHARS#TOPROG + [LAMBDA NIL (* mjs " 4-Oct-85 13:45") + (PROG [(CHAR.STRING (SELECTQ TO.NAME + (ANONARG (MKSTRING (CHARACTER (CHARCODE 357,45)))) + (BULLET (MKSTRING (CHARACTER (CHARCODE %#7)))) + (CRSYMBOL (DUMPOUT START.SUPER DUMP.CHARS "cr" END.SUPER) + "") + (ELLIPSIS "...") + (EMDASH (MKSTRING (CHARACTER (CHARCODE 357,45)))) + (ENDASH (MKSTRING (CHARACTER (CHARCODE 357,44)))) + (GE ">=") + (LE "<=") + (NE "~=") + (PI "~PI~") + (PLUSMINUS "+-") + (SP " ") + (SHOULDNT] + (DUMPOUT DUMP.CHARS CHAR.STRING TRIVIAL.ARG]) + +(PROPDEF#TOPROG + [LAMBDA NIL (* mjs " 5-MAY-83 11:56") + (SAVE.ARGS NAME) + (FORMAT.DEF (PARSE.ATOM (GET.ARG.SAV NAME)) + '(Property Name) + (SAVE.DUMPOUT FONT LISP DUMP.CHARS (GET.ARG.SAV NAME]) + +(RBRACKET#TOPROG + [LAMBDA NIL (* mjs "10-Apr-85 09:50") + (IM.DUMP.CHARS "}") + (TRIVIAL.ARG]) + +(REF#TOPROG + [LAMBDA NIL (* mjs " 4-Aug-86 11:40") + (if (NOT IM.REF.FLG) + then (SAVE.ARG) + (IM.DUMP.CHARS (SELECTQ TO.NAME + (PAGEREF "page X.XX") + (SECTIONREF "section X.XX") + (FIGUREREF "figure X.X") + (SHOULDNT))) + else (PROG ((SAV (SAVE.ARG)) + (DEF.REFS NIL) + (PRIMARY.REFS NIL) + (SECONDARY.REFS NIL) + (MAX.REF NIL) + REF.STRING TYPE ARGS TEMP ARG.ATOM REFS) + (SETQ TEMP (PARSE.INDEX.SPEC SAV NIL)) + (if (OR (NULL TEMP) + (NULL (CAR TEMP))) + then (IM.WARNING "null index --- ignored") + (RETURN)) + (SETQ ARGS (CAR TEMP)) + (SETQ TYPE (if (EQ TO.NAME 'FIGUREREF) + then (* for FIGUREREF, ignore specified + type --- use TAG) + 'TAG + elseif (U-CASE (CDR TEMP)) + else 'TERM)) + [SETQ ARG.ATOM (U-CASE (MKATOM (LIST.TO.STRING ARGS] + + (* * only look at refs that have the correct type, AND that are not subentries + or subsub entries) + + (SETQ REFS (for X in (GETHASH ARG.ATOM IMPTR.HASH) + when [AND (EQUAL (if (U-CASE (fetch (IM.INDEX.DATA + TYPE) + of X)) + else 'TERM) + TYPE) + (NULL (LISTGET (fetch (IM.INDEX.DATA PROPLIST) + of X) + 'SUBNAME)) + (NULL (LISTGET (fetch (IM.INDEX.DATA PROPLIST) + of X) + 'SUBTEXT] collect X)) + (if (NULL REFS) + then (IM.WARNING " no refs for resolving {" TO.NAME " " TYPE " " + ARG.ATOM "} -- dummy used") + (IM.DUMP.CHARS (SELECTQ TO.NAME + (PAGEREF "page X.XX") + (SECTIONREF "section X.XX") + (FIGUREREF "figure X.X") + (SHOULDNT))) + (RETURN)) + + (* * REFS is list list of refs to index name ARG.ATOM of type TYPE, with + elements of form%: (type text info section file fileptr)) + + [for X in REFS + do (if (OR (AND (EQ TO.NAME 'FIGUREREF) + (MEMB '*FIGURE* (fetch (IM.INDEX.DATA INFO) + of X))) + (MEMB '*PRIMARY* (fetch (IM.INDEX.DATA INFO) + of X))) + then (SETQ PRIMARY.REFS (CONS X PRIMARY.REFS)) + elseif (MEMB '*DEF* (fetch (IM.INDEX.DATA INFO) of + X)) + then (SETQ DEF.REFS (CONS X DEF.REFS)) + else (SETQ SECONDARY.REFS (CONS X SECONDARY.REFS] + (SETQ MAX.REF (if PRIMARY.REFS + elseif DEF.REFS + else SECONDARY.REFS)) + (if (CDR MAX.REF) + then (IM.WARNING "multiple " + (if PRIMARY.REFS + then "primary" + elseif DEF.REFS + then "def" + else "secondary") + " refs for resolving {" TO.NAME " " TYPE " " ARG.ATOM + "} - first used")) + (SETQ MAX.REF (CAR MAX.REF)) + (SETQ REF.STRING + (SELECTQ TO.NAME + (PAGEREF [PROG ((CHAP.PAGE.LST (REF.TO.PAGE MAX.REF))) + (RETURN (if (EQ 0 (CAR CHAP.PAGE.LST)) + then (CONCAT "page " (CADR CHAP.PAGE.LST)) + else (CONCAT "page " (CAR CHAP.PAGE.LST) + "." + (CADR CHAP.PAGE.LST]) + (SECTIONREF (PROG ((SEC.LIST (REVERSE (fetch (IM.INDEX.DATA SUBSEC) + of X))) + SEC.STRING) + (SETQ SEC.STRING (if (CDR SEC.LIST) + then "section " + elseif (NUMBERP (CAR SEC.LIST)) + then "chapter " + else "appendix ")) + (if (EQ 0 (CAR SEC.LIST)) + then (SETQ SEC.LIST (CDR SEC.LIST))) + [for X on SEC.LIST + do (SETQ SEC.STRING + (CONCAT SEC.STRING (CAR X) + (if (CDR X) + then "." + else ""] + (RETURN SEC.STRING))) + (FIGUREREF [PROG [[CHAP.NUM (CAR (LAST (fetch (IM.INDEX.DATA SUBSEC) + of X] + (FIG.NUM (CADR (MEMB '*FIGURE* (fetch (IM.INDEX.DATA + INFO) + of X] + (RETURN (if (EQ 0 CHAP.NUM) + then (CONCAT "figure " FIG.NUM) + else (CONCAT "figure " CHAP.NUM "." FIG.NUM]) + (SHOULDNT))) + (IM.DUMP.CHARS REF.STRING]) + +(RM#TOPROG + [LAMBDA NIL (* mjs " 4-MAY-83 10:23") + (DUMPOUT FONT NIL DUMP.ARG]) + +(SUB#TOPROG + [LAMBDA NIL (* mjs "14-Dec-83 10:44") + (DUMPOUT START.SUB DUMP.ARG END.SUB]) + +(SUBSEC#TOPROG + [LAMBDA NIL (* mjs " 3-Oct-85 15:00") + (SAVE.ARGS TITLE) + (PROG ((SUBSEC.COUNT.LIST (CONS (SETQ SUBSEC.LAST.SUB (ADD1 SUBSEC.LAST.SUB)) + SUBSEC.COUNT.LIST)) + (SUBSEC.LAST.SUB 0) + PRINTING.TITLE SEC.STRING SEC.LIST CHAP.NUM) + (DECLARE (SPECVARS SUBSEC.COUNT.LIST SUBSEC.LAST.SUB)) + + (* SUBSEC.COUNT.LIST is a reverse list of the subsec numbers and chapter num, + so if this is subsec 3.5.7, SUBSEC.COUNT.LIST = + (7 5 3)) + (* set SUBSEC.SKIP.STRING to skip + before header (<<>>)) + (* set PRINTING.TITLE to subsec + title or with respect to the page *edges* .) + + + + +(* Note%: The formatting and printing does not always position the image on the page exactly as +specified. It will probably be necessary to adjust any variables based on the page edges until they +come out correctly on your printer.) + + + + +(* indentation of 1st line of definitian header, measured in points from left page margin. Also used + for indentation of hrule under defn header.) + + +(RPAQ? IM.DEF.TITLE.1STLEFTMARGIN 75) + + + +(* indentation of 2nd and other overflow lines of definition header, measured in points from left +page margin.) + + +(RPAQ? IM.DEF.TITLE.LEFTMARGIN 204) + + + +(* indentation of vertical rule to the left of definition text, measured in points from left page +margin. This is a never-used, never-debugged feature.) + + +(RPAQ? IM.VRULE.X 194) + + + +(* y-pos of top-left corner of top text line, measured in points from bottom page edge.) + + +(RPAQ? IM.TEXT.TOPMARGIN 738) + + + +(* y-pos of bottom-left corner of bottom text line, measured in points from bottom page edge.) + + +(RPAQ? IM.TEXT.BOTTOMMARGIN 54) + + + +(* x-pos of left edge of text, measured in points from the left page margin.) + + +(RPAQ? IM.TEXT.LEFTMARGIN 204) + + + +(* x-pos of right edge of text, measured in points from the left page margin.) + + +(RPAQ? IM.TEXT.RIGHTMARGIN 504) + + + +(* X-pos and Y-pos of the lower-left corner of the "[This page intentionally left blank]" message +printed on blank pages, measured in points from the left and bottom page edges.) + + +(RPAQ? IM.BLANKPAGE.SPECIALX 258) + +(RPAQ? IM.BLANKPAGE.SPECIALY 400) + + + +(* In the table of contents, indentation of first and second-level subsection headers, measured in +points from the left page margin.) + + +(RPAQ? IM.TOC.SUBSEC.ONE.LEFTMARGIN 120) + +(RPAQ? IM.TOC.SUBSEC.TWO.LEFTMARGIN 216) + + + +(* in the index, the indentation of the first line and remaining lines of a top-level entry, of a +subentry, and of a subsubentry, measured in points from the left page margin .) + + +(RPAQ? IM.INDEX.1STLEFTMARGIN 0) + +(RPAQ? IM.INDEX.LEFTMARGIN 75) + +(RPAQ? IM.INDEX.SUB.1STLEFTMARGIN 25) + +(RPAQ? IM.INDEX.SUB.LEFTMARGIN 75) + +(RPAQ? IM.INDEX.SUBSUB.1STLEFTMARGIN 50) + +(RPAQ? IM.INDEX.SUBSUB.LEFTMARGIN 75) + + + +(* on the title page, the y-pos of the lower-left corner of the first line in the title , measured in points from the bottom page margin. The X-pos is always 0 for the XEROX logo, + and the normal text indentation for the title.) + + +(RPAQ? IM.TITLEPAGE.TITLE.Y 258) + + + +(* on the title page, the y-pos of the lower-left corner of the first line in the document number, +measured in points from the bottom page margin. The Y-pos is always the normal text indentation.) + + +(RPAQ? IM.TITLEPAGE.DOCNUMBER.Y 45) + + + +(* Tedit tab setting used for subsection heading text. "(40 . LEFT)" determines the indentation of +the title after the subsec number, measured in points from the left page margin. "18" is the tab used +if the subsec number is wider than 40 pts.) + + +(RPAQ? IM.SUBSEC.TITLE.TABS '(18 (40 . LEFT))) + + + +(* Tedit tab setting used for chapter titles, headers, and footers to right-justify text. +"(504 . RIGHT)" specifies a right tab at the right-hand edge of the text, measured in points from the +left page margin.) + + +(RPAQ? IM.RIGHT.MARGIN.TABS '(0 (504 . RIGHT))) + + + +(* Tedit tab setting used for labeled lists, numbered lists, bullet-ed lists. "(186 . RIGHT)" +right-justifies the label on the left of the center space. "(204 . LEFT)" starts the first line of the + list item with the same indentation as normal text. Both measurements are measured in points from the + left page margin.) + + +(RPAQ? IM.LABELED.LIST.TABS '(18 (186 . RIGHT) + (204 . LEFT))) + + + +(* left, right, top, and bottom margins of the "page region" %, measured in points from the four +edges of the page.) + + +(RPAQ? IM.PAGE.LEFTMARGIN 58) + +(RPAQ? IM.PAGE.RIGHTMARGIN 54) + +(RPAQ? IM.PAGE.TOPMARGIN 54) + +(RPAQ? IM.PAGE.BOTTOMMARGIN 54) + + + +(* top margin of the page region for the first page of a chapter , measured in points from the top page edge.) + + +(RPAQ? IM.PAGE.FIRST.TOPMARGIN 12) + + + +(* top margin of the page region for the first page of the index, measured in points from the top +page edge. Note that in the case of the index, because it uses two columns, the index title is +implemented as a Tedit header, instead of as the first paragraph of the document.) + + +(RPAQ? IM.INDEX.PAGE.FIRST.TOPMARGIN 144) + + + +(* y-pos of lower-left corner of footer text, measured in points from the bottom page edge.) + + +(RPAQ? IM.FOOTER.Y 22) + + + +(* y-pos of the footer hrule, measured in points from the bottom page edge.) + + +(RPAQ? IM.FOOTER.RULE.Y 30) + + + +(* y-pos of lower-left corner of header text, measured in points from the bottom page edge.) + + +(RPAQ? IM.HEADER.Y 761) + + + +(* y-pos of the header hrule, measured in points from the bottom page edge.) + + +(RPAQ? IM.HEADER.RULE.Y 757) + + + +(* y-pos of lower-left corner of bottom draft message, measured in points from the bottom page edge. +) + + +(RPAQ? IM.DRAFT.MESSAGE.BOTTOM.Y 5) + + + +(* y-pos of lower-left corner of top draft message, measured in points from the bottom page edge.) + + +(RPAQ? IM.DRAFT.MESSAGE.TOP.Y 775) + + + +(* x-pos of lower-left corner of both top and bottom draft messages, measured in points from the +left page edge.) + + +(RPAQ? IM.DRAFT.MESSAGE.X 200) + +(FILESLOAD TEDIT IMTRAN HRULE IMINDEX) +(DEFINEQ + +(TRANSLATE.DUMPOUT + [LAMBDA (DUMPOUT.ARGS) (* mjs "18-Sep-85 16:17") + + (* * this function translates the DUMPOUT macro form into a PROGN form that + calls a series of functions, such as DUMP.) + + (* * the indentation code has been commented out --- + will try indenting everything to same, unless specified otherwise with + PARALOOKS) + + (PROG ((DUMPOUT.FORMS NIL) + (DUMPOUT.UNDO NIL) + COMM COMM.ARG) + [while DUMPOUT.ARGS do (SELECTQ (SETQ COMM (pop DUMPOUT.ARGS)) + (NIL) + ((CR TAB START.PARA DUMP.FOOTNOTES START.SUPER START.SUB + END.SUPER END.SUB) + (* just pass these atoms as commands + to DUMP) + (push DUMPOUT.FORMS (LIST 'DUMP.FORMAT + (KWOTE COMM)))) + ((FLUSH.ARG TRIVIAL.ARG DUMP.ARG) + (push DUMPOUT.FORMS (LIST COMM))) + (INDENT + + (* * SELECTQ (SETQ COMM.ARG (pop DUMPOUT.ARGS)) + (INIT (push DUMPOUT.FORMS (QUOTE (PUT.MY.PROP + (QUOTE INDENT) INITIAL.INDENT))) (push DUMPOUT.FORMS + (QUOTE (PUT.MY.PROP (QUOTE WIDTH) INITIAL.WIDTH))) + (push DUMPOUT.FORMS (QUOTE (DUMP.FORMAT + (QUOTE INDENT) INITIAL.INDENT)))) (NONE + (push DUMPOUT.FORMS (QUOTE (PUT.MY.PROP + (QUOTE INDENT) (QUOTE NONE)))) (push DUMPOUT.FORMS + (QUOTE (PUT.MY.PROP (QUOTE WIDTH) (ANC.WIDTH)))) + (push DUMPOUT.FORMS (QUOTE (DUMP.FORMAT + (QUOTE INDENT) (QUOTE NONE))))) (push DUMPOUT.FORMS + (LIST (QUOTE (LAMBDA (I) (PUT.MY.PROP (QUOTE INDENT) + (IPLUS (ANC.INDENT) I)) (PUT.MY.PROP (QUOTE WIDTH) + (IDIFFERENCE (ANC.WIDTH) I)) (DUMP.FORMAT + (QUOTE INDENT) (IPLUS (ANC.INDENT) I)))) COMM.ARG))) + + (* * push DUMPOUT.UNDO (QUOTE INDENT)) + + (SETQ COMM.ARG (pop DUMPOUT.ARGS))) + (WIDTH (push DUMPOUT.FORMS + (LIST 'PUT.MY.PROP (KWOTE 'WIDTH) + (pop DUMPOUT.ARGS)))) + (FONT (SETQ COMM.ARG (pop DUMPOUT.ARGS)) + [push DUMPOUT.FORMS + (LIST 'DUMP.FORMAT (KWOTE 'FONT) + (COND + ((LISTGET IM.TEDIT.FONT.DEFS + COMM.ARG) + (KWOTE COMM.ARG)) + (T COMM.ARG] + (push DUMPOUT.UNDO 'FONT)) + (PARALOOKS (push DUMPOUT.FORMS + (LIST 'DUMP.FORMAT (KWOTE 'PARALOOKS) + (pop DUMPOUT.ARGS)))) + (DUMP.CHARS (push DUMPOUT.FORMS + (LIST (FUNCTION IM.DUMP.CHARS) + (pop DUMPOUT.ARGS)))) + (push DUMPOUT.FORMS (LIST 'DUMP.FORMAT + (KWOTE 'TEXT) + (LIST 'MAKE.SAVE COMM] + [for X in DUMPOUT.UNDO do (push DUMPOUT.FORMS (LIST 'DUMP.FORMAT + (KWOTE 'UNDO) + (KWOTE X] + + (* * push DUMPOUT.FORMS (QUOTE (PUT.MY.PROP + (QUOTE INDENT) DUMPOUT.SAVE.INDENT))) + + (* * push DUMPOUT.FORMS (QUOTE (PUT.MY.PROP + (QUOTE WIDTH) DUMPOUT.SAVE.WIDTH))) + + (* * RETURN (APPEND (QUOTE (PROG ((DUMPOUT.SAVE.INDENT + (GET.MY.PROP (QUOTE INDENT))) (DUMPOUT.SAVE.WIDTH + (GET.MY.PROP (QUOTE WIDTH)))))) (DREVERSE DUMPOUT.FORMS))) + + (RETURN (CONS 'PROGN (DREVERSE DUMPOUT.FORMS]) + +(TRANSLATE.SAVE.DUMPOUT + [LAMBDA (SAVE.DUMPOUT.ARGS) (* mjs "12-Jan-84 15:00") + (LSUBST SAVE.DUMPOUT.ARGS 'XXX '(PROG ((GOBBLE.SAVE.CONC (CONS))) + (DECLARE (SPECVARS GOBBLE.SAVE.CONC)) + (DUMPOUT XXX) + (RETURN GOBBLE.SAVE.CONC]) +) +(DECLARE%: EVAL@COMPILE + +[PUTPROPS IM.HOLD.FOOTNOTES MACRO (X `(PROG NIL + (PUT.MY.PROP 'PASSFOOT T) + %,@ + X (PUT.MY.PROP 'PASSFOOT NIL) + (DUMPOUT CR CR DUMP.FOOTNOTES] + +(PUTPROPS DUMPOUT MACRO (X (TRANSLATE.DUMPOUT X))) + +(PUTPROPS SAVE.DUMPOUT MACRO (X (TRANSLATE.SAVE.DUMPOUT X))) +) +(PUTPROPS IMTEDIT COPYRIGHT ("Xerox Corporation" 1983 1984 1985 1986 1991)) +(DECLARE%: DONTCOPY + (FILEMAP (NIL (10973 37992 (IM.TEDIT 10983 . 12664) (DUMP 12666 . 14961) (DUMP.HEADERS.FOOTERS 14963 + . 17329) (DUMP.HRULE 17331 . 18482) (CHANGE.FONT 18484 . 19678) (IM.BOUT.IMAGEOBJ 19680 . 20003) ( +IM.TEDIT.DUMP.COMMANDS 20005 . 23558) (IM.TEDIT.DUMP.FOOTNOTES 23560 . 24001) (IM.TEDIT.DUMP.PARA +24003 . 24777) (INDEXX.PARSE.TYPE 24779 . 26074) (FORMAT.DEF 26076 . 28207) (FORMAT.LISPWORD 28209 . +28360) (MAKE.IM.DOCUMENT 28362 . 36847) (PRINT.NOTE 36849 . 37063) (SEND.INFO 37065 . 37990)) (38101 +42119 (IM.VRULE.DISPLAYFN 38111 . 38435) (CREATE.VRULE.OBJECT 38437 . 40217) (PRINT.VRULES.ON.PAGE +40219 . 42117)) (42277 47032 (IM.FOLIO.DISPLAYFN 42287 . 42965) (IM.FOLIO.SIZEFN 42967 . 43816) ( +CREATE.FOLIO.OBJECT 43818 . 45364) (GET.FOLIO.STRING 45366 . 47030)) (47164 93404 (ARG#TOPROG 47174 . +47313) (BIGLISPCODE#TOPROG 47315 . 48551) (BRACKET#TOPROG 48553 . 48717) (CHAPTER#TOPROG 48719 . 51400 +) (COMMENT#TOPROG 51402 . 51954) (DEF#TOPROG 51956 . 55291) (FIGURE#TOPROG 55293 . 56637) (FN#TOPROG +56639 . 57036) (FNDEF#TOPROG 57038 . 60930) (FOOT#TOPROG 60932 . 61473) (INCLUDE#TOPROG 61475 . 61790) + (INDEX#TOPROG 61792 . 62882) (INDEXX#TOPROG 62884 . 64965) (IT#TOPROG 64967 . 65108) (LBRACKET#TOPROG + 65110 . 65264) (LISP#TOPROG 65266 . 65407) (LISPCODE#TOPROG 65409 . 66528) (LISPWORD#TOPROG 66530 . +67270) (LIST#TOPROG 67272 . 71694) (MACDEF#TOPROG 71696 . 72874) (NOTE#TOPROG 72876 . 73556) ( +PRINT.SPECIAL.CHARS#TOPROG 73558 . 74535) (PROPDEF#TOPROG 74537 . 74814) (RBRACKET#TOPROG 74816 . +74970) (REF#TOPROG 74972 . 82811) (RM#TOPROG 82813 . 82951) (SUB#TOPROG 82953 . 83101) (SUBSEC#TOPROG +83103 . 87606) (SUPER#TOPROG 87608 . 87762) (TABLE#TOPROG 87764 . 91716) (TAG#TOPROG 91718 . 91985) ( +TERM#TOPROG 91987 . 92300) (VAR#TOPROG 92302 . 92705) (VARDEF#TOPROG 92707 . 93402)) (110656 116084 ( +TRANSLATE.DUMPOUT 110666 . 115683) (TRANSLATE.SAVE.DUMPOUT 115685 . 116082))))) +STOP diff --git a/docs/Documentation Tools/IMTEDIT.LCOM b/docs/Documentation Tools/IMTEDIT.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..1e48a11daa651925cfbfe28c1c0048f3c65a55dd GIT binary patch literal 63640 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.;2 65965 + + changes to%: (VARS IMTOOLSCOMS) + (FNS GRAB.IMPTR PRINT.INDEX.OBJECT REF.TO.PAGE) + + previous date%: " 4-Sep-91 18:04:53" {DSK}sybalsky>PUBS>IMTOOLS.;1) + + +(* ; " +Copyright (c) 1985, 1986, 1987, 1988, 1991 by Xerox Corporation. All rights reserved. +") + +(PRETTYCOMPRINT IMTOOLSCOMS) + +(RPAQQ IMTOOLSCOMS + ( (* ; + "Maintainance Functions: generating indexes, etc") + (FNS ADD.IM.MENU COLLECT.MODIFIED.IM.CHAPTERS DO.INDEX DO.MANUAL GRAB.IM.MANUAL.PTRS + GRAB.IMPTR IM.COMMAND.MENU IM.TEDIT.SELECTION INIT.INDEX.VARS INSERT.CHARS.AROUND.SEL + INTERPRET.IM.MENU.COMMAND MAKE.IM.TITLE MAKE.IM.TOC NEWTO PRINT.INDEX.OBJECT + PRINT.INDEX.SUBREFS PROCESS.IM.CHAPTERS REF.TO.PAGE REFS.TO.PAGES) + (COMS (FNS MAKE.IM.INDEX)) + (VARS IM.MANUAL.CHAPTERS IM.MANUAL.VOLUMES) + (VARS (IM.MANUAL.DIRECTORY '"{PELE:}IRM>")) + (FILES IMTEDIT FREEMENU))) + + + +(* ; "Maintainance Functions: generating indexes, etc") + +(DEFINEQ + +(ADD.IM.MENU + [LAMBDA (WINDOW) (* mjs "12-Jul-85 15:20") + (ATTACHMENU (create MENU + ITEMS _ '(fn var arg lisp FnDef VarDef Text Name Args lispcode U-CASE CLOSE) + WHENSELECTEDFN _ (FUNCTION INTERPRET.IM.MENU.COMMAND)) + WINDOW + 'RIGHT + 'TOP]) + +(COLLECT.MODIFIED.IM.CHAPTERS + [LAMBDA NIL (* mjs "29-Jul-85 17:09") + (* check which chapters have been + updated since they were last + processed) + (for CHAPTER.FILE.LIST in IM.MANUAL.CHAPTERS + when (PROG ((IPFILE (FINDFILE (PACKFILENAME 'EXTENSION 'IP 'BODY (CADR CHAPTER.FILE.LIST)) + T)) + (IMPTRFILE (FINDFILE (PACKFILENAME 'EXTENSION 'IMPTR 'BODY (CADR + CHAPTER.FILE.LIST + )) + T)) + EARLIEST.IDATE) + (printout T "checking " (CADR CHAPTER.FILE.LIST) + "...") + (if (OR (NULL IPFILE) + (NULL IMPTRFILE)) + then (* process if IP or IMPTR file + doesn't exist) + (printout T "will reprocess" T) + (RETURN T)) + [SETQ EARLIEST.IDATE (IMIN (GETFILEINFO IPFILE 'ICREATIONDATE) + (GETFILEINFO IMPTRFILE 'ICREATIONDATE] + (if (for IMFILE in (CDR CHAPTER.FILE.LIST) bind FULLFILE + thereis (AND (SETQ FULLFILE (FINDFILE (PACKFILENAME 'EXTENSION + 'IM + 'BODY IMFILE) + T)) + (IGREATERP (GETFILEINFO FULLFILE 'ICREATIONDATE) + EARLIEST.IDATE))) + then (printout T "will reprocess" T) + (RETURN T) + else (printout T "OK" T) + (RETURN NIL))) collect (LIST (CAR CHAPTER.FILE.LIST) + (CADR CHAPTER.FILE.LIST]) + +(DO.INDEX + [LAMBDA NIL (* mjs "23-Sep-85 14:10") + (printout T "creating Index" T) + (MAKE.IM.INDEX '{DSK}ChapIndex.IP IM.MANUAL.VOLUMES) + [if (INFILEP '{DSK}ChapIndex.IP) + then (RENAMEFILE '{DSK}ChapIndex.IP (PACK* IM.MANUAL.DIRECTORY 'ChapIndex.IP] + (for X in (CONS '(Master) + IM.MANUAL.VOLUMES) bind LOCALFILE REMOTEFILE + do (SETQ LOCALFILE (PACK* '{DSK}ChapTOC- (CAR X) + '.IP)) + (SETQ REMOTEFILE (PACK* IM.MANUAL.DIRECTORY 'ChapTOC- (CAR X) + '.IP)) + (printout T "creating TOC for vol: " (CAR X) + T) + (MAKE.IM.TOC LOCALFILE (CDR X)) + (if (INFILEP LOCALFILE) + then (RENAMEFILE LOCALFILE REMOTEFILE))) + (for X in IM.MANUAL.CHAPTERS do (printout T "making TOC for chapter: " X T) + (MAKE.IM.TOC (PACK* IM.MANUAL.DIRECTORY + (CADR X) + '-TOC.IP) + (CAR X))) + (for X in '((I "Volume I: Language" 3101272 "October, 1985") + (II "Volume II: Environment" 3101273 "October, 1985") + (III "Volume III: Input/Output" 3101274 "October, 1985")) + do (MAKE.IM.TITLE (PACK* IM.MANUAL.DIRECTORY "ChapTitle-" (CAR X) + '.IP) + (CADR X) + (CADDR X) + (CADDDR X]) + +(DO.MANUAL + [LAMBDA (CHAPNAMES MAKE.INDEX.FLG GET.REFS NO.IP.FLG) (* mjs "12-Oct-85 14:18") + (PROG ((IM.NOTE.FLG NIL) + (IM.CHECK.DEFS NIL) + (IM.REF.FLG NIL) + (IM.INDEX.FILE.FLG T) + (IM.DRAFT.FLG NIL) + (IM.EVEN.FLG T)) + (CNDIR '{DSK}) + (if GET.REFS + then (INIT.INDEX.VARS) + (GRAB.IM.MANUAL.PTRS) + (SETQ IM.REF.FLG T)) + (PROCESS.IM.CHAPTERS CHAPNAMES NO.IP.FLG) + (if MAKE.INDEX.FLG + then (INIT.INDEX.VARS) + (GRAB.IM.MANUAL.PTRS) + (DO.INDEX]) + +(GRAB.IM.MANUAL.PTRS + [LAMBDA NIL (* mjs "25-Sep-85 15:47") + (INIT.INDEX.VARS) + (for X in IM.MANUAL.CHAPTERS unless (MEMB (U-CASE (CADR X)) + '(CHAPACK CHAT)) + do (GRAB.IMPTR (PACKFILENAME 'BODY (CADR X) + 'BODY IM.MANUAL.DIRECTORY]) + +(GRAB.IMPTR + [LAMBDA (IMPTR.FILE.NAME KEEP.IMPLICIT.REFS.FLG IMPTR.TYPES) + (* ; "Edited 8-Dec-91 14:20 by jds") + + (* ;; "Reads the IMPTR file IMPTR.FILE.NAME, and puts the refs in the variables IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST. If KEEP.IMPLICIT.REFS.FLG is non-NIL, implicit references are kept. If IMPTR.TYPES is non-NIL, it should be a list of reference types that should be retrieved. For example 'IMPTR.TYPES=((Function)(Variable))' to retrieve only function and variable references.") + + (PROG ((PTRFILE (OPENSTREAM (FINDFILE (PACKFILENAME 'BODY (U-CASE IMPTR.FILE.NAME) + 'EXTENSION + 'IMPTR) + T) + 'INPUT + 'OLD)) + DATUM) + (COND + (KEEP.IMPLICIT.REFS.FLG (printout T T + " *** WARNING: implicit references will be included ***" + T T))) + (COND + ((NOT (BOUNDP 'IMPTR.HASH)) + (INIT.INDEX.VARS))) + [while [SETQ DATUM (CAR (NLSETQ (READ PTRFILE] + do (COND + ((NOT (type? IM.INDEX.DATA DATUM)) + (printout T "bad datum -- " DATUM T)) + ([MEMBER (MKLIST (fetch (IM.INDEX.DATA TYPE) of DATUM)) + '((CHAPTER) + (SUBSEC) + (APPENDIX] + + (* ;; "map (CHAPTER) => CHAPTER. We want to allow these words in a list, so that users can create TOC entries using IMINDEX.") + + [replace (IM.INDEX.DATA TYPE) of DATUM + with (CAR (MKLIST (fetch (IM.INDEX.DATA TYPE) of DATUM] + (SETQ IMPTR.TOC.LIST (CONS DATUM IMPTR.TOC.LIST))) + ((AND (NOT KEEP.IMPLICIT.REFS.FLG) + (MEMB '*IMPLICIT* (fetch (IM.INDEX.DATA INFO) of DATUM))) + (* ; + "unless KEEP.IMPLICIT.REFS.FLG is true, flush implicit references") + NIL) + ((AND IMPTR.TYPES (NOT (MEMBER (fetch (IM.INDEX.DATA TYPE) of DATUM) + IMPTR.TYPES))) + (* ; + "if IMPTR.TYPES is non-NIL, flush references that do not have one of these types.") + NIL) + (T [COND + ((NULL (fetch (IM.INDEX.DATA TYPE) of DATUM)) + (replace (IM.INDEX.DATA TYPE) of DATUM with 'TERM] + [COND + ((NOT (GETHASH (fetch (IM.INDEX.DATA NAME) of DATUM) + IMPTR.HASH)) + (SETQ IMPTR.NAME.LIST (CONS (fetch (IM.INDEX.DATA NAME) + of DATUM) + IMPTR.NAME.LIST] + (PUTHASH (fetch (IM.INDEX.DATA NAME) of DATUM) + (CONS DATUM (GETHASH (fetch (IM.INDEX.DATA NAME) of DATUM) + IMPTR.HASH)) + IMPTR.HASH] + (CLOSEF PTRFILE]) + +(IM.COMMAND.MENU + [LAMBDA (MENU.POS) (* mjs "24-Jul-85 17:02") + (ADDMENU (create MENU + ITEMS _ '[(|FORMAT TEDIT SELECTION| (IM.TEDIT.SELECTION)) + (|Add IM Menu| (ADD.IM.MENU (WHICHW (GETPOSITION] + TITLE _ "IM commands") + NIL + (if MENU.POS + else (GETPOSITION]) + +(IM.TEDIT.SELECTION + [LAMBDA NIL (* mjs "30-Jul-85 12:01") + (PROG ((TEDITW (WHICHW (GETPOSITION))) + TSTREAM TSTREAMSEL SELSTREAM FIRSTCHAR ENDCHAR) (* make sure that error window won't + pagehold) + (WINDOWPROP (WFROMDS (TTYDISPLAYSTREAM)) + 'PAGEFULLFN + (FUNCTION NILL)) + (if [OR (NULL TEDITW) + (NULL (WINDOWPROP TEDITW 'TEXTSTREAM] + then (RETURN)) + (SETQ TSTREAM (TEXTSTREAM TEDITW)) + (SETQ TSTREAMSEL (TEDIT.GETSEL TSTREAM)) + (SETQ SELSTREAM (OPENTEXTSTREAM)) + (SETQ FIRSTCHAR (SUB1 (fetch (SELECTION CH#) of TSTREAMSEL))) + (SETQ ENDCHAR (IPLUS FIRSTCHAR (fetch (SELECTION DCH) of TSTREAMSEL))) + (SETFILEPTR TSTREAM FIRSTCHAR) + [for X from 1 to (IDIFFERENCE ENDCHAR FIRSTCHAR) bind C + do (SETQ C (BIN TSTREAM)) + (if (SMALLP C) + then (BOUT SELSTREAM C) + elseif (IMAGEOBJP C) + then (TEDIT.INSERT.OBJECT C SELSTREAM (ADD1 (GETFILEPTR SELSTREAM))) + (SETFILEPTR SELSTREAM (GETEOFPTR SELSTREAM] + (for X in '(FORMATSELDUMMY.IM FORMATSELDUMMY.IMERR FORMATSELDUMMY.IMPTR) + when (INFILEP X) do (printout T "deleting " X T) + (DELFILE X)) + (TEDIT.PUT SELSTREAM 'FORMATSELDUMMY.IM) + (TEDIT.KILL SELSTREAM) + (TEDIT (IM.TEDIT 'FORMATSELDUMMY.IM T]) + +(INIT.INDEX.VARS + [LAMBDA NIL (* mjs " 6-Aug-86 09:49") + (SETQ IMPTR.HASH (HASHARRAY 5000)) + (SETQ IMPTR.NAME.LIST NIL) + (SETQ IMPTR.TOC.LIST NIL]) + +(INSERT.CHARS.AROUND.SEL + [LAMBDA (TEXTSTREAM BEFORETEXT AFTERTEXT) (* mjs " 8-May-85 11:46") + (PROG [(FIRSTCHAR (fetch (SELECTION CH#) of (TEDIT.GETSEL TEXTSTREAM))) + (AFTERLASTCHAR (fetch (SELECTION CHLIM) of (TEDIT.GETSEL TEXTSTREAM] + (TEDIT.INSERT TEXTSTREAM AFTERTEXT AFTERLASTCHAR) + (TEDIT.INSERT TEXTSTREAM BEFORETEXT FIRSTCHAR]) + +(INTERPRET.IM.MENU.COMMAND + [LAMBDA (ITEM MENU MOUSEKEY) (* mjs "12-Jul-85 15:19") + (PROG [(TS (TEXTSTREAM (MAINWINDOW (WFROMMENU MENU] + (if (EQ ITEM 'CLOSE) + then (DETACHWINDOW (WFROMMENU MENU)) + (CLOSEW (WFROMMENU MENU)) + elseif (EQ ITEM 'U-CASE) + then (PROG [(CH# (fetch (SELECTION CH#) of (TEDIT.GETSEL TS))) + (NEW (U-CASE (TEDIT.SEL.AS.STRING TS] + (TEDIT.DELETE TS (TEDIT.GETSEL TS)) + (TEDIT.INSERT TS NEW) + (TEDIT.SETSEL TS CH# (NCHARS NEW) + 'LEFT)) + else (INSERT.CHARS.AROUND.SEL TS (CONCAT "{" ITEM + (if (EQ ITEM 'Text) + then (CHARACTER (CHARCODE CR)) + else " ")) + "}"]) + +(MAKE.IM.TITLE + [LAMBDA (OUTFILE.FLG SUBTITLE DOCNUMBER DOCDATE) (* mjs "23-Sep-85 14:05") + (PROG ((SUBSEC.COUNT.LIST (LIST (LIST NIL "" "ii" "iii" "iv"))) + (IM.EVEN.FLG NIL)) + (DECLARE (SPECVARS SUBSEC.COUNT.LIST IM.EVEN.FLG)) + (RETURN (MAKE.IM.DOCUMENT [LIST (FUNCTION (LAMBDA NIL + (DUMPOUT FONT IM.CHAPTER.TITLE.FONT PARALOOKS + `(SPECIALX 0 SPECIALY %, + IM.TITLEPAGE.TITLE.Y) + DUMP.CHARS + "Interlisp-D Reference Manual" CR CR + PARALOOKS `(SPECIALX 0 SPECIALY %, + (DIFFERENCE + IM.TITLEPAGE.TITLE.Y + 20)) + DUMP.CHARS SUBTITLE CR CR) + (DUMPOUT FONT IM.XEROX.LOGO.FONT PARALOOKS + `(LEFTMARGIN 0 1STLEFTMARGIN 0 SPECIALX + 0 SPECIALY %, + IM.TITLEPAGE.TITLE.Y) + DUMP.CHARS "XEROX" CR CR) + (DUMPOUT FONT IM.SUBSEC.THREE.TITLE.FONT + PARALOOKS + `(SPECIALX 0 SPECIALY %, + IM.TITLEPAGE.DOCNUMBER.Y) + DUMP.CHARS DOCNUMBER CR CR PARALOOKS + `(SPECIALX 0 SPECIALY %, + (DIFFERENCE + IM.TITLEPAGE.DOCNUMBER.Y + 12)) + DUMP.CHARS DOCDATE CR CR) + (DUMPOUT FONT IM.SUBSEC.THREE.TITLE.FONT + PARALOOKS + `(SPECIALX 0 SPECIALY %, + IM.TITLEPAGE.TITLE.Y + NEWPAGEBEFORE T) + DUMP.CHARS + "Copyright (c) 1985 Xerox Corporation" + CR CR FONT NIL DUMP.CHARS + "All rights reserved." CR CR PARALOOKS + '(QUAD JUSTIFIED) + DUMP.CHARS "Portions from %"Interlisp Reference Manual%" Copyright (c) 1983 Xerox Corporation, and %"Interlisp Reference Manual%" Copyright (c) 1974, 1975, 1978 Bolt, Beranek & Newman and Xerox Corporation." + CR CR DUMP.CHARS "This publication may not be reproduced or transmitted in any form by any means, electronic, microfilm, xerography, or otherwise, or incorporated into any information retrieval system, without the written permission of Xerox Corporation." + CR CR] + OUTFILE.FLG NIL "Hardcopy of Title Page"]) + +(MAKE.IM.TOC + [LAMBDA (OUTFILE.FLG CHAPTER.NUMBERS IMPTR.FILES) (* mjs "12-Aug-86 09:54") + + (* * CHAPTER.NUMBERS is either%: NIL, meaning to generate TOC of ALL data + available; a single number, meaning to generate a chapter TOC for that chapter; + or a list of numbers, meaning to generate a TOC for those chapters) + + (PROG* ([IMPTR.DATA (if IMPTR.FILES + then (PROG ((IMPTR.HASH (HASHARRAY 50)) + (IMPTR.TOC.LIST NIL) + (IMPTR.NAME.LIST NIL)) + (DECLARE (SPECVARS IMPTR.HASH IMPTR.TOC.LIST + IMPTR.NAME.LIST)) + [for X in (MKLIST IMPTR.FILES) + do (printout T "Grabbing IMPTR file: " X T) + + (* * the IMPTR.TYPES arg to GRAB.IMPTR is a list containing no possible types, + so that no index entries will be saved.) + + (GRAB.IMPTR X NIL '(XXXXXXXXX] + (RETURN (LIST IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST] + (IMPTR.HASH (if IMPTR.FILES + then (CAR IMPTR.DATA) + else IMPTR.HASH)) + (IMPTR.TOC.LIST (if IMPTR.FILES + then (CADR IMPTR.DATA) + else IMPTR.TOC.LIST)) + (IMPTR.NAME.LIST (if IMPTR.FILES + then (CADDR IMPTR.DATA) + else IMPTR.NAME.LIST)) + (SINGLE.CHAP.TOC.FLG (NUMBERP CHAPTER.NUMBERS)) + (SUBSEC.COUNT.LIST '(TOC)) + (MAKE.IM.TOC.TITLE (if (NULL CHAPTER.NUMBERS) + then "MASTER TABLE OF CONTENTS" + else "TABLE OF CONTENTS")) + MAKE.IM.TOC.LIST) + (DECLARE (SPECVARS SINGLE.CHAP.TOC.FLG SUBSEC.COUNT.LIST MAKE.IM.TOC.TITLE + MAKE.IM.TOC.LIST IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST)) + (SETQ MAKE.IM.TOC.LIST (if (NULL CHAPTER.NUMBERS) + then (APPEND IMPTR.TOC.LIST) + else (for X in IMPTR.TOC.LIST + bind (CHLST _ (MKLIST CHAPTER.NUMBERS)) + when (MEMB (CAR (LAST (fetch (IM.INDEX.DATA + SUBSEC) + of X))) + CHLST) collect X))) + [SORT MAKE.IM.TOC.LIST (FUNCTION (LAMBDA (A B) + (LIST.ORDER (REVERSE (fetch (IM.INDEX.DATA SUBSEC) + of A)) + (REVERSE (fetch (IM.INDEX.DATA SUBSEC) + of B] + (RETURN + (MAKE.IM.DOCUMENT + [LIST + (FUNCTION (LAMBDA NIL + (DUMP.HEADERS.FOOTERS MAKE.IM.TOC.TITLE MAKE.IM.TOC.TITLE) + (DUMPOUT FONT IM.CHAPTER.TITLE.FONT PARALOOKS + `(PARALEADING 0 LINELEADING 0 QUAD LEFT TABS %, IM.RIGHT.MARGIN.TABS + ) + TAB DUMP.CHARS MAKE.IM.TOC.TITLE CR CR) + (DUMP.HRULE 6) + (DUMPOUT START.PARA FONT NIL PARALOOKS '(PARALEADING 93 LINELEADING 0) + DUMP.CHARS " " CR CR) + (for TOC.PTR on MAKE.IM.TOC.LIST bind TOC.LINE + do + (SETQ TOC.LINE (CAR TOC.PTR)) + (PROG ((SECTION.STRING "") + (SEC.LIST (REVERSE (fetch (IM.INDEX.DATA SUBSEC) of + TOC.LINE))) + (PAGE.LIST (REF.TO.PAGE TOC.LINE)) + MAJOR.SECTION.FLG LINE.PARA LINE.INDENT) + (SETQ MAJOR.SECTION.FLG (EQLENGTH SEC.LIST 1)) + [for X on SEC.LIST + do (SETQ SECTION.STRING (CONCAT SECTION.STRING (CAR X) + (if (CDR X) + then "." + else ""] + (SETQ LINE.INDENT (if MAJOR.SECTION.FLG + then 0 + elseif (EQLENGTH SEC.LIST 2) + then IM.TOC.SUBSEC.ONE.LEFTMARGIN + else IM.TOC.SUBSEC.TWO.LEFTMARGIN)) + (SETQ LINE.PARA (LIST '1STLEFTMARGIN LINE.INDENT 'LEFTMARGIN + (PLUS LINE.INDENT 72) + 'QUAD + 'LEFT + 'TABS IM.RIGHT.MARGIN.TABS)) + (DUMPOUT PARALOOKS (APPEND '(HEADINGKEEP ON) + LINE.PARA) + FONT + (if MAJOR.SECTION.FLG + then IM.SUBSEC.ONE.TITLE.FONT + else IM.SUBSEC.THREE.TITLE.FONT) + DUMP.CHARS SECTION.STRING DUMP.CHARS ". " DUMP.CHARS + [PROG ((SAV (fetch (IM.INDEX.DATA SAV) of TOC.LINE) + )) + (if (NLISTP SAV) + then (SETQ SAV (CHCON SAV))) + (RETURN (CONS SAV (LAST SAV] + TAB FONT NIL DUMP.CHARS (CONCAT (CAR PAGE.LIST) + "." + (CADR PAGE.LIST)) + CR CR) + (DUMP.HRULE + 1 NIL + (APPEND + (if [AND MAJOR.SECTION.FLG + (EQP (CAR SEC.LIST) + (CAR (REVERSE (fetch (IM.INDEX.DATA SUBSEC + ) + of (CADR TOC.PTR] + then (* if this is a major heading, and + there are subheadings, prevent a + pagebreak here) + '(HEADINGKEEP ON) + else NIL) + LINE.PARA] + OUTFILE.FLG NIL "Hardcopy of Table of Contents"]) + +(NEWTO + [LAMBDA (NAME) (* mjs " 8-APR-83 16:43") + (SETQ NAME (U-CASE NAME)) + (PROG ((TO.PROG.NAME (PACK* NAME "#TOPROG"))) + [COND + ((FMEMB NAME TO.NAME.LIST) + (printout T "$$$ WARNING --- " NAME " already defined as TO --- will redefine " + TO.PROG.NAME)) + (T (SETQ TO.NAME.LIST (CONS NAME TO.NAME.LIST] + (replace TO.PROG of NAME with TO.PROG.NAME) + (DEFINE (LIST (CONS TO.PROG.NAME '(NIL (STANDARD.DUMMY.TO.PROG]) + +(PRINT.INDEX.OBJECT + [LAMBDA (NAM LST VOLUME.INFO SUB.LEVEL) (* ; "Edited 8-Dec-91 15:10 by jds") + +(* ;;; "LST is a list of index refs") + +(* ;;; "VOLUME.INFO is a list of elements, where each element describes the 'name' of a given volume, and what chapters go into it. Example: ((I 1 2 3) (II 4 5) (III 6 7 8)) means that chapters 1-3 go into volume 'I' . If NIL, the index entries are not divided into volumes") + +(* ;;; "SUB.LEVEL is NIL if called to print a top-level index entry, 1 if called recursively for first-level subentries, or 2 for second-level subentries.") + +(* ;;; "for now, as the type we will just yank the type of the first index reference. Eventually may want to find the one which looks like it has the case-info most 'correct'") + + (PROG ([TYP (COND + ((fetch (IM.INDEX.DATA TYPE) of (CAR LST))) + (T 'TERM] + DEF.REFS OTHER.DEF.REFS REF.TEXT REF SUB.REFS) + (COND + ((EQ TYP 'TAG) (* ; "ignore TAG index entries") + (RETURN)) + ([NOT (OR (LISTP TYP) + (EQ TYP 'TERM] + (SHOULDNT "bad TYP given to PRINT.INDEX.OBJECT"))) + +(* ;;; "temporary: throw out all *END* references") + + [SETQ LST (for X in LST collect X unless (MEMB '*END* (fetch + (IM.INDEX.DATA + INFO) of X] + (COND + ((NULL LST) + (RETURN))) + +(* ;;; "seperate out all sub-index entries now, to be processed after this the main one") + + (SETQ SUB.REFS (for X in LST when [PROG ((PLIST (fetch (IM.INDEX.DATA + PROPLIST) + of X))) + (RETURN (OR (LISTGET PLIST 'SUBNAME) + (LISTGET PLIST 'SUBTEXT] + collect X)) + (SETQ LST (LDIFFERENCE LST SUB.REFS)) + +(* ;;; "if all refs are subrefs, generate a dummy ref") + + [COND + ((NULL LST) + (SETQ LST (LIST (create IM.INDEX.DATA + INFO _ '(*NOPAGE*) + PROPLIST _ NIL using (CAR SUB.REFS] + +(* ;;; "DEF.REFS is all definition references, sorted by size of description, longest one first") + + [SETQ DEF.REFS (SORT (for X in LST when (MEMB '*DEF* (fetch (IM.INDEX.DATA + INFO) + of X)) collect + X) + (FUNCTION (LAMBDA (A B) + (ILEQ (LENGTH (fetch (IM.INDEX.DATA SAV) of A)) + (LENGTH (fetch (IM.INDEX.DATA SAV) of B] + +(* ;;; "for all but the longest definition reference, print as separate index lines, and remove from index list for this line") + +(* ;;; +"note that any other defs that print the same as the longest def are also merged into this line") + + (SETQ OTHER.DEF.REFS (for X in (CDR DEF.REFS) + unless (EQUAL (fetch (IM.INDEX.DATA SAV) of X) + (fetch (IM.INDEX.DATA SAV) + of (CAR DEF.REFS))) collect X)) + [COND + (OTHER.DEF.REFS (PRINT.INDEX.OBJECT NAM OTHER.DEF.REFS VOLUME.INFO SUB.LEVEL) + (SETQ LST (LDIFFERENCE LST OTHER.DEF.REFS] + +(* ;;; "get the reference text from the definition ref, if there is one, otherwise from the first primary ref with text, otherwise from any ref, otherwise use the name") + + (SETQ REF.TEXT (COND + ((CAR DEF.REFS) + (fetch (IM.INDEX.DATA SAV) of (CAR DEF.REFS))) + ((SETQ REF (for X in LST when (MEMB '*PRIMARY* + (fetch (IM.INDEX.DATA + INFO) + of X)) + thereis (fetch (IM.INDEX.DATA SAV) of X))) + (fetch (IM.INDEX.DATA SAV) of REF)) + ([AND (SETQ REF (for X in LST thereis (fetch ( + IM.INDEX.DATA + SAV) + of X))) + (NULL DEF.REFS) + (for X in LST never (MEMB '*PRIMARY* + (fetch (IM.INDEX.DATA + INFO) + of X] + (* ; + "only use text from non-def,non-primary index if there are NO primary or def index entries") + (fetch (IM.INDEX.DATA SAV) of REF)) + (T NAM))) + +(* ;;; "if REF.TEXT is not a list , put it in a list, adding {lisp...} if it is not a term") + + [COND + ((NLISTP REF.TEXT) + (SETQ REF.TEXT (CHCON REF.TEXT)) + (COND + ((NEQ TYP 'TERM) + (SETQ REF.TEXT (CONS '(FONT . LISP) + REF.TEXT] + +(* ;;; "Flush all nopage refs") + + (SETQ LST (for X in LST unless (MEMB '*NOPAGE* (fetch (IM.INDEX.DATA INFO) + of X)) collect X)) + +(* ;;; "print out the text of the index entry") + + (DUMPOUT FONT NIL PARALOOKS (COND + ((NULL SUB.LEVEL) + NIL) + ((EQ SUB.LEVEL 1) + (LIST '1STLEFTMARGIN IM.INDEX.SUB.1STLEFTMARGIN + 'LEFTMARGIN IM.INDEX.SUB.LEFTMARGIN)) + (T (LIST '1STLEFTMARGIN IM.INDEX.SUBSUB.1STLEFTMARGIN + 'LEFTMARGIN IM.INDEX.SUBSUB.LEFTMARGIN))) + DUMP.CHARS + (CONS REF.TEXT (LAST REF.TEXT)) + DUMP.CHARS " " FONT ITALIC DUMP.CHARS (COND + ((OR (EQ (U-CASE TYP) + 'TERM) + (AND (EQUAL (U-CASE TYP) + '(FUNCTION)) + DEF.REFS)) + "") + (T (MKSTRING TYP))) + DUMP.CHARS " ") (* ; + "divide the index refs between the volumes. If none in a given volume, don't include it") + [SETQ VOLUME.REF.LISTS + (COND + (VOLUME.INFO (for VOL in VOLUME.INFO bind VOL.REFS + when (SETQ VOL.REFS + (for REF in LST + when (MEMBER (CAR (LAST (fetch (IM.INDEX.DATA + SUBSEC) + of REF))) + (CDR VOL)) collect REF)) + collect (CONS (CAR VOL) + VOL.REFS))) + (T (LIST (CONS NIL LST] + [for VOL.REF.LIST in VOLUME.REF.LISTS bind VOL.NAME VOL.REFS PRIMARY.PAGELST + PAGELST + do (SETQ VOL.NAME (CAR VOL.REF.LIST)) + (SETQ VOL.REFS (CDR VOL.REF.LIST)) + (DUMPOUT FONT NIL DUMP.CHARS (COND + ((EQ VOL.REF.LIST (CAR VOLUME.REF.LISTS)) + "") + (T "; ")) + DUMP.CHARS + (COND + (VOL.NAME (CONCAT VOL.NAME ": ")) + (T ""))) + + (* ;; "PRIMARY.PAGELST is a list of all primary or definition references, sorted by chapter and page, with no duplicates") + + (SETQ PRIMARY.PAGELST (for X in VOL.REFS + when (OR (MEMB '*DEF* (fetch (IM.INDEX.DATA + INFO) of X)) + (MEMB '*PRIMARY* (fetch (IM.INDEX.DATA + INFO) + of X))) + collect (REF.TO.PAGE X))) + (SETQ PRIMARY.PAGELST (INTERSECTION PRIMARY.PAGELST PRIMARY.PAGELST)) + [SETQ PRIMARY.PAGELST (SORT PRIMARY.PAGELST + (FUNCTION (LAMBDA (A B) + (COND + [(AND (NUMBERP (CAR A)) + (NUMBERP (CAR B))) + + (* ;; + "CHAPTER is numeric, so compare with numeric") + + (OR (LESSP (CAR A) + (CAR B)) + (AND (EQUAL (CAR A) + (CAR B)) + (LESSP (CADR A) + (CADR B] + (T + + (* ;; + "One or t'other chapter is alpha, so compare using ALPHORDER") + + (OR (ALPHORDER (CAR A) + (CAR B)) + (AND (STRING-EQUAL + (MKSTRING (CAR A)) + (MKSTRING (CAR B))) + (LESSP (CADR A) + (CADR B] + + (* ;; + "PAGELST is: ((chap1 page1) ... (chapN pageN)) EXCEPT for primary references") + + (SETQ PAGELST (for X in VOL.REFS collect (REF.TO.PAGE X))) + (SETQ PAGELST (INTERSECTION PAGELST PAGELST)) + (SETQ PAGELST (LDIFFERENCE PAGELST PRIMARY.PAGELST)) + + (* ;; "PAGELST.BY.CHAPTER is list with elements of form: ((chap1 page1) (chap1 page1) ...) partioned by chapter, and sorted by chapter") + + (SETQ PAGELST.BY.CHAPTER (PARTITION.LIST PAGELST [FUNCTION (LAMBDA (A B) + (STRING-EQUAL + (MKSTRING A) + (MKSTRING B] + (FUNCTION CAR) + (FUNCTION ALPHORDER))) + [COND + (PRIMARY.PAGELST + (DUMPOUT FONT BOLD DUMP.CHARS + (CONCATLIST (for X in PRIMARY.PAGELST + bind (LAST.PRIMARY.PAGE _ (CAR (LAST PRIMARY.PAGELST + ))) + join (APPEND (COND + ((CAR X) + (LIST (CAR X) + "-")) + (T NIL)) + (LIST (CADR X) + (COND + ((OR (NOT (EQUAL X + LAST.PRIMARY.PAGE + )) + PAGELST.BY.CHAPTER) + "; ") + (T ""] + (for CHAP.PAGES in PAGELST.BY.CHAPTER bind CHAP.STRING NUMS + do [SETQ CHAP.STRING (CONCAT (COND + ((EQ CHAP.PAGES (CAR PAGELST.BY.CHAPTER)) + "") + (T "; ")) + (COND + ((CAAR CHAP.PAGES) + (CONCAT (CAAR CHAP.PAGES) + "-")) + (T ""] + [SETQ NUMS (SORT (for X in CHAP.PAGES collect (CADR X] + (* (* ;; "terrible kludge for the sole purpose of merging runs of page numbers, to produce index entries like '1,3-5' instead of '1,3,4,5'") + (bind (FIRSTNUM _ (CAR NUMS)) + (SECONDNUM _ (CAR NUMS)) + (NEWNUMS _ NIL) for X in + (APPEND (CDR NUMS) + (QUOTE (BADNUM))) do + (COND ((AND (NUMBERP SECONDNUM) + (NOT (EQUAL X (ADD1 SECONDNUM)))) + (push NEWNUMS (COND + ((EQUAL FIRSTNUM SECONDNUM) FIRSTNUM) + (T (PACK* FIRSTNUM "-" SECONDNUM)))) + (SETQ FIRSTNUM X))) + (SETQ SECONDNUM X) finally + (SETQ NUMS (REVERSE NEWNUMS)))) + (for SINGLE.PAGE in NUMS + do (DUMPOUT FONT NIL DUMP.CHARS (COND + ((EQ SINGLE.PAGE (CAR NUMS)) + CHAP.STRING) + (T ",")) + DUMP.CHARS SINGLE.PAGE] + (DUMPOUT CR CR) + +(* ;;; "print out any sub references") + + (PRINT.INDEX.SUBREFS SUB.REFS VOLUME.INFO SUB.LEVEL]) + +(PRINT.INDEX.SUBREFS + [LAMBDA (SUB.REFS VOLUME.INFO SUB.LEVEL) (* mjs "14-Jul-86 12:39") + + (* ;; "Print sub-item references. This is how the Notecards manual's Analog-clock sub-items get printed, e.g.:") + + (* ;; " ANALOG CLOCK 168") + + (* ;; " creating 168") + + (* ;; " known problems 170") + + (PROG ((NEW.SUB.LEVEL (COND + ((NULL SUB.LEVEL) + 1) + (T 2))) + SHIFTED.REFS) + (COND + ([NOT (AND SUB.REFS (MEMB SUB.LEVEL '(NIL 1] + + (* ;; + "There must be references to print, and we only print 2 levels of sub-references.") + + (RETURN))) + + (* ;; "Move everything in the references over: SUBTYPEW -> TYPE, SUBTEXT -> SAV, etc, and move SUBSUB... up into the SUB fields.") + + (* ;; "Many items were created with only SUBTEXT, so use that as the name if need be (using TERM as the type.)") + + [SETQ SHIFTED.REFS (for X in SUB.REFS + collect (PROG ((PLIST (fetch (IM.INDEX.DATA PROPLIST) + of X))) + (RETURN (create IM.INDEX.DATA + NAME _ (OR (LISTGET PLIST + 'SUBNAME) + (LISTGET PLIST + 'SUBTEXT)) + TYPE _ (OR (LISTGET PLIST + 'SUBTYPE) + 'TERM) + SAV _ (LISTGET PLIST 'SUBTEXT) + PROPLIST _ + (LIST 'SUBNAME (LISTGET PLIST + 'SUBSUBNAME) + 'SUBTYPE + (LISTGET PLIST 'SUBSUBTYPE) + 'SUBTEXT + (LISTGET PLIST 'SUBSUBTEXT)) + using X] + (for LST in (PARTITION.LIST SHIFTED.REFS NIL + [FUNCTION (LAMBDA (A) + (CONCAT (if (MEMB '*NOPAGE* (fetch + (IM.INDEX.DATA + INFO) of + A)) + then "ZZZZZZZ" + else "") + (fetch (IM.INDEX.DATA NAME) of A] + (FUNCTION ALPHORDER)) + do + + (* ;; + "partition sort by ref name , and for each name, handle refs") + + (for X in (PARTITION.LIST LST NIL [FUNCTION (LAMBDA (A) + (fetch (IM.INDEX.DATA + TYPE) + of A] + (FUNCTION ALPHORDER)) + do (* ; "parition sort refs by type") + (PRINT.INDEX.OBJECT (fetch (IM.INDEX.DATA NAME) + of (CAR X)) + X VOLUME.INFO NEW.SUB.LEVEL]) + +(PROCESS.IM.CHAPTERS + [LAMBDA (CHAPNAMES NULL.IP.FLG) (* mjs "25-Sep-85 15:47") + (PROG (CHAPS.TO.PROCESS) + [SETQ CHAPS.TO.PROCESS (if (NULL CHAPNAMES) + then + + (* if chapter names are not given, check which chapters have been updated since + they were last processed) + + (COLLECT.MODIFIED.IM.CHAPTERS) + elseif (EQ CHAPNAMES T) + then (for X in IM.MANUAL.CHAPTERS + collect (LIST (CAR X) + (CADR X))) + else (for NAM in (U-CASE (MKLIST CHAPNAMES)) + join (for X in IM.MANUAL.CHAPTERS + when (EQ (U-CASE (CADR X)) + NAM) + collect (LIST (CAR X) + (CADR X] + (printout T "will re-process chapters: " CHAPS.TO.PROCESS T) + (for X in CHAPS.TO.PROCESS + do (SETQ GLOBAL.CHAPTER.NUMBER (CAR X)) + (IM.TEDIT (PACKFILENAME 'BODY (CADR X) + 'BODY IM.MANUAL.DIRECTORY) + (if NULL.IP.FLG + then '{NULL}FOO.IP + else (CADR X))) + (for EXT in (if NULL.IP.FLG + then '(IMPTR IMERR) + else '(IP IMPTR IMERR)) + bind (NAM _ (FILENAMEFIELD (CADR X) + 'NAME)) + FROMFILE TOFILE + do (SETQ FROMFILE (PACKFILENAME 'NAME NAM 'EXTENSION EXT 'BODY + '{DSK}FOO.IP)) + (SETQ TOFILE (PACKFILENAME 'NAME NAM 'EXTENSION EXT 'BODY + IM.MANUAL.DIRECTORY)) + (if (INFILEP FROMFILE) + then (printout T "copying from " FROMFILE " to " TOFILE "...." T) + (RENAMEFILE FROMFILE TOFILE]) + +(REF.TO.PAGE + [LAMBDA (REF DEFAULT-CHAPTER) (* ; "Edited 8-Dec-91 15:08 by jds") + + (* ;; "Returns a list of the form (chap# page#)") + + (LIST (CAR (LAST (OR (fetch (IM.INDEX.DATA SUBSEC) of REF) + DEFAULT-CHAPTER))) + (fetch (IM.INDEX.DATA PAGE#) of REF]) + +(REFS.TO.PAGES + [LAMBDA (REFS) (* mjs " 6-Jun-85 14:43") + + (* * REFS is list of index refs. Returns a list of the form + ((chap1 page1) |...| (chapN pageN))) + + (for X in REFS collect (REF.TO.PAGE X]) +) +(DEFINEQ + +(MAKE.IM.INDEX + [LAMBDA (OUTFILE.FLG VOLUME.INFO IMPTR.FILES IMPTR.TYPES) + (* ; "Edited 30-Aug-91 10:38 by jds") + (SETQ IMPTR.FILES (OR IMPTR.FILES (DIRECTORY "*.IMPTR;"))) + (PROG* ((*READTABLE* *TEDIT-FILE-READTABLE*) + [IMPTR.DATA (COND + (IMPTR.FILES (PROG ((IMPTR.HASH (HASHARRAY 500)) + (IMPTR.TOC.LIST NIL) + (IMPTR.NAME.LIST NIL)) + (DECLARE (SPECVARS IMPTR.HASH IMPTR.TOC.LIST + IMPTR.NAME.LIST)) + (for X in (MKLIST IMPTR.FILES) + do (printout T "Grabbing IMPTR file: " X T) + (GRAB.IMPTR X NIL IMPTR.TYPES)) + (RETURN (LIST IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST + ] + (IMPTR.HASH (COND + (IMPTR.FILES (CAR IMPTR.DATA)) + (T IMPTR.HASH))) + (IMPTR.TOC.LIST (COND + (IMPTR.FILES (CADR IMPTR.DATA)) + (T IMPTR.TOC.LIST))) + (IMPTR.NAME.LIST (COND + (IMPTR.FILES (CADDR IMPTR.DATA)) + (T IMPTR.NAME.LIST))) + INDEX.DATA INDEX.DATA.BY.TYPE) + (DECLARE (SPECVARS IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST)) + +(* ;;; "Use either global or local versions of IMPTR.HASH IMPTR.TOC.LIST IMPTR.NAME.LIST") + + [SORT IMPTR.NAME.LIST (FUNCTION (LAMBDA (A B) + (COND + ((OR (NUMBERP A) + (NUMBERP B)) + (ALPHORDER (MKSTRING A) + (MKSTRING B))) + (T (ALPHORDER A B] + (* ; + "sort, then put all names before first A--- at end of list") + [PROG ((X IMPTR.NAME.LIST)) + (until [OR (NULL X) + (EQ 'A (U-CASE (NTHCHAR (CADR X) + 1] do (SETQ X (CDR X))) + (COND + (X (RPLACD (LAST X) + IMPTR.NAME.LIST) + (SETQ IMPTR.NAME.LIST (CDR X)) + (RPLACD X NIL] + (SETQ SUBSEC.COUNT.LIST '(INDEX)) + (RETURN (MAKE.IM.DOCUMENT + [LIST (FUNCTION (LAMBDA NIL + (DUMP.HEADERS.FOOTERS "INDEX" "INDEX") + (DUMPOUT FONT IM.CHAPTER.TITLE.FONT PARALOOKS + `(PARALEADING 0 LINELEADING 0 QUAD LEFT 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN + TABS %, IM.RIGHT.MARGIN.TABS TYPE PAGEHEADING + SUBTYPE TITLEHEAD) + TAB DUMP.CHARS "INDEX" CR CR) + (DUMP.HRULE 6 NIL + `(PARALEADING 0 LINELEADING 0 QUAD LEFT 1STLEFTMARGIN 0 + LEFTMARGIN 0 RIGHTMARGIN %, IM.TEXT.RIGHTMARGIN + TABS %, IM.RIGHT.MARGIN.TABS TYPE PAGEHEADING + SUBTYPE TITLEHEADRULE)) + (for INDEX.NAME in IMPTR.NAME.LIST + bind (LAST.CHAR _ NIL) + CURRENT.CHAR + do (SETQ CURRENT.CHAR (U-CASE (NTHCHAR INDEX.NAME 1))) + (COND + ((NEQ CURRENT.CHAR LAST.CHAR) + (DUMPOUT CR CR FONT BOLD PARALOOKS + '(HEADINGKEEP ON PARALEADING 12) + DUMP.CHARS CURRENT.CHAR CR CR) + (SETQ LAST.CHAR CURRENT.CHAR))) + (SETQ INDEX.DATA (GETHASH INDEX.NAME IMPTR.HASH)) + (* ; + "INDEX.DATA is a lists of index refs") + [SETQ INDEX.DATA.BY.TYPE + (PARTITION.LIST INDEX.DATA NIL + [FUNCTION (LAMBDA (A) + (U-CASE (COND + ((fetch + (IM.INDEX.DATA TYPE) + of A)) + (T 'TERM] + (FUNCTION (LAMBDA (A B) + (LIST.ORDER (U-CASE A) + (U-CASE B] + + (* ;; "INDEX.DATA.BY.TYPE is a list of index refs partioned by type, case-independent, and sorted by the ALPHORDER of the U-CASE of the types. Eventually, may want to make sorting more dependent on the types ") + + (for X in INDEX.DATA.BY.TYPE + do (PRINT.INDEX.OBJECT INDEX.NAME X + VOLUME.INFO) + (* ; + "print the info about a single object of a single type") + )) + (COND + (IM.EVEN.FLG + + (* ;; "this is a hack so that if you are going to print '[This page intentionally left blank]' on a blank page at the end, skip to the right column or the next page") + + (DUMPOUT CR CR START.PARA PARALOOKS + '(NEWPAGEBEFORE T) + DUMP.CHARS " " CR CR] + OUTFILE.FLG + [TEDIT.COMPOUND.PAGEFORMAT [TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL + IM.PAGE.LEFTMARGIN IM.PAGE.RIGHTMARGIN + IM.INDEX.PAGE.FIRST.TOPMARGIN + IM.PAGE.BOTTOMMARGIN 2 NIL 18 + `((RECTOFOOT %, IM.PAGE.LEFTMARGIN %, + IM.FOOTER.Y) + (RECTOFOOTRULE %, IM.PAGE.LEFTMARGIN %, + IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, + IM.DRAFT.MESSAGE.BOTTOM.Y) + (TITLEHEAD %, IM.PAGE.LEFTMARGIN %, + IM.HEADER.Y) + (TITLEHEADRULE %, IM.PAGE.LEFTMARGIN %, + IM.HEADER.RULE.Y] + [TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL IM.PAGE.LEFTMARGIN + IM.PAGE.RIGHTMARGIN IM.PAGE.TOPMARGIN IM.PAGE.BOTTOMMARGIN 2 NIL 18 + `((DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, IM.DRAFT.MESSAGE.TOP.Y) + (VERSOHEAD %, IM.PAGE.LEFTMARGIN %, IM.HEADER.Y) + (VERSOHEADRULE %, IM.PAGE.LEFTMARGIN %, IM.HEADER.RULE.Y) + (VERSOFOOT %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.Y) + (VERSOFOOTRULE %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, IM.DRAFT.MESSAGE.BOTTOM.Y] + (TEDIT.SINGLE.PAGEFORMAT NIL NIL NIL NIL NIL IM.PAGE.LEFTMARGIN + IM.PAGE.RIGHTMARGIN IM.PAGE.TOPMARGIN IM.PAGE.BOTTOMMARGIN 2 NIL 18 + `((DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, IM.DRAFT.MESSAGE.TOP.Y) + (RECTOHEAD %, IM.PAGE.LEFTMARGIN %, IM.HEADER.Y) + (RECTOHEADRULE %, IM.PAGE.LEFTMARGIN %, IM.HEADER.RULE.Y) + (RECTOFOOT %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.Y) + (RECTOFOOTRULE %, IM.PAGE.LEFTMARGIN %, IM.FOOTER.RULE.Y) + (DRAFTMESSAGE %, IM.DRAFT.MESSAGE.X %, IM.DRAFT.MESSAGE.BOTTOM.Y] + "Hardcopy of Index" + `(QUAD LEFT 1STLEFTMARGIN %, IM.INDEX.1STLEFTMARGIN LEFTMARGIN %, + IM.INDEX.LEFTMARGIN POSTPARALEADING 0 PARALEADING 0 LINELEADING 0]) +) + +(RPAQQ IM.MANUAL.CHAPTERS + (((NIL iii iv v vi vii viii ix x xi xii xiii xiv xv) + ChapAck) + (1 ChapIntro) + (2 ChapLitatoms) + (3 ChapLists) + (4 ChapStrings) + (5 ChapArrays) + (6 ChapHashArrays) + (7 ChapNumbers) + (8 ChapRecordPackage) + (9 ChapControlFns Conditionals PROG IterativeStatements) + (10 ChapFnDef FNTYPES FNDEF FNEVAL MACROS) + (11 ChapStack STACKORG STACKFNS INTERPRETERBLIPS GENERATORSANDCOROUTINES) + (12 ChapMisc GREET IdleMode VirtualMemory VersionInfo DATETIME DURATION RESOURCES + PATTERNMATCH) + (13 ChapExec PAINTRO PACOMS PAMISC PAGUTS PAFNS) + (14 ChapErrors BREAKS ERRORFNS RESETVARS ERRORLIST) + (15 ChapBreaking BREAKFNS ADVISING) + (16 ChapEditor DEDIT EDITORATTNCOMS EDITORMODCOMS EDITORMISC EDITORFNS) + (17 ChapFP FPINTRO FPFNS FPTYPES FPCOMS FPFILECOMS FPFORMAT) + (18 ChapCompiler COMPILERINTRO COMPILERISSUES COMPILERFNS BLOCKCOMPILER COMPILERERRORS) + (19 ChapMasterScope MSLANG MSORG) + (20 ChapDWIM DWIMINTRO DWIMORG SPELLINGCORRECTION) + (21 ChapCLISP CLISPINTRO CLISPCHARS CLISPDECLARATIONS CLISPORG CLISPGUTS) + (22 ChapPerformance GarbageCollection VariableBindings MEASURING GAINSPACE) + (23 ChapProcesses) + (24 ChapFiles FileStreams FileNames FileOther Directories FileServers) + (25 ChapIO INPUTFNS OUTPUTFNS RANDOMIO PRINTOUT READFILE READTABLES) + (26 ChapUserIO Inspector PROMPTFORWORD ASKUSER TTYIN PRETTYPRINT) + (27 ChapGraphics GraphicsPrimitives ImageStreams ImageStreamsImpl FONTS IMAGEOBJECTS) + (28 ChapWindows WindowSystem Windows Menus AttachedWindows) + (29 ChapHardcopy) + (30 ChapTerminal InterruptChars TERMINALTABLES Dribble Mouse Keyboard Screen) + (31 ChapEther ETHEROVERVIEW ETHERPUP ETHERNS ETHERINTROLEVELONE ETHERPUPLEVELONE + ETHERNSLEVELONE ETHEROTHERLEVELONE))) + +(RPAQQ IM.MANUAL.VOLUMES ((I 1 2 3 4 5 6 7 8 9 10 11 12) + (II 13 14 15 16 17 18 19 20 21 22 23) + (III 24 25 26 27 28 29 30 31))) + +(RPAQQ IM.MANUAL.DIRECTORY "{PELE:}IRM>") + +(FILESLOAD IMTEDIT FREEMENU) +(PUTPROPS IMTOOLS COPYRIGHT ("Xerox Corporation" 1985 1986 1987 1988 1991)) +(DECLARE%: DONTCOPY + (FILEMAP (NIL (1285 53259 (ADD.IM.MENU 1295 . 1667) (COLLECT.MODIFIED.IM.CHAPTERS 1669 . 4256) ( +DO.INDEX 4258 . 6023) (DO.MANUAL 6025 . 6709) (GRAB.IM.MANUAL.PTRS 6711 . 7127) (GRAB.IMPTR 7129 . +10872) (IM.COMMAND.MENU 10874 . 11304) (IM.TEDIT.SELECTION 11306 . 13009) (INIT.INDEX.VARS 13011 . +13223) (INSERT.CHARS.AROUND.SEL 13225 . 13634) (INTERPRET.IM.MENU.COMMAND 13636 . 14734) ( +MAKE.IM.TITLE 14736 . 18929) (MAKE.IM.TOC 18931 . 27165) (NEWTO 27167 . 27736) (PRINT.INDEX.OBJECT +27738 . 45522) (PRINT.INDEX.SUBREFS 45524 . 49994) (PROCESS.IM.CHAPTERS 49996 . 52611) (REF.TO.PAGE +52613 . 52963) (REFS.TO.PAGES 52965 . 53257)) (53260 63626 (MAKE.IM.INDEX 53270 . 63624))))) +STOP diff --git a/docs/Documentation Tools/IMTOOLS.LCOM b/docs/Documentation Tools/IMTOOLS.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..9aec597ec1b24659fa1a09968e47dde2f74875c3 GIT binary patch literal 26866 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 Z?Sq%+=?9}<0C$cbn!y6u_{l-#{{gbw3=seT literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/IMTRAN b/docs/Documentation Tools/IMTRAN new file mode 100644 index 00000000..0bc92e88 --- /dev/null +++ b/docs/Documentation Tools/IMTRAN @@ -0,0 +1,1270 @@ +(DEFINE-FILE-INFO READTABLE "INTERLISP" PACKAGE "INTERLISP") +(FILECREATED " 8-Dec-91 15:16:14" {DSK}sybalsky>PUBS>IMTRAN.;2 61628 + + changes to%: (FNS PARTITION.LIST) + (VARS IMTRANCOMS) + + previous date%: "11-Jul-86 12:39:31" {DSK}sybalsky>PUBS>IMTRAN.;1) + + +(* ; " +Copyright (c) 1983, 1984, 1985, 1986, 1991 by Xerox Corporation. All rights reserved. +") + +(PRETTYCOMPRINT IMTRANCOMS) + +(RPAQQ IMTRANCOMS + [ + (* ;; "Functions to help converting IM format to TEdit.") + + (FNS ADD.ANY.PARENT.PROP.IF ADD.MY.PROP.IF ANC.INDENT ANC.WIDTH ANY.PARENT.CORRECT.ARG + ANY.PARENT.EVAL ANY.PARENT.TO.MATCH ARGS.REMAINING ARGS.REMAINING.AFTER CHANGE.INDENT + CONCCONC CORRECT.ARG CORRECT.TO DECODE.TO.ARG.NAME.SYNONYM DECODE.TO.NAME.SYNONYM + DEFINED.TO DESCRIBE.CURRENT.TO DESCRIBE.TO DUMP.ARG DUMP.FORMAT FLUSH.ARG + GET.ANY.PARENT.PROP GET.ARG GET.ARG.SAV GET.ARG.TYPE GET.MY.PROP GET.TO.TYPE GOBBLE + GOBBLE.DUMP GOBBLE.DUMP.UNDEFINED GOBBLE.FLUSH GOBBLE.SAVE GOBBLE.TRIVIAL IM.DUMP.CHARS + IM.FILE.EOF IM.PRINT.MESSAGE IMTRAN INCLUDE.FILE LIST.ORDER LIST.TO.STRING MAKE.SAVE + OPEN.IM.FILE PARSE.ATOM PARSE.INDEX.SPEC PARSE.LIST PARSE.NUMBER.OR.PERCENTAGE + PARSE.STRING PARSE.TO.NAME PARTITION.LIST PRINT.INFILE.NOTES PUT.MY.PROP SAVE.ARG + SAVE.ARGS SAVE.ARGS.EMPTY SAVE.INFILE.NOTE SCRUNCH.REFS SEND.IMPLICIT SKIP.WHITE.SPACE + STANDARD.DUMMY.TO.PROG TAG.LIST.MATCH TO.MATCH TO.NAME.CHAR TRANSLATE.SPECIAL.TYPES + TRIVIAL.ARG) + (RECORDS TO) + (VARS IM.INFILE.NOTE.TAGS) + (INITVARS (IM.NOTE.FLG NIL) + (IM.DRAFT.FLG NIL) + (IM.INDEX.FILE.FLG NIL) + (IM.REF.FLG NIL) + (IM.SEND.IMPLICIT NIL) + (IM.EVEN.FLG NIL) + (IM.CHECK.DEFS NIL)) + (PROP INFO DUMPOUT) + (MACROS IM.ERROR IM.WARNING) + (DECLARE%: DONTEVAL@LOAD DOEVAL@COMPILE DONTCOPY COMPILERVARS (ADDVARS (NLAMA SAVE.ARGS) + (NLAML GET.ARG.SAV) + (LAMA]) + + + +(* ;; "Functions to help converting IM format to TEdit.") + +(DEFINEQ + +(ADD.ANY.PARENT.PROP.IF + [LAMBDA (PROPNAME VAL) (* mjs "15-APR-83 10:31") + (ANY.PARENT.EVAL (LIST 'ADD.MY.PROP.IF (LIST 'QUOTE PROPNAME) + (LIST 'QUOTE VAL]) + +(ADD.MY.PROP.IF + [LAMBDA (PROPNAME VAL) (* mjs "15-APR-83 10:32") + (if (GET.MY.PROP PROPNAME) + then [PUT.MY.PROP PROPNAME (CONS VAL (LISTP (GET.MY.PROP PROPNAME] + T + else NIL]) + +(ANC.INDENT + [LAMBDA NIL (* mjs "14-APR-83 13:31") + (GET.ANY.PARENT.PROP 'INDENT]) + +(ANC.WIDTH + [LAMBDA NIL (* mjs "14-APR-83 13:31") + (GET.ANY.PARENT.PROP 'WIDTH]) + +(ANY.PARENT.CORRECT.ARG + [LAMBDA (NAME) (* mjs " 8-APR-83 12:32") + (ANY.PARENT.EVAL (LIST 'CORRECT.ARG (LIST 'QUOTE NAME]) + +(ANY.PARENT.EVAL + [LAMBDA (FORM) (* mjs "11-APR-83 10:00") + (PROG ((S (STKSCAN 'TO.NAME)) + VAL) + loop + (SETQ S (STKNTH 1 S S)) + (SETQ S (STKSCAN 'TO.NAME S S)) + (COND + ((NULL S) + (RETURN NIL)) + ((SETQ VAL (STKEVAL S FORM)) + (RETURN VAL)) + (T (GO loop]) + +(ANY.PARENT.TO.MATCH + [LAMBDA (NAME BEGINFLG TAGLIST) (* mjs " 8-APR-83 16:00") + (ANY.PARENT.EVAL (LIST 'TO.MATCH (LIST 'QUOTE NAME) + (LIST 'QUOTE BEGINFLG) + (LIST 'QUOTE TAGLIST]) + +(ARGS.REMAINING + [LAMBDA (NAME ARGS) (* mjs "21-APR-83 13:28") + + (* returns T if NAME is a correct next-arg according to the TO.ARGS.REMAINING + list ARGS. Specifically if the next non-list member of ARGS is EQ to NAME or + NAME is a member of one of the list elements of ARGS before the next non-list + member, then NAME is a correct next-arg.) + + (if (NLISTP (CAR ARGS)) + then (EQ (CAR ARGS) + NAME) + else (OR (FMEMB NAME (CAR ARGS)) + (ARGS.REMAINING NAME (CDR ARGS]) + +(ARGS.REMAINING.AFTER + [LAMBDA (NAME ARGS) (* mjs "21-APR-83 13:28") + + (* returns the new TO.ARGS.REMAINING list after arg NAME has been processed. + Assumes that NAME is a correct next-arg of ARGS, as according to ARGS.REMAINING + NIL) + + (if (NULL ARGS) + then NIL + elseif (EQ NAME (CAR ARGS)) + then (CDR ARGS) + elseif (AND (LISTP (CAR ARGS)) + (FMEMB NAME (CAR ARGS))) + then ARGS + else (ARGS.REMAINING.AFTER NAME (CDR ARGS]) + +(CHANGE.INDENT + [LAMBDA (X) (* mjs "10-Apr-85 10:07") + (if (EQ X 'NONE) + then (PRIN3 "\parshape 0 {}" IM.OUTFILE) + else (printout IM.OUTFILE "\parshape 1 " .I4.10 X "pt " .I4.10 (IDIFFERENCE INITIAL.WIDTH X + ) + "pt " "{}"]) + +(CONCCONC + [LAMBDA (X Y) (* mjs "13-APR-83 16:44") + (* takes two TCONC-format lists, and + concatonates them) + (COND + ((NLISTP X) + Y) + ((NULL (CAR Y)) + X) + ((NULL (CAR X)) + (RPLNODE2 X Y)) + (T (RPLACD (CDR X) + (CAR Y)) + (RPLACD X (CDR Y]) + +(CORRECT.ARG + [LAMBDA (NAME) (* mjs "21-APR-83 13:30") + + (* returns non-NIL if NAME is an arg that appears in the args.remaining list of + the current TO) + + (ARGS.REMAINING NAME TO.ARGS.REMAINING]) + +(CORRECT.TO + [LAMBDA (NAME) (* mjs " 9-NOV-83 11:56") + (* returns T if NAME can occur as a + TO below TO.NAME) + (if (NULL TO.NAME) + then (* anything can occur below + top-level TO) + T + elseif (OR (EQ TO.NAME 'COMMENT) + (EQ TO.NAME 'NOTE)) + then (* anything can occur below a + comment or a note) + T + elseif (SELECTQ (GET.ARG.TYPE TO.NAME) + (SIMPLE (* a COMPLEX TO cannot occur within + a SIMPLE arg) + (EQ (GET.TO.TYPE NAME) + NIL)) + (CHARS (* no TO can occur within a CHARS + arg) + T) + NIL) + then NIL + elseif (SELECTQ NAME + (CHAPTER (* exception 1%: chapter can only + occur in top-level TO) + T) + ((SUBSEC FNDEF VARDEF PROPDEF MACDEF COMDEF) + (* exception 2%: subsec, ---def can + only occur within subsec, chapter, + or top-level TO) + [NOT (FMEMB TO.NAME '(CHAPTER SUBSEC]) + (FOOT (* exception 3%: foot cannot occur + in foot) + [OR (EQ TO.NAME 'FOOT) + (ANY.PARENT.EVAL '(EQ TO.NAME 'FOOT]) + NIL) + then NIL + else T]) + +(DECODE.TO.ARG.NAME.SYNONYM + [LAMBDA (NAME) (* mjs "14-APR-83 14:40") + (* eventually should do arg name + synonym search) + (COND + ((LISTGET (fetch TO.ARG.SYNONYMS of TO.NAME) + NAME)) + (T NAME]) + +(DECODE.TO.NAME.SYNONYM + [LAMBDA (NAME) (* mjs "13-APR-83 18:56") + (COND + ((CADR (ASSOC NAME TO.SYNONYM.LIST))) + (T NAME]) + +(DEFINED.TO + [LAMBDA (NAME) (* mjs " 8-APR-83 11:02") + (fetch TO.PROG of NAME]) + +(DESCRIBE.CURRENT.TO + [LAMBDA NIL (* mjs "13-APR-83 18:22") + (DESCRIBE.TO (if TO.BEGIN.FLG + then 'BEGIN + else NIL) + TO.ORIG.NAME TO.TAG.LIST TO.ORIG.ARG.NAME]) + +(DESCRIBE.TO + [LAMBDA (BEGIN.END ORIG.NAME TAG.LIST ORIG.ARG.NAME) (* mjs " 3-MAY-83 14:42") + (CONCAT "{" (COND + (BEGIN.END (CONCAT BEGIN.END " " ORIG.NAME " " (LIST.TO.STRING TAG.LIST) + "}")) + (T ORIG.NAME)) + (COND + (ORIG.ARG.NAME (CONCAT " (arg " ORIG.ARG.NAME ")")) + (T ""]) + +(DUMP.ARG + [LAMBDA (NO.SKIP.FLG) (* mjs "21-APR-83 14:14") + (if (fetch TO.ARGS of TO.NAME) + then (if TO.ARG.NAME + then (GOBBLE.DUMP NO.SKIP.FLG) + (SETQ TO.ARG.NAME NIL) + else (ERROR "TO PROG BUG: attempting to dump arg not yet gotten")) + else (if (NOT TO.DONE.FLG) + then (GOBBLE.DUMP NO.SKIP.FLG) + (SETQ TO.DONE.FLG T) + else (ERROR "TO PROG BUG: attempting to process unlabeled arg twice"]) + +(DUMP.FORMAT + [LAMBDA (FORMAT.TYPE FORMAT) (* mjs "13-APR-83 17:01") + (COND + ((BOUNDP 'GOBBLE.SAVE.CONC) + (TCONC GOBBLE.SAVE.CONC (CONS FORMAT.TYPE FORMAT))) + (T (DUMP (CONS FORMAT.TYPE FORMAT]) + +(FLUSH.ARG + [LAMBDA NIL (* mjs "21-APR-83 14:13") + (if (fetch TO.ARGS of TO.NAME) + then (if TO.ARG.NAME + then (GOBBLE.FLUSH) + (SETQ TO.ARG.NAME NIL) + else (ERROR "TO PROG BUG: attempting to dump arg not yet gotten")) + else (if (NOT TO.DONE.FLG) + then (GOBBLE.FLUSH) + (SETQ TO.DONE.FLG T) + else (ERROR "TO PROG BUG: attempting to process unlabeled arg twice"]) + +(GET.ANY.PARENT.PROP + [LAMBDA (PROPNAME) (* mjs "11-APR-83 10:08") + (ANY.PARENT.EVAL (LIST 'GET.MY.PROP (LIST 'QUOTE PROPNAME]) + +(GET.ARG + [LAMBDA NIL (* mjs "12-Jul-85 12:32") + (PROG (C SAVE.FILE.PTR ORIG.NAME BEGIN.END TAG.LIST NAME) + (if (OR TO.ARG.NAME TO.DONE.FLG (NULL (fetch TO.ARGS of TO.NAME))) + then (ERROR "TO PROG BUG: called GET.ARG at bad time")) + (SKIP.WHITE.SPACE) + (SETQ C (if (EOFP IM.INFILE) + then (IM.FILE.EOF) + else (BIN IM.INFILE))) + (if (EQ C (CHARCODE })) + then (if TO.BEGIN.FLG + then (IM.ERROR "} closes " (DESCRIBE.CURRENT.TO))) + (SETQ TO.DONE.FLG T) + (RETURN NIL) + elseif (EQ C 'EOF) + then (if (NEQ TO.NAME NIL) + then (IM.ERROR "EOF - closing bracket for " (DESCRIBE.CURRENT.TO)) + ) + (SETQ TO.DONE.FLG T) + (RETURN NIL) + elseif (NEQ C (CHARCODE {)) + then (IM.ERROR "Garbage chars found between labeled args of " ( + DESCRIBE.CURRENT.TO + ) + " --- auto-completed") + (SETQ SAVE.FILE.PTR (SUB1 (GETFILEPTR IM.INFILE))) + (SETQ TO.DONE.FLG T) + (RETURN NIL)) + (SETQ SAVE.FILE.PTR (SUB1 (GETFILEPTR IM.INFILE))) + (SETQ ORIG.NAME (PARSE.TO.NAME)) (* if PARSE.TO.NAME returns a list, + it must be a BEGIN/END, so unpack + elements) + (if (NLISTP ORIG.NAME) + then (SETQ BEGIN.END NIL) + (SETQ TAG.LIST NIL) + else (SETQ BEGIN.END (CAR ORIG.NAME)) + (SETQ TAG.LIST (CADDR ORIG.NAME)) + (SETQ ORIG.NAME (CADR ORIG.NAME))) + (if (EQ BEGIN.END 'BEGIN) + then (IM.ERROR (DESCRIBE.TO BEGIN.END ORIG.NAME TAG.LIST) + " found between labeled args of " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (SETQ TO.DONE.FLG T) + (RETURN NIL) + elseif (EQ BEGIN.END 'END) + then (SETQ NAME (DECODE.TO.NAME.SYNONYM ORIG.NAME)) + (if (TO.MATCH NAME T TAG.LIST) + then (* normal {end return) + (SETQ TO.DONE.FLG T) + (RETURN NIL) + elseif (ANY.PARENT.TO.MATCH NAME T TAG.LIST) + then (IM.ERROR (DESCRIBE.TO 'END ORIG.NAME TAG.LIST) + " found between labeled args of " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (SETQ TO.DONE.FLG T) + (RETURN NIL) + else (IM.ERROR "Unmatched " (DESCRIBE.TO 'END ORIG.NAME TAG.LIST) + " --- flushed") + (RETURN (GET.ARG))) + elseif BEGIN.END + then (ERROR "PARSE.TO.NAME returned something besides BEGIN or END")) + (SETQ NAME (DECODE.TO.ARG.NAME.SYNONYM ORIG.NAME)) + (if (CORRECT.ARG NAME) + then (SETQ TO.ORIG.ARG.NAME ORIG.NAME) + (SETQ TO.ARG.NAME NAME) + (SETQ TO.ARGS.REMAINING (ARGS.REMAINING.AFTER NAME TO.ARGS.REMAINING)) + (RETURN NAME) + else (IM.ERROR (DESCRIBE.TO NIL ORIG.NAME NIL) + " found between labeled args of " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (SETQ TO.DONE.FLG T) + (RETURN NIL]) + +(GET.ARG.SAV + [NLAMBDA (NAME) (* mjs "13-APR-83 10:23") + (LISTGET (GET.MY.PROP 'SAVE.ARGS.PROPLIST) + NAME]) + +(GET.ARG.TYPE + [LAMBDA (NAME) (* mjs "22-APR-83 13:19") + + (* if NAME is a TO with labeled args, use the current arg name as index into + the property list TO.ARG.TYPE. otherwise TO.ARG.TYPE is the arg type) + + (if (fetch TO.ARGS of NAME) + then (LISTGET (fetch TO.ARG.TYPE of NAME) + TO.ARG.NAME) + else (fetch TO.ARG.TYPE of NAME]) + +(GET.MY.PROP + [LAMBDA (PROPNAME) (* mjs "11-APR-83 10:10") + (LISTGET TO.PROP.LIST PROPNAME]) + +(GET.TO.TYPE + [LAMBDA (NAME) (* mjs "22-APR-83 13:20") + + (* note that undefined TOs are always SIMPLE, so they can appear anywhere + except in CHARS TOs) + + (if (fetch TO.PROG of NAME) + then (fetch TO.TYPE of NAME) + else 'SIMPLE]) + +(GOBBLE + [LAMBDA NIL (* mjs "12-Jul-85 12:39") + + (* * reads and dumps chars until closing } or {end) + + (PROG ((SAVE.DUMP.FLG (BOUNDP 'GOBBLE.SAVE.CONC)) + C SAVE.FILE.PTR CLIST ORIG.NAME NAME BEGIN.END TAG.LIST SAVE.CONC) + (if SAVE.DUMP.FLG + then (SETQ SAVE.CONC GOBBLE.SAVE.CONC)) + loop + (SETQ C (if (EOFP IM.INFILE) + then (IM.FILE.EOF) + else (BIN IM.INFILE))) (* if C is just a normal char, just + dump it and loop) + (if (EQ C 'EOF) + then (if (NEQ TO.NAME NIL) + then (IM.ERROR "EOF - closing bracket for " (DESCRIBE.CURRENT.TO)) + ) + (RETURN NIL)) + (if (EQ C (CHARCODE })) + then (if (AND TO.BEGIN.FLG (NOT TO.ARG.NAME)) + then (IM.ERROR "} closes " (DESCRIBE.CURRENT.TO))) + (RETURN NIL)) + (if (NEQ C (CHARCODE {)) + then + + (* if it is anything else besides a left bracket, it is a character to dump) + + (if SAVE.DUMP.FLG + then (TCONC SAVE.CONC C) + else (DUMP C)) + (GO loop)) (* at this point, C must be a left + bracket) + + (* * before getting name after {, save current file ptr so you can back it up + if necessary.) + + (* * note%: complete TO name (or Begin spec) must be in one file, so that you + can back up) + + (SETQ SAVE.FILE.PTR (SUB1 (GETFILEPTR IM.INFILE))) + (SETQ ORIG.NAME (PARSE.TO.NAME)) (* if PARSE.TO.NAME returns a list, + it must be a BEGIN/END, so unpack + elements) + (if (NLISTP ORIG.NAME) + then (SETQ BEGIN.END NIL) + (SETQ TAG.LIST NIL) + else (SETQ BEGIN.END (CAR ORIG.NAME)) + (SETQ TAG.LIST (CADDR ORIG.NAME)) + (SETQ ORIG.NAME (CADR ORIG.NAME))) + (SETQ NAME (DECODE.TO.NAME.SYNONYM ORIG.NAME)) + (COND + [(EQ BEGIN.END 'END) + (COND + ((AND (NOT TO.ARG.NAME) + (TO.MATCH NAME T TAG.LIST)) (* normal {end return) + (RETURN NIL)) + ((OR (TO.MATCH NAME T TAG.LIST) + (ANY.PARENT.TO.MATCH NAME T TAG.LIST)) + (IM.ERROR (DESCRIBE.TO 'END ORIG.NAME TAG.LIST) + " occurred in " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL)) + (T (IM.ERROR "Unmatched " (DESCRIBE.TO 'END ORIG.NAME TAG.LIST) + " --- flushed") + (GO loop] + ((AND BEGIN.END (NEQ BEGIN.END 'BEGIN)) + (ERROR "PARSE.TO.NAME returned something besides BEGIN or END"))) + + (* * now, we must be beginning a TO) + + (COND + ((AND (DEFINED.TO NAME) + (NOT (CORRECT.TO NAME))) + + (* if name is defined but not correct, auto-complete to pop up to where it is + correct) + + (IM.ERROR (DESCRIBE.TO BEGIN.END ORIG.NAME TAG.LIST) + " not legal in " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL))) + (COND + ((AND (NOT BEGIN.END) + (NOT (DEFINED.TO NAME)) + (OR (CORRECT.ARG ORIG.NAME) + (ANY.PARENT.CORRECT.ARG ORIG.NAME))) + + (* if name is not in a {begin and is undefined, AND it is a legal arg for the + current TO or a parent TO, auto-complete current TO or arg) + + (IM.ERROR "Possible Argument " (DESCRIBE.TO NIL ORIG.NAME NIL) + " occurred in " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL))) + [PROG ((TO.NAME NAME) + (TO.ORIG.NAME ORIG.NAME) + (TO.BEGIN.FLG (NOT (NULL BEGIN.END))) + (TO.TAG.LIST TAG.LIST) + (TO.ARG.NAME NIL) + (TO.ORIG.ARG.NAME NIL) + (TO.ARGS.REMAINING (fetch TO.ARGS of NAME)) + (TO.DONE.FLG NIL) + (TO.PROP.LIST (CONS))) + (DECLARE (SPECVARS TO.NAME TO.ORIG.NAME TO.BEGIN.FLG TO.ARG.NAME TO.TAG.LIST + TO.ORIG.ARG.NAME TO.ARGS.REMAINING TO.DONE.FLG TO.PROP.LIST)) + (if (DEFINED.TO NAME) + then (APPLY (fetch TO.PROG of NAME)) + else (GOBBLE.DUMP.UNDEFINED)) + (if (NOT TO.DONE.FLG) + then (if (AND (fetch TO.ARGS of NAME) + (NULL TO.ARG.NAME) + (NULL TO.ARGS.REMAINING)) + then + + (* if the TO has used up all args, but hasn't formally completed scanning, + close it automatically) + + (GET.ARG) + else (ERROR (CONCAT "TO function: " (fetch TO.PROG + of NAME) + " ended with input in bad state"] + (GO loop]) + +(GOBBLE.DUMP + [LAMBDA (NO.SKIP.FLG) (* mjs "21-APR-83 13:48") + (PROG NIL + (COND + ((NOT NO.SKIP.FLG) + (SKIP.WHITE.SPACE))) + (GOBBLE) + (SETQ TO.ORIG.ARG.NAME NIL) + (SETQ TO.ARG.NAME NIL]) + +(GOBBLE.DUMP.UNDEFINED + [LAMBDA NIL (* mjs "10-Apr-85 09:53") + + (* * old fn def%: (WARNING T TO.ORIG.NAME + " is undefined as a TO --- contents will be dumped") + (DUMP.ARG)) + + (* * current behavior%: for unidentified name, print out "{ }") + + (SAVE.INFILE.NOTE 'BAD.TO.NAME TO.ORIG.NAME) + (IM.DUMP.CHARS "{") + (IM.DUMP.CHARS TO.ORIG.NAME) + (DUMP.ARG T) (* dump rest of TO, WITHOUT SKIPPING + SPACES) + (IM.DUMP.CHARS "}"]) + +(GOBBLE.FLUSH + [LAMBDA NIL (* mjs "22-APR-83 10:37") + + (* this flushes all gobbled chars by means of an incredible hack --- + by initializing GOBBLE.SAVE.CONC to NIL rather than + (NIL)%, none of the TCONCs can update the saved list) + + (PROG ((GOBBLE.SAVE.CONC NIL)) + (DECLARE (SPECVARS GOBBLE.SAVE.CONC)) + (GOBBLE) + (SETQ TO.ORIG.ARG.NAME NIL) + (SETQ TO.ARG.NAME NIL]) + +(GOBBLE.SAVE + [LAMBDA (NO.SKIP.FLG) (* mjs "21-APR-83 13:49") + (PROG ((GOBBLE.SAVE.CONC (CONS))) + (DECLARE (SPECVARS GOBBLE.SAVE.CONC)) + (COND + ((NOT NO.SKIP.FLG) + (SKIP.WHITE.SPACE))) + (GOBBLE) + (SETQ TO.ORIG.ARG.NAME NIL) + (SETQ TO.ARG.NAME NIL) + (RETURN GOBBLE.SAVE.CONC]) + +(GOBBLE.TRIVIAL + [LAMBDA NIL (* mjs "12-Jul-85 12:41") + (PROG (C SAVE.FILE.PTR PARSED.NAME) + (SKIP.WHITE.SPACE) + (SETQ SAVE.FILE.PTR (SUB1 (GETFILEPTR IM.INFILE))) + (SETQ C (if (EOFP IM.INFILE) + then (IM.FILE.EOF) + else (BIN IM.INFILE))) + (if (EQ C 'EOF) + then (if (NEQ TO.NAME NIL) + then (IM.ERROR "EOF - closing bracket for " (DESCRIBE.CURRENT.TO)) + ) + (RETURN NIL) + elseif (EQ C (CHARCODE })) + then (if (AND TO.BEGIN.FLG (NOT TO.ARG.NAME)) + then (IM.ERROR "} closes " (DESCRIBE.CURRENT.TO))) + (RETURN NIL) + elseif (EQ C (CHARCODE {)) + then (if TO.ARG.NAME + then (IM.ERROR "{ terminates trivial arg " (DESCRIBE.CURRENT.TO)) + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL) + else (SETQ PARSED.NAME (PARSE.TO.NAME)) + (if (AND (LISTP PARSED.NAME) + (EQ (CAR PARSED.NAME) + 'END) + (TO.MATCH (CADR PARSED.NAME) + T + (CADDR PARSED.NAME))) + then (RETURN NIL) + else (IM.ERROR (if (LISTP PARSED.NAME) + then (DESCRIBE.TO (CAR PARSED.NAME) + (CADR PARSED.NAME) + (CADDR PARSED.NAME)) + else (DESCRIBE.TO NIL PARSED.NAME NIL)) + " found in trivial " + (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL))) + else (IM.ERROR "garbage character found in trivial " (DESCRIBE.CURRENT.TO) + " --- auto-completed") + (SETFILEPTR IM.INFILE SAVE.FILE.PTR) + (RETURN NIL]) + +(IM.DUMP.CHARS + [LAMBDA (X) (* mjs "13-APR-83 17:01") + (COND + [(AND (LISTP X) + (LISTP (CDR X))) + (COND + ((BOUNDP 'GOBBLE.SAVE.CONC) + (CONCCONC GOBBLE.SAVE.CONC X)) + (T (for C in (CAR X) do (DUMP C] + (X (IM.DUMP.CHARS (MAKE.SAVE X]) + +(IM.FILE.EOF + [LAMBDA NIL (* mjs "25-Jul-85 10:49") + (if INFILE.STACK + then (IM.WARNING "EOF - included file: " IM.INFILE.FILENAME) + (PRINT.INFILE.NOTES) + (CLOSEF IM.INFILE) + (PROG ((LASTFILEINFO (pop INFILE.STACK))) + (SETQ IM.INFILE (CAR LASTFILEINFO)) + (SETQ IM.INFILE.FILENAME (CDR LASTFILEINFO))) + (BIN IM.INFILE) + else (IM.WARNING "EOF - top-level file: " IM.INFILE.FILENAME) + (PRINT.INFILE.NOTES) + 'EOF]) + +(IM.PRINT.MESSAGE + [LAMBDA (WARNING.STRING PRINT.CONTEXT.FLAG MESSAGE.LIST) + (* mjs "12-Sep-85 08:30") + (PROG NIL + [if [AND ERRFILE.NAME (OR (NULL ERRFILE) + (NOT (OPENP ERRFILE] + then (SETQ ERRFILE (OPENSTREAM ERRFILE.NAME 'OUTPUT 'NEW] + (for PRINTFILE in (LIST T ERRFILE) when PRINTFILE + do + + (* * print out identical warning on terminal and in error file + . If ERRFILE=NIL, warning is only printed on terminal) + + (PRIN3 WARNING.STRING PRINTFILE) + (for Y in MESSAGE.LIST do (PRIN3 Y PRINTFILE)) + (TERPRI PRINTFILE) + (if (AND PRINT.CONTEXT.FLAG (OPENP IM.INFILE) + (NOT (EOFP IM.INFILE))) + then (PROG ((SAVEPOS (GETFILEPTR IM.INFILE)) + BEGINPOS ENDPOS) + (SETQ BEGINPOS (IMAX 0 (IDIFFERENCE SAVEPOS 100))) + (SETQ ENDPOS (IMIN (GETEOFPTR IM.INFILE) + (IPLUS SAVEPOS 100))) + (SETFILEPTR IM.INFILE BEGINPOS) + (printout PRINTFILE "CONTEXT:" T) + (until (IGEQ (GETFILEPTR IM.INFILE) + ENDPOS) + do (BOUT PRINTFILE (if (FIXP (BIN IM.INFILE)) + else (CHARCODE ~))) + (if (EQ (GETFILEPTR IM.INFILE) + SAVEPOS) + then (printout PRINTFILE T "---->" T))) + (printout PRINTFILE T "ENDCONTEXT:" T T) + (SETFILEPTR IM.INFILE SAVEPOS]) + +(IMTRAN + [LAMBDA (INFILE.NAME) (* mjs "25-Jul-85 10:44") + (PROG ((IM.INFILE NIL) + (INFILE.STACK NIL) + (IM.INFILE.FILENAME) + (WARNING.COUNT.DOWN -1) + (SUBSEC.COUNT.LIST '(0)) + (SUBSEC.LAST.SUB 0) + (FOOTNOTE.NUM 0) + (FIGURE.NUM 0) + (INITIAL.WIDTH 462) + (INITIAL.INDENT 0)) + (DECLARE (SPECVARS IM.INFILE INFILE.STACK IM.INFILE.FILENAME WARNING.COUNT.DOWN + SUBSEC.COUNT.LIST SUBSEC.LAST.SUB FOOTNOTE.NUM FIGURE.NUM INITIAL.WIDTH + INITIAL.INDENT)) + (OPEN.IM.FILE INFILE.NAME) + + (* * note%: SUBSEC.COUNT.LIST and SUBSEC.LAST.SUB set so that if no CHAPTER TO + is given, this is treated like chapter 0) + + (if IM.NOTE.FLG + then (IM.WARNING + " + WARNING: --- Note facility enabled --- Notes will be printed --- + ")) + (do (PROG ((TO.NAME NIL) + (TO.ORIG.NAME NIL) + (TO.BEGIN.FLG NIL) + (TO.TAG.LIST NIL) + (TO.ARG.NAME NIL) + (TO.ORIG.ARG.NAME NIL) + (TO.ARGS.REMAINING NIL) + (TO.DONE.FLG NIL) + (TO.PROP.LIST (CONS))) + (DECLARE (SPECVARS TO.NAME TO.ORIG.NAME TO.BEGIN.FLG TO.ARG.NAME + TO.TAG.LIST TO.ORIG.ARG.NAME TO.DONE.FLG TO.PROP.LIST)) + (* set initial indentation and width) + (PUT.MY.PROP 'WIDTH INITIAL.WIDTH) + (PUT.MY.PROP 'INDENT INITIAL.INDENT) + (* dump everything, including white + space at beginning) + (DUMP.ARG T)) repeatuntil (COND + ((AND (EOFP IM.INFILE) + (NULL INFILE.STACK))) + (T (IM.ERROR + "unmatched right bracket at top level -- ignored" + ) + NIL))) + (CLOSEF IM.INFILE]) + +(INCLUDE.FILE + [LAMBDA (FILENAME) (* mjs "12-Jul-85 15:41") + (IM.WARNING) + (IM.WARNING) + (OPEN.IM.FILE FILENAME]) + +(LIST.ORDER + [LAMBDA (A B) (* mjs "20-JUN-83 16:33") + (if (AND (LISTP A) + (LISTP B)) + then (if (EQUAL (CAR A) + (CAR B)) + then (LIST.ORDER (CDR A) + (CDR B)) + else (LIST.ORDER (CAR A) + (CAR B))) + else (ALPHORDER A B]) + +(LIST.TO.STRING + [LAMBDA (LST) (* mjs "26-SEP-83 15:20") + (PROG ((STR "")) + [for X on LST do (SETQ STR (CONCAT STR (CAR X) + (if (CDR X) + then " " + else ""] + (RETURN STR]) + +(MAKE.SAVE + [LAMBDA (X) (* mjs "10-Apr-85 17:31") + (if (NULL X) + then NIL + elseif (LISTP X) + then (CONCCONC (MAKE.SAVE (CAR X)) + (MAKE.SAVE (CDR X))) + else (PROG [(S (if (IMAGEOBJP X) + then (CONS X) + else (CHCON X] + (RETURN (CONS S (LAST S]) + +(OPEN.IM.FILE + [LAMBDA (FILENAME) (* mjs "10-Jul-86 15:31") + (PROG ((DIR.LIST (if IM.INFILE.FILENAME + then (CONS (PACKFILENAME 'HOST (FILENAMEFIELD IM.INFILE.FILENAME + 'HOST) + 'DIRECTORY + (FILENAMEFIELD IM.INFILE.FILENAME 'DIRECTORY)) + DIRECTORIES) + else DIRECTORIES)) + (OPEN.FILE.RESULT NIL) + NEW.FILENAME NEW.FILE) + (DECLARE (SPECVARS NEW.FILENAME NEW.FILE)) + (SETQ NEW.FILENAME (if (INFILEP FILENAME) + elseif (if (NULL (FILENAMEFIELD FILENAME 'EXTENSION)) + then (FINDFILE (PACKFILENAME 'BODY FILENAME + 'EXTENSION + 'IM) + T DIR.LIST)) + elseif (FINDFILE FILENAME T DIR.LIST) + else NIL)) + [if (NULL NEW.FILENAME) + then (IM.WARNING "Can't find file: " FILENAME " --- using NULL file") + (SETQ NEW.FILENAME '{NULL}FOO.IM) + (SETQ NEW.FILE (OPENSTREAM '{NULL}FOO.IM 'INPUT)) + else (for W in '(5000 10000 20000 40000 80000) + do (IM.WARNING "Opening File: " NEW.FILENAME) + [SETQ OPEN.FILE.RESULT (NLSETQ (SETQ NEW.FILE (OPENTEXTSTREAM + NEW.FILENAME] + (if (NULL OPEN.FILE.RESULT) + then (IM.WARNING "Error opening file " NEW.FILENAME + " -- waiting " W " msecs and trying again") + (BLOCK W)) repeatuntil OPEN.FILE.RESULT) + (if (NULL OPEN.FILE.RESULT) + then (IM.WARNING "Can't open file " FILENAME " --- using NULL file") + (SETQ NEW.FILENAME '{NULL}FOO.IM) + (SETQ NEW.FILE (OPENSTREAM '{NULL}FOO.IM 'INPUT] + (if IM.INFILE + then (push INFILE.STACK (CONS IM.INFILE IM.INFILE.FILENAME))) + (SETQ IM.INFILE.FILENAME NEW.FILENAME) + (SETQ IM.INFILE NEW.FILE) + (for X in IM.INFILE.NOTE.TAGS do (PUTPROP IM.INFILE.FILENAME X NIL]) + +(PARSE.ATOM + [LAMBDA (SAV) (* mjs "19-MAY-83 12:20") + + (* * note%: eventually, this should be modified so that it doesn't just throw + away everything but the first atom, so that you can DEF things with multiple + words (low priority)) + + (CAR (PARSE.LIST SAV]) + +(PARSE.INDEX.SPEC + [LAMBDA (SAV END.FLG) (* mjs "11-AUG-83 15:26") + + (* * parses the argument to INDEX#TOPROG or REF#TOPROG, which may include an + object type. For {index...}, the argument has the form "xxx xxx " + %. For {SectionRef ...} or {PageRef...}, the arg has the for " xxx xxx" + %. If END.FLG is true, the object-type is at the end of the arg. + PARSE.INDEX.SPEC returns a list ( . )) + + (PROG ((BEGIN.PAREN (CHARCODE %()) + (END.PAREN (CHARCODE %))) + (TYPE 'TERM) + (LST NIL) + TYPE.LST CHAR.LST TEMP (PARENS.TYPE.FLG NIL)) + (SETQ CHAR.LST (APPEND (CAR SAV))) + (if END.FLG + then (SETQ CHAR.LST (DREVERSE CHAR.LST)) + (SETQ BEGIN.PAREN (CHARCODE %))) + (SETQ END.PAREN (CHARCODE %())) + (while (MEMB (CAR CHAR.LST) + (CHARCODE (SPACE TAB CR))) do (SETQ CHAR.LST (CDR CHAR.LST))) + (if (AND (EQ BEGIN.PAREN (CAR CHAR.LST)) + (SETQ TEMP (MEMB END.PAREN CHAR.LST))) + then (SETQ TYPE.LST (LDIFF (CDR CHAR.LST) + TEMP)) + (SETQ CHAR.LST (CDR TEMP)) + (if END.FLG + then (SETQ TYPE.LST (REVERSE TYPE.LST))) + [SETQ TYPE (PARSE.LIST (CONS TYPE.LST (LAST TYPE.LST] + (if (NULL TYPE) + then (SETQ TYPE 'TERM)) + (SETQ PARENS.TYPE.FLG T)) + (if END.FLG + then (SETQ CHAR.LST (DREVERSE CHAR.LST))) + [SETQ LST (PARSE.LIST (CONS CHAR.LST (LAST CHAR.LST] + [if [AND (NOT PARENS.TYPE.FLG) + (SETQ TEMP (TRANSLATE.SPECIAL.TYPES + (U-CASE (if END.FLG + then (CAR (LAST LST)) + else (CAR LST] + then (SETQ TYPE TEMP) + (SETQ LST (if END.FLG + then (CAR (LASTN LST 1)) + else (CDR LST] + (RETURN (CONS LST TYPE]) + +(PARSE.LIST + [LAMBDA (SAV PAREN.FLG) (* mjs " 5-AUG-83 14:42") + + (* * if PAREN.FLG then the left and right paren chars parse as self-delimiting + atoms) + + (if (NULL SAV) + then NIL + elseif (AND (LISTP SAV) + (LISTP (CDR SAV))) + then [PROG [(CHARS (CAR SAV)) + (ELIST NIL) + (CLIST NIL) + (DELIM.CHARS (if PAREN.FLG + then (CHARCODE (SP TAB CR %( %))) + else (CHARCODE (SP TAB CR] + [for X in CHARS when (SMALLP X) + do (if (FMEMB X DELIM.CHARS) + then (if CLIST + then (SETQ ELIST (CONS (PACKC (DREVERSE CLIST)) + ELIST)) + (SETQ CLIST NIL)) + (if [AND PAREN.FLG (FMEMB X (CHARCODE (%( %)] + then (SETQ ELIST (CONS (CHARACTER X) + ELIST))) + else (SETQ CLIST (CONS X CLIST] + (RETURN (DREVERSE (if CLIST + then (CONS (PACKC (DREVERSE CLIST)) + ELIST) + else ELIST] + else NIL]) + +(PARSE.NUMBER.OR.PERCENTAGE + [LAMBDA (SAV TOTAL IF.BAD.NUM) (* mjs "20-APR-83 11:47") + (PROG ((NUM (PARSE.ATOM SAV))) + (if (NUMBERP NUM) + then (RETURN (FIX NUM))) + [if (STRPOS "PERCENT" (U-CASE NUM)) + then (SETQ NUM + (PACK (for X in (UNPACK NUM) + while (MEMB X + '(0 1 2 3 4 5 6 7 8 9 %.)) collect X] + [if (NUMBERP NUM) + then (RETURN (FIX (FTIMES 0.01 TOTAL NUM] + (RETURN IF.BAD.NUM]) + +(PARSE.STRING + [LAMBDA (SAV) (* mjs "20-APR-83 11:44") + (if (NULL SAV) + then "" + elseif (AND (LISTP SAV) + (LISTP (CAR SAV))) + then (CONCATLIST (for X in (CAR SAV) when (SMALLP X) + collect (CHARACTER X))) + else ""]) + +(PARSE.TO.NAME + [LAMBDA NIL (* mjs "12-Jul-85 12:48") + + (* * PARSE.TO.NAME is called just after GOBBLE finds a left-bracket. + It scans the file for the TO name which should follow. + It also processes {Begin and {End constructs. + Note%: this function will not scan past the end of the current + possibly-included file, so that GOBBLE can move the pointer back if necessary.) + + (* * PARSE.TO.NAME returns%: (1) If the current word is not BEGIN or END, a + litatom which is the upper-case version of the name, and leaves the file + pointer to the next character after the name. + (2) If the current word is BEGIN/END, a list of the form + (BEGIN/END TONAME TAG.LIST) In this case, the file ptr is left after the + closing }, or at the closing {, if one is found.) + + (PROG (CLIST ELIST NAME C) + (SETQ CLIST NIL) + (until (EOFP IM.INFILE) do (SETQ C (BIN IM.INFILE)) + (SETQ CLIST (CONS C CLIST)) repeatwhile ( + TO.NAME.CHAR + C)) + [COND + ((NOT (TO.NAME.CHAR C)) + (SETQ CLIST (CDR CLIST)) + (SETFILEPTR IM.INFILE (SUB1 (GETFILEPTR IM.INFILE] + [SETQ NAME (U-CASE (PACKC (DREVERSE CLIST] (* if the scan was ternimated by end + of file, print warning) + (COND + ((EOFP IM.INFILE) + (IM.ERROR "TO Spec " (DESCRIBE.TO NIL NAME NIL) + " terminated by EOF" " --- auto-completed"))) + (COND + ((AND (NEQ NAME 'BEGIN) + (NEQ NAME 'END)) + (RETURN NAME))) + (SETQ ELIST NIL) + (SETQ CLIST NIL) + [until (EOFP IM.INFILE) do (SETQ C (BIN IM.INFILE)) + [COND + [(FMEMB C (CHARCODE ({ } SP TAB CR))) + (COND + (CLIST (SETQ ELIST + (CONS (U-CASE (PACKC (DREVERSE CLIST))) + ELIST)) + (SETQ CLIST NIL] + (T (if (SMALLP C) + then + (* ignore non-smallp chars in TO tag) + (SETQ CLIST (CONS C CLIST] + repeatuntil (FMEMB C (CHARCODE ({ }] + (SETQ ELIST (DREVERSE ELIST)) + (COND + ((AND (EOFP IM.INFILE) + (EQ C (CHARCODE }))) + (IM.ERROR "TO Spec " (DESCRIBE.TO NAME (CAR ELIST) + (CDR ELIST)) + " terminated by EOF" " --- auto-completed"))) + [COND + ((EQ C (CHARCODE {)) (* if {Begin or {End terminated by + {, auto-complete,) + (IM.ERROR "TO Spec " (DESCRIBE.TO NAME (CAR ELIST) + (CDR ELIST)) + " terminated by {" " --- auto-completed") + (SETFILEPTR IM.INFILE (SUB1 (GETFILEPTR IM.INFILE] + (RETURN (LIST NAME (CAR ELIST) + (CDR ELIST]) + +(PARTITION.LIST + [LAMBDA (LST EQUAL.FN MAKE.TOKEN.FN SORT.TOKEN.FN) (* ; "Edited 8-Dec-91 15:03 by jds") + + (* ;; "LST is a list of objects (X1 X2 X3 X4 ...); PARTITION.LIST partitions them into sublists ((X1 X4 X7 ...) (X2 X56 ...) ...) where the members of each sublist are 'equal' as determined by EQUAL.FN (default EQUAL), and returns the resulting list") + + (* ;; "if MAKE.TOKEN.FN is given, this is a function applied to each object to create 'tokens' , which are compared with EQUAL.FN . This is done so that MAKE.TOKEN.FN is done as few times as possible, which is nice if MAKE.TOKEN.FN is expensive. For example, (PARTITION.LIST L (QUOTE EQ) (QUOTE LENGTH)) is the same as (PARTITION L (QUOTE (LAMBDA (A B) (EQ (LENGTH A) (LENGTH B))))), but much less expensive, since LENGTH is only computed once for each element of L") + + (* ;; "if SORT.TOKEN.FN is given, the list is sorted by the 'order' of the tokens as determined by essentially evaluating (SORT SORT.TOKEN.FN)") + + (PROG ((NEWLIST NIL) + SUBNEWLIST) + (DECLARE (SPECVARS SORT.TOKEN.FN)) + (if (NULL EQUAL.FN) + then (SETQ EQUAL.FN 'EQUAL)) + [if (NULL MAKE.TOKEN.FN) + then (SETQ MAKE.TOKEN.FN (FUNCTION (LAMBDA (X) + X] + [for OBJECT in LST bind OBJECT.TOKEN + do (SETQ OBJECT.TOKEN (APPLY* MAKE.TOKEN.FN OBJECT)) + (* ; + "find first sublist in NEWLIST whose CAR is a token 'equal' to OBJECT.TOKEN") + [SETQ SUBNEWLIST (for X in NEWLIST thereis (APPLY* EQUAL.FN + OBJECT.TOKEN + (CAR X] + (if SUBNEWLIST + then (* ; + "if there is such a sublist, put OBJECT second in list ") + (RPLACD SUBNEWLIST (CONS OBJECT (CDR SUBNEWLIST))) + else (SETQ NEWLIST (CONS (LIST OBJECT.TOKEN OBJECT) + NEWLIST] (* ; + "if SORT.TOKEN.FN is given, sort the lists by the tokens") + [if SORT.TOKEN.FN + then (SORT NEWLIST (FUNCTION (LAMBDA (X Y) + (APPLY* SORT.TOKEN.FN (CAR X) + (CAR Y] + (* ; + "get rid of token at beginning of each sublist") + (for X in NEWLIST do (RPLNODE2 X (CDR X))) + (RETURN NEWLIST]) + +(PRINT.INFILE.NOTES + [LAMBDA NIL (* mjs "25-Jul-85 10:48") + (for TYP in IM.INFILE.NOTE.TAGS bind LST when (SETQ LST (GETPROP + IM.INFILE.FILENAME + TYP)) + do (SETQ LST (SORT (INTERSECTION LST LST))) + (IM.WARNING " ---------- " (SELECTQ TYP + (UNDEF.FN "Undefined Functions") + (UNBOUND.VAR "Unbound Variables") + (IM.TAG "Tags") + (IM.NO.REFS "Unresolved References") + (MKSTRING TYP))) + (for X in LST do (IM.WARNING " " X)) finally (IM.WARNING]) + +(PUT.MY.PROP + [LAMBDA (PROPNAME VAL) (* mjs "13-APR-83 10:30") + (LISTPUT TO.PROP.LIST PROPNAME VAL]) + +(SAVE.ARG + [LAMBDA (NO.SKIP.FLG) (* mjs "21-APR-83 14:14") + (PROG (SAVE) + (if (fetch TO.ARGS of TO.NAME) + then (if TO.ARG.NAME + then (SETQ SAVE (GOBBLE.SAVE NO.SKIP.FLG)) + (SETQ TO.ARG.NAME NIL) + else (ERROR "TO PROG BUG: attempting to dump arg not yet gotten")) + else (if (NOT TO.DONE.FLG) + then (SETQ SAVE (GOBBLE.SAVE NO.SKIP.FLG)) + (SETQ TO.DONE.FLG T) + else (ERROR "TO PROG BUG: attempting to process unlabeled arg twice"))) + (RETURN SAVE]) + +(SAVE.ARGS + [NLAMBDA GOOD.ARGS (* mjs "18-APR-83 16:55") + + (* * gets and saves args with the names on GOOD.ARGS until an unknown name + comes up. If duplicate names come up, the later arg replaces the formar.) + + (PROG (ANAME (ARG.PROPLIST (CONS))) + (if TO.DONE.FLG + then (PUT.MY.PROP 'SAVE.ARGS.PROPLIST NIL) + (RETURN NIL)) + loop + (SETQ ANAME (GET.ARG)) + (if (AND ANAME (FMEMB ANAME GOOD.ARGS)) + then (LISTPUT ARG.PROPLIST ANAME (SAVE.ARG)) + (GO loop) + else (PUT.MY.PROP 'SAVE.ARGS.PROPLIST (COND + ((CDR ARG.PROPLIST) + ARG.PROPLIST) + (T NIL))) + (RETURN ANAME]) + +(SAVE.ARGS.EMPTY + [LAMBDA NIL (* mjs "13-APR-83 10:29") + + (* if called right after a call to SAVE.ARGS, this will return T if SAVE.ARGS + did not find any args, and the TO has been closed.) + + (AND TO.DONE.FLG (NOT (GET.MY.PROP 'SAVE.ARGS.PROPLIST]) + +(SAVE.INFILE.NOTE + [LAMBDA (TYP NAM) (* mjs "29-Jul-85 16:29") + (PUTPROP IM.INFILE.FILENAME TYP (CONS NAM (GETPROP IM.INFILE.FILENAME TYP]) + +(SCRUNCH.REFS + [LAMBDA (REFS) (* mjs "28-SEP-83 12:01") + (PROG (REFS.BY.TYPE) + + (* * REFS is list with elements of form%: + (type text info section file fileptr)) + + (* * REFS.BY.TYPE is list with elements of form%: + ((type text info section file fileptr) (type text info section file fileptr) + ...) partioned by type, case-independent, sorted by ALPHORDER of U-CASE of type) + + [SETQ REFS.BY.TYPE (PARTITION.LIST REFS NIL [FUNCTION (LAMBDA (A) + (U-CASE (CAR A] + (FUNCTION (LAMBDA (A B) + (LIST.ORDER A B] + (RETURN + (for REFS.ON.ONE.TYPE in REFS.BY.TYPE bind REFS.BY.FILE + collect + + (* REFS.BY.FILE is list of refs partioned by file, case-independent, sorted by + ALPHORDER of U-CASE of file) + + (SETQ REFS.BY.FILE (PARTITION.LIST REFS.ON.ONE.TYPE NIL + [FUNCTION (LAMBDA (A) + (U-CASE (CAR (CDDDDR A] + (FUNCTION ALPHORDER))) + (CONS + (if (NLISTP (CAAR REFS.ON.ONE.TYPE)) + then (MKSTRING (L-CASE (CAAR REFS.ON.ONE.TYPE) + T)) + else (LIST.TO.STRING (L-CASE (CAAR REFS.ON.ONE.TYPE) + T))) + (for REFS.ON.ONE.FILE in REFS.BY.FILE + collect + (CONS [U-CASE (CAR (CDDDDR (CAR REFS.ON.ONE.FILE] + (PROG [(SMALLREFS (for REF in REFS.ON.ONE.FILE + collect (LIST (if (MEMB '*PRIMARY* (CADDR REF)) + then 'Primary + elseif (MEMB '*DEF* (CADDR + REF)) + then 'Definition + else NIL) + (CADR (CDDDDR REF] + [SORT SMALLREFS (FUNCTION (LAMBDA (A B) + (IGEQ (CADR B) + (CADR A] + (RETURN (APPLY 'NCONC SMALLREFS]) + +(SEND.IMPLICIT + [LAMBDA (NAME TYPE SAV) (* mjs " 5-AUG-83 13:55") + + (* if IM.SEND.IMPLICIT is true and there are no references to this object in + the index table, then send an implicit reference to this object) + + (if (AND IM.SEND.IMPLICIT (for X in (GETHASH NAME IMPTR.HASH) + never (EQUAL (CAR X) + TYPE))) + then (if (U-CASEP NAME) + then (SEND.INFO NAME TYPE NIL '(*IMPLICIT*)) + else (SEND.INFO (U-CASE NAME) + TYPE NAME '(*IMPLICIT*]) + +(SKIP.WHITE.SPACE + [LAMBDA NIL (* mjs "10-Apr-85 10:09") + (PROG (X) + [do (SETQ X (if (EOFP IM.INFILE) + then (IM.FILE.EOF) + else (BIN IM.INFILE))) repeatwhile (FMEMB X + (CHARCODE (SPACE CR TAB + ] + (COND + ((NEQ X 'EOF) + (SETFILEPTR IM.INFILE (SUB1 (GETFILEPTR IM.INFILE]) + +(STANDARD.DUMMY.TO.PROG + [LAMBDA NIL (* mjs " 9-Apr-85 16:00") + (IM.ERROR "Dummy TO - " TO.NAME) + (DUMP.ARG]) + +(TAG.LIST.MATCH + [LAMBDA (TLIST1 TLIST2) (* mjs " 8-APR-83 15:56") + (EQUAL (U-CASE TLIST1) + (U-CASE TLIST2]) + +(TO.MATCH + [LAMBDA (NAME BEGINFLG TAGLIST) (* mjs " 8-APR-83 15:58") + (AND (EQ NAME TO.NAME) + (EQ BEGINFLG TO.BEGIN.FLG) + (OR (NOT BEGINFLG) + (TAG.LIST.MATCH TAGLIST TO.TAG.LIST]) + +(TO.NAME.CHAR + [LAMBDA (C) (* mjs "12-Jul-85 12:43") + (* returns true if C is the char + code of a legal TO name char) + (AND (SMALLP C) + (OR (AND (IGEQ C (CHARCODE A)) + (ILEQ C (CHARCODE Z))) + (AND (IGEQ C (CHARCODE a)) + (ILEQ C (CHARCODE z))) + (AND (IGEQ C (CHARCODE 0)) + (ILEQ C (CHARCODE 9]) + +(TRANSLATE.SPECIAL.TYPES + [LAMBDA (X) (* mjs " 9-NOV-83 12:17") + (SELECTQ (U-CASE X) + (FN '(Function)) + (VAR '(Variable)) + (PROP '(Property Name)) + (BREAKCOM '(Break Command)) + (EDITCOM '(Editor Command)) + (PACOM '(Prog. Asst. Command)) + (FILECOM '(File Package Command)) + ((LITATOM ATOM) + '(Litatom)) + (ERROR '(Error Message)) + (TERM 'TERM) + ((TAG FIGURE) + 'TAG) + NIL]) + +(TRIVIAL.ARG + [LAMBDA NIL (* mjs "21-APR-83 14:10") + (if (fetch TO.ARGS of TO.NAME) + then (if TO.ARG.NAME + then (GOBBLE.TRIVIAL) + (SETQ TO.ARG.NAME NIL) + else (ERROR "TO PROG BUG: attempting to process ungotten arg ")) + else (if (NOT TO.DONE.FLG) + then (GOBBLE.TRIVIAL) + (SETQ TO.DONE.FLG T) + else (ERROR "TO PROG BUG: attempting to process unlabeled arg twice"]) +) +(DECLARE%: EVAL@COMPILE + +(ATOMRECORD TO (TO.PROG TO.ARGS TO.ARG.SYNONYMS TO.TYPE TO.ARG.TYPE)) +) + +(RPAQQ IM.INFILE.NOTE.TAGS (UNDEF.FN UNBOUND.VAR IM.TAG IM.NO.REFS IM.FIGURE BAD.TO.NAME)) + +(RPAQ? IM.NOTE.FLG NIL) + +(RPAQ? IM.DRAFT.FLG NIL) + +(RPAQ? IM.INDEX.FILE.FLG NIL) + +(RPAQ? IM.REF.FLG NIL) + +(RPAQ? IM.SEND.IMPLICIT NIL) + +(RPAQ? IM.EVEN.FLG NIL) + +(RPAQ? IM.CHECK.DEFS NIL) + +(PUTPROPS DUMPOUT INFO EVAL) +(DECLARE%: EVAL@COMPILE + +[PUTPROPS IM.ERROR MACRO (X `(IM.PRINT.MESSAGE "ERROR: " T %, (CONS 'LIST X] + +[PUTPROPS IM.WARNING MACRO (X `(IM.PRINT.MESSAGE " Warning: " NIL %, (CONS 'LIST X] +) +(DECLARE%: DONTEVAL@LOAD DOEVAL@COMPILE DONTCOPY COMPILERVARS + +(ADDTOVAR NLAMA SAVE.ARGS) + +(ADDTOVAR NLAML GET.ARG.SAV) + +(ADDTOVAR LAMA ) +) +(PUTPROPS IMTRAN COPYRIGHT ("Xerox Corporation" 1983 1984 1985 1986 1991)) +(DECLARE%: DONTCOPY + (FILEMAP (NIL (2346 60730 (ADD.ANY.PARENT.PROP.IF 2356 . 2594) (ADD.MY.PROP.IF 2596 . 2869) ( +ANC.INDENT 2871 . 3016) (ANC.WIDTH 3018 . 3161) (ANY.PARENT.CORRECT.ARG 3163 . 3345) (ANY.PARENT.EVAL +3347 . 3759) (ANY.PARENT.TO.MATCH 3761 . 4044) (ARGS.REMAINING 4046 . 4672) (ARGS.REMAINING.AFTER 4674 + . 5269) (CHANGE.INDENT 5271 . 5677) (CONCCONC 5679 . 6170) (CORRECT.ARG 6172 . 6451) (CORRECT.TO 6453 + . 8832) (DECODE.TO.ARG.NAME.SYNONYM 8834 . 9243) (DECODE.TO.NAME.SYNONYM 9245 . 9435) (DEFINED.TO +9437 . 9580) (DESCRIBE.CURRENT.TO 9582 . 9872) (DESCRIBE.TO 9874 . 10281) (DUMP.ARG 10283 . 10908) ( +DUMP.FORMAT 10910 . 11165) (FLUSH.ARG 11167 . 11771) (GET.ANY.PARENT.PROP 11773 . 11956) (GET.ARG +11958 . 16446) (GET.ARG.SAV 16448 . 16624) (GET.ARG.TYPE 16626 . 17103) (GET.MY.PROP 17105 . 17249) ( +GET.TO.TYPE 17251 . 17598) (GOBBLE 17600 . 23789) (GOBBLE.DUMP 23791 . 24094) (GOBBLE.DUMP.UNDEFINED +24096 . 24773) (GOBBLE.FLUSH 24775 . 25277) (GOBBLE.SAVE 25279 . 25694) (GOBBLE.TRIVIAL 25696 . 28421) + (IM.DUMP.CHARS 28423 . 28799) (IM.FILE.EOF 28801 . 29418) (IM.PRINT.MESSAGE 29420 . 31602) (IMTRAN +31604 . 34215) (INCLUDE.FILE 34217 . 34392) (LIST.ORDER 34394 . 34865) (LIST.TO.STRING 34867 . 35307) +(MAKE.SAVE 35309 . 35774) (OPEN.IM.FILE 35776 . 38565) (PARSE.ATOM 38567 . 38920) (PARSE.INDEX.SPEC +38922 . 41310) (PARSE.LIST 41312 . 43041) (PARSE.NUMBER.OR.PERCENTAGE 43043 . 43688) (PARSE.STRING +43690 . 44073) (PARSE.TO.NAME 44075 . 47932) (PARTITION.LIST 47934 . 50937) (PRINT.INFILE.NOTES 50939 + . 51893) (PUT.MY.PROP 51895 . 52043) (SAVE.ARG 52045 . 52791) (SAVE.ARGS 52793 . 53768) ( +SAVE.ARGS.EMPTY 53770 . 54103) (SAVE.INFILE.NOTE 54105 . 54297) (SCRUNCH.REFS 54299 . 57088) ( +SEND.IMPLICIT 57090 . 57793) (SKIP.WHITE.SPACE 57795 . 58417) (STANDARD.DUMMY.TO.PROG 58419 . 58594) ( +TAG.LIST.MATCH 58596 . 58761) (TO.MATCH 58763 . 59013) (TO.NAME.CHAR 59015 . 59577) ( +TRANSLATE.SPECIAL.TYPES 59579 . 60118) (TRIVIAL.ARG 60120 . 60728))))) +STOP diff --git a/docs/Documentation Tools/IMTRAN.LCOM b/docs/Documentation Tools/IMTRAN.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..b002ec65982290f6973d654e08e966db724061bf GIT binary patch literal 24271 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 literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/INDEX-FORMAT.TEDIT b/docs/Documentation Tools/INDEX-FORMAT.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..096b1e36b56b42bca7dadc1d08e9eaa11767b080 GIT binary patch literal 1740 zcmZ`(!EW0|5T(2;P9F(Ur5O~%oSj%Yvn*MVXe(I^l`3h2WOD!+SozV3*k6v zDq?SF7=rPJ(%R)W1pQ<@iWBHhE?$kJcoKOIkiay)g2(-3UXa3)>_C9QKmxr%c5@kl zAzK%osa%uTe~oAHo3}rWbo$~->&pI24qwb@DZjB04`;ZJxQyI+PE)-G>(Dr0BqPIB zN04x6hxQtB>(itesuckih5u@)LW52lD;b4{WRCzYwE@~-Srs(&c-t!O;mTmiY+Y@X zg$h^Py3UpR3QwZ5=kVk-dOAFR#)oIodH6lY6CR%Qw)?Oqs4drd;2nDJ@TtTI+X&$~ z`~RkRYOYr3sAz`LcSun^c2M&0cI7Ba$yziGv~~L62&+QRu>f1ot;=2QxFnmal-OA{ zGG{4#uN7z{q}5$vjy4WZE&RPymnCuo{-|@F8AIqi9YYmMt-X?A<;Z}l%Q+cl|B^W3 zN|XJu7ly}|IcttH`bd_|BhBi&y| z+nOO~5)#l-nWwtokp1TaPybGe-iol$4q#5)=~k0_(V5CelGsj|Z*vvg2A)z{-#!_lxBhT? zdaK4D(akTqHo6(EY=Elf_uSP za1uN^`ZxGefY0s+!BOx?j(2~~*mUx-$I0EdJIj5}^>y$?GM-K1>BUu>&l?{GpHE(o z#@W?h!f M<$(>p`t$Gq07-P-od5s; literal 0 HcmV?d00001 diff --git a/docs/Documentation Tools/NONAME.IMPTR b/docs/Documentation Tools/NONAME.IMPTR new file mode 100644 index 00000000..26a256ac --- /dev/null +++ b/docs/Documentation Tools/NONAME.IMPTR @@ -0,0 +1,2 @@ +(ASDF NIL NIL NIL ("1") 1) +(ASDF NIL NIL NIL ("A") 2)