From 6f9648868bed01cb544455635de238fd1c95cb23 Mon Sep 17 00:00:00 2001 From: Larry Masinter Date: Mon, 8 Mar 2021 18:51:25 -0800 Subject: [PATCH] delete WINDOW-OLD, old version of WINDOW (#241) --- sources/WINDOW-OLD | 1 - sources/WINDOW-OLD.LCOM | Bin 53851 -> 0 bytes 2 files changed, 1 deletion(-) delete mode 100644 sources/WINDOW-OLD delete mode 100644 sources/WINDOW-OLD.LCOM diff --git a/sources/WINDOW-OLD b/sources/WINDOW-OLD deleted file mode 100644 index 466b6cac..00000000 --- a/sources/WINDOW-OLD +++ /dev/null @@ -1 +0,0 @@ -(DEFINE-FILE-INFO PACKAGE "INTERLISP" READTABLE "INTERLISP" BASE 10) (FILECREATED "20-Aug-91 18:35:01" |{PELE:MV:ENVOS}SOURCES>WINDOW.;3| 169079 changes to%: (FNS UPDATEWFROMIMAGE) previous date%: "18-May-90 00:59:17" |{PELE:MV:ENVOS}SOURCES>WINDOW.;2|) (* ; " Copyright (c) 1982, 1983, 1984, 1985, 1986, 1987, 1988, 1990, 1991 by Venue & Xerox Corporation. All rights reserved. ") (PRETTYCOMPRINT WINDOWCOMS) (RPAQQ WINDOWCOMS [(COMS (FNS WINDOWWORLD WINDOWWORLDP CHANGEBACKGROUND CHANGEBACKGROUNDBORDER TILE \TTY.CREATING.DISPLAYSTREAM \CREATE.TTY.OUTCHARFN \CREATE.TTYDISPLAYSTREAM HASTTYWINDOWP TTYINFOSTREAM CREATESCREEN \INSURESCREEN \BITMAPTOSCREEN MAINSCREEN) (VARS (\TTYREGIONOFFSETSPTR)) (INITVARS [TTYREGIONOFFSETS '((0 . 0) (20 . -20) (40 . 0) (20 . 20] (DEFAULTTTYREGION '(153 100 384 208)) (INITIAL-EXEC-REGION '(8 378 550 330)) (INITIAL-PROMPT-REGION '(8 719 550 89)) (\MAINSCREEN) (\CURRENTBACKGROUNDBORDER) (\SCREENS) (\SCREENBITMAPS)) (GLOBALVARS \TTYREGIONOFFSETSPTR TTYREGIONOFFSETS \DEFAULTTTYDISPLAYSTREAM) (VARIABLES \TopLevelTtyWindow)) (COMS (* ; "Window menu operations") (FNS WINDOW.MOUSE.HANDLER \PROTECTED.APPLY DOWINDOWCOM DOBACKGROUNDCOM DEFAULT.BACKGROUND.COPYFN) (VARS (BackgroundCopyMenu)) (INITVARS BackgroundCopyMenuCommands) (FNS BURYW CLEARW CLOSEW \CLOSEW1 \OKTOCLOSEW \INTERACTIVE.CLOSEW OPENW DOUSERFNS DOUSERFNS2 \USERFNISDON'T \OPENW1 CREATEW OPENDISPLAYSTREAM MOVEW PPROMPT3 \ONSCREENCLIPPINGREGION RELMOVEW SHAPEW SHAPEW1 \SHAPEW2 RESHOWBORDER \RESHOWBORDER1 TRACKW SNAPW WINDOWREGION) (FNS MINIMUMWINDOWSIZE) (INITVARS (BACKGROUNDCURSORINFN) (BACKGROUNDBUTTONEVENTFN) (BACKGROUNDCURSOROUTFN) (BACKGROUNDCURSORMOVEDFN) (BACKGROUNDCOPYBUTTONEVENTFN) (BACKGROUNDCOPYRIGHTBUTTONEVENTFN (FUNCTION DEFAULT.BACKGROUND.COPYFN)) (BACKGROUNDCURSOREXITFN)) (GLOBALVARS BACKGROUNDCURSORINFN BACKGROUNDBUTTONEVENTFN BACKGROUNDCURSOROUTFN BACKGROUNDCURSORMOVEDFN BACKGROUNDCOPYBUTTONEVENTFN BACKGROUNDCOPYRIGHTBUTTONEVENTFN \CARET.UP BACKGROUNDCURSOREXITFN) (EXPORT (MACROS .COPYKEYDOWNP. WSOP)) (PROP ARGNAMES WSOP) (RECORDS WSOPS WSDATA)) (COMS (* ; "Window utilities") (FNS ADVISEWDS SHOWWFRAME SHOWWTITLE \STRINGWIDTHGUESS RESHOWTITLE TOTOPW \INTERNALTOTOPW \TTW1 WHICHW) (INITVARS (WINDOWTITLEPRINTLEVEL '(2 . 5)) (WINDOWTITLESHADE BLACKSHADE))) [COMS (* ; "Window vs non-window world") (FNS WFROMDS NU\TOTOPWDS \COERCETODS) (DECLARE%: DONTCOPY (EXPORT (MACROS \COERCETODS .WHILE.ON.TOP.))) (P (MOVD 'NU\TOTOPWDS '\TOTOPWDS] (COMS (* ; "User interface functions") (FNS WINDOWP INSURE.WINDOW WINDOWPROP WINDOWADDPROP WINDOWDELPROP GETWINDOWPROP GETWINDOWUSERPROP PUTWINDOWPROP REMWINDOWPROP WINDOWADDFNPROP) (* ; "Compiled WINDOWPROP") (PROP ARGNAMES WINDOWPROP) (OPTIMIZERS WINDOWPROP) (FNS CWINDOWPROP CGETWINDOWPROP \GETWINDOWHEIGHT \GETWINDOWWIDTH)) (COMS (FNS OPENWP TOPWP RESHAPEBYREPAINTFN \INBETWEENP DECODE/WINDOW/OR/DISPLAYSTREAM GROW/REGION CLRPROMPT PROMPTPRINT OPENWINDOWS \INSUREWINDOW) (* ;  "these entries are left in for backward compatibility. They were dedocumented 6/83. rrb") (P (MOVD 'OPENWP 'ACTIVEWP)) (FNS OVERLAPPINGWINDOWS WOVERLAPP ORDERFROMBOTTOMTOTOP) (* ; "screen size changing functions.") (FNS \ONSCREENW \PUTONSCREENW \UPDATECACHEDFIELDS \WWCHANGESCREENSIZE CREATEWFROMIMAGE UPDATEWFROMIMAGE)) (DECLARE%: EVAL@COMPILE DONTCOPY (GLOBALVARS \LastCursorPosition \LastInWindow WindowMenu BackgroundMenu BackgroundMenuCommands \LastWindowButtons WWFNS WindowMenuCommands WindowTitleDisplayStream WINDOWTITLEPRINTLEVEL WBorder \TOPWDS WINDOWBACKGROUNDSHADE BACKGROUNDFNS) (EXPORT (CONSTANTS (MinWindowWidth 26) (MinWindowHeight 16)) (RECORDS WINDOW SCREEN))) (DECLARE%: EVAL@COMPILE (EXPORT (GLOBALVARS WINDOWUSERFORMS ENDOFWINDOWUSERFORMS PROMPTWINDOW ))) (SYSRECORDS WINDOW SCREEN) (INITRECORDS WINDOW SCREEN) (INITVARS (WindowMenu) (BackgroundMenu) (\LastCursorPosition (CREATEPOSITION)) (\LastInWindow) (\LastWindowButtons 0) (WINDOWBACKGROUNDSHADE 34850) (WBorder 4) (HIGHLIGHTSHADE 32800) (WINDOWBACKGROUNDBORDER 34850)) (FILES PAINTW) [ADDVARS (WindowMenuCommands (Close '\INTERACTIVE.CLOSEW "Closes a window") (Snap 'SNAPW "Saves a snapshot of a region of the screen.") (Paint 'PAINTW "Starts a painting mode in which the mouse can be used to draw pictures or make notes on windows.") (Clear 'CLEARW "Clears a window to its gray.") (Bury 'BURYW "Puts a window on the bottom.") (Redisplay 'REDISPLAYW "Redisplays a window using its REPAINTFN.") (Hardcopy 'HARDCOPYIMAGEW "Prints a window using its HARDCOPYFN." (SUBITEMS ("To a file" 'HARDCOPYIMAGEW.TOFILE "Puts image on a file; prompts for filename and format" ) ("To a printer" 'HARDCOPYIMAGEW.TOPRINTER "Sends image to a printer of your choosing"))) (Move 'MOVEW "Moves a window by a corner.") (Shape 'SHAPEW "Gets a new region for a window. Left button down marks fixed corner; sweep to other corner. Middle button down moves closest corner.") (Shrink 'SHRINKW "Replaces this window with its icon (or title if it doesn't have an icon." )) (BackgroundMenuCommands (SaveVM '(SAVEVM) "Updates the virtual memory.") (Snap '(SNAPW) "Saves a snapshot of a region of the screen.") (Hardcopy '(HARDCOPYW) "Send hardcopy of screen region to printer." (SUBITEMS ("To a file" '(HARDCOPYREGION.TOFILE) "Writes a region of screen to a file; prompts for filename and format" ) ("To a printer" '(HARDCOPYREGION.TOPRINTER) "Sends a region of screen to a printer of your choosing"] (ADDVARS (WINDOWUSERFORMS) (ENDOFWINDOWUSERFORMS)) (DECLARE%: DONTEVAL@LOAD DOCOPY [P (COND ((NULL \MAINSCREEN) (SETQ \MAINSCREEN (CREATESCREEN (SCREENBITMAP))) (SETQ \CURSORSCREEN \MAINSCREEN) (SETQ LASTSCREEN \MAINSCREEN) (WINDOWWORLD 'ON \MAINSCREEN T] (VARS (\WINDOWWORLD T))) (* ;; "Arrange for the proper compiler") (PROP FILETYPE WINDOW) (DECLARE%: DONTEVAL@LOAD DOEVAL@COMPILE DONTCOPY COMPILERVARS (ADDVARS (NLAMA) (NLAML) (LAMA PROMPTPRINT WINDOWPROP DOWINDOWCOM]) (DEFINEQ (WINDOWWORLD [LAMBDA (ONOFF SCREEN MAINFLG) (* ; "Edited 4-Dec-86 23:24 by lmm") (* ;; "ONOFF should be ON or OFF. SCREEN will generally be either \MAINSCREEN or \COLORSCREEN. MAINFLG = T if this is the first window world being created (\MAINSCREEN), in which case we create the EXEC window, PROMPTWINDOW, and LOGOW. ") (DECLARE (GLOBALVARS \TopLevelTtyWindow)) (PROG NIL (SETQ SCREEN (\INSURESCREEN SCREEN)) (COND ((NULL ONOFF) (RETURN (fetch (SCREEN SCONOFF) of SCREEN))) ((EQ ONOFF (fetch (SCREEN SCONOFF) of SCREEN)) (* ; "Already on or off. *") ) ((EQ ONOFF 'ON) (UNINTERRUPTABLY (\CLEARBM (fetch (SCREEN SCDESTINATION) of SCREEN) WINDOWBACKGROUNDSHADE) (* ;  "Initially there are no windows. SCTOPW must be NIL before any CREATEWs are done. ") (replace (SCREEN SCTOPW) of SCREEN with NIL) (CHANGEBACKGROUNDBORDER WINDOWBACKGROUNDBORDER) (SETQ \TOPWDS NIL) (push \SCREENBITMAPS (fetch (SCREEN SCDESTINATION) of SCREEN)) (push \SCREENS SCREEN) (replace (SCREEN SCONOFF) of SCREEN with 'ON) [COND (MAINFLG (* ;  "creating the first window system") (* ;; "set up stream for displaying titles") (SETQ WindowTitleDisplayStream (fetch (SCREEN SCTITLEDS) of SCREEN)) (* ;  "Get TTY in shape. Region is only approx as user can change it.") (* ;; "default display stream will create a window when it needs one") (SETQ \DEFAULTTTYDISPLAYSTREAM (\TTY.CREATING.DISPLAYSTREAM)) (* ;; "create the exec window") (TTYDISPLAYSTREAM (SETQ \TopLevelTtyWindow (CREATEW INITIAL-EXEC-REGION "Exec"))) (SETLINELENGTH) (SETQ PROMPTWINDOW (CREATEW INITIAL-PROMPT-REGION "Prompt Window" 2)) (DSPTEXTURE BLACKSHADE PROMPTWINDOW) (DSPOPERATION 'ERASE PROMPTWINDOW) (DSPSCROLL 'ON PROMPTWINDOW) (WINDOWPROP PROMPTWINDOW 'SHRINKFN 'DON'T) (CLEARW PROMPTWINDOW) (WINDOWPROP PROMPTWINDOW 'PAGEFULLFN (FUNCTION NILL)) (* ;; "window.mouse.handler variables?") (SETQ \LastInWindow NIL) (SETQ \LastWindowButtons 0) (SETQ \LastCursorPosition (create POSITION)) (* ;; "other things that happen at WINDOWWORLD time") (MAPC WINDOWUSERFORMS (FUNCTION EVAL])]) (WINDOWWORLDP [LAMBDA (SCREEN) (* kbr%: "30-Mar-85 14:28") (* ; "is the window system operating?") (EQ (fetch (SCREEN SCONOFF) of (\INSURESCREEN SCREEN)) 'ON]) (CHANGEBACKGROUND (LAMBDA (SHADE SCREEN) (* ; "Edited 6-Jul-88 11:39 by drc:") (* ; "changes the window world background to SHADE") (PROG (WINDOWS) (COND ((OR (NULL SHADE) (EQ SHADE T)) (SETQ SHADE WINDOWBACKGROUNDSHADE)) ((NOT (OR (TEXTUREP SHADE) (BITMAPP SHADE))) (\ILLEGAL.ARG SHADE))) (OR SCREEN (SETQ SCREEN \CURSORSCREEN)) (SETQ WINDOWS (OPENWINDOWS SCREEN)) (for W in WINDOWS do (\CLOSEW1 W)) (COND ((TEXTUREP SHADE) (BLTSHADE SHADE (fetch (SCREEN SCDESTINATION) of SCREEN))) ((BITMAPP SHADE) (TILE SHADE (fetch (SCREEN SCDESTINATION) of SCREEN)))) (for W in (DREVERSE WINDOWS) do (\OPENW1 W)))) ) (CHANGEBACKGROUNDBORDER [LAMBDA (SHADE) (* lmm "25-Apr-86 15:48") (* ;; "Changes the screen border on a Dandelion. SHADE is a 8x2 pattern") (PROG1 \CURRENTBACKGROUNDBORDER (COND ((SMALLP SHADE) (SETQ \CURRENTBACKGROUNDBORDER SHADE) (SELECTC \MACHINETYPE (\DANDELION (replace (IOPAGE DLDISPBORDER) of \IOPAGE with SHADE)) (\DAYBREAK (\DoveDisplay.SetBorderPattern SHADE)) NIL]) (TILE [LAMBDA (SRC DST) (* kbr%: "10-Jul-85 23:51") (PROG (X Y W H DSTW DSTH) (SETQ X 0) (SETQ Y 0) (SETQ W (BITMAPWIDTH SRC)) (SETQ H (BITMAPHEIGHT SRC)) (SETQ DSTW (BITMAPWIDTH DST)) (SETQ DSTH (BITMAPHEIGHT DST)) (while (ILESSP X DSTW) do (SETQ Y 0) (while (ILESSP Y DSTH) do (BITBLT SRC 0 0 DST X Y W H NIL 'REPLACE) (add Y H)) (add X W]) (\TTY.CREATING.DISPLAYSTREAM [LAMBDA NIL (* rmk%: "27-AUG-83 13:41") (* ;; "creates a displaystream that points to a stream that has a OUTCHARFN that creates a new displaystream. It is used as the default TtyDisplayStream in a process.") (PROG [(DS (DSPCREATE (BITMAPCREATE 1 1] (replace OUTCHARFN of DS with (FUNCTION \CREATE.TTY.OUTCHARFN)) (replace FULLFILENAME of DS with T) (RETURN DS]) (\CREATE.TTY.OUTCHARFN [LAMBDA (STREAM CHAR) (* ; "Edited 8-Mar-87 14:58 by bvm:") (* ;;  "outcharfn for \DEFAULTTTYDISPLAYSTREAM which creates a new window and then bouts to it.") (\OUTCHAR (\CREATE.TTYDISPLAYSTREAM) CHAR]) (\CREATE.TTYDISPLAYSTREAM [LAMBDA NIL (* ; "Edited 9-Mar-87 13:05 by bvm:") (* ;; "Called when system attempts input from or output to the %"default tty stream%", a dummy stream that is every new process's initial standard i/o. We make a new window to be the ttydisplaystream, and return the stream.") [COND ((AND \WINDOWWORLD (NOT (HASTTYWINDOWP NIL))) (* ;; "Check that the process does not yet have a tty window. We can get called even after one is created in the case where somebody explicitly passed (TTYDISPLAYSTREAM) or *STANDARD-OUTPUT* as an argument to someone else (e.g., as stream arg to a printing fn that prints more than one character). In this case, TTYDISPLAYSTREAM can't update the private variable holding the stream, so the dummy outcharfn gets called again. So avoid creating a second window!") (* ;; "\windowworld check is to prevent error when loading window during loadup") (COND ((NULL (SETQ \TTYREGIONOFFSETSPTR (CDR \TTYREGIONOFFSETSPTR))) (* ;  "the offsets distribute the break windows a little so many can be seen.") (SETQ \TTYREGIONOFFSETSPTR TTYREGIONOFFSETS))) (SETQ \TTYWINDOW (CREATEW (CREATEREGION (IPLUS (fetch (REGION LEFT) of DEFAULTTTYREGION ) (CAR (CAR \TTYREGIONOFFSETSPTR))) (IPLUS (fetch (REGION BOTTOM) of DEFAULTTTYREGION ) (CDR (CAR \TTYREGIONOFFSETSPTR))) (fetch (REGION WIDTH) of DEFAULTTTYREGION) (fetch (REGION HEIGHT) of DEFAULTTTYREGION)) (CONCAT "TTY window for " (PROCESSPROP (THIS.PROCESS) 'NAME)) NIL T)) (* ;; "\TTYWINDOW (bound at top of each process) saves the window so it won't get collected. This allows WFROMDS to find it even if it is closed, which is how we create it initially (in case no output ever actually happens). In future, if windows become streams this can go away.") (TTYDISPLAYSTREAM \TTYWINDOW)) ((EQ *STANDARD-OUTPUT* \DEFAULTTTYDISPLAYSTREAM) (* ; "Somebody bound *STANDARD-OUTPUT* at the time the tty window got created, so masked this binding. Fix it now to avoid future calls here") (SETQ *STANDARD-OUTPUT* (TTYDISPLAYSTREAM] (TTYDISPLAYSTREAM]) (HASTTYWINDOWP [LAMBDA (PROCESS) (* lmm "17-Jan-86 20:31") (* ;; "True if PROCESS has a tty window already.") (NEQ (OR (PROCESS.TTY PROCESS) \DEFAULTTTYDISPLAYSTREAM) \DEFAULTTTYDISPLAYSTREAM]) (TTYINFOSTREAM [LAMBDA (PROCESS) (* lmm "17-Jan-86 20:29") (* ;;; "Returns a stream to which to print informative messages = PROCESS tty if PROCESS has one, else PROMPTWINDOW") (DECLARE (GLOBALVARS \DEFAULTTTYDISPLAYSTREAM)) (PROG ((STREAM (PROCESS.TTY PROCESS))) (RETURN (COND ((AND STREAM (NEQ STREAM \DEFAULTTTYDISPLAYSTREAM)) STREAM) (T (\GETSTREAM PROMPTWINDOW]) (CREATESCREEN [LAMBDA (DESTINATION) (* ; "Edited 4-Dec-86 23:26 by lmm") (* ;;; "destination is the framebuffer for the screen you want created.e.g. (SCREENBITMAP)") (PROG (TITLEDS SCREEN) (SETQ TITLEDS (DSPCREATE DESTINATION)) (* ; "Create TITLEDS. ") (DSPOPERATION 'INVERT TITLEDS) (DSPFONT WINDOWTITLEFONT TITLEDS) (DSPRIGHTMARGIN MAX.SMALLP TITLEDS) (* ;  "Set right margin so title doesn't autoCR. ") (* ;; "now create SCREEN. ") (SETQ SCREEN (create SCREEN SCONOFF _ 'OFF SCDESTINATION _ DESTINATION SCWIDTH _ (BITMAPWIDTH DESTINATION) SCHEIGHT _ (BITMAPHEIGHT DESTINATION) SCTOPW _ NIL SCTITLEDS _ TITLEDS)) (RETURN SCREEN]) (\INSURESCREEN [LAMBDA (SCREEN) (* kbr%: " 4-Aug-85 13:30") (COND ((type? SCREEN SCREEN) SCREEN) ((NULL SCREEN) \CURSORSCREEN) (T (\ILLEGAL.ARG SCREEN]) (\BITMAPTOSCREEN [LAMBDA (BITMAP) (* gbn%: "25-Jan-86 16:44") (* ;;; "returns the screen with this bitmap as its destination, NIL otherwise") (for SCREEN in \SCREENS thereis (EQ (fetch (SCREEN SCDESTINATION) of SCREEN) BITMAP]) (MAINSCREEN [LAMBDA NIL (* kbr%: " 2-Feb-86 14:55") \MAINSCREEN]) ) (RPAQQ \TTYREGIONOFFSETSPTR NIL) (RPAQ? TTYREGIONOFFSETS '((0 . 0) (20 . -20) (40 . 0) (20 . 20))) (RPAQ? DEFAULTTTYREGION '(153 100 384 208)) (RPAQ? INITIAL-EXEC-REGION '(8 378 550 330)) (RPAQ? INITIAL-PROMPT-REGION '(8 719 550 89)) (RPAQ? \MAINSCREEN ) (RPAQ? \CURRENTBACKGROUNDBORDER ) (RPAQ? \SCREENS ) (RPAQ? \SCREENBITMAPS ) (DECLARE%: DOEVAL@COMPILE DONTCOPY (GLOBALVARS \TTYREGIONOFFSETSPTR TTYREGIONOFFSETS \DEFAULTTTYDISPLAYSTREAM) ) (DEFGLOBALVAR \TopLevelTtyWindow) (* ; "Window menu operations") (DEFINEQ (WINDOW.MOUSE.HANDLER [LAMBDA NIL (* lmm " 7-Nov-86 02:34") (* ;;; "Does user window operations if state of buttons has changed or mouse has changed windows") (COND (\INTERRUPTABLE (* ;  "don't do anything if uninterruptable") (PROG (\MHCOM \MHPROCESS \MHWINDOW) (GETMOUSESTATE) [COND ((OR (NEQ LASTMOUSEX (fetch XCOORD of \LastCursorPosition)) (NEQ LASTMOUSEY (fetch YCOORD of \LastCursorPosition)) (NEQ LASTMOUSEBUTTONS \LastWindowButtons)) (* ;  "Cursor has changed position or a button is down, see if it is in a window or scroll area.") (PROG ((\MOUSEBUSY T)) (DECLARE (SPECVARS \MOUSEBUSY)) (* ;  "Indicates to others that the mouse process is doing something 'interesting'") (replace XCOORD of \LastCursorPosition with LASTMOUSEX) (replace YCOORD of \LastCursorPosition with LASTMOUSEY) (SETQ \MHWINDOW (WHICHW LASTMOUSEX LASTMOUSEY \CURSORSCREEN)) [COND ((NEQ \MHWINDOW \LastInWindow) (* ;; "Cursor has moved outside the current window, check to see if it moved into the scroll area and that the scroll handler wants it.") (COND ((AND \LastInWindow (IN/SCROLL/BAR? \LastInWindow LASTMOUSEX LASTMOUSEY) (PROGN (* ;  "SCROLL.HANDLER returns NIL if this window doesn't want to scroll.") (SCROLL.HANDLER \LastInWindow))) (replace XCOORD of \LastCursorPosition with -1) (GO RESETBUTTONS)) [(OR (EQ LASTMOUSEBUTTONS 0) (NEQ LASTMOUSEBUTTONS \LastWindowButtons)) (* ;; "Cursor has changed windows, so call CURSOROUTFN of old window, CURSORINFN of new. The user enters another window by moving the cursor into it with no buttons pressed or by pressing a button in the window. This allows the user to go into a window with a button down, release it and still be 'in' the window he came from.") [COND ((NULL \LastInWindow) (AND BACKGROUNDCURSOROUTFN (GETD BACKGROUNDCURSOROUTFN) (\PROTECTED.APPLY BACKGROUNDCURSOROUTFN))) ((SETQ \MHCOM (fetch CURSOROUTFN of \LastInWindow)) (ERSETQ (DOUSERFNS \MHCOM \LastInWindow] [COND ((NULL \MHWINDOW) (AND BACKGROUNDCURSORINFN (GETD BACKGROUNDCURSORINFN) (\PROTECTED.APPLY BACKGROUNDCURSORINFN))) ((SETQ \MHCOM (fetch CURSORINFN of \MHWINDOW)) (ERSETQ (DOUSERFNS \MHCOM \MHWINDOW] (SETQ \LastInWindow \MHWINDOW) (COND ((EQ LASTMOUSEBUTTONS 0) (* ;  "Don't show transition to UP as we come out of another window") (SETQ \LastWindowButtons LASTMOUSEBUTTONS) (RETURN] (T (* ;; "Mouse is down and had not changed. Nothing interesting to do -- act as if we are still in old window") (RETURN] (* ;;; "We have now taken care of window changing stuff, and \MHWINDOW = \LastInWindow -- Now take care of button transitions") (COND ([AND (LASTMOUSESTATE (ONLY RIGHT)) (NOT (AND \MHWINDOW (fetch RIGHTBUTTONFN of \MHWINDOW] (* ;  "Right button is down. This does window com unless overridden by RIGHTBUTTONFN") (* ;  "this is separated out from the process stuff below so that window commands don't grab the tty.") (COND ((AND (NULL \MHWINDOW) (.COPYKEYDOWNP.) BACKGROUNDCOPYRIGHTBUTTONEVENTFN (GETD BACKGROUNDCOPYRIGHTBUTTONEVENTFN)) (* ; "check for copy key.") (\PROTECTED.APPLY BACKGROUNDCOPYRIGHTBUTTONEVENTFN)) (T (* ;  "if \MHWINDOW is NIL, this does background menu stuff.") (DOWINDOWCOM \MHWINDOW))) (* ;; "this attempts to prevent the cursorout fn and scrolling fns from being called if the \LastInWindow was closed.") (OR (OPENWP \LastInWindow) (SETQ \LastInWindow NIL)) (GO RESETBUTTONS)) [\MHWINDOW (* ;  "Mouse is in a window, look for button change or cursor moving fn.") (COND ((NEQ LASTMOUSEBUTTONS \LastWindowButtons) (* ;  "Button change within same window") (COND ((AND (LASTMOUSESTATE (NOT UP)) (SETQ \MHPROCESS (WINDOWPROP \MHWINDOW 'PROCESS)) (NOT (TTY.PROCESSP \MHPROCESS)) (NOT (.COPYKEYDOWNP.)) (SETQ \MHCOM (fetch WINDOWENTRYFN of \MHWINDOW))) (* ;  "make sure that if this window has a process that that process has the tty.") (ERSETQ (DOUSERFNS \MHCOM \MHWINDOW)) (GO RESETBUTTONS)) ([SETQ \MHCOM (COND [(AND (.COPYKEYDOWNP.) (WINDOWPROP \MHWINDOW 'COPYBUTTONEVENTFN] ((LASTMOUSESTATE (ONLY RIGHT)) (fetch RIGHTBUTTONFN of \MHWINDOW)) (T (fetch BUTTONEVENTFN of \MHWINDOW] (\PROTECTED.APPLY \MHCOM \MHWINDOW) (GO RESETBUTTONS))) (SETQ \LastWindowButtons LASTMOUSEBUTTONS)) ((SETQ \MHCOM (fetch (WINDOW CURSORMOVEDFN) of \MHWINDOW)) (* ; "cursor must have moved.") (ERSETQ (DOUSERFNS \MHCOM \MHWINDOW] (T (* ;  "look for button change or cursor moving in background") (COND ((NEQ LASTMOUSEBUTTONS \LastWindowButtons) (* ; "Button change within background") (COND ((AND (NULL \MHWINDOW) (.COPYKEYDOWNP.) BACKGROUNDCOPYBUTTONEVENTFN (GETD BACKGROUNDCOPYBUTTONEVENTFN)) (\PROTECTED.APPLY BACKGROUNDCOPYBUTTONEVENTFN) (GO RESETBUTTONS)) ((AND BACKGROUNDBUTTONEVENTFN (GETD BACKGROUNDBUTTONEVENTFN )) (\PROTECTED.APPLY BACKGROUNDBUTTONEVENTFN) (GO RESETBUTTONS))) (SETQ \LastWindowButtons LASTMOUSEBUTTONS)) ((AND BACKGROUNDCURSORMOVEDFN (GETD BACKGROUNDCURSORMOVEDFN)) (* ; "cursor must have moved.") (\PROTECTED.APPLY BACKGROUNDCURSORMOVEDFN) (GO RESETBUTTONS)) ([AND BACKGROUNDCURSOREXITFN (OR (EQ LASTMOUSEX 0) (EQ LASTMOUSEX (SUB1 \CURSORDESTWIDTH ] (* ; "cursor must have moved.") (ERSETQ (APPLY* BACKGROUNDCURSOREXITFN)) (GETMOUSESTATE) (replace (POSITION XCOORD) of \LastCursorPosition with LASTMOUSEX) (replace (POSITION YCOORD) of \LastCursorPosition with LASTMOUSEY] (RETURN) RESETBUTTONS (* ;  "Look at mouse again, since user fn may have waited for mouse to come up") (GETMOUSESTATE) (SETQ \LastWindowButtons LASTMOUSEBUTTONS) (RETURN]) (\PROTECTED.APPLY [LAMBDA (FN WINDOW) (* bvm%: "20-Apr-84 16:20") (DECLARE (LOCALVARS . T)) (* ;;; "Apply FN to WINDOW under an errorset to trap errors") (ERSETQ (APPLY* FN WINDOW]) (DOWINDOWCOM [LAMBDA ARGS (* ; "Edited 25-Nov-86 17:30 by hdj") (* ;; "the button handler for the window system. if no arg, just return.") (if (NEQ ARGS 0) then (LET ((WINDOW (ARG ARGS 1))) (COND [(type? WINDOW WINDOW) (PROG ($$VAR) (COND ((SETQ $$VAR (WINDOWPROP WINDOW 'DOWINDOWCOMFN)) (RETURN (APPLY* $$VAR WINDOW))) (T (\CHECKCARET WINDOW) (TOTOPW WINDOW) (RETURN (COND ([SETQ $$VAR (MENU (COND ((type? MENU WindowMenu) WindowMenu) (T (SETQ WindowMenu (create MENU ITEMS _ WindowMenuCommands CHANGEOFFSETFLG _ 'Y MENUOFFSET _ (create POSITION XCOORD _ -1 YCOORD _ 0) WHENHELDFN _ (FUNCTION PPROMPT3) WHENUNHELDFN _ (FUNCTION CLRPROMPT) CENTERFLG _ T] (APPLY* $$VAR WINDOW) T] ((NULL WINDOW) (DOBACKGROUNDCOM]) (DOBACKGROUNDCOM [LAMBDA NIL (* ; "Edited 25-Nov-86 17:25 by hdj") (* ;; "Bring up the background menu.") (PROG (FORM) (AND [SETQ FORM (MENU (if (type? MENU BackgroundMenu) then BackgroundMenu else (SETQ BackgroundMenu (create MENU ITEMS _ BackgroundMenuCommands CHANGEOFFSETFLG _ 'Y MENUOFFSET _ (create POSITION XCOORD _ -1 YCOORD _ 0) WHENHELDFN _ (FUNCTION PPROMPT3) WHENUNHELDFN _ (FUNCTION CLRPROMPT) CENTERFLG _ T] (ERSETQ (EVAL FORM]) (DEFAULT.BACKGROUND.COPYFN [LAMBDA NIL (* bvm%: "17-Oct-85 00:02") (* ;;; "the default function called when the right button goes down in the background and the copy key is held down.") (COND ((AND (MOUSESTATE (NOT UP)) BackgroundCopyMenuCommands) (LET [(FORM (MENU (COND ((type? MENU BackgroundCopyMenu) BackgroundCopyMenu) (T (SETQ BackgroundCopyMenu (create MENU ITEMS _ BackgroundCopyMenuCommands CHANGEOFFSETFLG _ 'Y MENUOFFSET _ (create POSITION XCOORD _ -1 YCOORD _ 0) CENTERFLG _ T] (AND FORM (ERSETQ (EVAL FORM]) ) (RPAQQ BackgroundCopyMenu NIL) (RPAQ? BackgroundCopyMenuCommands NIL) (DEFINEQ (BURYW [LAMBDA (WINDOW) (* ; "Edited 17-Aug-88 19:43 by jds") (* ;; "HACK: Puts WINDOW at the bottom by putting everything that touches it to the top!") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (PROG ((OVERLAPPINGWINDOWS (ORDERFROMBOTTOMTOTOP (OVERLAPPINGWINDOWS WINDOW))) ABOVEWINDOWS ATWINS) [SETQ ABOVEWINDOWS (REMOVE WINDOW (LDIFFERENCE OVERLAPPINGWINDOWS (SETQ ATWINS ( ALLATTACHEDWINDOWS WINDOW] (* ;; "close them in order from the top. This should be the fastest since they would have to come to the top to be closed anyway.") (for W in (REVERSE OVERLAPPINGWINDOWS) do (\CLOSEW1 W)) (\OPENW1 WINDOW) (* ;  "put attached windows below the other windows.") (for W in ATWINS do (\OPENW1 W)) (* ; "finally open the other windows.") (for W in ABOVEWINDOWS do (\OPENW1 W)) (RETURN WINDOW]) (CLEARW [LAMBDA (WINDOW) (* rrb "27-AUG-82 11:28") (* ;; "clears a window to its background shade, resets its offsets to 0,0 in the lower left corner and resets the position to the upper left {first line of text}.") (WXOFFSET (WXOFFSET NIL (SETQ WINDOW (\INSUREWINDOW WINDOW))) WINDOW) (WYOFFSET (WYOFFSET NIL WINDOW) WINDOW) (DSPRESET (fetch DSP of WINDOW]) (CLOSEW [LAMBDA (WINDOW) (* ; "Edited 28-Dec-87 17:03 by jds") (* ;;  "closes a window. saves the current state in the WINDOW and allow it to be reOPENWed.") (* ;;  "Returns T if the window closed OK (and was previously open), as a signal to \INTERACTIVE.CLOSEW.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (COND ((OPENWP WINDOW) (COND ((\OKTOCLOSEW WINDOW) (* ;  "one of the CLOSEFNs may have closed the window. If so, don't reopen it.") (AND (OPENWP WINDOW) (\CLOSEW1 WINDOW)) T]) (\CLOSEW1 [LAMBDA (WINDOW) (* ; "Edited 17-Aug-88 19:43 by jds") (* ;;  "actually does the closing operation. Is used by SHRINKW to avoid the CLOSEFN mechanism.") (LET (SCREEN NEXTW) (SETQ SCREEN (fetch (WINDOW SCREEN) of WINDOW)) (COND ((NOT (EQ \TOPWDS (FETCH (WINDOW DSP) OF WINDOW))) (* ;  "This window isn't on top, so we want to bring it there WITHOUT running topfns.") (\TOTOPWDS (FETCH (WINDOW DSP) OF WINDOW) T))) (.WHILE.TOP.DS. \TOPWDS (\SW2BM (fetch (SCREEN SCDESTINATION) of SCREEN) (fetch (WINDOW REG) of WINDOW) (fetch (WINDOW SAVE) of WINDOW) NIL) (SETQ NEXTW (fetch (WINDOW NEXTW) of WINDOW)) (replace (SCREEN SCTOPW) of SCREEN with NEXTW) [SETQ \TOPWDS (COND (NEXTW (fetch (WINDOW DSP) of NEXTW] (* ;  "smash the window's link to other's in the chain.") (replace (WINDOW NEXTW) of WINDOW with 'CLOSED]) (\OKTOCLOSEW [LAMBDA (WINDOW) (* rrb "14-JUN-82 12:40") (* ;; "calls the windows closefns. Returns T if it is ok to close the window.") (COND ((EQ (DOUSERFNS (fetch (WINDOW CLOSEFN) of WINDOW) WINDOW T) 'DON'T) NIL) (T WINDOW]) (\INTERACTIVE.CLOSEW [LAMBDA (WINDOW) (* ; "Edited 4-Mar-88 09:52 by jds") (* ;; "Interactive version of CLOSEW -- used by the window-command menu. If the window can't be closed, this function prints a message saying so.") (LET ((CLOSEFN (fetch (WINDOW CLOSEFN) of WINDOW))) (COND ((OR (EQ 'DON'T CLOSEFN) (AND (LISTP CLOSEFN) (FMEMB 'DON'T CLOSEFN))) (* ;  "The window has DON'T as one of its CLOSEFNs. Tell the guy the window isn't closeable.") (PROMPTPRINT "This window cannot be closed.")) (T (* ; "Try closing it.") (CLOSEW WINDOW) T]) (OPENW [LAMBDA (WINDOW) (* rrb "28-JUN-83 11:52") (* ;; "opens a window by putting on the window stack and putting its bits on the screen. Returns the window if it was actually opened.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (COND ((OPENWP WINDOW) (* ;  "used to bring the window to top but doesn't since TOTOPW has been documented.") NIL) (T (PROG [(USEROPENFN (WINDOWPROP WINDOW 'OPENFN] (COND ((\USERFNISDON'T USEROPENFN) (* ; "one of the OPENFNs is DON'T") NIL) (T (* ;  "open it by putting it on top and swapping its bits in") (\OPENW1 WINDOW) (* ;  "call the openfns after the window has been opened.") (DOUSERFNS USEROPENFN WINDOW) (RETURN WINDOW]) (DOUSERFNS [LAMBDA (FNLST WINDOW CHECKFORDON'TFLG) (* rrb "20-Mar-84 16:18") (* ;; "applys a list of user functins and If CHECKFORDON'TFLG is non-NIL, it stops if don't is returned as one of the values and returns DON'T") (DECLARE (GLOBALVARS LAMBDASPLST)) (COND [(OR (NLISTP FNLST) (FMEMB (CAR FNLST) LAMBDASPLST)) (COND ((AND CHECKFORDON'TFLG (EQ FNLST 'DON'T)) 'DON'T) (FNLST (AND (EQ (APPLY* FNLST WINDOW) 'DON'T) 'DON'T] ((AND CHECKFORDON'TFLG (FMEMB 'DON'T FNLST)) 'DON'T) ((for USERFN in FNLST when (EQ (APPLY* USERFN WINDOW) 'DON'T) do (* ;  "return if any of the openfns says don't") (AND CHECKFORDON'TFLG (RETURN 'DON'T]) (DOUSERFNS2 [LAMBDA (FNLST WINDOW ARG1 ARG2 ARG3) (* rrb " 3-Jul-84 15:59") (* ;; "applys a list of user functions to two arguments. This is used by SHAPEW.") (DECLARE (GLOBALVARS LAMBDASPLST)) (COND [(OR (NLISTP FNLST) (FMEMB (CAR FNLST) LAMBDASPLST)) (COND (FNLST (APPLY* FNLST WINDOW ARG1 ARG2 ARG3] ((for USERFN in FNLST do (APPLY* USERFN WINDOW ARG1 ARG2 ARG3]) (\USERFNISDON'T [LAMBDA (USERFN) (* rrb "18-JUN-82 12:16") (* ;; "determines if one of the userfunction is DON'T") (COND ((NLISTP USERFN) (EQ USERFN 'DON'T)) (T (FMEMB 'DON'T USERFN]) (\OPENW1 [LAMBDA (WINDOW) (* ; "Edited 17-Aug-88 19:22 by jds") (* ;;; "Open a closed window without running the OPENW methods. ") (* ;; "If already open, punt.") (if (EQ (fetch (WINDOW NEXTW) of WINDOW) 'CLOSED) then (LET ((SCREEN (fetch (WINDOW SCREEN) of WINDOW)) DD) (UNINTERRUPTABLY (replace (WINDOW NEXTW) of WINDOW with (fetch (SCREEN SCTOPW) of SCREEN)) (replace (SCREEN SCTOPW) of SCREEN with WINDOW) (SETQ \TOPWDS (fetch (WINDOW DSP) of WINDOW)) (* ;  "DSP of a window is guaranteed to be a display-stream") (SETQ DD (fetch (STREAM IMAGEDATA) of \TOPWDS)) (* ;  "Just in case screen width has changed.") (replace (PILOTBBT PBTDESTBPL) of (fetch (\DISPLAYDATA DDPILOTBBT) of DD) with (UNFOLD (fetch (BITMAP BITMAPRASTERWIDTH) of (fetch (SCREEN SCDESTINATION) of SCREEN)) BITSPERWORD)) (.WHILE.TOP.DS. \TOPWDS (\SW2BM (fetch (\DISPLAYDATA DDDestination) of DD) (fetch (WINDOW REG) of WINDOW) (fetch (WINDOW SAVE) of WINDOW) NIL)))]) (CREATEW [LAMBDA (REGION TITLE BORDERSIZE NOOPENFLG) (* kbr%: "17-Sep-86 12:27") (* ;; "creates and returns a window.") (PROG (SCREEN REG DSP DISPLAYDATA TITLEHEIGHT WINDOW WBORDER) (SETQ WBORDER (COND ((NUMBERP BORDERSIZE) (ABS BORDERSIZE)) ((NUMBERP WBorder) (ABS WBorder)) (T 2))) (COND [(NULL REGION) (printout PROMPTWINDOW T "Specify region for window") (COND (TITLE (printout PROMPTWINDOW " %"" TITLE "%""))) (SETQ REGION (GETSCREENREGION MinWindowWidth MinWindowHeight)) (SETQ SCREEN (fetch (SCREENREGION SCREEN) of REGION)) (SETQ REG (COPY (fetch (SCREENREGION REGION) of REGION] ((type? REGION REGION) (SETQ SCREEN \CURSORSCREEN) (* ;  "Protect against user smashing REGION later on.") (SETQ REG (COPY REGION))) [(type? SCREENREGION REGION) (SETQ SCREEN (fetch (SCREENREGION SCREEN) of REGION)) (SETQ REG (COPY (fetch (SCREENREGION REGION) of REGION] [(DISPLAYSTREAMP REGION) (COND ((EQ REGION \DEFAULTTTYDISPLAYSTREAM) (\CREATE.TTYDISPLAYSTREAM) (RETURN \TTYWINDOW))) (SETQ DSP REGION) (SETQ DISPLAYDATA (fetch (STREAM IMAGEDATA) of DSP)) (SETQ SCREEN (\BITMAPTOSCREEN (fetch (\DISPLAYDATA DDDestination) of DISPLAYDATA ))) (COND ((NULL SCREEN) (ERROR "Displaystream destination not a screen" DSP))) (SETQ TITLEHEIGHT (COND [TITLE (IMINUS (DSPLINEFEED NIL (fetch (SCREEN SCTITLEDS) of SCREEN] (T 0))) (SETQ REG (fetch (\DISPLAYDATA DDClippingRegion) of DISPLAYDATA)) (* ;  "adjust region by offsets and reduce to size screen. (destination bitmap.)") (SETQ REG (create REGION LEFT _ (IDIFFERENCE (IMAX (IPLUS (fetch (\DISPLAYDATA DDXOFFSET) of DISPLAYDATA) (fetch (REGION LEFT) of REG)) 0) WBORDER) BOTTOM _ (IDIFFERENCE (IMAX (IPLUS (fetch (\DISPLAYDATA DDYOFFSET) of DISPLAYDATA) (fetch (REGION BOTTOM) of REG)) 0) WBORDER) WIDTH _ (IPLUS (IMIN (fetch (SCREEN SCWIDTH) of SCREEN) (fetch (REGION WIDTH) of REG)) (UNFOLD WBORDER 2)) HEIGHT _ (IPLUS (IMIN (IDIFFERENCE (fetch (SCREEN SCHEIGHT) of SCREEN) TITLEHEIGHT) (fetch (REGION HEIGHT) of REG)) (UNFOLD WBORDER 2) TITLEHEIGHT] (T (ERROR "Not a region" REG))) [COND ((NULL DSP) (* ;  "Don't have a DSP yet. User passed some kind of region.") (SETQ DSP (DSPCREATE (fetch (SCREEN SCDESTINATION) of SCREEN))) (SETQ DISPLAYDATA (fetch (STREAM IMAGEDATA) of DSP] (COND ((NOT (IGREATERP (IMIN (fetch (REGION WIDTH) of REG) (fetch (REGION HEIGHT) of REG)) (UNFOLD WBORDER 2))) (ERROR "Region too small to use as a window" REG))) (SETQ WINDOW (create WINDOW DSP _ DSP REG _ REG SAVE _ (BITMAPCREATE (fetch (REGION WIDTH) of REG) (fetch (REGION HEIGHT) of REG) (BITSPERPIXEL (fetch (SCREEN SCDESTINATION) of SCREEN))) WTITLE _ TITLE WBORDER _ WBORDER NEXTW _ 'CLOSED SCREEN _ SCREEN)) (replace (\DISPLAYDATA XWINDOWHINT) of DISPLAYDATA with WINDOW) (ADVISEWDS WINDOW) (* ;  "make the display stream and window agree about dimensions.") (MOVETOUPPERLEFT WINDOW) (SHOWWFRAME WINDOW) (COND ((NOT NOOPENFLG) (OPENW WINDOW))) (RETURN WINDOW]) (OPENDISPLAYSTREAM [LAMBDA (FILE OPTIONS) (* hdj "17-Jan-86 14:47") (GETSTREAM (CREATEW (LISTGET OPTIONS 'REGION) (COND ((EQ FILE '{LPT}) "Display image stream") (T FILE]) (MOVEW [LAMBDA (WINDOW POSorX Y) (* ; "Edited 7-Jun-88 14:26 by atm") (* ;; "moves a window. If window is closed and position is given, it won't open the window. It also calls the window's MOVEFN property.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (PROG ((OLDREGION (fetch (WINDOW REG) of WINDOW)) (USERMOVEFN (fetch (WINDOW MOVEFN) of WINDOW)) (OPEN? (OPENWP WINDOW)) OLDSCREEN POS NEWREGION OLDLEFT OLDBOTTOM OLDWIDTH OLDHEIGHT OLDCLIPREGION LFT BTM REG FN) (SETQ OLDSCREEN (fetch (WINDOW SCREEN) of WINDOW)) (COND ([COND ((LISTP USERMOVEFN) (FMEMB 'DON'T USERMOVEFN)) (T (EQ USERMOVEFN 'DON'T] (PROMPTPRINT "This window cannot be moved.") (RETURN))) [COND ((NOT (SUBREGIONP OLDREGION (fetch (SCREEN SCREGION) of OLDSCREEN))) (* ;  "use T as an indication that the window was completely off screen.") (SETQ OLDCLIPREGION (OR (\ONSCREENCLIPPINGREGION WINDOW) T] (SETQ OLDLEFT (fetch (REGION LEFT) of OLDREGION)) (SETQ OLDBOTTOM (ffetch (REGION BOTTOM) of OLDREGION)) (SETQ OLDWIDTH (ffetch (REGION WIDTH) of OLDREGION)) (SETQ OLDHEIGHT (ffetch (REGION HEIGHT) of OLDREGION)) (COND ([AND POSorX (SETQ POS (COND ((POSITIONP POSorX) POSorX) [(NUMBERP POSorX) (COND ((NUMBERP Y) (create POSITION XCOORD _ POSorX YCOORD _ Y)) (T (\ILLEGAL.ARG Y] ((REGIONP POSorX) (create POSITION XCOORD _ (fetch (REGION LEFT) of POSorX) YCOORD _ (fetch (REGION BOTTOM) of POSorX))) (T (\ILLEGAL.ARG POSorX] (* ; "if not aready open, don't") (AND OPEN? (TOTOPW WINDOW))) (T (* ;  "no position to move to has been given, ask user for one.") (TOTOPW WINDOW) (* ;  "TOTOPW opens the window if it is not already.") [COND [[AND (SETQ FN (WINDOWPROP WINDOW 'CALCULATEREGIONFN)) (SETQ REG (APPLY* FN WINDOW 'MOVEW] (* ;  "prompt with a region that is calculated by the window") [SETQ POS (GETBOXPOSITION (fetch (REGION WIDTH) of REG) (ffetch (REGION HEIGHT) of REG) (SETQ LFT (ffetch (REGION LEFT) of REG)) (SETQ BTM (ffetch (REGION BOTTOM) of REG] (* ;; "use a position that is offset by the same amount as the calculated region was from the window's region.") (SETQ POS (create POSITION XCOORD _ (IPLUS (fetch (POSITION XCOORD) of POS) (IDIFFERENCE OLDLEFT LFT)) YCOORD _ (IPLUS (ffetch (POSITION YCOORD) of POS) (IDIFFERENCE OLDBOTTOM BTM] (T (SETQ POS (GETBOXPOSITION OLDWIDTH OLDHEIGHT OLDLEFT OLDBOTTOM] (SETQ OPEN? T))) [COND ((AND (LISTP USERMOVEFN) (NOT (FMEMB (CAR USERMOVEFN) LAMBDASPLST))) (AND (EQ [for MFN in USERMOVEFN do (SETQ NEWREGION (APPLY* MFN WINDOW POS)) (COND ((EQ NEWREGION 'DON'T) (RETURN 'DON'T)) ((POSITIONP NEWREGION) (SETQ POS NEWREGION] 'DON'T) (RETURN))) (USERMOVEFN (SETQ NEWREGION (APPLY* USERMOVEFN WINDOW POS)) (COND ((EQ NEWREGION 'DON'T) (RETURN)) ((POSITIONP NEWREGION) (SETQ POS NEWREGION] (COND ((OR (NOT (EQ (fetch (POSITION XCOORD) of POS) OLDLEFT)) (NOT (EQ (ffetch (POSITION YCOORD) of POS) OLDBOTTOM))) (SETQ NEWREGION (create REGION LEFT _ (ffetch (POSITION XCOORD) of POS) BOTTOM _ (ffetch (POSITION YCOORD) of POS) WIDTH _ OLDWIDTH HEIGHT _ OLDHEIGHT)) (UNINTERRUPTABLY [COND (OPEN? (* ;; "if window is open, move it to top as its MOVEFN may have changed things and swap its bits to its new location") (.WHILE.TOP.DS. WINDOW (\SW2BM (fetch (SCREEN SCDESTINATION) of OLDSCREEN) OLDREGION (fetch (WINDOW SAVE) of WINDOW) NIL) (\SW2BM (ffetch (WINDOW SAVE) of WINDOW) NIL (ffetch (SCREEN SCDESTINATION) of OLDSCREEN) NEWREGION] (replace (WINDOW REG) of WINDOW with NEWREGION) (ADVISEWDS WINDOW OLDREGION T)) [COND ((AND OPEN? (WINDOWPROP WINDOW 'REPAINTFN) OLDCLIPREGION) (* ;  "redisplay those parts that were off the screen.") (COND ((EQ OLDCLIPREGION T) (* ; "whole window was off.") (REDISPLAYW WINDOW NIL T)) (T (PROG (NEWCLIPPINGREGION NCL OCL NCB OCB OCR NCR OCW NCW OCH NCH OCT NCT) (SETQ NEWCLIPPINGREGION (\ONSCREENCLIPPINGREGION WINDOW)) (* ;  "the title may be the only thing now on the screen.") (OR NEWCLIPPINGREGION (RETURN)) (SETQ NCB (fetch (REGION BOTTOM) of NEWCLIPPINGREGION)) (SETQ OCB (fetch (REGION BOTTOM) of OLDCLIPREGION)) (SETQ OCW (ffetch (REGION WIDTH) of OLDCLIPREGION)) (SETQ NCW (ffetch (REGION WIDTH) of NEWCLIPPINGREGION)) (SETQ OCH (ffetch (REGION HEIGHT) of OLDCLIPREGION)) (SETQ NCH (ffetch (REGION HEIGHT) of NEWCLIPPINGREGION)) [COND ((ILESSP (SETQ NCL (ffetch (REGION LEFT) of NEWCLIPPINGREGION )) (SETQ OCL (ffetch (REGION LEFT) of OLDCLIPREGION))) (REDISPLAYW WINDOW (CREATEREGION NCL OCB (IDIFFERENCE OCL NCL) OCH] [COND ((ILESSP (SETQ OCR (IPLUS OCL OCW)) (SETQ NCR (IPLUS NCL NCW))) (* ;  "some stuff appeared from the right.") (REDISPLAYW WINDOW (CREATEREGION OCR OCB (IDIFFERENCE NCR OCR) OCH] [COND ((ILESSP NCB OCB) (REDISPLAYW WINDOW (CREATEREGION NCL NCB NCW (IDIFFERENCE OCB NCB] [COND ((ILESSP (SETQ OCT (IPLUS OCB OCH)) (SETQ NCT (IPLUS NCB NCH))) (* ;  "some stuff appeared from the top") (REDISPLAYW WINDOW (CREATEREGION NCL OCT NCW (IDIFFERENCE NCT OCT] (COND ((IGREATERP (IPLUS OLDBOTTOM OLDHEIGHT) (fetch (SCREEN SCHEIGHT) of OLDSCREEN)) (* ;  "should reshow the title but don't have any entry for that.") NIL] (DOUSERFNS (WINDOWPROP WINDOW 'AFTERMOVEFN) WINDOW))) (RETURN POS]) (PPROMPT3 [LAMBDA (ITEM) (* rrb "17-NOV-81 12:15") (* ;; "prints the third element of ITEM in the prompt window. This is the default WHENHELDFN for MENUs.") (COND ((AND (LISTP ITEM) (CADDR ITEM)) (PROMPTPRINT (CADDR ITEM]) (\ONSCREENCLIPPINGREGION [LAMBDA (WIN) (* kbr%: "26-Mar-85 23:34") (* ;;  "returns a region which is the part of the windows clipping region that is on the screen.") (INTERSECTREGIONS (DSPCLIPPINGREGION NIL WIN) (\DSPUNTRANSFORMREGION (fetch (SCREEN SCREGION) of (fetch (WINDOW SCREEN) of WIN)) (fetch (STREAM IMAGEDATA) of (WINDOWPROP WIN 'DSP]) (RELMOVEW [LAMBDA (WINDOW POS) (* rrb "13-JUN-82 15:54") (* ;; "Move WINDOW by relative DX DY") (PROG [(WINREG (WINDOWPROP WINDOW 'REGION] (MOVEW WINDOW (create POSITION XCOORD _ (IPLUS (fetch LEFT of WINREG) (fetch (POSITION XCOORD) of POS)) YCOORD _ (IPLUS (fetch BOTTOM of WINREG) (fetch (POSITION YCOORD) of POS]) (SHAPEW [LAMBDA (WINDOW NEWREGION) (* ; "Edited 12-Apr-88 12:12 by FS") (* ;; "entry that shapes a window checking the userfns for DON'T and interacting to get a region if necessary. This also checks for a user function to do the actual reshaping. look for a function on windowprop INITCORNERSFN, which will take the window and return the initcorners for the window, to be passed to getregion.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (PROG ((OLDSIZE (WINDOWPROP WINDOW 'REGION)) NEWSIZE) (COND ((\USERFNISDON'T (fetch (WINDOW RESHAPEFN) of WINDOW)) (* ;  "don't allow the window to be reshaped.") (PROMPTPRINT "This window cannot be reshaped.") (RETURN NIL))) (SETQ NEWSIZE (MINIMUMWINDOWSIZE WINDOW)) (* ;  "Start with the minimum allowable size.") [SETQ NEWSIZE (COND (NEWREGION (* ;  "An explicit new region was specified; make sure it's big enough.") (COND [(OR (LESSP (fetch (REGION WIDTH) of NEWREGION) (CAR NEWSIZE)) (LESSP (fetch (REGION HEIGHT) of NEWREGION) (CDR NEWSIZE))) (* ;  "given a region that is too small, so expand the width and height to at least the minima.") (CREATEREGION (fetch (REGION LEFT) of NEWREGION) (fetch (REGION BOTTOM) of NEWREGION) (IMAX (CAR NEWSIZE) (fetch (REGION WIDTH) of NEWREGION)) (IMAX (CDR NEWSIZE) (fetch (REGION HEIGHT) of NEWREGION] (T NEWREGION))) ((WINDOWPROP WINDOW 'INITCORNERSFN) (* ;  "There's an INITCORNERSFN. Fire it up and prompt the user for a new shape.") (GETREGION (CAR NEWSIZE) (CDR NEWSIZE) (WINDOWREGION WINDOW 'SHAPEW) (fetch NEWREGIONFN of WINDOW) WINDOW (APPLY* (WINDOWPROP WINDOW 'INITCORNERSFN) WINDOW))) (T (* ;  "Just go prompt the user for a new shape.") (GETREGION (CAR NEWSIZE) (CDR NEWSIZE) (WINDOWREGION WINDOW 'SHAPEW) (fetch NEWREGIONFN of WINDOW) WINDOW] (RETURN (if (EQUAL NEWSIZE OLDSIZE) then (* ;; "if same size and place as before, do nothing") NIL elseif (AND (EQ (fetch (REGION WIDTH) of NEWSIZE) (fetch (REGION WIDTH) of OLDSIZE)) (EQ (fetch (REGION HEIGHT) of NEWSIZE) (fetch (REGION HEIGHT) of OLDSIZE))) then (* ;; "if same width and height, then optimize to a move") (MOVEW WINDOW (fetch (REGION LEFT) of NEWSIZE) (fetch (REGION BOTTOM) of NEWSIZE)) else (* ;; "do the shape, checking for a doshapefn") (APPLY* (OR (WINDOWPROP WINDOW 'DOSHAPEFN) 'SHAPEW1) WINDOW (COPYALL NEWSIZE]) (SHAPEW1 [LAMBDA (WINDOW REGION) (* kbr%: "25-Jan-86 15:08") (* ;;  "entry for shaping a window that does the reshape without checking for a user function.") (DECLARE (LOCALVARS . T)) (SETQ WINDOW (\INSUREWINDOW WINDOW)) (OR (REGIONP REGION) (\ILLEGAL.ARG REGION)) (PROG ((OLDREGION (fetch (WINDOW REG) of WINDOW)) (OLDCLIPREG (DSPCLIPPINGREGION NIL (fetch (WINDOW DSP) of WINDOW))) (WBORDER (fetch (WINDOW WBORDER) of WINDOW)) SCREEN NUSAV NOWOPEN?) (SETQ SCREEN (fetch (WINDOW SCREEN) of WINDOW)) [SETQ NUSAV (BITMAPCREATE (fetch (REGION WIDTH) of REGION) (fetch (REGION HEIGHT) of REGION) (fetch (BITMAP BITMAPBITSPERPIXEL) of (fetch (SCREEN SCDESTINATION ) of SCREEN] (UNINTERRUPTABLY (COND ((OPENWP WINDOW) (* ;  "notice whether window is open or not to call OPENFNs only if not now open.") (SETQ NOWOPEN? T) (\CLOSEW1 WINDOW))) (* ; "Save window image") (replace (WINDOW REG) of WINDOW with REGION) [replace (WINDOW SAVE) of WINDOW with (PROG1 NUSAV (SETQ NUSAV (fetch (WINDOW SAVE) of WINDOW] (ADVISEWDS WINDOW OLDREGION) (SHOWWFRAME WINDOW) (COND (NOWOPEN? (\OPENW1 WINDOW)) (T (OPENW WINDOW)))) (DOUSERFNS2 (OR (fetch (WINDOW RESHAPEFN) of WINDOW) (FUNCTION RESHAPEBYREPAINTFN)) WINDOW NUSAV (create REGION LEFT _ WBORDER BOTTOM _ WBORDER WIDTH _ (fetch (REGION WIDTH) of OLDCLIPREG) HEIGHT _ (fetch (REGION HEIGHT) of OLDCLIPREG)) OLDREGION) (RETURN WINDOW]) (\SHAPEW2 [LAMBDA (WINDOW REGION) (* ; "Edited 6-Jan-87 13:56 by woz") (* ;;; "entry for shaping a window that does the reshape without checking for a user function, and without running the openfn.") (DECLARE (LOCALVARS . T)) (SETQ WINDOW (\INSUREWINDOW WINDOW)) (OR (REGIONP REGION) (\ILLEGAL.ARG REGION)) (PROG ((OLDREGION (fetch (WINDOW REG) of WINDOW)) (OLDCLIPREG (DSPCLIPPINGREGION NIL (fetch (WINDOW DSP) of WINDOW))) (WBORDER (fetch (WINDOW WBORDER) of WINDOW)) SCREEN NUSAV) (SETQ SCREEN (fetch (WINDOW SCREEN) of WINDOW)) [SETQ NUSAV (BITMAPCREATE (fetch (REGION WIDTH) of REGION) (fetch (REGION HEIGHT) of REGION) (fetch (BITMAP BITMAPBITSPERPIXEL) of (fetch (SCREEN SCDESTINATION ) of SCREEN] (UNINTERRUPTABLY (COND ((OPENWP WINDOW) (* ;  "close open window before changing region") (\CLOSEW1 WINDOW))) (* ;; "Save window image") (replace (WINDOW REG) of WINDOW with REGION) [replace (WINDOW SAVE) of WINDOW with (PROG1 NUSAV (SETQ NUSAV (fetch (WINDOW SAVE) of WINDOW] (ADVISEWDS WINDOW OLDREGION) (SHOWWFRAME WINDOW) (* ; "open without openfn") (\OPENW1 WINDOW)) (DOUSERFNS2 (OR (fetch (WINDOW RESHAPEFN) of WINDOW) (FUNCTION RESHAPEBYREPAINTFN)) WINDOW NUSAV (CREATEREGION WBORDER WBORDER (fetch (REGION WIDTH) of OLDCLIPREG ) (fetch (REGION HEIGHT) of OLDCLIPREG)) OLDREGION) (RETURN WINDOW]) (RESHOWBORDER [LAMBDA (BORDER WINDOW) (* rrb "15-JUN-83 14:46") (* ;; "updates a windows display with a new border") (* ;  "if the border is the same, don't change anything.") (OR (EQ BORDER (fetch (WINDOW WBORDER) of WINDOW)) (\RESHOWBORDER1 BORDER (fetch (WINDOW WBORDER) of WINDOW) WINDOW]) (\RESHOWBORDER1 [LAMBDA (NEWBORDER OLDBORDER WINDOW) (* kbr%: "25-Jan-86 15:13") (* ;; "redisplays the border of a window. Is called by RESHOWBORDER and RESHOWTITLE. It doesn't check for equality between the new and old borders because it is also used when a title is added or deleted.") (PROG ((REGION (fetch (WINDOW REG) of WINDOW)) (OLDSAVE (fetch (WINDOW SAVE) of WINDOW)) NUSAV DELTA NUWIDTH NUHEIGHT) (SETQ DELTA (IDIFFERENCE NEWBORDER OLDBORDER)) (SETQ NUWIDTH (IPLUS (fetch (REGION WIDTH) of REGION) (ITIMES DELTA 2))) [SETQ NUHEIGHT (IDIFFERENCE (IPLUS (fetch (REGION HEIGHT) of (DSPCLIPPINGREGION NIL (fetch (WINDOW DSP) of WINDOW))) (ITIMES NEWBORDER 2)) (COND [(fetch (WINDOW WTITLE) of WINDOW) (DSPLINEFEED NIL (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN) of WINDOW] (T 0] (SETQ NUSAV (BITMAPCREATE NUWIDTH NUHEIGHT (fetch (BITMAP BITMAPBITSPERPIXEL) of OLDSAVE))) (.WHILE.TOP.DS. WINDOW (* ; "Save window image") (\SW2BM (fetch (SCREEN SCDESTINATION) of (fetch (WINDOW SCREEN) of WINDOW)) REGION (fetch (WINDOW SAVE) of WINDOW) NIL) (* ; "put new save image into window") (replace (WINDOW SAVE) of WINDOW with NUSAV) (replace (WINDOW WBORDER) of WINDOW with NEWBORDER) (* ;  "create a region that coresponds to the old region with the new border.") (replace (WINDOW REG) of WINDOW with (create REGION LEFT _ (IDIFFERENCE (fetch (REGION LEFT) of REGION) DELTA) BOTTOM _ (IDIFFERENCE (fetch (REGION BOTTOM) of REGION) DELTA) WIDTH _ NUWIDTH HEIGHT _ NUHEIGHT)) (UPDATE/SCROLL/REG WINDOW) (* ; "draw border in the new image.") (SHOWWFRAME WINDOW) (* ;  "copy the visible part from the old image into the new one.") (BITBLT OLDSAVE OLDBORDER OLDBORDER NUSAV NEWBORDER NEWBORDER (IDIFFERENCE (fetch (BITMAP BITMAPWIDTH) of OLDSAVE) (ITIMES 2 OLDBORDER)) (fetch (REGION HEIGHT) of (DSPCLIPPINGREGION NIL (fetch (WINDOW DSP) of WINDOW))) 'INPUT 'REPLACE) (* ;  "put the new image up on the screen.") (\SW2BM (fetch (SCREEN SCDESTINATION) of (fetch (WINDOW SCREEN) of WINDOW)) (fetch (WINDOW REG) of WINDOW) (fetch (WINDOW SAVE) of WINDOW) NIL]) (TRACKW [LAMBDA (WINDOW) (* rrb " 9-MAR-82 14:28") (* ;;  "causes a window to follow the cursor. found to be not useful but very pretty for small windows.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (RESETFORM (CURSOR CROSSHAIRS) (TOTOPW WINDOW) (until (MOUSESTATE (NOT UP))) (CURSOR LOCKEDSPOT) (bind (DX _ (IDIFFERENCE (fetch (REGION LEFT) of (fetch (WINDOW REG) of WINDOW)) LASTMOUSEX)) (DY _ (IDIFFERENCE (fetch (REGION BOTTOM) of (fetch (WINDOW REG) of WINDOW)) LASTMOUSEY)) until (MOUSESTATE UP) do (MOVEW WINDOW (create POSITION XCOORD _ (IPLUS LASTMOUSEX DX) YCOORD _ (IPLUS LASTMOUSEY DY]) (SNAPW [LAMBDA NIL (* kbr%: "25-Jan-86 15:15") (* ;;  "makes a new window which is a copy of the bits underneath the REGION read from the user.") (PROG (SCREENREGION SCREEN REGION NEWWINDOW) (SETQ SCREENREGION (GETSCREENREGION 30 20)) (SETQ SCREEN (fetch (SCREENREGION SCREEN) of SCREENREGION)) (SETQ REGION (fetch (SCREENREGION REGION) of SCREENREGION)) (SETQ NEWWINDOW (CREATEW (create SCREENREGION SCREEN _ SCREEN REGION _ (GROW/REGION REGION WBorder)) NIL NIL T)) (* ;  "keep it closed so it doesn't cover any of the bits it is to copy.") (* ;  "put existing screen bits from SAVE.") (BITBLT (fetch (SCREEN SCDESTINATION) of SCREEN) (fetch (REGION LEFT) of REGION) (fetch (REGION BOTTOM) of REGION) (fetch (WINDOW SAVE) of NEWWINDOW) WBorder WBorder (fetch (REGION WIDTH) of REGION) (fetch (REGION HEIGHT) of REGION) 'INPUT 'REPLACE) (OPENW NEWWINDOW) (MOVEW NEWWINDOW) (RETURN NEWWINDOW]) (WINDOWREGION [LAMBDA (WINDOW COM) (* jow "26-Aug-85 13:48") (* ;; "gets the region that a window wants to consider to be its. COM can be a window com used to help calculate the region, ie for shaping or moving...") (PROG (FN) (RETURN (COND ((SETQ FN (WINDOWPROP WINDOW 'CALCULATEREGIONFN)) (APPLY* FN WINDOW COM)) (T (WINDOWPROP WINDOW 'REGION]) ) (DEFINEQ (MINIMUMWINDOWSIZE [LAMBDA (WINDOW) (* rrb "20-NOV-83 12:06") (* ;; "returns the minimum extent of a window") (PROG [(EXT (WINDOWPROP WINDOW 'MINSIZE] [COND [(NULL EXT) (SETQ EXT (CONS MinWindowWidth (HEIGHTIFWINDOW (FONTPROP WINDOW 'HEIGHT) (WINDOWPROP WINDOW 'TITLE] ((LITATOM EXT) (SETQ EXT (APPLY* EXT WINDOW] [COND [(AND (NUMBERP (CAR EXT)) (NUMBERP (CDR EXT] (T (SETQ EXT (ERROR "Illegal extent property" EXT] (RETURN EXT]) ) (RPAQ? BACKGROUNDCURSORINFN ) (RPAQ? BACKGROUNDBUTTONEVENTFN ) (RPAQ? BACKGROUNDCURSOROUTFN ) (RPAQ? BACKGROUNDCURSORMOVEDFN ) (RPAQ? BACKGROUNDCOPYBUTTONEVENTFN ) (RPAQ? BACKGROUNDCOPYRIGHTBUTTONEVENTFN (FUNCTION DEFAULT.BACKGROUND.COPYFN)) (RPAQ? BACKGROUNDCURSOREXITFN ) (DECLARE%: DOEVAL@COMPILE DONTCOPY (GLOBALVARS BACKGROUNDCURSORINFN BACKGROUNDBUTTONEVENTFN BACKGROUNDCURSOROUTFN BACKGROUNDCURSORMOVEDFN BACKGROUNDCOPYBUTTONEVENTFN BACKGROUNDCOPYRIGHTBUTTONEVENTFN \CARET.UP BACKGROUNDCURSOREXITFN) ) (* "FOLLOWING DEFINITIONS EXPORTED")(DECLARE%: EVAL@COMPILE (PUTPROPS .COPYKEYDOWNP. MACRO [NIL (OR (KEYDOWNP 'LSHIFT) (KEYDOWNP 'RSHIFT) (KEYDOWNP 'COPY]) (PUTPROPS WSOP MACRO [ARGS (LET ((METHOD (CADR (CAR ARGS))) (DISPLAY (CADR ARGS)) (OTHERARGS (CDDR ARGS))) `(SPREADAPPLY* (fetch (WSOPS ,METHOD) of (fetch (FDEV WINDOWOPS) of ,DISPLAY)) ,DISPLAY ,@OTHERARGS]) ) (* "END EXPORTED DEFINITIONS") (PUTPROPS WSOP ARGNAMES (METHOD DISPLAY . OTHERARGS)) (DECLARE%: EVAL@COMPILE (RECORD WSOPS (STARTBOARD STARTCOLOR STOPCOLOR EVENTFN SENDCOLORMAPENTRY SENDPAGE PILOTBITBLT)) (RECORD WSDATA (WSDESTINATION WSREGION WSBACKGROUND WSCOLORMAP) (SYSTEM)) ) (* ; "Window utilities") (DEFINEQ (ADVISEWDS [LAMBDA (WINDOW OLDREG MOVEONLYFLG) (* kbr%: "29-Mar-85 14:01") (DECLARE (LOCALVARS . T)) (* ;; "called whenever the dimensions of a guaranteed WINDOW change. Updates the dependent fields in the associated DisplayStream. Also updates dependent fields in the WINDOW such as Scroll region.") (* ;; "OLDREG if given, is the region this window used to have and is used to maintain the relationship between the WINDOW coordinates and the displaystreams when the WINDOW moves.") (* ;; "MOVEONLYFLG indicates that the dimensions of the region haven't changed.") (PROG (R D WBORDERSIZE CLIPREG TWICEBORDER PROC) (SETQ R (fetch (WINDOW REG) of WINDOW)) (SETQ D (fetch (WINDOW DSP) of WINDOW)) (SETQ WBORDERSIZE (fetch (WINDOW WBORDER) of WINDOW)) (SETQ TWICEBORDER (UNFOLD WBORDERSIZE 2)) (COND (OLDREG (RELDSPXOFFSET (IDIFFERENCE (fetch (REGION LEFT) of R) (fetch (REGION LEFT) of OLDREG)) D) (RELDSPYOFFSET (IDIFFERENCE (fetch (REGION BOTTOM) of R) (fetch (REGION BOTTOM) of OLDREG)) D) (* ;; "if only moving, the clipping region remains the same. This is checked for because the height of the window title may have changed and this calculation results in the wrong answer. All other calls to ADVISEWDS should repaint the border.") (OR MOVEONLYFLG (DSPCLIPPINGREGION [create REGION LEFT _ (fetch (REGION LEFT) of (SETQ CLIPREG ( DSPCLIPPINGREGION NIL D))) BOTTOM _ (fetch (REGION BOTTOM) of CLIPREG) WIDTH _ (IDIFFERENCE (fetch (REGION WIDTH) of R) TWICEBORDER) HEIGHT _ (IPLUS (IDIFFERENCE (fetch (REGION HEIGHT) of R) TWICEBORDER) (COND [(fetch (WINDOW WTITLE) of WINDOW) (DSPLINEFEED NIL (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN) of WINDOW] (T 0] D))) (T (DSPXOFFSET (IPLUS (fetch (REGION LEFT) of R) WBORDERSIZE) D) (DSPYOFFSET (IPLUS (fetch (REGION BOTTOM) of R) WBORDERSIZE) D) (DSPCLIPPINGREGION [create REGION LEFT _ 0 BOTTOM _ 0 WIDTH _ (IDIFFERENCE (fetch (REGION WIDTH) of R) TWICEBORDER) HEIGHT _ (IPLUS (IDIFFERENCE (fetch (REGION HEIGHT) of R) TWICEBORDER) (COND [(fetch (WINDOW WTITLE) of WINDOW) (DSPLINEFEED NIL (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN) of WINDOW] (T 0] D))) [COND ((NULL MOVEONLYFLG) (* ;  "if the previous right margin was the default, change it.") (AND (OR (NOT OLDREG) (EQ (DSPRIGHTMARGIN NIL D) (IDIFFERENCE (fetch (REGION WIDTH) of OLDREG) TWICEBORDER))) (DSPRIGHTMARGIN (IDIFFERENCE (fetch (REGION WIDTH) of R) TWICEBORDER) D)) (COND ((AND (SETQ PROC (WINDOWPROP WINDOW 'PROCESS)) (EQ D (PROCESS.TTY PROC))) (* ;  "if the window changing is a tty, set its linelength.") [PROCESS.EVAL PROC (LIST (FUNCTION PAGEHEIGHT) (IQUOTIENT (fetch (REGION HEIGHT) of (SETQ CLIPREG (DSPCLIPPINGREGION NIL D))) (IMINUS (DSPLINEFEED NIL D] (PROCESS.EVAL PROC '(SETLINELENGTH)) (IF NIL THEN (* ; "try it without this.") (COND ((EQ (PROCESSPROP PROC 'NAME) 'EXEC) (* ;; "in the exec process, make sure the current position is inside the new shape. reuse variables R and TWICEBORDER to save binding.") (COND ((ILESSP (SETQ R (DSPYPOSITION NIL D)) (SETQ TWICEBORDER (fetch (REGION BOTTOM) of CLIPREG ))) (DSPYPOSITION TWICEBORDER D)) ((IGREATERP R (SETQ TWICEBORDER (IPLUS (fetch (REGION HEIGHT) of CLIPREG) TWICEBORDER))) (DSPYPOSITION (IDIFFERENCE TWICEBORDER (FONTPROP D 'ASCENT)) D] (UPDATE/SCROLL/REG WINDOW)) WINDOW]) (SHOWWFRAME [LAMBDA (WIN) (* rrb "23-May-84 16:12") (* ;; "Displays the border and title in the save image of a window") (PROG ((TITLE (fetch WTITLE of WIN)) (BORDER (fetch WBORDER of WIN)) (DSP (fetch DSP of WIN)) (SAVEIMAGE (fetch SAVE of WIN)) WINWDTH WINHGHT BLACKPART WHITEPART) [SETQ WINHGHT (fetch (REGION HEIGHT) of (SETQ WINWDTH (fetch (WINDOW REG) of WIN] (SETQ WINWDTH (fetch (REGION WIDTH) of WINWDTH)) (* ; "make most of the border black") (SETQ BLACKPART (IMAX (FOLDHI BORDER 2) (IDIFFERENCE BORDER 2))) (SETQ WHITEPART (IDIFFERENCE BORDER BLACKPART)) (* ; "Fill in frame in save image") (BITBLT NIL NIL NIL SAVEIMAGE 0 0 WINWDTH WINHGHT 'TEXTURE 'REPLACE BLACKSHADE) (* ;  "White out the frame in the saved image") (BITBLT NIL NIL NIL SAVEIMAGE BLACKPART BLACKPART (IDIFFERENCE WINWDTH (ITIMES 2 BLACKPART) ) (IPLUS (fetch (REGION HEIGHT) of (DSPCLIPPINGREGION NIL DSP)) (ITIMES 2 WHITEPART)) 'TEXTURE 'REPLACE WHITESHADE) (AND TITLE (SHOWWTITLE TITLE SAVEIMAGE BORDER NIL WIN))) WIN]) (SHOWWTITLE [LAMBDA (TITLE BM BORDER CENTERFLG WINDOW) (* kbr%: "25-Jan-86 15:21") (* ;; "prints a title in a window.") (PROG (TITLEDS FONT BLACKPART TITLESHADE BMWIDTH HEIGHT BOTTOM X LEFTMARGIN) (SETQ TITLEDS (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN) of WINDOW ))) (SETQ FONT (DSPFONT NIL TITLEDS)) (SETQ BLACKPART (SELECTQ BORDER (0 0) ((1 2) 1) (3 2) (IDIFFERENCE BORDER 2))) (SETQ TITLESHADE (OR (TEXTUREP (OR (WINDOWPROP WINDOW 'WINDOWTITLESHADE) WINDOWTITLESHADE)) BLACKSHADE)) (DSPDESTINATION BM TITLEDS) (DSPCLIPPINGREGION (create REGION LEFT _ 0 BOTTOM _ [SETQ BOTTOM (IDIFFERENCE (IPLUS (BITMAPHEIGHT BM) (COND ((ZEROP BORDER) 0) (T (* ;  "if room, leave a line of the border at the top of the title.") -1))) (SETQ HEIGHT (FONTPROP FONT 'HEIGHT] WIDTH _ (SETQ BMWIDTH (BITMAPWIDTH BM)) HEIGHT _ HEIGHT) TITLEDS) (MOVETO (COND [CENTERFLG (* ;  "save left margin for later shading.") (SETQ LEFTMARGIN (IMAX BORDER (IQUOTIENT (IDIFFERENCE BMWIDTH (\STRINGWIDTHGUESS TITLE FONT)) 2] (T BORDER)) (IPLUS BOTTOM (FONTPROP FONT 'DESCENT)) TITLEDS) (RESETFORM (PRINTLEVEL WINDOWTITLEPRINTLEVEL) (PROG ((PLVLFILEFLG T)) (PRIN3 TITLE TITLEDS))) (BITBLT NIL NIL NIL TITLEDS (SETQ X (IPLUS (IMAX 2 BLACKPART) (DSPXPOSITION NIL TITLEDS))) (COND ((EQ BLACKPART 1) (ADD1 BOTTOM)) (T BOTTOM)) (IDIFFERENCE BMWIDTH (IPLUS X BLACKPART)) NIL 'TEXTURE 'REPLACE TITLESHADE) (* ;  "shade stuff before title if centered.") (AND CENTERFLG (BITBLT NIL NIL NIL TITLEDS BORDER (COND ((EQ BLACKPART 1) (ADD1 BOTTOM)) (T BOTTOM)) (IDIFFERENCE LEFTMARGIN (IPLUS (IMAX 2 BLACKPART) BORDER)) NIL 'TEXTURE 'REPLACE TITLESHADE]) (\STRINGWIDTHGUESS [LAMBDA (X FONT) (* ; "Edited 3-Apr-87 13:44 by jop") (* ;; "returns a guess as to the string width of X. It goes one level so works on circular structures. It is used as a heuristic by functions who are going to print something with printlevel.") (STRINGWIDTH X FONT T]) (RESHOWTITLE [LAMBDA (TITLE WINDOW JUSTDISPLAYFLG) (* kbr%: "25-Jan-86 15:26") (* ;; "updates a windows display with a new title") (PROG* ((WREG (fetch (WINDOW REG) of WINDOW)) (TITLEDS (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN) of WINDOW))) (TITLEHEIGHT (IMINUS (DSPLINEFEED NIL TITLEDS))) (OLDTITLE (fetch (WINDOW WTITLE) of WINDOW)) (BORDER (fetch (WINDOW WBORDER) of WINDOW)) BM BMBTM HGHT) [COND (JUSTDISPLAYFLG) ((EQ TITLE (fetch (WINDOW WTITLE) of WINDOW)) (RETURN)) (T (replace (WINDOW WTITLE) of WINDOW with TITLE) (COND ([OR (NULL OLDTITLE) (NULL TITLE) (NEQ TITLEHEIGHT (IDIFFERENCE (fetch (REGION HEIGHT) of WREG) (IPLUS (fetch (REGION HEIGHT) of (DSPCLIPPINGREGION NIL (fetch (WINDOW DSP) of WINDOW))) (ITIMES 2 BORDER] (* ;  "Previously no title, so make space for one") (* ; "Have to remove title") (* ; "or title height changed.") (* ;  "so windows region on the screen has to be made larger.") (\RESHOWBORDER1 (fetch (WINDOW WBORDER) of WINDOW) (fetch (WINDOW WBORDER) of WINDOW) WINDOW) (RETURN] (* ;  "code from here is to reprint the title in place to avoid creating any large bitmaps.") [SETQ BM (BITMAPCREATE (fetch (REGION WIDTH) of WREG) (SETQ TITLEHEIGHT (ADD1 TITLEHEIGHT)) (BITSPERPIXEL (fetch (SCREEN SCDESTINATION) of (fetch (WINDOW SCREEN) of WINDOW] (BITBLT NIL NIL NIL BM 0 0 NIL NIL 'TEXTURE 'REPLACE BLACKSHADE) (* ;  "use SHOWWTITLE to put the image of the title into the auxilliary bitmap.") (SHOWWTITLE TITLE BM BORDER NIL WINDOW) [COND ((IGREATERP TITLEHEIGHT (SETQ HGHT (fetch (REGION HEIGHT) of WREG))) (SETQ BMBTM (IDIFFERENCE (SUB1 TITLEHEIGHT) HGHT] (UNINTERRUPTABLY (TOTOPW WINDOW) (BITBLT BM 0 (COND (BMBTM) ((IGREATERP BORDER 0) (* ;; "if there is a border, the title was printed in the scratch bitmap so to leave one point of the border on top") 0) (T 1)) (fetch (SCREEN SCDESTINATION) of (fetch (WINDOW SCREEN) of WINDOW)) (fetch (REGION LEFT) of WREG) [IDIFFERENCE (fetch (REGION PTOP) of WREG) (COND (BMBTM HGHT) (T (IPLUS TITLEHEIGHT (COND ((IGREATERP BORDER 0) (* ;; "if there is a border, the title was printed in the scratch bitmap so to leave one point of the border on top") 0) (T -1] NIL (COND (BMBTM HGHT))))]) (TOTOPW [LAMBDA (WINDOW NOCALLTOTOPFNFLG) (* kbr%: "25-Jan-86 15:28") (* ;; "user entry to bring a window to the top. Unless NOCALLTOTOPFNFLG is non-NIL, it will call the windows TOTOPFN") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (COND ((EQ WINDOW (fetch (SCREEN SCTOPW) of (fetch (WINDOW SCREEN) of WINDOW))) (PROGN (* (SETQ \TOPWDS (fetch  (WINDOW DSP) of WINDOW))) NIL)) ((OPENWP WINDOW) (OR NOCALLTOTOPFNFLG (DOUSERFNS (WINDOWPROP WINDOW 'TOTOPFN) WINDOW)) (\INTERNALTOTOPW WINDOW)) ((OPENW WINDOW) (* ;  "if it is not open, open it and then call the TOTOPFN") (OR NOCALLTOTOPFNFLG (DOUSERFNS (WINDOWPROP WINDOW 'TOTOPFN) WINDOW))) (T (* ;  "window won't open probably because of DON'T OPENFN") (ERROR "Window won't open; Can't be bring to top." WINDOW))) WINDOW]) (\INTERNALTOTOPW [LAMBDA (W1 RPT) (* gbn%: "25-Jan-86 15:36") (PROG (SCREEN SCREENTOPW) (SETQ W1 (\INSUREWINDOW W1)) (SETQ SCREEN (fetch (WINDOW SCREEN) of W1)) (SETQ SCREENTOPW (fetch (SCREEN SCTOPW) of SCREEN)) (OR (EQ W1 SCREENTOPW) (COND ((NULL SCREENTOPW) (* ;  "all windows are closed open this one.") (OPENW W1)) (T (UNINTERRUPTABLY (\TTW1 W1 SCREENTOPW) (* ;; "N.B. \TTW1 can side effect the screen") (COND ((EQ W1 (fetch (SCREEN SCTOPW) of SCREEN))) ((NOT RPT) (* ;  "GC msgs or other glitches can cause W1 not to make it. Check and try ONCE more") (\INTERNALTOTOPW W1 T))))]) (\TTW1 (LAMBDA (WINDOW WS) (* ; "Edited 6-Jul-88 13:42 by drc:") (* ;;; "This seems to swap the intersection of bitmaps.") (COND ((fetch (WINDOW NEXTW) of WS) (PROG (ISECT SCREEN) (SETQ SCREEN (fetch (WINDOW SCREEN) of WINDOW)) (.WHILE.TOP.DS. \TOPWDS (SETQ ISECT (INTERSECTREGIONS (fetch (WINDOW REG) of WINDOW) (fetch (WINDOW REG) of WS) (fetch (SCREEN SCREGION) of SCREEN))) (AND ISECT (\SW2BM (fetch (WINDOW SAVE) of WS) (TRANSLATEREG ISECT (fetch (WINDOW REG) of WS)) (fetch (SCREEN SCDESTINATION) of SCREEN) ISECT)) (COND ((EQ WINDOW (fetch (WINDOW NEXTW) of WS)) (* ; "doesn't have to be uninterruptable here because TOTOPW is.") (replace (WINDOW NEXTW) of WS with (fetch (WINDOW NEXTW) of WINDOW)) (replace (WINDOW NEXTW) of WINDOW with (fetch (SCREEN SCTOPW) of SCREEN)) (replace (SCREEN SCTOPW) of SCREEN with WINDOW) (SETQ \TOPWDS (fetch (WINDOW DSP) of WINDOW))) (T (\TTW1 WINDOW (fetch (WINDOW NEXTW) of WS)))) (AND ISECT (\SW2BM (fetch (WINDOW SAVE) of WINDOW) (TRANSLATEREG ISECT (fetch (WINDOW REG) of WINDOW)) (fetch (WINDOW SAVE) of WS) (TRANSLATEREG ISECT (fetch (WINDOW REG) of WS))))))) ((type? WINDOW WINDOW) (* ; "must be closed window; reopen it") (OPENW WINDOW)))) ) (WHICHW [LAMBDA (X Y SCREEN) (* gbn%: "25-Jan-86 15:47") (SETQ SCREEN (\INSURESCREEN SCREEN)) (COND ((POSITIONP X) (WHICHW (fetch (POSITION XCOORD) of X) (fetch (POSITION YCOORD) of X) SCREEN)) (T (for (WINDOW _ (fetch (SCREEN SCTOPW) of SCREEN)) by (fetch (WINDOW NEXTW) of WINDOW) while WINDOW thereis (INSIDE? (fetch (WINDOW REG) of WINDOW) X Y]) ) (RPAQ? WINDOWTITLEPRINTLEVEL '(2 . 5)) (RPAQ? WINDOWTITLESHADE BLACKSHADE) (* ; "Window vs non-window world") (DEFINEQ (WFROMDS [LAMBDA (DS DONTCREATE) (* gbn%: "25-Jan-86 15:43") (* ;; "Finds or creates a window for a display stream") (* ;; "uses an XPointer from the displaystream as a hint. This means that the window might have been garbage collected, hence all the confirmation.") (DECLARE (GLOBALVARS \DEFAULTTTYDISPLAYSTREAM)) (COND ((WINDOWP DS) DS) ((IMAGESTREAMP DS) (PROG (DD HINTW) [COND ((IMAGESTREAMTYPEP DS 'TEXT) (* ;; "generalize this mess!!!") (RETURN (CAR (fetch (TEXTOBJ \WINDOW) of (TEXTOBJ DS] (SETQ DD (\GETDISPLAYDATA DS DS)) (RETURN (COND ((AND (SETQ HINTW (fetch (\DISPLAYDATA XWINDOWHINT) of DD)) (EQ (fetch (WINDOW DSP) of HINTW) DS)) HINTW) [(AND (EQ DS \DEFAULTTTYDISPLAYSTREAM) (EQ (TTYDISPLAYSTREAM) \DEFAULTTTYDISPLAYSTREAM))(* ;  "assume this process is doing something with T.") (COND ((NOT DONTCREATE) (\CREATE.TTYDISPLAYSTREAM) (WFROMDS (TTYDISPLAYSTREAM] ([SETQ HINTW (for WINDOW in (OPENWINDOWS T) thereis (EQ DS (fetch (WINDOW DSP) of WINDOW] (* ;  "(OPENWINDOWS T) returns all windows on all screens") HINTW) ((NOT DONTCREATE) (CREATEW DS NIL NIL T]) (NU\TOTOPWDS [LAMBDA (DS NOTOTOPFNFLG) (* ; "Edited 17-Aug-88 19:37 by jds") (* ;  "Moves the window of displaystream DS to the top") (AND (FMEMB (DSPDESTINATION NIL DS) \SCREENBITMAPS) (TOTOPW (WFROMDS DS) NOTOTOPFNFLG]) (\COERCETODS [LAMBDA (X) (* rrb "23-OCT-81 13:29") (* ;; "Called from \SFInsureDisplayStream macro. Compiles open in system code, closed call in user code, and equivalent to \ILLEGAL.ARG if no window package.") (COND ((type? WINDOW X) (fetch (WINDOW DSP) of X)) (T (\ILLEGAL.ARG X]) ) (DECLARE%: DONTCOPY (* "FOLLOWING DEFINITIONS EXPORTED")(DECLARE%: EVAL@COMPILE (PUTPROPS \COERCETODS MACRO [OPENLAMBDA (X) (COND ((type? WINDOW X) (fetch (WINDOW DSP) of X)) (T (\ILLEGAL.ARG X]) (PUTPROPS .WHILE.ON.TOP. MACRO ((FIRST . REST) (UNINTERRUPTABLY (\INTERNALTOTOPW FIRST) . REST))) ) (* "END EXPORTED DEFINITIONS") ) (MOVD 'NU\TOTOPWDS '\TOTOPWDS) (* ; "User interface functions") (DEFINEQ (WINDOWP [LAMBDA (X) (* rrb "20-NOV-81 07:30") (AND (type? WINDOW X) X]) (INSURE.WINDOW [LAMBDA (WIN? NOERRORFLG) (* rrb "17-Mar-86 15:39") (* ;;; "coerces WIN? to a window.") (COND ((type? WINDOW WIN?) WIN?) ((DISPLAYSTREAMP (\OUTSTREAMARG WIN? T)) (WFROMDS WIN?)) ((NULL NOERRORFLG) (\ILLEGAL.ARG WIN?]) (WINDOWPROP [LAMBDA X (* rrb "26-AUG-82 17:36") (* ;; "general top level entry for both fetching and setting window properties.") (COND ((IGREATERP X 2) (PUTWINDOWPROP (ARG X 1) (ARG X 2) (ARG X 3))) ((EQ X 2) (GETWINDOWPROP (ARG X 1) (ARG X 2))) (T (\ILLEGAL.ARG NIL]) (WINDOWADDPROP [LAMBDA (WINDOW PROP ITEMTOADD FIRSTFLG) (* rrb "20-Mar-84 16:07") (* ;; "adds an element to a window property.") (PROG ((CURRENT (WINDOWPROP WINDOW PROP))) (RETURN (WINDOWPROP WINDOW PROP (COND ((NULL CURRENT) (LIST ITEMTOADD)) [(NLISTP CURRENT) (COND ((EQ CURRENT ITEMTOADD) (LIST ITEMTOADD)) (FIRSTFLG (LIST ITEMTOADD CURRENT)) (T (LIST CURRENT ITEMTOADD] ((FMEMB ITEMTOADD CURRENT) (* ; "don't put things on twice.") (COND ((AND FIRSTFLG (NEQ (CAR CURRENT) ITEMTOADD)) (* ; "make it first") (CONS ITEMTOADD (REMOVE ITEMTOADD CURRENT))) (T CURRENT))) (FIRSTFLG (CONS ITEMTOADD CURRENT)) (T (NCONC1 (APPEND CURRENT) ITEMTOADD]) (WINDOWDELPROP [LAMBDA (WINDOW PROP ITEMTODELETE) (* rrb "13-JUN-82 17:58") (* ;; "deletes a property from a window property.") (PROG ((CURRENT (WINDOWPROP WINDOW PROP))) (RETURN (COND ((LISTP CURRENT) (AND (FMEMB ITEMTODELETE CURRENT) (WINDOWPROP WINDOW PROP (REMOVE ITEMTODELETE CURRENT]) (GETWINDOWPROP [LAMBDA (WINDOW PROP) (* kbr%: "13-Feb-86 16:19") (* ;; "gets values from a window. Called by the macro for WINDOWPROP.") [OR (type? WINDOW WINDOW) (COND ((DISPLAYSTREAMP (\OUTSTREAMARG WINDOW T)) (SETQ WINDOW (WFROMDS WINDOW))) (T (\ILLEGAL.ARG WINDOW] (SELECTQ PROP (HEIGHT (\GETWINDOWHEIGHT WINDOW)) (WIDTH (* ;  "calculate the width from the REGION in case the user has changed the clipping region.") (\GETWINDOWWIDTH WINDOW)) (RIGHTBUTTONFN (fetch (WINDOW RIGHTBUTTONFN) of WINDOW)) (BUTTONEVENTFN (fetch (WINDOW BUTTONEVENTFN) of WINDOW)) (CURSORINFN (fetch (WINDOW CURSORINFN) of WINDOW)) (CURSOROUTFN (fetch (WINDOW CURSOROUTFN) of WINDOW)) (CURSORMOVEDFN (fetch (WINDOW CURSORMOVEDFN) of WINDOW)) (DSP (fetch (WINDOW DSP) of WINDOW)) (SCREEN (fetch (WINDOW SCREEN) of WINDOW)) (SCROLLFN (fetch (WINDOW SCROLLFN) of WINDOW)) (RESHAPEFN (fetch (WINDOW RESHAPEFN) of WINDOW)) (EXTENT (fetch (WINDOW EXTENT) of WINDOW)) (REPAINTFN (fetch (WINDOW REPAINTFN) of WINDOW)) (MOVEFN (fetch (WINDOW MOVEFN) of WINDOW)) (CLOSEFN (fetch (WINDOW CLOSEFN) of WINDOW)) (WINDOWENTRYFN (fetch (WINDOW WINDOWENTRYFN) of WINDOW)) (PROCESS (fetch (WINDOW PROCESS) of WINDOW)) (REGION (* ;  "make a copy so we don't have to worry about {or document} the user clobbering it.") (fetch (WINDOW REG) of WINDOW)) (NEWREGIONFN (fetch (WINDOW NEWREGIONFN) of WINDOW)) (TITLE (fetch (WINDOW WTITLE) of WINDOW)) (BORDER (fetch (WINDOW WBORDER) of WINDOW)) (IMAGECOVERED (fetch (WINDOW SAVE) of WINDOW)) (GETWINDOWUSERPROP WINDOW PROP]) (GETWINDOWUSERPROP [LAMBDA (WINDOW USERPROP) (* rrb "28-OCT-83 11:00") (* ;; "gets a property from the USERDATA property list of a window. This is the function called by the macro for GETWINDOWPROP which result from a call to WINDOWPROP that doesn't have a third argument.") (LISTGET (fetch (WINDOW USERDATA) of (\INSUREWINDOW WINDOW)) USERPROP]) (PUTWINDOWPROP [LAMBDA (WINDOW PROP VALUE) (* kbr%: "13-Feb-86 16:22") [OR (type? WINDOW WINDOW) (COND ((DISPLAYSTREAMP (\OUTSTREAMARG WINDOW)) (SETQ WINDOW (WFROMDS WINDOW))) (T (\ILLEGAL.ARG WINDOW] (SELECTQ PROP (RIGHTBUTTONFN (PROG1 (fetch (WINDOW RIGHTBUTTONFN) of WINDOW) (replace (WINDOW RIGHTBUTTONFN) of WINDOW with VALUE))) (BUTTONEVENTFN (PROG1 (fetch (WINDOW BUTTONEVENTFN) of WINDOW) (replace (WINDOW BUTTONEVENTFN) of WINDOW with VALUE))) (CLOSEFN (PROG1 (fetch (WINDOW CLOSEFN) of WINDOW) (replace (WINDOW CLOSEFN) of WINDOW with VALUE))) (MOVEFN (PROG1 (fetch (WINDOW MOVEFN) of WINDOW) (replace (WINDOW MOVEFN) of WINDOW with VALUE))) (CURSORINFN (PROG1 (fetch (WINDOW CURSORINFN) of WINDOW) (replace (WINDOW CURSORINFN) of WINDOW with VALUE))) (CURSOROUTFN (PROG1 (fetch (WINDOW CURSOROUTFN) of WINDOW) (replace (WINDOW CURSOROUTFN) of WINDOW with VALUE))) (CURSORMOVEDFN (PROG1 (fetch (WINDOW CURSORMOVEDFN) of WINDOW) (replace (WINDOW CURSORMOVEDFN) of WINDOW with VALUE))) (DSP (ERROR "Can't change DSP of a window" WINDOW)) (SCREEN (ERROR "Can't change SCREEN of a window" WINDOW)) (RESHAPEFN (PROG1 (fetch (WINDOW RESHAPEFN) of WINDOW) (replace (WINDOW RESHAPEFN) of WINDOW with VALUE))) (REPAINTFN (PROG1 (fetch (WINDOW REPAINTFN) of WINDOW) (replace (WINDOW REPAINTFN) of WINDOW with VALUE))) (EXTENT (PROG1 (fetch (WINDOW EXTENT) of WINDOW) (OR (NULL VALUE) (REGIONP VALUE) (\ILLEGAL.ARG VALUE)) (replace (WINDOW EXTENT) of WINDOW with VALUE))) (SCROLLFN (PROG1 (fetch (WINDOW SCROLLFN) of WINDOW) (replace (WINDOW SCROLLFN) of WINDOW with VALUE) (UPDATE/SCROLL/REG WINDOW))) (IMAGECOVERED (ERROR "Not implemented to change IMAGECOVERED property." WINDOW)) (HEIGHT (ERROR "Not implemented to change HEIGHT as property." WINDOW)) (WIDTH (ERROR "Not implemented to change WIDTH as property." WINDOW)) (REGION [PROG (CURREGION) (SETQ CURREGION (WINDOWPROP WINDOW 'REGION)) (COND ((NOT (REGIONP VALUE)) (\ILLEGAL.ARG VALUE))) (* ;; "there is no check for where the new region is nor how big it is; this is left to MOVEW and RESHAPEW.") (COND ((AND (EQ (fetch (REGION WIDTH) of CURREGION) (fetch (REGION WIDTH) of VALUE)) (EQ (fetch (REGION HEIGHT) of CURREGION) (fetch (REGION HEIGHT) of VALUE))) (* ;  "width and height are the same, move the window") (MOVEW WINDOW (fetch (REGION LEFT) of VALUE) (fetch (REGION BOTTOM) of VALUE))) (T (* ; "dimensions changed, reshape it.") (SHAPEW WINDOW VALUE]) (NEWREGIONFN (PROG1 (fetch (WINDOW NEWREGIONFN) of WINDOW) (replace (WINDOW NEWREGIONFN) of WINDOW with VALUE))) (TITLE (PROG1 (fetch (WINDOW WTITLE) of WINDOW) (RESHOWTITLE VALUE WINDOW))) (BORDER [PROG1 (fetch (WINDOW WBORDER) of WINDOW) (COND ((NUMBERP VALUE) (RESHOWBORDER VALUE WINDOW)) (T (\ILLEGAL.ARG VALUE]) (PROCESS (PROG1 (fetch (WINDOW PROCESS) of WINDOW) (replace (WINDOW PROCESS) of WINDOW with VALUE))) (WINDOWENTRYFN (PROG1 (fetch (WINDOW WINDOWENTRYFN) of WINDOW) (replace (WINDOW WINDOWENTRYFN) of WINDOW with VALUE))) (PROG (OLDDATA OLDVALUE) (SETQ OLDDATA (fetch (WINDOW USERDATA) of WINDOW)) (RETURN (PROG1 (COND (OLDDATA (SETQ OLDVALUE (LISTGET OLDDATA PROP)) [COND (VALUE (LISTPUT OLDDATA PROP VALUE)) (OLDVALUE (* Remove the property) (COND ((EQ (CAR OLDDATA) PROP) (replace (WINDOW USERDATA) of WINDOW with (CDDR OLDDATA))) (T (for TAIL on (CDR OLDDATA) by (CDDR TAIL) when (EQ (CADR TAIL) PROP) do (FRPLACD TAIL (CDDDR TAIL)) (RETURN] OLDVALUE) (VALUE (replace (WINDOW USERDATA) of WINDOW with (LIST PROP VALUE)) (* know old value is NIL) NIL)) (COND ((AND (fetch (WINDOW WTITLE) of WINDOW) (EQ PROP 'WINDOWTITLESHADE)) (* change windowtitleshade.) (RESHOWTITLE (fetch (WINDOW WTITLE) of WINDOW) WINDOW T]) (REMWINDOWPROP [LAMBDA (WINDOW PROP) (* rmk%: "31-AUG-83 16:42") [OR (type? WINDOW WINDOW) (COND ((DISPLAYSTREAMP (\OUTSTREAMARG WINDOW)) (SETQ WINDOW (WFROMDS WINDOW))) (T (LISPERROR "ILLEGAL ARG" WINDOW] (PROG (DATA) (SETQ DATA (fetch (WINDOW USERDATA) of WINDOW)) (RETURN (for TAIL on DATA by (CDDR TAIL) bind PREV do (COND ((EQ (CAR TAIL) PROP) (COND (PREV (RPLACD (CDR PREV) (CDDR TAIL))) ((CDDR TAIL) (FRPLNODE2 TAIL (CDDR TAIL))) (T (replace (WINDOW USERDATA) of WINDOW with NIL))) (RETURN PROP))) (SETQ PREV TAIL]) (WINDOWADDFNPROP [LAMBDA (WINDOW PROP ITEMTOADD) (* rrb "18-JUN-82 16:30") (* ;; "adds A functional element to a window property. This is different from WINDOWADDTOPROP because is checks for LAMBDA expressions as a single element.") (PROG ((CURRENT (WINDOWPROP WINDOW PROP))) (RETURN (WINDOWPROP WINDOW PROP (COND ((NULL CURRENT) (LIST ITEMTOADD)) ((OR (NLISTP CURRENT) (FMEMB (CAR CURRENT) LAMBDASPLST)) (LIST CURRENT ITEMTOADD)) ((FMEMB ITEMTOADD CURRENT) (* ; "don't put things on twice.") CURRENT) (T (NCONC1 (APPEND CURRENT) ITEMTOADD]) ) (* ; "Compiled WINDOWPROP") (PUTPROPS WINDOWPROP ARGNAMES (NIL (WINDOW PROP {NEWVALUE}) . U)) (DEFOPTIMIZER WINDOWPROP (&REST ARGS) (CWINDOWPROP ARGS)) (DEFINEQ (CWINDOWPROP [LAMBDA (FORMTAIL) (* rrb "28-OCT-83 10:51") (* ;; "compiles calls to WINDOWPROP") (COND ((NULL (CDR FORMTAIL)) (* ; "less than 2 args") (printout T "Possible error in call to WINDOWPROP: less than 2 args" T (LIST 'WINDOWPROP FORMTAIL) T) (CGETWINDOWPROP (CAR FORMTAIL) NIL)) ((NOT (EQ (CAADR FORMTAIL) 'QUOTE)) (* ; "property is not quoted.") 'IGNOREMACRO) [(NULL (CDDR FORMTAIL)) (* ; "fetching a window property.") (CGETWINDOWPROP (CAR FORMTAIL) (CADR (CADR FORMTAIL] (T (* ; "storing a window property") (CONS 'PUTWINDOWPROP FORMTAIL]) (CGETWINDOWPROP [LAMBDA (WINFORM PROP) (* kbr%: "17-Feb-86 10:43") (* ;; "compiles calls on WINDOWPROP that are fetching values. This needs to be changed whenever GETWINDOWPROP is changed.") (PROG NIL (RETURN (SUBST (LIST '\INSUREWINDOW WINFORM) 'DATUM (SELECTQ PROP (RIGHTBUTTONFN (CONSTANT (RECORDACCESSFORM '(WINDOW RIGHTBUTTONFN) 'DATUM 'ffetch))) (BUTTONEVENTFN (CONSTANT (RECORDACCESSFORM '(WINDOW BUTTONEVENTFN) 'DATUM 'ffetch))) (CURSORINFN (CONSTANT (RECORDACCESSFORM '(WINDOW CURSORINFN) 'DATUM 'ffetch))) (CURSOROUTFN (CONSTANT (RECORDACCESSFORM '(WINDOW CURSOROUTFN) 'DATUM 'ffetch))) (CURSORMOVEDFN (CONSTANT (RECORDACCESSFORM '(WINDOW CURSORMOVEDFN) 'DATUM 'ffetch))) (DSP (CONSTANT (RECORDACCESSFORM '(WINDOW DSP) 'DATUM 'ffetch))) (SCREEN (CONSTANT (RECORDACCESSFORM '(WINDOW SCREEN) 'DATUM 'ffetch))) (SCROLLFN (CONSTANT (RECORDACCESSFORM '(WINDOW SCROLLFN) 'DATUM 'ffetch))) (MOVEFN (CONSTANT (RECORDACCESSFORM '(WINDOW MOVEFN) 'DATUM 'ffetch))) (RESHAPEFN (CONSTANT (RECORDACCESSFORM '(WINDOW RESHAPEFN) 'DATUM 'ffetch))) (EXTENT (CONSTANT (RECORDACCESSFORM '(WINDOW EXTENT) 'DATUM 'ffetch))) (REPAINTFN (CONSTANT (RECORDACCESSFORM '(WINDOW REPAINTFN) 'DATUM 'ffetch))) (CLOSEFN (CONSTANT (RECORDACCESSFORM '(WINDOW CLOSEFN) 'DATUM 'ffetch))) (WINDOWENTRYFN (CONSTANT (RECORDACCESSFORM '(WINDOW WINDOWENTRYFN) 'DATUM 'ffetch))) (PROCESS (CONSTANT (RECORDACCESSFORM '(WINDOW PROCESS) 'DATUM 'ffetch))) (REGION (CONSTANT (RECORDACCESSFORM '(WINDOW REG) 'DATUM 'ffetch))) (NEWREGIONFN (CONSTANT (RECORDACCESSFORM '(WINDOW NEWREGIONFN) 'DATUM 'ffetch))) (TITLE (CONSTANT (RECORDACCESSFORM '(WINDOW WTITLE) 'DATUM 'ffetch))) (BORDER (CONSTANT (RECORDACCESSFORM '(WINDOW WBORDER) 'DATUM 'ffetch))) (IMAGECOVERED (CONSTANT (RECORDACCESSFORM '(WINDOW SAVE) 'DATUM 'ffetch))) (HEIGHT (LIST 'GETWINDOWPROP WINFORM ''HEIGHT)) (WIDTH (LIST 'GETWINDOWPROP WINFORM ''WIDTH)) (RETURN (PROGN (* ;; "return around SUBST. GETWINDOWUSERPROP will perform the window check and this avoids compiling code for it at every call.") (LIST 'GETWINDOWUSERPROP WINFORM (KWOTE PROP]) (\GETWINDOWHEIGHT [LAMBDA (WINDOW) (* gbn%: "25-Jan-86 15:45") (* ;; "calculate the height from the REGION in case user has changed the clipping region. This won't work if the height of the title display stream has changed.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (DIFFERENCE (fetch (REGION HEIGHT) of (fetch (WINDOW REG) of WINDOW)) (DIFFERENCE (ITIMES 2 (fetch (WINDOW WBORDER) of WINDOW)) (COND [(fetch (WINDOW WTITLE) of WINDOW) (DSPLINEFEED NIL (fetch (SCREEN SCTITLEDS) of (fetch (WINDOW SCREEN ) of WINDOW] (T 0]) (\GETWINDOWWIDTH [LAMBDA (WINDOW) (* rrb " 4-Jun-84 18:03") (* ;;  "calculate the width from the REGION in case the user has changed the clipping region.") (SETQ WINDOW (\INSUREWINDOW WINDOW)) (DIFFERENCE (fetch (REGION WIDTH) of (fetch (WINDOW REG) of WINDOW)) (ITIMES 2 (fetch (WINDOW WBORDER) of WINDOW]) ) (DEFINEQ (OPENWP [LAMBDA (WINDOW) (* rrb "26-OCT-83 15:01") (* ;; "is WINDOW an open window?") (AND (type? WINDOW WINDOW) (NEQ (fetch (WINDOW NEXTW) of WINDOW) 'CLOSED) WINDOW]) (TOPWP [LAMBDA (WINDOW) (* kbr%: "17-Feb-86 10:37") (* ;;; "A function user's can use to test if WINDOW is the TOPW of it's screen.") (EQ WINDOW (fetch (SCREEN SCTOPW) of (fetch (WINDOW SCREEN) of WINDOW]) (RESHAPEBYREPAINTFN [LAMBDA (WINDOW OLDIMAGE IMAGEREGION OLDSCREENREGION) (* rrb "11-Oct-84 17:22") (* ;; "default reshaping function that copies the lower left portion of the old image into the new image and calls the repaint function on the newly exposed portions.") (* ;; "if IMAGEREGION shares a corner with the current region, the excess is added in the opposite directions. Also the newly exposed region will be a subset of the EXTENT property if the window has one.") (PROG ((NEWSCREENREGION (WINDOWPROP WINDOW 'REGION)) (EXTENT (WINDOWPROP WINDOW 'EXTENT)) (DSP (WINDOWPROP WINDOW 'DSP)) (OLDWIDTH (fetch (REGION WIDTH) of IMAGEREGION)) (OLDHEIGHT (fetch (REGION HEIGHT) of IMAGEREGION)) NEWWID NEWHGHT WREGION OLDCRLFT OLDCRBTM NEWCRLFT NEWCRBTM DELTAWID DELTAHGHT NEWPTOP OLDPTOP NEWPRIGHT OLDPRIGHT YPOS) (SETQ WREGION (DSPCLIPPINGREGION NIL DSP)) (SETQ OLDCRLFT (fetch (REGION LEFT) of WREGION)) (SETQ OLDCRBTM (fetch (REGION BOTTOM) of WREGION)) (* ;  "calculate the position of the new clipping region.") (SETQ NEWWID (fetch (REGION WIDTH) of WREGION)) (SETQ DELTAWID (IDIFFERENCE NEWWID OLDWIDTH)) (SETQ NEWHGHT (fetch (REGION HEIGHT) of WREGION)) (SETQ DELTAHGHT (IDIFFERENCE NEWHGHT OLDHEIGHT)) [COND [(AND OLDSCREENREGION EXTENT (EQ (fetch (REGION PRIGHT) of NEWSCREENREGION) (fetch (REGION PRIGHT) of OLDSCREENREGION))) (* ;  "right edges match, move the left one") (SETQ NEWCRLFT (IDIFFERENCE OLDCRLFT DELTAWID)) (COND ((AND (IGREATERP DELTAWID 0) (IGREATERP (fetch (REGION LEFT) of EXTENT) NEWCRLFT)) (* ;; "this would be extending the window onto parts of the extent that don't have anything in them, reset the left so that it gets the entire extent") (SETQ NEWCRLFT (IMIN (fetch (REGION LEFT) of EXTENT) (IDIFFERENCE (fetch (REGION RIGHT) of EXTENT) NEWWID] (T (* ; "otherwise move the right edge.") (COND [(AND (IGREATERP DELTAWID 0) EXTENT (IGREATERP (IPLUS OLDCRLFT NEWWID) (fetch (REGION RIGHT) of EXTENT))) (* ;; "this would be extending the window onto parts of the extent that don't have anything in them, reset the left so that it gets the entire extent") (SETQ NEWCRLFT (IMAX (IMIN (fetch (REGION LEFT) of EXTENT) OLDCRLFT) (IDIFFERENCE OLDCRLFT DELTAWID] (T (SETQ NEWCRLFT OLDCRLFT] [COND [(AND OLDSCREENREGION (EQ (fetch (REGION PTOP) of NEWSCREENREGION) (fetch (REGION PTOP) of OLDSCREENREGION))) (* ;  "top edges match, move the bottom one") (SETQ NEWCRBTM (IDIFFERENCE OLDCRBTM DELTAHGHT)) (COND ((AND (IGREATERP DELTAHGHT 0) EXTENT (IGREATERP (fetch (REGION BOTTOM) of EXTENT) NEWCRBTM)) (* ;; "this would be extending the window onto parts of the extent that don't have anything in them, reset the bottom so that it gets the entire extent") (SETQ NEWCRBTM (IMIN (fetch (REGION BOTTOM) of EXTENT) (IDIFFERENCE (fetch (REGION TOP) of EXTENT) NEWHGHT] (T (* ; "otherwise move the top edge.") (COND [(AND (IGREATERP DELTAHGHT 0) EXTENT (IGREATERP (IPLUS OLDCRBTM OLDHEIGHT DELTAHGHT) (fetch (REGION PTOP) of EXTENT))) (* ;; "this would be extending the window onto parts of the extent that don't have anything in them, reset the bottom so that it gets the entire extent") (SETQ NEWCRBTM (IMAX (IDIFFERENCE OLDCRBTM DELTAHGHT) (fetch (REGION BOTTOM) of EXTENT) (IDIFFERENCE (fetch (REGION PTOP) of EXTENT) NEWHGHT] (T (SETQ NEWCRBTM OLDCRBTM] (* ;  "scroll the window so that the new left bottom is the left bottom of the clipping region.") [COND ((AND (NULL EXTENT) (\INBETWEENP (DSPXPOSITION NIL WINDOW) OLDCRLFT (IPLUS OLDCRLFT OLDWIDTH)) (\INBETWEENP (SETQ YPOS (DSPYPOSITION NIL WINDOW)) OLDCRBTM (IPLUS OLDCRBTM OLDHEIGHT))) (* ;; "if the window doesn't have any EXTENT and its position is visible, make sure its Y position is visible at the end of the scroll.") (COND [(ILESSP YPOS NEWCRBTM) (* ;  "make sure the entire line of text being printed is visible.") (SETQ NEWCRBTM (DIFFERENCE YPOS (FONTPROP WINDOW 'DESCENT] ([IGREATERP YPOS (DIFFERENCE (IPLUS NEWCRBTM NEWHGHT) (FONTPROP WINDOW 'ASCENT] (SETQ NEWCRBTM (IPLUS (IDIFFERENCE YPOS NEWHGHT) (FONTPROP WINDOW 'ASCENT] [COND ((NEQ OLDCRLFT NEWCRLFT) (COND ((EQ (DSPSCROLL NIL WINDOW) 'ON) (* ;  "if scrolling is turned on, don't change the coordinates.") NIL) (T (WXOFFSET (DIFFERENCE OLDCRLFT NEWCRLFT) WINDOW] [COND ((NEQ OLDCRBTM NEWCRBTM) (COND ((EQ (DSPSCROLL NIL WINDOW) 'ON) (* ;  "if scrolling is turned on, change the Y rather than the coordinates.") (DSPYPOSITION (PLUS (DIFFERENCE OLDCRBTM NEWCRBTM) YPOS) WINDOW)) (T (WYOFFSET (DIFFERENCE OLDCRBTM NEWCRBTM) WINDOW] (* ;  "call the redisplay function on the four possible areas and blt the middle one.") (COND ((IGREATERP (SETQ NEWPTOP (IPLUS NEWCRBTM NEWHGHT)) (SETQ OLDPTOP (IPLUS OLDCRBTM OLDHEIGHT))) (* ;  "call the display function on the newly exposed top area.") (REDISPLAYW WINDOW (create REGION LEFT _ NEWCRLFT BOTTOM _ OLDPTOP WIDTH _ NEWWID HEIGHT _ (IDIFFERENCE NEWPTOP OLDPTOP)) T))) (COND ((IGREATERP OLDCRLFT NEWCRLFT) (* ;  "call the display function on the newly exposed LEFT area.") (REDISPLAYW WINDOW (create REGION LEFT _ NEWCRLFT BOTTOM _ OLDCRBTM WIDTH _ (IDIFFERENCE OLDCRLFT NEWCRLFT) HEIGHT _ OLDHEIGHT) T))) (* ; "blt center region.") (BITBLT OLDIMAGE (fetch (REGION LEFT) of IMAGEREGION) (fetch (REGION BOTTOM) of IMAGEREGION) DSP OLDCRLFT OLDCRBTM OLDWIDTH OLDHEIGHT NIL 'REPLACE) (COND ((IGREATERP (SETQ NEWPRIGHT (IPLUS NEWCRLFT NEWWID)) (SETQ OLDPRIGHT (IPLUS OLDCRLFT OLDWIDTH))) (* ;  "call the display function on the newly exposed right area.") (REDISPLAYW WINDOW (create REGION LEFT _ OLDPRIGHT BOTTOM _ OLDCRBTM WIDTH _ (IDIFFERENCE NEWPRIGHT OLDPRIGHT) HEIGHT _ OLDHEIGHT) T))) (COND ((IGREATERP OLDCRBTM NEWCRBTM) (* ;  "call the display function on the newly exposed LEFT area.") (REDISPLAYW WINDOW (create REGION LEFT _ NEWCRLFT BOTTOM _ NEWCRBTM WIDTH _ NEWWID HEIGHT _ (IDIFFERENCE OLDCRBTM NEWCRBTM)) T))) (RETURN WINDOW]) (\INBETWEENP [LAMBDA (X LFT RGHT) (* rrb "11-Oct-84 17:07") (* ;; "returns T if X is between LEFT and RIGHT") (AND (GEQ X LFT) (GREATERP RGHT X]) (DECODE/WINDOW/OR/DISPLAYSTREAM [LAMBDA (DSORW WINDOWVAR TITLE BORDER) (* rmk%: "12-OCT-83 11:31") (* ;; "provides a defaulting mechanism for display-streams that uses windows too. If DSORW is NIL, it uses the value of WINDOWVAR and if DSORW is NEW, it creates a new one.") (COND ((DISPLAYSTREAMP DSORW)) ((WINDOWP DSORW) (OPENW DSORW) (AND TITLE (NOT (EQUAL TITLE (fetch WTITLE of DSORW))) (WINDOWPROP DSORW 'TITLE TITLE)) (AND BORDER (WINDOWPROP DSORW 'BORDER BORDER)) (fetch DSP of DSORW)) [(NULL DSORW) (fetch DSP of (PROG ((WINDOW (EVALV WINDOWVAR))) (RETURN (COND ((WINDOWP WINDOW) (OPENW WINDOW) (AND TITLE (NOT (EQUAL TITLE (fetch WTITLE of WINDOW))) (WINDOWPROP WINDOW 'TITLE TITLE)) (AND BORDER (WINDOWPROP WINDOW 'BORDER BORDER)) WINDOW) (T (SET WINDOWVAR (CREATEW NIL TITLE BORDER] [(EQ DSORW 'NEW) (fetch DSP of (SET WINDOWVAR (CREATEW NIL TITLE BORDER] (T (ERROR "Illegal args" (LIST DSORW WINDOWVAR]) (GROW/REGION [LAMBDA (REGION AMOUNT) (* rrb "19-OCT-83 11:18") (* ;; "increase REGION by amount in all directions") (CREATEREGION (IDIFFERENCE (fetch (REGION LEFT) of REGION) AMOUNT) (IDIFFERENCE (fetch (REGION BOTTOM) of REGION) AMOUNT) (IPLUS (fetch (REGION WIDTH) of REGION) (SETQ AMOUNT (ITIMES AMOUNT 2))) (IPLUS (fetch (REGION HEIGHT) of REGION) AMOUNT]) (CLRPROMPT [LAMBDA NIL (* lmm "28-MAY-83 12:06") (* ;; "clears the prompt window") (COND ((type? WINDOW PROMPTWINDOW) (CLEARW PROMPTWINDOW)) (T (TERPRI PROMPTWINDOW) (TERPRI PROMPTWINDOW]) (PROMPTPRINT [LAMBDA N (* lmm "28-MAY-83 14:45") (* ;; "prints its arguments in the prompt window.") (CLRPROMPT) (for I from 1 to N do (PRIN1 (ARG N I) PROMPTWINDOW]) (OPENWINDOWS [LAMBDA (SCREEN) (* kbr%: " 4-Aug-85 16:34") (* ;; "returns a list of all open windows") (PROG (WINDOW WINDOWS) (COND ((EQ SCREEN T) (* ; "Return all open windows.") (SETQ WINDOWS (for SCREEN in \SCREENS join (OPENWINDOWS SCREEN))) (RETURN WINDOWS))) (SETQ SCREEN (\INSURESCREEN SCREEN)) (SETQ WINDOW (fetch (SCREEN SCTOPW) of SCREEN)) (while WINDOW do (SETQ WINDOWS (CONS WINDOW WINDOWS)) (SETQ WINDOW (fetch (WINDOW NEXTW) of WINDOW))) (SETQ WINDOWS (DREVERSE WINDOWS)) (RETURN WINDOWS]) (\INSUREWINDOW [LAMBDA (WINDOW) (* rmk%: " 1-SEP-83 10:25") (* ;; "coerces to a window") (COND ((type? WINDOW WINDOW) WINDOW) ((AND (DISPLAYSTREAMP (\OUTSTREAMARG WINDOW T)) (WFROMDS WINDOW))) (T (\ILLEGAL.ARG WINDOW]) ) (* ; "these entries are left in for backward compatibility. They were dedocumented 6/83. rrb") (MOVD 'OPENWP 'ACTIVEWP) (DEFINEQ (OVERLAPPINGWINDOWS [LAMBDA (WINDOW) (* gbn%: "25-Jan-86 15:52") (* ;; "returns all windows that overlap with WINDOW or that overlap a window that is in the OVERLAPPINGWINDOWS of WINDOW.") (PROG (WPTR OVERLAPS DONTS) (SETQ WPTR (fetch (SCREEN SCTOPW) of (fetch (WINDOW SCREEN) of WINDOW))) (SETQ OVERLAPS (CONS WINDOW (ALLATTACHEDWINDOWS WINDOW))) LP [COND ((NULL WPTR) (RETURN OVERLAPS)) ((MEMB WPTR OVERLAPS) (* ; "skip the window itself") NIL) ([SOME OVERLAPS (FUNCTION (LAMBDA (X) (WOVERLAPP WPTR X] (* ;  "this window overlaps a member of the interesting ones.") (SETQ OVERLAPS (CONS WPTR OVERLAPS)) (* ;; "find all members of donts that overlap this new window and move them {and ones that overlap them} to OVERLAPS.") (PROG ((ADDS (CONS WPTR)) OVERLAPPED) NWLP (COND ((for old OVERLAPPED in DONTS thereis (WOVERLAPP (CAR ADDS) OVERLAPPED)) (* ;  "the window that was added overlaps one of the previously looked at windows that was untouched.") (SETQ ADDS (CONS OVERLAPPED ADDS)) (SETQ OVERLAPS (CONS OVERLAPPED OVERLAPS)) (SETQ DONTS (REMOVE OVERLAPPED DONTS)) (GO NWLP)) ((SETQ ADDS (CDR ADDS)) (* ;  "there are more windows that were added.") (GO NWLP))) (RETURN))) (T (SETQ DONTS (CONS WPTR DONTS] (SETQ WPTR (fetch (WINDOW NEXTW) of WPTR)) (GO LP]) (WOVERLAPP [LAMBDA (W1 W2) (* rrb "16-AUG-81 08:30") (* ;; "do these windows overlap?") (REGIONSINTERSECTP (fetch (WINDOW REG) of W1) (fetch (WINDOW REG) of W2]) (ORDERFROMBOTTOMTOTOP [LAMBDA (WLST) (* gbn%: "25-Jan-86 15:56") (* ;; "returns a list of windows in order from bottom to top") (PROG (ANS WPTR) (COND ((NULL WLST) (RETURN NIL))) [SETQ WPTR (fetch (SCREEN SCTOPW) of (fetch (WINDOW SCREEN) of (CAR WLST] (* ; "start at the topw") LP [COND ((NULL WPTR) (RETURN ANS)) ((FMEMB WPTR WLST) (SETQ ANS (CONS WPTR ANS] (SETQ WPTR (fetch (WINDOW NEXTW) of WPTR)) (GO LP]) ) (* ; "screen size changing functions.") (DEFINEQ (\ONSCREENW [LAMBDA (W) (* kbr%: "18-Jan-86 18:40") (* ;; "does W have any part on the screen?") (* ;; "for now only consider that it might be too far to the right as this is the wide to narrow screen case.") (* ;; "HARDCURSORWIDTH is to make sure the cursor can be set in the window. It can be taken out when cursor hotspot can go anywhere.") (IGREATERP (IDIFFERENCE (fetch (SCREEN SCWIDTH) of (fetch (WINDOW SCREEN) of W)) HARDCURSORWIDTH) (fetch (REGION LEFT) of (WINDOWPROP W 'REGION]) (\PUTONSCREENW [LAMBDA (W) (* kbr%: "26-Mar-85 23:29") (* ;;  "moves W so that it will be on the screen. For now, moves it to the left by screenwidth") (MOVEW W (create POSITION XCOORD _ (IDIFFERENCE (fetch (REGION LEFT) of (fetch (WINDOW REG) of W)) (fetch (SCREEN SCWIDTH) of (fetch (WINDOW SCREEN) of W))) YCOORD _ (fetch (REGION BOTTOM) of (WINDOWPROP W 'REGION]) (\UPDATECACHEDFIELDS [LAMBDA (DS) (* rrb "14-OCT-81 16:53") (* ;;  "updates the cached fields of a displaystream for the fact that the screen bitmap changed sizes") (\SFFixDestination DS]) (\WWCHANGESCREENSIZE [LAMBDA (SCREEN) (* lmm "16-Nov-86 05:04") (* ;; "the sysout has been moved to a screen of a different size. All windows are closed, the screenbitmap is updated to correct new size and the windows are reopened so that at least part of each is visible.") (PROG (WINDOWS) (SETQ SCREEN (\INSURESCREEN SCREEN)) (SETQ WINDOWS (DREVERSE (OPENWINDOWS SCREEN))) (* ;  "OPENWINDOWS returns the windows with bottom window first.") (for W in WINDOWS do (\CLOSEW1 W)) (\STARTDISPLAY) (\CLEARBM (fetch (SCREEN SCDESTINATION) of SCREEN) WINDOWBACKGROUNDSHADE) (* ;  "update cached bitmap width information that is in the display streams") [for W in WINDOWS do (\UPDATECACHEDFIELDS (WINDOWPROP W 'DSP] (* ; "bring back windows") (for W in (REVERSE WINDOWS) do (COND ((NOT (\ONSCREENW W)) (\PUTONSCREENW W))) (OPENW W]) (CREATEWFROMIMAGE [LAMBDA (IMAGE SCREEN) (* gbn%: "25-Jan-86 16:05") (* ;; "creates a window that has IMAGE (a bitmap) as an image. It is initially closed and can be opened.") (PROG (WINDOW) (SETQ WINDOW (CREATEW (create SCREENREGION SCREEN _ (\INSURESCREEN SCREEN) LEFT _ 0 BOTTOM _ 0 WIDTH _ (BITMAPWIDTH IMAGE) HEIGHT _ (BITMAPHEIGHT IMAGE)) NIL 0 T)) [WINDOWPROP WINDOW 'MINSIZE (CONS (IMIN MinWindowWidth (BITMAPWIDTH IMAGE)) (IMIN MinWindowWidth (BITMAPHEIGHT IMAGE] (BITBLT IMAGE 0 0 (fetch (WINDOW SAVE) of WINDOW)) (RETURN WINDOW]) (UPDATEWFROMIMAGE [LAMBDA (WINDOW) (* ; "Edited 20-Aug-91 18:05 by jds") (* ;; "makes the fields of a window consistent with its image.") (PROG ((REGION (fetch (WINDOW REG) of WINDOW)) (IMAGE (fetch (WINDOW SAVE) of WINDOW))) (replace (REGION LEFT) of REGION with 0) (replace (REGION BOTTOM) of REGION with 0) (replace (REGION WIDTH) of REGION with (BITMAPWIDTH IMAGE)) (replace (REGION HEIGHT) of REGION with (BITMAPHEIGHT IMAGE]) ) (DECLARE%: EVAL@COMPILE DONTCOPY (DECLARE%: DOEVAL@COMPILE DONTCOPY (GLOBALVARS \LastCursorPosition \LastInWindow WindowMenu BackgroundMenu BackgroundMenuCommands \LastWindowButtons WWFNS WindowMenuCommands WindowTitleDisplayStream WINDOWTITLEPRINTLEVEL WBorder \TOPWDS WINDOWBACKGROUNDSHADE BACKGROUNDFNS) ) (* "FOLLOWING DEFINITIONS EXPORTED")(DECLARE%: EVAL@COMPILE (RPAQQ MinWindowWidth 26) (RPAQQ MinWindowHeight 16) (CONSTANTS (MinWindowWidth 26) (MinWindowHeight 16)) ) (DECLARE%: EVAL@COMPILE (DATATYPE WINDOW (DSP NEXTW SAVE REG BUTTONEVENTFN RIGHTBUTTONFN CURSORINFN CURSOROUTFN CURSORMOVEDFN REPAINTFN RESHAPEFN EXTENT USERDATA VERTSCROLLREG HORIZSCROLLREG SCROLLFN VERTSCROLLWINDOW HORIZSCROLLWINDOW CLOSEFN MOVEFN WTITLE NEWREGIONFN WBORDER PROCESS WINDOWENTRYFN SCREEN) BUTTONEVENTFN _ (FUNCTION TOTOPW) WBORDER _ WBorder WINDOWENTRYFN _ (FUNCTION GIVE.TTY.PROCESS) (SYSTEM)) (DATATYPE SCREEN (SCONOFF SCDESTINATION SCWIDTH SCHEIGHT SCTOPW SCTOPWDS SCTITLEDS SCFDEV SCDS SCDATA) SCONOFF _ 'OFF [ACCESSFNS ((SCBITSPERPIXEL (fetch (BITMAP BITMAPBITSPERPIXEL) of (fetch (SCREEN SCDESTINATION) of DATUM))) (SCREGION (create REGION LEFT _ 0 BOTTOM _ 0 WIDTH _ (fetch (SCREEN SCWIDTH) of DATUM) HEIGHT _ (fetch (SCREEN SCHEIGHT) of DATUM] (SYSTEM)) ) (/DECLAREDATATYPE 'WINDOW '(POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER) '((WINDOW 0 POINTER) (WINDOW 2 POINTER) (WINDOW 4 POINTER) (WINDOW 6 POINTER) (WINDOW 8 POINTER) (WINDOW 10 POINTER) (WINDOW 12 POINTER) (WINDOW 14 POINTER) (WINDOW 16 POINTER) (WINDOW 18 POINTER) (WINDOW 20 POINTER) (WINDOW 22 POINTER) (WINDOW 24 POINTER) (WINDOW 26 POINTER) (WINDOW 28 POINTER) (WINDOW 30 POINTER) (WINDOW 32 POINTER) (WINDOW 34 POINTER) (WINDOW 36 POINTER) (WINDOW 38 POINTER) (WINDOW 40 POINTER) (WINDOW 42 POINTER) (WINDOW 44 POINTER) (WINDOW 46 POINTER) (WINDOW 48 POINTER) (WINDOW 50 POINTER)) '52) (/DECLAREDATATYPE 'SCREEN '(POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER) '((SCREEN 0 POINTER) (SCREEN 2 POINTER) (SCREEN 4 POINTER) (SCREEN 6 POINTER) (SCREEN 8 POINTER) (SCREEN 10 POINTER) (SCREEN 12 POINTER) (SCREEN 14 POINTER) (SCREEN 16 POINTER) (SCREEN 18 POINTER)) '20) (* "END EXPORTED DEFINITIONS") ) (DECLARE%: EVAL@COMPILE (* "FOLLOWING DEFINITIONS EXPORTED")(DECLARE%: DOEVAL@COMPILE DONTCOPY (GLOBALVARS WINDOWUSERFORMS ENDOFWINDOWUSERFORMS PROMPTWINDOW) ) (* "END EXPORTED DEFINITIONS") ) (ADDTOVAR SYSTEMRECLST (DATATYPE WINDOW (DSP NEXTW SAVE REG BUTTONEVENTFN RIGHTBUTTONFN CURSORINFN CURSOROUTFN CURSORMOVEDFN REPAINTFN RESHAPEFN EXTENT USERDATA VERTSCROLLREG HORIZSCROLLREG SCROLLFN VERTSCROLLWINDOW HORIZSCROLLWINDOW CLOSEFN MOVEFN WTITLE NEWREGIONFN WBORDER PROCESS WINDOWENTRYFN SCREEN)) (DATATYPE SCREEN (SCONOFF SCDESTINATION SCWIDTH SCHEIGHT SCTOPW SCTOPWDS SCTITLEDS SCFDEV SCDS SCDATA)) ) (/DECLAREDATATYPE 'WINDOW '(POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER) '((WINDOW 0 POINTER) (WINDOW 2 POINTER) (WINDOW 4 POINTER) (WINDOW 6 POINTER) (WINDOW 8 POINTER) (WINDOW 10 POINTER) (WINDOW 12 POINTER) (WINDOW 14 POINTER) (WINDOW 16 POINTER) (WINDOW 18 POINTER) (WINDOW 20 POINTER) (WINDOW 22 POINTER) (WINDOW 24 POINTER) (WINDOW 26 POINTER) (WINDOW 28 POINTER) (WINDOW 30 POINTER) (WINDOW 32 POINTER) (WINDOW 34 POINTER) (WINDOW 36 POINTER) (WINDOW 38 POINTER) (WINDOW 40 POINTER) (WINDOW 42 POINTER) (WINDOW 44 POINTER) (WINDOW 46 POINTER) (WINDOW 48 POINTER) (WINDOW 50 POINTER)) '52) (/DECLAREDATATYPE 'SCREEN '(POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER POINTER) '((SCREEN 0 POINTER) (SCREEN 2 POINTER) (SCREEN 4 POINTER) (SCREEN 6 POINTER) (SCREEN 8 POINTER) (SCREEN 10 POINTER) (SCREEN 12 POINTER) (SCREEN 14 POINTER) (SCREEN 16 POINTER) (SCREEN 18 POINTER)) '20) (RPAQ? WindowMenu ) (RPAQ? BackgroundMenu ) (RPAQ? \LastCursorPosition (CREATEPOSITION)) (RPAQ? \LastInWindow ) (RPAQ? \LastWindowButtons 0) (RPAQ? WINDOWBACKGROUNDSHADE 34850) (RPAQ? WBorder 4) (RPAQ? HIGHLIGHTSHADE 32800) (RPAQ? WINDOWBACKGROUNDBORDER 34850) (FILESLOAD PAINTW) (ADDTOVAR WindowMenuCommands (Close '\INTERACTIVE.CLOSEW "Closes a window") (Snap 'SNAPW "Saves a snapshot of a region of the screen.") (Paint 'PAINTW "Starts a painting mode in which the mouse can be used to draw pictures or make notes on windows.") (Clear 'CLEARW "Clears a window to its gray.") (Bury 'BURYW "Puts a window on the bottom.") (Redisplay 'REDISPLAYW "Redisplays a window using its REPAINTFN.") (Hardcopy 'HARDCOPYIMAGEW "Prints a window using its HARDCOPYFN." (SUBITEMS ("To a file" 'HARDCOPYIMAGEW.TOFILE "Puts image on a file; prompts for filename and format") ("To a printer" 'HARDCOPYIMAGEW.TOPRINTER "Sends image to a printer of your choosing"))) (Move 'MOVEW "Moves a window by a corner.") (Shape 'SHAPEW "Gets a new region for a window. Left button down marks fixed corner; sweep to other corner. Middle button down moves closest corner.") (Shrink 'SHRINKW "Replaces this window with its icon (or title if it doesn't have an icon." )) (ADDTOVAR BackgroundMenuCommands (SaveVM '(SAVEVM) "Updates the virtual memory.") (Snap '(SNAPW) "Saves a snapshot of a region of the screen.") (Hardcopy '(HARDCOPYW) "Send hardcopy of screen region to printer." (SUBITEMS ("To a file" '(HARDCOPYREGION.TOFILE) "Writes a region of screen to a file; prompts for filename and format" ) ("To a printer" '(HARDCOPYREGION.TOPRINTER) "Sends a region of screen to a printer of your choosing")))) (ADDTOVAR WINDOWUSERFORMS ) (ADDTOVAR ENDOFWINDOWUSERFORMS ) (DECLARE%: DONTEVAL@LOAD DOCOPY (COND ((NULL \MAINSCREEN) (SETQ \MAINSCREEN (CREATESCREEN (SCREENBITMAP))) (SETQ \CURSORSCREEN \MAINSCREEN) (SETQ LASTSCREEN \MAINSCREEN) (WINDOWWORLD 'ON \MAINSCREEN T))) (RPAQQ \WINDOWWORLD T) ) (* ;; "Arrange for the proper compiler") (PUTPROPS WINDOW FILETYPE :FAKE-COMPILE-FILE) (DECLARE%: DONTEVAL@LOAD DOEVAL@COMPILE DONTCOPY COMPILERVARS (ADDTOVAR NLAMA ) (ADDTOVAR NLAML ) (ADDTOVAR LAMA PROMPTPRINT WINDOWPROP DOWINDOWCOM) ) (PUTPROPS WINDOW COPYRIGHT ("Venue & Xerox Corporation" 1982 1983 1984 1985 1986 1987 1988 1990 1991)) (DECLARE%: DONTCOPY (FILEMAP (NIL (9277 21583 (WINDOWWORLD 9287 . 12824) (WINDOWWORLDP 12826 . 13126) (CHANGEBACKGROUND 13128 . 13738) (CHANGEBACKGROUNDBORDER 13740 . 14511) (TILE 14513 . 15105) ( \TTY.CREATING.DISPLAYSTREAM 15107 . 15629) (\CREATE.TTY.OUTCHARFN 15631 . 15949) ( \CREATE.TTYDISPLAYSTREAM 15951 . 18998) (HASTTYWINDOWP 19000 . 19285) (TTYINFOSTREAM 19287 . 19796) ( CREATESCREEN 19798 . 20840) (\INSURESCREEN 20842 . 21091) (\BITMAPTOSCREEN 21093 . 21453) (MAINSCREEN 21455 . 21581)) (22242 38974 (WINDOW.MOUSE.HANDLER 22252 . 34497) (\PROTECTED.APPLY 34499 . 34746) ( DOWINDOWCOM 34748 . 36773) (DOBACKGROUNDCOM 36775 . 37929) (DEFAULT.BACKGROUND.COPYFN 37931 . 38972)) (39055 86867 (BURYW 39065 . 40341) (CLEARW 40343 . 40814) (CLOSEW 40816 . 41545) (\CLOSEW1 41547 . 43023) (\OKTOCLOSEW 43025 . 43389) (\INTERACTIVE.CLOSEW 43391 . 44219) (OPENW 44221 . 45375) ( DOUSERFNS 45377 . 46543) (DOUSERFNS2 46545 . 47046) (\USERFNISDON'T 47048 . 47324) (\OPENW1 47326 . 49677) (CREATEW 49679 . 55765) (OPENDISPLAYSTREAM 55767 . 56090) (MOVEW 56092 . 66631) (PPROMPT3 66633 . 66966) (\ONSCREENCLIPPINGREGION 66968 . 67530) (RELMOVEW 67532 . 68142) (SHAPEW 68144 . 72787) ( SHAPEW1 72789 . 75523) (\SHAPEW2 75525 . 78219) (RESHOWBORDER 78221 . 78737) (\RESHOWBORDER1 78739 . 83670) (TRACKW 83672 . 84792) (SNAPW 84794 . 86367) (WINDOWREGION 86369 . 86865)) (86868 87569 ( MINIMUMWINDOWSIZE 86878 . 87567)) (89326 112165 (ADVISEWDS 89336 . 97260) (SHOWWFRAME 97262 . 98971) ( SHOWWTITLE 98973 . 103012) (\STRINGWIDTHGUESS 103014 . 103378) (RESHOWTITLE 103380 . 107967) (TOTOPW 107969 . 109306) (\INTERNALTOTOPW 109308 . 110383) (\TTW1 110385 . 111582) (WHICHW 111584 . 112163)) ( 112294 115125 (WFROMDS 112304 . 114290) (NU\TOTOPWDS 114292 . 114728) (\COERCETODS 114730 . 115123)) ( 115836 130595 (WINDOWP 115846 . 115992) (INSURE.WINDOW 115994 . 116332) (WINDOWPROP 116334 . 116771) ( WINDOWADDPROP 116773 . 118512) (WINDOWDELPROP 118514 . 118945) (GETWINDOWPROP 118947 . 121118) ( GETWINDOWUSERPROP 121120 . 121552) (PUTWINDOWPROP 121554 . 128333) (REMWINDOWPROP 128335 . 129390) ( WINDOWADDFNPROP 129392 . 130593)) (130803 137337 (CWINDOWPROP 130813 . 131823) (CGETWINDOWPROP 131825 . 135985) (\GETWINDOWHEIGHT 135987 . 136900) (\GETWINDOWWIDTH 136902 . 137335)) (137338 152284 ( OPENWP 137348 . 137631) (TOPWP 137633 . 137915) (RESHAPEBYREPAINTFN 137917 . 148134) (\INBETWEENP 148136 . 148357) (DECODE/WINDOW/OR/DISPLAYSTREAM 148359 . 149955) (GROW/REGION 149957 . 150525) ( CLRPROMPT 150527 . 150831) (PROMPTPRINT 150833 . 151150) (OPENWINDOWS 151152 . 151941) (\INSUREWINDOW 151943 . 152282)) (152415 155674 (OVERLAPPINGWINDOWS 152425 . 154707) (WOVERLAPP 154709 . 154969) ( ORDERFROMBOTTOMTOTOP 154971 . 155672)) (155723 160555 (\ONSCREENW 155733 . 156454) (\PUTONSCREENW 156456 . 157301) (\UPDATECACHEDFIELDS 157303 . 157573) (\WWCHANGESCREENSIZE 157575 . 158969) ( CREATEWFROMIMAGE 158971 . 159939) (UPDATEWFROMIMAGE 159941 . 160553))))) STOP \ No newline at end of file diff --git a/sources/WINDOW-OLD.LCOM b/sources/WINDOW-OLD.LCOM deleted file mode 100644 index 398200b750d9f8f84c8c0011d4800a5b74cea36a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 53851 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 b_%ld