From b9901709c9960087623c35dcfadd7f49fe496682 Mon Sep 17 00:00:00 2001 From: Arun Welch Date: Sun, 13 Dec 2020 17:54:28 -0700 Subject: [PATCH] Rooms built for Medley 3.5 --- rooms/APPENDIXATEMPLATE.TEDIT | Bin 0 -> 1947 bytes rooms/BACKGROUND-MENU-BUTTONS | 1 + rooms/BACKGROUND-MENU-BUTTONS.DFASL | Bin 0 -> 2356 bytes rooms/BACKGROUND-MENU-BUTTONS.TEDIT | Bin 0 -> 2938 bytes rooms/COVER-LETTER.TEDIT | Bin 0 -> 5025 bytes rooms/EASYTEMPLATE.TEDIT | Bin 0 -> 4174 bytes rooms/LAFITE-WINDOW-TYPES | 192 ++++++++++++ rooms/LAFITE-WINDOW-TYPES.TEDIT | Bin 0 -> 2849 bytes rooms/NEW-LAFITE-WINDOW-TYPES | 24 ++ rooms/NOTECARDS-WINDOW-TYPES | 72 +++++ rooms/OFFICE.SUITE | 25 ++ rooms/OFFICE.TEDIT | Bin 0 -> 2937 bytes rooms/RANDOM-WINDOW-TYPES | 1 + rooms/RANDOM-WINDOW-TYPES.DFASL | Bin 0 -> 10951 bytes rooms/RANDOM-WINDOW-TYPES.LISTING | Bin 0 -> 13449 bytes rooms/RANDOM-WINDOW-TYPES.TEDIT | Bin 0 -> 3304 bytes rooms/RELEASEEASYTEMPLATE.TEDIT | Bin 0 -> 4118 bytes rooms/ROOMS | 1 + rooms/ROOMS-BACKGROUNDS | 1 + rooms/ROOMS-BACKGROUNDS.DFASL | Bin 0 -> 11054 bytes rooms/ROOMS-BIOS | 1 + rooms/ROOMS-BIOS.DFASL | Bin 0 -> 5065 bytes rooms/ROOMS-BUTTONS | 2 + rooms/ROOMS-BUTTONS.DFASL | Bin 0 -> 40411 bytes rooms/ROOMS-CORE | 1 + rooms/ROOMS-CORE.DFASL | Bin 0 -> 23510 bytes rooms/ROOMS-D | 1 + rooms/ROOMS-D.DFASL | Bin 0 -> 15078 bytes rooms/ROOMS-GEOMETRY | 1 + rooms/ROOMS-GEOMETRY.DFASL | Bin 0 -> 7183 bytes rooms/ROOMS-INTERACTIVE | 1 + rooms/ROOMS-INTERACTIVE.DFASL | Bin 0 -> 16068 bytes rooms/ROOMS-INTRO | 426 ++++++++++++++++++++++++++ rooms/ROOMS-MEDLEY-WINDOW-TYPES | 1 + rooms/ROOMS-MEDLEY-WINDOW-TYPES.DFASL | Bin 0 -> 14448 bytes rooms/ROOMS-NOTES | 1 + rooms/ROOMS-NOTES.DFASL | Bin 0 -> 7999 bytes rooms/ROOMS-OVERVIEW | 1 + rooms/ROOMS-OVERVIEW.DFASL | Bin 0 -> 10520 bytes rooms/ROOMS-PLACEMENT-EDITOR | 1 + rooms/ROOMS-PLACEMENT-EDITOR.DFASL | Bin 0 -> 21921 bytes rooms/ROOMS-SUITES | 1 + rooms/ROOMS-SUITES.DFASL | Bin 0 -> 16445 bytes rooms/ROOMS-TEXT | 1 + rooms/ROOMS-TEXT.DFASL | Bin 0 -> 15050 bytes rooms/ROOMS-WINDOW-HIDER | 17 + rooms/ROOMS-WINDOW-HIDER.DFASL | Bin 0 -> 12689 bytes rooms/ROOMS-WINDOW-TYPES | 1 + rooms/ROOMS-WINDOW-TYPES.DFASL | Bin 0 -> 9147 bytes rooms/ROOMS.DFASL | Bin 0 -> 2026 bytes rooms/ROOMSTECHDESC.TEDIT | Bin 0 -> 253072 bytes rooms/ROOMSUSERS-RULES.TEDIT | Bin 0 -> 6207 bytes rooms/RoomsUsers-Rules.IP | Bin 0 -> 6319 bytes rooms/SCREENPAPER | 168 ++++++++++ rooms/SCREENPAPER.LCOM | Bin 0 -> 5795 bytes rooms/TABLE-OF-CONTENTS.TEDIT | Bin 0 -> 2492 bytes rooms/TITLEPAGE.TEDIT | Bin 0 -> 5962 bytes rooms/TOUCHY-BUTTONS | 1 + rooms/TOUCHY-BUTTONS.DFASL | Bin 0 -> 4569 bytes rooms/TOUCHY-BUTTONS.TEDIT | Bin 0 -> 4074 bytes rooms/UN-HIDE-TTY | 1 + rooms/UN-HIDE-TTY.DFASL | Bin 0 -> 1685 bytes rooms/UN-HIDE-TTY.TEDIT | Bin 0 -> 4053 bytes rooms/USERINTRO.TEDIT | Bin 0 -> 3356 bytes rooms/WALLPAPER | 1 + rooms/WALLPAPER.DFASL | Bin 0 -> 3013 bytes rooms/WALLPAPER.TEDIT | Bin 0 -> 3720 bytes 67 files changed, 945 insertions(+) create mode 100644 rooms/APPENDIXATEMPLATE.TEDIT create mode 100644 rooms/BACKGROUND-MENU-BUTTONS create mode 100644 rooms/BACKGROUND-MENU-BUTTONS.DFASL create mode 100644 rooms/BACKGROUND-MENU-BUTTONS.TEDIT create mode 100644 rooms/COVER-LETTER.TEDIT create mode 100644 rooms/EASYTEMPLATE.TEDIT create mode 100644 rooms/LAFITE-WINDOW-TYPES create mode 100644 rooms/LAFITE-WINDOW-TYPES.TEDIT create mode 100644 rooms/NEW-LAFITE-WINDOW-TYPES create mode 100644 rooms/NOTECARDS-WINDOW-TYPES create mode 100644 rooms/OFFICE.SUITE create mode 100644 rooms/OFFICE.TEDIT create mode 100644 rooms/RANDOM-WINDOW-TYPES create mode 100644 rooms/RANDOM-WINDOW-TYPES.DFASL create mode 100644 rooms/RANDOM-WINDOW-TYPES.LISTING create mode 100644 rooms/RANDOM-WINDOW-TYPES.TEDIT create mode 100644 rooms/RELEASEEASYTEMPLATE.TEDIT create mode 100644 rooms/ROOMS create mode 100644 rooms/ROOMS-BACKGROUNDS create mode 100644 rooms/ROOMS-BACKGROUNDS.DFASL create mode 100644 rooms/ROOMS-BIOS create mode 100644 rooms/ROOMS-BIOS.DFASL create mode 100644 rooms/ROOMS-BUTTONS create mode 100644 rooms/ROOMS-BUTTONS.DFASL create mode 100644 rooms/ROOMS-CORE create mode 100644 rooms/ROOMS-CORE.DFASL create mode 100644 rooms/ROOMS-D create mode 100644 rooms/ROOMS-D.DFASL create mode 100644 rooms/ROOMS-GEOMETRY create mode 100644 rooms/ROOMS-GEOMETRY.DFASL create mode 100644 rooms/ROOMS-INTERACTIVE create mode 100644 rooms/ROOMS-INTERACTIVE.DFASL create mode 100644 rooms/ROOMS-INTRO create mode 100644 rooms/ROOMS-MEDLEY-WINDOW-TYPES create mode 100644 rooms/ROOMS-MEDLEY-WINDOW-TYPES.DFASL create mode 100644 rooms/ROOMS-NOTES create mode 100644 rooms/ROOMS-NOTES.DFASL create mode 100644 rooms/ROOMS-OVERVIEW create mode 100644 rooms/ROOMS-OVERVIEW.DFASL create mode 100644 rooms/ROOMS-PLACEMENT-EDITOR create mode 100644 rooms/ROOMS-PLACEMENT-EDITOR.DFASL create mode 100644 rooms/ROOMS-SUITES create mode 100644 rooms/ROOMS-SUITES.DFASL create mode 100644 rooms/ROOMS-TEXT create mode 100644 rooms/ROOMS-TEXT.DFASL create mode 100644 rooms/ROOMS-WINDOW-HIDER create mode 100644 rooms/ROOMS-WINDOW-HIDER.DFASL create mode 100644 rooms/ROOMS-WINDOW-TYPES create mode 100644 rooms/ROOMS-WINDOW-TYPES.DFASL create mode 100644 rooms/ROOMS.DFASL create mode 100644 rooms/ROOMSTECHDESC.TEDIT create mode 100644 rooms/ROOMSUSERS-RULES.TEDIT create mode 100644 rooms/RoomsUsers-Rules.IP create mode 100644 rooms/SCREENPAPER create mode 100644 rooms/SCREENPAPER.LCOM create mode 100644 rooms/TABLE-OF-CONTENTS.TEDIT create mode 100644 rooms/TITLEPAGE.TEDIT create mode 100644 rooms/TOUCHY-BUTTONS create mode 100644 rooms/TOUCHY-BUTTONS.DFASL create mode 100644 rooms/TOUCHY-BUTTONS.TEDIT create mode 100644 rooms/UN-HIDE-TTY create mode 100644 rooms/UN-HIDE-TTY.DFASL create mode 100644 rooms/UN-HIDE-TTY.TEDIT create mode 100644 rooms/USERINTRO.TEDIT create mode 100644 rooms/WALLPAPER create mode 100644 rooms/WALLPAPER.DFASL create mode 100644 rooms/WALLPAPER.TEDIT diff --git a/rooms/APPENDIXATEMPLATE.TEDIT b/rooms/APPENDIXATEMPLATE.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..1e04dca4d9598697962cd73d2ff55bcca10f1896 GIT binary patch literal 1947 zcmeHH&2HN;43?9uz?Sv4!;VCDn0?6LcxjT}rrNYERF*tRZj#;m0z*%Gv^_x|tCar| z3_b0zT_OV($&VjNlQ50em4(Klv7g`ax<-|W18`V^;VRSBaxduGFWs?53sP7oRB@eL z4~O|P4Lty1Sn~ow2?-?C6jJ;^kdIGKk3S*TQfQ%a4IwxDPNcB#Sr)KZL|`2^KCtJ1 zf>i`z3^8n032bi@(!!QKL^fP%eQzQB-tY`kR1OVh5u_zIJz^W5J~g6t6iBECVa1(9 z(0L9PC8n;XVqB}&MmsWK)}g-URSY?=ggio}Gc*eH0~#q*AHW%LkGkpTjUtZ`!$ZxL z6-r6wu%(xRXEvv6Hkq~d(<^W%nWWNd|CiJk5>&s|MnUc_co`(jP k31RcnG!nlQ=yDaDr9P$UBMihbarunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>BACKGROUND-MENU-BUTTONS.;2| 4018 IL:|previous| IL:|date:| "17-Aug-90 14:42:07" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>BACKGROUND-MENU-BUTTONS.;1| ) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:BACKGROUND-MENU-BUTTONSCOMS) (IL:RPAQQ IL:BACKGROUND-MENU-BUTTONSCOMS ((IL:FILES (IL:SYSLOAD) IL:ROOMS) (FILE-ENVIRONMENTS IL:BACKGROUND-MENU-BUTTONS) (IL:FUNCTIONS MAKE-BACKGROUND-MENU-BUTTON BACKGROUND-ITEM) (IL:P (EVAL-WHEN (LOAD) (ROOMS:MAKE-BUTTON-WINDOW (ROOMS:MAKE-BUTTON :TEXT "Make Background Button" :ACTION '(MAKE-BACKGROUND-MENU-BUTTON) :HELP "make a button which does the same thing as an entry on the background menu" )))))) (IL:FILESLOAD (IL:SYSLOAD) IL:ROOMS) (DEFINE-FILE-ENVIRONMENT IL:BACKGROUND-MENU-BUTTONS :PACKAGE "XCL-USER" :READTABLE "XCL" :COMPILER :COMPILE-FILE) (DEFUN MAKE-BACKGROUND-MENU-BUTTON () (LET ((ITEM (BACKGROUND-ITEM))) (WHEN ITEM (ROOMS:MAKE-BUTTON-WINDOW (ROOMS:MAKE-BUTTON :TEXT (PRINC-TO-STRING (FIRST ITEM)) :HELP (THIRD ITEM) :ACTION `(IL:EVAL ,(SECOND ITEM))))))) (DEFUN BACKGROUND-ITEM () (IL:* IL:|;;| "return a menu item from the background menu") (IL:* IL:|;;| "labels of sub-items are coerced to show where they came from") (DECLARE (GLOBAL IL:|BackgroundMenuCommands|)) (LET ((ITEM (IL:MENU (IL:CREATE IL:MENU IL:ITEMS IL:_ IL:|BackgroundMenuCommands| IL:CENTERFLG IL:_ T IL:WHENSELECTEDFN IL:_ #'VALUES)))) (WHEN ITEM (LABELS ((ITEM-PATH (ITEMS) (IL:* IL:|;;|  "construct a list of the names of the items in ITEMS on the path to ITEM") (DOLIST (I ITEMS) (WHEN (EQ I ITEM) (RETURN (LIST (FIRST I)))) (LET ((FOUND (ITEM-PATH (CDR (FOURTH I))))) (WHEN FOUND (RETURN (CONS (FIRST I) FOUND))))))) (LET ((PATH (ITEM-PATH IL:|BackgroundMenuCommands|))) (IF (REST PATH) (IL:* IL:|;;| "it's a subitem - coerce the label") (LIST* (LET ((*PRINT-CASE* :UPCASE)) (FORMAT NIL "~A~{ > ~A~}" (FIRST PATH) (REST PATH))) (REST ITEM)) (IL:* IL:|;;| "it's a top-level item - just return it") ITEM)))))) (EVAL-WHEN (LOAD) (ROOMS:MAKE-BUTTON-WINDOW (ROOMS:MAKE-BUTTON :TEXT "Make Background Button" :ACTION '(MAKE-BACKGROUND-MENU-BUTTON) :HELP "make a button which does the same thing as an entry on the background menu" ))) (IL:PUTPROPS IL:BACKGROUND-MENU-BUTTONS IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020) ) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1386 1817 (MAKE-BACKGROUND-MENU-BUTTON 1386 . 1817)) (1819 3506 (BACKGROUND-ITEM 1819 . 3506))))) IL:STOP \ No newline at end of file diff --git a/rooms/BACKGROUND-MENU-BUTTONS.DFASL b/rooms/BACKGROUND-MENU-BUTTONS.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..5069d18cf877bc54ae9f07a520c0b7a6d23ee82f GIT binary patch literal 2356 zcmcIm-EJFI5Z+xoc8pWHX^l%=Xb)-=iL{$04vA2yEH>VCy!Lu`*`L&*T(C{Hb=ugD z{6nd#mckvVdl7Ltg5*{0?S&@IXg3FzL{_4 z_yIRsFY2V&Zf>q`1Rc`u_cr@Ia<$zd-FCmT8j!27Pi`wt_0C1F8+5t_zteBs3^rC9 z1*f{A*xIsMP|TuNQw`TCc!pLl=$c~{bVV)Lrde|eHC55o6=`n1uqYR+OSb75iUjJO zwCK66X*km#%AZzZa|#$M5w!YyPcsWS%I&YS6p_5$0#|Gv~m^NBi?%AefW<5dTy#Ga zryN%{6xmiJ&9FRoDhkC}(ra%@8^LG62IjCSfQ#sxaJ1wZMOQP8Xp6rmybTUTMJ;KD zDxqI6FPS2EjGLBf2x%}#n4SwR6CkD(%~qMQ@Mg3X#~p}6apgr_jlvjI54MsPWL92+ z4J@bRIjYS^VdA#Y-`Kdr0aWhXK1zm;LET~EF$6jgpJR@~@wu0fbWw@M7=TFtkiy6v z-INs(R!IofvP~;?0v0C@D030Wkk~U-Ae9cL_Sga1v3H^^0gglO&I&sT#1TfREGA+r zhHDlEsL^BeI2t?*$5~EQV_CCJgRwGt0D$VMZPq1-p=KHqGL(WBbdlOCjswOgYI0ST zUL6v;d68bwJv^kQxoVA`!2lkIyoHYMhbeVg)}>2j70Zt0#cT~?JTf?j(O{bvFvLHUCCH7X8&5*E;QfYmF@Sd%boG6cX}tjtOws$VZ;( zs+gDwv@NT;6@`^1+WO=QGa)w{>#Gg2)(*O)*9b`0Zw4T&x2_StOZ*lITD{IK(r&T0 zSN2bA2CaS?F+CEZFhk}gXif?H@2;H<`q^E^<+rAMUy#h7e7^ zFjUOp*)&A^33^ndM@ILrCH>72CMfn5qX;BA#ZV-8Z<6V z4-ty{9xC;OyEuv`)}PL?$jdzI$bl>f{64U3SUTl-n7WM12;GP||% z-x+S_=>qe9gAJpyv|SON66SlHk2lz6g|7%>7|N0I@0^em;VA-KAr9cirVyPg6=g@A zqLU+_HAp}VaXbW#M9H*kvg;#aEbY6P5@)5hXzJ2l?sOANFxd&{R{qR|1TYI2=*%0}U0rg*xDo}Q@A^;bJ zy@Xwc&1z26gl9kf0VGf1ERrnQEyp>I2S~}HZaSWg!vMeG2r4*$m!tkk>f`OO!1B#< z{VHjQW-s3p`GfC?*bG1#eSR}I6Lgx;^D*FBn&x>r6F&=65@s-_&9qi*ZK>==TO(0; zd>N7*kV#SxI_=NluSsXK-SK_%rvPPBoDY%*26Hmiw-`yZaB4 CdaIBC literal 0 HcmV?d00001 diff --git a/rooms/BACKGROUND-MENU-BUTTONS.TEDIT b/rooms/BACKGROUND-MENU-BUTTONS.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..c71d33763c9848920ba84a28a63df9752b8e747f GIT binary patch literal 2938 zcmeHHOK;mo5MIf4iq_?!Ko9M0;2uH(jv%SBEay~;TuF@iP?yWZZcnttT8t^N-~+XD z&m})8zaT#=vrEcSlPD>A$jOAXkC|^~zxnpTJkRkV@G0{je>>ET^D*-R*L>noH+V7( zIQLv%=_*Q3Q96pU3xF;J4DX%-m}z+pMp+c`>KfE~(3yQ}`mzVV=&) zWwa_F3G)J?d0a$uNLTPIT$N#V2i?Ijbj}8YmSVY_d1hd6%X4>8fMs|SXOilMI=yI(K4NvNd!1b(r}K|g!N)r;#HI+XgP9_CJZLq-XO#qE&3u+c(W(Wo$zL&-&@9Sxxq#qPmy)FEO%5+hR5OWjl}|7iu~`^nC?@u! zB$~->3RkjXlr2k_buBV)oFsre!Xnz#vepgdkv#8}6T(RygnD-^g@|uYwJo26s!sJW z1=q3xM^ij))*lq?s3>q}MxJeXmOJu5)tNrD3^+Q%p9VhH8MoZAi2VglG*H{nhJL3D zr)OQ9sWNh%mFc$Uo%^8v9_S_*)a8^>Qv+k7v)bbaVrhd}Q;vx&_qpX;Lz{v(8i7x3 zYVau%;c`A@9!CQ;E3e?&X~Rf&Ec+51&!o%+?>S|*<<Gx;WBMHRj+6{8%;=rgPeZ zU;B842H0s8UY$_gL@_J5>IuITBm&n(hcIF6pa-YD9-MTyV>!LxGEnXyLeBcoJLyBe z-LBGW82LZ87^5Dx^kGXMZt2&$rJ5$6xk;3om8 zHmZU&(RVmuflXUu%13TvYnjc`b%u4I$nWFT)8clpL^ti@Y5+H3UrL2Ue3k9mslD6x=ryV+%c9M3c&L3b6 zDQxx&_!WHg**Bj`eDDjHeJU-x#!$-P8k63 zFGAj*A%t|ucO+y#PpgkvxhrhjeNQGN8lYT&@B(8?bn_9q`3T*7gfJ%NHYVmard)s+ zxQh_(HX`meqMR$S4?=uk2i$CSxA7vmv5bCxu>H|&JK$yq+yY+zHk|qs7zD@)P%l8l zPlEti0qO;a_-POzD?q&fd6ULVjBd{2B}O-AU_oc zQ}NWVd9kLB57TJsIQ6_a;N$`SJu(_rP9rx?BR5VXH%4POMq@Wd{eY#vkk6Go&ho{T zLYKnj3BDbE7}%G>lkhnHsx{PufIDv{}Aa%mZ=q5^rvP!(B)iYiKx>0Q-S z3{h6#6PX^(!MfOz4^&N&MOaBE(u3oDt-d?uAhM5f0UcOafkBxWI-O3!D~ z=@rzeiXkf$4{X7`h3bN5kxFIfmljh?5qDMD3zOoXod!PJWFMcJP39oElFf3H4Jv9- zDVKMva8IY&ok%2a7-GFiC6IM6niM3pZnjw@c00h7`EEs3+d6moK!>&}nJua>L?R{C zpr{uO+|vzE516q|JqwVPddrk3=&GsJDb!VoE&$Y;rVjg5mnF(RWu*b8P7ll$+Oq@N zI&B?NeQx5gj;0=>3p7+!0(vaAJD3EEiHe3Mw%eF;ot?z?_#H9BapI$-M2#{lZN83G z)#QECz}xHUfpLVIIS>^IL>+Xq-UMc0XP9n7brvv~IwcCe>L7unM}_Xt=vwg=a`sT(Rb8>-GYMEF}V9N#HcYY>m`<+ln@D((PEdxc81_(cJBs9~VP zW_hPrE|xaS5YJcgcZ=(A`!@c}&O$r^3CJWP3dF4Z6j@vZ#&b{>-WHgZLr zD4e&-Zn2c#fh=D7)sg%7$X7;tOqe391h<$NCS>|C;?29e<+~p(Y!zyorA4OTMRF=N z#jMDiY?lelpMAc~ME}OSlN+y3ZoD(OaeH!uNAwPzLM`850t@@kZm>{zOQ$;1EFur? rkNY<_-njPA)oU%jxz^&_Yb}1f*5dKC7Q7VCRuAv`k)O%OUw!{O#VIF6 literal 0 HcmV?d00001 diff --git a/rooms/EASYTEMPLATE.TEDIT b/rooms/EASYTEMPLATE.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..ec4ca7e30dfd80da568d0fdaf7a9a9d1dec1a18b GIT binary patch literal 4174 zcmeHK-)_@p6#rTZgLRfRY1*{ABPOlMltpbs@uf^Vv=VtPJgfD=gyJ=bYd9^E>B!DX!ym`!whqZh!68-d@*f z4=jUhy=(05YMYw2rD+?Q21PQQMv`oQETMo1iv8JrqP@N2WSW)=s+F&?%*h`PQ<-JE zyLD}l$?QH%o%~FuG*-Scie&)3pUx;xD4oWXpM@DEF-O?j^JWuCrtKN7ty=_~q;Lci zNuv;%z;cwNWX8EnV?QEB+=GA6xYnMOl8k(A0w1-BrD7&)Jleuj2HfR0y*+GbFOZhO;Hw@ z8HFh-I1SIGsy;>wIJQrt(r<(1F%4xFq#+Uxa}+X7CkZIwAkq)c7{PKsJyo=1O`?a4 zVnW|`spy@@jT^wSC_`J5(TJk(87C8F_qCeY)enr0-EX-Dh$U*9eN=zku}Nw6okw`= z4LsZr48FIV9<=pak1JlDpkwH2Sxu1*f`u_{tp6}cLNqazr_;z!31f(MgS#lAz@Kmx zdQ}l>L+uNoF!!S{pg9P-3fG`<_yR2r{7g0oa}*`dWm>%X8IyuuPbLx}fntubS(eLj z^Rj_}B+m*as?^a``67^$90;FplAb5&ke)uR+TK`OBN+z~S~FzN*{@U1`Xu#(XEFzV zltf5HWkBcUtSCmB)Qcptr8vo%`@%nW7ynMfqWT3Mtlm?DO6*QGPrt7Y&(XA7iD#{9Rm#zea*C z1Y4*?hH@g~Ay^K%XdCIIBY7kz;6@;Okn=GW#CYYCS9% z*``H!>fxX^e=*3CIa*B}$1)w$?l@G_U47qd(e2y#SEs(GyPjzuF!o#8s#9&9)@gfV zlkVQz#9K`vE3d9@InIMV)qWo6ZE6{O>Kg4jwGMT+)bs}&y5*WZ4~|Ux$n2Z@_^EI@ z9qJpF(eipo#8dA**YO}Q+J%<$-B_oN-Ziab!WoGpotz`XwM@Ho;JM}l!xbxYa9$L-KDvw1Jq7yIb_*Hf`?g;HzHP*A5N64KfS5$`|jLlNi`G6f6REXN&G`ZPA_0MXYB$ z@)S^Y5GMDwY3t55ZLhBv?(0DQj}`;R7%mZir2OT6!fu;je2e zxGlX}QrfF-6=D?zEANG9uq(v)f)UHt`0dK8Azq4?OFPKy{cYLV$})0)$92d$sgt2_(E>cT--Sif~&5jVw`;zn`&i_hlzuf$FK+H_6)l`lS>OTQMk4h`$b@XVIJ zAii`^nl6h4r@XV`VViNa(Vy46D$|7mKf zziyZQHJ#E!1?2A!3*6qe1q$Tk2gG%9PWm6^h6ALh(>ds!e{J2<;`KAD)xU4L`xl%({YHn8=fD12N c%WDARELEASE>rooms>current>users-src>LAFITE-WINDOW-TYPES.;3| 8873 + + IL:|changes| IL:|to:| (IL:VARS IL:LAFITE-WINDOW-TYPESCOMS) + + IL:|previous| IL:|date:| "27-Jul-90 06:11:06" +IL:|{DSK}RELEASE>rooms>current>users-src>LAFITE-WINDOW-TYPES.;2|) + + +; Copyright (c) 1988, 1989, 1990 by Venue & Xerox Corporation. All rights reserved. + +(IL:PRETTYCOMPRINT IL:LAFITE-WINDOW-TYPESCOMS) + +(IL:RPAQQ IL:LAFITE-WINDOW-TYPESCOMS + ( + (IL:* IL:|;;| "window types for Lafite") + + (FILE-ENVIRONMENTS IL:LAFITE-WINDOW-TYPES) + (IL:P (REQUIRE "ROOMS")) + (EVAL-WHEN (COMPILE EVAL) + (IL:FILES (IL:LOADCOMP T) + IL:LAFITEDECLS)) + (IL:WINDOW-TYPES :LAFITE-STATUS-WINDOW :LAFITE-BROWSER) + (IL:FUNCTIONS ABSTRACT-LAFITE-BROWSER RECONSTITUTE-LAFITE-BROWSER) + + (IL:* IL:|;;| "keep il:shapew from hanging") + + (IL:P (IL:CHANGENAME 'IL:LAB.RESHAPEFN 'IL:OBTAIN.MONITORLOCK 'TRUE) + (IL:CHANGENAME 'IL:LAB.REPAINTFN 'IL:OBTAIN.MONITORLOCK 'TRUE)) + (IL:GLOBALVARS IL:LAFITESTATUSWINDOW IL:DEFAULTMAILFOLDERNAME IL:\\LAFITE.ACTIVE + IL:LAFITEBROWSERREGION))) + + + +(IL:* IL:|;;| "window types for Lafite") + + +(DEFINE-FILE-ENVIRONMENT IL:LAFITE-WINDOW-TYPES :COMPILER :COMPILE-FILE + :READTABLE "XCL" + :PACKAGE "ROOMS") + +(REQUIRE "ROOMS") +(EVAL-WHEN (COMPILE EVAL) + +(IL:FILESLOAD (IL:LOADCOMP T) + IL:LAFITEDECLS) +) + +(DEF-WINDOW-TYPE :LAFITE-STATUS-WINDOW :RECOGNIZER (LAMBDA (WINDOW) + (EQ WINDOW IL:LAFITESTATUSWINDOW)) + :ABSTRACTER (LAMBDA (WINDOW) + NIL) + :RECONSTITUTER (LAMBDA (IGNORE) + (WHEN (FBOUNDP 'IL:LAFITE) + (OR IL:LAFITESTATUSWINDOW (PROGN (IL:LAFITE 'IL:ON NIL) + (IL:BLOCK) + IL:LAFITESTATUSWINDOW)))) + :UPDATER (LAMBDA (PLACEMENT) + (IF IL:\\LAFITE.OUTBOX + + (IL:* IL:|;;| "note the height of the outbox") + + (PLACEMENT-PROP PLACEMENT :OUTBOX-HEIGHT (REGION-HEIGHT (IL:WINDOWPROP + (FIRST + IL:\\LAFITE.OUTBOX + ) + 'IL:REGION))) + (REMF (PLACEMENT-PROPS PLACEMENT) + :OUTBOX-HEIGHT))) + :PLACER (LAMBDA (PLACEMENT) + + (IL:* IL:|;;| "adjust placement as outbox might have appeared or been removed since we were last here & we don't want status window creeping around.") + + (IL:RELMOVEW (PLACEMENT-WINDOW PLACEMENT) + (MAKE-POSITION 0 (- (GETF (PLACEMENT-PROPS PLACEMENT) + :OUTBOX-HEIGHT 0) + (IF IL:\\LAFITE.OUTBOX + (REGION-HEIGHT (IL:WINDOWPROP (FIRST + IL:\\LAFITE.OUTBOX + ) + 'IL:REGION)) + 0))))) + :TITLE (LAMBDA (PLACEMENT REGION DSP) + (PRINT-PEP-TITLE-STRING "Lafite" REGION DSP :NO-TITLE-BAR? T)) + :FILES + +(IL:* IL:|;;;| "we don't load Lafite on demand.") + + (IL:LAFITE-WINDOW-TYPES)) + +(DEF-WINDOW-TYPE :LAFITE-BROWSER :RECOGNIZER (LAMBDA (WINDOW) + (TYPEP (IL:WINDOWPROP WINDOW 'IL:MAILFOLDER) + 'IL:MAILFOLDER)) + :ABSTRACTER ABSTRACT-LAFITE-BROWSER + :RECONSTITUTER RECONSTITUTE-LAFITE-BROWSER + :TITLE (LAMBDA (PLACEMENT REGION DSP) + (LET* ((FOLDER (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) + 'IL:MAILFOLDER))) + (PRINT-PEP-TITLE-STRING (IF FOLDER + (IL:|fetch| (IL:MAILFOLDER IL:SHORTFOLDERNAME) + IL:|of| FOLDER) + "Lafite Browser") + REGION DSP :NO-TITLE-BAR? (PLACEMENT-SHRUNKEN? PLACEMENT)))) + :FILES + +(IL:* IL:|;;;| "we don't load Lafite on demand") + + (IL:LAFITE-WINDOW-TYPES)) + +(DEFUN ABSTRACT-LAFITE-BROWSER (WINDOW) + (LET ((FOLDER (IL:WINDOWPROP WINDOW 'IL:MAILFOLDER)) + (MOVE-TO-WINDOW (IL:WINDOWPROP WINDOW 'IL:LAFITE.AUTO.MOVE.MENU))) + (LIST :FOLDER-NAME (IL:|fetch| (IL:MAILFOLDER IL:SHORTFOLDERNAME) IL:|of| FOLDER) + :LAYOUT + (LET ((FOLDER-REGION (WINDOW-REGION WINDOW)) + (ICON-POSITION (ICON-POSITION WINDOW)) + (DISPLAY-REGION (IL:|fetch| (IL:MAILFOLDER IL:FOLDERDISPLAYREGION) + IL:|of| FOLDER))) + (WHEN MOVE-TO-WINDOW + + (IL:* IL:|;;| "knock off portion of FOLDER-REGION which includes MoveTo menu window so tht FOLDER-REGION is right for passing to LAFITE.BROWSE.FOLDER (which won't create the MoveTo menu for us).") + + (DECF (REGION-WIDTH FOLDER-REGION) + (REGION-WIDTH (IL:WINDOWPROP MOVE-TO-WINDOW 'IL:REGION)))) + (LIST (EXTERNALIZE-REGION FOLDER-REGION) + (WHEN ICON-POSITION (EXTERNALIZE-POSITION ICON-POSITION)) + (WHEN DISPLAY-REGION (EXTERNALIZE-REGION DISPLAY-REGION)))) + :OPTIONS + (WHEN (IL:|fetch| (IL:MAILFOLDER IL:FOLDERGETSMAIL) IL:|of| FOLDER) + (LIST :ACTIVE)) + :MOVE-TO-FOLDERS + (WHEN MOVE-TO-WINDOW + (MAPCAR #'IL:LA.SHORTFILENAME (IL:WINDOWPROP WINDOW 'IL:LAFITE.AUTO.MOVE.NAMES)))))) + +(DEFUN RECONSTITUTE-LAFITE-BROWSER (PLIST) + + (IL:* IL:|;;| "pass if lafite is not loaded") + + (WHEN (FBOUNDP 'IL:LAFITE) + + (IL:* IL:|;;| "first make sure lafite is turned on") + + (UNLESS (EQ IL:\\LAFITE.ACTIVE T) + (IL:LAFITE 'IL:ON NIL) + (LOOP (IL:BLOCK) + (WHEN (EQ IL:\\LAFITE.ACTIVE T) + (RETURN))) + + (IL:* IL:|;;| "don't want to add windows to current room") + + (HIDE-WINDOW IL:LAFITESTATUSWINDOW)) + (LET* ((EXTERNALIZED-REGION (GETF PLIST :REGION)) + (EXTERNALIZED-LAYOUT (GETF PLIST :LAYOUT (LIST IL:LAFITEBROWSERREGION))) + (LAYOUT (IF EXTERNALIZED-REGION + + (IL:* IL:|;;| "for back compatability") + + (LIST (INTERNALIZE-REGION EXTERNALIZED-REGION)) + (LIST (INTERNALIZE-REGION (FIRST EXTERNALIZED-LAYOUT)) + (WHEN (SECOND EXTERNALIZED-LAYOUT) + (INTERNALIZE-POSITION (SECOND EXTERNALIZED-LAYOUT))) + (WHEN (THIRD EXTERNALIZED-LAYOUT) + (INTERNALIZE-REGION (THIRD EXTERNALIZED-LAYOUT)))))) + (FOLDER (IL:LAFITE.BROWSE.FOLDER (GETF PLIST :FOLDER-NAME IL:DEFAULTMAILFOLDERNAME) + LAYOUT + (GETF PLIST :OPTIONS))) + (MOVE-TO-FOLDERS (GETF PLIST :MOVE-TO-FOLDERS))) + (WHEN FOLDER + (WHEN MOVE-TO-FOLDERS + (IL:WINDOWPROP (IL:FETCH (IL:MAILFOLDER IL:BROWSERWINDOW) IL:OF FOLDER) + 'IL:LAFITE.AUTO.MOVE.NAMES MOVE-TO-FOLDERS) + (IL:\\LAFITE.UPDATE.MOVE.MENU FOLDER T)) + (IL:FETCH (IL:MAILFOLDER IL:BROWSERWINDOW) IL:OF FOLDER))))) + + + +(IL:* IL:|;;| "keep il:shapew from hanging") + + +(IL:CHANGENAME 'IL:LAB.RESHAPEFN 'IL:OBTAIN.MONITORLOCK 'TRUE) + +(IL:CHANGENAME 'IL:LAB.REPAINTFN 'IL:OBTAIN.MONITORLOCK 'TRUE) +(IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY + +(IL:GLOBALVARS IL:LAFITESTATUSWINDOW IL:DEFAULTMAILFOLDERNAME IL:\\LAFITE.ACTIVE + IL:LAFITEBROWSERREGION) +) +(IL:PUTPROPS IL:LAFITE-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1989 1990)) +(IL:DECLARE\: IL:DONTCOPY + (IL:FILEMAP (NIL))) +IL:STOP diff --git a/rooms/LAFITE-WINDOW-TYPES.TEDIT b/rooms/LAFITE-WINDOW-TYPES.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..17d9f2aea783defec5f83b25907322bb67e67fb3 GIT binary patch literal 2849 zcmeHJ&2rl|5QbzWoz~@{og8}HNiWol&5=|^mUAjCLJ}GZWI-^Ndt)lv=8QyoNGh&- z={?WVC+HL8vAO_BN44X0+Cxsp*!bDqZ};0>0;44r-ttS=o-#=fPZ@W-(?faY)4&)Q z#?UbOhVd~aicxuT^Afo~~e>@&r2IEqAPB@Xw;}v$3t+wkJuJY_{vWg41PSRC& z4du-h9?r8I+~^$r)$+oEMu2h4%NST%#`!uat_~g8M9Erty2zuAGR&ftqFySFb(}bj z-mKB{O}2$HgCcqxHx8@F1th7`=1^=^-17v@ErTw7*XFk39T=y#d>^FyCeN;mI4>Yd zS2_*FwN9ldqjKA1Y8gB$LUFkqNddFvkaofp6Rkcf@%8pi~?sa;LfKaV82js;}UBOQ_p1{<5Lez zTi7RT0?(i0Ul#&t3(5FQVZVod7t9{?VALPL(eVIJrbaeih3$IYs{qWOL)(D~<&p~O zbYU{LMXd=!6?!6=FVPX>uUWuOTngTF3ITQLMEXcX>a#CAi2~|WTE(~DgQ>k>?inmR zhYAkfYbspEYX?%WSJVqDc*xP>R)<}-d4N3zL1&?B3kY1#r?;n5%4Ty33+k|Np@>n@ zL=FQgba7Pi0(pjXao5GFi3NT(_sfQb=^qW@hY?x?$?*t=FGeux^(yyWME;K!BkHlGk1c(?rJw7TcDwpn zenOs*f!ej+lP}b=*TJdvzNNJfO$SPWh;MM|wD%q|)A9rIj=XD)$sWKo$ W|8m*I^1Bv)+!fT&wn@z2|N0w6YE#Sr literal 0 HcmV?d00001 diff --git a/rooms/NEW-LAFITE-WINDOW-TYPES b/rooms/NEW-LAFITE-WINDOW-TYPES new file mode 100644 index 00000000..bb2ee2e2 --- /dev/null +++ b/rooms/NEW-LAFITE-WINDOW-TYPES @@ -0,0 +1,24 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") +(IL:FILECREATED "17-Aug-90 14:44:10"  +IL:|{DSK}RELEASE>rooms>current>users-src>NEW-LAFITE-WINDOW-TYPES.;3| 911 + + IL:|changes| IL:|to:| (IL:FILES IL:LAFITE-WINDOW-TYPES) + (IL:VARS IL:NEW-LAFITE-WINDOW-TYPESCOMS) + + IL:|previous| IL:|date:| "27-Jul-90 06:12:07" +IL:|{DSK}RELEASE>rooms>current>users-src>NEW-LAFITE-WINDOW-TYPES.;2|) + + +; Copyright (c) 1988, 1990 by Venue & Xerox Corporation. All rights reserved. + +(IL:PRETTYCOMPRINT IL:NEW-LAFITE-WINDOW-TYPESCOMS) + +(IL:RPAQQ IL:NEW-LAFITE-WINDOW-TYPESCOMS ((IL:FILES (IL:SYSLOAD) + IL:LAFITE-WINDOW-TYPES))) + +(IL:FILESLOAD (IL:SYSLOAD) + IL:LAFITE-WINDOW-TYPES) +(IL:PUTPROPS IL:NEW-LAFITE-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990)) +(IL:DECLARE\: IL:DONTCOPY + (IL:FILEMAP (NIL))) +IL:STOP diff --git a/rooms/NOTECARDS-WINDOW-TYPES b/rooms/NOTECARDS-WINDOW-TYPES new file mode 100644 index 00000000..7caa09f4 --- /dev/null +++ b/rooms/NOTECARDS-WINDOW-TYPES @@ -0,0 +1,72 @@ +(DEFINE-FILE-INFO PACKAGE "XCL-USER" READTABLE "XCL" BASE 10) +(IL:FILECREATED "17-Aug-90 14:44:29"  +IL:|{DSK}RELEASE>rooms>current>users-src>NOTECARDS-WINDOW-TYPES.;3| 3563 + + IL:|changes| IL:|to:| (IL:VARS IL:NOTECARDS-WINDOW-TYPESCOMS) + + IL:|previous| IL:|date:| "27-Jul-90 06:12:54" +IL:|{DSK}RELEASE>rooms>current>users-src>NOTECARDS-WINDOW-TYPES.;2|) + + +; Copyright (c) 1988, 1990 by Venue & Xerox Corporation. All rights reserved. + +(IL:PRETTYCOMPRINT IL:NOTECARDS-WINDOW-TYPESCOMS) + +(IL:RPAQQ IL:NOTECARDS-WINDOW-TYPESCOMS ((IL:WINDOW-TYPES :NOTECARDS-ICON) + + (IL:* IL:|;;| "") + + (IL:DECLARE\: IL:DONTCOPY (IL:PROPS ( + IL:NOTECARDS-WINDOW-TYPES + + IL:MAKEFILE-ENVIRONMENT + ) + ( + IL:NOTECARDS-WINDOW-TYPES + IL:FILETYPE))))) + +(ROOMS:DEF-WINDOW-TYPE :NOTECARDS-ICON :RECOGNIZER (LAMBDA (ROOMS::WINDOW) + (EQ (IL:WINDOWPROP ROOMS::WINDOW + 'IL:BUTTONEVENTFN) + + 'IL:|NC.NoteCardsIconButtonEventFn| + )) + :ABSTRACTER (LAMBDA (ROOMS::WINDOW) + (DECLARE (IGNORE ROOMS::WINDOW)) + NIL) + :RECONSTITUTER (LAMBDA (ROOMS::DATA) + (DECLARE (IGNORE ROOMS::DATA)) + (WHEN (FBOUNDP 'IL:|NC.BringUpNoteCardsIcon|) + (WHEN (NOT (IL:OPENWP IL:|NC.NoteCardsIconWindow|)) + (IL:|NC.BringUpNoteCardsIcon| (IL:CREATEPOSITION 0 0)) + + (IL:* IL:|;;| + "(il:closew (il:shrinkw il:|NC.NoteCardsIconWindow| nil (il:createposition 0 0)))") + + (IL:* IL:|;;| "So it doesn't come up in the current room.") + + (IL:CLOSEW IL:|NC.NoteCardsIconWindow|)) + + (IL:* IL:|;;| "") + + IL:|NC.NoteCardsIconWindow|)) + :TITLE (LAMBDA (PLACEMENT REGION DSP) + (ROOMS:PRINT-PEP-TITLE-STRING "NoteCards" REGION DSP :NO-TITLE-BAR? T)) + :FILES (IL:NOTECARDS-WINDOW-TYPES)) + + + +(IL:* IL:|;;| "") + +(IL:DECLARE\: IL:DONTCOPY + +(IL:PUTPROPS IL:NOTECARDS-WINDOW-TYPES IL:MAKEFILE-ENVIRONMENT (:PACKAGE "XCL-USER" + :READTABLE "XCL" :BASE + 10)) + +(IL:PUTPROPS IL:NOTECARDS-WINDOW-TYPES IL:FILETYPE :COMPILE-FILE) +) +(IL:PUTPROPS IL:NOTECARDS-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990)) +(IL:DECLARE\: IL:DONTCOPY + (IL:FILEMAP (NIL))) +IL:STOP diff --git a/rooms/OFFICE.SUITE b/rooms/OFFICE.SUITE new file mode 100644 index 00000000..9fb4f995 --- /dev/null +++ b/rooms/OFFICE.SUITE @@ -0,0 +1,25 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE (DEFPACKAGE "ROOMS" (USE "LISP" "XCL") (SHADOW CLROOM)) +) +(il:filecreated " 5-Aug-88 11:01:04" il:|{POGO:AISNORTH:XEROX}MEDLEY>USERS>OFFICE.SUITE;2| 2617 + + il:|changes| il:|to:| (il:suites "OFFICE") + + il:|previous| il:|date:| " 8-Mar-88 16:13:34" +il:|{POGO:AISNORTH:XEROX}MEDLEY>USERS>OFFICE.SUITE;1|) + + +; Copyright (c) 1987, 1988 by Xerox Corporation. All rights reserved. + +(il:prettycomprint il:officecoms) + +(il:rpaqq il:officecoms ((il:files il:rooms) (file-environments il:office.suite) (il:suites "OFFICE"))) + +(il:filesload il:rooms) + +(define-file-environment il:office.suite :package (defpackage "ROOMS" (:use "LISP" "XCL") (:shadow cl:room)) :readtable "XCL" :compiler :compile-file) + +(defsuite "OFFICE" (:version 1) (:files) (:window 0 :type :button :text "Go to Room" :action (interactive-go-to-room :allow-new? t) :help "Go to a room, possibly new.") (:window 1 :type :button :text "Overview" :action (go-to-overview) :help "Enter the overview") (:window 2 :type :prompt-window) (:window 3 :type :button :text-form (symbol-value (quote *back-door-room-name*)) :action (interactive-go-to-room-named *back-door-room-name*) :help "Go to the previous room" :type :door :inverted? t) (:window 4 :type :exec :region (271/512 7/101 119/256 141/808) :package "XCL-USER" :readtable "XCL") (:room "Mail" :placements nil :inclusions ("Office Panel") :background ((:region (0 1/4 1.0 3/4) :shade (:eval squares-bitmap) :border 2) (:text "Mail" :position (10 . 10) :font (il:helvetica 36 il:bold))) :file-watch-on? nil) (:room "Office" :placements nil :inclusions ("Office Panel") :background ((:region (0 1/4 1.0 3/4) :shade (:eval tile-bitmap) :border 2) (:text "Office" :font (il:helvetica 36 il:bold) :position (10 . 10))) :file-watch-on? nil) (:room "Office Panel" :placements ((0 :region (77/1024 137/808 41/512 11/404)) (1 :region (77/1024 167/808 35/512 11/404)) (2 :region (271/512 1/808 239/512 13/202) :font (il:helvetica 10 (il:medium il:regular il:regular)) :border 2 :shade 65535 :title nil :operation il:erase) (3 :region (5/512 95/808 59/1024 99/808)) (4 :region (271/512 7/101 119/256 141/808))) :inclusions nil :background ((:whole-screen 33825 :border 2)) :file-watch-on? nil) (:room "Project" :placements nil :inclusions ("Office Panel") :background ((:region (0 1/4 1.0 3/4) :shade (:eval renaissance-bitmap) :border 2) (:text "Project" :font (il:helvetica 36 il:bold) :position (10 . 10))) :file-watch-on? nil)) +(il:putprops il:office.suite il:copyright ("Xerox Corporation" 1987 1988)) +(il:declare\: il:dontcopy + (il:filemap (nil))) +il:stop diff --git a/rooms/OFFICE.TEDIT b/rooms/OFFICE.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..a244928f09d6b71474a71a2cd05f990462682342 GIT binary patch literal 2937 zcmeHI&u`;I6n4_?A}Br}aYcG62W(VXNyw%tC){L`4C~loY%eW`l}s{CMmTmAI|=2^ zW&b4ZNc(5;X2xl>64_ADZ|L*jHv28{RQNS#pu9rM3Ax(-B z_)L_126+ZQCfPb!-9f8+2F;6Z*D~65&A9e?>!j=@IELgv2AgXo5l_)t|5+!T{;(tkm0Vz`z|-?;6HI zpD-VSSA==guLg)1eMy2?!($&S?sMd7;`$-(b6{i`doF{}3nt{g_cNixQ3PYsr}0<{ zBW%YkPpdLVniodbC>L8cy2i%1Ti&+~jcJ~@;kynVwJv^aU2lzu+eb6CT~#N#mLg)` z$Ak!pHAt=I;FO) zuH|ROGovM2wYSD6@^f^IuiD$1%0BiwlLqV3jFW?FO;^A7K1LV5G@k3r-1z)HzmI*UV|C-8u8Lu1Usqw@ zsgpC`KXv3XG>0@<87(8~XHr|KOX`?A8L`+S&X7a{zji>gr>;iW0i|aj7buyPcD-D6 zLk2!1VQ*2TeFywE?T-S{Z9{G6oeR=b2mh58<*+Q#vMTRoKxGawU&*4wz@HBTuO9}~ T)DK7h`(Z^zTVERA{_)p8f<arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>RANDOM-WINDOW-TYPES.;2| 14251 IL:|previous| IL:|date:| "17-Aug-90 14:45:06" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>RANDOM-WINDOW-TYPES.;1|) ; Copyright (c) 1988, 1989, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:RANDOM-WINDOW-TYPESCOMS) (IL:RPAQQ IL:RANDOM-WINDOW-TYPESCOMS ( (IL:* IL:|;;| "Window types for various LispUsers modules") (FILE-ENVIRONMENTS IL:RANDOM-WINDOW-TYPES) (IL:P (REQUIRE "ROOMS")) (IL:* IL:|;;| "Window type for WHO-LINE") (IL:WINDOW-TYPES :WHO-LINE) (IL:* IL:|;;| "Window types for the CALENDAR program") (IL:WINDOW-TYPES :CALENDAR-YEAR :CALENDAR-MONTH) (IL:* IL:|;;| "Window type for the PRINTERMENU program") (IL:WINDOW-TYPES :PRINTER-MENU-WINDOW) (IL:* IL:|;;| "Window type for some clocks") (IL:WINDOW-TYPES :CROCK-WINDOW :BICLOCK) (IL:* IL:|;;| "Window types for AddressBook and PhoneDirectory") (IL:COMS (IL:WINDOW-TYPES :ADDRESSBOOK :PHONE-DIRECTORY) (IL:FUNCTIONS ADDRESS-BOOK-WINDOW-P PHONE-DIRECTORY-WINDOW-P FIND-WINDOW)) (IL:* IL:|;;| "Window type for GRID-ICONS") (IL:WINDOW-TYPES :GRID-ICON-COMS-EDITOR) (IL:COMS (IL:* IL:|;;| "special handlers for FILEWATCH. these are somewhat broken") (IL:WINDOW-TYPES :FILE-WATCH) (IL:FUNCTIONS FILE-WATCH-EXIT-FUNCTION FILE-WATCH-ENTRY-FUNCTION) (IL:P (PUSHNEW 'FILE-WATCH-EXIT-FUNCTION *ROOM-EXIT-FUNCTIONS*) (PUSHNEW 'FILE-WATCH-ENTRY-FUNCTION *ROOM-ENTRY-FUNCTIONS*))))) (IL:* IL:|;;| "Window types for various LispUsers modules") (DEFINE-FILE-ENVIRONMENT IL:RANDOM-WINDOW-TYPES :COMPILER :COMPILE-FILE :READTABLE "XCL" :PACKAGE "ROOMS") (REQUIRE "ROOMS") (IL:* IL:|;;| "Window type for WHO-LINE") (DEF-WINDOW-TYPE :WHO-LINE :RECOGNIZER (LAMBDA (WINDOW) (DECLARE (GLOBAL IL:*WHO-LINE*)) (EQ WINDOW IL:*WHO-LINE*)) :ABSTRACTER (LAMBDA (WINDOW) NIL) :RECONSTITUTER (LAMBDA (PROPS) (DECLARE (GLOBAL IL:*WHO-LINE*)) (IL:INSTALL-WHO-LINE-OPTIONS) IL:*WHO-LINE*) :NO-SHAPE T (IL:* IL:\; "don't scale placements") :TITLE "" :FILES (IL:WHO-LINE IL:RANDOM-WINDOW-TYPES)) (IL:* IL:|;;| "Window types for the CALENDAR program") (DEF-WINDOW-TYPE :CALENDAR-YEAR :RECOGNIZER (LAMBDA (W) (EQ (IL:WINDOWPROP W 'IL:REPAINTFN) 'IL:REPAINTYEAR)) :ABSTRACTER (LAMBDA (W) (LIST (IL:WINDOWPROP W 'IL:YEAR#))) :RECONSTITUTER (LAMBDA (DATA) (DESTRUCTURING-BIND (YEAR) DATA (FLET ((FIND-CALENDAR-YEAR NIL (FIND-IF #'(LAMBDA (W) (AND (EQ (IL:WINDOWPROP W 'IL:REPAINTFN) 'IL:REPAINTYEAR) (EQL (IL:WINDOWPROP W 'IL:YEAR#) YEAR))) (IL:OPENWINDOWS)))) (OR (FIND-CALENDAR-YEAR) (PROGN (IL:CALENDAR NIL NIL YEAR) (FIND-CALENDAR-YEAR)))))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING (OR (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'IL:YEAR#) "YEAR") REGION DSP :NO-TITLE-BAR? T)) :FILES (IL:CALENDAR IL:RANDOM-WINDOW-TYPES)) (DEF-WINDOW-TYPE :CALENDAR-MONTH :RECOGNIZER (LAMBDA (W) (EQ (IL:WINDOWPROP W 'IL:REPAINTFN) 'IL:REPAINTMONTH)) :ABSTRACTER (LAMBDA (W) (LIST (IL:WINDOWPROP W 'IL:YEAR#) (IL:WINDOWPROP W 'IL:MONTH#))) :RECONSTITUTER (LAMBDA (DATA) (DESTRUCTURING-BIND (YEAR MONTH) DATA (FLET ((FIND-CALENDAR-MONTH NIL (FIND-IF #'(LAMBDA (W) (AND (EQ (IL:WINDOWPROP W 'IL:REPAINTFN) 'IL:REPAINTYEAR) (EQL (IL:WINDOWPROP W 'IL:YEAR#) YEAR) (EQL (IL:WINDOWPROP W 'IL:MONTH#) MONTH))) (IL:OPENWINDOWS)))) (OR (FIND-CALENDAR-MONTH) (PROGN (IL:CALENDAR MONTH NIL YEAR) (FIND-CALENDAR-MONTH)))))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING (LET ((MONTH-NUMBER (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'IL:MONTH#))) (IF MONTH-NUMBER (NTH (1- MONTH-NUMBER) '("Jan" "Feb" "Mar" "Apr" "May" "Jun" "Jul" "Aug" "Sep" "Oct" "Nov" "Dec")) "MONTH")) REGION DSP :NO-TITLE-BAR? T)) :FILES (IL:CALENDAR IL:RANDOM-WINDOW-TYPES)) (IL:* IL:|;;| "Window type for the PRINTERMENU program") (DEF-WINDOW-TYPE :PRINTER-MENU-WINDOW :RECOGNIZER (LAMBDA (W) (AND (BOUNDP 'IL:PRINTERMENU.WINDOW) (EQ W IL:PRINTERMENU.WINDOW))) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA)) (UNLESS (AND (BOUNDP 'IL:PRINTERMENU.WINDOW) IL:PRINTERMENU.WINDOW) (IL:PRINTERMENU)) IL:PRINTERMENU.WINDOW) :ABSTRACTER (LAMBDA (W) (DECLARE (IGNORE W)) NIL) :TITLE "PrinterMenu" :FILES (IL:PRINTERMENU IL:RANDOM-WINDOW-TYPES)) (IL:* IL:|;;| "Window type for some clocks") (DEF-WINDOW-TYPE :CROCK-WINDOW :RECOGNIZER (LAMBDA (W) (AND (BOUNDP 'IL:CROCKWINDOW) (EQ W IL:CROCKWINDOW))) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA)) (UNLESS (AND (BOUNDP 'IL:CROCKWINDOW) (IL:WINDOWP IL:CROCKWINDOW)) (IL:CROCK (IL:CREATEREGION 0 0 100 100))) IL:CROCKWINDOW) :ABSTRACTER (LAMBDA (W) (DECLARE (IGNORE W)) NIL) :TITLE "Crock" :FILES (IL:CROCK IL:RANDOM-WINDOW-TYPES)) (DEF-WINDOW-TYPE :BICLOCK :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN) 'IL:BICLOCKRSFN)) :ABSTRACTER (LAMBDA (WINDOW) (DECLARE (IGNORE WINDOW)) NIL) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA) (GLOBAL IL:BICLOCKWINDOW)) (IF (BOUNDP 'IL:BICLOCKWINDOW) IL:BICLOCKWINDOW (IL:BICLOCK))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING "Clock" REGION DSP :NO-TITLE-BAR? T)) :FILES (IL:BICLOCK IL:RANDOM-WINDOW-TYPES)) (IL:* IL:|;;| "Window types for AddressBook and PhoneDirectory") (DEF-WINDOW-TYPE :ADDRESSBOOK :DEPENDENCIES (:TEXTSTREAM) :RECOGNIZER ADDRESS-BOOK-WINDOW-P :ABSTRACTER (LAMBDA (WINDOW) (DECLARE (IGNORE WINDOW)) NIL) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA)) (OR (FIND-WINDOW #'ADDRESS-BOOK-WINDOW-P T) (IL:|MakeAddressBook|))) :TITLE "Address" :FILES (IL:ADDRESSBOOK IL:RANDOM-WINDOW-TYPES)) (DEF-WINDOW-TYPE :PHONE-DIRECTORY :RECOGNIZER PHONE-DIRECTORY-WINDOW-P :ABSTRACTER (LAMBDA (WINDOW) (DECLARE (IGNORE WINDOW)) NIL) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA)) (OR (FIND-WINDOW #'PHONE-DIRECTORY-WINDOW-P T) (IL:|Let-your-fingers-do-the-walking|))) :TITLE "Phone" :FILES (IL:PHONE-DIRECTORY IL:RANDOM-WINDOW-TYPES)) (DEFUN ADDRESS-BOOK-WINDOW-P (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:|ProcessName|) 'IL:|Address Book|)) (DEFUN PHONE-DIRECTORY-WINDOW-P (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) 'IL:|Phone-Window-ButtonEventFn|)) (DEFUN FIND-WINDOW (TEST &OPTIONAL INCLUDE-HIDDEN-P) (DOLIST (WINDOW (ALL-WINDOWS INCLUDE-HIDDEN-P)) (WHEN (FUNCALL TEST WINDOW) (RETURN WINDOW)))) (IL:* IL:|;;| "Window type for GRID-ICONS") (DEF-WINDOW-TYPE :GRID-ICON-COMS-EDITOR :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) ' IL:LOADED-FILES-ICON-WINDOW-BUTTONEVENTFN )) :ABSTRACTER (LAMBDA (WINDOW) (DECLARE (IGNORE WINDOW)) NIL) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA) (GLOBAL IL:LOADED-FILES-ICON-WINDOW)) IL:LOADED-FILES-ICON-WINDOW) :FILES (IL:GRID-ICONS IL:RANDOM-WINDOW-TYPES)) (IL:* IL:|;;| "special handlers for FILEWATCH. these are somewhat broken") (DEF-WINDOW-TYPE :FILE-WATCH :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) 'IL:FW-BUTTONEVENTFN))) (DEFUN FILE-WATCH-EXIT-FUNCTION (ROOM) (DECLARE (GLOBAL IL:|FW-Running?| IL:|FW-Anchor| IL:|FW-Position|)) (WHEN (FBOUNDP 'IL:FILEWATCH) (COND (IL:|FW-Running?| (ROOM-PROP ROOM :FILE-WATCH-ON? T) (ROOM-PROP ROOM :FILE-WATCH-ANCHOR IL:|FW-Anchor|) (ROOM-PROP ROOM :FILE-WATCH-POSITION (EXTERNALIZE-POSITION IL:|FW-Position|)) (LET* ((CHANGED? NIL) (NEW-PLACEMENTS (DELETE-IF #'(LAMBDA (PLACEMENT) (AND (EQ (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'IL:BUTTONEVENTFN) 'IL:FW-BUTTONEVENTFN) (SETQ CHANGED? T))) (ROOM-PLACEMENTS ROOM)))) (WHEN CHANGED? (SETF (ROOM-PLACEMENTS ROOM) NEW-PLACEMENTS) (ROOM-CHANGED ROOM :PLACEMENTS))) (IL:FILEWATCH :OFF) (IL:PROCESS.RESULT (IL:FIND.PROCESS "FileWatcher") T)) (T (ROOM-PROP ROOM :FILE-WATCH-ON? NIL) (REMF (ROOM-PROPS ROOM) :FILE-WATCH-ANCHOR) (REMF (ROOM-PROPS ROOM) :FILE-WATCH-POSITION))))) (DEFUN FILE-WATCH-ENTRY-FUNCTION (ROOM) (DECLARE (GLOBAL IL:|FW-Properties|)) (WHEN (FBOUNDP 'IL:FILEWATCH) (LET ((POS (ROOM-PROP ROOM :FILE-WATCH-POSITION)) (ANCHOR (ROOM-PROP ROOM :FILE-WATCH-ANCHOR))) (WHEN POS (SETF (GETF IL:|FW-Properties| 'IL:POSITION) (INTERNALIZE-POSITION POS))) (WHEN ANCHOR (SETF (GETF IL:|FW-Properties| 'IL:ANCHOR) ANCHOR)) (WHEN (ROOM-PROP ROOM :FILE-WATCH-ON?) (IL:FILEWATCH :ON) (IL:BLOCK))))) (PUSHNEW 'FILE-WATCH-EXIT-FUNCTION *ROOM-EXIT-FUNCTIONS*) (PUSHNEW 'FILE-WATCH-ENTRY-FUNCTION *ROOM-ENTRY-FUNCTIONS*) (IL:PUTPROPS IL:RANDOM-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1989 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (10066 10183 (ADDRESS-BOOK-WINDOW-P 10066 . 10183)) (10185 10319 ( PHONE-DIRECTORY-WINDOW-P 10185 . 10319)) (10321 10495 (FIND-WINDOW 10321 . 10495)) (11809 13397 ( FILE-WATCH-EXIT-FUNCTION 11809 . 13397)) (13399 14002 (FILE-WATCH-ENTRY-FUNCTION 13399 . 14002))))) IL:STOP \ No newline at end of file diff --git a/rooms/RANDOM-WINDOW-TYPES.DFASL b/rooms/RANDOM-WINDOW-TYPES.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..687804dbb86f6c6cb4775cd8b90a6c420e296093 GIT binary patch literal 10951 zcmd5?U2q%Mb>3a@|3`u(Qook9wk#?py|heOwN0fIm%u^*@w2O4KqMWfB}}dbSR}v! zKq(s6Gj7w#^amq{Ru$t~l4Cn*I_Y#8g%7o4Dd9tYCh9}q^3WMipYqVRYTB9fp_97j zoVyDwK#(G%c2bVCxO?~BbI;Fr&b{~CyCQT<2V!y{zqpiLunTg2xwN!glHbS|9sr~%@yo)$)1<3bZNOT zpT6>(d`b@5bN1rvz}?7+krU6!FZ|x<$(Kh@jtuvPR4c|A+*Y?QZdJY|9nA~yccJ>| z#?r1`B2{F#o8^vBDiKIV^hD*F_>OcK2>OFsD3Z_=qzm0cx*sUE=!TY%x}igx zo=O7AHYj!mBc?{3rTvv_Em#A51e5ASOskZAU^%F2H`G8>Jqs1Bq;IiOZhI@Sys+@L z0CEaX)kGxGNX|7X?&DHc%DYAycrW4?=0lc6Kd{^m3>l_w_zuC#z9wc2fT7#qTPF$? z1XWq6x;;%=N_#8U{FQ4y_$&^>LppuBQXZVj=H~O4<W#I3-<#tm$ zmjb1_$^u5%Ube4N-tXan7?=v{Kp~;={ykpIg3>!`pB)0nJOsE1rHm~H)R=}ik(Ubj z3x)I|j&}_D_qrdH8BH~zVn?+CSWkwld>!|YCBBfVVMY>3%>=nqHNp}R-s5~z@T22t zRbq!4i52sUwmi3xpSuWp<(%~dOg#{Fdjh;BA_0JXv`XZ84-qb?IzL~qi^Yk2{-T`D z&C5n6pRx3uq=bwing3C*brA2?aP^T zNq)VMzi8*&VY&#>)Evov86~P!DcW=-skj;;i4J(bCX(ii_cKs<638Ipjg%EmXj2^j zt>;pDQe!bx=^%!SdcxKq*Nu)`87vOX_Bze#M!U@TL=Yjw zbJ$bww@J)dY}6onhTe06aD)cvOnzx5t#60wlg$) z+a0lui;BEI17teKXR-M3@ra2M`xBr7|9#`Ytl#mIpyG&of<9lB`46s4-XdVp*i@=L z9s{?H;3fnUZW~bh!T3V2B*ah8qk088yUt0g%g zQkG`YD(^{vX)ib(Z#^D8MgvT*jf>&m^a*Qk zl9XX(W+md!WWo=4(5O~#OJG<}i!}_lz#>x>j}V&PgD>blov#^5Gn`69M>rP0HvkMB z^dKVKCz0Qh5peL`v?^%St3boNBlTg-q85?RPN3h7YjmzEOAuRu_|xOGQ+TkO%=qxz z@CqMnQFhSl4c{RB-b7fok=#eQAwQIk!sJFZuzBr)a5S0D!82sP4$pYH z08e!ZpYik+cup?k*U9AttY5wWPs?6{r#@GLXCi+Ip0LamD9pTE7iPvK3^!6Wu3)$c zKaiRSoUJRSS;TpkTL&W!mHwIw`}v7Sg_=F}zE64q%~xX$QTsl3-oNG1yW{l#wjxmESax>)l$@AE5+HHSRR zd5SRgVpQ0=(i;Ph#5uU(#2=}b^TpZRI1K&v13D27;t(LZ#|gBKLq9SiEz<-r3qlA~ zsy!ZKO+(I3l&I8fHS^3mA8(QeK(3sClxK@?!kXsQ=4+bg-GKCb>mTwZaJMJr!1_~_ za<@^)=1O)UZs(R^K`in#6U~MznRl|d!a0Y9>wKYn&M)|Iir(#^GtB2T*qGJux)m`* z(K|KKLO?n|sQ8aIh)r!1dMXh#9H9Q%yHwuhK%lNVPeJ{`f?4FVJ;{1)+<1si=M#v5 zUvFC&p-vca3O0DSjQ+10`@RjQzuy(u4zIJ4H)n)e+7il6x+pv8qO6tZ5WZRi1;|Pv zvPKB`US$3Gx$4{Mo;TlIm|vKu9VykWxlrpSVlKvxZ-Ox|_f5dnLNlD$bqwPHPXzN7 zb{|x<^8t)Hvx&W4)NOTW(A)OlCiYg!TPD6K&XD1aarV32sO?{eHYX$L0ovwUv=?2V zz36Vy+@vO7Wc5>6UB4H5dK1jlc-YD=Oyu+W2Vw_#_f5*+1TgPP*@XQyh+m&YvHTP@ zapK$>4<6j`cu13`__TvcsRxkS>#)oLORE?0gcqmV9;zXa;BE%`NE%8f{I(?P=HPCJ zanlMVwy-HE((t54D%Bpfd9+sN*&R}4<2zN>I&L@tKd}y_o*Xxt)Cq};Y%#-fJ<}|o zU`r8Jc!d?8Wu<4>nIld<;T0FGue5&EnR`8ySie;%x4Q{5H~I7-aW*n2Iy(PHQGUp~tHEW|*ta2*L<(!!uG_92Jz}8Px-( zgP5p-^j%V$PC}+aQ{&PY`OVc~{)5@0JPF>+%zULqpXt$P(#Cgcv;`Bd&+IjvIC#vQ zWsCD*<|NBcvL%fbPO;)KR+8Dcn>HGC%{NG@hoNRk%k`J#Lx{~ zZe;8uF}tK(fumUEjco1$oM9;Qc?FIwl*{Rbi%^5cNA-(gu=lti3|H;Fjlnmxxird6 z%XgDkZ?ZE$evfA(K~{pGf=~n8;MpXlPaWL2`3VYjJq~7NJd#4)!fG`?2S-$i^r9^Y zH`zE4cf(ajl`;s`jIy&MqW!=@vWLP?jg*PyQYoL)F4?(K2vBvCsX+IzO5S)Ub2q#a z{^N{aoVhr@12?47o!kE=Fco%{lEXeE?poleGzmV{IlxoBY7FxKkwhSt3TjF?5`=WM zVu+Y@>!!po9i3Zj3|K`k;A#3CYpZ@@02A!9nQF2prG8AD#2U^mAW|A6JX43=M) zHVwJ>54EH?{=2HwEY=STKcRgVN#P`TViR;%dwEaipr0qS(3Hqig!^N<8q|VxdSlT! zpK}J`od_RuI8P*l-NJgDJ+?e9vn`y}( znrhUC=$uI0ghSD9;qis|5GRP~H4>j(`I8@tpOacX`JwRN<9D5uT-U1~PEwmJzfy5~ zFMk8axfh|7f3&Y_&C`6fpSLGcPM?F+hiW$J_ZfX9M(#~ILq_X{j6&D@e8?CKnW5CX zXO@Gsx5KkUON6_SJX+n)t0Is#^F&#X)clT!XJz5{$l~ykspBKFp$L=rGWVmtk8i6{ z$+vnuDw5O>SHBdi#H6Ss9ay`4d{UA=<1$Qw47c~ugiNEaL5m+n@5k@m{&9_i&nE9@ z?!|l`XZ$fF8LN_vR-#f2NoM`^B(r`GNoet-*uD7u+dqcQJBxw2JX1;w9*p-Q6#fMw zbE{^Wx`}UpNz>o^SbPp9m3Fvbf;V;WeGk0vfU}bT+-ewxs|~3bRrf-559Z*8op0C{ zCnUNjL!JRO!hb?|@1fK9Kv+$j)q-pct3StiA*jLeGTajiVa<1mg9;X}L!UlaAZcbo zjlmJ8V(3-`4-46t&0A5vR;=^@mG%%%iX4HS;y*!85|Ks`{{fa-keq}AYvQL$2b+FK zls>}ZTeadG^xzk8cn>uZ2y+cZYmLs-iZ4QYx<%!TpeN2C#Q|#Z9V|XkZ7lo-8vFDR ziTm$R?y8<_S4Tj|Ip<9ym*w_p|fl`aBEl*?W1cTX&D7ekoWx)pL$uejxdYlNCPEdsmDO`2(-#6iw2*pj|@5!r)BM6iqxnYuOkKd_(y&GPAeio<*pM|Nzy~$fVI69H- zUFwB_?KQfkwia0(qV}tO^h2K`Jo@mq5or4=Z(Bdq>Yf^3YkXf#d2$wqL)S*HZ$r_( z3r1|6z)Mf~#!+;mK&q&O_|Hq|eRK(Ho%gj-i*N73z6<~?=?N^ZP&J}m_zNncR|#K- zp?VRQ91K~zcm-9GZ2wE>9Uk@h%;ZiJuNoi%;lmRQ!li z^y0_dk{|JH{|#C^N-v+gL#jD2i)qAIQWiz-!x ze&^ix?%eVGW_K&$)!vNfy?f4ge($;GUe7v#^ctS@{Ua;Vb8j3udU#yyR(7wy`0ABh zA;0qCYgVSlNAcf_cP-@#^Ro-tx&5Dh{{G$Hc;Qud|7hRcyPw&8cK`Dq+g;ne{=%L6 z_T6#E2Y2z+@9%$p_v1s+#=l47m-g@Oeqz_zz5bP{_e|vrxt&6GVLCtm(*vh}x^H7M%ZDe&1^=An@3LW)|2=t9j33L4jb)CXdTw`Z<^ag<-@Wz5=QQOz7pABB?Y{}??vs$ZB_nkV9=Rm-VLe_PNmft%SDf&|^H zIc0Z~tA3 zjvk8@=x7BV%}h*W#!j*Vhob8Tqsi}S)Rze2dlvKO^O@}I<%N7<=|YCxcIOE;+v$be z%F^j8mve>7r+ez`*tWvF`gg!w{T&RIcSNVYuNj@46jN?v%d1sa1CcHbi}6!%%i@;c zpusb*;d)k3bDhINWNlmUo4$ZXq_-i`e5yqXh` z-aQM-uCosI>K(873T*M?AZJ~PuKq}qyFui zY*-%INX*sz#uZ57i@IA5ZRw|mMVdUH5lUyH#_~P$Mia}H=Q?%i1b!bVAVoS5X-}?) zHBai0Qx7`h69jMhLY@K4A*cxv$gs8;%sanng4yZnxxKjf%qCcsVk$eATbRxkM8k8d zo>e#5wU91Zwsgvt$H2Cv<%vwmVnFZsNDCn2wYuvBtG#e&7>kA31iPjNH?A*g29)K9^C&O0PHfTxh)pXftq#)BJacf@n!g+uOr=#PMOg8^QCuepq_^k>uorNOD~DOk}D^C~=vWoq$%Fyz04VPP|( zx@MwT(oDXLWe6Npu{nPnv@iV!hKqk3UHODw5q~vZmWVwS_*#XuWW~!aEQaYS zhN-u)u78kA(kvtGPBW7_3XAo(*F4TmU$1L^f2TV-sR8P{Bj8*gl z&njVu($3VW*?5CsIet(J!j_k?NH_dJfz@mV@x=E`5H~Y5(6ww;$eY5jw%i8QdSKBm zs>nF1EcRC|q;iyt^bWmvZBnF=?G6RPrz$}-Y^x->LPDO*KnQZ9l;FJMtMoego6(`N zHvTwQIA+xisy#}@H~=%tu=}YuVR-yo7*2eYo$A=Vnl2Ziot>&z1*E;}cphXYUWei6 z-(7GqPgObk0p7X4Lbf|6H7gLlWH=`^_{&7 zMC_WcjHcYRjUy2_NZGBc`;}F}H+J3xuoGD9k#Om-6ojbs)%LasxkQ>#32cK9R~1_V z0P5?wVrbVDoS*9N_<5~@U#NzGOB#U!Zd5Z-;H6c4e&p3Apn9^WYm=~}PFwXyWPt$& z=&dCYt6MDvqhB=vsPe^aNJr7|S*d9h98KBUWQSD1TZN$Dojet!5c*%KvDb9s!O_M( z^4QH5Koo&Gz3K48F0M+dE&C1T4tL`u(2x!Omm`-y!L~4~U=dnXlh)Mu#W)k{FF|*m z0X=#q%70b|rkB(`vCoOrQ@Lyb*`kR^r<*2gohqfYrYK~(Z!Y7EG5o)X z<@BGLx*0T$GMSJ;9Q?cqqCR*s=$kqc-NxFX zc%@)B5(NWDt(yRLIIepnk66{6vPZ1je)&UDAU>Qx%w)lU4jeH7-E4-u5v~I!5VZm@ zL(UgYST9l)bX!SK); zHZE^|DEe7wpC4tNw6)KNBJ{kC2IF@3lCDR;sr!1s6-vbU4=P#PviNeiM490PE_)&hWA1)bP;fyF^= zybp$*@pr0F8GsW-iv{h0Xpd|Hv)+TnvTTB`+9Smqi$&@!OK%=J)q4zbUIPjN>0cbw zFCY@^J26~;0YmNm(Mvhk7#o@~1ZfAS4` zq&mZj>&h`PCdSA3e?p(U7>nM?G1&=O1J;kD+M9Y-6b9I29xp(ZJ4y;c*Dt$j0A;q9opSDcbzQyJI72M=$3;@%+mAeU1X$Q zJ&krOGoiAzAF{;BV&G`wy3A23|~42CO3E(cDX z(8SMnPi3l;((gnAfK_^15@1mHTMWPQTc%Fm*WJ5YPCLpH`|7fEN;TR6W&(L5!0uF9 z^>|f`H)s7%H}-lgt90>c6VrN^c3`p;4erHVJQhLO(iPZb5c#*5Aa>#y)t!*Oq77q{ z%#pr5Z>>qgGTZF0Ep5C#c8%M3+~MO*JOi5lwh1WY*4|^HC`(p|69ttss6P-R6Lg&9 z3)}ViKsC@kz!*wPPK@W!l%AQ9fy_M{z2TGEDPJYgS>f+572r=7?=ew+pu0bHIM-^) zoE@GU%?u5aZ%esRb@IisdA=Q5**Zh_PRu!t4xi=3?}~jyCRt z1Ej6oT`>F9Uzl=nl@vOOD>Aaqr<=_-{{ZXa_97N@9N#TibqNWL6>~dwY8K(#2O{Hg z%H84|yqXlk53}ch_Uyh+Xgg@7%__#Z!~lScVGuy~8@Q*?T+Dgl-d==J7|`iIi^Kt~ z@RTy+GW!s7KgTq3L}SL$Vm!GGF`menVsNZM>AG{9te$~H%lQ#?s6gi@PRS0-iqC4T zj4aN4sQXxUReL&_sZS^v4z5~sn~J%cs}gNf7Af=JQThv7q(hW5K}j%`yo8#{tsfx(6p&Q?v`=FkFUygxGq2GoO50vd+k`>g_j4wmbvo*cMK+q2oaSksV0>samvQ0Gwzh;@sn8vs zWYxjF8&m%p4y?>amMXuoMz<>xDyFNbL(!Z6Ji7FGt;c7Sb@WXhq6orCPA2=hm2I%b z9Ur}F(K~cdh{IoA>6F>7UBd+-Uv7>k-zEn9S?H)9W7+$5RGURXyN|TptHGk&*GUSY z>N1;nL~P1KAYe;t1A-s%ROJNz zd>TvFHyKsnVh>iKZ5S?Kcv3ot$+zhd<0N4eat4Af>(%DP+FLEssD+DXH6z+}&ZrZ2 zL&Hs5q#c)U_O=;>To%ef+ocr=L*_cxMUNA>LQH}dvk?xy{a1olCO7w7AFCw)TGKF(2F)e zgyxOEo(Tp@@MXZ)rQ1xyg_P2(&Z-7BmpgifUo#N&!wn$obgx?HS9X@Y$u(AWcNB4# z!U!Jjh}V&ySFH^xNGFI2AGN;}GYkUFaRbE7vr-et8+cqnQ~Ln)TVQ>1AO470meYqK$)qp$Hv#+`j*DGU_YW;m8R-an%_ob3na z9`W_AuJ?4kqwAk@q8Xhhw{HO~vA6_tQ511<35{yf_KaWN^Gw{dO?TXE>3$I=V24Sf zK-J_v2*M=NSvU`q5LhUnfv@`rJ-CW&!F3BLFc&N zZar0^NIvX0`d^aWhpsKGakw%e7J=| z<*5=woIt+7)ydF4$0bA|u27*cdM2*ph{L525%8OEp3Zm<;^N5_Vth%w%)Z|`ndl~S z%~Sn^nzkGb%VNa$Ph9s@_eQQm_ASbY8My3RA2Mp~Q`2>PohA@Q*hTC^3m2TGA}ge5 z)e0lk8(H~)+T_d#%+Z4;DeaN66xr{&6jBDn-5AOsDbETNO#lz4SC9!Yhvij_(?p=Q zIOiBV+lVd&NTmA3Rahv(D*jzGgdiI+$dvo91#z3V@q0R3RGC#G3{vJ=*N)UkU|z{D z7Fn{9SfJ_#%;H?N1bg|JlLu2gNFO+gvPdFXq>-jPiQ*eDWcQ2B6Vlc-`Rp`o>Icwh zc*c-`Lv6sBhv%ODM!@E{32^nUOfmo$i*4sINfib4`IgDM4FbCXsgvlLQLIOrli90Fj69*A@KJwl( z9G|)lFfyFj1_R%AJ#zPTM(A)9z?fKcGM0rAw#qDTNhOXH&kxSAT%0vgH8wU-od>d^ zFrA|w{Co)AejkTsiEoUEVWF6%T-ArXZGlZ32OZLc+JLUzqWl-+UnW{uCk$LjjOo#aB}7Ar;fR_GKUmd2`w$JB&3wGgw)Zu zH)0c;w1*@ZIJJ#5>(o_*6;W#TWr;Ggs=aJiU9I7%64nw`wXcZ(R{NtwR9j2&e`VogW3R6UI5}rv!DJe!C`D~v?rQZh2V;agVNJ9_~^Nc3b zbdqFJ9U}eUlo2fV(-W1JtV#5MQEzw21TN2w8^E$CLv51Lh@$W*lL@nXTFva~`$ord z+m3<66788TqCe_bq%^zsLu~s459_|cYuoNaTfgoiqOlzw@PLdEs zOy$Wm@>4=D$rN<_D5Aiha1?qK5n@B^bD%KyqcETu2)YW_pmF#dB@O&cHYiCcN}kEI zc=Iz(3Ti!>NE`_i=O{bRayf2Z77&o+X_1Ml5GbmA9>_@!gwKnlXGuDwCr_%fH&#|i z#zBPA4B2z``;=K9r+)BM=D?4V2vigUIxBlcWu!^{NP;cJNzS=1{BwnY=aYg{^lp&L zG^0n48*HY;=x9vAsl*sjF&RiL+E^C-#(fbWsZA=nZa#mWOvho2CLASk-qfmcDLSAU zB;zr9m`R72Z|+O%xvQCuYLV9~f>A;FP&9298J#lo1ZfDODJFnXMfhQS0_iA8$3D*u zC(4h{%RvKk%ww!H=)a2#@%Kp3gGI>v_2EAx%9Lbq`n zRtF$wRiUxvGc--`bFJ1jU5{$DJ_d{|vrE|Zap9W38q}3JN=+TRYucvOv8kpz`mWig z+qdyoC)d**&$RX#`yFl7skTb1w7IrUTX)y-R#V8ztD|>q`@T!HUk3UfwGGQN9AmFe z?E~E@HSU0qZaZe*gCo;AG+lEScb(nokZW{}w$}#{PrdgY+k?Q^E40jaZIwED&+Hx% z?nuM2$UZcju4$DHJjc9m*nLZ@pC^?ZPM+%>fi8A+WX)YG-su%XP14G|KGK+MT zFWwQ87+4k*ECP0WgSIv{=+62))-xV@3aBawle?R=ac7e@S62)7bs+yoiGli9(vKzm zIHezIO6zrXEngQm#5(U5UW!ln>)H~Qg_jFTd(~1QmSM2;UWf*}!WmyMV(}WkUHLS` z3-MxM8_eF{mYppvg8Mt31J;3qdR}9_%y(9K7mDS%i?FbMV_gzA#aH4+as7+WX8Nzi zP5j#QOiS;IPiN9^#H|CPduVuOTb~nOIw(yS#hlYi_@!NW&?|PFrsBD@E3su27gZ`1 zmL*Ec#r~3E*Le|z$s%;i2M+%0Z>s-p7v4&z^iTo$`@;gc%%3ysBJ@SUf_G84Ok2sl z0{$2GD}mg>KQM(V3oKA$Q3+<5o)>&yK~xQjc4gwCXdxCT%{-=4VTu^JMexjH)w%P6 zKVOIN*eR+jyt#?b>=?CS_B_n9a9H|JB~aOVg&TWN6rNNz6}g{Tfc{h~d+G6ZJ|6RR w0a|fUS$un?hOX4yt~3A_Uex6>e<1dSrd`>xfH}^RPzm@O!t1{Y>yN+w1!r1(@Bjb+ literal 0 HcmV?d00001 diff --git a/rooms/ROOMS b/rooms/ROOMS new file mode 100644 index 00000000..e19a55fb --- /dev/null +++ b/rooms/ROOMS @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE (DEFPACKAGE "ROOMS" (USE "LISP" "XCL") (SHADOW CLROOM)) ) (IL:FILECREATED " 5-Dec-2020 16:12:54"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS.;3| 2513 IL:|previous| IL:|date:| "17-Aug-90 12:28:18" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMSCOMS) (IL:RPAQQ IL:ROOMSCOMS ((IL:P (PROVIDE "ROOMS") (EXPORT '(*ROOMS-SYSTEM-DATE*) "ROOMS")) (FILE-ENVIRONMENTS IL:ROOMS) (IL:COMS (IL:P (PROCLAIM '(GLOBAL *ROOMS-SYSTEM-DATE*))) (IL:E (SETQ *ROOMS-SYSTEM-DATE* (IL:DATE))) (IL:VARS *ROOMS-SYSTEM-DATE*)) (IL:FILES (IL:SYSLOAD) (IL:* IL:|;;| "load Rooms modules") IL:ROOMS-D IL:ROOMS-CORE IL:ROOMS-WINDOW-HIDER IL:ROOMS-GEOMETRY IL:ROOMS-TEXT IL:ROOMS-WINDOW-TYPES IL:ROOMS-BUTTONS IL:ROOMS-BIOS IL:ROOMS-SUITES IL:ROOMS-INTERACTIVE IL:ROOMS-BACKGROUNDS IL:ROOMS-PLACEMENT-EDITOR IL:ROOMS-OVERVIEW (IL:* IL:|;;| "load appropriate window types") IL:ROOMS-MEDLEY-WINDOW-TYPES) (IL:P (EVAL-WHEN (LOAD) (UNLESS *CURRENT-ROOM* (IL:* IL:|;;| "bootstrap") (RESET)))))) (PROVIDE "ROOMS") (EXPORT '(*ROOMS-SYSTEM-DATE*) "ROOMS") (DEFINE-FILE-ENVIRONMENT IL:ROOMS :COMPILER :COMPILE-FILE :PACKAGE (DEFPACKAGE "ROOMS" (:USE "LISP" "XCL") (:SHADOW CL:ROOM)) :READTABLE "XCL") (PROCLAIM '(GLOBAL *ROOMS-SYSTEM-DATE*)) (IL:RPAQQ *ROOMS-SYSTEM-DATE* " 5-Dec-2020 16:12:54") (IL:FILESLOAD (IL:SYSLOAD) IL:ROOMS-D IL:ROOMS-CORE IL:ROOMS-WINDOW-HIDER IL:ROOMS-GEOMETRY IL:ROOMS-TEXT IL:ROOMS-WINDOW-TYPES IL:ROOMS-BUTTONS IL:ROOMS-BIOS IL:ROOMS-SUITES IL:ROOMS-INTERACTIVE IL:ROOMS-BACKGROUNDS IL:ROOMS-PLACEMENT-EDITOR IL:ROOMS-OVERVIEW IL:ROOMS-MEDLEY-WINDOW-TYPES) (EVAL-WHEN (LOAD) (UNLESS *CURRENT-ROOM* (IL:* IL:|;;| "bootstrap") (RESET))) (IL:PUTPROPS IL:ROOMS IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-BACKGROUNDS b/rooms/ROOMS-BACKGROUNDS new file mode 100644 index 00000000..26fde0ca --- /dev/null +++ b/rooms/ROOMS-BACKGROUNDS @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:35:40"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-BACKGROUNDS.;2| 16393 IL:|previous| IL:|date:| "17-Aug-90 12:29:44" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-BACKGROUNDS.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-BACKGROUNDSCOMS) (IL:RPAQQ IL:ROOMS-BACKGROUNDSCOMS ( (IL:* IL:|;;| "code for painting background") (FILE-ENVIRONMENTS IL:ROOMS-BACKGROUNDS) (IL:P (EXPORT '(MAKE-BACKGROUND BACKGROUND-INTERNAL-FORM *DEFAULT-BACKGROUND-TEXT-FONT* RENAISSANCE-BITMAP SQUARES-BITMAP TILE-BITMAP INTERNALIZE-ALL-BACKGROUNDS)) (REQUIRE "ROOMS")) (IL:STRUCTURES BACKGROUND) (IL:FUNCTIONS MAKE-BACKGROUND INTERNALIZE-BACKGROUND INTERNALIZE-BACKGROUND-TEXT INTERNALIZE-ALL-BACKGROUNDS) (EVAL-WHEN (LOAD) (IL:P (PUSHNEW 'INTERNALIZE-ALL-BACKGROUNDS *SCREEN-CHANGED-FUNCTIONS*))) (IL:VARIABLES *DEFAULT-BACKGROUND* *DEFAULT-BACKGROUND-TEXT-FONT*) (IL:FUNCTIONS PAINT-BACKGROUND FIND-BACKGROUNDS DRAW&FILL-BOX-WITHIN) (IL:VARIABLES *SCREEN-BITMAP*) (IL:VARIABLES RENAISSANCE-BITMAP SQUARES-BITMAP TILE-BITMAP) (IL:GLOBALVARS IL:WINDOWBACKGROUNDSHADE IL:WHOLESCREEN))) (IL:* IL:|;;| "code for painting background") (DEFINE-FILE-ENVIRONMENT IL:ROOMS-BACKGROUNDS :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(MAKE-BACKGROUND BACKGROUND-INTERNAL-FORM *DEFAULT-BACKGROUND-TEXT-FONT* RENAISSANCE-BITMAP SQUARES-BITMAP TILE-BITMAP INTERNALIZE-ALL-BACKGROUNDS)) (REQUIRE "ROOMS") (DEFSTRUCT (BACKGROUND (:CONSTRUCTOR MAKE-BACKGROUND-INTERNAL)) (EXTERNAL-FORM NIL :TYPE LIST :READ-ONLY T) (IL:* IL:|;;| "what the user sees") (INTERNAL-FORM NIL :TYPE LIST) (IL:* IL:|;;| "what PAINT-BACKGROUND operates on") ) (DEFUN MAKE-BACKGROUND (EXTERNAL-FORM) (MAKE-BACKGROUND-INTERNAL :EXTERNAL-FORM EXTERNAL-FORM :INTERNAL-FORM (INTERNALIZE-BACKGROUND EXTERNAL-FORM))) (DEFUN INTERNALIZE-BACKGROUND (BACKGROUND) (IL:* IL:|;;| "internalize BACKGROUND") (MAPCAR #'(LAMBDA (PROP-LIST) (CASE (CAR PROP-LIST) (:WHOLE-SCREEN (CHECK-TYPE (SECOND PROP-LIST) (OR BITMAP TEXTURE)) (CHECK-TYPE (GETF PROP-LIST :BORDER) (OR NULL INTEGER)) (CHECK-TYPE (GETF PROP-LIST :BORDER-SHADE) (OR NULL TEXTURE)) `(:WHOLE-SCREEN ,(SECOND PROP-LIST) ,@(WHEN (GETF PROP-LIST :BORDER) `(:BORDER ,(GETF PROP-LIST :BORDER))) ,@(WHEN (GETF PROP-LIST :BORDER-SHADE) `(:BORDER-SHADE ,(GETF PROP-LIST :BORDER-SHADE))))) (:REGION (CHECK-TYPE (GETF PROP-LIST :SHADE) (OR NULL BITMAP TEXTURE)) (CHECK-TYPE (GETF PROP-LIST :BORDER) (OR NULL INTEGER)) (CHECK-TYPE (GETF PROP-LIST :BORDER-SHADE) (OR NULL TEXTURE)) `(:REGION ,(INTERNALIZE-REGION (SECOND PROP-LIST)) ,@(WHEN (GETF PROP-LIST :SHADE) `(:SHADE ,(GETF PROP-LIST :SHADE))) ,@(WHEN (GETF PROP-LIST :BORDER) `(:BORDER ,(GETF PROP-LIST :BORDER))) ,@(WHEN (GETF PROP-LIST :BORDER-SHADE) `(:BORDER-SHADE ,(GETF PROP-LIST :BORDER-SHADE))))) (:TEXT (LIST :TEXT (LET ((*DEFAULT-TEXT-FONT* *DEFAULT-BACKGROUND-TEXT-FONT*) ) (INTERNALIZE-BACKGROUND-TEXT PROP-LIST)))))) (EVAL-WALK BACKGROUND))) (DEFUN INTERNALIZE-BACKGROUND-TEXT (PROP-LIST) (MAKE-TEXT :STRING (GETF PROP-LIST :TEXT) :POSITION (INTERNALIZE-POSITION (OR (GETF PROP-LIST :POSITION) (MAKE-POSITION 0 0))) :ALIGNMENT (OR (GETF PROP-LIST :ALIGNMENT) :LEFT-BOTTOM) :FONT (LET ((FONT (GETF PROP-LIST :FONT))) (IF FONT (IL:FONTCREATE FONT) *DEFAULT-TEXT-FONT*)) :SHADOWS (GETF PROP-LIST :SHADOWS T))) (DEFUN INTERNALIZE-ALL-BACKGROUNDS () (IL:* IL:|;;| "do all the named rooms") (DO-ROOMS (ROOM) (LET ((BACKGROUND (ROOM-BACKGROUND ROOM))) (SETF (BACKGROUND-INTERNAL-FORM BACKGROUND) (INTERNALIZE-BACKGROUND (BACKGROUND-EXTERNAL-FORM BACKGROUND))))) (IL:* IL:|;;| "do the Overview too (yes, this is ugly)") (LET ((BACKGROUND (ROOM-BACKGROUND *OVERVIEW-ROOM*))) (SETF (BACKGROUND-INTERNAL-FORM BACKGROUND) (INTERNALIZE-BACKGROUND (BACKGROUND-EXTERNAL-FORM BACKGROUND)))) NIL) (EVAL-WHEN (LOAD) (PUSHNEW 'INTERNALIZE-ALL-BACKGROUNDS *SCREEN-CHANGED-FUNCTIONS*) ) (DEFGLOBALPARAMETER *DEFAULT-BACKGROUND* (MAKE-BACKGROUND `((:WHOLE-SCREEN ,IL:WINDOWBACKGROUNDSHADE) ))) (DEFPARAMETER *DEFAULT-BACKGROUND-TEXT-FONT* (IL:FONTCREATE 'IL:TIMESROMAND 36)) (DEFUN PAINT-BACKGROUND (ROOM DSP &KEY (SCALE *ONE-TO-ONE*) NO-TEXT CLIPPING-REGION) (DOLIST (BACKGROUND (FIND-BACKGROUNDS ROOM)) (DOLIST (SPEC (BACKGROUND-INTERNAL-FORM BACKGROUND)) (CASE (FIRST SPEC) (:WHOLE-SCREEN (DRAW&FILL-BOX-WITHIN (SCALE-REGION IL:WHOLESCREEN SCALE) DSP :SHADE (SECOND SPEC) :BORDER-WIDTH (SCALE-WIDTH (GETF SPEC :BORDER 0) SCALE) :BORDER-SHADE (GETF SPEC :BORDER-SHADE IL:BLACKSHADE) :CLIPPING-REGION CLIPPING-REGION)) (:REGION (DRAW&FILL-BOX-WITHIN (SCALE-REGION (GETF SPEC :REGION) SCALE) DSP :SHADE (GETF SPEC :SHADE) :BORDER-WIDTH (SCALE-WIDTH (GETF SPEC :BORDER 0) SCALE) :BORDER-SHADE (GETF SPEC :BORDER-SHADE IL:BLACKSHADE) :CLIPPING-REGION CLIPPING-REGION)) (:TEXT (UNLESS NO-TEXT (DISPLAY-TEXT (SECOND SPEC) DSP :SCALE SCALE))))))) (DEFUN FIND-BACKGROUNDS (ROOM) (IL:* IL:|;;;| "returns the list of backgrounds which apply to ROOM") (LET (BACKGROUNDS FOUND-WHOLE-SCREEN?) (DO-INCLUSIONS (ROOM ROOM) (LET ((BACKGROUND (ROOM-BACKGROUND ROOM))) (PUSH BACKGROUND BACKGROUNDS) (IL:* IL:|;;| "stop when we see one which paints the whole background") (WHEN (ASSOC :WHOLE-SCREEN BACKGROUND :TEST 'EQ) (SETQ FOUND-WHOLE-SCREEN? T) (RETURN-FROM DO-INCLUSIONS)))) (UNLESS FOUND-WHOLE-SCREEN? (PUSH *DEFAULT-BACKGROUND* BACKGROUNDS)) BACKGROUNDS)) (DEFUN DRAW&FILL-BOX-WITHIN (REGION DSP &KEY (SHADE IL:WHITESHADE) (BORDER-WIDTH 0) CLIPPING-REGION (BORDER-SHADE IL:BLACKSHADE)) (LET ((LEFT (REGION-LEFT REGION)) (BOTTOM (REGION-BOTTOM REGION)) (WIDTH (REGION-WIDTH REGION)) (HEIGHT (REGION-HEIGHT REGION))) (IF (OR (NULL BORDER-WIDTH) (ZEROP BORDER-WIDTH)) (PAINT-REGION DSP REGION SHADE CLIPPING-REGION) (LET ((TOP (+ BOTTOM HEIGHT)) (RIGHT (+ LEFT WIDTH)) (INSIDE-LEFT (+ LEFT BORDER-WIDTH)) (INSIDE-WIDTH (- WIDTH BORDER-WIDTH))) (PAINT-REGION DSP (MAKE-REGION :LEFT INSIDE-LEFT :BOTTOM (+ BOTTOM BORDER-WIDTH) :WIDTH INSIDE-WIDTH :HEIGHT (- HEIGHT BORDER-WIDTH)) SHADE CLIPPING-REGION) (IL:* IL:|;;| "up left") (IL:BLTSHADE BORDER-SHADE DSP LEFT BOTTOM BORDER-WIDTH HEIGHT BORDER-WIDTH NIL CLIPPING-REGION) (IL:* IL:|;;| "across top") (IL:BLTSHADE BORDER-SHADE DSP INSIDE-LEFT (- TOP BORDER-WIDTH) INSIDE-WIDTH BORDER-WIDTH NIL CLIPPING-REGION) (IL:* IL:|;;| "up the right") (IL:BLTSHADE BORDER-SHADE DSP (- RIGHT BORDER-WIDTH) BOTTOM BORDER-WIDTH (- HEIGHT BORDER-WIDTH) NIL CLIPPING-REGION) (IL:* IL:|;;| "across the bottom") (IL:BLTSHADE BORDER-SHADE DSP INSIDE-LEFT BOTTOM INSIDE-WIDTH BORDER-WIDTH NIL CLIPPING-REGION))))) (DEFGLOBALVAR *SCREEN-BITMAP* (IL:SCREENBITMAP)) (DEFGLOBALVAR RENAISSANCE-BITMAP '#*(74 73)JJJJJJJJJJJJJJJJJJH@EEEEEEEEEEEEEEEEEED@JJJJJJJJJJJJJJJJJJH@EEEEEEEEEEEEEEEEEED@JOOOOOOOOOOOOOOOONH@EGOOOOOOOOOOOOOOOMD@JOOOOOOOOOOOOOOOOFH@EGOOOOOOOOOOOOOONED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJOOOOOOOOOONJLFH@EGMEGOOOOOOOOOMEDED@JOJJOOOOOOOOOOFJLFH@EGMEGOOOOOOOONEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJOOOOJJLFJLFH@EGMEGMEOOOOMEDEEDED@JOJJOJJOOONJJLFJLFH@EGMEGMEOOOLMEDEEDED@JOJJOJJOJJHJJLFJLFH@EGMEGMEOEEHMEDEEDED@JOJJOJJOJJHJJLFJLFH@EGMEGMEOEEHMEDEEDED@JOJJOJJOJJHJJLFJLFH@EGMEGMEOEEHMEDEEDED@JOJJOJJOJJHJJLFJLFH@EGMEGMEOEEHMEDEEDED@JOJJOJJOOOHJJLFJLFH@EGMEGMEO@@DMEDEEDED@JOJJOJJN@@BJJLFJLFH@EGMEGMEL@@@MEDEEDED@JOJJOJJOOOOJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOJJJJJJJJLFJLFH@EGMEGMEEEEEEEDEEDED@JOJJOOOOOOOOOLFJLFH@EGMEGH@@@@@@@BEEDED@JOJJO@@@@@@@@AFJLFH@EGMEF@@@@@@@@@EEDED@JOJJOOOOOOOOOONJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOJJJJJJJJJJJJJJLFH@EGMEEEEEEEEEEEEEDED@JOOOOOOOOOOOOOOOLFH@EGH@@@@@@@@@@@@@BED@JO@@@@@@@@@@@@@@AFH@EF@@@@@@@@@@@@@@@ED@JOOOOOOOOOOOOOOOONH@EEEEEEEEEEEEEEEEEED@JJJJJJJJJJJJJJJJJJH@EEEEEEEEEEEEEEEEEED@JJJJJJJJJJJJJJJJJJH@ ) (DEFGLOBALPARAMETER SQUARES-BITMAP '#*(72 72)JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@GOOOMOOOOGOOOMOOOO@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@OOKOOONOOOOKOOONOO@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@GOOOMOOOOGOOOMOOOO@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@OOKOOONOOOOKOOONOO@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@GOOOMOOOOGOOOMOOOO@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@OOKOOONOOOOKOOONOO@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@GOOOMOOOOGOOOMOOOO@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@MEEEGEEEEMEEEGEEEE@@JJNJJJKJJJJNJJJKJJ@@OOKOOONOOOOKOOONOO@@ ) (DEFGLOBALPARAMETER TILE-BITMAP '#*(100 100)@@@@@@@@@@@@D@@@@@@@@@@@A@@@@@@@@@@@@@@@L@@@@@@@@@@@C@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@COOOOOOOOOOOLOOOOOOOOOOOO@@@GOOOOOOOOOOOMOOOOOOOOOOOO@@@@@@@@@@@@@@@D@@@@@@@@@@@A@@@@@@@@@@@@@@@D@@@@@@@@@@@A@@@@@@@@@@@@@@@L@@@@@@@@@@@C@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@BJJJJJJJJJJJLJJJJJJJJJJJK@@@AEEEEEEEEEEELEEEEEEEEEEEG@@@COOOOOOOOOOOLOOOOOOOOOOOO@@@GOOOOOOOOOOOMOOOOOOOOOOOO@@@@@@@@@@@@@@@D@@@@@@@@@@@A@@@ ) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:WINDOWBACKGROUNDSHADE IL:WHOLESCREEN) ) (IL:PUTPROPS IL:ROOMS-BACKGROUNDS IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (2211 2445 (MAKE-BACKGROUND 2211 . 2445)) (2447 4605 (INTERNALIZE-BACKGROUND 2447 . 4605)) (4607 5161 (INTERNALIZE-BACKGROUND-TEXT 4607 . 5161)) (5163 5742 (INTERNALIZE-ALL-BACKGROUNDS 5163 . 5742)) (6176 7664 (PAINT-BACKGROUND 6176 . 7664)) (7666 8335 (FIND-BACKGROUNDS 7666 . 8335)) ( 8337 10138 (DRAW&FILL-BOX-WITHIN 8337 . 10138))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-BACKGROUNDS.DFASL b/rooms/ROOMS-BACKGROUNDS.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..2bfa2ca5ec7078df49ae3732293f76a54b614d85 GIT binary patch literal 11054 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.;2| 7337 IL:|previous| IL:|date:| "17-Aug-90 12:31:56" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-BIOS.;1|) ; Copyright (c) 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-BIOSCOMS) (IL:RPAQQ IL:ROOMS-BIOSCOMS ( (IL:* IL:|;;| "button image objects") (IL:FILES (IL:SYSLOAD) IL:ROOMS-BUTTONS) (FILE-ENVIRONMENTS IL:ROOMS-BIOS) (IL:P (EXPORT '(MAKE-BIO *BIO-SELECTION-BORDER*) "ROOMS")) (IL:VARIABLES *BIO-SELECTION-BORDER*) (IL:FUNCTIONS MAKE-BIO BIO-BUTTON BIO-COPYFN BIO-IMAGEBOXFN BIO-PUTFN IL:BIO-GETFN BIO-DISPLAYFN BIO-BUTTONEVENTINFN BIO-BUTTONEVENTINFN-INTERNAL) (IL:VARIABLES *BIO-IMAGEFNS*))) (IL:* IL:|;;| "button image objects") (IL:FILESLOAD (IL:SYSLOAD) IL:ROOMS-BUTTONS) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-BIOS :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(MAKE-BIO *BIO-SELECTION-BORDER*) "ROOMS") (DEFGLOBALVAR *BIO-SELECTION-BORDER* 4 "Width of mouse-insensitive strip around outside edge of button image objects") (DEFUN MAKE-BIO (BUTTON) (CHECK-TYPE BUTTON BUTTON) (IL:IMAGEOBJCREATE BUTTON *BIO-IMAGEFNS*)) (DEFMACRO BIO-BUTTON (BIO) `(IL:IMAGEOBJPROP ,BIO 'IL:OBJECTDATUM)) (DEFUN BIO-COPYFN (BIO SOURCE DESTINATION) (MAKE-BIO (COPY-BUTTON (BIO-BUTTON BIO)))) (DEFUN BIO-IMAGEBOXFN (BIO IMAGE-STREAM CURRENT-X RIGHT-MARGIN) (LET ((BUTTON (BIO-BUTTON BIO)) (SCALE (IL:DSPSCALE NIL IMAGE-STREAM))) (UPDATE-BUTTON BUTTON) (IL:|create| IL:IMAGEBOX IL:XSIZE IL:_ (* (BUTTON-WIDTH BUTTON) SCALE) IL:YSIZE IL:_ (* (BUTTON-HEIGHT BUTTON) SCALE) IL:YDESC IL:_ (* (IL:FONTDESCENT (TEXT-FONT (BUTTON-TEXT BUTTON))) SCALE) IL:XKERN IL:_ 0))) (DEFUN BIO-PUTFN (BIO FILE-STREAM) (LET ((*PRINT-PRETTY* NIL) (*PRINT-ARRAY* T) (*PRINT-STRUCTURE* T) (*PACKAGE* (FIND-PACKAGE "USER")) (*PRINT-BASE* 10) (*READTABLE* (IL:FIND-READTABLE "LISP"))) (PRINT (EXTERNALIZE-BUTTON (BIO-BUTTON BIO)) FILE-STREAM))) (DEFUN IL:BIO-GETFN (FILE-STREAM) (IL:* IL:|;;| "TEdit presumes GETFNS are in package IL. sigh.") (MAKE-BIO (APPLY #'MAKE-BUTTON (LET ((*PACKAGE* (FIND-PACKAGE "USER")) (*READ-BASE* 10) (*READTABLE* (IL:FIND-READTABLE "LISP"))) (READ FILE-STREAM))))) (DEFUN BIO-DISPLAYFN (BIO IMAGE-STREAM IMAGE-STREAM-TYPE HOST-STREAM) (LET ((BUTTON (BIO-BUTTON BIO))) (UPDATE-BUTTON BUTTON) (LET* ((WIDTH (BUTTON-WIDTH BUTTON)) (HEIGHT (BUTTON-HEIGHT BUTTON)) (SCRATCH (IL:DSPCREATE (IL:BITMAPCREATE WIDTH HEIGHT)))) (IL:* IL:|;;| "this rather crude approach solves lots of scaling & offset problems") (DISPLAY-BUTTON BUTTON SCRATCH :NO-UPDATE T :WIDTH WIDTH :HEIGHT HEIGHT) (IL:BITBLT SCRATCH 0 0 IMAGE-STREAM (IL:DSPXPOSITION NIL IMAGE-STREAM) (IL:* IL:|;;| "adjust for descent") (- (IL:DSPYPOSITION NIL IMAGE-STREAM) (* (IL:FONTDESCENT (TEXT-FONT (BUTTON-TEXT BUTTON))) (IL:DSPSCALE NIL IMAGE-STREAM))))))) (DEFUN BIO-BUTTONEVENTINFN (BIO DSP) (LET ((BUTTON (BIO-BUTTON BIO))) (IF (UPDATE-BUTTON BUTTON) 'IL:CHANGED (LET ((X-OFFSET (IL:DSPXOFFSET NIL DSP)) (Y-OFFSET (IL:DSPYOFFSET NIL DSP)) (CLIPPING-REGION (IL:DSPCLIPPINGREGION NIL DSP))) (IL:* IL:|;;| "applications don't always adjust coordinates so we're at 0,0 but they are good about setting the clipping region. we move 0,0 to the bottom-left of the clipping region.") (UNWIND-PROTECT (PROGN (IL:DSPXOFFSET (+ X-OFFSET (REGION-LEFT CLIPPING-REGION)) DSP) (IL:DSPYOFFSET (+ Y-OFFSET (REGION-BOTTOM CLIPPING-REGION)) DSP) (IL:DSPCLIPPINGREGION (IL:CREATEREGION 0 0 (REGION-WIDTH CLIPPING-REGION) (REGION-HEIGHT CLIPPING-REGION)) DSP) (WHEN (AND (IL:LASTMOUSESTATE (OR IL:LEFT IL:MIDDLE)) (IL:INSIDEP (MAKE-REGION :LEFT *BIO-SELECTION-BORDER* :BOTTOM *BIO-SELECTION-BORDER* :WIDTH (- (BUTTON-WIDTH BUTTON) (* *BIO-SELECTION-BORDER* 2)) :HEIGHT (- (BUTTON-HEIGHT BUTTON) (* *BIO-SELECTION-BORDER* 2))) (IL:LASTMOUSEX DSP) (IL:LASTMOUSEY DSP))) (BIO-BUTTONEVENTINFN-INTERNAL BIO DSP))) (IL:DSPXOFFSET X-OFFSET DSP) (IL:DSPYOFFSET Y-OFFSET DSP) (IL:DSPCLIPPINGREGION CLIPPING-REGION DSP)))))) (DEFUN BIO-BUTTONEVENTINFN-INTERNAL (BIO DSP) (LET ((BUTTON (BIO-BUTTON BIO))) (IF (AND (IL:LASTMOUSESTATE (IL:ONLY IL:MIDDLE)) (NOT (BUTTON-PROP BUTTON :PROTECTED?))) (CASE (MENU '(("Edit Button" :EDIT "Edit this button") ("Copy to Screen" :COPY "Copy this button to the screen "))) (:EDIT (LET ((NEW-BUTTON (EDIT-BUTTON BUTTON))) (UNLESS (EQ NEW-BUTTON BUTTON) (IL:IMAGEOBJPROP BIO 'IL:OBJECTDATUM NEW-BUTTON) 'IL:CHANGED))) (:COPY (MAKE-BUTTON-WINDOW (COPY-BUTTON BUTTON)) NIL)) (WHEN (AND (BUTTON-TRACK-MOUSE BUTTON DSP) (UPDATE-BUTTON BUTTON)) (IL:* IL:|;;| "button's action caused it to need redisplay") 'IL:CHANGED)))) (DEFGLOBALPARAMETER *BIO-IMAGEFNS* (IL:IMAGEFNSCREATE 'BIO-DISPLAYFN 'BIO-IMAGEBOXFN 'BIO-PUTFN 'IL:BIO-GETFN 'BIO-COPYFN 'BIO-BUTTONEVENTINFN)) (IL:PUTPROPS IL:ROOMS-BIOS IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1445 1549 (MAKE-BIO 1445 . 1549)) (1627 1727 (BIO-COPYFN 1627 . 1727)) (1729 2294 ( BIO-IMAGEBOXFN 1729 . 2294)) (2296 2630 (BIO-PUTFN 2296 . 2630)) (2632 3034 (IL:BIO-GETFN 2632 . 3034) ) (3036 3884 (BIO-DISPLAYFN 3036 . 3884)) (3886 5997 (BIO-BUTTONEVENTINFN 3886 . 5997)) (5999 6934 ( BIO-BUTTONEVENTINFN-INTERNAL 5999 . 6934))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-BIOS.DFASL b/rooms/ROOMS-BIOS.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..e78f8c06842281878bbef5e96b1a0ea13b00129d GIT binary patch literal 5065 zcmcIoO>7(25ne8TM2eJ5MzY+g9oq;uu`7|LL=bpSJeJ<8=XkuXi3%93>JyB1do%7ers{R&y|;8(P}d6c^OD z(xTA%s2NW>u41Z+t;)KYFSyB8Gk#KP)VJjI@*CxKblZjqB3d6e!>v~K zllCux_7POuF)T%m!>kW9&D&Pqe-u4M`%_rc5bsc%TLsrS=*s>sga24-PXwVT!zqzG z7!G(01=qDqXQZ{)*V^*~-Is)iI6K>F4zKJs8ud-7y0QFvS*owp%BzhX&J-lgKqfoF zo<-?5n+fulizSO|v|9&>BdYKmOWq}V?%K^6qF#vVgQvqW-G!8 zksii@Tgq!AYy@FGjIekdYd$vO1MdV_gy$-Yw&6hPCnyK$(U04rl1~(ou0FmfJ0Xan zwg?{vWSmWqs40>{Ieb7?)3Es4^#D)tu1|=u{AA(^R%0b#t^ju&JXKlz!Y+{s6#Mp!gNnxC?t~DxB{j#)C z-`y$8)yM};c;mCtD!Cv_&&og$sVl<4XaAhPghS8&Y#faBk+BGBu!>RP@JF=7jgudm%5lB>p5L?}_{sA}0NQtuhKfh|n2`P{7kH(AJE*Uv^wLq#;g`biuZv#L7hop{*}uU2u@S zpqrstj7Y{ZU9cbx9AlvQ07s3S)sT}Vp9fmZqn+1PH_MVE$X3YXaoREQ5c*hk@=jVY zG_cqIJzxsBS`kFZY{j$w)z*IKbhX+o6YKrmapG{W$1!9n_YE{aLCE33WZs5@K+fBm z>z0yY0BF%p^O#4ewsOY?We^@Dl}>=%XTVfCqx1`1uY8A9hruz>x|yon(KL*D63Nrd z_dKhKhg!`5_5c8|K*7;$0LyEweg8CJlDyG%)gx~6i}SSnOc%J|F_B#d;Cu)+x4k5D zp9r+jWUu)jDKfpLg(lhfI9jLV^F|5lX8@Idj=sDVr`J9f*+Wh#m$D4G-9Grx!%^Ow zcFghkUBGgZ%&;A6*4cAsKP?JXD!F|NU^IB-B3z*Q-=E!a?ATQdRRDQ`JC9#57>fQF6}(%`B=uPN%J5!T2Ee8#K$ar_3P=M;}{l!U)COs{tb==C0C zTWFPrA6#TBXQ59B@#LL`VUTim5=Ifzl6lg4$v6v9*w_?=7mD-4f-)=~WbX;x0=Sm_ z&v4*?0&|O~@k;idNFjlh&_VAk{K%~T0EH4*hlT90c!h>p8GJqq2ip@#>&MM}Drp6(e%3vGf|1a5l zq3peW-{0E0gOOn%h&_~A4GE%;o}w>?sOqrSF5z@N`1OOEmCt@ejv&foqwKu^xr%d( z_rId`C#W2SFIV)q|{ zYm2Mpuw{TK_oWTXfvQGlF7yt;g_F}$lLP3BFR>CVDMmqa@Ur0|?f2-ni@Bxt{5Cs_ zZK8i3qt_P^{P2A?ah0aO+hP+O;J1IwCQ1nKlm$1loXaLGm<0?i&#Wz^FLlFBNy|ooh_J))1R=j9w2Y_l)XFaeV0Ih@b#4kw-0+oD@MRMaiem* zdaZKX=$8BvEj+k=j91AE*#|c&aW3o}ze^KCoEOIjpK>+=(m^F&iD&s)y3gs?D($3( ztUL=R!Bev`jMiT#OW%77g8Piu2e>v|^<}~WOV)9rr{v3sQ0qKP*4WPqtcqnWs;Ro$ zsd3a9z$LiAl2E!R)F09we^|j_V(0WjKDStH21)q&F&OlFxYyM0kFu3R#PnCFX1-Uj z_l6rY?6g*GNGZCT)AB#yGDEaRrMlzw?Zi2lu5Vq1{}?0({67%0%%@;Vi%Zx0I z3fu>XO`@iCx*L|BewF~hA^L>+SZj8-JZ2BmBZG^p=U}s`%1`b~6urIJV(l6H4@0)IO*sh1YKTjM1#rWY* z2*56eftp49!>9S|Qh9T?EWIQZ%iHxg;qSTat@`$Iqgvkti1dAlk3Zw%U&5~tGyi`0 F@V`LHV!!|Z literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-BUTTONS b/rooms/ROOMS-BUTTONS new file mode 100644 index 00000000..f76a5acc --- /dev/null +++ b/rooms/ROOMS-BUTTONS @@ -0,0 +1,2 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE (DEFPACKAGE "ROOMS" (USE "LISP" "XCL") (SHADOW CLROOM)) ) (IL:FILECREATED " 5-Dec-2020 16:35:05"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-BUTTONS.;3| 58830 IL:|previous| IL:|date:| "17-Aug-90 12:33:51" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-BUTTONS.;2|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-BUTTONSCOMS) (IL:RPAQQ IL:ROOMS-BUTTONSCOMS ((FILE-ENVIRONMENTS IL:ROOMS-BUTTONS) (IL:FILES (IL:SYSLOAD) IL:ROOMS-D IL:ROOMS-TEXT IL:ROOMS-BIOS) (IL:P (EXPORT '(BUTTON *DEFAULT-BUTTON-TYPE* DEF-BUTTON-TYPE MAKE-BUTTON BUTTON-PROP *BUTTON-HELP-DELAY* *BUTTON-SELECTION-SHADE* MAKE-BUTTON-WINDOW SET-BUTTON-WINDOW-TEXT-STRING WITH-BUTTON *DEFAULT-BUTTON-SHADOWS* MAKE-EAST-WEST-BITMAP MAKE-NORTH-SOUTH-BITMAP MAKE-NSEW-BITMAP) "ROOMS")) (IL:COMS (IL:* IL:\; "button types") (IL:DEFINE-TYPES IL:BUTTON-TYPES) (IL:STRUCTURES BUTTON-TYPE) (IL:VARIABLES *BUTTON-TYPES* *DEFAULT-BUTTON-TYPE*) (IL:FUNCTIONS DEF-BUTTON-TYPE BUTTON-TYPE-PROP SELECT-BUTTON-TYPE BUTTON-TYPE-NAMED ) (IL:SEDIT-FORMATS DEF-BUTTON-TYPE)) (IL:COMS (IL:* IL:\; "the button object") (IL:STRUCTURES BUTTON UPDATED-BUTTON MARGINS) (IL:VARIABLES *DEFAULT-BUTTON-SHADOWS*) (IL:FUNCTIONS (IL:* IL:\; "core code") MAKE-BUTTON COPY-BUTTON DISPLAY-BUTTON UPDATE-BUTTON SET-BUTTON-TEXT-STRING BUTTON-PROP) (IL:FUNCTIONS (IL:* IL:\; "text") SET-BUTTON-TEXT-STRING COMPUTE-BUTTON-TEXT-POSITION BUTTON-TEXT-X-COORD BUTTON-TEXT-Y-COORD TEXT-FROM-TEXT-FORM) (IL:FUNCTIONS (IL:* IL:\; "mouse code") BUTTON-TRACK-MOUSE PERFORM-BUTTON-ACTION EDIT-BUTTON BUTTON-COPY-SELECTED SHADE-BUTTON PRINT-BUTTON-HELP)) (IL:COMS (IL:* IL:\; "button windows") (IL:VARIABLES *BUTTON-HELP-DELAY* *BUTTON-SELECTION-SHADE*) (IL:FUNCTIONS MAKE-BUTTON-WINDOW BW-REPAINTFN BW-TOTOPFN BW-BUTTONEVENTFN BW-BUTTONEVENTFN-INTERNAL SET-BUTTON-WINDOW-TEXT-STRING MAYBE-RESIZE-BUTTON-WINDOW BW-SCREEN-CHANGED-FUNCTION) (IL:VARIABLES (IL:* IL:|;;|  "this variable also on ROOMS-CORE, but here so we can be loaded w/o loading all of rooms") *SCREEN-CHANGED-FUNCTIONS*) (IL:P (PUSHNEW 'BW-SCREEN-CHANGED-FUNCTION *SCREEN-CHANGED-FUNCTIONS*))) (IL:COMS (IL:* IL:\; "button bitmaps") (IL:STRUCTURES NORTH-SOUTH-BITMAP EAST-WEST-BITMAP NSEW-BITMAP) (IL:FUNCTIONS DISPLAY-BUTTON-IMAGE DISPLAY-BUTTON-MASK BUTTON-WIDTH BUTTON-HEIGHT BUTTON-BITMAP-BITBLT EW-BITBLT NS-BITBLT NSEW-BITBLT PAINT-REGION)) (IL:* IL:\; "externalization") (IL:FUNCTIONS EDIT-BUTTON-WINDOW EXTERNALIZE-BUTTON EXTERNALIZE-FONT) (IL:FUNCTIONS WITH-BUTTON) (IL:BUTTON-TYPES :DOOR :SHADOWED :TRANSPARENT :PORTHOLE :ARK :ROUND-ARK :STRETCHY-ARK :STRETCHY-ROUND-ARK) (IL:GLOBALVARS IL:MENUHELDWAIT))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-BUTTONS :COMPILER :COMPILE-FILE :PACKAGE (DEFPACKAGE "ROOMS" (:USE "LISP" "XCL") (:SHADOW CL:ROOM)) :READTABLE "XCL") (IL:FILESLOAD (IL:SYSLOAD) IL:ROOMS-D IL:ROOMS-TEXT IL:ROOMS-BIOS) (EXPORT '(BUTTON *DEFAULT-BUTTON-TYPE* DEF-BUTTON-TYPE MAKE-BUTTON BUTTON-PROP *BUTTON-HELP-DELAY* *BUTTON-SELECTION-SHADE* MAKE-BUTTON-WINDOW SET-BUTTON-WINDOW-TEXT-STRING WITH-BUTTON *DEFAULT-BUTTON-SHADOWS* MAKE-EAST-WEST-BITMAP MAKE-NORTH-SOUTH-BITMAP MAKE-NSEW-BITMAP) "ROOMS") (IL:* IL:\; "button types") (DEF-DEFINE-TYPE IL:BUTTON-TYPES "Button types" :UNDEFINER (LAMBDA (NAME) (REMHASH NAME *BUTTON-TYPES*))) (DEFSTRUCT BUTTON-TYPE NAME (IL:* IL:|;;| "name of the type") IMAGE-BITMAP (IL:* IL:|;;| "the background for the text") MASK-BITMAP (IL:* IL:|;;| "to allow non-rectangular buttons. should be a bitmap the same size as IMAGE-BITMAP. designates the set of bits of IMAGE-BITMAP which are the region to be displayed. ") (MARGINS (MAKE-MARGINS)) (IL:* IL:|;;| "a MARGINS record.") PROPS) (DEFGLOBALVAR *BUTTON-TYPES* (MAKE-HASH-TABLE :TEST 'EQ)) (DEFPARAMETER *DEFAULT-BUTTON-TYPE* :SHADOWED) (DEFDEFINER DEF-BUTTON-TYPE IL:BUTTON-TYPES (NAME &REST REST-KEYS &KEY IMAGE MASK (MARGINS ( MAKE-MARGINS )) &ALLOW-OTHER-KEYS) `(SETF (GETHASH ',NAME *BUTTON-TYPES*) (MAKE-BUTTON-TYPE :NAME ',NAME :IMAGE-BITMAP ',IMAGE :MASK-BITMAP ',MASK :MARGINS ',MARGINS :PROPS ',(LET ((PROPS (COPY-LIST REST-KEYS))) (DOLIST (KEYWORD '(:IMAGE :MASK :MARGINS)) (REMF PROPS KEYWORD)) PROPS)))) (DEFMACRO BUTTON-TYPE-PROP (BUTTON-TYPE PROP &OPTIONAL (NEW-VALUE NIL NEW-VALUE-SUPPLIED)) (IF NEW-VALUE-SUPPLIED `(SETF (GETF (BUTTON-TYPE-PROPS ,BUTTON-TYPE) ,PROP) ,NEW-VALUE) `(GETF (BUTTON-TYPE-PROPS ,BUTTON-TYPE) ,PROP))) (DEFUN SELECT-BUTTON-TYPE (&OPTIONAL (REASON "Select Button Type")) (IL:* IL:|;;| "returns the name of a button type or NIL") (MENU (WITH-COLLECTION (DOLIST (TYPE (SORT (WITH-COLLECTION (MAPHASH #'(LAMBDA (NAME TYPE) (COLLECT TYPE)) *BUTTON-TYPES*)) #'STRING-LESSP :KEY #'BUTTON-TYPE-NAME)) (LET ((NAME (BUTTON-TYPE-NAME TYPE))) (COLLECT `(,(OR (BUTTON-TYPE-PROP TYPE :SAMPLE-IMAGE) (IL:* IL:|;;| "cache sample images on button type") (LET* ((BUTTON (MAKE-BUTTON :TYPE NAME :TEXT (LET ((*PRINT-CASE* :CAPITALIZE) (*READTABLE* (IL:FIND-READTABLE "XCL"))) (PRINC-TO-STRING NAME)))) (IMAGE (IL:BITMAPCREATE (BUTTON-WIDTH BUTTON) (BUTTON-HEIGHT BUTTON)))) (DISPLAY-BUTTON BUTTON IMAGE) (BUTTON-TYPE-PROP TYPE :SAMPLE-IMAGE IMAGE) IMAGE)) ',NAME))))) REASON)) (DEFMACRO BUTTON-TYPE-NAMED (TYPE-NAME) `(GETHASH ,TYPE-NAME *BUTTON-TYPES*)) (SEDIT:DEF-LIST-FORMAT DEF-BUTTON-TYPE :ARGS (NIL :KEYWORD NIL) :INDENT (1)) (IL:* IL:\; "the button object") (DEFSTRUCT (BUTTON (:CONSTRUCTOR MAKE-BUTTON-INTERNAL) (:PRINT-FUNCTION (LAMBDA (BUTTON STREAM DEPTH) (LET ((TYPE (BUTTON-TYPE BUTTON)) (TEXT (BUTTON-TEXT BUTTON))) (FORMAT STREAM "#<~A button ~S>" (TYPECASE TYPE (BUTTON-TYPE (BUTTON-TYPE-NAME TYPE)) (T TYPE)) (TYPECASE (BUTTON-TEXT BUTTON) (TEXT (TEXT-STRING TEXT)) (T TEXT)))))) (:COPIER COPY-BUTTON-INTERNAL)) (TYPE *DEFAULT-BUTTON-TYPE* :TYPE BUTTON-TYPE) (IL:* IL:|;;| "a BUTTON-TYPE structure") (TEXT NIL :TYPE TEXT) (IL:* IL:|;;| "a TEXT structure") (ACTION NIL :TYPE LIST) (IL:* IL:|;;| "form to EVAL when this button is pressed") (HELP-STRING NIL :TYPE STRING) (IL:* IL:|;;| "printed when button is held") (INVERTED? NIL :TYPE (MEMBER T NIL)) (IL:* IL:|;;| "if true, button image will be inverted") (%SELECTED? NIL :TYPE (MEMBER T NIL)) (IL:* IL:|;;| "non-nil when button appears selected") %MASK %IMAGE (IL:* IL:|;;| "caches used by redisplay") (PROPS NIL :TYPE LIST)) (DEFSTRUCT (UPDATED-BUTTON (:INCLUDE BUTTON) (:PRINT-FUNCTION (LAMBDA (BUTTON STREAM DEPTH) (FORMAT STREAM "#" (LET ((TYPE (BUTTON-TYPE BUTTON))) (TYPECASE TYPE (BUTTON-TYPE (BUTTON-TYPE-NAME TYPE)) (T TYPE))) (UPDATED-BUTTON-TEXT-FORM BUTTON))))) (TEXT-FORM NIL :TYPE T)) (DEFSTRUCT (MARGINS (:TYPE LIST)) (IL:* IL:|;;;| "defines the region within a button intended for the text. We cannot use a region, as buttons may be strechable.") (LEFT 0 :TYPE INTEGER) (BOTTOM 0 :TYPE INTEGER) (RIGHT 0 :TYPE INTEGER) (TOP 0 :TYPE INTEGER)) (DEFVAR *DEFAULT-BUTTON-SHADOWS* NIL "Default for :SHADOWS arg to MAKE-BUTTON.\ +Overridden when button type has default shadows.") (DEFUN MAKE-BUTTON (&REST REST-KEYS &KEY (TYPE *DEFAULT-BUTTON-TYPE*) (TEXT NIL TEXT-PROVIDED) (TEXT-FORM NIL TEXT-FORM-PROVIDED) (SHADOWS NIL SHADOWS-PROVIDED) ACTION HELP FONT INVERTED? &ALLOW-OTHER-KEYS) (IL:* IL:|;;;| "make & return a button. use MAKE-BUTTON-WINDOW to put this button in a window.") (LET* ((BUTTON-TYPE (OR (IF (BUTTON-TYPE-P TYPE) TYPE) (BUTTON-TYPE-NAMED TYPE) (ERROR "No button type named ~S exists." TYPE))) (TEXT (MAKE-TEXT :STRING (IF (AND (NOT TEXT-PROVIDED) TEXT-FORM-PROVIDED) (TEXT-FROM-TEXT-FORM TEXT-FORM) TEXT) :ALIGNMENT :CENTER :FONT (IF FONT (IL:FONTCREATE FONT) *DEFAULT-TEXT-FONT*) :SHADOWS (IF SHADOWS-PROVIDED SHADOWS (IL:* IL:|;;| "default shadows per button type") (GETF (BUTTON-TYPE-PROPS BUTTON-TYPE) :DEFAULT-SHADOWS *DEFAULT-BUTTON-SHADOWS*)))) (BUTTON (APPLY (IF TEXT-FORM-PROVIDED #'MAKE-UPDATED-BUTTON #'MAKE-BUTTON-INTERNAL) :TYPE BUTTON-TYPE :TEXT TEXT :ACTION ACTION :HELP-STRING HELP :INVERTED? INVERTED? :PROPS (LET ((PROPS (COPY-LIST REST-KEYS))) (DOLIST (KEYWORD '(:TYPE :TEXT :ACTION :HELP :FONT :SHADOWS :TEXT-FORM :INVERTED?)) (REMF PROPS KEYWORD)) PROPS) (WHEN TEXT-FORM-PROVIDED `(:TEXT-FORM ,TEXT-FORM))))) (COMPUTE-BUTTON-TEXT-POSITION BUTTON) BUTTON)) (DEFUN COPY-BUTTON (OLD) (LET ((NEW (ETYPECASE OLD (UPDATED-BUTTON (COPY-UPDATED-BUTTON OLD)) (BUTTON (COPY-BUTTON-INTERNAL OLD))))) (SETF (BUTTON-TEXT NEW) (COPY-TEXT (BUTTON-TEXT OLD))) NEW)) (DEFUN DISPLAY-BUTTON (BUTTON DSP &KEY NO-UPDATE WIDTH HEIGHT) (WHEN (AND (NULL NO-UPDATE) (OR WIDTH HEIGHT)) (ERROR "Illegal to pass WIDTH & HEIGHT unless NO-UPDATE specified")) (UNLESS NO-UPDATE (UPDATE-BUTTON BUTTON)) (LET* ((WIDTH (OR WIDTH (BUTTON-WIDTH BUTTON))) (HEIGHT (OR HEIGHT (BUTTON-HEIGHT BUTTON))) (TYPE (BUTTON-TYPE BUTTON))) (WHEN (OR (BUTTON-TYPE-MASK-BITMAP TYPE) (NOT (BUTTON-TYPE-IMAGE-BITMAP TYPE))) (IL:* IL:|;;| "erase what's in the mask (or if button is transparent)") (DISPLAY-BUTTON-MASK BUTTON DSP WIDTH HEIGHT)) (IL:* IL:|;;| "paint the image on") (DISPLAY-BUTTON-IMAGE BUTTON DSP WIDTH HEIGHT) (WHEN (BUTTON-%SELECTED? BUTTON) (IL:* IL:|;;| "rationalize the selection") (SETF (BUTTON-%SELECTED? BUTTON) NIL) (SHADE-BUTTON BUTTON DSP)))) (DEFUN UPDATE-BUTTON (BUTTON DSP) (IL:* IL:|;;;| "should really be called BUTTON-NEEDS-REDISPLAY?") (WHEN (UPDATED-BUTTON-P BUTTON) (IL:* IL:|;;| "set the text string of WINDOW's BUTTON to the value of its TEXT-FORM.") (LET ((NEW-TEXT-STRING (TEXT-FROM-TEXT-FORM (UPDATED-BUTTON-TEXT-FORM BUTTON) DSP BUTTON))) (UNLESS (EQUAL NEW-TEXT-STRING (TEXT-STRING (BUTTON-TEXT BUTTON))) (IL:* IL:|;;| "optimization: don't bother if string is same") (SET-BUTTON-TEXT-STRING BUTTON NEW-TEXT-STRING) (IL:* IL:|;;| "return T if things have changed") (RETURN-FROM UPDATE-BUTTON T)))) (IL:* IL:|;;| "a null image cache means button needs redisplay") (NULL (BUTTON-%IMAGE BUTTON))) (DEFUN SET-BUTTON-TEXT-STRING (BUTTON STRING) (IL:* IL:|;;;| "does everything but redisplay") (SET-TEXT-STRING (BUTTON-TEXT BUTTON) STRING) (COMPUTE-BUTTON-TEXT-POSITION BUTTON) (IL:* IL:|;;| "clear caches") (SETF (BUTTON-%MASK BUTTON) NIL) (SETF (BUTTON-%IMAGE BUTTON) NIL)) (DEFMACRO BUTTON-PROP (BUTTON PROP &OPTIONAL (NEW-VALUE NIL NEW-VALUE-SUPPLIED)) (IF NEW-VALUE-SUPPLIED `(SETF (GETF (BUTTON-PROPS ,BUTTON) ,PROP) ,NEW-VALUE) `(GETF (BUTTON-PROPS ,BUTTON) ,PROP))) (DEFUN SET-BUTTON-TEXT-STRING (BUTTON STRING) (IL:* IL:|;;;| "does everything but redisplay") (SET-TEXT-STRING (BUTTON-TEXT BUTTON) STRING) (COMPUTE-BUTTON-TEXT-POSITION BUTTON) (IL:* IL:|;;| "clear caches") (SETF (BUTTON-%MASK BUTTON) NIL) (SETF (BUTTON-%IMAGE BUTTON) NIL)) (DEFUN COMPUTE-BUTTON-TEXT-POSITION (BUTTON) (SETF (TEXT-POSITION (BUTTON-TEXT BUTTON)) (MAKE-POSITION (BUTTON-TEXT-X-COORD BUTTON) (BUTTON-TEXT-Y-COORD BUTTON)))) (DEFUN BUTTON-TEXT-X-COORD (BUTTON) (LET ((TEXT (BUTTON-TEXT BUTTON)) (MARGINS (BUTTON-TYPE-MARGINS (BUTTON-TYPE BUTTON)))) (ECASE (TEXT-ALIGNMENT TEXT) (:CENTER (+ (MARGINS-LEFT MARGINS) (FLOOR (MAX (TEXT-%WIDTH TEXT) (- (BUTTON-WIDTH BUTTON) (MARGINS-LEFT MARGINS) (MARGINS-RIGHT MARGINS))) 2))) ((:LEFT-BOTTOM :LEFT-TOP) (MARGINS-LEFT MARGINS)) ((:RIGHT-BOTTOM :RIGHT-TOP) (MARGINS-RIGHT MARGINS))))) (DEFUN BUTTON-TEXT-Y-COORD (BUTTON) (LET ((TEXT (BUTTON-TEXT BUTTON)) (MARGINS (BUTTON-TYPE-MARGINS (BUTTON-TYPE BUTTON)))) (ECASE (TEXT-ALIGNMENT TEXT) (:CENTER (+ (MARGINS-BOTTOM MARGINS) (FLOOR (MAX (TEXT-%HEIGHT TEXT) (- (BUTTON-HEIGHT BUTTON) (MARGINS-BOTTOM MARGINS) (MARGINS-TOP MARGINS))) 2))) ((:LEFT-BOTTOM :RIGHT-BOTTOM) (MARGINS-BOTTOM MARGINS)) ((:LEFT-TOP :RIGHT-TOP) (MARGINS-TOP MARGINS))))) (DEFUN TEXT-FROM-TEXT-FORM (TEXT-FORM &OPTIONAL DSP BUTTON) (IL:* IL:|;;;| "return the text string for an updated button in WINDOW.") (TYPECASE TEXT-FORM (LIST (EVAL TEXT-FORM)) (IL:* IL:|;;| "note: when an updated button is first created this is called with WINDOW=NIL. text form functions are required to handle this condition gracefully. ") (T (FUNCALL TEXT-FORM DSP BUTTON)))) (DEFUN BUTTON-TRACK-MOUSE (BUTTON DSP) (IL:* IL:|;;;| "a mouse key has gone down in BUTTON. watch the mouse with button shaded 'til either the key goes up or the mouse leaves BUTTON. if key went up then perform button action & return true. ") (LET ((REGION (MAKE-REGION :LEFT 0 :BOTTOM 0 :WIDTH (BUTTON-WIDTH BUTTON) :HEIGHT (BUTTON-HEIGHT BUTTON))) (TIMER (IL:SETUPTIMER *BUTTON-HELP-DELAY*))) (UNWIND-PROTECT (PROGN (SHADE-BUTTON BUTTON DSP :REGION REGION) (LOOP (IL:GETMOUSESTATE) (UNLESS (IL:INSIDEP REGION (IL:LASTMOUSEX DSP) (IL:LASTMOUSEY DSP)) (RETURN)) (UNLESS (IL:LASTMOUSESTATE (OR IL:LEFT IL:MIDDLE)) (PERFORM-BUTTON-ACTION BUTTON DSP) (IL:* IL:|;;| "return true if we performed action") (RETURN T)) (WHEN (AND TIMER (IL:TIMEREXPIRED? TIMER)) (SETQ TIMER NIL) (PRINT-BUTTON-HELP BUTTON)))) (SHADE-BUTTON BUTTON DSP :REGION REGION :DESELECT T)))) (DEFUN PERFORM-BUTTON-ACTION (BUTTON DSP) (LET ((ACTION (BUTTON-ACTION BUTTON))) (TYPECASE ACTION (LIST (EVAL ACTION)) (T (FUNCALL ACTION DSP BUTTON))))) (DEFUN EDIT-BUTTON (BUTTON) (IL:ALLOW.BUTTON.EVENTS) (LET* ((EXTERNAL-FORM (EXTERNALIZE-BUTTON BUTTON T)) (COPY (COPY-TREE EXTERNAL-FORM)) (EDITED (WITH-PROFILE (FIND-PROFILE "XCL") (IL:EDITE EXTERNAL-FORM NIL (TEXT-STRING (BUTTON-TEXT BUTTON)) NIL NIL :CLOSE-ON-COMPLETION)))) (IF (EQUAL EDITED COPY) BUTTON (APPLY #'MAKE-BUTTON EDITED)))) (DEFUN BUTTON-COPY-SELECTED (BUTTON) (IF (FBOUNDP 'MAKE-BIO) (IL:* IL:|;;| "if ROOMS-BIO is loaded") (LET* ((DESTINATION (IL:WFROMDS (IL:PROCESS.TTY (IL:TTY.PROCESS)))) (COPYINSERTFN (AND DESTINATION (IL:WINDOWPROP DESTINATION 'IL:COPYINSERTFN)))) (IL:* IL:|;;|  "fake IL:COPYINSERT, but instead of punting to IL:BKSYSBUF punt to copying the window") (IF COPYINSERTFN (FUNCALL COPYINSERTFN (MAKE-BIO (COPY-BUTTON BUTTON)) DESTINATION) (MAKE-BUTTON-WINDOW (COPY-BUTTON BUTTON)))) (MAKE-BUTTON-WINDOW (COPY-BUTTON BUTTON)))) (DEFUN SHADE-BUTTON (BUTTON DSP &KEY (REGION (MAKE-REGION :LEFT 0 :BOTTOM 0 :WIDTH (  BUTTON-WIDTH BUTTON) :HEIGHT (BUTTON-HEIGHT BUTTON))) DESELECT) (IL:* IL:|;;;| "called when mouse key down in BUTTON.") (IL:* IL:|;;| "DESELECT? tells the intention of the call.") (IL:* IL:|;;| "see also DISPLAY-BUTTON") (LET ((MASK (BUTTON-%MASK BUTTON)) (SELECTED? (BUTTON-%SELECTED? BUTTON))) (WHEN (EQ DESELECT SELECTED?) (IL:* IL:|;;| "invert MASK with *BUTTON-SELECTION-SHADE*") (IL:BITBLT MASK NIL NIL DSP 0 0 (REGION-WIDTH REGION) (REGION-HEIGHT REGION) (IF (NULL MASK) 'IL:TEXTURE 'IL:MERGE) 'IL:INVERT *BUTTON-SELECTION-SHADE*) (IL:* IL:|;;| "toggle SELECTED? bit") (SETF (BUTTON-%SELECTED? BUTTON) (NOT SELECTED?))))) (DEFUN PRINT-BUTTON-HELP (BUTTON) (NOTIFY-USER (OR (BUTTON-HELP-STRING BUTTON) "No help provided for this button."))) (IL:* IL:\; "button windows") (DEFGLOBALVAR *BUTTON-HELP-DELAY* IL:MENUHELDWAIT) (DEFPARAMETER *BUTTON-SELECTION-SHADE* 32768) (DEFUN MAKE-BUTTON-WINDOW (BUTTON &OPTIONAL POSITION) (LET* ((WIDTH (BUTTON-WIDTH BUTTON)) (HEIGHT (BUTTON-HEIGHT BUTTON)) (POSITION (OR (IL:POSITIONP POSITION) (IL:GETBOXPOSITION WIDTH HEIGHT))) (WINDOW (IL:CREATEW (IL:CREATEREGION (POSITION-X POSITION) (POSITION-Y POSITION) WIDTH HEIGHT) NIL 0))) (IL:WINDOWPROP WINDOW 'BUTTON BUTTON) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'BW-BUTTONEVENTFN) (IL:WINDOWPROP WINDOW 'IL:AFTERMOVEFN 'BW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:OPENFN 'BW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:TOTOPFN 'BW-TOTOPFN) (IL:WINDOWPROP WINDOW 'IL:REPAINTFN 'BW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'IL:DON\'T) (IL:WINDOWPROP WINDOW 'IL:SHRINKFN 'IL:DON\'T) (WHEN (BUTTON-PROP BUTTON :PROTECTED?) (IL:WINDOWPROP WINDOW 'IL:RIGHTBUTTONFN 'IL:TOTOPW)) (BW-REPAINTFN WINDOW) WINDOW)) (DEFUN BW-REPAINTFN (WINDOW &REST REST &KEY NO-UPDATE) (DECLARE (IGNORE REST)) (IL:TOTOPW WINDOW T) (LET* ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON)) (DSP (IL:WINDOWPROP WINDOW 'IL:DSP)) (TYPE (BUTTON-TYPE BUTTON))) (UNLESS NO-UPDATE (WHEN (UPDATED-BUTTON-P BUTTON) (UPDATE-BUTTON BUTTON))) (LET ((WIDTH (BUTTON-WIDTH BUTTON)) (HEIGHT (BUTTON-HEIGHT BUTTON))) (MAYBE-RESIZE-BUTTON-WINDOW WINDOW BUTTON WIDTH HEIGHT) (IF (AND (BUTTON-TYPE-IMAGE-BITMAP TYPE) (NOT (BUTTON-TYPE-MASK-BITMAP TYPE))) (IL:* IL:|;;| "OK to clear - don't care what's behind ") (IL:CLEARW WINDOW) (IL:* IL:|;;| "copy what's behind the window through ") (IL:BITBLT (IL:WINDOWPROP WINDOW 'IL:IMAGECOVERED) 0 0 DSP 0 0 WIDTH HEIGHT 'IL:INPUT 'IL:REPLACE)) (DISPLAY-BUTTON BUTTON DSP :NO-UPDATE T :WIDTH WIDTH :HEIGHT HEIGHT)))) (DEFUN BW-TOTOPFN (WINDOW) (IL:* IL:|;;| "called when window is un-hidden or brought to top") (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (WHEN (BUTTON-P BUTTON) (WHEN (OR (IL:* IL:|;;| "needs redisplay because of update") (UPDATE-BUTTON BUTTON) (IL:* IL:|;;| "or it has a mask & needs background copied through") (BUTTON-TYPE-MASK-BITMAP (BUTTON-TYPE BUTTON)) (IL:* IL:|;;|  "or it has no mask and no image, i.e. it's transparent & needs background copied through.") (NULL (BUTTON-TYPE-IMAGE-BITMAP (BUTTON-TYPE BUTTON)))) (BW-REPAINTFN WINDOW :NO-UPDATE T))))) (DEFUN BW-BUTTONEVENTFN (WINDOW) (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (IF (IL:MOUSESTATE IL:MIDDLE) (COND ((BUTTON-PROP BUTTON :PROTECTED?) (BW-BUTTONEVENTFN-INTERNAL BUTTON WINDOW)) ((EDIT-KEY-DOWN-P) (EDIT-BUTTON-WINDOW BUTTON WINDOW)) ((COPY-KEY-DOWN-P) (BUTTON-COPY-SELECTED BUTTON)) ((MOVE-KEY-DOWN-P) (IL:MOVEW WINDOW)) ((DELETE-KEY-DOWN-P) (IF (FBOUNDP 'INTERACTIVE-CLOSE-WINDOW) (INTERACTIVE-CLOSE-WINDOW WINDOW) (CLOSE-WINDOW WINDOW))) ((HELP-KEY-DOWN-P) (PRINT-BUTTON-HELP BUTTON)) (T (BW-BUTTONEVENTFN-INTERNAL BUTTON WINDOW))) (BW-BUTTONEVENTFN-INTERNAL BUTTON WINDOW)))) (DEFUN BW-BUTTONEVENTFN-INTERNAL (WINDOW BUTTON) (LET ((WINDOW WINDOW) (BUTTON BUTTON)) (LOOP (WHEN (BUTTON-P BUTTON) (IL:TOTOPW WINDOW) (WHEN (BUTTON-TRACK-MOUSE BUTTON WINDOW) (WHEN (UPDATE-BUTTON BUTTON) (IL:* IL:|;;| "button's action caused it to need redisplay") (BW-REPAINTFN WINDOW :NO-UPDATE T)) (RETURN))) (UNLESS (IL:MOUSESTATE (OR IL:LEFT IL:MIDDLE)) (RETURN)) (SETQ WINDOW (IL:WHICHW)) (SETQ BUTTON (WHEN WINDOW (IL:WINDOWPROP WINDOW 'BUTTON)))))) (DEFUN SET-BUTTON-WINDOW-TEXT-STRING (WINDOW STRING) (IL:* IL:|;;;| "note: this does everything but the redisplay.") (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (SET-BUTTON-TEXT-STRING BUTTON STRING) (MAYBE-RESIZE-BUTTON-WINDOW WINDOW BUTTON))) (DEFUN MAYBE-RESIZE-BUTTON-WINDOW (WINDOW BUTTON &OPTIONAL (WIDTH (BUTTON-WIDTH BUTTON)) (HEIGHT (BUTTON-HEIGHT BUTTON))) (LET ((OLD-REGION (WINDOW-REGION WINDOW))) (UNLESS (AND (= WIDTH (REGION-WIDTH OLD-REGION)) (= HEIGHT (REGION-HEIGHT OLD-REGION))) (UNWIND-PROTECT (PROGN (IL:TOTOPW WINDOW T) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'IL:NILL) (IL:SHAPEW1 WINDOW (MAKE-REGION :LEFT (REGION-LEFT OLD-REGION) :BOTTOM (REGION-BOTTOM OLD-REGION) :WIDTH WIDTH :HEIGHT HEIGHT)) (IL:* IL:|;;| "return true if we shaped") T) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'IL:DON\'T))))) (DEFUN BW-SCREEN-CHANGED-FUNCTION () (LET ((OLD-DEFAULT-FONT *DEFAULT-TEXT-FONT*) (NEW-DEFAULT-FONT (SET-DEFAULT-TEXT-FONT))) (UNLESS (EQ OLD-DEFAULT-FONT NEW-DEFAULT-FONT) (DOLIST (WINDOW (ALL-WINDOWS T)) (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (WHEN (AND (BUTTON-P BUTTON) (EQ OLD-DEFAULT-FONT (TEXT-FONT (BUTTON-TEXT BUTTON)))) (IL:* IL:|;;| "upgrade buttons with default font") (SETF (TEXT-FONT (BUTTON-TEXT BUTTON)) NEW-DEFAULT-FONT) (UPDATE-TEXT-CACHES (BUTTON-TEXT BUTTON)) (COMPUTE-BUTTON-TEXT-POSITION BUTTON) (IL:* IL:|;;| "force redisplay") (SETF (BUTTON-%IMAGE BUTTON) NIL) (SETF (BUTTON-%MASK BUTTON) NIL))))))) (DEFGLOBALVAR *SCREEN-CHANGED-FUNCTIONS* (LIST '%INTERNALIZE-ALL-PLACEMENTS)) (PUSHNEW 'BW-SCREEN-CHANGED-FUNCTION *SCREEN-CHANGED-FUNCTIONS*) (IL:* IL:\; "button bitmaps") (DEFSTRUCT (NORTH-SOUTH-BITMAP (:CONC-NAME "NS-BITMAP-")) NORTH CENTER SOUTH) (DEFSTRUCT (EAST-WEST-BITMAP (:CONC-NAME "EW-BITMAP-")) EAST CENTER WEST) (DEFSTRUCT NSEW-BITMAP NORTH NW NE SOUTH SW SE EAST CENTER WEST) (DEFUN DISPLAY-BUTTON-IMAGE (BUTTON DSP WIDTH HEIGHT) (LET ((CACHED-IMAGE (BUTTON-%IMAGE BUTTON)) (INVERTED? (BUTTON-INVERTED? BUTTON)) (MASK? (BUTTON-%MASK BUTTON))) (UNLESS CACHED-IMAGE (SETQ CACHED-IMAGE (IL:BITMAPCREATE WIDTH HEIGHT)) (LET ((TYPE-IMAGE (BUTTON-TYPE-IMAGE-BITMAP (BUTTON-TYPE BUTTON)))) (WHEN TYPE-IMAGE (BUTTON-BITMAP-BITBLT TYPE-IMAGE CACHED-IMAGE WIDTH HEIGHT))) (DISPLAY-TEXT (BUTTON-TEXT BUTTON) CACHED-IMAGE) (SETF (BUTTON-%IMAGE BUTTON) CACHED-IMAGE)) (IL:BITBLT CACHED-IMAGE 0 0 DSP 0 0 WIDTH HEIGHT (IF (AND INVERTED? (NOT MASK?)) 'IL:INVERT 'IL:SOURCE) (IF (AND INVERTED? MASK?) 'IL:INVERT 'IL:PAINT)))) (DEFUN DISPLAY-BUTTON-MASK (BUTTON DSP WIDTH HEIGHT) (LET ((CACHED-MASK (BUTTON-%MASK BUTTON))) (UNLESS CACHED-MASK (SETQ CACHED-MASK (IL:BITMAPCREATE WIDTH HEIGHT)) (LET ((TYPE-MASK (BUTTON-TYPE-MASK-BITMAP (BUTTON-TYPE BUTTON)))) (WHEN TYPE-MASK (BUTTON-BITMAP-BITBLT TYPE-MASK CACHED-MASK WIDTH HEIGHT))) (DISPLAY-TEXT (BUTTON-TEXT BUTTON) CACHED-MASK :MASK-ONLY T) (SETF (BUTTON-%MASK BUTTON) CACHED-MASK)) (IL:BITBLT CACHED-MASK 0 0 DSP 0 0 WIDTH HEIGHT 'IL:SOURCE (IF (BUTTON-INVERTED? BUTTON) 'IL:PAINT 'IL:ERASE)))) (DEFUN BUTTON-WIDTH (BUTTON) (LET* ((BUTTON-TYPE (BUTTON-TYPE BUTTON)) (MARGINS (BUTTON-TYPE-MARGINS BUTTON-TYPE)) (BITMAP (BUTTON-TYPE-IMAGE-BITMAP BUTTON-TYPE)) (TEXT-WIDTH (TEXT-%WIDTH (BUTTON-TEXT BUTTON)))) (ETYPECASE BITMAP (BITMAP (IL:BITMAPWIDTH BITMAP)) (NULL TEXT-WIDTH) (NORTH-SOUTH-BITMAP (IL:BITMAPWIDTH (NS-BITMAP-NORTH BITMAP))) ((OR NSEW-BITMAP EAST-WEST-BITMAP) (LET* ((WIDTH (+ TEXT-WIDTH (MARGINS-LEFT MARGINS) (MARGINS-RIGHT MARGINS))) (EAST-WIDTH (IL:BITMAPWIDTH (TYPECASE BITMAP (NSEW-BITMAP ( NSEW-BITMAP-EAST BITMAP)) (EAST-WEST-BITMAP (EW-BITMAP-EAST BITMAP)))) ) (CENTER-WIDTH (IL:BITMAPWIDTH (TYPECASE BITMAP (NSEW-BITMAP (NSEW-BITMAP-CENTER BITMAP)) (EAST-WEST-BITMAP (EW-BITMAP-CENTER BITMAP))))) (WEST-WIDTH (IL:BITMAPWIDTH (TYPECASE BITMAP (NSEW-BITMAP ( NSEW-BITMAP-WEST BITMAP)) (EAST-WEST-BITMAP (EW-BITMAP-WEST BITMAP)))) )) (IL:* IL:|;;| "we could use WIDTH directly but we'd rather tile in an even number of CENTER bitmaps, in case it's a pattern that needs to blend with the EAST and WEST.") (MAX (+ WIDTH (- CENTER-WIDTH (MOD (- WIDTH EAST-WIDTH WEST-WIDTH) CENTER-WIDTH))) (+ EAST-WIDTH WEST-WIDTH))))))) (DEFUN BUTTON-HEIGHT (BUTTON) (LET* ((BUTTON-TYPE (BUTTON-TYPE BUTTON)) (MARGINS (BUTTON-TYPE-MARGINS BUTTON-TYPE)) (BITMAP (BUTTON-TYPE-IMAGE-BITMAP BUTTON-TYPE)) (TEXT-HEIGHT (TEXT-%HEIGHT (BUTTON-TEXT BUTTON)))) (ETYPECASE BITMAP (BITMAP (IL:BITMAPHEIGHT BITMAP)) (NULL TEXT-HEIGHT) (EAST-WEST-BITMAP (IL:BITMAPHEIGHT (EW-BITMAP-EAST BITMAP))) ((OR NSEW-BITMAP NORTH-SOUTH-BITMAP) (LET* ((HEIGHT (+ TEXT-HEIGHT (MARGINS-BOTTOM MARGINS) (MARGINS-TOP MARGINS))) (NORTH-HEIGHT (IL:BITMAPHEIGHT (TYPECASE BITMAP (NSEW-BITMAP (NSEW-BITMAP-NORTH BITMAP)) (NORTH-SOUTH-BITMAP (NS-BITMAP-NORTH BITMAP))))) (CENTER-HEIGHT (IL:BITMAPHEIGHT (TYPECASE BITMAP (NSEW-BITMAP (NSEW-BITMAP-CENTER BITMAP)) (NORTH-SOUTH-BITMAP (NS-BITMAP-CENTER BITMAP))))) (SOUTH-HEIGHT (IL:BITMAPHEIGHT (TYPECASE BITMAP (NSEW-BITMAP (NSEW-BITMAP-SOUTH BITMAP)) (NORTH-SOUTH-BITMAP (NS-BITMAP-SOUTH BITMAP)))))) (IL:* IL:|;;| "we could use HEIGHT directly but we'd rather tile in an even number of CENTER bitmaps, in case it's a pattern that needs to blend with the EAST and WEST.") (MAX (+ HEIGHT (- CENTER-HEIGHT (MOD (- HEIGHT NORTH-HEIGHT SOUTH-HEIGHT) CENTER-HEIGHT))) (+ NORTH-HEIGHT SOUTH-HEIGHT))))))) (DEFUN BUTTON-BITMAP-BITBLT (BITMAP DESTINATION WIDTH HEIGHT) (ETYPECASE BITMAP (BITMAP (IL:BITBLT BITMAP 0 0 DESTINATION 0 0 WIDTH HEIGHT)) (EAST-WEST-BITMAP (EW-BITBLT (EW-BITMAP-WEST BITMAP) (EW-BITMAP-CENTER BITMAP) (EW-BITMAP-EAST BITMAP) DESTINATION WIDTH 0)) (NORTH-SOUTH-BITMAP (NS-BITBLT (NS-BITMAP-SOUTH BITMAP) (NS-BITMAP-CENTER BITMAP) (NS-BITMAP-NORTH BITMAP) DESTINATION HEIGHT 0)) (NSEW-BITMAP (NSEW-BITBLT BITMAP DESTINATION WIDTH HEIGHT)))) (DEFUN EW-BITBLT (WEST CENTER EAST DESTINATION WIDTH BOTTOM) (LET* ((WEST-WIDTH (IL:BITMAPWIDTH WEST)) (CENTER-WIDTH (IL:BITMAPWIDTH CENTER)) (EAST-WIDTH (IL:BITMAPWIDTH EAST)) (EAST-LEFT (- WIDTH EAST-WIDTH)) (HEIGHT (IL:BITMAPHEIGHT CENTER))) (IL:* IL:|;;| "blt the west bitmap down the left ") (IL:BITBLT WEST 0 0 DESTINATION 0 BOTTOM WEST-WIDTH HEIGHT) (WHEN (> EAST-LEFT WEST-WIDTH) (IL:* IL:|;;| "blt in one copy of center") (IL:BITBLT CENTER 0 0 DESTINATION WEST-WIDTH BOTTOM CENTER-WIDTH HEIGHT) (DO* ((WIDTH CENTER-WIDTH (+ WIDTH WIDTH)) (LEFT (+ WEST-WIDTH WIDTH) (+ WEST-WIDTH WIDTH))) ((>= LEFT EAST-LEFT)) (IL:* IL:|;;| "blt the center bitmap across the middle") (IL:BITBLT DESTINATION WEST-WIDTH BOTTOM DESTINATION LEFT BOTTOM (MIN WIDTH (- EAST-LEFT LEFT)) HEIGHT))) (IL:* IL:|;;| "blt the east bitmap on the right end") (IL:BITBLT EAST 0 0 DESTINATION EAST-LEFT BOTTOM EAST-WIDTH HEIGHT))) (DEFUN NS-BITBLT (SOUTH CENTER NORTH DESTINATION HEIGHT LEFT &OPTIONAL (DO-ENDS? T)) (LET* ((SOUTH-HEIGHT (IL:BITMAPHEIGHT SOUTH)) (CENTER-HEIGHT (IL:BITMAPHEIGHT CENTER)) (NORTH-HEIGHT (IL:BITMAPHEIGHT NORTH)) (NORTH-BOTTOM (- HEIGHT NORTH-HEIGHT)) (WIDTH (IL:BITMAPWIDTH CENTER))) (WHEN DO-ENDS? (IL:* IL:|;;| "blt the south bitmap across the bottom") (IL:BITBLT SOUTH 0 0 DESTINATION LEFT 0 WIDTH SOUTH-HEIGHT)) (WHEN (> NORTH-BOTTOM SOUTH-HEIGHT) (IL:* IL:|;;| "blt in one copy of center") (IL:BITBLT CENTER 0 0 DESTINATION LEFT SOUTH-HEIGHT WIDTH CENTER-HEIGHT) (DO* ((HEIGHT CENTER-HEIGHT (+ HEIGHT HEIGHT)) (BOTTOM (+ SOUTH-HEIGHT HEIGHT) (+ SOUTH-HEIGHT HEIGHT))) ((>= BOTTOM NORTH-BOTTOM)) (IL:* IL:|;;| "blt the center bitmap up the middle") (IL:BITBLT DESTINATION LEFT SOUTH-HEIGHT DESTINATION LEFT BOTTOM WIDTH (MIN HEIGHT (- NORTH-BOTTOM BOTTOM))))) (WHEN DO-ENDS? (IL:* IL:|;;| "blt the north bitmap across the top") (IL:BITBLT NORTH 0 0 DESTINATION LEFT NORTH-BOTTOM WIDTH NORTH-HEIGHT)))) (DEFUN NSEW-BITBLT (NSEW-BITMAP DESTINATION WIDTH HEIGHT) (LET* ((SW (NSEW-BITMAP-SW NSEW-BITMAP)) (SE (NSEW-BITMAP-SE NSEW-BITMAP)) (NW (NSEW-BITMAP-NW NSEW-BITMAP)) (NE (NSEW-BITMAP-NE NSEW-BITMAP)) (NORTH-BOTTOM (- HEIGHT (IL:BITMAPHEIGHT NW))) (EAST-LEFT (- WIDTH (IL:BITMAPWIDTH SE)))) (IL:* IL:|;;| "across the bottom") (EW-BITBLT SW (NSEW-BITMAP-SOUTH NSEW-BITMAP) SE DESTINATION WIDTH 0) (IL:* IL:|;;| "across the top") (EW-BITBLT NW (NSEW-BITMAP-NORTH NSEW-BITMAP) NE DESTINATION WIDTH NORTH-BOTTOM) (IL:* IL:|;;| "up the left") (NS-BITBLT SW (NSEW-BITMAP-WEST NSEW-BITMAP) NW DESTINATION HEIGHT 0 NIL) (IL:* IL:|;;| "up the right") (NS-BITBLT SE (NSEW-BITMAP-EAST NSEW-BITMAP) NE DESTINATION HEIGHT EAST-LEFT NIL) (IL:* IL:|;;| "tile the center") (PAINT-REGION DESTINATION (LET ((LEFT (IL:BITMAPWIDTH SW)) (BOTTOM (IL:BITMAPHEIGHT SW))) (MAKE-REGION :LEFT LEFT :BOTTOM BOTTOM :WIDTH (- EAST-LEFT LEFT) :HEIGHT (- NORTH-BOTTOM BOTTOM))) (NSEW-BITMAP-CENTER NSEW-BITMAP)))) (DEFUN PAINT-REGION (DESTINATION REGION SHADE &OPTIONAL CLIPPING-REGION) (IL:* IL:|;;| "fill REGION of DESTINATION with SHADE") (TYPECASE SHADE (BITMAP (IL:* IL:|;;| "tile the bitmap within REGION") (LET* ((REGION-LEFT (REGION-LEFT REGION)) (REGION-BOTTOM (REGION-BOTTOM REGION)) (REGION-WIDTH (REGION-WIDTH REGION)) (REGION-HEIGHT (REGION-HEIGHT REGION)) (BITMAP-WIDTH (IL:BITMAPWIDTH SHADE)) (BITMAP-HEIGHT (IL:BITMAPHEIGHT SHADE)) (REGION-RIGHT (+ REGION-LEFT REGION-WIDTH)) (REGION-TOP (+ REGION-BOTTOM REGION-HEIGHT)) (CLIPPING-REGION (IF CLIPPING-REGION (IL:INTERSECTREGIONS CLIPPING-REGION REGION) REGION))) (IL:* IL:|;;| "blt in one copy in lower left corner") (IL:BITBLT SHADE 0 0 DESTINATION REGION-LEFT REGION-BOTTOM BITMAP-WIDTH BITMAP-HEIGHT NIL NIL NIL CLIPPING-REGION) (IL:* IL:|;;| "blt across bottom, doubling size each time") (LET ((LEFT BITMAP-WIDTH)) (LOOP (WHEN (>= LEFT REGION-RIGHT) (RETURN)) (IL:BITBLT DESTINATION REGION-LEFT REGION-BOTTOM DESTINATION (+ LEFT REGION-LEFT) REGION-BOTTOM LEFT BITMAP-HEIGHT NIL NIL NIL CLIPPING-REGION) (SETF LEFT (+ LEFT LEFT)))) (IL:* IL:|;;| "blt up, doubling size each time") (LET ((BOTTOM BITMAP-HEIGHT)) (LOOP (WHEN (>= BOTTOM REGION-TOP) (RETURN)) (IL:BITBLT DESTINATION REGION-LEFT REGION-BOTTOM DESTINATION REGION-LEFT (+ REGION-BOTTOM BOTTOM) REGION-WIDTH BOTTOM NIL NIL NIL CLIPPING-REGION) (SETF BOTTOM (+ BOTTOM BOTTOM)))))) (TEXTURE (IL:* IL:|;;| "squirt the texture onto the screen within REGION") (IL:BLTSHADE SHADE DESTINATION (REGION-LEFT REGION) (REGION-BOTTOM REGION) (REGION-WIDTH REGION) (REGION-HEIGHT REGION) NIL CLIPPING-REGION)))) (IL:* IL:\; "externalization") (DEFUN EDIT-BUTTON-WINDOW (BUTTON WINDOW) (UNLESS (IL:WINDOWPROP WINDOW 'BUTTON-BEING-EDITED) (UNWIND-PROTECT (PROGN (IL:WINDOWPROP WINDOW 'BUTTON-BEING-EDITED T) (LET ((NEW-BUTTON (EDIT-BUTTON BUTTON))) (UNLESS (EQ BUTTON NEW-BUTTON) (IL:WINDOWPROP WINDOW 'BUTTON NEW-BUTTON) (BW-REPAINTFN WINDOW)))) (IL:REMWINDOWPROP WINDOW 'BUTTON-BEING-EDITED)))) (DEFUN EXTERNALIZE-BUTTON (BUTTON &OPTIONAL VERBOSE) (IL:* IL:|;;;| "returns a property list to which MAKE-BUTTON can be applied") (LET* ((TEXT (BUTTON-TEXT BUTTON)) (TYPE (BUTTON-TYPE BUTTON)) (TYPE-NAME (BUTTON-TYPE-NAME TYPE)) (SHADOWS (TEXT-SHADOWS TEXT)) (FONT (TEXT-FONT TEXT)) (INVERTED? (BUTTON-INVERTED? BUTTON))) `(,@(ETYPECASE BUTTON (UPDATED-BUTTON `(:TEXT-FORM ,(UPDATED-BUTTON-TEXT-FORM BUTTON))) (BUTTON `(:TEXT ,(TEXT-STRING TEXT)))) :ACTION ,(COPY-TREE (BUTTON-ACTION BUTTON)) :HELP ,(BUTTON-HELP-STRING BUTTON) ,@(WHEN (OR VERBOSE (NOT (EQ FONT *DEFAULT-TEXT-FONT*))) (LIST :FONT (EXTERNALIZE-FONT FONT))) ,@(WHEN (OR VERBOSE (NOT (EQUAL SHADOWS (GETF (BUTTON-TYPE-PROPS TYPE) :DEFAULT-SHADOWS *DEFAULT-BUTTON-SHADOWS*))) ) (LIST :SHADOWS (EXTERNALIZE-TEXT-SHADOWS SHADOWS))) ,@(WHEN (OR (NULL TYPE-NAME) VERBOSE (NOT (EQUAL TYPE-NAME *DEFAULT-BUTTON-TYPE*))) (LIST :TYPE (IF (NULL TYPE-NAME) TYPE TYPE-NAME))) ,@(WHEN (OR VERBOSE INVERTED?) (LIST :INVERTED? INVERTED?)) ,@(COPY-TREE (BUTTON-PROPS BUTTON))))) (DEFUN EXTERNALIZE-FONT (FONT) (LIST (IL:FONTPROP FONT 'IL:FAMILY) (IL:FONTPROP FONT 'IL:SIZE) (IL:FONTPROP FONT 'IL:FACE))) (DEFUN WITH-BUTTON (ACTION TEXT HELP) (IF (COPY-KEY-DOWN-P) (PROG1 NIL (MAKE-BUTTON-WINDOW (MAKE-BUTTON :TYPE *DEFAULT-BUTTON-TYPE* :TEXT TEXT :HELP HELP :ACTION ACTION) TEXT HELP)) (EVAL ACTION))) (DEF-BUTTON-TYPE :DOOR :IMAGE #*(59 99)OOOOOOOOOOOOOON@OOOOOOOOOOOOOON@OOOOOOOOOOOOOON@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@OOOOL@OOOOL@N@L@OOOOL@OOOOL@N@L@L@@@L@L@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@OOOLL@OOONL@N@L@OOOOL@OOOOL@N@L@OOOOL@OOOOL@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@OOOOL@OOOOL@N@L@OOOOL@OOOOL@N@L@L@@@L@L@@@L@N@L@LBBBL@LBBBL@N@L@N@@@L@N@@CO@N@L@NHHHL@NHHGGHN@L@N@@@L@N@@NCLN@L@NBBBL@NBBLCLN@L@N@@@L@N@@NGLN@L@NHHHL@NHHOOLN@L@N@@@L@N@@OOLN@L@NBBBL@NBBGOHN@L@N@@@L@N@@CO@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@NBBBL@NBBBL@N@L@N@@@L@N@@@L@N@L@NHHHL@NHHHL@N@L@N@@@L@N@@@L@N@L@OOOLL@OOOHL@N@L@OOOOL@OOOOL@N@L@OOOOL@OOOOL@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@L@@@@@@@@@@@@@N@OOOOOOOOOOOOOON@OOOOOOOOOOOOOON@ :MASK NIL :MARGINS (2 18 3 2) :DEFAULT-SHADOWS NIL) (DEF-BUTTON-TYPE :SHADOWED :IMAGE #S(NSEW-BITMAP NORTH #*(2 4)L@@@L@@@@@@@@@@@ NW #*(5 4)CH@@GH@@N@@@L@@@ NE #*(7 4)O@@@OH@@CL@@AN@@ SOUTH #*(2 6)@@@@L@@@L@@@D@@@H@@@L@@@ SW #*(5 6)N@@@OH@@GH@@C@@@AH@@@H@@ SE #*(7 6)GJ@@OF@@OJ@@EN@@JL@@OH@@ EAST #*(7 2)CF@@CJ@@ CENTER #*(2 2)@@@@@@@@ WEST #*(5 2)L@@@L@@@) :MASK #S(NSEW-BITMAP NORTH #*(2 4)L@@@L@@@L@@@L@@@ NW #*(5 4)CH@@GH@@OH@@OH@@ NE #*(7 4)O@@@OH@@OL@@ON@@ SOUTH #*(2 6)L@@@L@@@L@@@D@@@H@@@L@@@ SW #*(5 6)OH@@OH@@GH@@C@@@AH@@@H@@ SE #*(7 6)OJ@@OF@@OJ@@EN@@JL@@OH@@ EAST #*(7 2)OF@@OJ@@ CENTER #*(2 2)L@@@L@@@ WEST #*(5 2)OH@@OH@@) :MARGINS (3 5 7 3)) (DEF-BUTTON-TYPE :TRANSPARENT :IMAGE NIL :MASK NIL :MARGINS (0 0 0 0) :DEFAULT-SHADOWS T) (DEF-BUTTON-TYPE :PORTHOLE :IMAGE #S(NSEW-BITMAP NORTH #*(15 36)OOONOOON@@@@@@@@L@@FN@@NG@ALCHAHCHAHGHALOH@NO@@FN@@B@@@@@@@@OOONOOON@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ NW #*(36 36)@@@@@@@CO@@@@@@@@@GOO@@@@@@@@AON@@@@@@@@@OL@@@@@@@@@CO@@C@@@@@@@GH@@G@@@@@@AN@@@N@@@@@@CL@@@L@@@@@@G@O@@L@@@@@@NAOH@N@@@@@ALCIL@G@@@@@CHC@N@C@@@@@G@C@N@A@@@@@N@CIN@@@@@@AL@AON@@@@@@CH@@OLCO@@@@C@@@GIOO@@@@G@@@@CO@@@@@NCL@@OL@@@@@LGN@AO@@@@@ALNG@CL@@@@@AHLCHGH@@@@@AHLCHO@@@@@@CHNGIN@@@@@@C@GOKL@@@@@@G@COCH@@@@@@F@ANG@@@@@@@F@@@G@@@@@@@F@@@N@@@@@@@F@@@N@@@@@@@N@@AL@@@@@@@L@@AL@@@@@@@LCLAH@@@@@@@LGNAH@@@@@@@LNGAH@@@@@@@LLCIH@@@@@@@ NE #*(36 36)OL@@@@@@@@@@OON@@@@@@@@@@GOH@@@@@@@@@@CO@@@@@@@@L@@OL@@@@@@@N@@AN@@@@@@@G@@@GH@@@@@@CH@@CL@@@@@@CHAN@N@@@@@@GHCO@G@@@@@@OHGCHCH@@@@@O@FALAL@@@@@N@FAL@N@@@@@@@GCL@G@@@@@@@COL@CH@@@@OHAOH@AL@@@@OO@O@@@L@@@@@GL@@GHN@@@@@AO@@OLG@@@@@@GHALNC@@@@@@ALAHGCH@@@@@@NAHGAH@@@@@@GALOAH@@@@@@CHOOAL@@@@@@ALGN@L@@@@@@@LCL@N@@@@@@@N@@@F@@@@@@@F@@@F@@@@@@@G@@@F@@@@@@@C@@@F@@@@@@@C@@@G@@@@@@@CH@@C@@@@@@@AHGHC@@@@@@@AHOLC@@@@@@@AILNC@@@@@@@AIHGC@@@ SOUTH #*(15 36)@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@OOONOOON@@@@@@@@L@@FN@@NG@ALCHAHCHAHGH@LOH@NO@@FN@@B@@@@@@@@OOONOOON SW #*(36 36)LLCIH@@@@@@@LNGIH@@@@@@@LGOIH@@@@@@@LCOAH@@@@@@@LANAH@@@@@@@N@@@L@@@@@@@F@@@L@@@@@@@F@@@N@@@@@@@F@@@F@@@@@@@F@CLG@@@@@@@G@GNC@@@@@@@C@NGCH@@@@@@CHLCIL@@@@@@AHLCHN@@@@@@AHNGHG@@@@@@ALGOHCH@@@@@@LCO@AN@@@@@@NAN@@OH@@@@@G@@@@CO@@@@@C@@@O@OO@@@@CH@AOHAO@@@@AL@CIL@@@@@@@N@C@N@@@@@@@G@C@N@C@@@@@CHCIN@G@@@@@ALAON@N@@@@@@N@OL@L@@@@@@G@GH@L@@@@@@CL@@@N@@@@@@AN@@@G@@@@@@@GH@@C@@@@@@@CO@@A@@@@@@@@OL@@@@@@@@@@AON@@@@@@@@@@GOO@@@@@@@@@@CO@@@ SE #*(36 36)@@@@AIHGC@@@@@@@AILOC@@@@@@@AHOOC@@@@@@@AHGNC@@@@@@@AHCLC@@@@@@@C@@@G@@@@@@@C@@@F@@@@@@@G@@@F@@@@@@@F@@@F@@@@@@@NCL@F@@@@@@@LGN@N@@@@@@ALNG@L@@@@@@CHLCIL@@@@@@G@LCIH@@@@@@N@NGIH@@@@@AL@GOKH@@@@@GH@COCH@@@@AO@@ANG@@@@@GL@@@@O@@@@OO@GH@@N@@@@OH@OL@AL@@@@@@ALN@CL@@@@@@AHG@GH@@@@L@AHG@O@@@@@N@ALOAN@@@@@G@@OOCL@@@@@CH@GNGH@@@@@CH@CLO@@@@@@GH@@CN@@@@@@OH@@GL@@@@@@O@@AO@@@@@@@N@@OL@@@@@@@@@COH@@@@@@@@GOL@@@@@@@@OON@@@@@@@@@OL@@@@@@@@@@ EAST #*(36 15)@@@@AIHGC@@@@@@@AILOC@@@@@@@AHOOC@@@@@@@AHGNC@@@@@@@AHCLC@@@@@@@AH@@C@@@@@@@AH@@C@@@@@@@AH@@C@@@@@@@AH@@C@@@@@@@AH@@C@@@@@@@AH@@C@@@@@@@AHGHC@@@@@@@AHOLC@@@@@@@AILNC@@@@@@@AIHGC@@@ CENTER #*(15 15)@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ WEST #*(36 15)LLCIH@@@@@@@LNGIH@@@@@@@LGOIH@@@@@@@LCOAH@@@@@@@LANAH@@@@@@@L@@AH@@@@@@@L@@AH@@@@@@@L@@AH@@@@@@@L@@AH@@@@@@@L@@AH@@@@@@@L@@AH@@@@@@@LCLAH@@@@@@@LGNAH@@@@@@@LNGAH@@@@@@@LLCIH@@@@@@@) :MASK #S(NSEW-BITMAP NORTH #*(15 36)OOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOON@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ NW #*(36 36)@@@@@@@CO@@@@@@@@@GOO@@@@@@@@AOOO@@@@@@@@OOOO@@@@@@@COOOO@@@@@@@GOOOO@@@@@@AOOOOO@@@@@@COOOOO@@@@@@GOOOOO@@@@@@OOOOOO@@@@@AOOOOOO@@@@@COOOOOO@@@@@GOOOOOO@@@@@OOOOOOO@@@@AOOOOOOO@@@@COOOOOOO@@@@COOOOOOO@@@@GOOOOOO@@@@@OOOOOOL@@@@@OOOOOO@@@@@AOOOOOL@@@@@AOOOOOH@@@@@AOOOOO@@@@@@COOOON@@@@@@COOOOL@@@@@@GOOOOH@@@@@@GOOOO@@@@@@@GOOOO@@@@@@@GOOON@@@@@@@GOOON@@@@@@@OOOOL@@@@@@@OOOOL@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@ NE #*(36 36)OL@@@@@@@@@@OON@@@@@@@@@OOOH@@@@@@@@OOOO@@@@@@@@OOOOL@@@@@@@OOOON@@@@@@@OOOOOH@@@@@@OOOOOL@@@@@@OOOOON@@@@@@OOOOOO@@@@@@OOOOOOH@@@@@OOOOOOL@@@@@OOOOOON@@@@@OOOOOOO@@@@@OOOOOOOH@@@@OOOOOOOL@@@@OOOOOOOL@@@@@GOOOOON@@@@@AOOOOOO@@@@@@GOOOOO@@@@@@AOOOOOH@@@@@@OOOOOH@@@@@@GOOOOH@@@@@@COOOOL@@@@@@AOOOOL@@@@@@@OOOON@@@@@@@OOOON@@@@@@@GOOON@@@@@@@GOOON@@@@@@@COOON@@@@@@@COOOO@@@@@@@COOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@ SOUTH #*(15 36)@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@OOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOONOOON SW #*(36 36)OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOL@@@@@@@GOOOL@@@@@@@GOOON@@@@@@@GOOON@@@@@@@GOOOO@@@@@@@GOOOO@@@@@@@COOOOH@@@@@@COOOOL@@@@@@AOOOON@@@@@@AOOOOO@@@@@@AOOOOOH@@@@@@OOOOON@@@@@@OOOOOOH@@@@@GOOOOOO@@@@@COOOOOOO@@@@COOOOOOO@@@@AOOOOOOO@@@@@OOOOOOO@@@@@GOOOOOO@@@@@COOOOOO@@@@@AOOOOOO@@@@@@OOOOOO@@@@@@GOOOOO@@@@@@COOOOO@@@@@@AOOOOO@@@@@@@GOOOO@@@@@@@COOOO@@@@@@@@OOOO@@@@@@@@AOOO@@@@@@@@@GOO@@@@@@@@@@CO@@@ SE #*(36 36)@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@COOOO@@@@@@@COOON@@@@@@@GOOON@@@@@@@GOOON@@@@@@@OOOON@@@@@@@OOOON@@@@@@AOOOOL@@@@@@COOOOL@@@@@@GOOOOH@@@@@@OOOOOH@@@@@AOOOOOH@@@@@GOOOOOH@@@@AOOOOOO@@@@@GOOOOOO@@@@OOOOOOON@@@@OOOOOOOL@@@@OOOOOOOL@@@@OOOOOOOH@@@@OOOOOOO@@@@@OOOOOON@@@@@OOOOOOL@@@@@OOOOOOH@@@@@OOOOOO@@@@@@OOOOON@@@@@@OOOOOL@@@@@@OOOOO@@@@@@@OOOOL@@@@@@@OOOOH@@@@@@@OOOL@@@@@@@@OON@@@@@@@@@OL@@@@@@@@@@ EAST #*(36 15)@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@@@@@AOOOO@@@ CENTER #*(15 15)@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ WEST #*(36 15)OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@OOOOH@@@@@@@) :MARGINS (17 17 17 17) :DEFAULT-SHADOWS T) (DEF-BUTTON-TYPE :ARK :IMAGE #S(NORTH-SOUTH-BITMAP NORTH #*(86 5)OOOOOOOOOOOOOOOOOOOOOL@@JBBBBBBBBBBBBBBBBBBBBL@@HHHHHHHHHHHHHHHHHHHHID@@JBBBBBBBBBBBBBBBBBBBCL@@HHHHHHHHHHHHHHHHHHHHOD@@ CENTER #*(86 2)JEEEEEEEEEEEEEEEEEEEEL@@HJJJJJJJJJJJJJJJJJJJOD@@ SOUTH #*(86 5)JMMMMMMMMMMMMMMMMMMMML@@IGGGGGGGGGGGGGGGGGGGGD@@KMMMMMMMMMMMMMMMMMMMML@@OGGGGGGGGGGGGGGGGGGGGD@@OOOOOOOOOOOOOOOOOOOOOL@@) :MARGINS (4 5 5 6) :DEFAULT-SHADOWS :ARK) (DEF-BUTTON-TYPE :ROUND-ARK :IMAGE #*(74 24)@@@@@@@@@@@@@@@@@@@@@AOOOOOOOOOOOOOOH@@@@GAAAAAAAAAAAAAAF@@@AL@DDDDDDDDDDDDDEH@@A@EEEEEEEEEEEEEEAH@@BBJJJJJJJJJJJJJJJL@@BEEEEEEEEEEEEEEEED@@FJJJJJJJJJJJJJJJJJ@@DEEEEEEEEEEEEEEEEF@@FJJJJJJJJJJJJJJJJJ@@EEEEEEEEEEEEEEEEEF@@GJJJJJJJJJJJJJJJJJ@@EEEEEEEEEEEEEEEEEF@@GJJJJJJJJJJJJJJJJN@@EEEEEEEEEEEEEEEEEF@@GJJJJJJJJJJJJJJJKN@@CMEEEEEEEEEEEEEEFL@@CFJJJJJJJJJJJJJJOL@@AMMMMMMMMMMMMMMMKH@@@GGGGGGGGGGGGGGGN@@@@AOOOOOOOOOOOOOOH@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ :MASK #*(74 24)@@@@@@@@@@@@@@@@@@@@@AOOOOOOOOOOOOOOH@@@@GOOOOOOOOOOOOOON@@@AOOOOOOOOOOOOOOOOH@@AOOOOOOOOOOOOOOOOH@@COOOOOOOOOOOOOOOOL@@COOOOOOOOOOOOOOOOL@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@GOOOOOOOOOOOOOOOON@@COOOOOOOOOOOOOOOOL@@COOOOOOOOOOOOOOOOL@@AOOOOOOOOOOOOOOOOH@@@GOOOOOOOOOOOOOON@@@@AOOOOOOOOOOOOOOH@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ :MARGINS (5 4 5 2) :DEFAULT-SHADOWS :ARK) (DEF-BUTTON-TYPE :STRETCHY-ARK :IMAGE #S(NSEW-BITMAP NORTH #*(4 5)O@@@D@@@A@@@D@@@A@@@ NW #*(5 5)OH@@J@@@HH@@J@@@HH@@ NE #*(5 5)OH@@EH@@BH@@GH@@NH@@ SOUTH #*(4 5)K@@@N@@@K@@@N@@@O@@@ SW #*(5 5)JH@@I@@@KH@@O@@@OH@@ SE #*(5 5 )KH@@NH@@KH@@NH@@OH@@ EAST #*(5 4)KH@@NH@@KH@@NH@@ CENTER #*(4 4)J@@@E@@@J@@@E@@@ WEST #*(5 4)J@@@HH@@J@@@HH@@) :MARGINS (6 6 6 6) :DEFAULT-SHADOWS :ARK) (DEF-BUTTON-TYPE :STRETCHY-ROUND-ARK :IMAGE #S(NSEW-BITMAP NORTH #*(4 6)O@@@D@@@A@@@E@@@J@@@E@@@ NW #*(7 6)@B@@@N@@CH@@B@@@DD@@DJ@@ NE #*(9 6)N@@@EH@@AF@@DF@@JK@@EE@@ SOUTH #*(4 6)J@@@E@@@J@@@G@@@M@@@O@@@ SW #*(7 6)OD@@GJ@@FL@@CJ@@@N@@@B@@ SE #*(9 6)JOH@EK@@KO@@FN@@OH@@N@@@ EAST #*(9 8)JJH@EEH@JJH@EEH@JJH@EEH@JJH@EEH@ CENTER #*(4 8)J@@@E@@@J@@@E@@@J@@@E@@@J@@@E@@@ WEST #*(7 8)OD@@JJ@@OD@@JJ@@OD@@JJ@@OD@@JJ@@) :MASK #S(NSEW-BITMAP NORTH #*(4 6)O@@@O@@@O@@@O@@@O@@@O@@@ NW #*(7 6)@B@@@N@@CN@@CN@@GN@@GN@@ NE #*(9 6)N@@@OH@@ON@@ON@@OO@@OO@@ SOUTH #*(4 6)O@@@O@@@O@@@O@@@O@@@O@@@ SW #*(7 6)ON@@GN@@GN@@CN@@@N@@@B@@ SE #*(9 6)OOH@OO@@OO@@ON@@OH@@N@@@ EAST #*(9 8)OOH@OOH@OOH@OOH@OOH@OOH@OOH@OOH@ CENTER #*(4 8)O@@@O@@@O@@@O@@@O@@@O@@@O@@@O@@@ WEST #*(7 8)ON@@ON@@ON@@ON@@ON@@ON@@ON@@ON@@) :MARGINS (4 1 4 2) :DEFAULT-SHADOWS :ARK) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:MENUHELDWAIT) ) (IL:PUTPROPS IL:ROOMS-BUTTONS IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (6457 7875 (SELECT-BUTTON-TYPE 6457 . 7875)) (10909 13146 (MAKE-BUTTON 10909 . 13146) ) (13148 13414 (COPY-BUTTON 13148 . 13414)) (13416 14419 (DISPLAY-BUTTON 13416 . 14419)) (14421 15264 (UPDATE-BUTTON 14421 . 15264)) (15266 15604 (SET-BUTTON-TEXT-STRING 15266 . 15604)) (15874 16212 ( SET-BUTTON-TEXT-STRING 15874 . 16212)) (16214 16417 (COMPUTE-BUTTON-TEXT-POSITION 16214 . 16417)) ( 16419 17055 (BUTTON-TEXT-X-COORD 16419 . 17055)) (17057 17697 (BUTTON-TEXT-Y-COORD 17057 . 17697)) ( 17699 18120 (TEXT-FROM-TEXT-FORM 17699 . 18120)) (18122 19426 (BUTTON-TRACK-MOUSE 18122 . 19426)) ( 19428 19620 (PERFORM-BUTTON-ACTION 19428 . 19620)) (19622 20088 (EDIT-BUTTON 19622 . 20088)) (20090 20785 (BUTTON-COPY-SELECTED 20090 . 20785)) (20787 22056 (SHADE-BUTTON 20787 . 22056)) (22058 22202 ( PRINT-BUTTON-HELP 22058 . 22202)) (22349 23450 (MAKE-BUTTON-WINDOW 22349 . 23450)) (23452 24543 ( BW-REPAINTFN 23452 . 24543)) (24545 25335 (BW-TOTOPFN 24545 . 25335)) (25337 26238 (BW-BUTTONEVENTFN 25337 . 26238)) (26240 26967 (BW-BUTTONEVENTFN-INTERNAL 26240 . 26967)) (26969 27253 ( SET-BUTTON-WINDOW-TEXT-STRING 26969 . 27253)) (27255 28200 (MAYBE-RESIZE-BUTTON-WINDOW 27255 . 28200)) (28202 29222 (BW-SCREEN-CHANGED-FUNCTION 28202 . 29222)) (29688 30643 (DISPLAY-BUTTON-IMAGE 29688 . 30643)) (30645 31439 (DISPLAY-BUTTON-MASK 30645 . 31439)) (31441 34832 (BUTTON-WIDTH 31441 . 34832)) ( 34834 38509 (BUTTON-HEIGHT 34834 . 38509)) (38511 39213 (BUTTON-BITMAP-BITBLT 38511 . 39213)) (39215 40415 (EW-BITBLT 39215 . 40415)) (40417 41728 (NS-BITBLT 40417 . 41728)) (41730 43230 (NSEW-BITBLT 41730 . 43230)) (43232 45698 (PAINT-REGION 43232 . 45698)) (45739 46229 (EDIT-BUTTON-WINDOW 45739 . 46229)) (46231 47729 (EXTERNALIZE-BUTTON 46231 . 47729)) (47731 47880 (EXTERNALIZE-FONT 47731 . 47880) ) (47882 48179 (WITH-BUTTON 47882 . 48179))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-BUTTONS.DFASL b/rooms/ROOMS-BUTTONS.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..795bc6ca1a6ee4e34c7012bf8bbc6d91114be0a4 GIT binary patch literal 40411 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 BJdgkY literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-CORE b/rooms/ROOMS-CORE new file mode 100644 index 00000000..12f33b4b --- /dev/null +++ b/rooms/ROOMS-CORE @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:26:01"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-CORE.;2| 38390 IL:|previous| IL:|date:| "17-Aug-90 12:39:01" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-CORE.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-CORECOMS) (IL:RPAQQ IL:ROOMS-CORECOMS ( (IL:* IL:|;;| "core rooms code") (FILE-ENVIRONMENTS IL:ROOMS-CORE) (IL:P (EXPORT '(ROOM ROOM-P ROOM-NAME ROOM-PLACEMENTS ROOM-INCLUSIONS ROOM-BACKGROUND ROOM-TTY-PROCESS ROOM-PROPS ROOM-PROP MAKE-ROOM COPY-ROOM DELETE-ROOM RENAME-ROOM ROOM-NAMED ROOM-SORT-FUNCTION)) (EXPORT '(*CURRENT-ROOM* *POCKET-ROOM-NAME* *ROOM-ENTRY-FUNCTIONS* *ROOM-EXIT-FUNCTIONS* *ROOM-CHANGED-FUNCTIONS*)) (EXPORT '(PLACEMENT PLACEMENT-P PLACEMENT-WINDOW PLACEMENT-REGION PLACEMENT-SHRUNKEN? PLACEMENT-ICON-POSITION PLACEMENT-PROPS PLACEMENT-PROP MAKE-PLACEMENT COPY-PLACEMENT MOVE-PLACEMENT)) (EXPORT '(GO-TO-ROOM UPDATE-PLACEMENTS FIND-PLACEMENT ROOM-CHANGED DO-INCLUSIONS RESET)) (REQUIRE "ROOMS")) (IL:COMS (IL:* IL:|;;| "the room -- a named object") (IL:STRUCTURES ROOM) (IL:VARIABLES *ROOMS* *CURRENT-ROOM*) (IL:FUNCTIONS IN-ROOM? MAKE-ROOM COPY-ROOM RENAME-ROOM ROOM-PROP DO-ROOMS ALL-ROOMS ROOM-SORT-FUNCTION ROOM-NAMED DELETE-ROOM)) (IL:COMS (IL:* IL:|;;| "placements") (IL:STRUCTURES PLACEMENT) (IL:FUNCTIONS PLACEMENT-PROP MAKE-PLACEMENT COPY-PLACEMENT MOVE-PLACEMENT ADD-PLACEMENT DELETE-PLACEMENT)) (IL:* IL:|;;| "going from one room to another") (IL:VARIABLES *POCKET-ROOM-NAME* *MONITOR-LOCK* *ROOM-ENTRY-FUNCTIONS* *ROOM-EXIT-FUNCTIONS*) (IL:FUNCTIONS GO-TO-ROOM GO-TO-ROOM-PROCESS GO-TO-ROOM-INTERNAL CALL-ENTRY-FUNCTIONS CALL-EXIT-FUNCTIONS UPDATE-PLACEMENTS FIND-PLACEMENT FIND-PLACEMENT-IN-ROOM UPDATE-PLACEMENT PLACE-PLACEMENTS FIND-PLACEMENTS PLACE-PLACEMENT) (IL:FUNCTIONS UPDATE-TTY-PROCESS PLACE-TTY-PROCESS) (IL:* IL:|;;| "other essentials") (IL:FUNCTIONS FIND-ROOMS-CONTAINING) (IL:COMS (IL:VARIABLES *ROOM-CHANGED-FUNCTIONS*) (IL:FUNCTIONS ROOM-CHANGED)) (IL:FUNCTIONS DO-INCLUSIONS ROOM-INCLUDERS) (IL:* IL:|;;| "bootstrapping & resetting") (IL:VARIABLES *RESET-FORMS*) (IL:FUNCTIONS RESET) (IL:VARIABLES OLD-WHOLESCREEN *SCREEN-CHANGED-FUNCTIONS*) (IL:FUNCTIONS AROUNDEXITFN %INTERNALIZE-ALL-PLACEMENTS %INTERNALIZE-PLACEMENTS) (IL:GLOBALVARS IL:PROMPTWINDOW IL:AROUNDEXITFNS) (EVAL-WHEN (LOAD) (IL:P (IL:* IL:\;  "smash system code which moves windows around on reboot so we don't fight with it.") (PUSHNEW '(IL:CHANGENAME 'IL:\\STARTDISPLAY 'IL:\\MOVE.WINDOWS.ONTO.SCREEN 'IL:NILL) *RESET-FORMS* :TEST 'EQUAL))) (IL:* IL:|;;| "random") (IL:PROP IL:ARGNAMES GO-TO-ROOM) (IL:SEDIT-FORMATS DO-INCLUSIONS DO-ROOMS))) (IL:* IL:|;;| "core rooms code") (DEFINE-FILE-ENVIRONMENT IL:ROOMS-CORE :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(ROOM ROOM-P ROOM-NAME ROOM-PLACEMENTS ROOM-INCLUSIONS ROOM-BACKGROUND ROOM-TTY-PROCESS ROOM-PROPS ROOM-PROP MAKE-ROOM COPY-ROOM DELETE-ROOM RENAME-ROOM ROOM-NAMED ROOM-SORT-FUNCTION)) (EXPORT '(*CURRENT-ROOM* *POCKET-ROOM-NAME* *ROOM-ENTRY-FUNCTIONS* *ROOM-EXIT-FUNCTIONS* *ROOM-CHANGED-FUNCTIONS*)) (EXPORT '(PLACEMENT PLACEMENT-P PLACEMENT-WINDOW PLACEMENT-REGION PLACEMENT-SHRUNKEN? PLACEMENT-ICON-POSITION PLACEMENT-PROPS PLACEMENT-PROP MAKE-PLACEMENT COPY-PLACEMENT MOVE-PLACEMENT)) (EXPORT '(GO-TO-ROOM UPDATE-PLACEMENTS FIND-PLACEMENT ROOM-CHANGED DO-INCLUSIONS RESET)) (REQUIRE "ROOMS") (IL:* IL:|;;| "the room -- a named object") (DEFSTRUCT (ROOM (:CONSTRUCTOR MAKE-ROOM-INTERNAL) (:COPIER COPY-ROOM-INTERNAL) (:PRINT-FUNCTION (LAMBDA (ROOM STREAM DEPTH) (FORMAT STREAM "#" (ROOM-NAME ROOM))))) (NAME NIL :READ-ONLY T) (PLACEMENTS NIL :TYPE LIST) (IL:* IL:|;;| "list of PLACEMENT objects") (INCLUSIONS NIL :TYPE LIST) (IL:* IL:|;;| "list of names of included rooms") (BACKGROUND NIL :TYPE BACKGROUND) (IL:* IL:|;;| "how to paint the background") (TTY-PROCESS NIL) (IL:* IL:|;;| "which process has the TTY in this room") (PROPS NIL :TYPE LIST) (IL:* IL:|;;| "property list") ) (DEFVAR *ROOMS* (MAKE-HASH-TABLE :TEST 'EQUAL) "A hash table mapping from room names to rooms.") (DEFGLOBALVAR *CURRENT-ROOM* NIL "The room the user is currently in.") (DEFUN IN-ROOM? (ROOM) (IL:* IL:|;;;| "true if ROOM is a sub-room of the current room") (DO-INCLUSIONS (INCLUDED-ROOM *CURRENT-ROOM*) (WHEN (EQUAL (ROOM-NAME ROOM) (ROOM-NAME INCLUDED-ROOM)) (RETURN-FROM DO-INCLUSIONS T)))) (DEFUN MAKE-ROOM (NAME &REST REST-KEYS &KEY PLACEMENTS INCLUSIONS (BACKGROUND NIL BACKGROUND-SPECIFIED?) TTY-PROCESS &ALLOW-OTHER-KEYS) (IL:* IL:|;;| "check whether a room with this already exists") (WHEN (ROOM-NAMED NAME) (CERROR "Delete existing room named ~S (will close windows)" "A room named ~S already exists" NAME) (DELETE-ROOM (ROOM-NAMED NAME))) (IL:* IL:|;;| "check the types of the placements") (DOLIST (PLACEMENT PLACEMENTS) (CHECK-TYPE PLACEMENT PLACEMENT)) (IL:* IL:|;;| "default the background to contain the name of the room") (UNLESS BACKGROUND-SPECIFIED? (SETQ BACKGROUND `((:TEXT ,NAME)))) (LET ((ROOM (MAKE-ROOM-INTERNAL :NAME NAME :PLACEMENTS PLACEMENTS :INCLUSIONS INCLUSIONS :BACKGROUND (MAKE-BACKGROUND BACKGROUND) :TTY-PROCESS TTY-PROCESS :PROPS (LET ((PROPS (COPY-LIST REST-KEYS))) (DOLIST (KEYWORD '(:PLACEMENTS :INCLUSIONS :BACKGROUND :TTY-PROCESS)) (REMF PROPS KEYWORD)) PROPS)))) (SETF (ROOM-NAMED NAME) ROOM) (WHEN *CURRENT-ROOM* (WHEN (EQUAL NAME (ROOM-NAME *CURRENT-ROOM*)) (SETQ *CURRENT-ROOM* ROOM)) (ROOM-CHANGED ROOM :CREATED)) ROOM)) (DEFUN COPY-ROOM (ROOM NEW-NAME) (UPDATE-PLACEMENTS) (APPLY 'MAKE-ROOM NEW-NAME :PLACEMENTS (MAPCAR #'COPY-PLACEMENT (ROOM-PLACEMENTS ROOM)) :INCLUSIONS (COPY-LIST (ROOM-INCLUSIONS ROOM)) :BACKGROUND (LET* ((BACKGROUND (COPY-TREE (BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND ROOM)))) (OLD-NAME (ROOM-NAME ROOM)) (TEXT (FIND-IF #'(LAMBDA (COMMAND) (AND (EQ (FIRST COMMAND) :TEXT) (EQUAL (SECOND COMMAND) OLD-NAME))) BACKGROUND))) (WHEN TEXT (SETF (SECOND TEXT) NEW-NAME)) BACKGROUND) (COPY-TREE (ROOM-PROPS ROOM)))) (DEFUN RENAME-ROOM (ROOM NEW-NAME) (LET ((OLD-NAME (ROOM-NAME ROOM))) (PROG1 (COPY-ROOM ROOM NEW-NAME) (DELETE-ROOM ROOM) (LET ((SUITE-NAME (FIND-SUITE-CONTAINING OLD-NAME))) (IL:* IL:|;;| "if its in a suite, rename it there too") (WHEN SUITE-NAME (SETF (SUITE-ROOMS SUITE-NAME) (SUBSTITUTE NEW-NAME OLD-NAME (SUITE-ROOMS SUITE-NAME) :TEST 'EQUAL)))) (DO-ROOMS (ROOM) (IL:* IL:|;;| "rename it in inclusions of other rooms") (WHEN (MEMBER OLD-NAME (ROOM-INCLUSIONS ROOM) :TEST 'EQUAL) (IL:* IL:|;;|  "don't need to call UPDATE-PLACEMENTS as COPY-ROOM has already called it for us. ") (SETF (ROOM-INCLUSIONS ROOM) (SUBSTITUTE NEW-NAME OLD-NAME (ROOM-INCLUSIONS ROOM) :TEST 'EQUAL)) (ROOM-CHANGED ROOM :EDITED)))))) (DEFMACRO ROOM-PROP (ROOM PROP &OPTIONAL (NEW-VALUE NIL NEW-VALUE-SUPPLIED)) (IF NEW-VALUE-SUPPLIED `(SETF (GETF (ROOM-PROPS ,ROOM) ,PROP) ,NEW-VALUE) `(GETF (ROOM-PROPS ,ROOM) ,PROP))) (DEFMACRO DO-ROOMS ((ROOM-VAR) &BODY BODY) (IL:* IL:|;;;| "evaluate BODY once for each room with ROOM-VAR bound to the room.") `(BLOCK DO-ROOMS (MAPHASH #'(LAMBDA (,(GENSYM) ,ROOM-VAR) ,@BODY) *ROOMS*))) (DEFUN ALL-ROOMS (&OPTIONAL SORTED?) (IL:* IL:|;;;| "return a list of all rooms. if SORTED? is true, sort them alphabetically by name") (LET ((ALL-ROOMS (WITH-COLLECTION (DO-ROOMS (ROOM) (COLLECT ROOM))))) (IF SORTED? (SORT ALL-ROOMS #'ROOM-SORT-FUNCTION) ALL-ROOMS))) (DEFUN ROOM-SORT-FUNCTION (ROOM-1 ROOM-2) (IL:* IL:|;;;| "used as the predicate for sorting lists of rooms. we sort alphabetically by the name of the room.") (MACROLET ((STRINGIFY (NAME) `(IF (STRINGP ,NAME) ,NAME (PRINC-TO-STRING ,NAME)))) (LET ((NAME-1 (ROOM-NAME ROOM-1)) (NAME-2 (ROOM-NAME ROOM-2))) (STRING-LESSP (STRINGIFY NAME-1) (STRINGIFY NAME-2))))) (DEFMACRO ROOM-NAMED (NAME) `(GETHASH ,NAME *ROOMS*)) (DEFUN DELETE-ROOM (ROOM) (IL:* IL:|;;| "first close all the windows which only have placements in this room") (LET ((ONLY-THIS-ROOM (LIST ROOM))) (DOLIST (WINDOW (ALL-WINDOWS T)) (WHEN (EQUAL (FIND-ROOMS-CONTAINING WINDOW) ONLY-THIS-ROOM) (UN-HIDE-WINDOW WINDOW) (CLOSE-WINDOW (IF (SHRUNKEN? WINDOW) (WINDOW-ICON WINDOW) WINDOW))))) (WHEN (DO-ROOMS (RM) (WHEN (EQ ROOM RM) (RETURN-FROM DO-ROOMS T))) (IL:* IL:|;;| "if it's in the name table, remove it. this is so deleting an un-named room (like the Overview) doesn't cause a room named \"Overview\" to also disappear.") (REMHASH (ROOM-NAME ROOM) *ROOMS*)) (IL:* IL:|;;| "tell the world we've deleted it") (ROOM-CHANGED ROOM :DELETED)) (IL:* IL:|;;| "placements") (DEFSTRUCT (PLACEMENT (:CONSTRUCTOR MAKE-PLACEMENT-INTERNAL) (:COPIER COPY-PLACEMENT-INTERNAL)) WINDOW REGION SHRUNKEN? ICON-POSITION PROPS) (DEFMACRO PLACEMENT-PROP (PLACEMENT PROP &OPTIONAL (NEW-VALUE NIL NEW-VALUE-SUPPLIED)) (IF NEW-VALUE-SUPPLIED `(SETF (GETF (PLACEMENT-PROPS ,PLACEMENT) ,PROP) ,NEW-VALUE) `(GETF (PLACEMENT-PROPS ,PLACEMENT) ,PROP))) (DEFUN MAKE-PLACEMENT (WINDOW) (LET ((PLACEMENT (MAKE-PLACEMENT-INTERNAL :WINDOW WINDOW))) (UPDATE-PLACEMENT PLACEMENT) PLACEMENT)) (DEFUN COPY-PLACEMENT (PLACEMENT) (IL:* IL:|;;| "make sure PROPS gets copied. it is not important that REGION & ICON-POSITION are copied, but seems safer.") (MAKE-PLACEMENT-INTERNAL :WINDOW (PLACEMENT-WINDOW PLACEMENT) :REGION (COPY-REGION (PLACEMENT-REGION PLACEMENT)) :SHRUNKEN? (PLACEMENT-SHRUNKEN? PLACEMENT) :ICON-POSITION (COPY-TREE (PLACEMENT-ICON-POSITION PLACEMENT)) :PROPS (COPY-TREE (PLACEMENT-PROPS PLACEMENT)))) (DEFUN MOVE-PLACEMENT (PLACEMENT FROM-ROOM TO-ROOM &OPTIONAL COPY?) (ADD-PLACEMENT (COPY-PLACEMENT PLACEMENT) TO-ROOM) (UNLESS COPY? (DELETE-PLACEMENT PLACEMENT FROM-ROOM) (LET* ((WINDOW (PLACEMENT-WINDOW PLACEMENT)) (INHERITED (FIND-PLACEMENT WINDOW))) (HIDE-WINDOW WINDOW) (WHEN INHERITED (PLACE-PLACEMENT INHERITED))))) (DEFUN ADD-PLACEMENT (PLACEMENT ROOM) (IL:* IL:|;;;| "add PLACEMENT to ROOM's placements. does not update screen. ") (IL:* IL:|;;| "first delete any old placements for same window") (SETF (ROOM-PLACEMENTS ROOM) (DELETE (PLACEMENT-WINDOW PLACEMENT) (ROOM-PLACEMENTS ROOM) :TEST 'EQ :KEY #'PLACEMENT-WINDOW)) (IL:* IL:|;;| "add it") (PUSH PLACEMENT (ROOM-PLACEMENTS ROOM)) (IL:* IL:|;;| "notify system that ROOM has changed.") (ROOM-CHANGED ROOM :PLACEMENTS)) (DEFUN DELETE-PLACEMENT (PLACEMENT ROOM) (IL:* IL:|;;| "delete PLACEMENT from ROOM. does not remove placement from screen.") (SETF (ROOM-PLACEMENTS ROOM) (DELETE (PLACEMENT-WINDOW PLACEMENT) (ROOM-PLACEMENTS ROOM) :TEST 'EQ :KEY #'PLACEMENT-WINDOW)) (IL:* IL:|;;| "notify system that ROOM has changed.") (ROOM-CHANGED ROOM :PLACEMENTS)) (IL:* IL:|;;| "going from one room to another") (DEFGLOBALVAR *POCKET-ROOM-NAME* NIL "The name of the room to be the pockets or NIL.") (DEFGLOBALVAR *MONITOR-LOCK*) (DEFVAR *ROOM-ENTRY-FUNCTIONS* NIL "A list of functions to be called before a room is entered") (DEFVAR *ROOM-EXIT-FUNCTIONS* NIL "A list of functions to be called before a room is left") (DEFUN GO-TO-ROOM (&REST ARGS) (IL:* IL:|;;;| "skip to GO-TO-ROOM-INTERNAL for details...") (IL:* IL:|;;| "can't run under mouse, as mouse switches TTY around. have to spawn our own process, let the mouse return the TTY, then we'll be run. ") (CHECK-TYPE (FIRST ARGS) ROOM) (IL:RESETVAR IL:\\PROC.RUN.NEXT.FLG T (IL:* IL:|;;| "ensure that we'll be the next process run when the mouse blocks.") (IL:ADD.PROCESS `(GO-TO-ROOM-PROCESS ',ARGS) 'IL:NAME "Go To Room"))) (DEFUN GO-TO-ROOM-PROCESS (ARGS) (LET ((OLD-CURSOR (IL:CURSOR))) (UNWIND-PROTECT (IF (IL:OBTAIN.MONITORLOCK *MONITOR-LOCK* T) (PROGN (IL:CURSOR IL:WAITINGCURSOR) (IL:\\CARET.DOWN NIL IL:MAX.FIXP) (APPLY 'GO-TO-ROOM-INTERNAL ARGS)) (NOTIFY-USER "Can't! Rooms is busy.")) (IL:RELEASE.MONITORLOCK *MONITOR-LOCK*) (IL:CURSOR OLD-CURSOR) (IL:CARET T)))) (DEFUN GO-TO-ROOM-INTERNAL (ROOM &KEY NO-UPDATE BAGGAGE) (CHECK-TYPE ROOM ROOM) (IL:* IL:|;;;| "Leave the current room & enter ROOM. BAGGAGE is a list of additional placements to be placed in ROOM.") (IL:* IL:|;;| "call exit hooks on current room") (CALL-EXIT-FUNCTIONS *CURRENT-ROOM*) (UNLESS NO-UPDATE (IL:* IL:|;;| "update the current room per the screen") (UPDATE-PLACEMENTS *CURRENT-ROOM*)) (IL:* IL:|;;| "note which process has the keyboard") (UPDATE-TTY-PROCESS *CURRENT-ROOM*) (IL:* IL:|;;| "clear the screen") (HIDE-ALL-WINDOWS) (UNWIND-PROTECT (PROGN (IL:* IL:|;;| "paint the background") (PAINT-BACKGROUND ROOM *SCREEN-BITMAP*) (IL:* IL:|;;| "call entry hooks") (CALL-ENTRY-FUNCTIONS ROOM)) (IL:* IL:|;;| "set *CURRENT-ROOM*.") (SETQ *CURRENT-ROOM* ROOM)) (IL:* IL:|;;| "place placements from ROOM -- inherited & direct") (PLACE-PLACEMENTS ROOM BAGGAGE) (IL:* IL:|;;| "place the caret ") (PLACE-TTY-PROCESS ROOM)) (DEFUN CALL-ENTRY-FUNCTIONS (ROOM) (IL:* IL:|;;| "first call global entry functions") (DOLIST (FN *ROOM-ENTRY-FUNCTIONS*) (FUNCALL FN ROOM)) (IL:* IL:|;;| "then call inherited entry functions") (DO-INCLUSIONS (SUB-ROOM ROOM) (DOLIST (FN (ROOM-PROP SUB-ROOM :BEFORE-ENTRY-FUNCTIONS)) (FUNCALL FN ROOM)))) (DEFUN CALL-EXIT-FUNCTIONS (ROOM) (IL:* IL:|;;| "first call global room exit functions") (DOLIST (FN *ROOM-EXIT-FUNCTIONS*) (FUNCALL FN ROOM)) (IL:* IL:|;;| "then call inherited functions on ROOM") (DO-INCLUSIONS (SUB-ROOM ROOM) (DOLIST (FN (ROOM-PROP SUB-ROOM :BEFORE-EXIT-FUNCTIONS)) (FUNCALL FN ROOM)))) (DEFUN UPDATE-PLACEMENTS (&OPTIONAL (FOR-ROOM *CURRENT-ROOM*)) (IL:* IL:|;;;| "called when leaving a room to update it's placements") (IL:* IL:|;;;| "returns the new list of placements ") (LET ((NEW-PLACEMENTS NIL) (CHANGED-ROOMS NIL) (OLD-PLACEMENTS (ROOM-PLACEMENTS FOR-ROOM)) (ALL-WINDOWS (ALL-WINDOWS))) (DOLIST (WINDOW ALL-WINDOWS) (MULTIPLE-VALUE-BIND (PLACEMENT IN-ROOM) (FIND-PLACEMENT WINDOW FOR-ROOM) (UNLESS PLACEMENT (IL:* IL:|;;| "new window in this room - make a placement") (SETQ PLACEMENT (MAKE-PLACEMENT WINDOW)) (SETQ IN-ROOM FOR-ROOM) (IL:* IL:|;;| "note change to this room") (PUSHNEW FOR-ROOM CHANGED-ROOMS :TEST 'EQ)) (IL:* IL:|;;| "collect placements in this room in top to bottom order.") (WHEN (EQ IN-ROOM FOR-ROOM) (PUSH PLACEMENT NEW-PLACEMENTS)) (IL:* IL:|;;| "update the placement") (WHEN (UPDATE-PLACEMENT PLACEMENT) (IL:* IL:|;;| "placement has changed - note it") (PUSHNEW IN-ROOM CHANGED-ROOMS :TEST 'EQ)))) (DOLIST (PLACEMENT (FIND-PLACEMENTS FOR-ROOM)) (UNLESS (MEMBER (PLACEMENT-WINDOW PLACEMENT) ALL-WINDOWS :TEST 'EQ) (IL:* IL:|;;| "it's a window that's been closed") (DO-INCLUSIONS (ROOM FOR-ROOM) (WHEN (MEMBER PLACEMENT (ROOM-PLACEMENTS ROOM) :TEST 'EQ) (IL:* IL:|;;| "delete its placement") (UNLESS (EQ ROOM FOR-ROOM) (IL:* IL:|;;| "unless we'll delete it below anyway") (DELETE-PLACEMENT PLACEMENT ROOM)) (IL:* IL:|;;| "note that this room has changed") (PUSHNEW ROOM CHANGED-ROOMS :TEST 'EQ) (RETURN-FROM DO-INCLUSIONS))))) (UNLESS (EQUAL NEW-PLACEMENTS OLD-PLACEMENTS) (IL:* IL:|;;| "check if occlusion order of placements has changed") (PUSHNEW FOR-ROOM CHANGED-ROOMS :TEST 'EQ)) (SETF (ROOM-PLACEMENTS FOR-ROOM) NEW-PLACEMENTS) (DOLIST (ROOM CHANGED-ROOMS) (ROOM-CHANGED ROOM :PLACEMENTS)) T)) (DEFUN FIND-PLACEMENT (WINDOW &OPTIONAL (FROM-ROOM *CURRENT-ROOM*)) (IL:* IL:|;;;| "returns the placement which caused WINDOW to be in ROOM.") (IL:* IL:|;;;| "does a breadth-first search through ROOM & its inclusions for a placement containing WINDOW. second value is room placement was found in. ") (DO-INCLUSIONS (ROOM FROM-ROOM) (LET ((PLACEMENT (FIND-PLACEMENT-IN-ROOM WINDOW ROOM))) (WHEN PLACEMENT (RETURN-FROM FIND-PLACEMENT (VALUES PLACEMENT ROOM)))))) (DEFMACRO FIND-PLACEMENT-IN-ROOM (WINDOW ROOM) `(LET ((WINDOW ,WINDOW)) (DOLIST (PLACEMENT (ROOM-PLACEMENTS ,ROOM)) (WHEN (EQ (PLACEMENT-WINDOW PLACEMENT) WINDOW) (RETURN PLACEMENT))))) (DEFUN UPDATE-PLACEMENT (PLACEMENT) (IL:* IL:|;;;| "called when leaving a room on each placement in the room. returns true if placement has changed since the last time it was updated.") (LET* ((WINDOW (PLACEMENT-WINDOW PLACEMENT)) (ICON-POSITION (ICON-POSITION WINDOW)) (REGION (WINDOW-REGION WINDOW)) (SHRUNKEN? (SHRUNKEN? WINDOW)) (CHANGED? NIL)) (UNLESS (EQUAL ICON-POSITION (PLACEMENT-ICON-POSITION PLACEMENT)) (SETF (PLACEMENT-ICON-POSITION PLACEMENT) (COPY-TREE ICON-POSITION)) (SETQ CHANGED? T)) (UNLESS (EQUAL REGION (PLACEMENT-REGION PLACEMENT)) (SETF (PLACEMENT-REGION PLACEMENT) (COPY-REGION REGION)) (SETQ CHANGED? T)) (UNLESS (EQ SHRUNKEN? (PLACEMENT-SHRUNKEN? PLACEMENT)) (SETF (PLACEMENT-SHRUNKEN? PLACEMENT) SHRUNKEN?) (SETQ CHANGED? T)) (IL:* IL:|;;| "call the user hook") (LET ((WINDOW-TYPE (WINDOW-TYPE WINDOW T))) (WHEN WINDOW-TYPE (LET ((UPDATER (WINDOW-TYPE-UPDATER WINDOW-TYPE))) (WHEN UPDATER (FUNCALL (WINDOW-TYPE-UPDATER WINDOW-TYPE) PLACEMENT))))) CHANGED?)) (DEFUN PLACE-PLACEMENTS (ROOM &OPTIONAL BAGGAGE) (DOLIST (PLACEMENT (FIND-PLACEMENTS ROOM)) (PLACE-PLACEMENT PLACEMENT)) (DOLIST (PLACEMENT BAGGAGE) (PLACE-PLACEMENT PLACEMENT))) (DEFUN FIND-PLACEMENTS (ROOM) (IL:* IL:|;;;| "returns the list of placements to be displayed in room, ordered in bottom first (i.e. the order they should be displayed in)") (LET (PLACEMENTS) (DO-INCLUSIONS (INCLUSION ROOM) (DOLIST (PLACEMENT (ROOM-PLACEMENTS INCLUSION)) (IL:* IL:|;;| "save one placement for each window on the way down") (IL:* IL:|;;| "optimization: this rather convoluted piece of code is used rather than (pushnew placement placements :key #'placement-window) because pushnew compiles into something really slow in XCL.") (LET ((WINDOW (PLACEMENT-WINDOW PLACEMENT))) (UNLESS (DOLIST (PLACEMENT PLACEMENTS) (WHEN (EQ (PLACEMENT-WINDOW PLACEMENT) WINDOW) (RETURN T))) (PUSH PLACEMENT PLACEMENTS))))) PLACEMENTS)) (DEFUN PLACE-PLACEMENT (PLACEMENT) (IL:* IL:|;;;| "Called on each placement in a room when it's visited to place PLACEMENT's window per the rest of PLACEMENT.") (IL:* IL:|;;;| "This will probably require a lot of work in a different window system.") (LET* ((WINDOW (PLACEMENT-WINDOW PLACEMENT)) (IL:* IL:|;;| "we copy as window system sometimes seems to smash these") (PLACEMENT-REGION (COPY-REGION (PLACEMENT-REGION PLACEMENT))) (PLACEMENT-ICON-POSITION (COPY-TREE (PLACEMENT-ICON-POSITION PLACEMENT))) (WINDOW-REGION (WINDOW-REGION WINDOW)) (WINDOW-ICON (WINDOW-ICON WINDOW)) (WINDOW-TYPE (WINDOW-TYPE WINDOW T))) (WHEN (OR (IL:OPENWP WINDOW) (AND WINDOW-ICON (IL:OPENWP WINDOW-ICON))) (IL:* IL:|;;| "if it's been closed & we ignore it") (UN-HIDE-WINDOW WINDOW) (COND ((PLACEMENT-SHRUNKEN? PLACEMENT) (IL:* IL:|;;| "ensure the expansion is placed correctly") (UNLESS (EQUAL PLACEMENT-REGION WINDOW-REGION) (SHAPE-WINDOW WINDOW PLACEMENT-REGION :CURRENT-REGION WINDOW-REGION :NO-SHAPE (AND WINDOW-TYPE (WINDOW-TYPE-PROP WINDOW-TYPE :NO-SHAPE)))) (IL:* IL:|;;| "place the icon") (COND ((SHRUNKEN? WINDOW) (UNLESS (EQUAL (WINDOW-POSITION WINDOW-ICON) PLACEMENT-ICON-POSITION) (MOVE-WINDOW WINDOW-ICON PLACEMENT-ICON-POSITION) (OPEN-WINDOW WINDOW-ICON))) (T (MOVE-WINDOW (SHRINK-WINDOW WINDOW PLACEMENT-ICON-POSITION) PLACEMENT-ICON-POSITION)))) (T (WHEN PLACEMENT-ICON-POSITION (IL:* IL:|;;| "ensure the icon is placed correctly") (UNLESS WINDOW-ICON (SETQ WINDOW-ICON (SHRINK-WINDOW WINDOW PLACEMENT-ICON-POSITION))) (MOVE-WINDOW WINDOW-ICON PLACEMENT-ICON-POSITION) (WHEN (AND (IL:OPENWP WINDOW-ICON) (NOT (SHRUNKEN? WINDOW))) (IL:* IL:|;;| "we opened the icon by moving it") (IL:\\CLOSEW1 WINDOW-ICON))) (IL:* IL:|;;| "place the window") (WHEN (SHRUNKEN? WINDOW) (EXPAND-WINDOW WINDOW)) (UNLESS (EQUAL PLACEMENT-REGION WINDOW-REGION) (SHAPE-WINDOW WINDOW PLACEMENT-REGION :CURRENT-REGION WINDOW-REGION :NO-SHAPE (AND WINDOW-TYPE (WINDOW-TYPE-PROP WINDOW-TYPE :NO-SHAPE)))) (OPEN-WINDOW WINDOW) (UNLESS PLACEMENT-ICON-POSITION (DELETE-WINDOW-ICON WINDOW)))) (IL:* IL:|;;| "call the user hook") (WHEN (AND WINDOW-TYPE (WINDOW-TYPE-PLACER WINDOW-TYPE)) (FUNCALL (WINDOW-TYPE-PLACER WINDOW-TYPE) PLACEMENT))))) (DEFUN UPDATE-TTY-PROCESS (ROOM) (IL:* IL:|;;;| "update ROOM's notion of which process has the keyboard.") (SETF (ROOM-TTY-PROCESS ROOM) (IL:TTY.PROCESS))) (DEFUN PLACE-TTY-PROCESS (ROOM) (IL:* IL:|;;;| "place the keyboard per ROOM's TTY-PROCESS field") (LET ((PROCESS (ROOM-TTY-PROCESS ROOM))) (IL:TTY.PROCESS (IF (IL:PROCESSP PROCESS) PROCESS (IL:* IL:|;;| "if no process specified, or the specified process is dead, then we give the TTY to the MOUSE process ") (IL:FIND.PROCESS 'IL:MOUSE))))) (IL:* IL:|;;| "other essentials") (DEFUN FIND-ROOMS-CONTAINING (WINDOW) (IL:* IL:|;;;| "return a list of all rooms which directly contain a placement for WINDOW") (LET ((ROOMS)) (DO-ROOMS (ROOM) (WHEN (FIND-PLACEMENT-IN-ROOM WINDOW ROOM) (PUSH ROOM ROOMS))) (IL:* IL:|;;| "we need a general way of handling un-named rooms, but as there is only one now, we can just special case it.") (WHEN (FIND-PLACEMENT-IN-ROOM WINDOW *OVERVIEW-ROOM*) (PUSH *OVERVIEW-ROOM* ROOMS)) ROOMS)) (DEFGLOBALVAR *ROOM-CHANGED-FUNCTIONS* NIL) (DEFUN ROOM-CHANGED (ROOM REASON) (IL:* IL:|;;;| "called when we notice a room has changed to ensure display is up to date.") (ECASE REASON ((:EDITED :CREATED :DELETED) (WHEN (IN-ROOM? ROOM) (IL:* IL:|;;|  "if we're in this room, redisplay whole screen") (IL:* IL:|;;|  "note: we depend upon our caller to update placements") (IL:WITH.MONITOR *MONITOR-LOCK* (GO-TO-ROOM-INTERNAL *CURRENT-ROOM* :NO-UPDATE T) ))) (:PLACEMENTS (IL:* IL:|;;| "we presume our caller & the hooks handle these cases") )) (IL:* IL:|;;| "call hooks") (DOLIST (FN *ROOM-CHANGED-FUNCTIONS*) (FUNCALL FN ROOM REASON))) (DEFMACRO DO-INCLUSIONS ((ROOM-VAR ROOM-FORM) &BODY BODY) (IL:* IL:|;;;| "descend breadth-first, left to right down the inclusions of a room, performing BODY with ROOM-VAR bound to each room. ") `(LET* ((,ROOM-VAR ,ROOM-FORM) ($ROOMS$ (LIST ,ROOM-VAR)) ($QUEUE-HEAD$ $ROOMS$) ($QUEUE-TAIL$ $QUEUE-HEAD$) ($POCKET-ROOM-NAME$ *POCKET-ROOM-NAME*) $INCLUSIONS$ $INCLUSION$) (BLOCK DO-INCLUSIONS (TAGBODY $LOOP$ ,@BODY (SETQ $INCLUSIONS$ (ROOM-INCLUSIONS ,ROOM-VAR)) (UNLESS (LISTP $INCLUSIONS$) (RETURN-FROM DO-INCLUSIONS)) (DOLIST (INCLUDED-ROOM-NAME $INCLUSIONS$) (SETQ $INCLUSION$ (ROOM-NAMED INCLUDED-ROOM-NAME)) (WHEN (AND $INCLUSION$ (NOT (MEMBER $INCLUSION$ $ROOMS$ :TEST #'EQ))) (RPLACD $QUEUE-TAIL$ (SETQ $QUEUE-TAIL$ (LIST $INCLUSION$))))) (POP $QUEUE-HEAD$) (IF $QUEUE-HEAD$ (SETQ ,ROOM-VAR (FIRST $QUEUE-HEAD$)) (IF (AND $POCKET-ROOM-NAME$ (SETQ ,ROOM-VAR (ROOM-NAMED $POCKET-ROOM-NAME$)) (NOT (MEMBER ,ROOM-VAR $ROOMS$ :TEST #'EQ))) (SETQ $POCKET-ROOM-NAME$ NIL) (RETURN-FROM DO-INCLUSIONS))) (GO $LOOP$))))) (DEFUN ROOM-INCLUDERS (ROOM &OPTIONAL SORTED?) (IL:* IL:|;;;| "returns the list of rooms which include ROOM.") (IL:* IL:|;;;| "note that every room implicitly includes itself. the motivation for this is that most code which wants to map over includers also wants the root.") (IF (EQUAL (ROOM-NAME ROOM) *POCKET-ROOM-NAME*) (IL:* IL:|;;| "special case: all rooms include the pocket room") (ALL-ROOMS SORTED?) (DO* ((INCLUDERS NIL) (IL:* IL:\; "list of included rooms") (QUEUE (LIST ROOM)) (IL:* IL:\;  "list of rooms to examine ") (INCLUDER ROOM (POP QUEUE)) (IL:* IL:\; "room being examined") (INCLUDER-NAME (ROOM-NAME INCLUDER) (ROOM-NAME INCLUDER))) ((NULL QUEUE) (IF SORTED? (SORT INCLUDERS #'ROOM-SORT-FUNCTION) INCLUDERS)) (UNLESS (MEMBER INCLUDER INCLUDERS :TEST 'EQ) (PUSH INCLUDER INCLUDERS) (DO-ROOMS (ROOM) (LET ((INCLUSIONS (ROOM-INCLUSIONS ROOM))) (WHEN (AND (LISTP INCLUSIONS) (MEMBER INCLUDER-NAME INCLUSIONS :TEST 'EQUAL)) (PUSHNEW ROOM QUEUE :TEST 'EQ)))))))) (IL:* IL:|;;| "bootstrapping & resetting") (DEFVAR *RESET-FORMS* NIL "List of forms to be EVALled when Rooms is reset.") (DEFUN RESET () (IL:* IL:|;;| "delete all existing rooms") (CLRHASH *ROOMS*) (IL:* IL:|;;| "bootstrap *CURRENT-ROOM*") (SETQ *CURRENT-ROOM* NIL) (SETQ *POCKET-ROOM-NAME* "Pockets") (MAKE-ROOM *POCKET-ROOM-NAME* :PLACEMENTS (IL:* IL:|;;| "put promptwindow in pockets") (LIST (MAKE-PLACEMENT IL:PROMPTWINDOW)) :BACKGROUND (COPY-TREE '((:WHOLE-SCREEN (:EVAL IL:WINDOWBACKGROUNDSHADE))))) (SETQ *CURRENT-ROOM* (MAKE-ROOM "Original")) (SETQ *MONITOR-LOCK* (IL:CREATE.MONITORLOCK "Rooms")) (IL:WITH.MONITOR *MONITOR-LOCK* (GO-TO-ROOM-INTERNAL *CURRENT-ROOM*)) (IL:* IL:|;;| "install our aroundexitfn last so it gets called before greet") (UNLESS (MEMBER 'AROUNDEXITFN IL:AROUNDEXITFNS) (SETQ IL:AROUNDEXITFNS (NCONC IL:AROUNDEXITFNS (LIST 'AROUNDEXITFN)))) (IL:* IL:|;;| "do reset forms") (DOLIST (FORM *RESET-FORMS*) (EVAL FORM)) (IL:* IL:|;;| "may have lost some windows...") (CHECK-LOST-WINDOWS)) (DEFGLOBALVAR OLD-WHOLESCREEN (COPY-REGION IL:WHOLESCREEN)) (DEFGLOBALVAR *SCREEN-CHANGED-FUNCTIONS* (LIST '%INTERNALIZE-ALL-PLACEMENTS)) (DEFUN AROUNDEXITFN (EVENT) (CASE EVENT ((IL:BEFORESAVEVM IL:BEFORELOGOUT IL:BEFORESYSOUT IL:BEFOREMAKESYS) ) ((IL:AFTERSAVEVM IL:AFTERLOGOUT IL:AFTERSYSOUT IL:AFTERMAKESYS) (UNLESS (EQUAL IL:WHOLESCREEN OLD-WHOLESCREEN ) (DOLIST #' *SCREEN-CHANGED-FUNCTIONS* (FUNCALL FUNCTION)) (SETQ OLD-WHOLESCREEN (COPY-REGION IL:WHOLESCREEN )))))) (DEFUN %INTERNALIZE-ALL-PLACEMENTS () (IL:* IL:|;;;| "called when we re-boot on different sized screen. re-scales the placement regions & icon-positions of all placements.") (LET ((OLD-SCREEN-WIDTH (REGION-WIDTH OLD-WHOLESCREEN)) (OLD-SCREEN-HEIGHT (REGION-HEIGHT OLD-WHOLESCREEN))) (UPDATE-PLACEMENTS) (DO-ROOMS (ROOM) (IL:* IL:|;;| "do all the named rooms") (%INTERNALIZE-PLACEMENTS ROOM OLD-SCREEN-WIDTH OLD-SCREEN-HEIGHT) (ROOM-CHANGED ROOM :PLACEMENTS)) (IL:* IL:|;;| "redisplay the current room.") (IL:PROCESS.RESULT (GO-TO-ROOM *CURRENT-ROOM* :NO-UPDATE T) T))) (DEFUN %INTERNALIZE-PLACEMENTS (ROOM OLD-SCREEN-WIDTH OLD-SCREEN-HEIGHT) (DOLIST (PLACEMENT (ROOM-PLACEMENTS ROOM)) (IL:* IL:|;;| "re-scale placements to new size of screen") (LET ((REGION (PLACEMENT-REGION PLACEMENT))) (SETF (PLACEMENT-REGION PLACEMENT) (INTERNALIZE-REGION (MAKE-REGION :LEFT (EXTERNALIZE-COORDINATE (REGION-LEFT REGION) OLD-SCREEN-WIDTH) :BOTTOM (EXTERNALIZE-COORDINATE (REGION-BOTTOM REGION) OLD-SCREEN-HEIGHT) :WIDTH (EXTERNALIZE-COORDINATE (REGION-WIDTH REGION) OLD-SCREEN-WIDTH) :HEIGHT (EXTERNALIZE-COORDINATE (REGION-HEIGHT REGION) OLD-SCREEN-HEIGHT))))) (LET ((POSITION (PLACEMENT-ICON-POSITION PLACEMENT))) (WHEN POSITION (SETF (PLACEMENT-ICON-POSITION PLACEMENT) (INTERNALIZE-POSITION (MAKE-POSITION (EXTERNALIZE-COORDINATE (POSITION-X POSITION) OLD-SCREEN-WIDTH) (EXTERNALIZE-COORDINATE (POSITION-Y POSITION) OLD-SCREEN-HEIGHT)))))))) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:PROMPTWINDOW IL:AROUNDEXITFNS) ) (EVAL-WHEN (LOAD) (IL:* IL:\;  "smash system code which moves windows around on reboot so we don't fight with it.") (PUSHNEW '(IL:CHANGENAME 'IL:\\STARTDISPLAY 'IL:\\MOVE.WINDOWS.ONTO.SCREEN 'IL:NILL) *RESET-FORMS* :TEST 'EQUAL) ) (IL:* IL:|;;| "random") (IL:PUTPROPS GO-TO-ROOM IL:ARGNAMES (ROOM &KEY NO-UPDATE BAGGAGE)) (SEDIT:DEF-LIST-FORMAT DO-INCLUSIONS :INDENT (1) :ARGS (:KEYWORD :BINDING NIL) :SUBLISTS (2)) (SEDIT:DEF-LIST-FORMAT DO-ROOMS :INDENT (1) :ARGS (:KEYWORD :BINDING NIL) :SUBLISTS (2)) (IL:PUTPROPS IL:ROOMS-CORE IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (5690 5979 (IN-ROOM? 5690 . 5979)) (5981 7495 (MAKE-ROOM 5981 . 7495)) (7497 8405 ( COPY-ROOM 7497 . 8405)) (8407 9647 (RENAME-ROOM 8407 . 9647)) (10224 10594 (ALL-ROOMS 10224 . 10594)) (10596 11110 (ROOM-SORT-FUNCTION 10596 . 11110)) (11174 12121 (DELETE-ROOM 11174 . 12121)) (12632 12790 (MAKE-PLACEMENT 12632 . 12790)) (12792 13313 (COPY-PLACEMENT 12792 . 13313)) (13315 13731 ( MOVE-PLACEMENT 13315 . 13731)) (13733 14297 (ADD-PLACEMENT 13733 . 14297)) (14299 14725 ( DELETE-PLACEMENT 14299 . 14725)) (15117 15646 (GO-TO-ROOM 15117 . 15646)) (15648 16138 ( GO-TO-ROOM-PROCESS 15648 . 16138)) (16140 17282 (GO-TO-ROOM-INTERNAL 16140 . 17282)) (17284 17654 ( CALL-ENTRY-FUNCTIONS 17284 . 17654)) (17656 18029 (CALL-EXIT-FUNCTIONS 17656 . 18029)) (18031 20678 ( UPDATE-PLACEMENTS 18031 . 20678)) (20680 21211 (FIND-PLACEMENT 20680 . 21211)) (21471 22821 ( UPDATE-PLACEMENT 21471 . 22821)) (22823 23037 (PLACE-PLACEMENTS 22823 . 23037)) (23039 24064 ( FIND-PLACEMENTS 23039 . 24064)) (24066 27240 (PLACE-PLACEMENT 24066 . 27240)) (27242 27419 ( UPDATE-TTY-PROCESS 27242 . 27419)) (27421 27871 (PLACE-TTY-PROCESS 27421 . 27871)) (27915 28469 ( FIND-ROOMS-CONTAINING 27915 . 28469)) (28520 29523 (ROOM-CHANGED 28520 . 29523)) (31104 32572 ( ROOM-INCLUDERS 31104 . 32572)) (32711 33760 (RESET 32711 . 33760)) (33910 35084 (AROUNDEXITFN 33910 . 35084)) (35086 35801 (%INTERNALIZE-ALL-PLACEMENTS 35086 . 35801)) (35803 37536 ( %INTERNALIZE-PLACEMENTS 35803 . 37536))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-CORE.DFASL b/rooms/ROOMS-CORE.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..3bcf697448cca4a6880c57f27bfb6495b6104d6a GIT binary patch literal 23510 zcmdsfYjjlCmFB&-O790HA%qYZ$|?}Hpk%<7z;*;GsYK6-3yf6{#~%H0q7+{!+}BXtu2!GcABw3^PQV2;yDBCA4?8RBoDab zLleiw4h)@G?{0DXllzm0_W`I)8#ZlN@7~yY$EMahHf(CH=<>zG0@roDcJ=e=^M+?s z!@v77KV_7vs?xc*gfcG8(9=&(Rd$8KfzDXKmjL)?r=g{vnsPP86TYb57xQ~V(Z2pf zQ+mp^(LFJG)H{-VAUQ&4J8Ynf^k=4uyZWP@iI5phpVcRg8_=Q4ALt52177MEuXmX) z^yoDE0#Tz3FBF>n33OSAWQji%3-HTEUHYt(N&tsH;p+$o(o+sB7>bJee4V|%ZWI(S zn)UQl;X~15BO@QzFi-8q>=b!wJkNPfE|poPr>ZtBfPI{5l!HLlT>!ZV0QJSpKF4xG z2oJ-n*NJ59dQ_p_9O%J_Ii)DWno_pK3t5gws)9B*584QWf@f26*h8!cep`+#kmZ z#&Zfgfb{N|*&p?Dp^INnBnG`eQ)eJ9O&JkX(kFQtlk)shNyOJ1@Y0)-?KJxav)M9# zARI{K)R)Bq1a7v4bWddhL^T5u2Qs`i(V^qBhFV2G?)2FL%)7FwvpPxv~X2LQ%iDgPY})#sb|~87^I%Z5t29`lG#p=r*ocnymPtrL0QDy9`NRt<;=Mdb1v;Ry$LhBj8*-8v~{wt2(f_gME%)9 z9L*gN zAKhNBd&qrc=rB0&=)Qx={S(v)c62-u>+ekTqi5xj?Od|m7Yh+1iepMeyyCR{swI84 z3~!X!6iC&@p(sxm%c0gQuewF8qf&rQ^Rf1ZFC4bBYNOhqn!)kZKnBLrqa#BQ1IZ&3 z<3!DOtG4vnBDGifRX}yAZuD2-^Do2~SS|0Nyw$KKz4E@%;Uo9C?;RUG>>fR0&3|Il zJ#=Ig=orIpQTM1;^jp~k))PvYF)!GEFU@hY+LAt7fx&xGU7cOdyv@Hjr#uu*1Y%KN zn3t@klcu_0Q*q5=sma??7%r?L7^gO$9koN)P?jEwjC1D#=CEZ~J& z;v-TaCAu&^7*7Nu<=B2TP%pfF;8IZTGA|Y0j+!OZ+6#po#!3PE8CtaMAE|oM)5UYjc z-|x35eYOs88PL}~z)5vRL5K9oNN~UgC7d#b9u`KM~(bTy%}hFJp1!%x_YgWb_NdeldCSB=_-;YK@J=UrwTbCv36ABv<{D zYP73#ttQVQM%WCn<-*w;xm zmKj63q%Q`(-U$VIa&l687Fas36}Nwf2;8Nq)p+P^$P%xIZOvq+=>}+vw^sx26}IXVG4qY6+lr6cOdgalf z%fqkOB_*j>Q+q1sPY=C1jE7xXmfGW*PwlCm|Kt!7!${=R)S#x8YHCnZJHHn|Xshg>w-1fd@r6oHO71d&v1=%-mF9-T2nZ0R-ZTPOjk|uyje@Bnwrviv(7@`yA_&o z>MH(Ot5HNW)Yuys#2WHu!ZT+pQ7*fYD3{$v$mMP#WMvC!MTD@E*a~G%2XQ&#IUdz; zA0bq)kMLvJW`5MI;m6X&{HWzUrZ2IP{|6v{d;0|;qv@IYVMb4oe^bI~_i6JpKNZ{z zw7;eSFTwWL44?%MC$NG?A#j36F%W`BDX>z z3v`BHPVMGBeA~6L@zoSNxZVc?>8a(IeMaMU=etFK346CU^9nRp@#7}uiu%pgx-_j) zEz49(xoR0@w`x`*N6IyN>2D`@0|d-#Y<0FEdbS1ng9*zQB=^E%qDrdm)v+rUk9%>(j$7EA6~zIyH%Xea5Uj9dS$#Po}<C`E-JKGy=yku4yXgl*?dW@atdh`o3?(l4F*lIiQ zOpw|>Hhd~InL3lYd@|*F>FROKQKELMp%OipsWSB%G=Wc&xb6-lh&t|Od~GRMr#!2a zhuK@Jj_G2)>t(+Bw~_~c|H7dZ!#1BvdW;K9rz?%WDoD+p9J2TvFCLsTXi77tYmDl$e5m4 zE_>Z{aqrer0-S9WKyggN4pQ;zW+s-8+{_Wx4ULJ^(5&jKw0eWGmFurS^ z#~;Sx(D>E!rVH%WtOmbLfz_I|jxWu0o3(~x)??P{X3dq^Mzij-W}SgDW7+)7I^Gb|Ota>UhEn&K_qHsNvsQ{$0wyb^N;w8@Z|x zX0o}%YbJt$7{5|Ztokb|N{>IItq#vKkrU+)(|g*xlnkS)AP|e0F)I2cawV+GkWxY= zKZXzxPL&lKs)1_0!h<*5ubM|VwPinEF6`vK?vj!syj%(Mk&iOGT*D*3xtNCjBIHex zbsj+Zv}&QplgdMnPf2c)AKK5k!+KO`Kjq{yO8x^U>nQp6oLoxDzvE;rCI6a}ODOqm zj0W3xfM@ju)kbB{$m7$ht(_Y#6BbqHmd>iBBPW{b-RY?t%>xH;EOF#MnC?f%Mvo@P zCQi6VhQ}wskKD09q^p_w{5@HF^u{$7>Ynt}N*{Az%Qg6kxO->>2Q>#yxRVc}r}2UG z)Fyv&Bsr0k0&>P=`1b)Qo$i~C508wv_m7N@CvAtr&0qyyOUwDz5$G5L^TmL~vSEBo zeHQaG=2B2~QkO%|^~@{}>AagR_nhkuH(q)yoT|V3V#t`Ac`Nq~XLbu(eH2<0&J}YR zuKEW^ZW^3-QH>U?F+xo8V2OqgN{`jBlwYghUkGt8tS!URWZ*!MqlT$sI78Td&Wgy3 zM5DgGzVIL+__+*?LSGM1$&)B4Vt-hu>k#8U7UM@pv+62R;Zkb!IprBso&!{_{rVo| z*}*O9dX*=@sin)5$I@Xc)Or>pr-0L%cAc?t<(YOv55A_o?n;p-Ve!b&;e7{&Xyr4i zKdB;2(qS_W2QTT#q$(HDkqeYsO?U7>-I(wvz~5b#L&5Lulo#m4r({=OA{KcOP#rxg`Z0!WUo9qH7zso=09q^%43JDV$#+I<$VIC~pgv zuU;MTb;e9~@PX3pY>vN7E7+!*?!b(l&{4V?Rnv_O{y5olPO{>}By7w=B!rdCGn2^p zRH~ss@|f&W;n@-miwbSHRW%)iET)dV7HHN{u#=grHdCe6i9UHmSL^iUWVqX`MBJDV zYmH=7nm9XvU?uhfhi`vCBUCT4P@Qv(a$eg;m>$$G1`Sb8van}U%w>BB&!oiE^Q1Uc zZ=v=P=k=miUrmJ69f-yUBL%CNME*xTiZZ9)OBmHdF7mp9Eq2gRihe7o)6(HTG}5aw zNVn&`0Ovf=gIN^s6BIw9t9^uG2Yewnk#Pu2#%?B98aqt?AP`Rvh@}1CUmYTjQbCdq z^lL1T5iy|*?AN*W*~Oy!F(;F)Nvy~KE81^lHD%e54}r7N32nf?&B3HdnHGSt2$<_I z!Wx8WH{|M1;5TbovR~v|EA&*(h26;B8 z&pSxwJVzwDvmNx=^O^=zWSCb27GroiOoq)pobP>o))V2>ygWW91_>|Lq*W6(F3)^7 z%O2_ndxYS>^=gisg~w+{CBJs6s8mnQ&DLOCOQo_Z2omnbA_apSrBzMv&2g*b zarWNXM9ZnYiP)O=R3=QT(ouxX(_EC@JcIy3UJ1SXESm?~r)gcFz>*w4Cc7m7hFeH_ zNnpoTB&)#Z<%Fp}9*B{fbrS|H$%zgi5ntIK^#()!fY**NV6mW0R-vwpwvly6r5Xxo z^k+y}l5=H0UKY#q(pp@52REr!Z372MM9MLZJArAlD z89z4$w4Eb#c)(EnSoDJbT6jBWf5N(t_TO$%Z5}T8@71bJS8e3lFCf=-o48fkli$Xy zQIm9zSHF!nfmLpK_2J1c;11cI600izmwfo#;vIwtoS9mhAGVR>=q5VWpA^moI*H}*O8r#WTV>`KP#K~P_36(d>@?G09sTxwJg}5jsq=i(L z{UEb|zKHDVwZi*Ac`m0Tv*9d1wm7is#ex0q8b;(hBD>!f75rap^!*6vGyk7Du&ufN zh|ERH@C8%O#&7BM3{QjQ8U58_)mEX}oY?5BtS+%6b!JX~TI1k%Mc1prl5x;^2hU-= zQFYp;0T)bMr(v)(Bk=R5OGK7q9dO?{nyOz2=XbjDTgE^Zy^wz-zxWmCkh!LS3ShC9 z@IGm0Au}KXpAH)W`O9U|qfwzADB`Z(&~pf<3;hg8KbBz6&4{I*TOwAhr6(5hpt;q> zTvA~v1F8#?zb554#q03~2Ycu-S%cVe?13_IQdl8=r2*BpjiIi;Rke9J^=_kT6Svnp zHL9(W%ib;`PC{FWw?j8(b*K0nIvAGu&gqn^-6v^V%N3kiD(-yfyy&!KW2BV&mQ2>5MR_=NHdL3socD+#bzzt2 z+BQ&@=4~)m7yJlvd7WUL_%5{DjqB&+bRa~<{F1!_!he z$2dG!DqhjrZsloHo<_CpM(`~M+`D8p8-csnr>ni-Ql4T3Ne;Kbv+5w`68Ok-$piWz z$mRoq-UgrvQlrKKxL7EtmO$l-B`kA{+V?_Aiqc0sJz9l5o^yKio&Z{GJX=ZnBPU3$ z%T#N*YNZpTW;#Kl@JsjTy>2>0Vkat&zxE|LdvtXFq2$E48&Ua)j^fiKUZhQ`^;)4O z3r@K5!WaRb1s`H`h-7c(I32N4H>pwTPv6MalduzB6;2L(IrTvYi<{F^Hvl=AgT;lR zj!oHfMu#lfg2Oe3FyE#XYIC{TY&52)Zug1D8d$ma*pdAc!=p#|R1j#{KQuCeXw`j5 z#M~#{LxM3JyWz+!IhH&?Mkr5jz1sZIrvz(xMgElXVl=N~MqA3&7MfA(_0MP|dGAEd zbhcoh^zC*nFK`$;sIKjfoC6v;Nqy))mZ>rvceAP#AjhI6x&QIcoA0|-=jIe~+2fvl< zg9hg|lveMegW_g{X*Wl4y3yPf?&fW4w5(O08pHtIjjg$rAr#9g$3nrZ;I_hlu4W+F zUg23BY_FW>1pFb;qMG{I93yQbfdC`RzGSILL@)kPvM#$@H@7;sfTfkOhb>Nb4HCBi z(xP3F?UbhL3uOo~ZYIFtw4Qzz&QFmh09m9FH z7RRiL*#AcEn##_RxpL@r&}P)#BZ3}S<$S7i=F#@d_syHQTT3%WuvoVOts ziEynN40cBAwh{QOx*vnBqxBphHvx~z{-T^E#&Jh>l>s$Sl2z`wU%eC)E5w}vII1+m zgD&sd3m7z6mD%;2VT8}8cqv4#^3q_TILFnW=2}kjPtHQo%#7A+FUscPUar2QgCBR2 zO;;8*6QQm_FIn}fVUtvdLU7kATBco{2wzJy#!ocYpLzsgELt5A z;)xM`+3>L($SkU(7K0Tqbc-15FvValjv-9l7Z2n@2E_~rGsNqaUDGj)N_6n=c-QA1 zpa*G@8SU?LfR5F;gg=WntdMi=UVg*k3(P=f-prX)=<7L|oTMDoU7L__s-yJ?6(Gep z0W!v%`JBRbbrTkJvXx4rrdMLkktyo%b$8=ZQ!&l;YwBTod{G^LgtjzmQh9!v6Y8NO zDm5m%VuHau%|mAiVH|hZ2rF;ws6kv!5E6b!*JA@5kttq2p>8Pk;;VM4)UXiLQ$VN#imFbU>G zn79n|Y)6>PJR3kY zwH*OSCj_A8Us$@C&aYZYFP-@R8);kA#PuU>iH)>8l_ra`Fmw!}`tKwUU;X{r5bUXxs24-$xR;lg zMVUu{P=Y83_Nsps^8;6oJ@^`F!?UOQ8MB&#kY*aq+Sz)u)_${6nU(ye?2mI4k~w+m zrK`P&=XvSs;!yAFU&~@DYw-2hD6i3XGiR3>5wdeh81~Y_M31v3b~- zEu;1Rwglm%GP_L|{f#%?Tk0U~zo*rMA6F0Dt#Iywta0Zy6%jFf$!5XS(@We1MYibA za+Hkrzvb}*dCaR;>g=nk4PnXk5+fE7s?&Z85qB;*V*EaRXvC1oBoDoL@XGTeMuzf& z;B`CizRYBZ`4eku2Q^tN3^>N}P;k{5v-(tOX1Ttn#-b9_b>)m%^GRNZ`I&#*<2ny= zTdf-|oBQqN1!wLTwd3oe=$iWz?za}*?WmRIu1quOaD?5tuvyu7*%Su&pL>nF&-LnH zfRWkSh}9en5OkJdfUj_fT}X43VT~eX`D=tzOWRRRXe19%#`VC*K|jnallFonEBFy8 zIIcX~RolmuXPs(Y$;gFJy1{bC<=+K^Big=Gc3%4!AEE^fT_W$8n&@yoC2BY4`G-!D z@t@VZ++$?p;||b-rB31`@WULo6|7c`t5h2u9T)mdQoC7A(!W=V5(h4>=o|Q8kpkhJ za_@=5Q|O+tflC~1Jn8R=f()N4ojJk1LU#U#K4B)yUXJyzjUABc2YK<1u{mvgTvx}) zi$_PGmKRu#upovW060YP%69bRd7mx{SEFzz+qd@m%Znu`ZYjhS4`1%FDveBK4|7Sl zeTFahT9wW#-;h)nkc8 z2lmlzR z+~Z!%HM=-qL)!Ai*qF0tOSz1aF=( zYr$yh^*wbqqp7(vJ^V>TXHrP!KRpl0R)4`_4d2e^HN>P&TfAmwZq@#ti>CNfsa&4I65M zYC}YCsVG$^gqroFMRVE(n=*N+>`*ZlBpvGhC@n<`%sy5Bt=eIk55%A#&@6NiVzn<5j7JM;mStn99|C09U zV5)~b2v)_+!#%Sb!Y|sTm-Aovtn?{?)E1!DIOi=;uN%Pmp08T3M$*-99ewi=>F>DY?&rt1hE$tqSg$NoZMcuj2U~b< zFJ91uX&Q+5?SUzfnpvXXZSm32mFeEcdW?%R?|hzH!sk-YE-fU$%$#6mJft&^p;_`* z=eRU|$Vs0hSk#2;$Fc1pMAXp)VU_y`{T_~HFy`TrIIrDK5ZT8n9|+Cod<2O^V@X`* zs%%^)YY{X^JST#bBkTZcZiMFMTW_^wm1ckh3OU5mMKj7c^+=JC`whHY;_u<)z;w_h z7hcG-NLPk)PA6#eYusjM-xPo4#i-(8?CUMYa&>#Tx}7fWigmCF_iGV$1M~UM+ zT)S_?uv{Adsu>O}oU4iacDQ+JdGRcduEB5`8&otucF~H=hAQZbn^9u`6j~bSgs;s@ z*Q*-TP~mQMJKdhNTBrs#W%OFUr=(x5WW00<77jUZ@16rx^g~k4znA&9b_>?#W+qFS z7fTeG5zlj&3oejPiH>Hmtk?E=ZoX}kaf2FT3(AN&Enii&Y9SvcRH{VK_7k#;a07<5 zUCP|4kM7hVfo*Vz<8v@z#Y$}{h=Ds1e1Cs&&ENo?&77L1{hxgR=SS4bW=1E|@ zdiBC%!_{(0-qJ*!T0$y8{xsjoLT<+&xU51uLtC?M)=^_Fd%0v^Z z?f;Q&FS>zebn{_@L6>o~IkIvP(}lG0GyZ*xFY4kf#fthPTUD9V_Um@TUs6Nu1)IUJ zd(+_CFKHPCp9P=}-+I`}QYOGfZ{J4)0z-Wg5MjK%&)Sy8DXIZt83%rF3FdrqSDW8` z#~%M@XjYcR73NBy$e91fZuFR)_&LA)Zx*!1KU+~~`avn@-)qkZJpk0g7)65kF{ZtE zIEe`JpgDMR;MO~H8ttm|dyn;Yf0QC+X>N#DCaYLXE=)$)-fxxJ#DR5^eOutMY8_&b zzHK*t3tvniWWFO~T%U1Vn=y{_K0Jh_{2-gy6cB!*E0b(um}E7X7;Fiir&C3iz4{bn zpcRTu6mr_K%cfX`u#Eum*1vwc24)44zcHHwiYUem^{q*SYA%1X6vAOXe-X* z=P^pL5~9tE5>l5{LU5M_H zv(F(ua*zOZ`~=7#bE;0?tg^n+^WozIxEB_b+7ooDz9CHa+9*l@AKFS*JYC=>j>lQIf6}cI?7qt@T%qebWdBwOD z7g%w%*#dcYVZO?(=MZ34OX4-=?pM6LjGtVR62T>X^@~nAIi=q%pps^Mg>3}-b|Ed4 z@m)hSjSZw6I|_I~pHO{H!``pV*e?*zl&j|mo=#*Vo(U1(1k-U65-IZxbdaK5QJ9pS zo9;%sT5dwx8VTuUy=r~CT5pAM-K+w{w2C^zF^bc!pgx{uD9B>cKEuhUDESxJ(nlrv z38~zxM*CC?b7sA6HJ6AA4cukVl2(5T@KQ> zXe{H0tYsbkqgoa>rsMhT^yv;Fvo5&Q&9UM8hK~%5v{<4OU*zG>O?fjPJA$Fe*ab3| zh*_IGLWGg&4=jSus!sxc^kEuB-$`abQB zwDB1M>&b;+J!#S1Q@|a8c}DJSvmxWQ(t~G0Gc{HktoLy%N%4XV^@nLZyM^)3Kd<9W zPFU{CKiB6DTIS5}xIAZ-$hSjqJq6~RW7HP}w&OUH)lAWm3V9FxIk%mn7bYp`@UxWB zp4=l9?D=r`V_33sUl+bzLt*gvgiklEAr~NnFOA-r$%oBu%u#zCun2 ztsaO9%B4iQp!f-^K>DCB2HGvS6MM^l2C_UMa-3&x;BG42u(C3oGptL%Ib0E9`7Uu0 za6?`RF{Z3b75q61p7&?6vcnk#7?oDAPBY?Y5RD&Hy_>0>K7_C8IXft6>}pdj9A%+R z@rKu?bbO#dt0!p+kth9{VELpAch24@NxRP;Lz>r1OMKtNxbV`|V?w#ppj?OLjxFqjkT$Fg#3vh zKI)oN6byvAg9(;GQ;u0&h+VRSaPPRcTOM2F!QKSNy(JH*wnM6oKCfFS0Jb4nz~J9Pg&ij1 zz9J38yTgI5#0{zq;m52Xkw&zdd0!u+oPStZ+po#z9~gD;RteIe1YP6vyC5A#u(=n7W?wLtk*U(l^fW`(5bJJmW8uD2Ca?xJ4vaf1v_>_+ zyTi^5?F(cYxcS|`%qG8-O@5hKdKJ%w=a$(C9{#G{9bn-cFlT*U&;35e0bgUP<{PnQ zmluJ7R(t+RFZYD7ClfdB@Qp2C8IDHqK1fcwpw7`~WIG@_2+_wou=bSfKqCZhO(I>4 z8{A|Z!BEnT_l0=n`$Eh{FBqyF7hA?O@d!ZL#~^VQmaW9hJ78-%xQNvi$78~WAI}Va zU0=x~T0E+e%yQrZ$A~PX=i-24w(b-F literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-D b/rooms/ROOMS-D new file mode 100644 index 00000000..ec15a42c --- /dev/null +++ b/rooms/ROOMS-D @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:24:55"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-D.;2| 14267 IL:|previous| IL:|date:| "17-Aug-90 12:43:06" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-D.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-DCOMS) (IL:RPAQQ IL:ROOMS-DCOMS ( (IL:* IL:|;;| "Rooms' interface to Interlisp-D window system") (FILE-ENVIRONMENTS IL:ROOMS-D) (IL:P (EXPORT '(*WHO-LINE-ENTRY*))) (IL:TYPES BITMAP FONT TEXTURE) (IL:* IL:\; "windows") (IL:FUNCTIONS MOVE-WINDOW SHAPE-WINDOW OPEN-WINDOW CLOSE-WINDOW) (IL:FUNCTIONS WINDOW-REGION MAIN-WINDOW WINDOW-TITLE WINDOW-VISIBLE-P) (IL:* IL:\; "regions") (IL:STRUCTURES REGION) (IL:FUNCTIONS (IL:* IL:\; " positions") MAKE-POSITION POSITION-X POSITION-Y GET-POSITION) (IL:FUNCTIONS (IL:* IL:\; "icons") SHRINK-WINDOW EXPAND-WINDOW ICON? SHRUNKEN? ICON-POSITION WINDOW-POSITION WINDOW-ICON DELETE-WINDOW-ICON) (IL:* IL:\; "user interface") (IL:FUNCTIONS MENU PROMPT-USER CONFIRM NOTIFY-USER GET-MESSAGE-STREAM SELECT-WINDOW SELECT-BAGGAGE EXTERNALIZE-FONT) (IL:FUNCTIONS (IL:* IL:\; "keyboard interpretation") (IL:* IL:|;;| "these have gotten out of control. it might be worth converting these to one function which returns a keyword naming the selected operation. EDITCALLERS, anyone? ") COPY-KEY-DOWN-P HELP-KEY-DOWN-P DELETE-KEY-DOWN-P EDIT-KEY-DOWN-P MOVE-KEY-DOWN-P EXPAND-KEY-DOWN-P) (IL:COMS (IL:* IL:|;;| "add a lafite form for bug reports") (IL:FUNCTIONS MAKE-ROOMS-SUPPORT-FORM) (IL:VARIABLES IL:ROOMSSUPPORT) (IL:ADDVARS (IL:LAFITESPECIALFORMS ("Rooms Report" (IL:FUNCTION MAKE-ROOMS-SUPPORT-FORM) "A form to report a Rooms bug or suggestion" ))) (IL:P (SETQ IL:LAFITEFORMSMENU NIL)) (IL:* IL:|;;| "provide a who line entry") (IL:VARIABLES *WHO-LINE-ENTRY*) (IL:P (WHEN (BOUNDP 'IL:*WHO-LINE-ENTRY-REGISTRY*) (PUSHNEW *WHO-LINE-ENTRY* IL:*WHO-LINE-ENTRY-REGISTRY* :TEST 'EQUAL :KEY 'CAR)))) (IL:GLOBALVARS IL:PROMPTWINDOW IL:CROSSHAIRS IL:WINDOWBACKGROUNDSHADE IL:WHOLESCREEN IL:LAFITESPECIALFORMS IL:LAFITEFORMSMENU IL:DEFAULTICONFN IL:*WHO-LINE-ENTRY-REGISTRY*))) (IL:* IL:|;;| "Rooms' interface to Interlisp-D window system") (DEFINE-FILE-ENVIRONMENT IL:ROOMS-D :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(*WHO-LINE-ENTRY*)) (DEFTYPE BITMAP () `(SATISFIES IL:BITMAPP)) (DEFTYPE FONT () `(SATISFIES IL:FONTP)) (DEFTYPE TEXTURE () `(SATISFIES IL:TEXTUREP)) (IL:* IL:\; "windows") (DEFUN MOVE-WINDOW (WINDOW POS &OPTIONAL (CURRENT-REGION (WINDOW-REGION WINDOW))) (UNLESS (IL:EQMEMB 'IL:DON\'T (IL:WINDOWPROP WINDOW 'IL:MOVEFN)) (LET ((CURRENT-MAIN-WINDOW-REGION (IL:WINDOWPROP WINDOW 'IL:REGION))) (IL:* IL:|;;| "have to compensate for (possible) windows attached at left or bottom. IL:SHAPEW does this for us, but not IL:MOVEW...") (IL:MOVEW WINDOW (+ (POSITION-X POS) (- (REGION-LEFT CURRENT-MAIN-WINDOW-REGION) (REGION-LEFT CURRENT-REGION))) (+ (POSITION-Y POS) (- (REGION-BOTTOM CURRENT-MAIN-WINDOW-REGION) (REGION-BOTTOM CURRENT-REGION))))))) (DEFUN SHAPE-WINDOW (WINDOW DESIRED-REGION &KEY (CURRENT-REGION (WINDOW-REGION WINDOW)) NO-SHAPE) (IL:* IL:|;;| "open up IL:SHAPEW a bit") (MULTIPLE-VALUE-BIND (VALUE CONDITION) (IGNORE-ERRORS (IF (OR (IL:* IL:|;;| "if we don't really need to reshape") (AND (= (REGION-WIDTH DESIRED-REGION) (REGION-WIDTH CURRENT-REGION)) (= (REGION-HEIGHT DESIRED-REGION) (REGION-HEIGHT CURRENT-REGION))) (IL:* IL:|;;| "or we're not supposed to reshape") (IL:\\USERFNISDON\'T (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN)) NO-SHAPE) (IL:* IL:|;;| "then just move") (MOVE-WINDOW WINDOW (MAKE-POSITION (REGION-LEFT DESIRED-REGION) (REGION-BOTTOM DESIRED-REGION)) CURRENT-REGION) (IL:* IL:|;;| "otherwise do the reshape") (FUNCALL (OR (IL:WINDOWPROP WINDOW 'IL:DOSHAPEFN) 'IL:SHAPEW1) WINDOW (COPY-REGION DESIRED-REGION)))) (WHEN CONDITION (NOTIFY-USER "Error reshaping ~A: ~A" WINDOW CONDITION)) VALUE)) (DEFMACRO OPEN-WINDOW (WINDOW) `(IL:OPENW ,WINDOW)) (DEFMACRO CLOSE-WINDOW (WINDOW) `(IL:CLOSEW ,WINDOW)) (DEFMACRO WINDOW-REGION (WINDOW) `(IL:WINDOWREGION ,WINDOW)) (DEFMACRO MAIN-WINDOW (WINDOW) `(LET ((WINDOW ,WINDOW)) (OR (IL:WINDOWPROP WINDOW 'IL:ICONFOR) (IL:MAINWINDOW WINDOW T)))) (DEFMACRO WINDOW-TITLE (WINDOW) `(IL:WINDOWPROP ,WINDOW 'IL:TITLE)) (DEFUN WINDOW-VISIBLE-P (WINDOW) (AND (IL:OPENWP WINDOW) (IL:REGIONSINTERSECTP (WINDOW-REGION WINDOW) IL:WHOLESCREEN))) (IL:* IL:\; "regions") (DEFSTRUCT (REGION (:TYPE LIST)) (IL:* IL:|;;;| "overlay onto an Interlisp-D region, so we don't have to use il:fetch cruft.") LEFT BOTTOM WIDTH HEIGHT) (DEFMACRO MAKE-POSITION (X Y) `(CONS ,X ,Y)) (DEFMACRO POSITION-X (POS) `(CAR ,POS)) (DEFMACRO POSITION-Y (POS) `(CDR ,POS)) (DEFUN GET-POSITION (MESSAGE &REST MESSAGE-ARGS) (APPLY #'NOTIFY-USER MESSAGE MESSAGE-ARGS) (IL:GETPOSITION)) (DEFMACRO SHRINK-WINDOW (WINDOW POS) `(IL:SHRINKW ,WINDOW NIL ,POS)) (DEFUN EXPAND-WINDOW (WINDOW) `(IL:EXPANDW (WINDOW-ICON ,WINDOW))) (DEFMACRO ICON? (WINDOW) `(IL:WINDOWPROP ,WINDOW 'IL:ICONFOR)) (DEFUN SHRUNKEN? (WINDOW) (IL:EQMEMB (IL:FUNCTION IL:CLOSEICONWINDOW) (IL:WINDOWPROP WINDOW 'IL:OPENFN))) (DEFUN ICON-POSITION (WINDOW) (LET ((ICON-WINDOW (WINDOW-ICON WINDOW))) (WHEN ICON-WINDOW (WINDOW-POSITION ICON-WINDOW)))) (DEFUN WINDOW-POSITION (WINDOW) (LET ((REGION (WINDOW-REGION WINDOW))) (MAKE-POSITION (REGION-LEFT REGION) (REGION-BOTTOM REGION)))) (DEFMACRO WINDOW-ICON (WINDOW) `(IL:WINDOWPROP ,WINDOW 'IL:ICONWINDOW)) (DEFUN DELETE-WINDOW-ICON (WINDOW) (IL:* IL:|;;;| "delete the icon for WINDOW, if any. We know WINDOW is expanded.") (IL:WINDOWPROP WINDOW 'IL:ICONWINDOW NIL) (IL:WINDOWPROP WINDOW 'IL:ICONPOSITION NIL)) (IL:* IL:\; "user interface") (DEFUN MENU (ITEMS &OPTIONAL TITLE MESSAGE &REST MESSAGE-ARGS) (WHEN MESSAGE (APPLY #'NOTIFY-USER MESSAGE MESSAGE-ARGS)) (IL:MENU (IL:CREATE IL:MENU IL:ITEMS IL:_ ITEMS IL:TITLE IL:_ TITLE IL:CENTERFLG IL:_ T))) (DEFUN PROMPT-USER (PROMPT &OPTIONAL MESSAGE &REST MESSAGE-ARGS) (IL:* IL:|;;;| "prompt the user for a string. input should end when CR is typed.") (WHEN MESSAGE (APPLY #'NOTIFY-USER MESSAGE MESSAGE-ARGS)) (IL:RESETFORM (IL:TTYDISPLAYSTREAM (GET-MESSAGE-STREAM)) (IL:PROMPTFORWORD PROMPT NIL NIL NIL NIL 'IL:TTY (IL:CHARCODE (IL:EOL))))) (DEFUN CONFIRM (&OPTIONAL MESSAGE &REST MESSAGE-ARGS) (IL:* IL:|;;| "make sure prompt-window is un-hidden") (LET ((STREAM (GET-MESSAGE-STREAM))) (IL:* IL:|;;| "use IL:MOUSECONFIRM") (PROG2 (TERPRI STREAM) (IL:MOUSECONFIRM (WHEN MESSAGE (APPLY #'FORMAT NIL MESSAGE MESSAGE-ARGS)) NIL STREAM T) (TERPRI STREAM)))) (DEFUN NOTIFY-USER (FORMAT-STRING &REST ARGS) (LET ((STREAM (GET-MESSAGE-STREAM))) (TERPRI STREAM) (APPLY #'FORMAT STREAM FORMAT-STRING ARGS) (TERPRI STREAM))) (DEFUN GET-MESSAGE-STREAM () (IL:* IL:|;;;| "return an output stream for user messages ") (WHEN (%WINDOW-HIDDEN? IL:PROMPTWINDOW) (UN-HIDE-WINDOW IL:PROMPTWINDOW)) (IL:GETSTREAM IL:PROMPTWINDOW)) (DEFUN SELECT-WINDOW (&OPTIONAL MESSAGE &REST MESSAGE-ARGS) (IL:* IL:|;;;| "get the user to select a window on the screen") (WHEN MESSAGE (APPLY #'NOTIFY-USER MESSAGE MESSAGE-ARGS)) (IL:RESETFORM (IL:CURSOR IL:CROSSHAIRS) (LET (WINDOW) (LOOP (WHEN (IL:MOUSESTATE (OR IL:LEFT IL:MIDDLE)) (RETURN (LET ((WINDOW (IL:WHICHW))) (WHEN WINDOW (UNWIND-PROTECT (PROGN (IL:INVERTW WINDOW) (LOOP (WHEN (NOT (IL:MOUSESTATE (OR IL:LEFT IL:MIDDLE))) (RETURN (LET ((NEW-WINDOW (IL:WHICHW))) (WHEN (AND NEW-WINDOW (EQ (MAIN-WINDOW NEW-WINDOW) (MAIN-WINDOW WINDOW))) (MAIN-WINDOW WINDOW))))))) (IL:INVERTW WINDOW)))))))))) (DEFUN SELECT-BAGGAGE () (IL:* IL:|;;;| "returns a list of selected placements.") (IL:* IL:|;;;| "we presume UPDATE-PLACEMENTS has just been called & won't be called again by GO-TO-ROOM.") (LET (WINDOW PLACEMENT ROOM BAGGAGE) (LOOP (LET ((OP (COND ((MOVE-KEY-DOWN-P) :MOVE) ((COPY-KEY-DOWN-P) :COPY) (T (RETURN))))) (SETQ WINDOW (SELECT-WINDOW "Select placement to ~A" OP)) (UNLESS WINDOW (RETURN)) (MULTIPLE-VALUE-SETQ (PLACEMENT ROOM) (FIND-PLACEMENT WINDOW)) (WHEN PLACEMENT (CASE OP (:MOVE (DELETE-PLACEMENT PLACEMENT ROOM)) (:COPY (SETQ PLACEMENT (COPY-PLACEMENT-INTERNAL PLACEMENT)))) (PUSHNEW PLACEMENT BAGGAGE :KEY #'PLACEMENT-WINDOW :TEST 'EQ)))) BAGGAGE)) (DEFUN EXTERNALIZE-FONT (FONT) (LIST (IL:FONTPROP FONT 'IL:FAMILY) (IL:FONTPROP FONT 'IL:SIZE) (IL:FONTPROP FONT 'IL:FACE))) (DEFMACRO COPY-KEY-DOWN-P () `(OR (IL:KEYDOWNP 'IL:COPY) (AND (IL:SHIFTDOWNP 'IL:SHIFT) (NOT (OR (IL:SHIFTDOWNP 'IL:CTRL) (IL:SHIFTDOWNP 'IL:META)))))) (DEFMACRO HELP-KEY-DOWN-P () `(OR (IL:KEYDOWNP 'HELP) (IL:KEYDOWNP 'IL:DBK-HELP))) (DEFMACRO DELETE-KEY-DOWN-P () `(OR (IL:KEYDOWNP 'IL:DELETE) (AND (IL:SHIFTDOWNP 'IL:CTRL) (IL:SHIFTDOWNP 'IL:META) (NOT (IL:SHIFTDOWNP 'IL:SHIFT))))) (DEFMACRO EDIT-KEY-DOWN-P () `(AND (IL:SHIFTDOWNP 'IL:CTRL) (NOT (OR (IL:SHIFTDOWNP 'IL:SHIFT) (IL:SHIFTDOWNP 'IL:META))))) (DEFMACRO MOVE-KEY-DOWN-P () `(OR (IL:KEYDOWNP 'IL:MOVE) (AND (IL:SHIFTDOWNP 'IL:CTRL) (IL:SHIFTDOWNP 'IL:SHIFT) (NOT (IL:SHIFTDOWNP 'IL:META))))) (DEFMACRO EXPAND-KEY-DOWN-P () `(OR (IL:KEYDOWNP 'IL:EXPAND) (IL:KEYDOWNP 'IL:ESCAPE))) (IL:* IL:|;;| "add a lafite form for bug reports") (DEFUN MAKE-ROOMS-SUPPORT-FORM () (IL:MAKEXXXSUPPORTFORM "Rooms" IL:ROOMSSUPPORT *ROOMS-SYSTEM-DATE*)) (DEFGLOBALVAR IL:ROOMSSUPPORT "RoomsSupport^.PA") (IL:ADDTOVAR IL:LAFITESPECIALFORMS ("Rooms Report" (IL:FUNCTION MAKE-ROOMS-SUPPORT-FORM) "A form to report a Rooms bug or suggestion")) (SETQ IL:LAFITEFORMSMENU NIL) (IL:* IL:|;;| "provide a who line entry") (DEFPARAMETER *WHO-LINE-ENTRY* `("Room:" (AND *CURRENT-ROOM* (ROOM-NAME *CURRENT-ROOM*)) 10 ,#'(LAMBDA NIL (INTERACTIVE-GO-TO-ROOM :ALLOW-NEW? T)))) (WHEN (BOUNDP 'IL:*WHO-LINE-ENTRY-REGISTRY*) (PUSHNEW *WHO-LINE-ENTRY* IL:*WHO-LINE-ENTRY-REGISTRY* :TEST 'EQUAL :KEY 'CAR)) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:PROMPTWINDOW IL:CROSSHAIRS IL:WINDOWBACKGROUNDSHADE IL:WHOLESCREEN IL:LAFITESPECIALFORMS IL:LAFITEFORMSMENU IL:DEFAULTICONFN IL:*WHO-LINE-ENTRY-REGISTRY*) ) (IL:PUTPROPS IL:ROOMS-D IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (3813 4569 (MOVE-WINDOW 3813 . 4569)) (4571 6175 (SHAPE-WINDOW 4571 . 6175)) (6597 6750 (WINDOW-VISIBLE-P 6597 . 6750)) (7108 7227 (GET-POSITION 7108 . 7227)) (7306 7383 (EXPAND-WINDOW 7306 . 7383)) (7456 7578 (SHRUNKEN? 7456 . 7578)) (7580 7725 (ICON-POSITION 7580 . 7725)) (7727 7897 ( WINDOW-POSITION 7727 . 7897)) (7979 8199 (DELETE-WINDOW-ICON 7979 . 8199)) (8239 8528 (MENU 8239 . 8528)) (8530 8905 (PROMPT-USER 8530 . 8905)) (8907 9348 (CONFIRM 8907 . 9348)) (9350 9544 (NOTIFY-USER 9350 . 9544)) (9546 9766 (GET-MESSAGE-STREAM 9546 . 9766)) (9768 10965 (SELECT-WINDOW 9768 . 10965)) (10967 12022 (SELECT-BAGGAGE 10967 . 12022)) (12024 12173 (EXTERNALIZE-FONT 12024 . 12173)) (13181 13290 (MAKE-ROOMS-SUPPORT-FORM 13181 . 13290))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-D.DFASL b/rooms/ROOMS-D.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..52bf438c293565a9f97c03d7e58cc42dc7cb4de8 GIT binary patch literal 15078 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.;2| 7129 IL:|previous| IL:|date:| "17-Aug-90 12:45:39" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-GEOMETRY.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-GEOMETRYCOMS) (IL:RPAQQ IL:ROOMS-GEOMETRYCOMS ((FILE-ENVIRONMENTS IL:ROOMS-GEOMETRY) (IL:P (EXPORT '(EXTERNALIZE-REGION INTERNALIZE-REGION EXTERNALIZE-POSITION INTERNALIZE-POSITION)) (REQUIRE "ROOMS")) (IL:COMS (IL:* IL:|;;| "externalizing for suites & background text") (IL:FUNCTIONS EXTERNALIZE-REGION INTERNALIZE-REGION EXTERNALIZE-POSITION INTERNALIZE-POSITION EXTERNALIZE-COORDINATE INTERNALIZE-COORDINATE) (IL:GLOBALVARS IL:SCREENWIDTH IL:SCREENHEIGHT)) (IL:COMS (IL:* IL:|;;| "scaling used by placement editor & backgrounds") (IL:STRUCTURES SCALE) (IL:VARIABLES *ONE-TO-ONE*) (IL:FUNCTIONS MAKE-SCALE EQUAL-SCALES) (IL:FUNCTIONS SCALE-WIDTH SCALE-HEIGHT SCALE-X SCALE-Y SCALE-REGION SCALE-POSITION) (IL:FUNCTIONS UN-SCALE-REGION UN-SCALE-POSITION UN-SCALE-HEIGHT UN-SCALE-WIDTH UN-SCALE-X UN-SCALE-Y)))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-GEOMETRY :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(EXTERNALIZE-REGION INTERNALIZE-REGION EXTERNALIZE-POSITION INTERNALIZE-POSITION)) (REQUIRE "ROOMS") (IL:* IL:|;;| "externalizing for suites & background text") (DEFUN EXTERNALIZE-REGION (REGION) (MAKE-REGION :LEFT (EXTERNALIZE-COORDINATE (REGION-LEFT REGION) IL:SCREENWIDTH) :BOTTOM (EXTERNALIZE-COORDINATE (REGION-BOTTOM REGION) IL:SCREENHEIGHT) :WIDTH (EXTERNALIZE-COORDINATE (REGION-WIDTH REGION) IL:SCREENWIDTH) :HEIGHT (EXTERNALIZE-COORDINATE (REGION-HEIGHT REGION) IL:SCREENHEIGHT))) (DEFUN INTERNALIZE-REGION (REGION) (MAKE-REGION :LEFT (INTERNALIZE-COORDINATE (REGION-LEFT REGION) IL:SCREENWIDTH) :BOTTOM (INTERNALIZE-COORDINATE (REGION-BOTTOM REGION) IL:SCREENHEIGHT) :WIDTH (INTERNALIZE-COORDINATE (REGION-WIDTH REGION) IL:SCREENWIDTH) :HEIGHT (INTERNALIZE-COORDINATE (REGION-HEIGHT REGION) IL:SCREENHEIGHT))) (DEFUN EXTERNALIZE-POSITION (POS) (MAKE-POSITION (EXTERNALIZE-COORDINATE (POSITION-X POS) IL:SCREENWIDTH) (EXTERNALIZE-COORDINATE (POSITION-Y POS) IL:SCREENHEIGHT))) (DEFUN INTERNALIZE-POSITION (POS) (MAKE-POSITION (INTERNALIZE-COORDINATE (POSITION-X POS) IL:SCREENWIDTH) (INTERNALIZE-COORDINATE (POSITION-Y POS) IL:SCREENHEIGHT))) (DEFUN EXTERNALIZE-COORDINATE (N RANGE) (LET ((EXTERNAL (/ N RANGE))) (TYPECASE EXTERNAL (INTEGER (FLOAT EXTERNAL)) (OTHERWISE EXTERNAL)))) (DEFUN INTERNALIZE-COORDINATE (N RANGE) (ETYPECASE N (INTEGER N) ((OR FLOAT RATIONAL) (ROUND (* N RANGE))))) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:SCREENWIDTH IL:SCREENHEIGHT) ) (IL:* IL:|;;| "scaling used by placement editor & backgrounds") (DEFSTRUCT (SCALE (:CONSTRUCTOR MAKE-SCALE-INTERNAL)) (IL:* IL:|;;;| "used to scale coordinates. X-FACTOR & Y-FACTOR are the scale factor, and X-OFFSET & Y-OFFSET are added after scaling.") (X-OFFSET 0 :TYPE INTEGER) (X-FACTOR 1 :TYPE (OR INTEGER FLOAT RATIONAL)) (Y-OFFSET 0 :TYPE INTEGER) (Y-FACTOR 1 :TYPE (OR INTEGER FLOAT RATIONAL))) (DEFGLOBALVAR *ONE-TO-ONE* (MAKE-SCALE-INTERNAL)) (DEFUN MAKE-SCALE (REGION) (IL:* IL:|;;;| "return a scale which scales the screen into REGION ") (MAKE-SCALE-INTERNAL :X-FACTOR (FLOAT (/ (REGION-WIDTH REGION) IL:SCREENWIDTH)) :X-OFFSET (REGION-LEFT REGION) :Y-FACTOR (FLOAT (/ (REGION-HEIGHT REGION) IL:SCREENHEIGHT)) :Y-OFFSET (REGION-BOTTOM REGION))) (DEFUN EQUAL-SCALES (SCALE-1 SCALE-2) (AND (= (SCALE-X-FACTOR SCALE-1) (SCALE-X-FACTOR SCALE-2)) (= (SCALE-Y-FACTOR SCALE-1) (SCALE-Y-FACTOR SCALE-2)))) (DEFMACRO SCALE-WIDTH (WIDTH SCALE) `(ROUND (* ,WIDTH (SCALE-X-FACTOR ,SCALE)))) (DEFMACRO SCALE-HEIGHT (HEIGHT SCALE) `(ROUND (* ,HEIGHT (SCALE-Y-FACTOR ,SCALE)))) (DEFINLINE SCALE-X (X SCALE) (+ (SCALE-WIDTH X SCALE) (SCALE-X-OFFSET SCALE))) (DEFINLINE SCALE-Y (Y SCALE) (+ (SCALE-HEIGHT Y SCALE) (SCALE-Y-OFFSET SCALE))) (DEFUN SCALE-REGION (REGION SCALE) (IF (EQ SCALE *ONE-TO-ONE*) REGION (MAKE-REGION :LEFT (SCALE-X (REGION-LEFT REGION) SCALE) :BOTTOM (SCALE-Y (REGION-BOTTOM REGION) SCALE) :WIDTH (SCALE-WIDTH (REGION-WIDTH REGION) SCALE) :HEIGHT (SCALE-HEIGHT (REGION-HEIGHT REGION) SCALE)))) (DEFUN SCALE-POSITION (POS SCALE) (IF (EQ SCALE *ONE-TO-ONE*) POS (MAKE-POSITION (SCALE-X (POSITION-X POS) SCALE) (SCALE-Y (POSITION-Y POS) SCALE)))) (DEFUN UN-SCALE-REGION (REGION SCALE) (MAKE-REGION :LEFT (UN-SCALE-X (REGION-LEFT REGION) SCALE) :BOTTOM (UN-SCALE-Y (REGION-BOTTOM REGION) SCALE) :WIDTH (UN-SCALE-WIDTH (REGION-WIDTH REGION) SCALE) :HEIGHT (UN-SCALE-HEIGHT (REGION-HEIGHT REGION) SCALE))) (DEFUN UN-SCALE-POSITION (POS SCALE) (MAKE-POSITION (UN-SCALE-X (POSITION-X POS) SCALE) (UN-SCALE-Y (POSITION-Y POS) SCALE))) (DEFMACRO UN-SCALE-HEIGHT (HEIGHT SCALE) `(ROUND ,HEIGHT (SCALE-Y-FACTOR ,SCALE))) (DEFMACRO UN-SCALE-WIDTH (WIDTH SCALE) `(ROUND ,WIDTH (SCALE-X-FACTOR ,SCALE))) (DEFUN UN-SCALE-X (X SCALE) (UN-SCALE-WIDTH (- X (SCALE-X-OFFSET SCALE)) SCALE)) (DEFUN UN-SCALE-Y (Y SCALE) (UN-SCALE-HEIGHT (- Y (SCALE-Y-OFFSET SCALE)) SCALE)) (IL:PUTPROPS IL:ROOMS-GEOMETRY IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1908 2400 (EXTERNALIZE-REGION 1908 . 2400)) (2402 2894 (INTERNALIZE-REGION 2402 . 2894)) (2896 3128 (EXTERNALIZE-POSITION 2896 . 3128)) (3130 3362 (INTERNALIZE-POSITION 3130 . 3362)) ( 3364 3542 (EXTERNALIZE-COORDINATE 3364 . 3542)) (3544 3673 (INTERNALIZE-COORDINATE 3544 . 3673)) (4259 4699 (MAKE-SCALE 4259 . 4699)) (4701 4890 (EQUAL-SCALES 4701 . 4890)) (5268 5761 (SCALE-REGION 5268 . 5761)) (5763 6005 (SCALE-POSITION 5763 . 6005)) (6007 6425 (UN-SCALE-REGION 6007 . 6425)) (6427 6619 (UN-SCALE-POSITION 6427 . 6619)) (6800 6901 (UN-SCALE-X 6800 . 6901)) (6903 7005 (UN-SCALE-Y 6903 . 7005))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-GEOMETRY.DFASL b/rooms/ROOMS-GEOMETRY.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..cdfb83d8f7fc001e694f19f5d34d400742e8d535 GIT binary patch literal 7183 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 Fe*w!jWeNZQ literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-INTERACTIVE b/rooms/ROOMS-INTERACTIVE new file mode 100644 index 00000000..98143f03 --- /dev/null +++ b/rooms/ROOMS-INTERACTIVE @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:35:32"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-INTERACTIVE.;2| 32009 IL:|previous| IL:|date:| "17-Aug-90 12:47:35" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-INTERACTIVE.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-INTERACTIVECOMS) (IL:RPAQQ IL:ROOMS-INTERACTIVECOMS ( (IL:* IL:|;;| "mostly portable interactive code (joke?)") (FILE-ENVIRONMENTS IL:ROOMS-INTERACTIVE) (IL:P (EXPORT '(INTERACTIVE-GO-TO-ROOM-NAMED INTERACTIVE-COPY-PLACEMENT INTERACTIVE-MOVE-PLACEMENT)) (REQUIRE "ROOMS")) (IL:VARIABLES *BACKGROUND-ITEM* *MOVE-ITEM* *CLOSE-ITEM*) (IL:FUNCTIONS INSTALL-MENU-ITEMS INSTALL-MENU-ITEM) (IL:P (PUSHNEW '(INSTALL-MENU-ITEMS) *RESET-FORMS* :TEST 'EQUAL)) (IL:FUNCTIONS INTERACTIVE-CLOSE-WINDOW INTERACTIVE-GO-TO-ROOM INTERACTIVE-GO-TO-OVERVIEW INTERACTIVE-GO-TO-ROOM-NAMED INTERACTIVE-EDIT-ROOM EDIT-ROOM INTERACTIVE-EDIT-PLACEMENTS INTERACTIVE-INCLUDE-ROOM INTERACTIVE-EXCLUDE-ROOM INTERACTIVE-DELETE-ROOM INTERACTIVE-FIND-PLACEMENT INTERACTIVE-COPY-PLACEMENT INTERACTIVE-MOVE-PLACEMENT INTERACTIVE-COPY-PLACEMENT-TO-THIS-ROOM INTERACTIVE-MOVE-PLACEMENT-TO-POCKETS INTERACTIVE-MOVE-OR-COPY-PLACEMENT INTERACTIVE-RESET SELECT-ROOM INTERACTIVE-MAKE-ROOM INTERACTIVE-COPY-ROOM INTERACTIVE-RENAME-ROOM INTERACTIVE-MAKE-DOOR MAKE-DOOR RETRIEVE-WINDOWS CHECK-LOST-WINDOWS EVAL-WALK) (IL:COMS (IL:* IL:|;;| "back doors") (IL:VARIABLES *BACK-DOOR-ROOM-NAME*) (IL:FUNCTIONS MAKE-BACK-DOOR BACK-DOOR-ENTRY-FUNCTION) (IL:P (PUSHNEW 'BACK-DOOR-ENTRY-FUNCTION *ROOM-ENTRY-FUNCTIONS*))) (IL:GLOBALVARS IL:PROMPTWINDOW IL:CROSSHAIRS))) (IL:* IL:|;;| "mostly portable interactive code (joke?)") (DEFINE-FILE-ENVIRONMENT IL:ROOMS-INTERACTIVE :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(INTERACTIVE-GO-TO-ROOM-NAMED INTERACTIVE-COPY-PLACEMENT INTERACTIVE-MOVE-PLACEMENT)) (REQUIRE "ROOMS") (DEFGLOBALPARAMETER *BACKGROUND-ITEM* `("Rooms" '(WITH-BUTTON '(INTERACTIVE-GO-TO-OVERVIEW) "Overview" "Enter the overview") "Enter the overview" (IL:SUBITEMS ("Go to Room" '(WITH-BUTTON '(INTERACTIVE-GO-TO-ROOM :ALLOW-NEW? T) "Go to Room" "Go to a room, possibly new.") "Go to a room, possibly new.") ("Make Room" '(WITH-BUTTON '(INTERACTIVE-MAKE-ROOM) "Make Room" "Make a new room.") "Make a new room.") ("Edit Room" '(WITH-BUTTON '(INTERACTIVE-EDIT-ROOM) "Edit Room" "Edit a selected room.") "Edit a selected room." (IL:SUBITEMS ("Edit This Room" '(WITH-BUTTON '(EDIT-ROOM *CURRENT-ROOM*) "Edit This Room" "Edit the current room.") "Edit a selected room.") ("Edit Placements" '(WITH-BUTTON '(INTERACTIVE-EDIT-PLACEMENTS) "Edit Placements" "Edit placements of a selected room") "Edit placements of a selected room") ("Exclude Room" '(WITH-BUTTON '(INTERACTIVE-EXCLUDE-ROOM) "Exclude Room" "Exclude a room from another." ) "Exclude a room from another." (IL:SUBITEMS ("From This Room" '(WITH-BUTTON '(INTERACTIVE-EXCLUDE-ROOM *CURRENT-ROOM*) "Exclude From This Room" "Exclude a room from the current room.") "Exclude a room from another."))) ("Include Room" '(WITH-BUTTON '(INTERACTIVE-INCLUDE-ROOM) "Include Room" "Include a room in another.") "Include a room in another." (IL:SUBITEMS ("In This Room" '(WITH-BUTTON '(  INTERACTIVE-INCLUDE-ROOM *CURRENT-ROOM*) "Include In This Room" "Include a room in the current room." ) "Include a room in the current room."))))) ("Delete Room" '(WITH-BUTTON '(INTERACTIVE-DELETE-ROOM) "Delete Room" "Delete a room.") "Delete a room.") ("" NIL "No-op") ("Retrieve Windows" '(WITH-BUTTON '(RETRIEVE-WINDOWS) "Retrieve Windows" "Retrieve windows lost from all rooms.") "Retrieve windows lost from all rooms.") ("Suites" '(WITH-BUTTON '(SUITE-MENU) "Suites" "Save a set of rooms to a file") "Save a set of rooms to a file" (IL:SUBITEMS ,@*SUITE-MENU-ITEMS*)) ("Make Door" '(INTERACTIVE-MAKE-DOOR :ALLOW-NEW? T) "Make a door to a room - a button to enter it." (IL:SUBITEMS ("Make Back Door" '(MAKE-BACK-DOOR) "Make a back door - a door to the previous room.")))))) (DEFPARAMETER *MOVE-ITEM* '(IL:|Move| 'IL:MOVEW "Moves window by a corner" (IL:SUBITEMS ("Move to another room" 'INTERACTIVE-MOVE-PLACEMENT "Move this placement to another room" (IL:SUBITEMS ("Move to pockets" ' INTERACTIVE-MOVE-PLACEMENT-TO-POCKETS "Move this placement to the pocket room" ))) ("Copy to another room" 'INTERACTIVE-COPY-PLACEMENT "Copy this placement to another room" (IL:SUBITEMS ("Copy to this room" ' INTERACTIVE-COPY-PLACEMENT-TO-THIS-ROOM "Copy this placement to this room" ))) ("Where is?" 'INTERACTIVE-FIND-PLACEMENT "Find which room this placement is in." )))) (DEFPARAMETER *CLOSE-ITEM* '(IL:|Close| 'INTERACTIVE-CLOSE-WINDOW "Closes a window")) (DEFUN INSTALL-MENU-ITEMS () (INSTALL-MENU-ITEM *BACKGROUND-ITEM* 'IL:|BackgroundMenuCommands| 'IL:|BackgroundMenu|) (INSTALL-MENU-ITEM *MOVE-ITEM* 'IL:|WindowMenuCommands| 'IL:|WindowMenu|) (INSTALL-MENU-ITEM *MOVE-ITEM* 'IL:|IconWindowMenuCommands| 'IL:|IconWindowMenu|) (INSTALL-MENU-ITEM *CLOSE-ITEM* 'IL:|WindowMenuCommands| 'IL:|WindowMenu|) (INSTALL-MENU-ITEM *CLOSE-ITEM* 'IL:|IconWindowMenuCommands| 'IL:|IconWindowMenu|)) (DEFUN INSTALL-MENU-ITEM (ITEM ITEMS-VAR MENU-VAR) (LET* ((ITEMS (COPY-TREE (SYMBOL-VALUE ITEMS-VAR))) (OLD-ENTRY (ASSOC (FIRST ITEM) ITEMS :TEST 'EQUAL))) (IF OLD-ENTRY (SETF (REST OLD-ENTRY) (REST ITEM)) (NCONC ITEMS (LIST ITEM))) (SET ITEMS-VAR ITEMS) (IL:* IL:|;;| "force the menu to be rebuilt") (SET MENU-VAR 'NIL))) (PUSHNEW '(INSTALL-MENU-ITEMS) *RESET-FORMS* :TEST 'EQUAL) (DEFUN INTERACTIVE-CLOSE-WINDOW (WINDOW &OPTIONAL (FROM-ROOM *CURRENT-ROOM*)) (IL:* IL:|;;;| "this should probably be called interactive-delete-placement. it's whats called from the window menu & is used by the placement editor.") (IL:* IL:|;;;| "we need to catch the case where a room has multiple placements and query the user as to which are to be deleted -- all or just the most immediate.") (LET ((MAIN-WINDOW (MAIN-WINDOW WINDOW)) (WINDOW-TO-CLOSE WINDOW)) (WHEN (AND (NOT (ICON? WINDOW)) (NOT (EQ WINDOW MAIN-WINDOW))) (IL:* IL:|;;| "it's an attached window") (LET ((PASS-TO-MAIN-COMS (IL:WINDOWPROP WINDOW 'IL:PASSTOMAINCOMS))) (IL:* IL:|;;| "have to simulate IL:DOATTACHEDWINDOWCOM") (UNLESS (OR (EQ PASS-TO-MAIN-COMS T) (MEMBER 'IL:CLOSEW PASS-TO-MAIN-COMS :TEST 'EQ)) (IL:* IL:|;;| "this window closes locally") (CLOSE-WINDOW WINDOW) (RETURN-FROM INTERACTIVE-CLOSE-WINDOW)) (SETQ WINDOW-TO-CLOSE MAIN-WINDOW))) (LET ((ROOMS (FIND-ROOMS-CONTAINING MAIN-WINDOW))) (IL:* IL:|;;|  "note: this needs to run fairly quickly, so we don't call UPDATE-PLACEMENTS.") (IF (NULL ROOMS) (IL:* IL:|;;| "new window -- just close it") (CLOSE-WINDOW WINDOW-TO-CLOSE) (CASE (IF (AND (ENDP (REST ROOMS)) (FIND-PLACEMENT MAIN-WINDOW FROM-ROOM)) (IL:* IL:|;;| "we're looking at the only placement") (IF (EQ FROM-ROOM (FIRST ROOMS)) (IL:* IL:|;;| "it's an immediate placement - just delete it") :ALL (IL:* IL:|;;| "it's inherited - get confirmation") (IF (CONFIRM "This placement is in the included room ~S.~%Are you sure you want to delete it?" (ROOM-NAME (FIRST ROOMS))) :ALL)) (MENU '(("All placements" :ALL) ("Just this placement" :THIS)) "Delete?" "This window has placements in more than one room")) (:ALL (LET ((HIDDEN? (WINDOW-HIDDEN? MAIN-WINDOW))) (IL:* IL:|;;| "note whether window was hidden & make it not") (WHEN HIDDEN? (UN-HIDE-WINDOW MAIN-WINDOW)) (IL:* IL:|;;| "try to close visible part ") (CLOSE-WINDOW (IF (SHRUNKEN? MAIN-WINDOW) (WINDOW-ICON MAIN-WINDOW) MAIN-WINDOW)) (IF (AND HIDDEN? (OR (IL:OPENWP MAIN-WINDOW) (IL:OPENWP (WINDOW-ICON MAIN-WINDOW)))) (IL:* IL:|;;|  "if close failed & window was hidden before, then re-hide it") (HIDE-WINDOW MAIN-WINDOW) (IL:* IL:|;;| "otherwise go ahead & delete all its placements") (DOLIST (ROOM ROOMS) (LET ((PLACEMENT (FIND-PLACEMENT-IN-ROOM MAIN-WINDOW ROOM))) (WHEN PLACEMENT (DELETE-PLACEMENT PLACEMENT ROOM))))))) (:THIS (MULTIPLE-VALUE-BIND (PLACEMENT IN-ROOM) (FIND-PLACEMENT MAIN-WINDOW FROM-ROOM) (WHEN PLACEMENT (DELETE-PLACEMENT PLACEMENT IN-ROOM)) (IL:* IL:|;;| "don't actually close -- just hide it") (HIDE-WINDOW MAIN-WINDOW) (SETQ PLACEMENT (FIND-PLACEMENT MAIN-WINDOW *CURRENT-ROOM*)) (WHEN PLACEMENT (IL:* IL:|;;| "we now inherit it from somewhere else") (PLACE-PLACEMENT PLACEMENT))))))))) (DEFUN INTERACTIVE-GO-TO-ROOM (&KEY ROOM ALLOW-NEW?) (LET ((NAME (IF ROOM (ROOM-NAME ROOM) (SELECT-ROOM :ALLOW-NEW? ALLOW-NEW? :REASON "Go to room" :NAME-ONLY? T)))) (WHEN NAME (WITH-BUTTON `(INTERACTIVE-GO-TO-ROOM-NAMED ',NAME) NAME (FORMAT NIL "Go to room named ~S." NAME))))) (DEFUN INTERACTIVE-GO-TO-OVERVIEW () (UPDATE-PLACEMENTS) (GO-TO-ROOM *OVERVIEW-ROOM* :BAGGAGE (SELECT-BAGGAGE) :NO-UPDATE T)) (DEFUN INTERACTIVE-GO-TO-ROOM-NAMED (NAME) (LET ((ROOM (ROOM-NAMED NAME))) (IF ROOM (PROGN (UPDATE-PLACEMENTS *CURRENT-ROOM*) (GO-TO-ROOM ROOM :BAGGAGE (SELECT-BAGGAGE) :NO-UPDATE T)) (NOTIFY-USER "No room named ~S exists!" NAME)))) (DEFUN INTERACTIVE-EDIT-ROOM () (LET ((NAME (SELECT-ROOM :REASON "Edit" :NAME-ONLY? T))) (WHEN NAME (WITH-BUTTON `(EDIT-ROOM (ROOM-NAMED ',NAME)) (FORMAT NIL "Edit ~A" NAME) (FORMAT NIL "Edit room named ~S." NAME))))) (DEFUN EDIT-ROOM (ROOM) (LET* ((ROOM (COND ((AND (ROOM-P ROOM) (ROOM-NAMED (ROOM-NAME ROOM))) ROOM) ((ROOM-NAMED ROOM)) (T (NOTIFY-USER "Can't edit room ~S" ROOM) (RETURN-FROM EDIT-ROOM)))) (EXTERNAL-FORM `(:INCLUSIONS ,(COPY-TREE (ROOM-INCLUSIONS ROOM)) :BACKGROUND ,(COPY-TREE (BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND ROOM))) ,@(COPY-TREE (ROOM-PROPS ROOM))))) (WITH-PROFILE (FIND-PROFILE "XCL") (IL:EDITE EXTERNAL-FORM NIL (ROOM-NAME ROOM) 'IL:|Expression| #'(LAMBDA (&REST IGNORE) (IL:* IL:|;;| "in case ROOM has been redefined") (SETQ ROOM (ROOM-NAMED (ROOM-NAME ROOM))) (SETF (ROOM-BACKGROUND ROOM) (MAKE-BACKGROUND (COPY-TREE (GETF EXTERNAL-FORM :BACKGROUND)))) (WHEN (IN-ROOM? ROOM) (UPDATE-PLACEMENTS)) (SETF (ROOM-INCLUSIONS ROOM) (COPY-TREE (GETF EXTERNAL-FORM :INCLUSIONS))) (LET ((PROPS (COPY-LIST EXTERNAL-FORM))) (DOLIST (PROP '(:INCLUSIONS :BACKGROUND)) (REMF PROPS PROP)) (SETF (ROOM-PROPS ROOM) (COPY-TREE PROPS))) (ROOM-CHANGED ROOM :EDITED)) '(:DONTWAIT))))) (DEFUN INTERACTIVE-EDIT-PLACEMENTS () (LET ((NAME (SELECT-ROOM :REASON "Edit Placements" :NAME-ONLY? T))) (WHEN NAME (WITH-BUTTON `(GET-PE ',NAME) (FORMAT NIL "Edit ~A's Placements" NAME) (FORMAT NIL "Edit the placements of ~S." NAME))))) (DEFUN INTERACTIVE-INCLUDE-ROOM (&OPTIONAL IN-ROOM) (LET* ((ALL-ROOMS (ALL-ROOMS T)) (ROOM (OR IN-ROOM (SELECT-ROOM :ALLOW-NEW? T :REASON "Include in ..." :FROM-ROOMS ALL-ROOMS)))) (WHEN ROOM (UNLESS (LISTP (ROOM-INCLUSIONS ROOM)) (RETURN-FROM INTERACTIVE-INCLUDE-ROOM (NOTIFY-USER "Can't add inclusions to ~S." ROOM))) (LET ((INCLUSION (SELECT-ROOM :ALLOW-NEW? T :REASON (FORMAT NIL "Include in ~A" (ROOM-NAME ROOM)) :FROM-ROOMS (REMOVE ROOM ALL-ROOMS)))) (WHEN INCLUSION (WHEN (MEMBER (ROOM-NAME INCLUSION) (ROOM-INCLUSIONS ROOM) :TEST 'EQUAL) (RETURN-FROM INTERACTIVE-INCLUDE-ROOM (NOTIFY-USER "~S is already included in ~S" (ROOM-NAME INCLUSION) (ROOM-NAME ROOM)))) (UPDATE-PLACEMENTS) (WHEN (AND (EQUAL (BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND INCLUSION)) `((:TEXT ,(ROOM-NAME INCLUSION)))) (EQUAL (BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND ROOM)) `((:TEXT ,(ROOM-NAME ROOM))))) (IL:* IL:|;;| "feature: when both names are in default position we delete name of included room s.t. they don't overwrite.") (SETF (ROOM-BACKGROUND INCLUSION) (MAKE-BACKGROUND `((:TEXT ,"")))) (ROOM-CHANGED INCLUSION :EDITED)) (PUSH (ROOM-NAME INCLUSION) (ROOM-INCLUSIONS ROOM)) (ROOM-CHANGED ROOM :EDITED) (NOTIFY-USER "Included ~S in ~S." (ROOM-NAME INCLUSION) (ROOM-NAME ROOM)) T))))) (DEFUN INTERACTIVE-EXCLUDE-ROOM (&OPTIONAL FROM-ROOM) (LET ((ROOM (OR FROM-ROOM (SELECT-ROOM :REASON "Exclude from ...")))) (WHEN ROOM (UNLESS (CONSP (ROOM-INCLUSIONS ROOM)) (RETURN-FROM INTERACTIVE-EXCLUDE-ROOM (NOTIFY-USER "~S has no inclusions." ROOM))) (LET ((INCLUSION (MENU (ROOM-INCLUSIONS ROOM) (FORMAT NIL "Exclude from ~A" (ROOM-NAME ROOM))))) (WHEN INCLUSION (UPDATE-PLACEMENTS) (SETF (ROOM-INCLUSIONS ROOM) (REMOVE INCLUSION (ROOM-INCLUSIONS ROOM :TEST 'EQUAL))) (ROOM-CHANGED ROOM :EDITED) (NOTIFY-USER "~S is no longer included in ~S." INCLUSION (ROOM-NAME ROOM)) T))))) (DEFUN INTERACTIVE-DELETE-ROOM (&OPTIONAL ROOM) (FLET ((DELETE? (ROOM) (WHEN (AND ROOM (CONFIRM " Delete room ~S? (will close windows)" (ROOM-NAME ROOM))) (DELETE-ROOM ROOM)))) (LET ((ROOMS (ROOMS-NOT-IN-ANY-SUITE T))) (IF ROOM (IF (MEMBER ROOM ROOMS :TEST 'EQ) (DELETE? ROOM) (NOTIFY-USER "Delete ~S from suite ~S before deleting" (ROOM-NAME ROOM) (FIND-SUITE-CONTAINING (ROOM-NAME ROOM)))) (IF ROOMS (DELETE? (SELECT-ROOM :REASON "Delete" :FROM-ROOMS ROOMS)) (NOTIFY-USER "All rooms belong to some suite.")))))) (DEFUN INTERACTIVE-FIND-PLACEMENT (WINDOW) (LET ((WINDOW (MAIN-WINDOW WINDOW))) (UPDATE-PLACEMENTS) (NOTIFY-USER "This placement is in ~S." (ROOM-NAME (MULTIPLE-VALUE-BIND (PLACEMENT ROOM) (FIND-PLACEMENT WINDOW) ROOM))))) (DEFUN INTERACTIVE-COPY-PLACEMENT (WINDOW &OPTIONAL ROOM-NAME) (UN-HIDE-WINDOW WINDOW) (LET ((NAME (OR ROOM-NAME (SELECT-ROOM :REASON "Copy this placement to" :ALLOW-NEW? T :NAME-ONLY? T)))) (WHEN NAME (INTERACTIVE-MOVE-OR-COPY-PLACEMENT WINDOW NAME T)))) (DEFUN INTERACTIVE-MOVE-PLACEMENT (WINDOW &OPTIONAL ROOM-NAME) (UN-HIDE-WINDOW WINDOW) (LET ((NAME (OR ROOM-NAME (SELECT-ROOM :REASON "Move this placement to" :ALLOW-NEW? T :NAME-ONLY? T)))) (WHEN NAME (INTERACTIVE-MOVE-OR-COPY-PLACEMENT WINDOW NAME NIL)))) (DEFUN INTERACTIVE-COPY-PLACEMENT-TO-THIS-ROOM (WINDOW) (INTERACTIVE-MOVE-OR-COPY-PLACEMENT WINDOW (ROOM-NAME *CURRENT-ROOM*) T)) (DEFUN INTERACTIVE-MOVE-PLACEMENT-TO-POCKETS (WINDOW) (IF *POCKET-ROOM-NAME* (INTERACTIVE-MOVE-OR-COPY-PLACEMENT WINDOW *POCKET-ROOM-NAME* NIL) (NOTIFY-USER "There is no pocket room."))) (DEFUN INTERACTIVE-MOVE-OR-COPY-PLACEMENT (WINDOW TO-ROOM-NAMED COPY?) (LET ((WINDOW (MAIN-WINDOW WINDOW)) (TO-ROOM (OR (ROOM-NAMED TO-ROOM-NAMED) (PROGN (NOTIFY-USER "There is no room named ~S." TO-ROOM-NAMED) NIL)))) (WHEN TO-ROOM (UPDATE-PLACEMENTS) (MULTIPLE-VALUE-BIND (PLACEMENT FROM-ROOM) (FIND-PLACEMENT WINDOW) (COND ((EQ FROM-ROOM TO-ROOM) (NOTIFY-USER "This placement is already in ~S." (ROOM-NAME FROM-ROOM)) :NOOP) (T (MOVE-PLACEMENT PLACEMENT FROM-ROOM TO-ROOM COPY?) (NOTIFY-USER "~A this placement from ~S to ~S." (IF COPY? "Copied" "Moved") (ROOM-NAME FROM-ROOM) TO-ROOM-NAMED) T)))))) (DEFUN INTERACTIVE-RESET () (WHEN (CONFIRM "Reset Rooms? (Will lose windows.)") (RESET))) (DEFUN SELECT-ROOM (&KEY ALLOW-NEW? NAME-ONLY? (FROM-ROOMS (ALL-ROOMS T)) (REASON "Select Room")) (LET ((ITEMS (WITH-COLLECTION (DOLIST (ROOM FROM-ROOMS) (COLLECT `(,(ROOM-NAME ROOM) ',ROOM) ITEMS)) (WHEN ALLOW-NEW? (COLLECT '("" :NEW)))))) (IF ITEMS (LET* ((CHOICE (MENU ITEMS REASON)) (ROOM (IF (AND ALLOW-NEW? (EQ CHOICE :NEW)) (INTERACTIVE-MAKE-ROOM) CHOICE))) (WHEN ROOM (IF NAME-ONLY? (ROOM-NAME ROOM) ROOM))) (PROGN (NOTIFY-USER "No rooms!") NIL)))) (DEFUN INTERACTIVE-MAKE-ROOM () (LET ((NAME (PROMPT-USER "Name:" "Type name of new room (CR to abort)."))) (WHEN NAME (IF (ROOM-NAMED NAME) (NOTIFY-USER "A room named ~S already exists. Aborted." NAME) (MAKE-ROOM NAME))))) (DEFUN INTERACTIVE-COPY-ROOM (&OPTIONAL ROOM) (LET ((ROOM (OR ROOM (SELECT-ROOM :REASON "Copy")))) (WHEN ROOM (LET ((NAME (PROMPT-USER "New Name:" "Copying room ~S." (ROOM-NAME ROOM)))) (WHEN NAME (IF (ROOM-NAMED NAME) (NOTIFY-USER "A room named ~S already exists." NAME) (PROGN (COPY-ROOM ROOM NAME) (NOTIFY-USER "Copied room ~S to ~S." (ROOM-NAME ROOM) NAME)))))))) (DEFUN INTERACTIVE-RENAME-ROOM (&OPTIONAL ROOM) (LET ((ROOM (OR ROOM (SELECT-ROOM :REASON "Rename")))) (WHEN ROOM (LET ((NAME (PROMPT-USER "New Name:" "Renaming room ~S." (ROOM-NAME ROOM)))) (WHEN NAME (IF (ROOM-NAMED NAME) (NOTIFY-USER "A room named ~S already exists." NAME) (PROGN (RENAME-ROOM ROOM NAME) (NOTIFY-USER "Renamed room ~S to be ~S." (ROOM-NAME ROOM) NAME)))))))) (DEFUN INTERACTIVE-MAKE-DOOR (&KEY ALLOW-NEW?) (LET ((NAME (SELECT-ROOM :NAME-ONLY? T :ALLOW-NEW? ALLOW-NEW?))) (WHEN NAME (LET ((BUTTON-TYPE (SELECT-BUTTON-TYPE))) (WHEN BUTTON-TYPE (MAKE-DOOR :ROOM-NAME NAME :BUTTON-TYPE BUTTON-TYPE)))))) (DEFUN MAKE-DOOR (&KEY ROOM-NAME (BUTTON-TYPE *DEFAULT-BUTTON-TYPE*) POSITION) (MAKE-BUTTON-WINDOW (MAKE-BUTTON :TEXT ROOM-NAME :ACTION `(INTERACTIVE-GO-TO-ROOM-NAMED ,(IF (CONSTANTP ROOM-NAME) ROOM-NAME (LIST 'QUOTE ROOM-NAME))) :HELP (FORMAT NIL "Go to room named ~S" ROOM-NAME) :TYPE BUTTON-TYPE) POSITION)) (DEFUN RETRIEVE-WINDOWS () (IL:* IL:|;;;| "un-hide all lost windows, telling the user what you've done.") (LET ((LOST-WINDOWS (LOST-WINDOWS))) (IF LOST-WINDOWS (PROGN (DOLIST (WINDOW LOST-WINDOWS) (UN-HIDE-WINDOW WINDOW)) (NOTIFY-USER "~S window(s) retrieved." (LENGTH LOST-WINDOWS))) (NOTIFY-USER "All windows are in some room.")))) (DEFUN CHECK-LOST-WINDOWS () (LET ((LOST-WINDOWS (LOST-WINDOWS))) (WHEN LOST-WINDOWS (NOTIFY-USER "~D lost window(s). Try \"Retrieve Windows\"." (LENGTH LOST-WINDOWS))))) (DEFUN EVAL-WALK (EXPRESSION) (IL:* IL:|;;| "an inverted evaluator: expressions are implicitly quoted unless wrapped in :EVAL. Only conses when it must, i.e. structure w/o EVALs in it will be shared.") (IF (CONSP EXPRESSION) (IF (AND (CONSP (FIRST EXPRESSION)) (EQ (FIRST (FIRST EXPRESSION)) :EVAL)) (CONS (EVAL (SECOND (FIRST EXPRESSION))) (EVAL-WALK (REST EXPRESSION))) (LET* ((OLD-FIRST (FIRST EXPRESSION)) (OLD-REST (REST EXPRESSION)) (NEW-FIRST (EVAL-WALK OLD-FIRST)) (NEW-REST (EVAL-WALK OLD-REST))) (IF (AND (EQ OLD-FIRST NEW-FIRST) (EQ OLD-REST NEW-REST)) EXPRESSION (CONS NEW-FIRST NEW-REST)))) EXPRESSION)) (IL:* IL:|;;| "back doors") (DEFGLOBALVAR *BACK-DOOR-ROOM-NAME* NIL) (DEFUN MAKE-BACK-DOOR (&KEY POSITION BUTTON-TYPE) (MAKE-BUTTON-WINDOW (MAKE-BUTTON :TEXT-FORM '(SYMBOL-VALUE '*BACK-DOOR-ROOM-NAME*) :ACTION '(INTERACTIVE-GO-TO-ROOM-NAMED *BACK-DOOR-ROOM-NAME*) :TYPE (OR BUTTON-TYPE :DOOR) :HELP "Go to the previous room." :INVERTED? T) POSITION)) (DEFUN BACK-DOOR-ENTRY-FUNCTION (ENTERING-ROOM) (IL:* IL:|;;;| "called whenever we enter a room") (IL:* IL:|;;;| "maintains the value of *BACK-DOOR-ROOM-NAME* to be the name of the last named room we were in before the current room.") (LET* ((LEAVING-ROOM *CURRENT-ROOM*) (LEAVING-NAME (ROOM-NAME LEAVING-ROOM)) (ENTERING-NAME (ROOM-NAME ENTERING-ROOM))) (UNLESS *BACK-DOOR-ROOM-NAME* (IL:* IL:|;;| "bootstrapping ") (SETQ *BACK-DOOR-ROOM-NAME* LEAVING-NAME)) (WHEN (NOT (EQUAL ENTERING-NAME LEAVING-NAME)) (IL:* IL:|;;| "ignore screen refreshes") (IF (ROOM-NAMED LEAVING-NAME) (IF (ROOM-NAMED ENTERING-NAME) (IL:* IL:|;;| "simple case - going between named rooms") (SETQ *BACK-DOOR-ROOM-NAME* LEAVING-NAME) (PROGN (IL:* IL:|;;| "when entering an un-named room from a named room we save the current back door on the room we're entering & update the global back door ") (ROOM-PROP ENTERING-ROOM :BACK-DOOR *BACK-DOOR-ROOM-NAME*) (SETQ *BACK-DOOR-ROOM-NAME* LEAVING-NAME))) (IF (ROOM-NAMED ENTERING-NAME) (IL:* IL:|;;| "entering a named room from an unnamed one") (WHEN (EQUAL *BACK-DOOR-ROOM-NAME* ENTERING-NAME) (IL:* IL:|;;| "if popping back to room we came from then restore back door we saved upon entering. global will be correct, making passage through un-named rooms transparent.") (SETQ *BACK-DOOR-ROOM-NAME* (ROOM-PROP LEAVING-ROOM :BACK-DOOR))) (IL:* IL:|;;|  "going between un-named rooms we just pass along the saved back door, & don't update the global") (ROOM-PROP ENTERING-ROOM :BACK-DOOR (ROOM-PROP LEAVING-ROOM :BACK-DOOR))))))) (PUSHNEW 'BACK-DOOR-ENTRY-FUNCTION *ROOM-ENTRY-FUNCTIONS*) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:PROMPTWINDOW IL:CROSSHAIRS) ) (IL:PUTPROPS IL:ROOMS-INTERACTIVE IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (9121 9591 (INSTALL-MENU-ITEMS 9121 . 9591)) (9593 10047 (INSTALL-MENU-ITEM 9593 . 10047)) (10120 14598 (INTERACTIVE-CLOSE-WINDOW 10120 . 14598)) (14600 14989 (INTERACTIVE-GO-TO-ROOM 14600 . 14989)) (14991 15136 (INTERACTIVE-GO-TO-OVERVIEW 14991 . 15136)) (15138 15454 ( INTERACTIVE-GO-TO-ROOM-NAMED 15138 . 15454)) (15456 15746 (INTERACTIVE-EDIT-ROOM 15456 . 15746)) ( 15748 17564 (EDIT-ROOM 15748 . 17564)) (17566 17873 (INTERACTIVE-EDIT-PLACEMENTS 17566 . 17873)) ( 17875 20277 (INTERACTIVE-INCLUDE-ROOM 17875 . 20277)) (20279 21106 (INTERACTIVE-EXCLUDE-ROOM 20279 . 21106)) (21108 21849 (INTERACTIVE-DELETE-ROOM 21108 . 21849)) (21851 22228 (INTERACTIVE-FIND-PLACEMENT 21851 . 22228)) (22230 22548 (INTERACTIVE-COPY-PLACEMENT 22230 . 22548)) (22550 22870 ( INTERACTIVE-MOVE-PLACEMENT 22550 . 22870)) (22872 23022 (INTERACTIVE-COPY-PLACEMENT-TO-THIS-ROOM 22872 . 23022)) (23024 23235 (INTERACTIVE-MOVE-PLACEMENT-TO-POCKETS 23024 . 23235)) (23237 24334 ( INTERACTIVE-MOVE-OR-COPY-PLACEMENT 23237 . 24334)) (24336 24442 (INTERACTIVE-RESET 24336 . 24442)) ( 24444 25349 (SELECT-ROOM 24444 . 25349)) (25351 25633 (INTERACTIVE-MAKE-ROOM 25351 . 25633)) (25635 26192 (INTERACTIVE-COPY-ROOM 25635 . 26192)) (26194 26762 (INTERACTIVE-RENAME-ROOM 26194 . 26762)) ( 26764 27056 (INTERACTIVE-MAKE-DOOR 26764 . 27056)) (27058 27676 (MAKE-DOOR 27058 . 27676)) (27678 28098 (RETRIEVE-WINDOWS 27678 . 28098)) (28100 28298 (CHECK-LOST-WINDOWS 28100 . 28298)) (28300 29174 (EVAL-WALK 28300 . 29174)) (29258 29710 (MAKE-BACK-DOOR 29258 . 29710)) (29712 31729 ( BACK-DOOR-ENTRY-FUNCTION 29712 . 31729))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-INTERACTIVE.DFASL b/rooms/ROOMS-INTERACTIVE.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..fe3dfa300ccae0612c8810494767cd30000bcdea GIT binary patch literal 16068 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 J=RW@Ue*ke-ZB+mO literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-INTRO b/rooms/ROOMS-INTRO new file mode 100644 index 00000000..3a7fd750 --- /dev/null +++ b/rooms/ROOMS-INTRO @@ -0,0 +1,426 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE (DEFPACKAGE "ROOMS" (USE "LISP" "XCL") (SHADOW CLROOM)) +) +(IL:FILECREATED "17-Aug-90 12:50:32" IL:|{DSK}local>lde>SOURCES>rooms>Medley>ROOMS-INTRO.;3| 32618 + + IL:|changes| IL:|to:| (IL:VARS IL:ROOMS-INTROCOMS) + + IL:|previous| IL:|date:| "27-Jul-90 05:37:18" +IL:|{DSK}local>lde>SOURCES>rooms>Medley>ROOMS-INTRO.;2|) + + +; Copyright (c) 1987, 1988, 1990 by Venue & Xerox Corporation. All rights reserved. + +(IL:PRETTYCOMPRINT IL:ROOMS-INTROCOMS) + +(IL:RPAQQ IL:ROOMS-INTROCOMS + ((IL:FILES (IL:SYSLOAD) + IL:ROOMS IL:ROOMS-NOTES) + (FILE-ENVIRONMENTS IL:ROOMS-INTRO) + (IL:VARIABLES *INTRO-NOTE-FONT*) + (IL:FUNCTIONS SET-INTRO-NOTE-FONT) + (EVAL-WHEN (LOAD) + (IL:P + (IL:* IL:|;;| "create both fonts when we're loaded") + + (IL:FONTCREATE 'IL:MODERN 24) + (IL:FONTCREATE 'IL:HELVETICA 14) + + (IL:* IL:|;;| "initialize variable") + + (SET-INTRO-NOTE-FONT) + + (IL:* IL:|;;| "make sure variable will get reset when screen size changes") + + (PUSHNEW 'SET-INTRO-NOTE-FONT *SCREEN-CHANGED-FUNCTIONS*))) + (IL:SUITES "ROOMS-INTRO") + (IL:P (EVAL-WHEN (LOAD) + (LET ((BUTTON (MAKE-BUTTON :TEXT "Enter Introduction" :FONT + '(IL:HELVETICAD 24) + :SHADOWS T :TYPE :STRETCHY-ARK :ACTION + '(INTERACTIVE-GO-TO-ROOM-NAMED "Intro") + :HELP "Enter the Rooms Introduction suite"))) + (MAKE-BUTTON-WINDOW BUTTON (MAKE-POSITION (FLOOR (- IL:SCREENWIDTH + (BUTTON-WIDTH BUTTON + )) + 2) + (FLOOR (- IL:SCREENHEIGHT ( + BUTTON-HEIGHT + BUTTON)) + 2)))))))) + +(IL:FILESLOAD (IL:SYSLOAD) + IL:ROOMS IL:ROOMS-NOTES) + +(DEFINE-FILE-ENVIRONMENT IL:ROOMS-INTRO :PACKAGE (DEFPACKAGE "ROOMS" (:USE "LISP" "XCL") + (:SHADOW CL:ROOM)) + :READTABLE "XCL" + :COMPILER :COMPILE-FILE) + +(DEFGLOBALVAR *INTRO-NOTE-FONT* + +(IL:* IL:|;;;| "font for note windows in the Intro suite") + + ) + +(DEFUN SET-INTRO-NOTE-FONT () + (DECLARE (GLOBAL IL:SCREENWIDTH)) + + (IL:* IL:|;;| "use a larger font when on a larger screen") + + (SETQ *INTRO-NOTE-FONT* (IF (> IL:SCREENWIDTH SMALL-SCREEN-WIDTH) + (IL:FONTCREATE 'IL:MODERN 24) + (IL:FONTCREATE 'IL:HELVETICA 14)))) +(EVAL-WHEN (LOAD) + + +(IL:* IL:|;;| "create both fonts when we're loaded") + + +(IL:FONTCREATE 'IL:MODERN 24) + +(IL:FONTCREATE 'IL:HELVETICA 14) + + +(IL:* IL:|;;| "initialize variable") + + +(SET-INTRO-NOTE-FONT) + + +(IL:* IL:|;;| "make sure variable will get reset when screen size changes") + + +(PUSHNEW 'SET-INTRO-NOTE-FONT *SCREEN-CHANGED-FUNCTIONS*) +) + +(DEFSUITE "ROOMS-INTRO" + (:VERSION 1) + (:FILES) + (:WINDOW 0 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Model") + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 1 :TYPE :BUTTON :TEXT-FORM (SYMBOL-VALUE '*BACK-DOOR-ROOM-NAME*) + :ACTION + (INTERACTIVE-GO-TO-ROOM-NAMED *BACK-DOOR-ROOM-NAME*) + :HELP "Go to the previous room." :TYPE :STRETCHY-ARK :INVERTED? T) + (:WINDOW 2 :TYPE :NOTE-WINDOW :REGION (33/1024 355/808 231/512 181/404) + :TITLE "Welcome" :STRING " + +Welcome to the Rooms Introduction. + +This is a suite of rooms which describe the Rooms system itself. Each room introduces certain topics, and where appropriate provides exercises to let you experience the things described (\"put some meat on the bones\"). + +The collection of buttons at the right can be used to move through the exhibits. Following the screen buttons labelled \"Next\" in each room will provide a step-by-step introduction to the basics of Rooms. This is recommended as the best way to get started. Start by selecting the Next screen button with the left mouse button. + +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 3 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Doors") + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 4 :TYPE :NOTE-WINDOW :REGION (33/1024 137/808 31/64 145/202) + :TITLE "The Rooms Model" :STRING " + +Rooms provides many screens worth of working space for the Xerox LISP user. + +Each space is called a \"room\", has a name, and contains a collection of windows. + +Windows can be in one or more rooms. A window in more than one room is referred to as \"shared\". + +A window may have a different position and shape in each room. The collection of this information is called the \"placement\" of the window in that room. + +In certain situations, it is desirable to use the same configuration of windows in more than one room. For example, in these introductory rooms, the navigation buttons, the promptwindow, and the EXEC window act as a common framework for each room's specific information windows. In these situations, a room containing only the common windows is created (here it is called \"Intro Panel\") and this room is \"included\" in the other rooms. + +Exercise: The \"Intro Panel\" button is an easy way to go to the \"Intro Panel\". Use it to go to that room, and notice the set of windows which is common. Then return to this room, using the inverted button at the center of the screeen below (a \"back door\"). + +So a room has (at least): + a name + a set of placements for various windows + a set of inclusions of other rooms. +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 5 :TYPE :BUTTON :TEXT "Intro Panel" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Panel") + :HELP "Go to the room named \"Intro Panel\"" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 6 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Overview") + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 7 :TYPE :NOTE-WINDOW :REGION (1/32 249/808 505/1024 461/808) + :TITLE "Doors" :STRING " + + +The various buttons which you have been using to move about in this exploratorium are called \"doors\". + +Doors can be of various different shapes. To the right you will find a number of those shapes, all of which will take you to this very room. + +Doors can be created using the background menu: select the \"Rooms>Make Door\" command. (This X>Y notation is used to denote the Y subcommand of the X command of a menu.) You will be prompted with a menu of room names to select a destination for the door; then you will be prompted with a menu of door shapes for the shape of the door. A door will be created, and you will be permitted to move it into the position you would like. + +Exercise: Create a door to this room, looking like a porthole. Then go through it to this room. + +Doors are windows. You can therefore get rid of them by closing the window. + +Exercise: Close the doors you just created. +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 8 :TYPE :BUTTON :TEXT "Doors" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Doors") + :HELP "Go to room named \"Intro Doors\"" :TYPE :DOOR) + (:WINDOW 9 :TYPE :BUTTON :TEXT "Intro Doors" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Doors") + :HELP "Go to room named \"Intro Doors\"" :FONT (IL:HELVETICA 18 (IL:BOLD IL:REGULAR + IL:REGULAR)) + :SHADOWS T) + (:WINDOW 10 :TYPE :BUTTON :TEXT "Doors" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Doors") + :HELP "Go to room named \"Intro Doors\"" :TYPE :PORTHOLE) + (:WINDOW 11 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Menus") + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 12 :TYPE :NOTE-WINDOW :REGION (59/1024 39/202 263/512 555/808) + :TITLE "The Overview" :STRING " + +The Overview provides a number of different operations. Roughly these can be grouped into: room selection, room manipulation, room structure viewing. + +All operations in the Overview are invoked in same way: +. the operation is selected by depressing and holding down a mode key on the keyboard, +. the object to be operated on selected by pointing and clicking: + a room: middle mouse button; or + a placement: left mouse button. + +The various operations are represented by screen buttons at the bottom of the screen. These are inverted to indicate the operation which is currently selected. + +Exercise: Use the GO TO operation to return to this room: + goto the overview; + select the GO TO operation (space bar); + return to this room by selecting its pictogram with the middle mouse button. + +Exercise: Use the Move operation on a placement: + goto the overview; + find the placement for this window; + select the MOVE operation (MOVE key); + move this placement around in this room; + return to this room when you are done. + +Exercise: Explore the other Overview commands. Return to this room when you are done. + +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 13 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Backgrounds" + ) + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 14 :TYPE :NOTE-WINDOW :REGION (1/32 227/808 261/512 503/808) + :TITLE "Background Menu" :STRING " + +So that commands to manipulate the Rooms system are always ready-at-hand, they are made available on the background menu, under the \"Rooms\" item. + +Menus are used for prompting in the interactions invoked by some of these commands. Selecting outside any of these menus indicates that you do not want to issue the command after all (you are \"cancelling\" or \"aborting\" the command). + +Exercise: Go to the \"Intro Doors\" room using the \"Rooms>Go to Room\" background command. Return here. + +Exercise: Go to the Overview using the \"Rooms\" background command. Return here. + +To make it quicker to issue these commands , Rooms provides a way of getting a screen button (an accelerator) for any command appearing on the background menu. Hold down the COPY (or SHIFT) key when selecting the command from the menu. Instead of the command being invoked, a button which will invoke the command will be created. + +Exercise: Create an accelerator for the \"Rooms>Go to Room\" background command. (It will be labelled \"Go to Room\", like the one you see at right.) +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 15 :TYPE :BUTTON :TEXT "Next >" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro End") + :HELP "Go to the next room in the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 16 :TYPE :NOTE-WINDOW :REGION (1/64 49/808 379/1024 691/808) + :TITLE "Backgrounds" :STRING " + +Each room has a background specification telling how to paint its background. The specification is an ordered list of commands. + +The three commands available are: + +(:TEXT &KEY :FONT :SHADOWS :POSITION :ALIGNMENT) + +(:REGION &KEY :SHADE :BORDER :BORDER-SHADE) + +(:WHOLE-SCREEN &KEY :BORDER :BORDER-SHADE) + +The use of these commands is best illustrated by example. + +Exercise: Select the \"Edit This Room\" button in the top middle of the screen using the left or middle button. This opens an SEdit window with this room's description. + +As you can see, the background specification for a room can be very complex allowing great flexibility in customizing the way the background is painted. + +The functions il:getregion, il:getposition, and il:editshade can be used to get regions, positions and shades interactively. For example, to insert a region in SEdit, type (il:getregion) followed by M-Z EVAL (mutate selection by EVAL). + +Exercise: change some of the regions, positions and shades in this rooms background specification. +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 17 :TYPE :BUTTON :TEXT "Edit This Room" :ACTION (EDIT-ROOM *CURRENT-ROOM*) + :HELP "Edit the current room.") + (:WINDOW 18 :TYPE :NOTE-WINDOW :REGION (129/1024 37/101 471/1024 381/808) + :TITLE "Good Bye" :STRING " + +This is the end of the Rooms Introduction. + +For more information please refer to the Rooms documentation. + + + +Enjoy! +" :FONT *INTRO-NOTE-FONT* :READ-ONLY? NIL) + (:WINDOW 19 :TYPE :BUTTON :TEXT "Intro Backgrounds" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED + "Intro Backgrounds") + :HELP "Go to the room which introduces Rooms' menus" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 20 :TYPE :BUTTON :TEXT "< Start" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro") + :HELP "Go back to the begining of the Introduction" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 21 :TYPE :BUTTON :TEXT "Overview" :ACTION (GO-TO-OVERVIEW) + :HELP "Enter the overview" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 22 :TYPE :PROMPT-WINDOW) + (:WINDOW 23 :TYPE :BUTTON :TEXT "Intro Overview" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED + "Intro Overview") + :HELP "Go to the room which introduces the Overview" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 24 :TYPE :BUTTON :TEXT "Intro Menus" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Menus") + :HELP "Go to the room which introduces Rooms' menus" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 25 :TYPE :BUTTON :TEXT "Intro Doors" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Doors") + :HELP "Go to the room which introduces doors" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 26 :TYPE :BUTTON :TEXT "Intro Model" :ACTION (INTERACTIVE-GO-TO-ROOM-NAMED "Intro Model") + :HELP "Go to the room which introduces the Rooms model" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 27 :TYPE :BUTTON :TEXT "Go to Room" :ACTION (INTERACTIVE-GO-TO-ROOM) + :HELP "Go to an existing room" :SHADOWS T :TYPE :STRETCHY-ARK) + (:WINDOW 28 :TYPE :EXEC :REGION (653/1024 15/808 11/32 85/404) + :PACKAGE "XCL-USER" :READTABLE "XCL") + (:ROOM "Intro" :PLACEMENTS ((0 :REGION (13/16 109/404 31/512 15/404)) + (1 :REGION (221/512 5/202 33/512 15/404)) + (2 :REGION (33/1024 355/808 231/512 181/404))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Model" :PLACEMENTS ((3 :REGION (13/16 219/808 31/512 15/404)) + (4 :REGION (33/1024 137/808 31/64 145/202)) + (1 :REGION (221/512 5/202 23/512 15/404)) + (5 :REGION (605/1024 267/404 45/512 15/404))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro Model" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24 IL:BOLD))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Doors" :PLACEMENTS ((6 :REGION (13/16 219/808 31/512 15/404)) + (7 :REGION (1/32 249/808 505/1024 461/808)) + (1 :REGION (221/512 5/202 47/512 15/404)) + (8 :REGION (145/256 473/808 59/1024 99/808)) + (9 :REGION (655/1024 237/404 7/64 4/101)) + (10 :REGION (165/256 529/808 87/1024 9/101))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro Doors" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Overview" :PLACEMENTS ((11 :REGION (13/16 55/202 31/512 15/404)) + (12 :REGION (59/1024 39/202 263/512 555/808)) + (1 :REGION (221/512 5/202 45/512 15/404))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro Overview" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Menus" :PLACEMENTS ((13 :REGION (415/512 55/202 31/512 15/404)) + (14 :REGION (1/32 227/808 261/512 503/808)) + (1 :REGION (221/512 5/202 59/512 15/404))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro Menus" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Backgrounds" :PLACEMENTS ((15 :REGION (831/1024 55/202 31/512 15/404)) + (16 :REGION (1/64 49/808 379/1024 691/808)) + (1 :REGION (221/512 5/202 49/512 15/404)) + (17 :REGION (437/1024 677/808 57/512 3/101))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro Backgrounds" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24)) + (:REGION (0.4 0.28 0.35 0.5) + :SHADE 42405 :BORDER 8 :BORDER-SHADE 63903) + (:REGION (0.42 0.55 0.15 0.18) + :SHADE #*(193 182)GB@@FD@@BD@IBBMIDABNJJHEEDDHAKFCD@@@@HABACFNJE@@@@@@MHADIHDALH@D@IEEEJEIAMBJJJIABEDBH@@@@@@@@JMKDH@@@@@@KB@HFBHBID@IBDKJIAEFGBHEMIBFAFHC@@@@@@@@AEKFM@@@@@@@NDKGIE@JJH@EEBNJFFKEHMEKGFEIDM@@D@@@@@@@@GGMJJ@@@@@@IEEJNDA@BJ@B@JJJIINJGCKEMMIFAD@@I@@@@@@@@HNKMA@H@@@@FBNDIEBDDA@@OEMDJGEM@NNOGKBM@M@@FH@@@D@@@CKODDH@@@@@LEJIGHA@@J@C@KBEELOEGAEJMFMHAH@@@B@@@H@@@@FJMA@@@@@@@BE@EEF@@@@LOEEJJKJNJFOOHICBAB@MAD@@@@@@@BIOJ@J@@@@@L@J@JJ@@@@@BBJJEEFOMJAMDABOL@@@B@B@@@@@@@@JJHID@@@@@@@DIEEFH@@HLJMEKJMKGDOFIB@BI@@@JJD@@@@@@@ABOJ@D@@@@@D@ABJKLA@@A@BJJDEJNNMAI@EHMJ@@@@@J@@@@@@@EEJHAI@@@@@@@JEEBJH@@BHEDIAJECMKOD@KECD@@@HOD@@@@@@@JHG@EF@@@@@@@@JJEE@@DEBJIFEBJJGNJJIGJNI@@@D@@@@@@@@@CADHBI@@@@@@BKEDHJD@@@DJJHHEEDOKOMFNNI@D@@@E@@@@@@@@DDE@EN@@@@@DADJIBJHBDKEEFKBHIEMGJKAOMJA@@@@I@@@@@@@@A@E@BH@@@@@HBBDJDEDHID@JIDHJJJKOGNKFOD@D@@@B@@@@@@@@@@J@EJ@@@@@@@DIADIIGBAGEEGBAEEGONJEOMH@@@@A@@@@@@@@@@EL@AD@@@@@B@AFFEBF@MFIEADJNNIOFOMKFKH@B@@@AH@@@@@@@@JH@FH@@@@@@@BHHHEIGBIFJFKDIMBJMJJBOOF@@@@JB@@@@@@@@@EJ@K@@@@@@@@@BBJJFHOFMMHDIGKOGKN@JMFM@@@ADHH@@@@@@@@K@JJD@@@@@@@@DJAEJOJKKGEI@JODMGJIDCMNH@@BEE@@@@@@@@@GEEFH@@@@@@@@HAJDEHMFNLIBAENOKNMBHEOM@@D@JI@@@@@@@@AFBMI@@@@@@@@A@BEEJGBIKOBDBKMNNK@E@AEKL@HAADH@@@D@@@BMEJFD@@@@@@@@DEJJAJEGNMDJ@NKOMNHJ@@OOE@JHFID@@@@@@@AFKE@@@@@@@HAAIJEDNEEEEKJIBKGMKJ@@@AEEJ@BBH@B@@@@@@@BMENJDH@@@@@@DFEJIAJDJJNIFANIGNH@B@DGOFHEJA@LH@@@@@@AKKGJKD@@@@@AJJMABE@IEEEFHNEBMED@@@@KEM@BE@@B@@@@@@@CFBNONM@@@@HDAEJFDHEBEEEAGANAEOD@@@@BOGHDN@@JH@@@@@@BMAEMENH@@@@IDBJIEBJEJJJF@OHBKED@@@@AMNHADEAB@@@@@@@AJ@CKKK@@@@DBBMEFIDJJMEFHOOFMFN@@@@@BOEHFH@BED@@@@@@BN@DD@GH@@@IDHBJIBAEGCOEGJJLJMIF@@@@@JOHH@BJHH@@@@@@@JH@IAFH@@@@A@EENLNKMEBODEGJKJBD@@@@@EOEC@@AA@@@@@@@AG@@@@CH@@@D@@BBICEFFJOJKJJOFMHH@@@@@CNMD@@B@D@@@@@@DM@@@ABH@@@HBHDMFLJIEGDOEBKMMJAJH@@@@GMNJ@@B@J@@@BH@BFDD@@CH@@@M@JAAEKDDIDKDJJOGGM@D@JH@@BKKE@@DAD@@@AB@JKI@@@A@@@@JK@DFKFJHBOLOFKJNL@AH@@@@@EODJ@@ADAB@@@DIEFBD@@BH@@@EDEIIBMEAEDKBMFOMJJ@@@A@@@CMEJH@DHJD@@@ABJMH@@@A@@@@JIBBFEEJDJOJMEMJKDH@H@@@@@BJKF@@ID@@@@@@@MKFJ@@@H@@@IEEEIDJEBMJDCJGEBI@@@@@@@@AEFM@@@H@@@@@@AGGMD@@B@@@@BJMEBEMJMKEIFOMJEB@@@@@@@@@JMO@@@@@@@@@@@IOOLH@@@@@@EGKEEBFKKFN@IHKDJD@@@@@@@@@AKJ@E@@@@@@@@@FKFKBH@@@@@JMFJBDIEFOKJFOOJJI@@@@@@@@ECGNH@@D@@@@@@@IFMOM@@H@@@EKOMMIFKOMFHIKGFJ@@@@@@@@@@BOE@@@B@@@@@@@B@KNKNI@@@@CGMGCBENJJMDGFNMH@@@@@B@@@BENN@@@H@@@@@@@@@BKOEB@@@@FOGMFDMEMFJHIOOOFH@@@@@@@@@EMHH@@B@@@@@@@@@EGOML@@@@EMMGOKJNJMEEFJKNM@@@@A@@@@@KKB@@@D@@@@@@@@@@JEGEH@@@BKKMEEEAEBNJIGNKJKD@@@@@@@AGFH@@@@@@@@@@@@@B@KMN@@@@JOGKOOJDJMIEBNKNOBDH@@@@@@BKO@@@@@@@@@@@@@@@@BKEH@@@AFOGEEDBIKFKEMMELHH@B@@@@AEFMD@@@@@@@@@@@@@@@EEO@@@@BMNOONIEGEMNOKJOKKJJ@D@@@BBOK@@@@@@@@@@@@@@@@@KJH@@@BKONNMFJMJCEJOEJBFEA@@@@@IOJN@@@@@@@@@@@@@@@@EEGH@@@COJMMNMEFMDOGJOFHLJ@@@@@AFJOH@@@@@@@@@@@@@@@@BJE@@@@EFOKKMJJMBCIMGMIEA@@@@@@JIOMD@@@@@@@BBB@@@@@@EDKH@@@KMBEOKEEJMDGGIBDBH@@@@@ACGEK@@@@@@@@DD@@@@@@@AAFH@@@FHDIEONJKEAMJBEHJ@@@@@@BNNOFD@@@@@@@A@A@@@J@@@NM@@@@G@@@OGEEFJJFNJIDBH@@@@@EEMNL@@@@@@@@D@@@@@@@@AEJ@@@@LD@ACNOGMEEMJD@M@@@@@@@KOOKH@@@@@@@@@@@@@@J@@JODH@@@K@@@EEMDKNIEFIEJ@@@@@JEEGED@@@@@@@@@@@HB@@A@BEHI@@@@LB@@JOOKFJJKM@AE@@@@A@HKMNH@@@@@@@@@@B@@@@J@IKFB@@@@JJJA@KJJMEEOJ@ED@@@EBJKNK@@@@@@@@@@@@DHB@@BJJFH@H@@@EDA@@NOMHKGFL@AD@@@@EEEEL@@@@@@@@@@@@AE@@@IAEN@@@@@@NAJD@KMEFBMMJ@@H@@@KJNKKB@@@@@@@@@@@@FH@@ABNKE@@H@@@DJ@I@AGOHMGGL@A@@@BJMKFJD@@@@@@@@@@@@A@@@BE@NH@A@@@@K@@DJBMJJKMMB@@@@@DOKFM@@@@@@@@@@@@@@FH@D@HOCD@@H@@@D@@IDEKGIFGFL@@@@@IJNH@@@@@@@@@@@@@@HC@@@FCDNHHA@@@@JH@@JHGOEEMME@@@@ACGH@@@@@@@@@@@@@@@BM@D@HLOMAB@@@@@I@@@JHMNLMCKJ@@@@@FNJ@@@@@@@@@@@@@@@DKFIEAEIEEH@@@@@BJ@@A@KEIBOFOH@@@BMM@@@@@@@@@@@@@@@@@EDBBBJBJBJH@@@@EDJ@DBFONMCOID@@@EGJ@@@@@@@@@@@@@@@@@I@@DAD@@IEE@@@@JKD@@AEOEJNMGJ@@@IML@@@@@@@@@@@@@@@@@@@@@BHB@@@JH@@@EDKD@BEJOGKGNLDJBFK@@@@@@JJ@@@@@@@@@@@H@@AB@@@AA@@@@H@BH@@CGMNHEKJH@@KOH@@@@ADD@@@@@@@@@@@@@@B@@@@@@@@@@@@BH@@EOOEJKGDAEEFJD@@AD@KE@@@@@@@@@@@@@@@H@@@@@@@@@H@AJ@BBMJKDGNOF@BMOH@JBIF@B@@@@@@@@@@@@@@B@@@@@@@@@@B@BM@@EKO@JIGMDIEOJ@@@EFHJHD@@H@@@@@@@@@@@@@@@@@H@@@D@AFH@IGJOECMFM@KENI@FJLB@@H@A@@@@@@@@@@@@@@@@EBH@@@@@@ID@BOGHNNOMJKFOE@BIA@@@@@@@@@@@@@@@@@@@@@@@BH@@@@@BAELAENOGECJOONMML@EDD@@@@@@@@@@@@@@@@@@@@@@@E@@@@@E@BHEBJKNNMFGJMEKKJ@JI@@@@@@BJ@@@@@@@@@@@@@@@BAD@@@@B@B@KDEBMOKFNOKOOGD@BHB@@@@@@@@@@@@@@@@@@@@@@@D@@@@@@@DAEEJEONNMMOGMKOH@E@D@@@@@@@@@@@@@@@@@@@@@@BI@@@@@H@HDBJEKEMOOKMOGNMD@A@I@@@@@@@@@@@@@@@@@@@@@@@B@@@@@BEBJMEJDOKMEGKNOGO@@B@B@@@@@@@@@@@@@@@@@@@@@@@D@@@@@JJIBJKAKMOOOOGENNJID@HD@@@@@@@@@@@@@@@@@@@@@@@@@@@@@DIFJJFJGGKJOFOOOMN@@BDH@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ABM@@KEMJOOMONOMOID@AHB@@@@@@@@@@@@@@@@@@@@@@@@@@@@@NKJ@BBMGEOFOFMMGFJH@E@D@@@@@@@@@@@@@@@@@@@@@@@@@@@@@EDDH@EEJKMMMOKKNMJB@JHID@@@@@@@@@@@@@@@@@@@@@@@@@@@@EKA@@@JGOGKKJOGMOELJEJB@@@@@@@@@@@@@@@@@@@@@@@@@@@@@JDE@@AEIEMGGGNMGNHC@KEDD@@@@@@@@@@@@@@@@@@@@@@@@@@@@JK@@@@ECJFMNMKEMMEDOELIAD@@@@@@@@@@@@@@@@@@@@@@@@@@@DJ@@@@JEDHJCJLKGKJ@@KE@J@@@@@@@@@@@@@@@@@@@@@@@@@@@@KD@@@AAJ@E@MECGOGL@EEJEBH@@@@@@@@@@@@@@@@@@@@@@@@@@@DJH@A@D@HHBJNLNJOKJBJHHD@H@@@@@@@@@@@@@@@@@@@@@@@@@@KM@@HA@H@B@JJKKOOFH@CKG@@@@@@@@@@@@@@@@@@@@@@@@@@@@@EBDH@@D@A@@EGNOGOOJEMDD@@J@@@@@@@@@@@@@@@@@@@@@@@@@@JLH@@@@@J@ABJKNOFMFHCJH@@@@@@@@@@@@@@@@@@@@@@@@@@@@@JAB@@@@@@H@JOKGNOOMAOEB@@@@@@@@@D@@@@@@@@@@@@@@BH@@@DJ@@@@H@I@A@JNNONMFHEN@@@@@@@@@@H@@@@@@@@@@@@@@A@@@@H@@@@A@@@@@AEIMMOODGKDH@@@@@@@@@B@@@@@@@@@@@@@@B@@@@D@@@@@@@@@@@CFKOMJH@BM@@@@@@@@@@@H@@@@@@@@@@@@@@@@@@H@@@@@@@@@@@DIGOKOFJINB@@@@@@@@BB@I@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ABOMGJH@AED@@@@@@@@@@I@@BH@@@@@@@@@@@@@@@@A@@@@@@@@@HEOGOOID@M@@@@@@@@@BJD@@D@@@@@@@@@@@@@@@HED@@@@@@@@BACMONK@HAGD@@@@E@@@@DJHBI@@@@@@@@@@@@@@@EBKM@JH@@@@@NMGMENHB@EJ@@B@H@@@@IEBJBA@@@@@@@@@@@@@@JMDBECD@@D@@IGMGOODD@BH@@@DB@@@@BHDDHB@@@@@@@@@@@@@@OKKMHFM@@@@@GJKMOJH@@EJ@@FHL@@@@@CAJJHH@@@@@@@@@@@@@KGDBBJNJ@@@@HGFKJOL@@CD@@I@@@@H@@@FEBC@@@@@@@@@@@@@@NNOMLJML@@@@AMEOGNJ@@AN@@ED@@@D@@@HMDH@@@@@@@@@@@@@@KJHJIEKKH@@@BJKEOKD@@BJJEE@AE@HBJ@EEE@@@@@@@@@@@@@@@DDBKFKGFJ@@@OJFONNNH@@OLJJ@HHH@AD@BJJH@@@@@@@@@@@@@@@@@@MEOOL@@ADDMKEME@@AEEEB@EC@@BB@DLE@@@@@@@@@@@@@@@@@@@BOFMD@@AKIKGOKJ@@@ONJLHHD@@@MDIKDD@@@@@@@@@@@@@@@@@@ABMKM@@CDFNOGFNH@@BMDK@BHH@AAAFLHH@@@@@@@@@@@@@@@@@@@EOOJ@@EEIENNMJHH@ENIF@@B@@BJDIGDB@@@@@@@@@@@@@@@@@@@CGFL@@CJBOMMCEC@@CMJDJIDH@AEBEEI@@@@@@@@@@@@@@@@@@@@BJOK@@NDAJKNJNLJ@EKDAABA@@BJEBOF@@@@@@@@@@@@@@@@@@@@@GNNAECHCEOJCIC@@CFHEEDAD@@EJDJHH@@@@@@@@@@@@@@@@@@@@AMLBJF@@KKDMFJH@EN@BB@B@D@KDAGN@@@@@@@@@@@@@@@@@@@@@GGNKMN@CGGOCMD@@CL@@IODLJ@FJAMA@@@@@@@@@@@@@@@@@@@@@BOJEGD@@MNHNJI@@EJJOGEEA@EMMFGNB@@@@@@@@@@@@@@@@@@@@ENNKMJ@CKKOEHB@@CNMJNOMEEBEFJM@D@@@@@@@@@@@@@@@@@@@@CKJBKD@@GGJKD@@@NMKOMNKJLIJMMKFJ@@@@@@@@@@@@@@@@@@@@EGNADA@CMOFED@AECOGEKMOGKFKKCFMD@@E@H@@@@@@@@@@@A@@@COD@AF@DGFMJHH@ENMNOOKOMFMFENLED@B@@@@@@@@@@@@@@@@@@GFN@B@@AMMOBK@@KGKONJOMGMJMNKJJI@JJHH@@@@@@@@@@@A@@@BOMD@JDBKGMEE@BNNOJIEAGMGFKENNKEBJE@@@@@@@@@@@@@@@A@GNNHBDH@NOGJKDJKMJDD@BJKJMEGGIEEEEJ@@@@@@@@@@@@@@@D@BMMB@I@ACMNIFMENKG@@@@BDENNLOFFJME@H@@@@AD@@@@@@AEAJEKJ@@B@@NKKJMJJKON@@@ADICEKKNLIJJJNAD@@@HI@@@@@@BJJDCON@@@J@CGGEFKEOED@@@JJ@DAEGMICEEEIJ@@@@ABH@@@@@@@EHAFJ@@@D@ENOMKFKFOL@@ABDAABKNKNAJMGF@@@@@DE@@@@@@HJJHFMN@@@A@FKNJEMEMNH@@BDHBJAEEOJJOKJI@@@@@BJH@@@@BB@A@HKL@@@@@ANMNKBCGM@@@AKJIDJKKONIEFE@@@@@@DK@@@@@@H@@DFOJ@@@@HFKKMFLMOK@@@BEEFIBFJEKKKJH@@@@@@IBH@@@@@B@A@IEE@@@J@AMGOEBKFN@@AEONMFBILONNFE@@@@@@@BEH@@@@@@@B@BKL@@@DHAGOJLMEMHH@JOIEJDDFABKKLH@@@@@@ADI@@@@@@@@@@DKD@@@H@BMMGJ@KGJH@EJJKGEIHKEOFH@@@@@@@@JJH@@@@@@@AAAFL@@@@@DKKOEGFOD@@KOKENJBEDNJMD@@@@@@@AEA@@@@@@@@@@JMH@@@@@AGGMNHMNHH@EGDJEBMJKEGHH@@@@@@@DHFH@@@@@@@@ABKH@D@@@@JOGIGGM@@@KNODOEJE@JN@@@@@@@@@BJI@@@@@@@@@BMGD@BH@@CGNNNJMK@@@CMJIMOFJDDMH@@@@@@@@EAF@@@@@@@@@CBMH@A@@@DDKMMOOF@@@FCGGGJM@@AGFH@@@@@@@BEDH@@@@@@@@DMFHAB@@@AKNOKJMD@@@BLLMMGJ@@@EM@@@@@@@@DJK@@@@@@@@@CBIJD@@ADBEEMOGJH@@BFICKGND@@@AGL@@@@@@@AAD@@@@@@@@@DICFKD@@@AKOOKOF@@BLJBLFMKJ@@@@JK@@@@@@@BJKH@@@@@@@@CFFMLH@@@BFMMOFH@@ABFLBMGFDH@@@AFJ@@@@@@ADJ@@@@@@@@ADHKOKBI@@AMKKKM@@@BNMKLBMLH@@@@@EL@@H@@@BKEH@@@@@@@@KEEEOMF@@FGOONH@@@AIKD@DKA@@@@@@BK@A@@@@ALK@@@@@@@@@EJKOJID@@IMGGEBJJJJFFMHAJJ@@@@@@@JH@@@@@@KOH@@@@@@@@BOFMONJ@BFKNNMEEOEAJIKBKEEA@@@@@@EL@L@BJAOFH@@@@@@@@ADMOKENHAIOKOJOOEJFJ@FH@BJJ@@@@@@AE@@@ADBJOH@@@@@@@@@KKKGOKBFGFOMEJIKEID@I@@IADH@@@@@@NJJ@KJAONH@@@@@@BH@BGGNMNNKJMJKOMBDBE@@@@@@B@@@@@@@@CEEAGEEGMH@@@@@ADJ@@JOGOKMNOKFOFH@@@@@@@@@@@@@@@@@@@@OJEEFKMGH@@@@@J@JH@AFNMOKMJLI@M@@@@@@@@@@@@@@@@@@@@CEEJJEFKMH@@@@@@HE@@@AOOKGKOHBE@@@@@@@@@@@@@@@@@@@@@@COD@@IOG@@@@@@A@KD@@EKKGOGMDDHD@@@@@@@@@@@@@@@@@@@@@AEH@JBJLH@@@@@@HFJJHAFONMOKHJKEB@@@@@@@@@@@@@@@@@@@@@O@I@EGK@@@@@@@@HAE@@ENOKNO@EDHDH@@@@@@@@@@@@@@@@@@@AMB@EEJJH@@@@@@@JBJJ@KEJOKMAKMEI@@@@@@@@@@@@@@@@@@@@@JDJHIFKH@@@@@@A@@CMI@JKNOFBGGFBNH@@@@@@@@@@@@@@@@@@AEADKCMDH@@@H@@@@@AGBEABENNBNHMMED@@@@@@@@@@@@@@@@@@@@JI@EBEH@@@D@@AD@BMDJJDKMMEOECEED@@@@@@@@@@@@@@@@@@@@EFEELJH@@@H@@@@@@KEAD@JKLAEBEJKH@@@@@@@@@@@@@@@@@@@@KM@KAA@@@@@@@@H@@NIFA@EGJCOLBEFJ@@@@@@@@@@@@@@@@@@@@FJE@NE@@@@@@@@D@AEFHJ@HODDK@AEEL@@@@@@@@@@@@@@@@@@@@KOHCD@H@@@@@@@H@@JIFH@AJMEFNJJO@@@@@@@@@@@@@@@@@@@@AFKBDIA@@@@@@@@@@@JJIB@CGJJOIEJML@@@@@@@@@@@@@@@@@@@@KOLAF@@@@@@@@@H@AEBNL@JM@EMDBKO@@@@@@@@@@@@@@@@@@@@AFK@FID@@@@H@@@@@FJMI@AADFOGJENJH@@@@@@@@@@@@@@@@@@@@MONIGD@@@@@@@@H@JJKFMBDIJJNHCEM@@@@@@@@@@@@@@@@@@@@@KFHFMMH@@@@@@@D@EEJMB@IBGOMJNOJH@@@@@@@@@@@@@@@@@D@@FONIGG@@@@@@@AH@JOFKMB@EMEGDCMF@@@@@@@@@@@@@@@@@@A@@KMDJMMH@@@@@@@@@EEMFFHHKGOJMNOL@@@@@@@@@@@@@@@@@BN@@BKMEGGH@@@@@@C@@KNJMM@@JJJEBEM@@@@@@@@@@@@@@@@@@HA@@EGDJMOH@@@@@@D@@FEMKJH@GGLJIGO@@@@@@@@@@@@@@@@@@DN@ABJJJKM@@@@@@@CA@JNKGG@@MDAABMJ@@@@@@@@@@@@@@@@@@@A@HHEDKOKH@@@@@@DHBEKNNLHBJJJJEGM@@@@@@@@@@@@@@A@@@@NEBEBANNOH@@@@@BAADMNKKKBLJEEEKE@@@@@@@@@@@@@@@A@@@@@HEB@FKKM@@@@@@DBJAKENFDDA@JJKFNH@@@@@@@@@@@@@@@H@@JI@@H@EFOGH@@@ + :BORDER 2) + (:TEXT "A bitmap" :POSITION (0.42 . 0.525) + :FONT + (IL:HELVETICA 10 IL:BOLD) + :SHADOWS :ARK) + (:REGION (0.62 0.62 0.1 0.1) + :SHADE 52428) + (:REGION (0.58 0.58 0.1 0.1) + :SHADE 52224) + (:TEXT "Some shades" :POSITION (0.58 . 0.525) + :FONT + (IL:HELVETICA 10 IL:BOLD) + :SHADOWS :ARK) + (:TEXT "Text with shadows..." :POSITION (0.43 . 0.47) + :FONT + (IL:HELVETICA 18 IL:BOLD) + :SHADOWS T) + (:TEXT "Erasing text..." :POSITION (0.43 . 0.44) + :FONT + (IL:HELVETICA 18 IL:BOLD) + :SHADOWS + ((:OPERATION IL:ERASE))) + (:TEXT "Outlined letters..." :POSITION (0.43 . 0.41) + :FONT + (IL:HELVETICA 18 IL:BOLD) + :SHADOWS + ((:DX 1) + (:DY 1) + (:DX -1) + (:DY -1) + (:TEXTURE 65535 :OPERATION IL:INVERT :SOURCE-TYPE IL:MERGE))) + (:TEXT "Some text" :POSITION (0.42 . 0.37) + :FONT + (IL:HELVETICA 10 IL:BOLD) + :SHADOWS :ARK)) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro End" :PLACEMENTS ((1 :REGION (221/512 5/202 69/512 15/404)) + (18 :REGION (129/1024 37/101 471/1024 381/808))) + :INCLUSIONS + ("Intro Panel") + :BACKGROUND + ((:TEXT "Intro End" :POSITION (10 . 10) + :FONT + (IL:HELVETICAD 24))) + :FILE-WATCH-ON? NIL) + (:ROOM "Intro Panel" :PLACEMENTS ((19 :REGION (793/1024 379/808 71/512 15/404)) + (1 :REGION (221/512 5/202 33/512 15/404)) + (20 :REGION (207/256 65/202 33/512 15/404)) + (21 :REGION (409/512 661/808 41/512 15/404)) + (22 :REGION (7/1024 94/101 63/64 6/101) + :FONT + (IL:HELVETICA 12 (IL:BOLD IL:REGULAR IL:REGULAR)) + :BORDER 2 :SHADE 65535 :TITLE NIL :OPERATION IL:ERASE) + (23 :REGION (401/512 231/404 61/512 15/404)) + (24 :REGION (407/512 105/202 49/512 15/404)) + (25 :REGION (815/1024 251/404 47/512 15/404)) + (26 :REGION (815/1024 271/404 47/512 15/404)) + (27 :REGION (811/1024 619/808 49/512 15/404)) + (28 :REGION (653/1024 15/808 11/32 85/404))) + :INCLUSIONS NIL :BACKGROUND ((:WHOLE-SCREEN 33825 :BORDER 2) + (:REGION (49/64 1/4 5/32 21/32) + :SHADE 50745) + (:REGION (5/8 7/8 340 40) + :SHADE 50745) + (:TEXT "Rooms Introduction" :POSITION + (:EVAL (CONS (+ (INTERNALIZE-COORDINATE 5/8 + IL:SCREENWIDTH) + 10) + (+ (INTERNALIZE-COORDINATE 7/8 + IL:SCREENHEIGHT) + 3))) + :FONT + (IL:HELVETICAD 24))))) + +(EVAL-WHEN (LOAD) + (LET ((BUTTON (MAKE-BUTTON :TEXT "Enter Introduction" :FONT '(IL:HELVETICAD 24) + :SHADOWS T :TYPE :STRETCHY-ARK :ACTION '(INTERACTIVE-GO-TO-ROOM-NAMED + "Intro") + :HELP "Enter the Rooms Introduction suite"))) + (MAKE-BUTTON-WINDOW BUTTON (MAKE-POSITION (FLOOR (- IL:SCREENWIDTH (BUTTON-WIDTH BUTTON)) + 2) + (FLOOR (- IL:SCREENHEIGHT (BUTTON-HEIGHT BUTTON)) + 2))))) +(IL:PUTPROPS IL:ROOMS-INTRO IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990)) +(IL:DECLARE\: IL:DONTCOPY + (IL:FILEMAP (NIL))) +IL:STOP diff --git a/rooms/ROOMS-MEDLEY-WINDOW-TYPES b/rooms/ROOMS-MEDLEY-WINDOW-TYPES new file mode 100644 index 00000000..f5003c61 --- /dev/null +++ b/rooms/ROOMS-MEDLEY-WINDOW-TYPES @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:36:07"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-MEDLEY-WINDOW-TYPES.;2| 20710 IL:|previous| IL:|date:| "17-Aug-90 12:52:53" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-MEDLEY-WINDOW-TYPES.;1| ) ; Copyright (c) 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-MEDLEY-WINDOW-TYPESCOMS) (IL:RPAQQ IL:ROOMS-MEDLEY-WINDOW-TYPESCOMS ( (IL:* IL:|;;| "window types for various modules") (FILE-ENVIRONMENTS IL:ROOMS-MEDLEY-WINDOW-TYPES) (IL:P (REQUIRE "ROOMS")) (IL:WINDOW-TYPES :EXEC :INSPECTOR :SPY-BUTTON :CHAT :TEXTSTREAM :TEDIT :BUTTON) (IL:COMS (IL:* IL:|;;| "the prompt window") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:P (OR (IL:RECLOOK 'IL:WINDOW) (IL:EVAL (IL:SYSRECLOOK1 'IL:WINDOW))))) (IL:WINDOW-TYPES :PROMPT-WINDOW) (IL:GLOBALVARS IL:PROMPTWINDOW)) (IL:COMS (IL:* IL:|;;| "SEdit") (IL:ADVISE (IL:OPENWP :IN SEDIT::GET-CONTEXT)) (IL:WINDOW-TYPES :SEDIT)) (IL:COMS (IL:* IL:|;;| "File Browser") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:P (OR (IL:RECLOOK 'IL:FILEBROWSER) (IL:EVAL (IL:SYSRECLOOK1 'IL:FILEBROWSER))) (OR (IL:RECLOOK 'IL:TABLEBROWSER) (IL:EVAL (IL:SYSRECLOOK1 'IL:TABLEBROWSER))))) (IL:WINDOW-TYPES :FILE-BROWSER :TABLE-BROWSER)) (IL:COMS (IL:* IL:|;;| "Sketch") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:P (OR (IL:RECLOOK 'IL:SKETCH) (IL:LOADDEF 'IL:SKETCH 'IL:RECORDS 'IL:SKETCH)))) (IL:WINDOW-TYPES :SKETCH)) (IL:COMS (IL:* IL:|;;| "Logo Window") (IL:WINDOW-TYPES :LOGO-WINDOW) (IL:ADVISE IL:LOGOW)) (IL:COMS (IL:* IL:|;;| "PSW") (IL:WINDOW-TYPES :PSW)))) (IL:* IL:|;;| "window types for various modules") (DEFINE-FILE-ENVIRONMENT IL:ROOMS-MEDLEY-WINDOW-TYPES :COMPILER :COMPILE-FILE :READTABLE "XCL" :PACKAGE "ROOMS") (REQUIRE "ROOMS") (DEF-WINDOW-TYPE :EXEC :RECOGNIZER (LAMBDA (WINDOW) (IL:EQMEMB 'XCL::EXEC-CLOSEFN (IL:WINDOWPROP WINDOW 'IL:CLOSEFN))) :ABSTRACTER (LAMBDA (WINDOW) (LET* ((PROCESS (IL:WINDOWPROP WINDOW 'IL:PROCESS))) (WHEN PROCESS (LET ((PROFILE (IL:PROCESSPROP PROCESS 'IL:PROFILE))) `(:REGION ,(EXTERNALIZE-REGION (WINDOW-REGION WINDOW)) :PACKAGE ,(IF PROFILE (PACKAGE-NAME (GETF PROFILE '*PACKAGE*)) "IL") :READTABLE ,(IF PROFILE (IL:READTABLEPROP (GETF PROFILE '*READTABLE*) 'IL:NAME) "OLD-INTERLISP-T")))))) :RECONSTITUTER (LAMBDA (ARGS) (LET ((PROCESS (ADD-EXEC :REGION (INTERNALIZE-REGION (GETF ARGS :REGION (LIST 0 0 400 100))) :PROFILE (OR (GETF ARGS :PROFILE) `(*PACKAGE* ,(OR (FIND-PACKAGE (GETF ARGS :PACKAGE)) (FIND-PACKAGE "XCL-USER")) *READTABLE* ,(OR (IL:FIND-READTABLE (GETF ARGS :READTABLE)) (IL:FIND-READTABLE "XCL"))))))) (IL:* IL:|;;|  "this is really grody. why doesn't ADD-EXEC just take a window?") (IL:BLOCK) (IL:WFROMDS (IL:PROCESS.EVALV PROCESS '*STANDARD-OUTPUT*)))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'IL:TITLE) REGION DSP))) (DEF-WINDOW-TYPE :INSPECTOR :RECOGNIZER (IL:LAMBDA (WINDOW) (IL:WINDOWPROP WINDOW 'IL:DATUM)) :TITLE "Inspector") (DEF-WINDOW-TYPE :SPY-BUTTON :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) 'IL:SPY.BUTTONA0001)) :ABSTRACTER (LAMBDA (WINDOW) (DECLARE (IGNORE WINDOW)) NIL) :RECONSTITUTER (LAMBDA (DATA) (DECLARE (IGNORE DATA) (GLOBAL IL:SPY.BUTTON)) (UNLESS (BOUNDP 'IL:SPY.BUTTON) (IL:FILESLOAD "spy")) (IF IL:SPY.BUTTON IL:SPY.BUTTON (PROGN (IL:SPY.BUTTON (MAKE-POSITION 0 0)) IL:SPY.BUTTON))) :NO-SHAPE T :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING "Spy" REGION DSP :NO-TITLE-BAR? T))) (DEF-WINDOW-TYPE :CHAT :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) 'IL:CHAT.BUTTONFN)) :ABSTRACTER (LAMBDA (WINDOW) (LIST :HOST (IL:CANONICAL.HOSTNAME (FIRST (IL:WINDOWPROP WINDOW 'IL:CHATHOST))) :REGION (IL:WINDOWREGION WINDOW))) :RECONSTITUTER (LAMBDA (DATA) (LET ((WINDOW (IL:CREATEW (GETF DATA :REGION) "Chat"))) (IL:* IL:|;;| "start the chat process") (IL:CHAT (GETF DATA :HOST) NIL NIL WINDOW) (IL:* IL:|;;| "return the window") WINDOW)) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING (FORMAT NIL "Chat ~A" (FIRST (IL:WINDOWPROP ( PLACEMENT-WINDOW PLACEMENT) 'IL:CHATHOST))) REGION DSP))) (DEF-WINDOW-TYPE :TEXTSTREAM :RECOGNIZER (LAMBDA (WINDOW) (IL:TYPE? IL:TEXTOBJ (IL:WINDOWPROP WINDOW 'IL:TEXTOBJ))) :TITLE "Text") (DEF-WINDOW-TYPE :TEDIT :DEPENDENCIES (:TEXTSTREAM) :RECOGNIZER (LAMBDA (WINDOW) (OR (IL:WINDOWPROP WINDOW 'IL:TEDITCREATED) (LET ((TEXTOBJ (IL:WINDOWPROP WINDOW 'IL:TEXTOBJ))) (AND (IL:TYPE? IL:TEXTOBJ TEXTOBJ) (GETF (IL:FFETCH (IL:TEXTOBJ IL:EDITPROPS) IL:OF TEXTOBJ) 'IL:TEDITCREATEDWINDOW))))) :ABSTRACTER (LAMBDA (WINDOW) (LET* ((STREAM (IL:FETCH (IL:TEXTOBJ IL:TXTFILE) IL:OF (IL:TEXTOBJ WINDOW)))) (WHEN STREAM `(:REGION ,(EXTERNALIZE-REGION (WINDOW-REGION WINDOW)) :PATHNAME ,(MAKE-PATHNAME :VERSION :NEWEST :DEFAULTS (PATHNAME STREAM)) )))) :RECONSTITUTER (LAMBDA (PROPS) (IL:FILESLOAD (IL:SYSLOAD) IL:TEDIT) (LET* ((PATHNAME (GETF PROPS :PATHNAME)) (FOUND (WHEN PATHNAME (PROBE-FILE PATHNAME))) (NAMESTRING (WHEN FOUND (NAMESTRING FOUND))) (WINDOW (IL:\\TEDIT.CREATEW.FROM.REGION (INTERNALIZE-REGION (GETF PROPS :REGION (LIST 0 0 200 200))) (IF FOUND NAMESTRING)))) (IL:TEDIT (IF FOUND (INTERN NAMESTRING "INTERLISP") (IF PATHNAME (FORMAT NIL "Couldn't edit file ~A" (NAMESTRING PATHNAME)))) WINDOW NIL (LIST 'IL:TEDITCREATEDWINDOW T 'IL:LEAVETTY T)) WINDOW)) :TITLE "TEdit") (DEF-WINDOW-TYPE :BUTTON :RECOGNIZER (LAMBDA (WINDOW) (TYPEP (IL:WINDOWPROP WINDOW 'BUTTON) 'BUTTON)) :ABSTRACTER (LAMBDA (WINDOW) (EXTERNALIZE-BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) :RECONSTITUTER (LAMBDA (ARGS) (MAKE-BUTTON-WINDOW (APPLY #'MAKE-BUTTON ARGS) (INTERNALIZE-POSITION (GETF ARGS :POSITION (MAKE-POSITION 0 0))))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (LET ((BUTTON (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'BUTTON))) (WHEN BUTTON (PRINT-PEP-TITLE-STRING (TEXT-STRING (BUTTON-TEXT BUTTON)) REGION DSP :NO-TITLE-BAR? T))))) (IL:* IL:|;;| "the prompt window") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (OR (IL:RECLOOK 'IL:WINDOW) (IL:EVAL (IL:SYSRECLOOK1 'IL:WINDOW))) ) (DEF-WINDOW-TYPE :PROMPT-WINDOW :RECOGNIZER (LAMBDA (WINDOW) (EQ WINDOW IL:PROMPTWINDOW)) :ABSTRACTER (LAMBDA (WINDOW) NIL) :RECONSTITUTER (LAMBDA (DATA) IL:PROMPTWINDOW) :UPDATER (LAMBDA (PLACEMENT) (LET ((FONT (IL:DSPFONT NIL IL:PROMPTWINDOW))) (PLACEMENT-PROP PLACEMENT :FONT (EXTERNALIZE-FONT FONT))) (PLACEMENT-PROP PLACEMENT :BORDER (IL:WINDOWPROP IL:PROMPTWINDOW 'IL:BORDER)) (PLACEMENT-PROP PLACEMENT :SHADE (IL:DSPTEXTURE NIL IL:PROMPTWINDOW)) (PLACEMENT-PROP PLACEMENT :TITLE (IL:WINDOWPROP IL:PROMPTWINDOW 'IL:TITLE)) (PLACEMENT-PROP PLACEMENT :OPERATION (IL:DSPOPERATION NIL IL:PROMPTWINDOW))) :PLACER (LAMBDA (PLACEMENT) (DO* ((CHANGED? NIL) (PROP-LIST (PLACEMENT-PROPS PLACEMENT) (CDDR PROP-LIST)) (PROP (CAR PROP-LIST) (CAR PROP-LIST)) (VALUE (CADR PROP-LIST) (CADR PROP-LIST))) ((NULL PROP-LIST) (WHEN CHANGED? (IL:* IL:|;;|  "this is how we change the border & title without changing the region") (IL:CLOSEW IL:PROMPTWINDOW) (IL:ADVISEWDS IL:PROMPTWINDOW) (IL:SHOWWFRAME IL:PROMPTWINDOW) (IL:CLEARW IL:PROMPTWINDOW))) (CASE PROP (:BORDER (UNLESS (EQL VALUE (IL:FETCH (IL:WINDOW IL:WBORDER) IL:OF IL:PROMPTWINDOW)) (IL:REPLACE (IL:WINDOW IL:WBORDER) IL:OF IL:PROMPTWINDOW IL:WITH VALUE) (SETQ CHANGED? T))) (:FONT (LET ((NEW-FONT (IL:FONTCREATE VALUE NIL NIL NIL 'IL:DISPLAY))) (UNLESS (EQ (IL:DSPFONT NEW-FONT IL:PROMPTWINDOW) NEW-FONT) (SETQ CHANGED? T)))) (:OPERATION (UNLESS (EQ VALUE (IL:DSPOPERATION VALUE IL:PROMPTWINDOW)) (SETQ CHANGED? T))) (:SHADE (UNLESS (EQ VALUE (IL:DSPTEXTURE VALUE IL:PROMPTWINDOW)) (SETQ CHANGED? T))) (:TITLE (UNLESS (EQL VALUE (IL:FETCH (IL:WINDOW IL:WTITLE) IL:OF IL:PROMPTWINDOW )) (IL:REPLACE (IL:WINDOW IL:WTITLE) IL:OF IL:PROMPTWINDOW IL:WITH VALUE) (SETQ CHANGED? T)))))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (IL:DSPFILL REGION IL:BLACKSHADE 'IL:PAINT DSP))) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:PROMPTWINDOW) ) (IL:* IL:|;;| "SEdit") (REINSTALL-ADVICE '(IL:OPENWP :IN SEDIT::GET-CONTEXT) :BEFORE '((:FIRST (LOCALLY (DECLARE (SPECIAL IL:WINDOW)) (UN-HIDE-WINDOW IL:WINDOW))))) (IL:READVISE (IL:OPENWP :IN SEDIT::GET-CONTEXT)) (DEF-WINDOW-TYPE :SEDIT :RECOGNIZER (LAMBDA (WINDOW) (IL:EQMEMB 'SEDIT::CLOSEFN (IL:WINDOWPROP WINDOW 'IL:CLOSEFN))) :TITLE "SEdit") (IL:* IL:|;;| "File Browser") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (OR (IL:RECLOOK 'IL:FILEBROWSER) (IL:EVAL (IL:SYSRECLOOK1 'IL:FILEBROWSER))) (OR (IL:RECLOOK 'IL:TABLEBROWSER) (IL:EVAL (IL:SYSRECLOOK1 'IL:TABLEBROWSER))) ) (DEF-WINDOW-TYPE :FILE-BROWSER :DEPENDENCIES (:TABLE-BROWSER) :RECOGNIZER (LAMBDA (WINDOW) (IL:TYPE? IL:FILEBROWSER (IL:WINDOWPROP WINDOW 'IL:FILEBROWSER))) :ABSTRACTER (LAMBDA (WINDOW) (LET ((FB (IL:WINDOWPROP WINDOW 'IL:FILEBROWSER))) (LIST :REGION (EXTERNALIZE-REGION (WINDOW-REGION WINDOW)) :PATTERN (IL:FETCH (IL:FILEBROWSER IL:PATTERN) IL:OF FB) :INFO (IL:FETCH (IL:FILEBROWSER IL:INFOMENUCHOICES) IL:OF FB)))) :RECONSTITUTER (LAMBDA (PROPS) (LET ((WINDOW (IL:FILEBROWSER (GETF PROPS :PATTERN "*") (GETF PROPS :INFO) (LIST 'IL:REGION (INTERNALIZE-REGION (GETF PROPS :REGION))))) ) (IL:* IL:|;;| "wait for FB to recompute") (IL:BLOCK) (IL:WITH.MONITOR (IL:FETCH (IL:FILEBROWSER IL:FBLOCK) IL:OF (IL:WINDOWPROP WINDOW 'IL:FILEBROWSER)) WINDOW))) :TITLE "FB" :FILES (IL:FILEBROWSER)) (DEF-WINDOW-TYPE :TABLE-BROWSER :RECOGNIZER (LAMBDA (WINDOW) (IL:TYPE? IL:TABLEBROWSER (IL:WINDOWPROP WINDOW 'IL:TABLEBROWSER) ))) (IL:* IL:|;;| "Sketch") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (OR (IL:RECLOOK 'IL:SKETCH) (IL:LOADDEF 'IL:SKETCH 'IL:RECORDS 'IL:SKETCH)) ) (DEF-WINDOW-TYPE :SKETCH :RECOGNIZER (LAMBDA (W) (IL:WINDOWPROP W 'IL:SKETCH)) :ABSTRACTER (LAMBDA (W) (LIST :FILE (IL:FETCH (IL:SKETCH IL:SKETCHNAME) IL:OF (IL:WINDOWPROP W 'IL:SKETCH)) :REGION (EXTERNALIZE-REGION (WINDOW-REGION W)))) :RECONSTITUTER (LAMBDA (DATA) (WHEN (FBOUNDP 'IL:SKETCH) (IL:SKETCH (GETF DATA :FILE) (IL:CREATEW (INTERNALIZE-REGION (GETF DATA :REGION (LIST 0 0 500 500))) "Sketch")))) :TITLE "Sketch") (IL:* IL:|;;| "Logo Window") (DEF-WINDOW-TYPE :LOGO-WINDOW :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'TYPE) 'IL:LOGOW)) :ABSTRACTER (LAMBDA (WINDOW) (IL:WINDOWPROP WINDOW 'ABSTRACTION)) :RECONSTITUTER (LAMBDA (ABSTRACTION) (IL:LOGOW (GETF ABSTRACTION :STRING) NIL (GETF ABSTRACTION :TITLE) (GETF ABSTRACTION :TITLE-LOCATION))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING "Envos" REGION DSP :NO-TITLE-BAR? T))) (REINSTALL-ADVICE 'IL:LOGOW :AFTER '((:LAST (IL:WINDOWPROP IL:!VALUE 'ABSTRACTION `(,@(WHEN STRING `(:STRING ,STRING)) ,@(WHEN IL:TITLE `(:TITLE ,IL:TITLE)) ,@(WHEN IL:TITLE-LOCATION `(:TITLE-LOCATION ,IL:TITLE-LOCATION))))))) (IL:READVISE IL:LOGOW) (IL:* IL:|;;| "PSW") (DEF-WINDOW-TYPE :PSW :RECOGNIZER (LAMBDA (WINDOW) (DECLARE (GLOBAL IL:PROCESS.STATUS.WINDOW)) (EQ WINDOW IL:PROCESS.STATUS.WINDOW)) :TITLE (LAMBDA (PLACEMENT REGION DSP) (PRINT-PEP-TITLE-STRING "PSW" REGION DSP :NO-TITLE-BAR? T))) (IL:PUTPROPS IL:ROOMS-MEDLEY-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-MEDLEY-WINDOW-TYPES.DFASL b/rooms/ROOMS-MEDLEY-WINDOW-TYPES.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..112674d8bfffe484878b144fa616e158351dac68 GIT binary patch literal 14448 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.;2| 12691 IL:|previous| IL:|date:| "17-Aug-90 12:55:10" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-NOTES.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-NOTESCOMS) (IL:RPAQQ IL:ROOMS-NOTESCOMS ((FILE-ENVIRONMENTS IL:ROOMS-NOTES) (IL:P (EXPORT '(*DEFAULT-NOTE-WINDOW-FONT* MAKE-NOTE-WINDOW)) (REQUIRE "ROOMS")) (IL:* IL:|;;| "provides note windows") (IL:STRUCTURES NOTE) (IL:VARIABLES *DEFAULT-NOTE-WINDOW-FONT*) (IL:FUNCTIONS MAKE-NOTE-WINDOW NOTE-WINDOW-REPAINTFN PRINT-NOTE-STRING NOTE-WINDOW-BUTTONEVENTFN EDIT-NOTE-WINDOW-TEXT SET-NOTE-WINDOW-FONT SET-NOTE-WINDOW-TITLE) (IL:WINDOW-TYPES :NOTE-WINDOW) (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:P (OR (IL:HASDEF 'STREAM 'IL:RECORDS) (IL:EVAL (IL:SYSRECLOOK1 'STREAM))))) (IL:GLOBALVARS IL:BOLDFONT))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-NOTES :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(*DEFAULT-NOTE-WINDOW-FONT* MAKE-NOTE-WINDOW)) (REQUIRE "ROOMS") (IL:* IL:|;;| "provides note windows") (DEFSTRUCT NOTE (IL:* IL:|;;;| "a note for display in a note-window") (STRING "" :TYPE STRING) (FONT NIL :TYPE FONT) (TITLE "Note:" :TYPE STRING) (READ-ONLY? NIL :TYPE (MEMBER T NIL))) (DEFVAR *DEFAULT-NOTE-WINDOW-FONT* IL:BOLDFONT) (DEFUN MAKE-NOTE-WINDOW (&KEY REGION (TITLE "Note:") (STRING "") (FONT *DEFAULT-NOTE-WINDOW-FONT*) (READ-ONLY? NIL)) (LET ((WINDOW (IL:CREATEW REGION TITLE))) (IL:WINDOWPROP WINDOW 'NOTE (MAKE-NOTE :STRING STRING :FONT (IF (SYMBOLP FONT) FONT (IL:FONTCREATE FONT)) :TITLE TITLE :READ-ONLY? READ-ONLY?)) (IL:WINDOWPROP WINDOW 'IL:REPAINTFN 'NOTE-WINDOW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'NOTE-WINDOW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'NOTE-WINDOW-BUTTONEVENTFN) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'NOTE-WINDOW-BUTTONEVENTFN) (NOTE-WINDOW-REPAINTFN WINDOW) WINDOW)) (DEFUN NOTE-WINDOW-REPAINTFN (WINDOW &REST IGNORE) (LET* ((NOTE (IL:WINDOWPROP WINDOW 'NOTE)) (DSP (IL:GETSTREAM WINDOW)) (FONT (NOTE-FONT NOTE))) (IL:WINDOWPROP WINDOW 'IL:TITLE (NOTE-TITLE NOTE)) (IL:DSPFONT (IF (SYMBOLP FONT) (SYMBOL-VALUE FONT) FONT) DSP) (IL:CLEARW WINDOW) (IL:* IL:|;;| "why 8? that's what TEdit uses.") (PRINT-NOTE-STRING (NOTE-STRING NOTE) DSP 8 (- (IL:WINDOWPROP WINDOW 'IL:WIDTH) 8)))) (DEFUN PRINT-NOTE-STRING (STRING DSP LEFT-MARGIN RIGHT-MARGIN &OPTIONAL (LINE-LEADING 0)) (IL:* IL:|;;;| "print STRING to DSP within LEFT-MARGIN & RIGHT-MARGIN, breaking lines at spaces. I shouldn't have to write this, so it's ok if the code is ugly, right?") (CHECK-TYPE DSP (SATISFIES IL:DISPLAYSTREAMP)) (PROG* ((CHAR) (FONT (IL:DSPFONT NIL DSP)) (LINE-HEIGHT (+ (IL:FONTHEIGHT FONT) LINE-LEADING)) (LENGTH (VECTOR-LENGTH STRING)) (DD (IL:FETCH (STREAM IL:IMAGEDATA) IL:OF DSP)) (LAST-SPACE 0) (IL:* IL:\;  "offset in string where we'll break") (LINE-START 0) (IL:* IL:\;  "offset into string where this line starts") (I -1) (IL:* IL:\;  "current offset into string") (X LEFT-MARGIN) (IL:* IL:\;  "x position of char at I in pixels") (X-AT-LAST-SPACE LEFT-MARGIN) (IL:* IL:\;  "x position of char at LAST-SPACE in pixels") ) (IL:MOVETO LEFT-MARGIN (- (IL:DSPYPOSITION NIL DSP) LINE-LEADING) DSP) LOOP (INCF I) (WHEN (>= I LENGTH) (SETQ LAST-SPACE LENGTH) (GO DUMP-LINE)) (SETQ CHAR (AREF STRING I)) (CASE CHAR (#\Space (DO ((N (1+ I) (1+ N))) (IL:* IL:|;;| "skip through multiple spaces without checking for line breaks so that line breaks are always forced after a group of spaces") ((OR (= N LENGTH) (NOT (EQL (AREF STRING N) #\Space)))) (INCF I) (INCF X (IL:CHARWIDTH (CHAR-CODE #\Space) FONT))) (SETQ LAST-SPACE I) (SETQ X-AT-LAST-SPACE X)) (#\Newline (IL:* IL:\; "force line break") (SETQ LAST-SPACE I) (SETQ X-AT-LAST-SPACE X) (GO DUMP-LINE))) (INCF X (IL:CHARWIDTH (CHAR-CODE CHAR) FONT)) (WHEN (> X RIGHT-MARGIN) (IL:* IL:|;;| "check if line needs breaking") (WHEN (AND (<= LAST-SPACE LINE-START)) (IL:* IL:|;;| "if we've had no spaces on this line, just break it where we are. we actually lose a character here, as DUMP-LINE always skips the character we're on, presuming it's a space or CR.") (SETQ LAST-SPACE I) (SETQ X-AT-LAST-SPACE X)) (GO DUMP-LINE)) (GO LOOP) DUMP-LINE (IL:* IL:|;;| "dump chars from LINE-START up to (but not including) LAST-SPACE.") (DO ((N LINE-START (1+ N))) ((OR (= N LAST-SPACE) (= N LENGTH)) (IL:* IL:|;;| "move to the next line") (IL:MOVETO LEFT-MARGIN (- (IL:DSPYPOSITION NIL DSP) LINE-HEIGHT) DSP) (IL:* IL:|;;| "adjust X & LINE-START") (SETQ X (+ LEFT-MARGIN (- X X-AT-LAST-SPACE))) (SETQ LINE-START (1+ LAST-SPACE))) (IL:* IL:|;;| "this is soooo much faster than calling WRITE-CHAR. the down side is that this code will now only work on display streams.") (IL:\\BLTCHAR (CHAR-CODE (AREF STRING N)) DSP DD)) (IF (>= I LENGTH) (RETURN) (GO LOOP)))) (DEFUN NOTE-WINDOW-BUTTONEVENTFN (WINDOW) (IL:TOTOPW WINDOW) (WHEN (AND (IL:MOUSESTATE (IL:ONLY IL:MIDDLE)) (NOT (NOTE-READ-ONLY? (IL:WINDOWPROP WINDOW 'NOTE)))) (CASE (MENU '(("Edit Text" :EDIT "Edit the text of this note window with TEdit.") ("Set Font" :FONT "Set the font of this note window.") ("Set Title" :TITLE "Set the title of this note window."))) (:EDIT (IL:ADD.PROCESS `(EDIT-NOTE-WINDOW-TEXT ',WINDOW))) (:FONT (IL:ADD.PROCESS `(SET-NOTE-WINDOW-FONT ',WINDOW))) (:TITLE (IL:ADD.PROCESS `(SET-NOTE-WINDOW-TITLE ',WINDOW)))))) (DEFUN EDIT-NOTE-WINDOW-TEXT (WINDOW) (LET ((NOTE (IL:WINDOWPROP WINDOW 'NOTE))) (IF (FBOUNDP 'IL:TEDIT) (LET ((TEXT-STREAM (IL:OPENTEXTSTREAM (NOTE-STRING NOTE) NIL NIL NIL `(IL:FONT ,(NOTE-FONT NOTE) IL:NOTITLE T IL:PROMPTWINDOW ,IL:PROMPTWINDOW IL:MENU (IL:|Find| IL:|Substitute| IL:|Quit|) IL:QUITFN ,#'(LAMBDA (WINDOW STREAM TEXTOBJ IL:PROPS) (IL:|replace| IL:EDITFINISHEDFLG IL:|of| TEXTOBJ IL:|with| T) 'IL:DON\'T) IL:AFTERQUITFN ,#'(LAMBDA (WINDOW STREAM) (IL:OPENW WINDOW)))))) (IL:TTY.PROCESS (IL:THIS.PROCESS)) (SETF (NOTE-STRING NOTE) (IL:TEDIT TEXT-STREAM WINDOW T)) (IL:BLOCK 200) (IL:WINDOWPROP WINDOW 'IL:REPAINTFN 'NOTE-WINDOW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'NOTE-WINDOW-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'NOTE-WINDOW-BUTTONEVENTFN) (NOTE-WINDOW-REPAINTFN WINDOW))))) (DEFUN SET-NOTE-WINDOW-FONT (WINDOW) (LET* ((NOTE (IL:WINDOWPROP WINDOW 'NOTE)) (OLD-FONT (NOTE-FONT NOTE)) (NEW-FONT (SEDIT::SEDITE (IF (SYMBOLP OLD-FONT) OLD-FONT (EXTERNALIZE-FONT OLD-FONT)) NIL NIL NIL NIL '(:CLOSE-ON-COMPLETION)))) (SETF (NOTE-FONT NOTE) (IF (SYMBOLP NEW-FONT) NEW-FONT (IL:FONTCREATE NEW-FONT))) (NOTE-WINDOW-REPAINTFN WINDOW))) (DEFUN SET-NOTE-WINDOW-TITLE (WINDOW) (LET* ((NOTE (IL:WINDOWPROP WINDOW 'NOTE)) (TITLE (PROMPT-USER "Title:" "Type title (CR to abort)"))) (WHEN TITLE (SETF (NOTE-TITLE NOTE) TITLE) (NOTE-WINDOW-REPAINTFN WINDOW)))) (DEF-WINDOW-TYPE :NOTE-WINDOW :RECOGNIZER (LAMBDA (WINDOW) (NOTE-P (IL:WINDOWPROP WINDOW 'NOTE))) :ABSTRACTER (LAMBDA (WINDOW) (LET* ((NOTE (IL:WINDOWPROP WINDOW 'NOTE)) (FONT (NOTE-FONT NOTE))) `(:REGION ,(EXTERNALIZE-REGION (WINDOW-REGION WINDOW)) :TITLE ,(NOTE-TITLE NOTE) :STRING ,(NOTE-STRING NOTE) :FONT ,(IF (SYMBOLP FONT) FONT (EXTERNALIZE-FONT FONT)) :READ-ONLY? ,(NOTE-READ-ONLY? NOTE)))) :RECONSTITUTER (LAMBDA (ARGS) (LET ((REST (COPY-LIST ARGS))) (REMF REST :REGION) (APPLY #'MAKE-NOTE-WINDOW :REGION (INTERNALIZE-REGION (GETF ARGS :REGION '(0 0 100 100))) REST))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (LET ((NOTE (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'NOTE))) (PRINT-PEP-TITLE-STRING (IF (AND NOTE (NOTE-TITLE NOTE)) (STRING (NOTE-TITLE NOTE)) "Note:") REGION DSP :NO-TITLE-BAR? (PLACEMENT-SHRUNKEN? PLACEMENT))))) (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (OR (IL:HASDEF 'STREAM 'IL:RECORDS) (IL:EVAL (IL:SYSRECLOOK1 'STREAM))) ) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:BOLDFONT) ) (IL:PUTPROPS IL:ROOMS-NOTES IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1804 2758 (MAKE-NOTE-WINDOW 1804 . 2758)) (2760 3362 (NOTE-WINDOW-REPAINTFN 2760 . 3362)) (3364 7501 (PRINT-NOTE-STRING 3364 . 7501)) (7503 8159 (NOTE-WINDOW-BUTTONEVENTFN 7503 . 8159)) (8161 9742 (EDIT-NOTE-WINDOW-TEXT 8161 . 9742)) (9744 10302 (SET-NOTE-WINDOW-FONT 9744 . 10302)) ( 10304 10595 (SET-NOTE-WINDOW-TITLE 10304 . 10595))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-NOTES.DFASL b/rooms/ROOMS-NOTES.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..1e270bf29763fb5f6a9be7e953eba4d5b123f816 GIT binary patch literal 7999 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 literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-OVERVIEW b/rooms/ROOMS-OVERVIEW new file mode 100644 index 00000000..c4d49fa1 --- /dev/null +++ b/rooms/ROOMS-OVERVIEW @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:35:56"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-OVERVIEW.;2| 20426 IL:|previous| IL:|date:| "17-Aug-90 13:23:15" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-OVERVIEW.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-OVERVIEWCOMS) (IL:RPAQQ IL:ROOMS-OVERVIEWCOMS ((FILE-ENVIRONMENTS IL:ROOMS-OVERVIEW) (IL:P (EXPORT '(RESET-OVERVIEW ROOM-UNWIND-SAVE) "ROOMS") (REQUIRE "ROOMS")) (IL:COMS (IL:* IL:\; "the room") (IL:VARIABLES *OVERVIEW-ROOM*) (IL:FUNCTIONS GO-TO-OVERVIEW OV-ENTRY-FN OV-EXIT-FN OV-ROOM-CHANGED-FN OV-SUITE-BODY)) (IL:COMS (IL:* IL:\; "tiling code") (IL:VARIABLES *OV-BORDER-SIZE*) (IL:FUNCTIONS OV-LAYOUT-PLACEMENT-EDITORS OV-ROWS&COLUMNS)) (IL:COMS (IL:* IL:\; "buttons") (IL:VARIABLES *OV-BUTTONS* *OV-SELECTED-BUTTON-WINDOW* *OV-CHANGED?*) (IL:FUNCTIONS MAKE-OV-KEYACTION-TABLE OV-WATCH-KEYBOARD OV-SELECT-BUTTON OV-DESELECT-BUTTON OV-OPERATION) (IL:VARIABLES *OV-KEYACTION-TABLE*)) (IL:FUNCTIONS RESET-OVERVIEW) (IL:COMS (IL:VARIABLES *ROOM-UNWINDERS*) (IL:FUNCTIONS ROOM-UNWIND-SAVE ROOM-UNWIND) (EVAL-WHEN (LOAD) (IL:P (PUSHNEW '(RESET-OVERVIEW) *RESET-FORMS* :TEST 'EQUAL) (PUSHNEW 'RESET-OVERVIEW *SCREEN-CHANGED-FUNCTIONS*) (PUSHNEW 'ROOM-UNWIND *ROOM-EXIT-FUNCTIONS*) (PUSHNEW 'OV-ROOM-CHANGED-FN *ROOM-CHANGED-FUNCTIONS*)))))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-OVERVIEW :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(RESET-OVERVIEW ROOM-UNWIND-SAVE) "ROOMS") (REQUIRE "ROOMS") (IL:* IL:\; "the room") (DEFGLOBALVAR *OVERVIEW-ROOM* NIL) (DEFUN GO-TO-OVERVIEW () (GO-TO-ROOM *OVERVIEW-ROOM*)) (DEFUN OV-ENTRY-FN (OVERVIEW-ROOM) (IL:* IL:|;;|  "the entry function of the overview room. called whenever we enter the overview room.") (LET ((KEYBOARD-WATCHER (IL:ADD.PROCESS '(OV-WATCH-KEYBOARD) 'IL:KEYACTION *OV-KEYACTION-TABLE* 'IL:RESTARTABLE T))) (IL:* IL:|;;| "add the keyboard watcher") (ROOM-UNWIND-SAVE (IL:* IL:|;;| "make sure it will get deleted when we exit") (IL:DEL.PROCESS KEYBOARD-WATCHER T)) (IL:* IL:|;;| "make sure it will have the TTY when we enter the overview") (SETF (ROOM-TTY-PROCESS OVERVIEW-ROOM) KEYBOARD-WATCHER)) (IL:* IL:|;;| "place a PE for each room") (OV-LAYOUT-PLACEMENT-EDITORS (ALL-ROOMS T) (INTERNALIZE-REGION (MAKE-REGION :LEFT 0 :BOTTOM 1/4 :WIDTH 1.0 :HEIGHT 3/4))) (IL:* IL:|;;| "make sure PE's don't get placed again") (SETF (ROOM-PLACEMENTS OVERVIEW-ROOM) (WITH-COLLECTION (DOLIST (PLACEMENT (ROOM-PLACEMENTS OVERVIEW-ROOM)) (UNLESS (PLACEMENT-EDITOR-P (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) :PLACEMENT-EDITOR)) (COLLECT PLACEMENT))))) (IL:* IL:|;;| "select GO-TO button initially") (OV-SELECT-BUTTON (GETHASH :ENTER *OV-BUTTONS*))) (DEFUN OV-EXIT-FN (OVERVIEW-ROOM) (WHEN *OV-SELECTED-BUTTON-WINDOW* (OV-DESELECT-BUTTON *OV-SELECTED-BUTTON-WINDOW*))) (DEFUN OV-ROOM-CHANGED-FN (ROOM REASON) (IL:* IL:|;;| "called whenever a room is changed") (WHEN (AND (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (NOT (EQ ROOM *OVERVIEW-ROOM*))) (IL:* IL:|;;| "when we're in the overview") (CASE REASON ((:CREATED :DELETED) (IL:* IL:|;;| "have to re-layout placement editors") (MAPHASH #'(LAMBDA (NAME PE) (WHEN (IL:OPENWP (PE-WINDOW PE)) (IL:CLOSEW (PE-WINDOW PE)))) *PLACEMENT-EDITORS*) (IL:* IL:|;;| "hack: signal OV-WATCH-KEYBOARD process that re-layout is required. this makes multiple deletes & adds appear as one event.") (SETQ *OV-CHANGED?* T))))) (DEFUN OV-SUITE-BODY () `((:VERSION 0) (:WINDOW :SPACE-BAR :TYPE :BUTTON :TEXT ,(LET ((FILLER (MAKE-STRING (- (FLOOR (/ IL:SCREENWIDTH (* (IL:CHARWIDTH (CHAR-CODE #\Space) *DEFAULT-TEXT-FONT*) 6))) 4) :INITIAL-ELEMENT #\Space))) (CONCATENATE 'STRING FILLER "GO TO" FILLER)) :SHADOWS :ARK :TYPE :STRETCHY-ARK :HELP "GO TO mode - selected rooms will be entered" :ACTION OV-SELECT-BUTTON :OV-BUTTON :ENTER :PROTECTED? T) (:WINDOW :EDIT :TYPE :BUTTON :TEXT "EDIT" :SHADOWS :ARK :TYPE :ARK :HELP "EDIT mode - selected rooms will be edited" :ACTION OV-SELECT-BUTTON :OV-BUTTON :EDIT :PROTECTED? T) (:WINDOW :EXPAND :TYPE :BUTTON :TEXT "EXPAND" :SHADOWS :ARK :TYPE :ARK :HELP "EDIT mode - selected rooms will be edited" :ACTION OV-SELECT-BUTTON :OV-BUTTON :EXPAND :PROTECTED? T) (:WINDOW :MOVE :TYPE :BUTTON :TEXT "MOVE" :SHADOWS :ARK :TYPE :ARK :HELP "MOVE mode - selected placements will be moved, rooms renamed" :ACTION OV-SELECT-BUTTON :OV-BUTTON :MOVE :PROTECTED? T) (:WINDOW :COPY :TYPE :BUTTON :TEXT "COPY" :SHADOWS :ARK :TYPE :ARK :HELP "COPY mode - selected rooms & placements will be copied" :ACTION OV-SELECT-BUTTON :OV-BUTTON :COPY :PROTECTED? T) (:WINDOW :DELETE :TYPE :BUTTON :TEXT "DELETE" :SHADOWS :ARK :TYPE :ARK :HELP "DELETE mode - selected rooms & placements will be deleted" :ACTION OV-SELECT-BUTTON :OV-BUTTON :DELETE :PROTECTED? T) (:WINDOW :PROMPT-WINDOW :TYPE :PROMPT-WINDOW) (:ROOM "Overview" :PLACEMENTS ((:PROMPT-WINDOW :REGION (0 3/16 1.0 1/16) :BORDER 0 :SHADE 65535 :OPERATION IL:INVERT :TITLE NIL :FONT (IL:HELVETICA 12 (IL:BOLD IL:REGULAR IL:REGULAR))) (:SPACE-BAR :REGION (1/3 1/60 100 100)) (:EXPAND :REGION (7/8 1/60 100 100)) ,@(CASE (IL:MACHINETYPE) (IL:MAIKO '((:DELETE :REGION (26 1/60 100 100)) (:COPY :REGION (26 1/20 100 100)) (:MOVE :REGION (26 1/12 100 100)) (:EDIT :REGION (125 1/20 100 100)))) (T '((:EDIT :REGION (1/40 1/60 100 100)) (:MOVE :REGION (1/40 1/20 100 100)) (:COPY :REGION (1/40 1/12 100 100)) (:DELETE :REGION (1/40 7/60 100 100)))))) :INCLUSIONS T :BACKGROUND ((:WHOLE-SCREEN 25500 :BORDER 2) (:REGION (0 0 1.0 3/16) :SHADE 31710 :BORDER 2) (:TEXT "Rooms Overview" :POSITION (0.5 . 1/8) :ALIGNMENT :CENTER) (:TEXT "TM" :POSITION (0.47 . 1/7) :ALIGNMENT :CENTER :FONT (:EVAL IL:BIGFONT)) (:TEXT "Copyright (c) Envos Corporations, 1988; Patent Pending" :POSITION (0.5 . 5/64) :ALIGNMENT :CENTER :FONT (:EVAL IL:BIGFONT))) :BEFORE-ENTRY-FUNCTIONS (OV-ENTRY-FN) :BEFORE-EXIT-FUNCTIONS (OV-EXIT-FN)))) (IL:* IL:\; "tiling code") (DEFGLOBALPARAMETER *OV-BORDER-SIZE* 10) (DEFUN OV-LAYOUT-PLACEMENT-EDITORS (ROOMS CONTAINING-REGION) (IL:* IL:|;;| "layout placement editors for ROOMS in rows & columns within SCREEN-REGION, attempting to use screen space as best as possible") (WHEN ROOMS (LET* ((N-ROOMS (LENGTH ROOMS)) (TITLE-FONT-HEIGHT (IL:FONTHEIGHT *PE-TITLE-FONT*)) (TITLE-HEIGHT (IL:* IL:|;;| "height of title including shadows") (+ TITLE-FONT-HEIGHT 1 (CEILING TITLE-FONT-HEIGHT *TEXT-SHADOW-FACTOR*)))) (MULTIPLE-VALUE-BIND (ROWS COLUMNS TILE-WIDTH TILE-HEIGHT SCALE) (OV-ROWS&COLUMNS N-ROOMS (REGION-WIDTH CONTAINING-REGION) (REGION-HEIGHT CONTAINING-REGION) *OV-BORDER-SIZE* TITLE-HEIGHT) (LET* ((WIDTH (FLOOR (* IL:SCREENWIDTH SCALE))) (HEIGHT (FLOOR (* IL:SCREENHEIGHT SCALE))) (X-OFFSET (+ (REGION-LEFT CONTAINING-REGION) *OV-BORDER-SIZE* (IL:* IL:|;;| "center within borders") (FLOOR (- TILE-WIDTH WIDTH) 2))) (Y-OFFSET (+ (REGION-BOTTOM CONTAINING-REGION) *OV-BORDER-SIZE* (IL:* IL:|;;| "center within borders") (FLOOR (- TILE-HEIGHT HEIGHT) 2)))) (DO* ((ROOMS ROOMS (REST ROOMS)) (ROOM (FIRST ROOMS) (FIRST ROOMS)) (COLUMN 0 (MOD (1+ COLUMN) COLUMNS)) (ROW (1- ROWS) (IF (= COLUMN 0) (1- ROW) ROW))) ((ENDP ROOMS)) (GET-PE (ROOM-NAME ROOM) (MAKE-REGION :LEFT (+ (* COLUMN TILE-WIDTH) (* COLUMN *OV-BORDER-SIZE*) X-OFFSET) :BOTTOM (+ (* ROW TILE-HEIGHT) (* ROW TITLE-HEIGHT) Y-OFFSET) :WIDTH WIDTH :HEIGHT (+ HEIGHT TITLE-HEIGHT))))))))) (DEFUN OV-ROWS&COLUMNS (N WIDTH HEIGHT BORDER TITLE-HEIGHT) (IL:* IL:|;;;| "compute the optimal (in terms of use of screen space) tiling for n tiles within WIDTH & HEIGHT with the constraint that each tile must preserve the screen aspect ratio. ") (IL:* IL:|;;;| "returns 5 values: 1. the number of rows; 2; the number of columns; 3. the tile width; 4. the tile height and 5. the scale factor to use. ") (LET ((ROWS 0) (MAX-SCALE 0) TILE-WIDTH-AT-MAX-SCALE TILE-HEIGHT-AT-MAX-SCALE) (LOOP (IL:* IL:|;;| "go through each possible tiling & maximize the scale we'd have to use at that tiling. with a little algebra we could probably find a formula which directly gave us this maximum, but this code is plenty fast & easy to understand, so why bother?") (INCF ROWS) (LET* ((COLUMNS (CEILING N ROWS)) (IL:* IL:|;;|  "there's one more border than rows & columns, but the same number of titles as rows.") (X-BORDERS (* (1+ COLUMNS) BORDER)) (Y-BORDERS (+ BORDER (* ROWS TITLE-HEIGHT) BORDER)) (IL:* IL:|;;| "subtract off the borders from the available space") (USEFUL-WIDTH (- WIDTH X-BORDERS)) (USEFUL-HEIGHT (- HEIGHT Y-BORDERS)) (IL:* IL:|;;| "divide up the useful space") (TILE-WIDTH (/ USEFUL-WIDTH COLUMNS)) (TILE-HEIGHT (/ USEFUL-HEIGHT ROWS)) (IL:* IL:|;;| "calculate the scale w.r.t the screen dimensions") (X-SCALE (/ TILE-WIDTH IL:SCREENWIDTH)) (Y-SCALE (/ TILE-HEIGHT IL:SCREENHEIGHT)) (IL:* IL:|;;| "in order to preserve aspect ratio the X & Y scales must be the same. we must chose the lesser so we stay within the tile. we'll center within the tile when we actually lay things out. ") (SCALE (MIN X-SCALE Y-SCALE))) (IL:* IL:|;;| "scale will smoothly increase until it reaches it maximum value, then decrease. we return the previous value as soon as it begins to decrease. ") (WHEN (< SCALE MAX-SCALE) (RETURN (VALUES (1- ROWS) (CEILING N (1- ROWS)) (FLOOR TILE-WIDTH-AT-MAX-SCALE) (FLOOR TILE-HEIGHT-AT-MAX-SCALE) MAX-SCALE))) (SETF MAX-SCALE SCALE) (SETF TILE-WIDTH-AT-MAX-SCALE TILE-WIDTH) (SETF TILE-HEIGHT-AT-MAX-SCALE TILE-HEIGHT))))) (IL:* IL:\; "buttons") (DEFGLOBALVAR *OV-BUTTONS* (MAKE-HASH-TABLE :TEST 'EQ)) (DEFGLOBALVAR *OV-SELECTED-BUTTON-WINDOW* NIL) (DEFGLOBALVAR *OV-CHANGED?* NIL) (DEFUN MAKE-OV-KEYACTION-TABLE () (IL:* IL:|;;;| "make keyaction table for overview") (IL:* IL:|;;| "want to get users' mods to shift, ctrl & meta, but don't want users' interrupts") (LET ((TABLE (IL:KEYACTIONTABLE IL:\\DEFAULTKEYACTION))) (DECLARE (GLOBAL IL:\\DEFAULTKEYACTION)) (IL:* IL:|;;| "install default interrupts") (IL:INTERRUPTCHAR T NIL NIL TABLE) (IL:* IL:|;;| "we need delete key & don't care about type ahead, so remove delete interrupt so screen doesn't flash") (IL:INTERRUPTCHAR (CHAR-CODE #\Rubout) NIL NIL TABLE) TABLE)) (DEFUN OV-WATCH-KEYBOARD () (IL:* IL:|;;;| "added as process when in overview.") (LOOP (IL:* IL:|;;| "watch the keyboard") (LET* ((KEY (COND ((EDIT-KEY-DOWN-P) :EDIT) ((MOVE-KEY-DOWN-P) :MOVE) ((COPY-KEY-DOWN-P) :COPY) ((DELETE-KEY-DOWN-P) :DELETE) ((EXPAND-KEY-DOWN-P) :EXPAND) ((IL:KEYDOWNP 'IL:SPACE) :ENTER)))) (WHEN KEY (LET ((BUTTON-WINDOW (GETHASH KEY *OV-BUTTONS*))) (UNLESS (EQ BUTTON-WINDOW *OV-SELECTED-BUTTON-WINDOW*) (IL:* IL:|;;| "select the button") (OV-SELECT-BUTTON BUTTON-WINDOW :REDISPLAY T))))) (IL:* IL:|;;| "watch for room creation/deletion signal. this flag is set by OV-ROOM-CHANGED-FN. doing this in a separate process makes DELETE-SUITE only re-layout once. this hack depends upon non-preemptive scheduling. ") (WHEN *OV-CHANGED?* (IL:* IL:|;;| "have to re-layout placement editors") (SETQ *OV-CHANGED?* NIL) (OV-LAYOUT-PLACEMENT-EDITORS (ALL-ROOMS T) (INTERNALIZE-REGION (MAKE-REGION :LEFT 0 :BOTTOM 1/4 :WIDTH 1.0 :HEIGHT 3/4)))) (IL:* IL:|;;| "clear any type ahead") (IL:\\CLEARSYSBUF) (IL:* IL:|;;| "don't want to cycle too fast, else chords won't be sticky") (IL:BLOCK 50))) (DEFUN OV-SELECT-BUTTON (WINDOW) (DECLARE (IGNORE REST)) (IL:* IL:|;;;| "called when one of the overview buttons is selected") (UNLESS (EQ WINDOW *OV-SELECTED-BUTTON-WINDOW*) (WHEN *OV-SELECTED-BUTTON-WINDOW* (IL:* IL:|;;| "first unselect the previously selected button ") (OV-DESELECT-BUTTON *OV-SELECTED-BUTTON-WINDOW*)) (IL:* IL:|;;| "mark us as the selected button") (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (SETQ *OV-SELECTED-BUTTON-WINDOW* WINDOW) (SETF (BUTTON-INVERTED? BUTTON) T) (IL:REDISPLAYW WINDOW)))) (DEFUN OV-DESELECT-BUTTON (WINDOW) (LET ((BUTTON (IL:WINDOWPROP WINDOW 'BUTTON))) (SETF (BUTTON-INVERTED? BUTTON) NIL) (SETQ *OV-SELECTED-BUTTON-WINDOW* NIL) (IL:REDISPLAYW WINDOW))) (DEFUN OV-OPERATION () (IL:* IL:|;;;| "call this to find out what key is down in the overview") (AND *OV-SELECTED-BUTTON-WINDOW* (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (BUTTON-PROP (IL:WINDOWPROP *OV-SELECTED-BUTTON-WINDOW* 'BUTTON) :OV-BUTTON))) (DEFGLOBALPARAMETER *OV-KEYACTION-TABLE*) (DEFUN RESET-OVERVIEW () (SETQ *OV-KEYACTION-TABLE* (MAKE-OV-KEYACTION-TABLE)) (WHEN *OVERVIEW-ROOM* (IL:* IL:|;;| "clean up existing overview") (DELETE-ROOM *OVERVIEW-ROOM*)) (LET ((ROOM-NAMED-OVERVIEW (ROOM-NAMED "Overview"))) (IL:* IL:|;;| "make an un-named room from the description in *OVERVIEW-SUITE-BODY*") (UNWIND-PROTECT (PROGN (INSTALL-SUITE-BODY (COPY-TREE (OV-SUITE-BODY))) (SETQ *OVERVIEW-ROOM* (ROOM-NAMED "Overview"))) (IF ROOM-NAMED-OVERVIEW (SETF (ROOM-NAMED "Overview") ROOM-NAMED-OVERVIEW) (REMHASH "Overview" *ROOMS*))) (WHEN (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (IL:* IL:|;;| "re-tile Overview to get rid of pe for Overview") (OV-ROOM-CHANGED-FN NIL :DELETED)) (DOLIST (PLACEMENT (ROOM-PLACEMENTS *OVERVIEW-ROOM*)) (LET ((BUTTON (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) 'BUTTON))) (WHEN BUTTON (IL:* IL:|;;| "save pointers to buttons in *OV-BUTTONS*") (SETF (GETHASH (BUTTON-PROP BUTTON :OV-BUTTON) *OV-BUTTONS*) (PLACEMENT-WINDOW PLACEMENT))))) *OVERVIEW-ROOM*)) (DEFGLOBALVAR *ROOM-UNWINDERS* NIL) (DEFMACRO ROOM-UNWIND-SAVE (&BODY BODY) `(PUSH #'(LAMBDA NIL ,@BODY) *ROOM-UNWINDERS*)) (DEFUN ROOM-UNWIND (ROOM) (DECLARE (IGNORE ROOM)) (DOLIST (UNWINDER (PROG1 *ROOM-UNWINDERS* (SETQ *ROOM-UNWINDERS* NIL))) (FUNCALL UNWINDER))) (EVAL-WHEN (LOAD) (PUSHNEW '(RESET-OVERVIEW) *RESET-FORMS* :TEST 'EQUAL) (PUSHNEW 'RESET-OVERVIEW *SCREEN-CHANGED-FUNCTIONS*) (PUSHNEW 'ROOM-UNWIND *ROOM-EXIT-FUNCTIONS*) (PUSHNEW 'OV-ROOM-CHANGED-FN *ROOM-CHANGED-FUNCTIONS*) ) (IL:PUTPROPS IL:ROOMS-OVERVIEW IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (2406 2467 (GO-TO-OVERVIEW 2406 . 2467)) (2469 3906 (OV-ENTRY-FN 2469 . 3906)) (3908 4037 (OV-EXIT-FN 3908 . 4037)) (4039 4839 (OV-ROOM-CHANGED-FN 4039 . 4839)) (4841 8919 (OV-SUITE-BODY 4841 . 8919)) (9002 11780 (OV-LAYOUT-PLACEMENT-EDITORS 9002 . 11780)) (11782 14626 (OV-ROWS&COLUMNS 11782 . 14626)) (14810 15449 (MAKE-OV-KEYACTION-TABLE 14810 . 15449)) (15451 17158 (OV-WATCH-KEYBOARD 15451 . 17158)) (17160 17813 (OV-SELECT-BUTTON 17160 . 17813)) (17815 18042 (OV-DESELECT-BUTTON 17815 . 18042)) (18044 18323 (OV-OPERATION 18044 . 18323)) (18372 19747 (RESET-OVERVIEW 18372 . 19747)) ( 19896 20059 (ROOM-UNWIND 19896 . 20059))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-OVERVIEW.DFASL b/rooms/ROOMS-OVERVIEW.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..8e9692842e8d4bd4c828939fa2da0e102f00ee6f GIT binary patch literal 10520 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 P!cT1!O4-#P-M;;QC&(IH literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-PLACEMENT-EDITOR b/rooms/ROOMS-PLACEMENT-EDITOR new file mode 100644 index 00000000..6767eb05 --- /dev/null +++ b/rooms/ROOMS-PLACEMENT-EDITOR @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:35:48"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-PLACEMENT-EDITOR.;2| 43072 IL:|previous| IL:|date:| "17-Aug-90 13:25:31" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-PLACEMENT-EDITOR.;1| ) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-PLACEMENT-EDITORCOMS) (IL:RPAQQ IL:ROOMS-PLACEMENT-EDITORCOMS ((FILE-ENVIRONMENTS IL:ROOMS-PLACEMENT-EDITOR) (IL:P (REQUIRE "ROOMS") (EXPORT '(GET-PE PRINT-PEP-TITLE-STRING) "ROOMS")) (IL:STRUCTURES PLACEMENT-EDITOR PE-PLACEMENT) (IL:VARIABLES *PLACEMENT-EDITORS* *PE-INHIBIT-REDISPLAY*) (IL:FUNCTIONS GET-PE MAKE-PE FIND-PE PE-WINDOW-P PE-CLOSEFN PE-REPAINTFN PE-RESHAPEFN PE-TOTOPFN UPDATE-PE? UPDATE-PE UPDATE-PEPS UPDATE-PEP-SAVE-BITMAP UPDATE-PE-WINDOW PLACED-REGION) (IL:COMS (IL:* IL:\; "display") (IL:VARIABLES *DEFAULT-ICON-SIZE* *PE-TITLE-FONT* *PEP-TITLE-FONT* *PEP-INCLUDED-SHADE* *PE-BORDER*) (IL:FUNCTIONS DISPLAY-PEPS SAVE-PEP-IMAGE DISPLAY-PE-TITLE DISPLAY-PE-BORDER DISPLAY-PEP PRINT-PEP-TITLE PRINT-PEP-TITLE-STRING) (IL:VARIABLES *DISPLAY-PE-DEPTH*) (IL:WINDOW-TYPES :PLACEMENT-EDITOR)) (IL:FUNCTIONS PE-RIGHTBUTTONFN (IL:* IL:\; "mouse trackers") PE-BUTTONEVENTFN PE-BUTTONEVENTFN-INTERNAL PE-TRACK-MOUSE PE-GETMOUSESTATE PE-TRACK-LEFT-BUTTON PE-TRACK-MIDDLE-BUTTON PEP-GETBOXPOSITION PEP-GETBOXPOSITION-INTERNAL) (IL:COMS (IL:* IL:\; "editing") (IL:FUNCTIONS PE-ROOM-CHANGED-FN PEP-SELECTED EXPAND-PLACEMENT PEP-SELECTED-COPY-OR-MOVE PE-ROOM-SELECTED) (EVAL-WHEN (LOAD) (IL:P (PUSHNEW 'PE-ROOM-CHANGED-FN *ROOM-CHANGED-FUNCTIONS*)))) (IL:GLOBALVARS IL:TINYFONT IL:CROSSHAIRS))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-PLACEMENT-EDITOR :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (REQUIRE "ROOMS") (EXPORT '(GET-PE PRINT-PEP-TITLE-STRING) "ROOMS") (DEFSTRUCT (PLACEMENT-EDITOR (:CONC-NAME "PE-") (:CONSTRUCTOR MAKE-PE-INTERNAL) (:PRINT-FUNCTION (LAMBDA (PE STREAM DEPTH) (FORMAT STREAM "#" (PE-ROOM-NAME PE))))) (CHANGED? T :TYPE (MEMBER T NIL :PLACEMENTS)) (ROOM-NAME NIL) (SCALE *ONE-TO-ONE* :TYPE SCALE) (PEPS NIL :TYPE LIST) (WINDOW NIL) (TITLE-TEXT NIL :TYPE TEXT) (CLIPPING-REGION NIL)) (DEFSTRUCT (PE-PLACEMENT (:CONC-NAME "PEP-") (:PRINT-FUNCTION (LAMBDA (PEP STREAM DEPTH) (FORMAT STREAM "#" (IL:\\HILOC PEP) (IL:\\LOLOC PEP))))) (PLACEMENT NIL :TYPE PLACEMENT) (SCALED-REGION NIL :TYPE REGION) (IMMEDIATE? NIL :TYPE (MEMBER T NIL)) (OPEN? NIL :TYPE (MEMBER T NIL)) (SAVE-BITMAP NIL) (UNSCALED-REGION NIL :TYPE REGION)) (DEFGLOBALVAR *PLACEMENT-EDITORS* (MAKE-HASH-TABLE :TEST 'EQUAL)) (DEFVAR *PE-INHIBIT-REDISPLAY* NIL) (DEFUN GET-PE (ROOM-NAME &OPTIONAL REGION) (IL:* IL:|;;;| "returns the PE for ROOM, creating one if required. if REGION is provided then the PE will occupy it.") (LET ((PE (FIND-PE ROOM-NAME))) (IF PE (IL:* IL:|;;|  "this code optimized so there is never more than one redisplay when entering overview") (LET* ((WINDOW (PE-WINDOW PE)) (ICON (WINDOW-ICON WINDOW)) SHAPED?) (IL:* IL:|;;| "this gets smashed when window closed") (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR PE) (LET ((*PE-INHIBIT-REDISPLAY* T)) (UN-HIDE-WINDOW WINDOW) (IL:OPENW WINDOW) (IL:TOTOPW WINDOW) (WHEN REGION (SHAPE-WINDOW WINDOW REGION))) (UPDATE-PE? PE) PE) (MAKE-PE ROOM-NAME REGION)))) (DEFUN MAKE-PE (ROOM-NAME &OPTIONAL REGION) (IL:* IL:|;;;| "don't call this. call GET-PE instead. we depend on there only being on PE per room.") (LET* ((WINDOW (IL:CREATEW REGION NIL 0)) (PE (MAKE-PE-INTERNAL :ROOM-NAME ROOM-NAME :WINDOW WINDOW :TITLE-TEXT (MAKE-TEXT :STRING (IF (STRINGP ROOM-NAME) ROOM-NAME (PRINC-TO-STRING ROOM-NAME)) :SHADOWS T :FONT *PE-TITLE-FONT*)))) (IL:WINDOWPROP WINDOW 'IL:CLOSEFN 'PE-CLOSEFN) (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR PE) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'PE-BUTTONEVENTFN) (IL:WINDOWPROP WINDOW 'IL:RIGHTBUTTONFN 'PE-RIGHTBUTTONFN) (IL:WINDOWPROP WINDOW 'IL:REPAINTFN 'PE-REPAINTFN) (IL:WINDOWPROP WINDOW 'IL:RESHAPEFN 'PE-RESHAPEFN) (IL:WINDOWPROP WINDOW 'IL:TOTOPFN 'PE-TOTOPFN) (IL:WINDOWPROP WINDOW 'IL:AFTERMOVEFN 'PE-TOTOPFN) (IL:WINDOWPROP WINDOW 'IL:OPENFN 'PE-TOTOPFN) (IL:DSPFONT *PEP-TITLE-FONT* WINDOW) (SETF (FIND-PE ROOM-NAME) PE) (IL:* IL:|;;| "update things") (UPDATE-PE-WINDOW PE) (UPDATE-PE PE) PE)) (DEFMACRO FIND-PE (ROOM-NAME) `(GETHASH ,ROOM-NAME *PLACEMENT-EDITORS*)) (DEFUN PE-WINDOW-P (WINDOW) (PLACEMENT-EDITOR-P (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (DEFUN PE-CLOSEFN (WINDOW) (IL:* IL:|;;| "remove circularity") (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR NIL)) (DEFUN PE-REPAINTFN (WINDOW &REST IGNORE) (LET ((PE (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (DISPLAY-PE-TITLE PE) (DISPLAY-PE-BORDER PE) (SETF (PE-CHANGED? PE) T) (UPDATE-PE PE))) (DEFUN PE-RESHAPEFN (WINDOW &REST IGNORE) (LET ((PE (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (UPDATE-PE-WINDOW PE) (SETF (PE-CHANGED? PE) T) (UNLESS *PE-INHIBIT-REDISPLAY* (UPDATE-PE PE)))) (DEFUN PE-TOTOPFN (WINDOW) (IL:TOTOPW WINDOW T) (LET ((PE (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (WHEN PE (DISPLAY-PE-TITLE PE) (UNLESS *PE-INHIBIT-REDISPLAY* (UPDATE-PE? PE))))) (DEFUN UPDATE-PE? (PE) (WHEN (PE-CHANGED? PE) (UPDATE-PE PE))) (DEFUN UPDATE-PE (PE) (IL:* IL:|;;;| "update PE per the current state of rooms") (LET ((*PE-INHIBIT-REDISPLAY* T) (IL:* IL:|;;| "don't want TOTOP to update too") (ROOM (ROOM-NAMED (PE-ROOM-NAME PE)))) (WHEN ROOM (LET ((DSP (IL:GETSTREAM (PE-WINDOW PE)))) (CASE (PE-CHANGED? PE) (:PLACEMENTS (IL:* IL:\; "incremental redisplay") (LET ((OLD-PEPS (PE-PEPS PE))) (UPDATE-PEPS PE OLD-PEPS) (DISPLAY-PEPS PE DSP OLD-PEPS))) (T (IL:* IL:\; "total redisplay") (UPDATE-PEPS PE) (PAINT-BACKGROUND ROOM DSP :SCALE (PE-SCALE PE) :NO-TEXT T :CLIPPING-REGION (PE-CLIPPING-REGION PE)) (DISPLAY-PEPS PE DSP))) (SETF (PE-CHANGED? PE) NIL))))) (DEFUN UPDATE-PEPS (PE &OPTIONAL OLD-PEPS) (IL:* IL:|;;| "build a new list of PEPs for PE.") (IL:* IL:|;;|  "the redisplay code depends upon us leaving EQ peps only when the placement hasn't changed.") (LET ((ROOM (ROOM-NAMED (PE-ROOM-NAME PE)))) (WHEN ROOM (LET ((IMMEDIATE-PLACEMENTS (ROOM-PLACEMENTS ROOM)) (SCALE (PE-SCALE PE))) (DO* ((ALL (FIND-PLACEMENTS ROOM)) (TAIL ALL (CDR TAIL))) ((NULL TAIL) (SETF (PE-PEPS PE) ALL)) (SETF (FIRST TAIL) (LET* ((PLACEMENT (FIRST TAIL)) (IMMEDIATE? (MEMBER PLACEMENT IMMEDIATE-PLACEMENTS :TEST 'EQ)) (SCALED-REGION (PLACED-REGION PLACEMENT))) (OR (DOLIST (PEP OLD-PEPS) (IL:* IL:|;;| "try to find an old PEP for placement") (WHEN (EQ (PEP-PLACEMENT PEP) PLACEMENT) (IL:* IL:|;;| "found it") (WHEN (EQ PEP (FIRST OLD-PEPS)) (IL:* IL:|;;| "speed future searches") (POP OLD-PEPS)) (RETURN (WHEN (AND (IF (PEP-IMMEDIATE? PEP) IMMEDIATE? (NOT IMMEDIATE?)) (EQUAL (PEP-UNSCALED-REGION PEP) SCALED-REGION)) (IL:* IL:\; "ok to use it") PEP)))) (UPDATE-PEP-SAVE-BITMAP (MAKE-PE-PLACEMENT :PLACEMENT PLACEMENT :IMMEDIATE? IMMEDIATE? :SCALED-REGION (SCALE-REGION SCALED-REGION SCALE) :UNSCALED-REGION SCALED-REGION)))) )))))) (DEFUN UPDATE-PEP-SAVE-BITMAP (PEP) (LET* ((SCALED-REGION (PEP-SCALED-REGION PEP)) (SAVE (IL:BITMAPCREATE (REGION-WIDTH SCALED-REGION) (REGION-HEIGHT SCALED-REGION))) (DSP (IL:LOADTIMECONSTANT (IL:DSPCREATE)))) (IL:DSPDESTINATION SAVE DSP) (IL:DSPXOFFSET (- (REGION-LEFT SCALED-REGION)) DSP) (IL:DSPYOFFSET (- (REGION-BOTTOM SCALED-REGION)) DSP) (DISPLAY-PEP PEP DSP) (SETF (PEP-SAVE-BITMAP PEP) SAVE) (SETF (PEP-OPEN? PEP) NIL) PEP)) (DEFUN UPDATE-PE-WINDOW (PE) (LET* ((WINDOW (PE-WINDOW PE)) (DSP (IL:GETSTREAM WINDOW)) (WINDOW-REGION (WINDOW-REGION WINDOW)) (WINDOW-HEIGHT (REGION-HEIGHT WINDOW-REGION)) (TEXT (PE-TITLE-TEXT PE)) (HEIGHT (- WINDOW-HEIGHT (TEXT-%HEIGHT TEXT))) (TWICE-BORDER (* *PE-BORDER* 2)) (CLIPPING-REGION (MAKE-REGION :LEFT *PE-BORDER* :BOTTOM *PE-BORDER* :WIDTH (- (REGION-WIDTH WINDOW-REGION) TWICE-BORDER) :HEIGHT (- HEIGHT TWICE-BORDER)))) (IL:* IL:|;;| "update scale & clipping region") (SETF (PE-CLIPPING-REGION PE) CLIPPING-REGION) (SETF (PE-SCALE PE) (MAKE-SCALE CLIPPING-REGION)) (SETF (TEXT-POSITION TEXT) (MAKE-POSITION *PE-BORDER* HEIGHT)) (DISPLAY-PE-TITLE PE) (DISPLAY-PE-BORDER PE))) (DEFUN PLACED-REGION (PLACEMENT) (IL:* IL:|;;;| "returns the region PLACEMENT would occupy on the screen. for non-shrunken placements this is just the PLACEMENT-REGION, but for shrunken placements we need to figure what the region of the icon would be.") (IF (PLACEMENT-SHRUNKEN? PLACEMENT) (LET* ((ICON-POSITION (PLACEMENT-ICON-POSITION PLACEMENT)) (ICON (WINDOW-ICON (PLACEMENT-WINDOW PLACEMENT))) (ICON-REGION (IF ICON (WINDOW-REGION ICON)))) (MAKE-REGION :LEFT (POSITION-X ICON-POSITION) :BOTTOM (POSITION-Y ICON-POSITION) :WIDTH (IF ICON (REGION-WIDTH ICON-REGION) *DEFAULT-ICON-SIZE*) :HEIGHT (IF ICON (REGION-HEIGHT ICON-REGION) *DEFAULT-ICON-SIZE*))) (PLACEMENT-REGION PLACEMENT))) (IL:* IL:\; "display") (DEFVAR *DEFAULT-ICON-SIZE* (IL:* IL:|;;;| "when we draw a placement for a non-existant icon, we draw it as a square with this many (scaled) pixels per side.") 75) (DEFGLOBALVAR *PE-TITLE-FONT* (IL:FONTCREATE 'IL:HELVETICA 36 '(IL:BOLD IL:REGULAR IL:REGULAR) NIL 'IL:DISPLAY)) (DEFGLOBALPARAMETER *PEP-TITLE-FONT* (IL:FONTCREATE IL:TINYFONT NIL NIL NIL 'IL:DISPLAY)) (DEFGLOBALPARAMETER *PEP-INCLUDED-SHADE* 4680) (DEFGLOBALPARAMETER *PE-BORDER* 4) (DEFUN DISPLAY-PEPS (PE DSP &OPTIONAL OLD-PEPS) (IL:* IL:|;;;| "displays PE on DSP. Should be called DISPLAY-PE-INTERNAL.") (LET ((OLD OLD-PEPS) (NEW (PE-PEPS PE))) (LOOP (IL:* IL:|;;| "pop off the EQ peps on the bottom of window stack") (WHEN (OR (NULL OLD) (NULL NEW) (NOT (EQ (FIRST OLD) (FIRST NEW)))) (RETURN)) (POP OLD) (POP NEW)) (IL:* IL:|;;| "remove image of remaining old peps") (DOLIST (PEP (REVERSE OLD)) (SAVE-PEP-IMAGE DSP PEP PE)) (IL:* IL:|;;| "display remaining new peps") (DOLIST (PEP NEW) (SAVE-PEP-IMAGE DSP PEP PE)))) (DEFUN SAVE-PEP-IMAGE (DSP PEP PE) (IL:* IL:|;;;| "switch contents of PEP's save & its region of DSP.") (LET* ((REGION (PEP-SCALED-REGION PEP)) (LEFT (POP REGION)) (BOTTOM (POP REGION)) (WIDTH (POP REGION)) (HEIGHT (POP REGION)) (CLIPPING (PE-CLIPPING-REGION PE)) (CLIPPING-LEFT (POP CLIPPING)) (CLIPPING-BOTTOM (POP CLIPPING)) (CLIPPING-WIDTH (POP CLIPPING)) (CLIPPING-HEIGHT (POP CLIPPING)) (SAVE (PEP-SAVE-BITMAP PEP))) (IL:UNINTERRUPTABLY (IL:BITBLT SAVE 0 0 DSP LEFT BOTTOM WIDTH HEIGHT 'IL:INPUT 'IL:INVERT NIL CLIPPING) (IL:BITBLT DSP (MAX LEFT CLIPPING-LEFT) (MAX BOTTOM CLIPPING-BOTTOM) SAVE 0 0 (MIN WIDTH (- (+ CLIPPING-WIDTH CLIPPING-LEFT) LEFT)) (MIN HEIGHT (- (+ CLIPPING-HEIGHT CLIPPING-BOTTOM) BOTTOM)) 'IL:INPUT 'IL:INVERT) (IL:BITBLT SAVE 0 0 DSP LEFT BOTTOM WIDTH HEIGHT 'IL:INPUT 'IL:INVERT NIL CLIPPING)) (SETF (PEP-OPEN? PEP) (NOT (PEP-OPEN? PEP))))) (DEFUN DISPLAY-PE-TITLE (PE) (LET* ((WINDOW (PE-WINDOW PE)) (WINDOW-REGION (WINDOW-REGION WINDOW)) (DSP (IL:GETSTREAM WINDOW)) (TEXT (PE-TITLE-TEXT PE)) (WINDOW-HEIGHT (REGION-HEIGHT WINDOW-REGION)) (BOTTOM (- WINDOW-HEIGHT (TEXT-%HEIGHT TEXT)))) (IL:* IL:|;;| "blt the background into the title bar") (IL:BITBLT (IL:WINDOWPROP WINDOW 'IL:IMAGECOVERED) 0 BOTTOM DSP 0 BOTTOM (REGION-WIDTH WINDOW-REGION) (- WINDOW-HEIGHT BOTTOM)) (IF (EQUAL (PE-ROOM-NAME PE) *BACK-DOOR-ROOM-NAME*) (IL:* IL:|;;| "the title of the back door room gets special shadows ") (WHEN (EQ (TEXT-SHADOWS TEXT) T) (SETF (TEXT-SHADOWS TEXT) (MAPLIST #'(LAMBDA (TAIL) (IF (REST TAIL) (FIRST TAIL) (IL:CONSTANT (MAKE-TEXT-SHADOW :SOURCE-TYPE 'IL:MERGE :TEXTURE 42405 :OPERATION 'IL:INVERT)))) (GET-TEXT-SHADOWS-INTERNAL *PE-TITLE-FONT*))) (UPDATE-TEXT-CACHES TEXT)) (UNLESS (EQ (TEXT-SHADOWS TEXT) T) (IL:* IL:|;;| "used to be back-door room") (SETF (TEXT-SHADOWS TEXT) T) (UPDATE-TEXT-CACHES TEXT))) (DISPLAY-TEXT TEXT DSP))) (DEFUN DISPLAY-PE-BORDER (PE) (LET* ((WINDOW (PE-WINDOW PE)) (WINDOW-REGION (WINDOW-REGION WINDOW))) (IL:* IL:|;;| "draw the window border & clear inside it") (DRAW&FILL-BOX-WITHIN (MAKE-REGION :LEFT 0 :BOTTOM 0 :WIDTH (REGION-WIDTH WINDOW-REGION) :HEIGHT (- (REGION-HEIGHT WINDOW-REGION) (TEXT-%HEIGHT (PE-TITLE-TEXT PE)))) (IL:GETSTREAM WINDOW) :BORDER-WIDTH (FLOOR *PE-BORDER* 2)))) (DEFUN DISPLAY-PEP (PEP DSP) (IL:* IL:|;;;| "displays a PE-PLACEMENT") (IL:* IL:|;;| "draw a box around the region & fill it if it represents an immediate placement in the room of this PEP.") (DRAW&FILL-BOX-WITHIN (PEP-SCALED-REGION PEP) DSP :BORDER-WIDTH 1 :SHADE (IF (PEP-IMMEDIATE? PEP) IL:WHITESHADE *PEP-INCLUDED-SHADE*)) (PRINT-PEP-TITLE PEP DSP)) (DEFUN PRINT-PEP-TITLE (PEP DSP) (IL:* IL:|;;| "print something within the box drawn for PEP on DSP ") (LET* ((WINDOW-TYPE (WINDOW-TYPE (PLACEMENT-WINDOW (PEP-PLACEMENT PEP)) T))) (WHEN WINDOW-TYPE (LET ((TITLE (WINDOW-TYPE-PROP WINDOW-TYPE :TITLE))) (IL:* IL:|;;|  "interpret the TITLE property of the window type of the placement this PEP represents") (COND ((NULL TITLE) (IL:* IL:|;;| "if none specified, just print the name of the type") (PRINT-PEP-TITLE-STRING (STRING (WINDOW-TYPE-NAME WINDOW-TYPE)) (PEP-SCALED-REGION PEP) DSP :NO-TITLE-BAR? (PLACEMENT-SHRUNKEN? (PEP-PLACEMENT PEP)))) ((STRINGP TITLE) (IL:* IL:|;;| "if it's a string, print it") (PRINT-PEP-TITLE-STRING TITLE (PEP-SCALED-REGION PEP) DSP :NO-TITLE-BAR? (PLACEMENT-SHRUNKEN? (PEP-PLACEMENT PEP)))) (T (IL:* IL:|;;| "otherwise assume it's a function & call it") (FUNCALL TITLE (PEP-PLACEMENT PEP) (PEP-SCALED-REGION PEP) DSP))))))) (DEFUN PRINT-PEP-TITLE-STRING (STRING REGION DSP &KEY (FONT *PEP-TITLE-FONT*) NO-TITLE-BAR?) (IL:* IL:|;;;| "prints STRING in the top left corner of REGION if it will fit.") (LET* ((STRING (IF (STRINGP STRING) STRING (PRINC-TO-STRING STRING))) (FONT-HEIGHT (IL:FONTHEIGHT FONT)) (TITLE-Y (- (+ (REGION-BOTTOM REGION) (REGION-HEIGHT REGION)) FONT-HEIGHT (IF NO-TITLE-BAR? 1 0))) (STRING-WIDTH (IL:STRINGWIDTH STRING FONT))) (WHEN (AND (< STRING-WIDTH (- (REGION-WIDTH REGION) 2)) (< FONT-HEIGHT (- (REGION-HEIGHT REGION) 2))) (UNLESS NO-TITLE-BAR? (IL:BLTSHADE IL:BLACKSHADE DSP (REGION-LEFT REGION) (1- TITLE-Y) (REGION-WIDTH REGION) FONT-HEIGHT 'IL:PAINT)) (IL:DSPOPERATION (IF NO-TITLE-BAR? 'IL:PAINT 'IL:INVERT) DSP) (IL:DSPFONT FONT DSP) (IL:MOVETO (+ (REGION-LEFT REGION) (IF NO-TITLE-BAR? (- (FLOOR (REGION-WIDTH REGION) 2) (FLOOR STRING-WIDTH 2)) 2)) (IF NO-TITLE-BAR? (+ (REGION-BOTTOM REGION) (- (FLOOR (REGION-HEIGHT REGION) 2) (FLOOR FONT-HEIGHT 2)) (IL:FONTDESCENT FONT)) (+ TITLE-Y (IL:FONTDESCENT FONT))) DSP) (CHECK-TYPE DSP STREAM) (IL:\\SOUT STRING DSP) (IL:DSPOPERATION 'IL:REPLACE DSP)))) (DEFPARAMETER *DISPLAY-PE-DEPTH* 1 "Depth to recursivly display placement editors within placement editors") (DEF-WINDOW-TYPE :PLACEMENT-EDITOR :RECOGNIZER (LAMBDA (WINDOW) (PLACEMENT-EDITOR-P (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR ))) :ABSTRACTER (LAMBDA (WINDOW) (LET ((PE (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (WHEN PE `(:REGION ,(EXTERNALIZE-REGION (WINDOW-REGION (PE-WINDOW PE))) :ROOM-NAME ,(PE-ROOM-NAME (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR)))))) :RECONSTITUTER (LAMBDA (PLIST) (PE-WINDOW (GET-PE (GETF PLIST :ROOM-NAME) (INTERNALIZE-REGION (GETF PLIST :REGION))))) :TITLE (LAMBDA (PLACEMENT REGION DSP) (LET ((PE (IL:WINDOWPROP (PLACEMENT-WINDOW PLACEMENT) :PLACEMENT-EDITOR))) (WHEN PE (PRINT-PEP-TITLE-STRING (LET ((NAME (PE-ROOM-NAME PE))) (IF (STRINGP NAME) NAME (PRINC-TO-STRING NAME))) REGION DSP) (IL:* IL:\| "(when (> *display-pe-depth* 0) (let ((*display-pe-depth* (1- *display-pe-depth*)) (old-scale (pe-scale pe)) (old-peps (pe-peps pe)) (old-clipping-region (pe-clipping-region pe)) (new-clipping-region (make-region :left (+ (region-left region) 1) :bottom (+ (region-bottom region) 1) :width (- (region-width region) 2) :height (- (region-height region) 2 (il:fontheight *pep-title-font*))))) (unwind-protect (progn (setf (pe-scale pe) (make-scale new-clipping-region)) (setf (pe-changed? pe) t) (setf (pe-clipping-region pe) new-clipping-region) (update-peps pe) (il:* il:|;;| \"recursively display pictogram\") (display-peps pe dsp)) (setf (pe-scale pe) old-scale) (setf (pe-peps pe) old-peps) (setf (pe-clipping-region pe) old-clipping-region))))") )))) (DEFUN PE-RIGHTBUTTONFN (WINDOW) (UNLESS (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (IL:DOWINDOWCOM WINDOW))) (DEFUN PE-BUTTONEVENTFN (WINDOW) (IL:TOTOPW WINDOW) (LET ((PE (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (IF (IL:INSIDEP (PE-CLIPPING-REGION PE) (IL:LASTMOUSEX WINDOW) (IL:LASTMOUSEY WINDOW)) (PE-BUTTONEVENTFN-INTERNAL PE WINDOW) (UNLESS (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (CASE (MENU '(("ReFetch" :RE-FETCH))) (:RE-FETCH (UPDATE-PLACEMENTS))))))) (DEFUN PE-BUTTONEVENTFN-INTERNAL (PE WINDOW) (LET ((WINDOW WINDOW) (PE PE)) (LOOP (WHEN (AND (PLACEMENT-EDITOR-P PE) (PE-TRACK-MOUSE PE WINDOW)) (RETURN)) (PE-GETMOUSESTATE) (UNLESS (IL:LASTMOUSESTATE (OR IL:LEFT IL:MIDDLE)) (RETURN)) (SETQ WINDOW (IL:WHICHW)) (SETQ PE (WHEN WINDOW (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR)))))) (DEFUN PE-TRACK-MOUSE (PE WINDOW) (LET ((*TIMER* (IL:SETUPTIMER *BUTTON-HELP-DELAY*))) (DECLARE (SPECIAL *TIMER*)) (COND ((IL:LASTMOUSESTATE (IL:ONLY IL:LEFT)) (LET ((SELECTED-PEP (PE-TRACK-LEFT-BUTTON PE))) (WHEN SELECTED-PEP (PEP-SELECTED SELECTED-PEP PE) (IL:* IL:|;;| "return true when something's been selected") T))) ((IL:LASTMOUSESTATE IL:MIDDLE) (LET ((ROOM-SELECTED? (PE-TRACK-MIDDLE-BUTTON PE))) (WHEN ROOM-SELECTED? (PE-ROOM-SELECTED PE) (IL:* IL:|;;| "return true when something's been selected") T)))))) (DEFUN PE-GETMOUSESTATE () (IL:* IL:|;;| "call GETMOUSESTATE, and if the mouse hasn't moved, block. This is in case we're in the Overview, so the keyboard watcher will run.") (LET ((X IL:LASTMOUSEX) (Y IL:LASTMOUSEY)) (IL:GETMOUSESTATE) (WHEN (AND (= X IL:LASTMOUSEX) (= Y IL:LASTMOUSEY)) (IL:BLOCK)))) (DEFUN PE-TRACK-LEFT-BUTTON (PE) (DECLARE (SPECIAL *TIMER*)) (LET ((SELECTED-PEP NIL) (CLIPPING-REGION (PE-CLIPPING-REGION PE)) (WINDOW (PE-WINDOW PE)) (IL:* IL:|;;| "need PEPS in top down order to handle occlusion correctly") (PEPS (REVERSE (PE-PEPS PE)))) (MACROLET ((INVERT-SELECTED-PEP NIL `(LET ((REGION (PEP-SCALED-REGION SELECTED-PEP))) (IL:BLTSHADE IL:BLACKSHADE WINDOW (REGION-LEFT REGION) (REGION-BOTTOM REGION) (REGION-WIDTH REGION) (REGION-HEIGHT REGION) 'IL:INVERT CLIPPING-REGION)))) (LOOP (UNLESS (AND (IL:LASTMOUSESTATE (IL:ONLY IL:LEFT)) (IL:INSIDEP CLIPPING-REGION (IL:LASTMOUSEX WINDOW) (IL:LASTMOUSEY WINDOW))) (RETURN (WHEN SELECTED-PEP (IL:* IL:|;;| "restore the display") (INVERT-SELECTED-PEP) (WHEN (AND (NOT (IL:LASTMOUSESTATE IL:MIDDLE)) (IL:INSIDEP CLIPPING-REGION (IL:LASTMOUSEX WINDOW) (IL:LASTMOUSEY WINDOW))) (IL:* IL:|;;|  "return the PEP if there's one selected & the button event fn should be exited.") SELECTED-PEP)))) (DOLIST (IL:* IL:|;;| "look down the occlusion stack") (PEP PEPS (WHEN SELECTED-PEP (IL:* IL:|;;| "bottomed out -- must be in the background") (IL:* IL:|;;| "have to de-select selection") (INVERT-SELECTED-PEP) (SETQ SELECTED-PEP NIL))) (WHEN (IL:INSIDEP (PEP-SCALED-REGION PEP) (IL:LASTMOUSEX WINDOW) (IL:LASTMOUSEY WINDOW)) (IL:* IL:|;;| "we're in a PEP") (UNLESS (EQ PEP SELECTED-PEP) (IL:* IL:|;;| "it's a new selection") (WHEN SELECTED-PEP (IL:* IL:|;;| "unselect the current selection") (INVERT-SELECTED-PEP)) (IL:* IL:|;;| "select the new one") (SETQ SELECTED-PEP PEP) (INVERT-SELECTED-PEP)) (IL:* IL:|;;| "pop to the outer loop") (RETURN))) (WHEN (AND *TIMER* (IL:TIMEREXPIRED? *TIMER*)) (NOTIFY-USER "Use LEFT to select placements, MIDDLE Rooms.") (IL:TOTOPW WINDOW T) (SETQ *TIMER* NIL)) (PE-GETMOUSESTATE))))) (DEFUN PE-TRACK-MIDDLE-BUTTON (PE) (DECLARE (SPECIAL *TIMER*)) (LET* ((WINDOW (PE-WINDOW PE)) (REGION (WINDOW-REGION WINDOW))) (UNWIND-PROTECT (PROGN (IL:INVERTW WINDOW) (LOOP (UNLESS (IL:INSIDEP REGION IL:LASTMOUSEX IL:LASTMOUSEY) (IL:* IL:|;;| "return NIL if mouse leaves clipping region") (RETURN NIL)) (UNLESS (IL:LASTMOUSESTATE IL:MIDDLE) (IL:* IL:|;;| "return true iff room was selected") (RETURN (NOT (IL:LASTMOUSESTATE (OR IL:LEFT IL:RIGHT))))) (WHEN (AND *TIMER* (IL:TIMEREXPIRED? *TIMER*)) (NOTIFY-USER "Use LEFT to select placements, MIDDLE Rooms.") (IL:TOTOPW WINDOW T) (SETQ *TIMER* NIL)) (PE-GETMOUSESTATE))) (IL:INVERTW WINDOW)))) (DEFUN PEP-GETBOXPOSITION (PE PEP) (IL:* IL:|;;;| "called when a placement is MOVE or COPY selected to get the new position for the placement.") (IL:* IL:|;;;| "returns two values - a position and a PE - or NIL") (LET* ((OLD-CURSOR (IL:CURSOR)) (OLD-TTY (IL:TTY.PROCESS))) (UNWIND-PROTECT (PROGN (IL:CURSOR IL:CROSSHAIRS) (IL:TTY.PROCESS (IL:THIS.PROCESS)) (IL:CURSORPOSITION (MAKE-POSITION (REGION-LEFT (PEP-SCALED-REGION PEP)) (REGION-BOTTOM (PEP-SCALED-REGION PEP))) (PE-WINDOW PE)) (DO* ((PLACED-REGION (PLACED-REGION (PEP-PLACEMENT PEP))) (HEIGHT (REGION-HEIGHT PLACED-REGION)) (WIDTH (REGION-WIDTH PLACED-REGION)) (WINDOW NIL (IL:* IL:|;;| "the window the cursor is over (if any)") (IL:WHICHW)) (PE NIL (IL:* IL:|;;| "the PE the cursor is over (if any)") (IF (AND WINDOW (PE-WINDOW-P WINDOW)) (IL:WINDOWPROP WINDOW :PLACEMENT-EDITOR))) (POSITION NIL (IL:* IL:|;;| "the selected position within PE (if any)") (IF PE (LET ((CLIPPING-REGION (PE-CLIPPING-REGION PE)) (SCALE (PE-SCALE PE))) (IF (IL:INSIDEP CLIPPING-REGION (IL:LASTMOUSEX WINDOW) (IL:LASTMOUSEY WINDOW)) (IL:* IL:|;;| "have to rescale box for each PE") (PEP-GETBOXPOSITION-INTERNAL (SCALE-WIDTH WIDTH SCALE) (SCALE-HEIGHT HEIGHT SCALE) (PE-CLIPPING-REGION PE) WINDOW) (IL:GETMOUSESTATE))) (IL:GETMOUSESTATE)))) ((OR POSITION (IL:LASTMOUSESTATE (OR IL:LEFT IL:MIDDLE IL:RIGHT))) (WHEN POSITION (VALUES (UN-SCALE-POSITION POSITION (PE-SCALE PE)) PE))))) (IL:CURSOR OLD-CURSOR) (IL:TTY.PROCESS OLD-TTY)))) (DEFUN PEP-GETBOXPOSITION-INTERNAL (WIDTH HEIGHT CLIPPING-REGION WINDOW) (IL:* IL:|;;;| "track a box WIDTH by HEIGHT within CLIPPING-REGION in WINDOW. if a button goes down return the X,Y position. if cursor goes outside CLIPPING-REGION then return NIL.") (LET* ((DSP (IL:GETSTREAM WINDOW)) (OLD-OPERATION (IL:DSPOPERATION NIL DSP)) (LAST-X (IL:LASTMOUSEX DSP)) (LAST-Y (IL:LASTMOUSEY DSP))) (MACROLET ((INVERT-BOX NIL `(IL:DRAWGRAYBOX LAST-X LAST-Y (+ LAST-X WIDTH) (+ LAST-Y HEIGHT) DSP IL:GRAYSHADE))) (UNWIND-PROTECT (PROGN (IL:TOTOPW WINDOW) (IL:DSPOPERATION 'IL:INVERT DSP) (INVERT-BOX) (TAGBODY LOOP (UNLESS (IL:INSIDEP CLIPPING-REGION LAST-X LAST-Y) (RETURN-FROM PEP-GETBOXPOSITION-INTERNAL)) (WHEN (IL:MOUSESTATE (OR IL:LEFT IL:MIDDLE IL:RIGHT)) (RETURN-FROM PEP-GETBOXPOSITION-INTERNAL (MAKE-POSITION LAST-X LAST-Y))) (UNLESS (AND (= (IL:LASTMOUSEX DSP) LAST-X) (= (IL:LASTMOUSEY DSP) LAST-Y)) (IL:UNINTERRUPTABLY (IL:* IL:|;;| "un-draw old") (INVERT-BOX) (SETQ LAST-X (IL:LASTMOUSEX DSP)) (SETQ LAST-Y (IL:LASTMOUSEY DSP)) (IL:* IL:|;;| "re-draw new") (INVERT-BOX))) (GO LOOP))) (INVERT-BOX) (IL:DSPOPERATION OLD-OPERATION DSP))))) (IL:* IL:\; "editing") (DEFUN PE-ROOM-CHANGED-FN (ROOM REASON) (WHEN (EQ REASON :DELETED) (IL:* IL:|;;| "if ROOM has been deleted then delete the placement editor") (LET ((PE (FIND-PE (ROOM-NAME ROOM)))) (WHEN PE (LET ((WINDOW (PE-WINDOW PE))) (IL:* IL:|;;| "delete the placement editor") (UN-HIDE-WINDOW WINDOW) (CLOSE-WINDOW WINDOW) (REMHASH (ROOM-NAME ROOM) *PLACEMENT-EDITORS*))))) (LET ((INCLUDERS (ROOM-INCLUDERS ROOM T))) (IL:* IL:|;;| "ensure PE's for all rooms which include ROOM will be redisplayed") (DOLIST (INCLUDER INCLUDERS) (LET ((PE (FIND-PE (ROOM-NAME INCLUDER)))) (WHEN PE (IL:* IL:|;;| "otherwise mark it as needing update") (UNLESS (EQ (PE-CHANGED? PE) T) (IL:* IL:|;;| "OK to upgrade :PLACEMENTS to T, but not vice versa") (SETF (PE-CHANGED? PE) (IF (EQ REASON :PLACEMENTS) REASON T))) (LET ((WINDOW (PE-WINDOW PE))) (WHEN (AND (IL:OPENWP WINDOW) (NOT (WINDOW-HIDDEN? WINDOW))) (IL:* IL:|;;| "update the PE if it's visible") (UPDATE-PE PE)))))))) (DEFUN PEP-SELECTED (PEP PE) (IL:* IL:|;;;| "called when a placement is selected in PE") (LET ((OP (COND ((COPY-KEY-DOWN-P) :COPY) ((MOVE-KEY-DOWN-P) :MOVE) ((DELETE-KEY-DOWN-P) :DELETE) ((EXPAND-KEY-DOWN-P) :EXPAND) (T (OV-OPERATION))))) (CASE OP ((:COPY :MOVE) (PEP-SELECTED-COPY-OR-MOVE OP PEP PE)) (:DELETE (INTERACTIVE-CLOSE-WINDOW (PLACEMENT-WINDOW (PEP-PLACEMENT PEP)) (ROOM-NAMED (PE-ROOM-NAME PE)))) (:EXPAND (EXPAND-PLACEMENT (PEP-PLACEMENT PEP))) (T (NOTIFY-USER "Use a modifier (eg. COPY, MOVE or DELETE)"))))) (DEFUN EXPAND-PLACEMENT (PLACEMENT) (LET ((WINDOW (PLACEMENT-WINDOW PLACEMENT))) (IF (WINDOW-HIDDEN? WINDOW) (PROGN (NOTIFY-USER "Click LEFT when finished") (PLACE-PLACEMENT PLACEMENT) (LOOP (WHEN (IL:MOUSESTATE IL:LEFT) (RETURN))) (HIDE-WINDOW WINDOW)) (IL:FLASHWINDOW (IF (SHRUNKEN? WINDOW) (WINDOW-ICON WINDOW) WINDOW))))) (DEFUN PEP-SELECTED-COPY-OR-MOVE (OP PEP PE) (MULTIPLE-VALUE-BIND (DESTINATION-POS DESTINATION-PE) (PEP-GETBOXPOSITION PE PEP) (IF DESTINATION-POS (LET* ((OLD-PLACEMENT (PEP-PLACEMENT PEP)) (NEW-PLACEMENT (COPY-PLACEMENT OLD-PLACEMENT))) (IL:* IL:|;;| "adjust the position of the new placement") (IF (PLACEMENT-SHRUNKEN? NEW-PLACEMENT) (SETF (PLACEMENT-ICON-POSITION NEW-PLACEMENT) DESTINATION-POS) (SETF (PLACEMENT-REGION NEW-PLACEMENT) (MAKE-REGION :LEFT (POSITION-X DESTINATION-POS) :BOTTOM (POSITION-Y DESTINATION-POS) :WIDTH (REGION-WIDTH (PLACEMENT-REGION NEW-PLACEMENT)) :HEIGHT (REGION-HEIGHT (PLACEMENT-REGION NEW-PLACEMENT))))) (IL:* IL:|;;| "do the move/copy") (LET ((PE-ROOM (ROOM-NAMED (PE-ROOM-NAME PE))) (DESTINATION-ROOM (ROOM-NAMED (PE-ROOM-NAME DESTINATION-PE)))) (MULTIPLE-VALUE-BIND (PLACEMENT SOURCE-ROOM) (IL:* IL:|;;| "find the room this placement is due to") (FIND-PLACEMENT (PLACEMENT-WINDOW OLD-PLACEMENT) PE-ROOM) (ECASE OP (:MOVE (IF (EQ PE DESTINATION-PE) (IL:* IL:|;;| "Allow inherited placements to be moved in place -- w/o moving them to the room they're visible in.") (SETQ DESTINATION-ROOM SOURCE-ROOM) (UNLESS (EQ DESTINATION-ROOM SOURCE-ROOM) (IL:* IL:|;;| "We don't bother deleting first when source & destination are same, as we know ADD-PLACEMENT will delete the old & we only want to redisplay once") (DELETE-PLACEMENT PLACEMENT SOURCE-ROOM))) (ADD-PLACEMENT NEW-PLACEMENT DESTINATION-ROOM)) (:COPY (ADD-PLACEMENT NEW-PLACEMENT DESTINATION-ROOM)))))) (NOTIFY-USER "Invalid destination.")))) (DEFUN PE-ROOM-SELECTED (PE) (IL:* IL:|;;;| "called when a room is selected in PE") (LET ((ROOM (ROOM-NAMED (PE-ROOM-NAME PE))) (OP (COND ((IL:KEYDOWNP 'IL:SPACE) :ENTER) ((EDIT-KEY-DOWN-P) :EDIT) ((COPY-KEY-DOWN-P) :COPY) ((MOVE-KEY-DOWN-P) :MOVE) ((DELETE-KEY-DOWN-P) :DELETE) (T (IF (EQ *CURRENT-ROOM* *OVERVIEW-ROOM*) (OV-OPERATION) :ENTER))))) (CASE OP (:EDIT (EDIT-ROOM ROOM)) (:COPY (INTERACTIVE-COPY-ROOM ROOM)) (:MOVE (INTERACTIVE-RENAME-ROOM ROOM)) (:DELETE (INTERACTIVE-DELETE-ROOM ROOM)) (:ENTER (GO-TO-ROOM ROOM)) (T (NOTIFY-USER "Use a modifier (eg. COPY, DELETE or GO TO)."))))) (EVAL-WHEN (LOAD) (PUSHNEW 'PE-ROOM-CHANGED-FN *ROOM-CHANGED-FUNCTIONS*) ) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:TINYFONT IL:CROSSHAIRS) ) (IL:PUTPROPS IL:ROOMS-PLACEMENT-EDITOR IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (3759 4733 (GET-PE 3759 . 4733)) (4735 6041 (MAKE-PE 4735 . 6041)) (6124 6221 ( PE-WINDOW-P 6124 . 6221)) (6223 6347 (PE-CLOSEFN 6223 . 6347)) (6349 6596 (PE-REPAINTFN 6349 . 6596)) (6598 6842 (PE-RESHAPEFN 6598 . 6842)) (6844 7076 (PE-TOTOPFN 6844 . 7076)) (7078 7160 (UPDATE-PE? 7078 . 7160)) (7162 8216 (UPDATE-PE 7162 . 8216)) (8218 10796 (UPDATE-PEPS 8218 . 10796)) (10798 11411 (UPDATE-PEP-SAVE-BITMAP 10798 . 11411)) (11413 12431 (UPDATE-PE-WINDOW 11413 . 12431)) (12433 13407 ( PLACED-REGION 12433 . 13407)) (14005 14813 (DISPLAY-PEPS 14005 . 14813)) (14815 16050 (SAVE-PEP-IMAGE 14815 . 16050)) (16052 17720 (DISPLAY-PE-TITLE 16052 . 17720)) (17722 18313 (DISPLAY-PE-BORDER 17722 . 18313)) (18315 18788 (DISPLAY-PEP 18315 . 18788)) (18790 20194 (PRINT-PEP-TITLE 18790 . 20194)) ( 20196 22323 (PRINT-PEP-TITLE-STRING 20196 . 22323)) (24746 24865 (PE-RIGHTBUTTONFN 24746 . 24865)) ( 24867 25335 (PE-BUTTONEVENTFN 24867 . 25335)) (25337 25819 (PE-BUTTONEVENTFN-INTERNAL 25337 . 25819)) (25821 26598 (PE-TRACK-MOUSE 25821 . 26598)) (26600 26977 (PE-GETMOUSESTATE 26600 . 26977)) (26979 30354 (PE-TRACK-LEFT-BUTTON 26979 . 30354)) (30356 31384 (PE-TRACK-MIDDLE-BUTTON 30356 . 31384)) ( 31386 34182 (PEP-GETBOXPOSITION 31386 . 34182)) (34184 36348 (PEP-GETBOXPOSITION-INTERNAL 34184 . 36348)) (36381 37953 (PE-ROOM-CHANGED-FN 36381 . 37953)) (37955 38730 (PEP-SELECTED 37955 . 38730)) ( 38732 39248 (EXPAND-PLACEMENT 38732 . 39248)) (39250 41851 (PEP-SELECTED-COPY-OR-MOVE 39250 . 41851)) (41853 42775 (PE-ROOM-SELECTED 41853 . 42775))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-PLACEMENT-EDITOR.DFASL b/rooms/ROOMS-PLACEMENT-EDITOR.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..b6957b646c6d6012c058f35f691b00d42d9d1ef1 GIT binary patch literal 21921 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.;2| 25421 IL:|previous| IL:|date:| "17-Aug-90 13:29:14" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-SUITES.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-SUITESCOMS) (IL:RPAQQ IL:ROOMS-SUITESCOMS ((FILE-ENVIRONMENTS IL:ROOMS-SUITES) (IL:P (EXPORT '(*SUITE-FILE-TYPE* *SUITE-DIRECTORIES* DEFSUITE)) (REQUIRE "ROOMS")) (IL:DEFINE-TYPES IL:SUITES) (IL:VARIABLES *DEFSUITE-VERSION* *SUITES* *SUITE-DIRECTORIES* *SUITE-FILE-TYPE*) (IL:P (PUSHNEW '(CLRHASH *SUITES*) *RESET-FORMS* :TEST 'EQUAL)) (IL:* IL:|;;| "loading suites") (IL:FUNCTIONS DEFSUITE MAKE-SUITE SUITE-ROOMS INSTALL-SUITE INSTALL-SUITE-BODY INSTALL-ROOM INSTALL-PLACEMENT) (IL:SEDIT-FORMATS DEFSUITE) (IL:* IL:|;;| "deleting suites") (IL:FUNCTIONS DELETE-SUITE) (IL:* IL:|;;| "constructing suites") (IL:FUNCTIONS DUMP-SUITE UPDATE-SUITE CONSTRUCT-DEFSUITE ALL-WINDOWS-IN-ROOMS CONSTRUCT-WINDOWS CONSTRUCT-FILES CONSTRUCT-PLACEMENTS) (IL:FUNCTIONS ROOMS-NOT-IN-ANY-SUITE FIND-SUITE-CONTAINING AUGMENT-SUITE DELETE-ROOM-FROM-SUITE) (IL:* IL:|;;| "interactive code") (IL:VARIABLES *SUITE-MENU-ITEMS* *SUITE-MENU*) (IL:FUNCTIONS SUITE-MENU INTERACTIVE-LOAD-SUITE INTERACTIVE-DUMP-SUITE INTERACTIVE-MAKE-SUITE INTERACTIVE-UPDATE-SUITE INTERACTIVE-DELETE-SUITE INTERACTIVE-SHOW-SUITE INTERACTIVE-AUGMENT-SUITE INTERACTIVE-DELETE-ROOM-FROM-SUITE SELECT-SUITE PROMPT-FOR-SUITE-NAME))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-SUITES :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(*SUITE-FILE-TYPE* *SUITE-DIRECTORIES* DEFSUITE)) (REQUIRE "ROOMS") (DEF-DEFINE-TYPE IL:SUITES "Room Suites") (DEFCONSTANT *DEFSUITE-VERSION* 1) (DEFGLOBALVAR *SUITES* (MAKE-HASH-TABLE :TEST 'EQUAL)) (DEFPARAMETER *SUITE-DIRECTORIES* (IL:* IL:|;;| "initially just the connected directory") (LIST T)) (DEFVAR *SUITE-FILE-TYPE* "SUITE") (PUSHNEW '(CLRHASH *SUITES*) *RESET-FORMS* :TEST 'EQUAL) (IL:* IL:|;;| "loading suites") (DEFDEFINER (DEFSUITE (:UNDEFINER (LAMBDA (NAME) (REMHASH NAME *SUITES*)))) IL:SUITES (NAME &BODY BODY) `(INSTALL-SUITE ',NAME ',BODY)) (DEFUN MAKE-SUITE (SUITE-NAME ROOM-NAMES) (WHEN (SUITE-ROOMS SUITE-NAME) (CERROR "Delete all rooms in existing suite named ~S" "Attempt to redefine suite ~S" SUITE-NAME) (DELETE-SUITE SUITE-NAME T)) (SETF (SUITE-ROOMS SUITE-NAME) ROOM-NAMES) SUITE-NAME) (DEFMACRO SUITE-ROOMS (SUITE-NAME) `(GETHASH ,SUITE-NAME *SUITES*)) (DEFUN INSTALL-SUITE (SUITE-NAME SUITE-BODY) (IL:* IL:|;;;| "do the work of DEFSUITE.") (IL:* IL:|;;| "first check for suite redefinition. MAKE-SUITE will do this for us, but by checking first we assure things will be left consistent should the user abort.") (WHEN (SUITE-ROOMS SUITE-NAME) (CERROR "Delete all rooms in existing suite named ~S" "Attempt to redefine suite ~S" SUITE-NAME) (DELETE-SUITE SUITE-NAME T)) (LET ((ROOM-NAMES (WITH-COLLECTION (DOLIST (SPEC SUITE-BODY) (CASE (FIRST SPEC) (:ROOM (COLLECT (SECOND SPEC)))))))) (DOLIST (ROOM-NAME ROOM-NAMES) (IL:* IL:|;;| "check for room redefinitions. MAKE-ROOM will do this again, but checking here leaves us in a much more consitstent state should the user choose to abort rather than continue. ") (WHEN (ROOM-NAMED ROOM-NAME) (CERROR "Delete existing room named ~S (will close windows)" "A room named ~S already exists" ROOM-NAME) (DELETE-ROOM (ROOM-NAMED ROOM-NAME)))) (IL:* IL:|;;| "make the rooms") (INSTALL-SUITE-BODY SUITE-BODY) (IL:* IL:|;;| "remember what rooms were in this suite") (MAKE-SUITE SUITE-NAME ROOM-NAMES) (CHECK-LOST-WINDOWS))) (DEFUN INSTALL-SUITE-BODY (SUITE-BODY) (IL:WITH.MONITOR *MONITOR-LOCK* (LET ((WINDOWS (MAKE-HASH-TABLE)) (VERSION NIL)) (IL:* IL:|;;| "first load files & parse version") (DOLIST (SPEC SUITE-BODY) (ECASE (FIRST SPEC) (:FILES (IL:DOFILESLOAD (REST SPEC))) ((:WINDOW :ROOM) ) (:VERSION (SETQ VERSION (SECOND SPEC)) (WHEN (> VERSION *DEFSUITE-VERSION*) (ERROR "DEFSUITE version ~S too high." VERSION))))) (UNLESS VERSION (WARN "No version found in DEFSUITE. Presuming current.") (SETQ VERSION *DEFSUITE-VERSION*)) (IL:* IL:|;;| "now make all the windows") (UPDATE-PLACEMENTS) (DOLIST (SPEC SUITE-BODY) (CASE (FIRST SPEC) (:WINDOW (LET ((WINDOW (RECONSTITUTE-WINDOW (FOURTH SPEC) (NTHCDR 4 SPEC)))) (WHEN (IL:WINDOWP WINDOW) (SETF (GETHASH (SECOND SPEC) WINDOWS) WINDOW) (UNLESS (FIND-PLACEMENT WINDOW) (HIDE-WINDOW WINDOW))))))) (IL:* IL:|;;| "finally make the rooms") (DOLIST (SPEC SUITE-BODY) (CASE (FIRST SPEC) (:ROOM (APPLY #'INSTALL-ROOM WINDOWS (REST SPEC)))))))) (DEFUN INSTALL-ROOM (WINDOWS NAME &REST REST-KEYS &KEY PLACEMENTS &ALLOW-OTHER-KEYS) (APPLY 'MAKE-ROOM NAME :PLACEMENTS (WITH-COLLECTION (DOLIST (PLACEMENT-SPEC PLACEMENTS) (LET ((PLACEMENT (APPLY #' INSTALL-PLACEMENT WINDOWS PLACEMENT-SPEC))) (WHEN PLACEMENT (COLLECT PLACEMENT)))) ) (LET ((REST (COPY-LIST REST-KEYS))) (REMF REST :PLACEMENTS) REST))) (DEFUN INSTALL-PLACEMENT (WINDOWS NAME &REST REST-KEYS &KEY REGION SHRUNKEN? ICON-POSITION &ALLOW-OTHER-KEYS) (LET ((WINDOW (GETHASH NAME WINDOWS))) (WHEN WINDOW (MAKE-PLACEMENT-INTERNAL :WINDOW WINDOW :REGION (INTERNALIZE-REGION REGION) :SHRUNKEN? SHRUNKEN? :ICON-POSITION (WHEN ICON-POSITION (INTERNALIZE-POSITION ICON-POSITION)) :PROPS (LET ((PROPS (COPY-LIST REST-KEYS))) (DOLIST (KEYWORD '(:REGION :SHRUNKEN? :ICON-POSITION)) (REMF PROPS KEYWORD)) PROPS))))) (SEDIT:DEF-LIST-FORMAT DEFSUITE :ARGS (NIL :KEYWORD NIL) :INDENT (1)) (IL:* IL:|;;| "deleting suites") (DEFUN DELETE-SUITE (SUITE-NAME &OPTIONAL ROOMS-TOO?) (IL:* IL:|;;| "delete all the rooms in the suite") (WHEN ROOMS-TOO? (DOLIST (ROOM-NAME (SUITE-ROOMS SUITE-NAME)) (LET ((ROOM (ROOM-NAMED ROOM-NAME))) (WHEN ROOM (DELETE-ROOM ROOM))))) (IL:* IL:|;;| "delete the suite") (REMHASH SUITE-NAME *SUITES*)) (IL:* IL:|;;| "constructing suites") (DEFUN DUMP-SUITE (SUITE-NAME &OPTIONAL QUIET?) (UPDATE-SUITE SUITE-NAME) (IL:* IL:|;;| "dump it to a file") (LET ((FILE (OR (FIRST (IL:WHEREIS SUITE-NAME 'IL:SUITES)) (INTERN (NAMESTRING (MAKE-PATHNAME :NAME (STRING-UPCASE SUITE-NAME) :TYPE *SUITE-FILE-TYPE* :HOST NIL :DEVICE NIL :DIRECTORY NIL)) "IL"))) FULL-NAME) (UNLESS (AND (IL:HASDEF FILE 'IL:FILES) (IL:INFILECOMS? SUITE-NAME 'IL:SUITES (IL:FILECOMS FILE))) (IL:PUTDEF FILE 'FILE-ENVIRONMENTS `(DEFINE-FILE-ENVIRONMENT ,FILE :PACKAGE (DEFPACKAGE "ROOMS" (:USE "LISP" "XCL") (:SHADOW CL:ROOM)) :READTABLE "XCL" :COMPILER :COMPILE-FILE)) (IL:PUTDEF FILE 'IL:FILES `(((IL:FILES IL:ROOMS) (FILE-ENVIRONMENTS ,FILE) (IL:SUITES ,SUITE-NAME))))) (UNLESS QUIET? (NOTIFY-USER "Making file ~A ..." FILE)) (IL:ALLOW.BUTTON.EVENTS) (SETQ FULL-NAME (PATHNAME (IL:MAKEFILE FILE '(IL:FAST IL:NEW)))) (UNLESS QUIET? (NOTIFY-USER "Made file ~A" (NAMESTRING FULL-NAME))) (SETQ IL:NOTCOMPILEDFILES (REMOVE FILE IL:NOTCOMPILEDFILES)) (SETQ IL:NOTLISTEDFILES (REMOVE FILE IL:NOTLISTEDFILES)) FULL-NAME)) (DEFUN UPDATE-SUITE (SUITE-NAME) (LET ((IL:DFNFLG 'IL:PROP)) (IL:PUTDEF SUITE-NAME 'IL:SUITES (CONSTRUCT-DEFSUITE SUITE-NAME (SUITE-ROOMS SUITE-NAME))))) (DEFUN CONSTRUCT-DEFSUITE (SUITE-NAME ROOM-NAMES) (LET* ((ROOMS (WITH-COLLECTION (DOLIST (NAME ROOM-NAMES) (LET ((ROOM (ROOM-NAMED NAME))) (IF ROOM (COLLECT ROOM) (WARN "No room named ~S exists." NAME)))))) (WINDOW-NAMES (MAKE-HASH-TABLE)) (WINDOW-ABSTRACTIONS (CONSTRUCT-WINDOWS (ALL-WINDOWS-IN-ROOMS ROOMS) WINDOW-NAMES))) `(DEFSUITE ,SUITE-NAME (:VERSION ,*DEFSUITE-VERSION*) (:FILES ,@(CONSTRUCT-FILES WINDOW-NAMES)) ,@WINDOW-ABSTRACTIONS ,@(MAPCAR #'(LAMBDA (ROOM) `(:ROOM ,(ROOM-NAME ROOM) :PLACEMENTS ,(CONSTRUCT-PLACEMENTS ROOM WINDOW-NAMES) :INCLUSIONS ,(ROOM-INCLUSIONS ROOM) :BACKGROUND ,(BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND ROOM)) ,@(ROOM-PROPS ROOM))) ROOMS)))) (DEFUN ALL-WINDOWS-IN-ROOMS (ROOMS) (IL:* IL:|;;;| "return a list containing all the windows in ROOMS") (UPDATE-PLACEMENTS) (LET (WINDOWS) (DOLIST (ROOM ROOMS) (DOLIST (PLACEMENT (ROOM-PLACEMENTS ROOM)) (PUSHNEW (PLACEMENT-WINDOW PLACEMENT) WINDOWS :TEST 'EQ))) (NREVERSE WINDOWS))) (DEFUN CONSTRUCT-WINDOWS (WINDOWS WINDOW-NAMES) (IL:* IL:|;;;| "construct the list of window abstractions for WINDOWS. store a name for each window in WINDOW-NAMES. ") (WITH-COLLECTION (LET ((WINDOW-NUMBER 0)) (DOLIST (WINDOW WINDOWS) (LET ((ABSTRACTION (ABSTRACT-WINDOW WINDOW))) (WHEN ABSTRACTION (COLLECT `(:WINDOW ,WINDOW-NUMBER ,@ABSTRACTION)) (SETF (GETHASH WINDOW WINDOW-NAMES) WINDOW-NUMBER) (INCF WINDOW-NUMBER))))))) (DEFUN CONSTRUCT-FILES (WINDOW-NAMES) (IL:* IL:|;;;| "returns the appended list of all the :FILES properties of all the window types of all the windows in WINDOW-NAMES. ") (LET ((ALL-FILES NIL)) (MAPHASH #'(LAMBDA (WINDOW NAME) (DOLIST (FILE (WINDOW-TYPE-PROP (WINDOW-TYPE WINDOW) :FILES)) (PUSHNEW FILE ALL-FILES))) WINDOW-NAMES) (REVERSE ALL-FILES))) (DEFUN CONSTRUCT-PLACEMENTS (ROOM WINDOW-NAMES) (IL:* IL:|;;| "construct a list of external representations for the placements in ROOM, using the hash table WINDOW-NAMES to name windows. these external representations are installed by INSTALL-PLACEMENT") (WITH-COLLECTION (DOLIST (PLACEMENT (ROOM-PLACEMENTS ROOM)) (LET ((WINDOW-NAME (GETHASH (PLACEMENT-WINDOW PLACEMENT) WINDOW-NAMES))) (WHEN WINDOW-NAME (IL:* IL:|;;|  "unnamed windows are ones that could not be abstracted -- we ignore them here. ") (COLLECT `(,WINDOW-NAME :REGION ,(EXTERNALIZE-REGION ( PLACEMENT-REGION PLACEMENT)) ,@(WHEN (PLACEMENT-ICON-POSITION PLACEMENT) (LIST :SHRUNKEN? (PLACEMENT-SHRUNKEN? PLACEMENT) :ICON-POSITION (EXTERNALIZE-POSITION ( PLACEMENT-ICON-POSITION PLACEMENT)))) ,@(PLACEMENT-PROPS PLACEMENT)))))))) (DEFUN ROOMS-NOT-IN-ANY-SUITE (&OPTIONAL FOR-DELETION?) (IL:* IL:|;;;| "returns a list of all the rooms which are not in any suite") (WITH-COLLECTION (DOLIST (ROOM (ALL-ROOMS T)) (LET ((NAME (ROOM-NAME ROOM))) (UNLESS (OR (UNLESS FOR-DELETION? (IL:* IL:|;;| "Original & Pockets implicitly belong to the bootstrap suite & we don't want them added to others.") (OR (EQUAL NAME "Pockets") (EQUAL NAME "Original"))) (FIND-SUITE-CONTAINING NAME)) (COLLECT ROOM)))))) (DEFUN FIND-SUITE-CONTAINING (ROOM-NAME) (MAPHASH #'(LAMBDA (SUITE-NAME ROOM-NAMES) (WHEN (MEMBER ROOM-NAME ROOM-NAMES :TEST 'EQUAL) (RETURN-FROM FIND-SUITE-CONTAINING SUITE-NAME))) *SUITES*)) (DEFUN AUGMENT-SUITE (SUITE-NAME ROOM-NAME) (PUSHNEW ROOM-NAME (SUITE-ROOMS SUITE-NAME) :TEST 'EQUAL)) (DEFUN DELETE-ROOM-FROM-SUITE (ROOM-NAME SUITE-NAME) (SETF (SUITE-ROOMS SUITE-NAME) (DELETE ROOM-NAME (SUITE-ROOMS SUITE-NAME) :TEST 'EQUAL))) (IL:* IL:|;;| "interactive code") (DEFGLOBALPARAMETER *SUITE-MENU-ITEMS* '(("Save Suite" '(WITH-BUTTON '(INTERACTIVE-DUMP-SUITE) "Save Suite" "Save a set of rooms to a file") "Save a set of rooms to a file" (IL:SUBITEMS ("Update Suite" '(WITH-BUTTON '(INTERACTIVE-UPDATE-SUITE) "Update Suite" "Update the DEFSUITE form of a suite" ) "Update the DEFSUITE form of a suite"))) ("Restore Suite" '(WITH-BUTTON '(INTERACTIVE-LOAD-SUITE) "Restore Suite" "Load a set of rooms from a file") "Load a set of rooms from a file") ("Show Suite" '(WITH-BUTTON '(INTERACTIVE-SHOW-SUITE) "Show Suite" "List the rooms in a suite") "List the rooms in a suite") ("Augment Suite" '(WITH-BUTTON '(INTERACTIVE-AUGMENT-SUITE) "Augment Suite" "Add a room to a suite") "Add a room to a suite") ("Delete Suite" '(WITH-BUTTON '(INTERACTIVE-DELETE-SUITE) "Delete Suite" "Delete a suite, and optionally all the rooms in it.") "Delete a suite, and optionally all the rooms in it." (IL:SUBITEMS ("Delete Room From Suite" '(WITH-BUTTON '(  INTERACTIVE-DELETE-ROOM-FROM-SUITE ) "Delete Room From Suite")))))) (DEFGLOBALVAR *SUITE-MENU* NIL) (DEFUN SUITE-MENU () (OR *SUITE-MENU* (SETQ *SUITE-MENU* (IL:CREATE IL:MENU IL:ITEMS IL:_ *SUITE-MENU-ITEMS* IL:TITLE IL:_ "Suites" IL:CENTERFLG IL:_ T))) (LET* ((ITEM (IL:MENU *SUITE-MENU*))) (WHEN ITEM (IL:* IL:\;  "to be 100% compatible w/ background menu") (IL:EVAL ITEM)))) (DEFUN INTERACTIVE-LOAD-SUITE () (LET ((SUITE-NAME (PROMPT-FOR-SUITE-NAME))) (WHEN SUITE-NAME (IF (SUITE-ROOMS SUITE-NAME) (NOTIFY-USER "A suite named ~S already exists." SUITE-NAME) (LET ((FOUND (IL:FINDFILE (NAMESTRING (MERGE-PATHNAMES SUITE-NAME (MAKE-PATHNAME :TYPE *SUITE-FILE-TYPE* (IL:* IL:|;;|  "override default defaults") :HOST NIL :DEVICE NIL :DIRECTORY NIL :VERSION NIL) NIL)) T *SUITE-DIRECTORIES*))) (IF FOUND (IL:ADD.PROCESS `(FUNCALL ',#'(LAMBDA NIL (LET ((LOAD-COMPLETED? 'NIL)) (UNWIND-PROTECT (PROGN (LOAD FOUND) (SETQ LOAD-COMPLETED? T)) (LET ((WINDOW (IL:WFROMDS NIL T))) (WHEN WINDOW (IL:CLOSEW WINDOW))) (WHEN LOAD-COMPLETED? (NOTIFY-USER "Restored suite ~S." SUITE-NAME)))))) 'IL:NAME "Restore Suite") (NOTIFY-USER "Can't find suite ~S on *SUITE-DIRECTORIES*" SUITE-NAME))))))) (DEFUN INTERACTIVE-DUMP-SUITE () (LET ((SUITE-NAME (SELECT-SUITE :REASON "Save" :ALLOW-NEW? T))) (WHEN SUITE-NAME (WITH-BUTTON `(IL:RESETFORM (IL:TTYDISPLAYSTREAM (GET-MESSAGE-STREAM)) (DUMP-SUITE ',SUITE-NAME)) (FORMAT NIL "Save ~A" SUITE-NAME) (FORMAT NIL "Save suite named ~S." SUITE-NAME))))) (DEFUN INTERACTIVE-MAKE-SUITE () (LET ((ROOMS (ROOMS-NOT-IN-ANY-SUITE))) (IF (NULL ROOMS) (NOTIFY-USER "All rooms are already in some suite.") (LET ((SUITE-NAME (PROMPT-FOR-SUITE-NAME))) (WHEN SUITE-NAME (IF (SUITE-ROOMS SUITE-NAME) (NOTIFY-USER "A suite named ~S already exists" SUITE-NAME) (LET ((ROOM-NAMES (WITH-COLLECTION (NOTIFY-USER "Select rooms to go in ~S.~%Click outside menu when finished." SUITE-NAME) (LOOP (WHEN (NULL ROOMS) (RETURN)) (LET ((ROOM (SELECT-ROOM :FROM-ROOMS ROOMS))) (COND (ROOM (SETQ ROOMS (DELETE ROOM ROOMS :TEST 'EQ)) (COLLECT (ROOM-NAME ROOM))) (T (RETURN)))))))) (WHEN ROOM-NAMES (MAKE-SUITE SUITE-NAME ROOM-NAMES))))))))) (DEFUN INTERACTIVE-UPDATE-SUITE () (LET ((SUITE-NAME (SELECT-SUITE :REASON "Update" :ALLOW-NEW? T))) (WHEN SUITE-NAME (WITH-BUTTON `(IL:RESETFORM (IL:TTYDISPLAYSTREAM (GET-MESSAGE-STREAM)) (UPDATE-SUITE ',SUITE-NAME)) (FORMAT NIL "Update ~A" SUITE-NAME) (FORMAT NIL "Update suite named ~S." SUITE-NAME))))) (DEFUN INTERACTIVE-DELETE-SUITE () (LET ((SUITE-NAME (SELECT-SUITE :REASON "Delete"))) (WHEN (AND SUITE-NAME (CONFIRM "Delete suite ~S?" SUITE-NAME)) (DELETE-SUITE SUITE-NAME (CONFIRM "Delete all rooms in ~S too? (will close windows)" SUITE-NAME)) (NOTIFY-USER "Suite ~S deleted." SUITE-NAME)))) (DEFUN INTERACTIVE-SHOW-SUITE () (LET ((SUITE-NAME (SELECT-SUITE :REASON "Show"))) (WHEN SUITE-NAME (NOTIFY-USER "Suite ~S contains rooms:~{ ~S~}." SUITE-NAME (SUITE-ROOMS SUITE-NAME))) )) (DEFUN INTERACTIVE-AUGMENT-SUITE () (LET ((ROOMS (ROOMS-NOT-IN-ANY-SUITE))) (IF (NULL ROOMS) (NOTIFY-USER "All rooms are already in some suite.") (LET ((SUITE-NAME (SELECT-SUITE :REASON "Augment Suite"))) (WHEN SUITE-NAME (NOTIFY-USER "Select room to add to suite ~S" SUITE-NAME) (LET ((ROOM-NAME (SELECT-ROOM :FROM-ROOMS ROOMS :NAME-ONLY? T))) (WHEN ROOM-NAME (AUGMENT-SUITE SUITE-NAME ROOM-NAME)))))))) (DEFUN INTERACTIVE-DELETE-ROOM-FROM-SUITE () (LET ((SUITE-NAME (SELECT-SUITE :REASON "Delete room from"))) (WHEN SUITE-NAME (LET ((ROOM-NAME (MENU (SUITE-ROOMS SUITE-NAME) "Select Room"))) (WHEN ROOM-NAME (DELETE-ROOM-FROM-SUITE ROOM-NAME SUITE-NAME) (NOTIFY-USER "Deleted room ~S from suite ~S." ROOM-NAME SUITE-NAME)))))) (DEFUN SELECT-SUITE (&KEY REASON ALLOW-NEW?) (LET ((ITEMS (WHEN ALLOW-NEW? '(("" :NEW))))) (MAPHASH #'(LAMBDA (SUITE-NAME SUITE-BODY) (PUSH SUITE-NAME ITEMS)) *SUITES*) (IF ITEMS (LET ((SUITE-NAME (MENU ITEMS REASON))) (IF (AND ALLOW-NEW? (EQ SUITE-NAME :NEW)) (INTERACTIVE-MAKE-SUITE) SUITE-NAME)) (PROGN (NOTIFY-USER "No suites!") NIL)))) (DEFUN PROMPT-FOR-SUITE-NAME (&OPTIONAL (PROMPT "Suite Name:")) (LET ((STRING (PROMPT-USER PROMPT))) (WHEN STRING (STRING-UPCASE STRING)))) (IL:PUTPROPS IL:ROOMS-SUITES IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (2846 3162 (MAKE-SUITE 2846 . 3162)) (3240 4653 (INSTALL-SUITE 3240 . 4653)) (4655 6318 (INSTALL-SUITE-BODY 4655 . 6318)) (6320 7222 (INSTALL-ROOM 6320 . 7222)) (7224 7960 ( INSTALL-PLACEMENT 7224 . 7960)) (8081 8449 (DELETE-SUITE 8081 . 8449)) (8496 10464 (DUMP-SUITE 8496 . 10464)) (10466 10726 (UPDATE-SUITE 10466 . 10726)) (10728 12059 (CONSTRUCT-DEFSUITE 10728 . 12059)) ( 12061 12426 (ALL-WINDOWS-IN-ROOMS 12061 . 12426)) (12428 13114 (CONSTRUCT-WINDOWS 12428 . 13114)) ( 13116 13615 (CONSTRUCT-FILES 13116 . 13615)) (13617 15321 (CONSTRUCT-PLACEMENTS 13617 . 15321)) (15323 16081 (ROOMS-NOT-IN-ANY-SUITE 15323 . 16081)) (16083 16340 (FIND-SUITE-CONTAINING 16083 . 16340)) ( 16342 16475 (AUGMENT-SUITE 16342 . 16475)) (16477 16675 (DELETE-ROOM-FROM-SUITE 16477 . 16675)) (18404 18962 (SUITE-MENU 18404 . 18962)) (18964 20790 (INTERACTIVE-LOAD-SUITE 18964 . 20790)) (20792 21194 ( INTERACTIVE-DUMP-SUITE 20792 . 21194)) (21196 22561 (INTERACTIVE-MAKE-SUITE 21196 . 22561)) (22563 22975 (INTERACTIVE-UPDATE-SUITE 22563 . 22975)) (22977 23367 (INTERACTIVE-DELETE-SUITE 22977 . 23367)) (23369 23600 (INTERACTIVE-SHOW-SUITE 23369 . 23600)) (23602 24142 (INTERACTIVE-AUGMENT-SUITE 23602 . 24142)) (24144 24600 (INTERACTIVE-DELETE-ROOM-FROM-SUITE 24144 . 24600)) (24602 25143 (SELECT-SUITE 24602 . 25143)) (25145 25299 (PROMPT-FOR-SUITE-NAME 25145 . 25299))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-SUITES.DFASL b/rooms/ROOMS-SUITES.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..bfe1474e317c241f81c0125ec4db9e22269cfc9c GIT binary patch literal 16445 zcmcJ1d2k%(b?0;sFt|wo1TT;T2ckqu5N9M(B4a@^fyPV&Gr(M&9$XYJ2pDoef&dJF zI-(U#%C=F#9)^4`8qO5BV z|KZa9-h18CJ)k5@sYFFjcYo)5?|b+6;48k`u}C5qnL9T>J(FJu&YfSHKfe?_HMbC4 zoIAfTnGc>qd+^1mHT2R`!;ATa#X}Pd=VzbG&rB8$SwrK|Y<$E#6ir8llV&Ps9U4x> z#||apR_0J5Y97j_(@E=4(u^j|@z7%jy$8)9?esX`4<=J9#AwRK{p9)$NOXnA+ zCSKSZJP?fLC-di?0a*JV-T&y`;J$<1j~(dVe<0k{Z&(R|>-ysfGmg1hBk^oH#jH}gg6+r5Y1>jre!W-) z@)8j+{6w2EkxxT!jQ@t@l-rDz^gVH!vjQ0&*)7yacIF%e-=MwhPKJt zJUzRVUzh-up3Mg*=ce*R@V(5ea^hHVI0P*$`~`a3;zI4jzSkOsr0!@2W>Y+sGqVO1 z(})>LqzxP9d;8WLMa8@|Jh;WX<~>JN(YuBzt`;lSwPNYfG9|7Sw|dvTmx%XyyFZnn zpo|4h1j9HazFOP}eVEKJH%n_MWh712(Ez1cdP6T2+kyu|uv{TBT4kH{W^v>n#)z`6 zfA|x1z1zrdYyg^lrQ#l2xvka7!FZxuxRkNATw9<&pjw+%YjqH2rxEHpLl%stlUb;x z7gCg))JC!hZFItG*VfcV4HT+Ubz;9%gQIX6fkvBsi4{Zmwi6%K9^W)t!38jY9u%&tHg?0Yuf|T&OXE{ck=7lZxq7b{5G@Sel!KBS4{We8{Bw!$CcPC{1$7U)MZirB4Hx8ak8j)<;@{|2;l13VpfaNM~MK>v3a(}3iSWTEr^E(bl6P?3$ z)k=>Ve)#^EJbo;Xe<_c5#fIj{U}CJVgzxpNRj4JzPSPx3s2MPM%n14eed*y;G&6+P zTF7rCVZ@V%sNIMTrsJvIiWVx8$J0Wl*KueK^4~fMpv~y2O2rci`e?<+dYcfWugUeL z_9oRu4{~@mKj6WZMFr5HNo~dm-_Ni>JuM)O)b#&&uJ3nj;M~=ikVjKe%U(7rqZ@jtkpOne#jHcuyX$Ll-n;O{TdOKVs72 zm(f<`e0*IU{Hi+ei$o0akzmt^nj!a)y42?Ls%x5Q|D7q-bsW1kM`A{5z>ErWfOiga z_d8FhgO95No$BCrbs(S~(o|PfKRFjy0cRrJXC%~S85kzbK(M@{;G8#P=jP4@Eq00E zjr!4cwWy7$&Gg=`y7556jtYXa>T&_LXfQl4Oyviy{VNT;#Xn)?vy)}4z%sphRz$s0 zopoR}_703xE_koMhy`t*Ti?p-e!B)h!D-5oH$VYLE~7T<>r_a?zcxX;*6AX@H(-rh zu;wbn06pUF?o~rqV$H5zU}(#6z(xQlWQ1!QbUatB4440YhU=Rx{PEh-I8?^FXdL?#RquQyr!%#3Q zma+RiwUc+=${S={ii&LzBp?4I6IR|xlZ}dcqdHil4hZG;3DtZ9?uz{Oi3mQ2A z*dsO}=CKK7Grs{S;~!LRmMAW0l#f(5*reBWtIkJN=R*+OdKnxI^^FHr*ET-OA8b-x z4XTS`(gu4iic2)uUEg&u>GrAosp;A2rRllZQ2zP(iP@?Ag4elz%lAO9KBnD_>9<_G z;)V8h{u;y!{0`hQ4NAtF1P4Y4Y61Ex!z zjpsoR&<8X*HCsuRrrwjZGmD{({*Umj+33STsiMua8shn^nIx^L>EID&z7sAn`R(WO zgU3x^z7?+G*Te2w!on;wP{l1`!!ud9%3|7uVy?vaN4cd4R@$pt>$B=$QXTjOP=(CB zLlvGMf_6ewlr#6M&IfqXkA%T~)P~{pu+74#R)gvkk^gh>m_7i9T6JD6uFJ?O_9(Ua zDdG^=8ln+BDJ*4%TrXT$N$jmIiu~4V5Z9IY?k_<2FUofeXO{*Ms3`*_EV$d@K!C(a>-c)?;;Xth~E;Nrjr zk?LE%Hr7adDse`%%m_c#zc3?c0TNKSN-Us_hyiUq{yEtI;Udn8k2~lA6r^=r0^$oM z)_)hP?O2g`sK*N!aHA2~iiH4<*ZtfaaA(4`O93N!sfPzjraUH4-x;Lr6zh zIVXvuI;it))kBZhR3AOQhM_QFoK~W}RL2Ej!DspLzo+DjxKtV(4(%rWLNmapRr94{ zhr#Su<~1-RQrA;22rn+4Efx3MoLXj1Vpn(kgU?Nag(qj`7W2X9re~+-o?CqA@16fu zA5z_&vp(O>vEDY{YD-Y3cRr*x-&uafLP&Iz2i@F-^!AV$4Iv8~&!w|nOn~>11gFdp zCnN1#BoXp`)#tA;RQ3t63ijz+Az>J%?Kz3Dz5?@+Fa)3X&BCqNhrZi|J4087E-gQ! z-AQQ2gx6F;7yeitNJ`7`E2&rP*Y7`OzpQLY=-QF9KUopaZ%|lixvjt`CHa@l*y@me zd-?j{``jW6pS{H(tO9^Lh1-cMiA&2-Vs;yVmHk7yu50w8^RmZz+R8QvK|Ccmq`2uf zZT_AnCE5Ob3B>VbU+4?eM;Xxs_i(=cKrhE0pI=Q(O?MO(Fz$t1?{s5+^Mv|c!`u+fO zHsG>?0+o1f7ztPDloj7ZZ;PGPE3b*HD9!vOz*aSCWK%C<$$B$lSjZ_E@x*DufQ`iC z=xB(hDIl{b-Pp=te6tbFt?52WlZI`UB?hj;qFS|z(Aqzvks4(beD8yX0fFf-k<-r7 z$7IBp`O)<-da8M!8Z6#88qdX?rAZ3bb=mts%|wQvrK)JT?#)-NiYI#uk0*f@bAO(3lHgtZTucPEjhj!cw{<(-~ z1Nb=T2;T$#2f+cH~>g z@A6AD(&7Kz>cY)S6E~Ut4gM{_yu|Mm?y}T9sNHoXqc_Qdar~XZH-=KXZ+|^iXn*<^ zN!FhZ##lz4zBPEaa3|^i?(&zCx__l3sqy5GR(2*z2|cOnTUVDm26g?&?d8oLX-CHg z$vdgL%Rd}yss?T_H7Zi$(_j7=|JiPKP08V9%XYYl{JWv@kh8*-8%)ZOIc^c7?#2t4 zq~7IXw6^TV)dAAZ>0Hdr^3VX0@}Kc>GLx71b^rr8mH|c1jLw_jUtm`M5?=Fk;!5d)~+P2_9D{R41%QsW{2g{{o z6GPlw02@S`D%k)zXDrbm2Zu=2Dk{ zqB?qLs_$|wuP{(M2Y9MsOfuF@@qRGc4Ok4Rsq^a(4abXw?-xGDakol4VE zGDOC6oZZ5w%jYO$#kE2Q-||uD!A#C!yOAqvL#*p0bs7i{j&sueA^6VrP`<(CMKp?R z0&??R1<|ko$weSl10ftuXQT8UfSp3(6*^4=R}aGD?KW2SdK_Ljwd|yB(Z($X^2l3* z!XxC3{#VaPIH8;~#NEQ6-}OHIWrvf)Oi1wVbcS-6xP6rf#|q`r>7J^`i88)F-NgiI zl)(0KJvUy~A5r0IircTNlz8P@uvft7Wg;?YH)7h@)!1@3w@5d?${m9UkNqor%qzI` zCtTgtt`sg#AGtcXyjgY-sbeimJu6We%Hw0aMti$BC(^-9((7budhJY2!5(P*77vOs z@T<04<$}Y|-88 z1q;bcrbj3djZ6vs&e5^_A23@3u3h8(s8QoGhmK86)m15gWPhwthSt0U7RD*E_?|hYnQd8v*Y_ofTQL}JYw#}YgG)<+irTH z%OMeLq6x95OrDAJx;w<@FT(@+= z2!_L9>iHE+VB9Yd5*%z&^DmXI1#lIK6bh;%fQ(&IgOtBhOM(l6*Nc8I4jcrkP_fHz zIQ+f+tU1DE|RDqOFSmjZ3b0Fc_r*vWvutO)b>YEO?g z^PWfFjlCI9?7q3&mY@*-+bpv~BCZtg|0s5o1^kA{vB>;w)(^crR#XMceEU%RRsn8a z;e)|nO)M7%$+B~IdL7?n+G*?bI$5QntE%EFV2^hu)^o-VKOZFCNTzn*B|q`l9fI#| z237KTeldXom8o_0IC9AzqS>mO6IE6%F~NT%sYA$QrlR!uk5%r3LM=|VPaS@e3H(h? zVQCMrjr3h^piwu#F>>l`!+(bus1F5M16jIh6eaVU%yIA0@b7{tJpI)49k=%y^~O_? z#4r^Q(OshN74Gf(stkIbA5G)@*qcIXl*@rIP$GpQBjW^wJuir)eQh@z0n5^ zib9rhu&S}r(YgpW3$Q)Rsgu=0>}SZHcv2^^HeFm_$|5kd0Klr0(8_He0A-NDXTnhV zR!!2#P_odcQPlQ?7<(c7I+lPv_7N4DwIjDFS22j69aj=B4<*_e96FEx42Ns$%*458 zrY6X_=kS{=n^=t_-Vtp_As?wqCjxe^6)5e~U{i-wuIj+`B5~7RPJ3y;Pq833bjx8r zd0piIE^+2-bZosg^Eg?<7qq8s<}pO6tUMzj!H_+WX=Q%|R`xKa_NNHG)5iljKYy`c zx79ileorp)8+86TY~jh@vsA)ncn`m7k&*fJ6TrL89CJPBvcukS5M8a_F2}hRC40Gk zhL>0#lSh^xnIZWy`H_A~zQnU$eu%$PTcnXww%U8dU?ZU92vKpGk#%U;SEk{e-m3+u zW7e*JbnHs<75nu{;c|kfkRSIBL}Lh|G2|p>?+`IYKnzDbg$Lj%H6ee8D-k3=p94L=**?< zPBmKPVubux9YM?@t?g&Z-tmW2c)c2}SEJf4P<9u@MUoB-9%lpJiG8TUhh;vZ5U^C- z=?V{Lyd?P!IkKzoAku3@=+kV7z74e8oT3WWbi@Ef1v|;h5rn??*OP@wn#n#htJkZ8 z)#?CN-^tLs@-+t7!@W0{YBvp!XW){Wak&+XiyFjfkNGQDzXC*;Q2qxQj8}O_l)3QN z<*IgdaHBfVpu&EMPsRbjg9h*4D-WjEn(b{DMU4Y7kJP!lRajg9eX{iqqJX5|S<(0| zS8Y)TH>d-3d;ug^XWsM;^M1KNfeJLFK;fRk0Z%O>AaX)XxghyAuG)|3xRt3U7Y|;* z1PUU#8id?I6yK8H2R)dJg~Xw!+DGot)H9Xii#vGoL~t>`6r4L{UqRunYJy!&r071o zpZ(QZYq*cgE~)OM*f=~tg_`$DfS4)%rVPc@+F`|A_N=8sz8qU~qK}{gcvS0B`h24Z zh^B0QacOShv!Or+a?QBn&IIa>X+JMHPA%Y~!y(Ae9YNdITZOsjK9d4aU*18*tqDqK z5%%R%~W851=K}B$Gp2{n5?fC-VeO6#Ty%a9}-DcV0(EnxcV3WOXmM*IL=@7ke zOK!yF$wI04DHF<7GS}5H&J%UA7_-R|i@~pBsLzp_NYcbqEU>otD8!Y>(810vXk~4V zzD*r(RL8wFN5^5IPC|h_f0DGo_mA;o=h#ijFSJ#y#_`V3w6*g4bXy}oS-rIdJ@4CB z<2TNnnf>a=_{WaO%@}lUTm9;wq%3%8Mr8agiHSI?c+!uJrEE!`rvS`^2`JDDAyYG{ zjvrIUzl`q|AZ!dLa?~6{rCxt(A6o11HvkCPP+AO~MaBCKRel;l?%6I4$nKyzFRo+* zsuM8AWLmx_ek!~7Q|uigC3_tfkbz|V{VrpTCb52aVU(rr!%ix3i~TMMrUL7E#&SB# z@3g$Wx*}DpJi%k`;TKDah&y;kF%*@X!}L-;mS0Ed?u4d0^rEX9-#=yX;0y|78XAmf zGz@}7Ov^fjZ{$l-oX9xAy`fjP%6`7dbgTIi%#cjDd zA&A?bE^#2dWo$I#t+kqy8ZUuQ_Ym=7ZNBl(6So_j~0u!RE`fW&u0&h_FiJobbXB5FIRx}l1$ z-mpa*L0yn)5Qp&*1?j)+9I?Y;IAmV^U?pIFad_sb$|XQoOXet*3fGL%-!McipSBU% z8`~PWv<>@o_E$8=QG!z%G;Gp4^&V^P;KTY$41hD`I*j>SzA=|I`E8oLsj-!wHSPQv z6K*E)m#gI%v$OYI_?wV@##K~R8Q%GCsM0tnItr@MmHn=};X31c5XgT4WMr0dT(8S$~YJT;S*U%2NC!T18>J!^bN% z8_jf$=lNcZeRugup%*KcqbpqrPjZ*@ee2?-%lQnASj2PB=ONuo?yc)!JDoqtjFNIvneBjmZ+f1DwgVUNiW$->V|Iq>B=bw*Po z)yKK-y(~^eHxHvq?aM@U{^J=AfLh@M6Cu7)D&B9D3ydb<7CF@&2(lOF&gF&i!l6>} zDGT*TlS{56czTW^@e5Y?!UK_+>B+P7$CQiH$XmkYI3IkjkjE7Ig1%-Ot?<6gcl1dK{4I(%_HP*Eu?|XZ{9_x`U%=bn-8hM2f-#ai0W{q zj*=e^#r1^-HH{l4lFIR_$M9!}Y*le`!6_~=n+o4oDn9DCVr6dN!=+32p5P~y@U)`l z*PbKPxM1}Vp3(+9PXW)puC5V0SEP^0m9e@Al zl)`Ov>F7!!RSr(TQ^&(O0n`mvI`hE30PLgpoWnlP3AlVXzOp$kJSO}W7c;=P`&2>4 znTe9B?iTz)YJ3-1j$J<0!Ez&~)mA<&KUl6qxME6T3LF|oP7c)J4*cbUjTpJ)I68;5 zI0m7?Kx7(-yg+V*U3Q^)%Pu*M|z#CynQGc6W79|w+2y@0D-yjyaJHn|Rw_pkFHET5UN5eH4m)O^1Coy=&%Q?vQ! zWV=HQ$+z@J8A#WAI0GQ|<By*Q9$`KAN|_di5uTw^4^gAxZ@YGMmnQc z5~!Sx3y7cZmjvN2QdLKTG}$+ljSRqmPs86IG+5;G2U93*?dF*3i~Ow|JdIlWPq^V= zAw2WrFRUrnKq*Q#J`lq#LNy|=5m=~vaCdMlzcBYa{@(x==I0hBDC&fctoZ}_`2qd> R3;Ovh-*@oPfBoZ+|3CA@pgRBn literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-TEXT b/rooms/ROOMS-TEXT new file mode 100644 index 00000000..96160854 --- /dev/null +++ b/rooms/ROOMS-TEXT @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:27:41"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-TEXT.;2| 16532 IL:|previous| IL:|date:| "17-Aug-90 13:31:54" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-TEXT.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-TEXTCOMS) (IL:RPAQQ IL:ROOMS-TEXTCOMS ((FILE-ENVIRONMENTS IL:ROOMS-TEXT) (IL:P (EXPORT '(*DEFAULT-TEXT-FONT* MAKE-TEXT DISPLAY-TEXT DEF-TEXT-SHADOWS SET-TEXT-STRING))) (IL:STRUCTURES TEXT TEXT-SHADOW) (IL:VARIABLES *DEFAULT-TEXT-FONT* DEFAULT-TEXT-FONT--SMALL-SCREEN DEFAULT-TEXT-FONT--LARGE-SCREEN SMALL-SCREEN-WIDTH) (IL:FUNCTIONS MAKE-TEXT UPDATE-TEXT-CACHES COMPUTE-TEXT-DIMEMSIONS MAXIMIZE MINIMIZE DISPLAY-TEXT SET-TEXT-STRING SET-DEFAULT-TEXT-FONT) (IL:P (SET-DEFAULT-TEXT-FONT)) (IL:FUNCTIONS (IL:* IL:|;;| "for back compatibility: buttons & pe's still call these two") TEXT-%WIDTH TEXT-%HEIGHT) (IL:VARIABLES *TEXT-SHADOWS* *TEXT-SHADOW-FACTOR*) (IL:FUNCTIONS GET-TEXT-SHADOWS GET-TEXT-SHADOWS-INTERNAL MAKE-TEXT-SHADOWS EXTERNALIZE-TEXT-SHADOWS INTERNALIZE-TEXT-SHADOWS INTERNALIZE-TEXT-SHADOWS-INTERNAL ) (IL:* IL:|;;| "a definer for shadows") (IL:DEFINE-TYPES IL:TEXT-SHADOWS) (IL:FUNCTIONS DEF-TEXT-SHADOWS) (IL:TEXT-SHADOWS NIL :ARK))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-TEXT :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(*DEFAULT-TEXT-FONT* MAKE-TEXT DISPLAY-TEXT DEF-TEXT-SHADOWS SET-TEXT-STRING)) (DEFSTRUCT (IL:* IL:|;;;| "specifies a bit of text for display") (TEXT (:CONSTRUCTOR MAKE-TEXT-INTERNAL) (:PRINT-FUNCTION (LAMBDA (TEXT STREAM DEPTH) (FORMAT STREAM "#" (TEXT-STRING TEXT))))) (STRING "" :TYPE STRING) (IL:* IL:|;;| "the text to print. use SET-TEXT-STRING to change this field.") (POSITION (MAKE-POSITION 0 0) :TYPE CONS) (IL:* IL:|;;| "where to print it") (ALIGNMENT :LEFT-BOTTOM :TYPE (IL:* IL:|;;| "how to align it") (MEMBER :LEFT-BOTTOM :LEFT-TOP :CENTER :RIGHT-BOTTOM :RIGHT-TOP)) (IL:* IL:|;;| "how to align it relative to POSITION") (FONT *DEFAULT-TEXT-FONT*) (IL:* IL:|;;| "font to use") (SHADOWS (MAKE-TEXT-SHADOWS *DEFAULT-TEXT-FONT*) :TYPE LIST) (IL:* IL:|;;| "a list of TEXT-SHADOW structures") (IL:* IL:|;;;| "caches to speed redisplay") (%IMAGE NIL :TYPE BITMAP) (%MASK NIL :TYPE BITMAP)) (DEFSTRUCT TEXT-SHADOW (IL:* IL:|;;;| "a specification of a call to IL:BITBLT. a list of these is used to achieve special effects when displaying text. the most common effect is that of shadowed text, hence the name TEXT-SHADOW.") (IL:* IL:|;;| "offset for this BLT") (DX 0 :TYPE INTEGER) (DY 0 :TYPE INTEGER) (IL:* IL:|;;| "args to IL:BITBLT") (SOURCE-TYPE 'IL:INPUT :TYPE (MEMBER IL:INPUT IL:INVERT IL:TEXTURE IL:MERGE)) (OPERATION 'IL:PAINT :TYPE (MEMBER IL:PAINT IL:REPLACE IL:ERASE IL:INVERT)) (TEXTURE 0 :TYPE TEXTURE)) (DEFVAR *DEFAULT-TEXT-FONT* NIL) (DEFGLOBALPARAMETER DEFAULT-TEXT-FONT--SMALL-SCREEN (IL:FONTCREATE 'IL:HELVETICA 10 'IL:BOLD)) (DEFGLOBALPARAMETER DEFAULT-TEXT-FONT--LARGE-SCREEN (IL:FONTCREATE 'IL:HELVETICA 18 'IL:BOLD)) (DEFGLOBALPARAMETER SMALL-SCREEN-WIDTH 1400) (DEFUN MAKE-TEXT (&KEY STRING (POSITION (MAKE-POSITION 0 0)) (ALIGNMENT :LEFT-BOTTOM) (FONT *DEFAULT-TEXT-FONT*) SHADOWS) (IL:* IL:|;;| "check args") (UNLESS (IL:POSITIONP POSITION) (ERROR "~S not a position" POSITION)) (ECASE ALIGNMENT ((:LEFT-BOTTOM :LEFT-TOP :CENTER :RIGHT-BOTTOM :RIGHT-TOP) )) (CHECK-TYPE FONT FONT) (LET ((TEXT (MAKE-TEXT-INTERNAL :STRING STRING :POSITION POSITION :ALIGNMENT ALIGNMENT :FONT FONT :SHADOWS (INTERNALIZE-TEXT-SHADOWS SHADOWS)))) (IL:* IL:|;;| "fill in the caches") (UPDATE-TEXT-CACHES TEXT) TEXT)) (DEFUN UPDATE-TEXT-CACHES (TEXT) (LET* ((FONT (TEXT-FONT TEXT)) (STRING-WIDTH (IL:STRINGWIDTH (TEXT-STRING TEXT) FONT)) (FONT-HEIGHT (IL:FONTHEIGHT FONT)) (TEMP-BITMAP (IL:BITMAPCREATE STRING-WIDTH FONT-HEIGHT))) (LET ((DSP (IL:LOADTIMECONSTANT (IL:DSPCREATE)))) (IL:* IL:|;;| "first put string into a temporary bitmap") (IL:DSPDESTINATION TEMP-BITMAP DSP) (IL:DSPFONT FONT DSP) (IL:MOVETO 0 (IL:FONTDESCENT FONT) DSP) (PRINC (TEXT-STRING TEXT) DSP)) (MULTIPLE-VALUE-BIND (WIDTH HEIGHT X-OFFSET Y-OFFSET) (COMPUTE-TEXT-DIMEMSIONS TEXT STRING-WIDTH) (LET* ((OLD-IMAGE (TEXT-%IMAGE TEXT)) (IMAGE (IF (AND OLD-IMAGE (= HEIGHT (IL:BITMAPHEIGHT OLD-IMAGE)) (= WIDTH (IL:BITMAPWIDTH OLD-IMAGE))) (IL:* IL:|;;| "OK to re-use bitmap") (PROGN (IL:BLTSHADE IL:WHITESHADE OLD-IMAGE 0 0 WIDTH HEIGHT) OLD-IMAGE) (IL:BITMAPCREATE WIDTH HEIGHT))) (SHADOWS (GET-TEXT-SHADOWS TEXT)) (OLD-MASK (TEXT-%MASK TEXT)) (MASK (WHEN (CDR SHADOWS) (IL:* IL:\;  "don't need mask for simple shadows") (IF (AND OLD-MASK (= HEIGHT (IL:BITMAPHEIGHT OLD-MASK)) (= WIDTH (IL:BITMAPWIDTH OLD-MASK))) (IL:* IL:|;;| "OK to re-use bitmap") (PROGN (IL:BLTSHADE IL:WHITESHADE OLD-MASK 0 0 WIDTH HEIGHT) OLD-MASK) (IL:BITMAPCREATE WIDTH HEIGHT))))) (DOLIST (SHADOW (GET-TEXT-SHADOWS TEXT)) (IL:BITBLT TEMP-BITMAP 0 0 IMAGE (+ (TEXT-SHADOW-DX SHADOW) X-OFFSET) (+ (TEXT-SHADOW-DY SHADOW) Y-OFFSET) STRING-WIDTH FONT-HEIGHT (TEXT-SHADOW-SOURCE-TYPE SHADOW) (TEXT-SHADOW-OPERATION SHADOW) (TEXT-SHADOW-TEXTURE SHADOW)) (WHEN MASK (IL:BITBLT TEMP-BITMAP 0 0 MASK (+ X-OFFSET (TEXT-SHADOW-DX SHADOW)) (+ Y-OFFSET (TEXT-SHADOW-DY SHADOW)) STRING-WIDTH FONT-HEIGHT 'IL:SOURCE 'IL:PAINT))) (SETF (TEXT-%IMAGE TEXT) IMAGE) (SETF (TEXT-%MASK TEXT) MASK) IMAGE)))) (DEFUN COMPUTE-TEXT-DIMEMSIONS (TEXT STRING-WIDTH) (IL:* IL:|;;;| "compute & return width, height & offsets of TEXT, taking shadows into consideration.") (LET* ((SHADOWS (GET-TEXT-SHADOWS TEXT)) (MAX-DX (MAXIMIZE (SHADOW SHADOWS) (TEXT-SHADOW-DX SHADOW))) (MIN-DX (MINIMIZE (SHADOW SHADOWS) (TEXT-SHADOW-DX SHADOW))) (MAX-DY (MAXIMIZE (SHADOW SHADOWS) (TEXT-SHADOW-DY SHADOW))) (MIN-DY (MINIMIZE (SHADOW SHADOWS) (TEXT-SHADOW-DY SHADOW)))) (VALUES (IL:* IL:|;;| "width") (+ STRING-WIDTH MAX-DX (- MIN-DX)) (IL:* IL:|;;| "height") (+ (IL:FONTHEIGHT (TEXT-FONT TEXT)) MAX-DY (- MIN-DY)) (IL:* IL:|;;| "x-offset") (- MIN-DX) (IL:* IL:|;;| "y-offset") (- MIN-DY)))) (DEFMACRO MAXIMIZE ((VAR LIST) FORM) `(LET ((SI::$MAX-VALUE$ NIL) (SI::$VALUE$ NIL)) (DOLIST (,VAR ,LIST SI::$MAX-VALUE$) (SETQ SI::$VALUE$ ,FORM) (UNLESS (AND SI::$MAX-VALUE$ (> SI::$MAX-VALUE$ SI::$VALUE$)) (SETQ SI::$MAX-VALUE$ SI::$VALUE$))))) (DEFMACRO MINIMIZE ((VAR LIST) FORM) `(LET* ((SI::$MIN-VALUE$ NIL) (SI::$VALUE$ NIL)) (DOLIST (,VAR ,LIST SI::$MIN-VALUE$) (SETQ SI::$VALUE$ ,FORM) (UNLESS (AND SI::$MIN-VALUE$ (< SI::$MIN-VALUE$ SI::$VALUE$)) (SETQ SI::$MIN-VALUE$ SI::$VALUE$))))) (DEFUN DISPLAY-TEXT (TEXT DESTINATION &KEY SCALE MASK-ONLY) (IL:* IL:|;;;| "print TEXT, a TEXT structure, to DESTINATION, a valid destination for IL:BITBLT.") (LET* ((POSITION (TEXT-POSITION TEXT)) (ALIGNMENT (TEXT-ALIGNMENT TEXT)) (IMAGE (TEXT-%IMAGE TEXT)) (WIDTH (IL:BITMAPWIDTH IMAGE)) (HEIGHT (IL:BITMAPHEIGHT IMAGE)) (SCALED-X (IF SCALE (SCALE-X (POSITION-X POSITION) SCALE) (POSITION-X POSITION))) (SCALED-Y (IF SCALE (SCALE-Y (POSITION-Y POSITION) SCALE) (POSITION-Y POSITION))) (X-COORD (ECASE ALIGNMENT ((:LEFT-BOTTOM :LEFT-TOP) SCALED-X) ((:RIGHT-BOTTOM :RIGHT-TOP) (- SCALED-X WIDTH)) (:CENTER (- SCALED-X (FLOOR WIDTH 2))))) (Y-COORD (CASE ALIGNMENT ((:LEFT-BOTTOM :RIGHT-BOTTOM) SCALED-Y) ((:LEFT-TOP :RIGHT-TOP) (- SCALED-Y HEIGHT)) (:CENTER (- SCALED-Y (FLOOR HEIGHT 2))))) (MASK (TEXT-%MASK TEXT))) (WHEN MASK (IL:* IL:\; "erase the mask") (IL:BITBLT MASK 0 0 DESTINATION X-COORD Y-COORD WIDTH HEIGHT 'IL:INPUT (IF MASK-ONLY 'IL:PAINT 'IL:ERASE))) (UNLESS MASK-ONLY (IL:* IL:\; "paint in the image") (IL:BITBLT IMAGE 0 0 DESTINATION X-COORD Y-COORD WIDTH HEIGHT 'IL:INPUT 'IL:PAINT)))) (DEFUN SET-TEXT-STRING (TEXT STRING) (IL:* IL:|;;;| "call this to change the string of a TEXT object") (SETF (TEXT-STRING TEXT) STRING) (IL:* IL:|;;| "update all caches") (UPDATE-TEXT-CACHES TEXT) (IL:* IL:|;;| "return the string") STRING) (DEFUN SET-DEFAULT-TEXT-FONT () (IL:* IL:|;;;| "called when screen size changes") (FLET ((DEFAULT-FONT (SCREEN-WIDTH) (IF (> SCREEN-WIDTH SMALL-SCREEN-WIDTH) DEFAULT-TEXT-FONT--LARGE-SCREEN DEFAULT-TEXT-FONT--SMALL-SCREEN))) (IL:* IL:|;;|  "if user hasn't changed *DEFAULT-TEXT-FONT* then set it proportional to the screen size.") (IF (OR (NULL *DEFAULT-TEXT-FONT*) (EQ (DEFAULT-FONT (REGION-WIDTH OLD-WHOLESCREEN)) *DEFAULT-TEXT-FONT*)) (SETQ *DEFAULT-TEXT-FONT* (DEFAULT-FONT IL:SCREENWIDTH)) *DEFAULT-TEXT-FONT*))) (SET-DEFAULT-TEXT-FONT) (DEFMACRO TEXT-%WIDTH (TEXT) `(IL:BITMAPWIDTH (TEXT-%IMAGE ,TEXT))) (DEFMACRO TEXT-%HEIGHT (TEXT) `(IL:BITMAPHEIGHT (TEXT-%IMAGE ,TEXT))) (DEFGLOBALVAR *TEXT-SHADOWS* (MAKE-HASH-TABLE :TEST 'EQ) "Cache of default shadows indexed by font.") (DEFPARAMETER *TEXT-SHADOW-FACTOR* 10 "Text shadows will use the inverse of this number to determine what fraction of the font size should be shadow." ) (DEFUN GET-TEXT-SHADOWS (TEXT) (LET ((SHADOWS (TEXT-SHADOWS TEXT))) (ETYPECASE SHADOWS ((MEMBER T) (GET-TEXT-SHADOWS-INTERNAL (TEXT-FONT TEXT))) (SYMBOL (IL:* IL:|;;| "user defined shadows") (LET ((INTERNAL (GETHASH SHADOWS *TEXT-SHADOWS*))) (OR INTERNAL (ERROR "No text shadows named ~S" SHADOWS)))) (CONS SHADOWS)))) (DEFUN GET-TEXT-SHADOWS-INTERNAL (FONT) (IL:* IL:|;;| "cache default shadows per font") (OR (GETHASH FONT *TEXT-SHADOWS*) (SETF (GETHASH FONT *TEXT-SHADOWS*) (MAKE-TEXT-SHADOWS FONT)))) (DEFUN MAKE-TEXT-SHADOWS (FONT &OPTIONAL (FACTOR *TEXT-SHADOW-FACTOR*)) (LIST (LET ((DEPTH (CEILING (IL:FONTHEIGHT FONT) FACTOR))) (MAKE-TEXT-SHADOW :DX DEPTH :DY (- DEPTH) :OPERATION 'IL:PAINT)) (MAKE-TEXT-SHADOW :DY 1) (MAKE-TEXT-SHADOW :DX 1) (MAKE-TEXT-SHADOW :DY -1) (MAKE-TEXT-SHADOW :DX -1) (MAKE-TEXT-SHADOW :OPERATION 'IL:ERASE))) (DEFUN EXTERNALIZE-TEXT-SHADOWS (SHADOWS) (ETYPECASE SHADOWS (SYMBOL SHADOWS) (CONS (MAPCAR #'(LAMBDA (SHADOW) (LIST :DX (TEXT-SHADOW-DX SHADOW) :DY (TEXT-SHADOW-DY SHADOW) :OPERATION (TEXT-SHADOW-OPERATION SHADOW) :SOURCE-TYPE (TEXT-SHADOW-SOURCE-TYPE SHADOW) :TEXTURE (TEXT-SHADOW-TEXTURE SHADOW))) SHADOWS)))) (DEFUN INTERNALIZE-TEXT-SHADOWS (SHADOWS) (ETYPECASE SHADOWS (SYMBOL (IL:* IL:|;;| "named shadows -- handled by GET-TEXT-SHADOWS") SHADOWS) (CONS (IL:* IL:|;;| "explitly specified shadows") (INTERNALIZE-TEXT-SHADOWS-INTERNAL SHADOWS)))) (DEFUN INTERNALIZE-TEXT-SHADOWS-INTERNAL (SHADOWS) (MAPCAR #'(LAMBDA (SHADOW) (IF (TEXT-SHADOW-P SHADOW) SHADOW (IL:* IL:|;;| "parse shadow from property list") (LET ((DX (GETF SHADOW :DX 0)) (DY (GETF SHADOW :DY 0)) (OPERATION (GETF SHADOW :OPERATION 'IL:PAINT)) (SOURCE-TYPE (GETF SHADOW :SOURCE-TYPE 'IL:INPUT)) (TEXTURE (GETF SHADOW :TEXTURE 0))) (IL:* IL:|;;| "check the types (defstruct won't)") (CHECK-TYPE DX INTEGER) (CHECK-TYPE DY INTEGER) (CHECK-TYPE OPERATION (MEMBER IL:PAINT IL:REPLACE IL:ERASE IL:INVERT)) (CHECK-TYPE SOURCE-TYPE (MEMBER IL:INPUT IL:INVERT IL:TEXTURE IL:MERGE)) (CHECK-TYPE TEXTURE TEXTURE) (IL:* IL:|;;| "make a shadow") (MAKE-TEXT-SHADOW :DX DX :DY DY :OPERATION OPERATION :SOURCE-TYPE SOURCE-TYPE :TEXTURE TEXTURE)))) SHADOWS)) (IL:* IL:|;;| "a definer for shadows") (DEF-DEFINE-TYPE IL:TEXT-SHADOWS "Text Shadows" :UNDEFINER (LAMBDA (NAME) (REMHASH NAME *TEXT-SHADOWS*))) (DEFDEFINER DEF-TEXT-SHADOWS IL:TEXT-SHADOWS (NAME &REST EXTERNAL-FORM) `(SETF (GETHASH ',NAME *TEXT-SHADOWS*) (INTERNALIZE-TEXT-SHADOWS-INTERNAL ',EXTERNAL-FORM))) (DEF-TEXT-SHADOWS NIL NIL) (DEF-TEXT-SHADOWS :ARK (:OPERATION IL:ERASE) (:DX -1 :DY 1)) (IL:PUTPROPS IL:ROOMS-TEXT IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (3805 4523 (MAKE-TEXT 3805 . 4523)) (4525 7611 (UPDATE-TEXT-CACHES 4525 . 7611)) ( 7613 8652 (COMPUTE-TEXT-DIMEMSIONS 7613 . 8652)) (9350 11046 (DISPLAY-TEXT 9350 . 11046)) (11048 11337 (SET-TEXT-STRING 11048 . 11337)) (11339 12027 (SET-DEFAULT-TEXT-FONT 11339 . 12027)) (12513 12943 ( GET-TEXT-SHADOWS 12513 . 12943)) (12945 13170 (GET-TEXT-SHADOWS-INTERNAL 12945 . 13170)) (13172 13648 (MAKE-TEXT-SHADOWS 13172 . 13648)) (13650 14321 (EXTERNALIZE-TEXT-SHADOWS 13650 . 14321)) (14323 14638 (INTERNALIZE-TEXT-SHADOWS 14323 . 14638)) (14640 15918 (INTERNALIZE-TEXT-SHADOWS-INTERNAL 14640 . 15918))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-TEXT.DFASL b/rooms/ROOMS-TEXT.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..0a6719a997fbb2feb7b713f67037a1ac2fd974d8 GIT binary patch literal 15050 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 Qx9RgsjY8u_{OZ;J1H$OgumAu6 literal 0 HcmV?d00001 diff --git a/rooms/ROOMS-WINDOW-HIDER b/rooms/ROOMS-WINDOW-HIDER new file mode 100644 index 00000000..a69a0045 --- /dev/null +++ b/rooms/ROOMS-WINDOW-HIDER @@ -0,0 +1,17 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:26:33"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-WINDOW-HIDER.;2| 30816 IL:|previous| IL:|date:| "17-Aug-90 13:34:55" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-WINDOW-HIDER.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-WINDOW-HIDERCOMS) (IL:RPAQQ IL:ROOMS-WINDOW-HIDERCOMS ((FILE-ENVIRONMENTS IL:ROOMS-WINDOW-HIDER) (IL:P (EXPORT '(HIDE-WINDOW UN-HIDE-WINDOW WINDOW-HIDDEN? ALL-WINDOWS LOST-WINDOWS)) (REQUIRE "ROOMS")) (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:FILES (IL:LOADCOMP T) IL:WINDOW IL:FILEIO IL:LLDISPLAY IL:TTYIN )) (IL:VARIABLES *HIDDEN-WINDOWS*) (IL:FUNCTIONS ALL-WINDOWS LOST-WINDOWS) (IL:FUNCTIONS HIDE-ALL-WINDOWS HIDE-WINDOW HIDE-WINDOW-INTERNAL UN-HIDE-WINDOW UN-HIDE-WINDOW-INTERNAL DO-TOTOP-FUNCTIONS WINDOW-HIDDEN? %WINDOW-HIDDEN?) (IL:FNS SHAPEW1 \\CLOSEW1 MOVEW \\INTERNALTOTOPW WFROMMENU RESHOWTITLE \\RESHOWBORDER1 TTYIN.SETUP) (IL:GLOBALVARS IL:LAMBDASPLST IL:\\EM.DISPINTERRUPT IL:\\SCREENBITMAPS IL:\\TTYIN.LAST.FONT IL:\\TTYIN.LAST.COMMENTFONT) (EVAL-WHEN (LOAD) (IL:P (IL:MOVD 'SHAPEW1 'IL:SHAPEW1) (IL:MOVD '\\CLOSEW1 'IL:\\CLOSEW1) (IL:MOVD 'MOVEW 'IL:MOVEW) (IL:MOVD '\\INTERNALTOTOPW 'IL:\\INTERNALTOTOPW) (IL:MOVD 'WFROMMENU 'IL:WFROMMENU) (IL:MOVD 'RESHOWTITLE 'IL:RESHOWTITLE) (IL:MOVD '\\RESHOWBORDER1 'IL:\\RESHOWBORDER1) (IL:MOVD 'TTYIN.SETUP 'IL:TTYIN.SETUP))) (IL:ADVISE IL:ATTACHWINDOW))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-WINDOW-HIDER :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(HIDE-WINDOW UN-HIDE-WINDOW WINDOW-HIDDEN? ALL-WINDOWS LOST-WINDOWS)) (REQUIRE "ROOMS") (IL:DECLARE\: IL:EVAL@COMPILE IL:DONTCOPY (IL:FILESLOAD (IL:LOADCOMP T) IL:WINDOW IL:FILEIO IL:LLDISPLAY IL:TTYIN) ) (DEFGLOBALVAR *HIDDEN-WINDOWS* (MAKE-HASH-TABLE :TEST 'EQ)) (DEFUN ALL-WINDOWS (&OPTIONAL INCLUDE-HIDDEN?) (IL:* IL:|;;;| "returns a list of all the window groups in bottom first order.") (LET (RESULT MAIN-WINDOW) (DOLIST (WINDOW (IL:OPENWINDOWS T) RESULT) (PUSHNEW (MAIN-WINDOW WINDOW) RESULT :TEST 'EQ)) (WHEN INCLUDE-HIDDEN? (MAPHASH #'(LAMBDA (WINDOW TRUE) (PUSHNEW (MAIN-WINDOW WINDOW) RESULT :TEST 'EQ)) *HIDDEN-WINDOWS*)) RESULT)) (DEFUN LOST-WINDOWS () (IL:* IL:|;;;| "returns the subset of all existing windows which are not in any room.") (IL:* IL:|;;;| "as UPDATE-PLACEMENTS guarentees us that all un-hidden windows belong to a room, we know that all lost windows must be hidden. ") (UPDATE-PLACEMENTS) (WITH-COLLECTION (DOLIST (WINDOW (ALL-WINDOWS T)) (UNLESS (FIND-ROOMS-CONTAINING WINDOW) (COLLECT WINDOW))))) (DEFUN HIDE-ALL-WINDOWS () (DOLIST (WINDOW (NREVERSE (ALL-WINDOWS))) (HIDE-WINDOW WINDOW))) (DEFUN HIDE-WINDOW (WINDOW) (LET ((WINDOW (MAIN-WINDOW WINDOW))) (UNLESS (WINDOW-HIDDEN? WINDOW) (LET ((ICON (WINDOW-ICON WINDOW))) (WHEN ICON (HIDE-WINDOW-INTERNAL ICON))) (HIDE-WINDOW-INTERNAL WINDOW) (IL:* IL:|;;| "return T if we succeded") T))) (DEFUN HIDE-WINDOW-INTERNAL (WINDOW) (UNLESS (WINDOW-HIDDEN? WINDOW) (DOLIST (ATTACHED-WINDOW (IL:WINDOWPROP WINDOW 'IL:ATTACHEDWINDOWS)) (IL:* IL:|;;| "recursively hide attached windows") (HIDE-WINDOW-INTERNAL ATTACHED-WINDOW)) (WHEN (IL:OPENWP WINDOW) (IL:* IL:|;;| "save the image") (IL:\\CLOSEW1 WINDOW)) (LET* ((DSP (IL:FETCH (IL:WINDOW IL:DSP) IL:OF WINDOW)) (BORDER (IL:FFETCH (IL:WINDOW IL:WBORDER) IL:OF WINDOW)) (CLIPPING-REGION (IL:DSPCLIPPINGREGION NIL DSP))) (IL:UNINTERRUPTABLY (IL:* IL:|;;| "switch the destination to the save bitmap") (IL:DSPDESTINATION (IL:FFETCH (IL:WINDOW IL:SAVE) IL:OF WINDOW) DSP) (IL:* IL:|;;| "adjust the offset") (IL:DSPXOFFSET (- BORDER (REGION-LEFT CLIPPING-REGION)) DSP) (IL:DSPYOFFSET (- BORDER (REGION-BOTTOM CLIPPING-REGION)) DSP) (IL:* IL:|;;| "so it's still IL:OPENWP") (IL:FREPLACE (IL:WINDOW IL:NEXTW) IL:OF WINDOW IL:WITH NIL)) (SETF (GETHASH WINDOW *HIDDEN-WINDOWS*) T)) T)) (DEFUN UN-HIDE-WINDOW (WINDOW) (LET* ((WINDOW (MAIN-WINDOW WINDOW)) (ICON (WINDOW-ICON WINDOW)) (SHRUNKEN? (SHRUNKEN? WINDOW))) (WHEN ICON (UN-HIDE-WINDOW-INTERNAL ICON (NOT SHRUNKEN?))) (UN-HIDE-WINDOW-INTERNAL WINDOW SHRUNKEN?) T)) (DEFUN UN-HIDE-WINDOW-INTERNAL (WINDOW &OPTIONAL NO-OPEN) (WHEN (WINDOW-HIDDEN? WINDOW) (IL:UNINTERRUPTABLY (LET* ((DSP (IL:FETCH (IL:WINDOW IL:DSP) IL:OF WINDOW)) (REGION (IL:FFETCH (IL:WINDOW IL:REG) IL:OF WINDOW)) (BORDER (IL:FFETCH (IL:WINDOW IL:WBORDER) IL:OF WINDOW)) (CLIPPING-REGION (IL:DSPCLIPPINGREGION NIL DSP))) (IL:* IL:|;;| "switch the destination to the screen") (IL:DSPDESTINATION (IL:FETCH (IL:SCREEN IL:SCDESTINATION) IL:OF (IL:FFETCH (IL:WINDOW IL:SCREEN) IL:OF WINDOW)) DSP) (IL:* IL:|;;| "adjust the offsets") (IL:DSPXOFFSET (- (+ (REGION-LEFT REGION) BORDER) (REGION-LEFT CLIPPING-REGION)) DSP) (IL:DSPYOFFSET (- (+ (REGION-BOTTOM REGION) BORDER) (REGION-BOTTOM CLIPPING-REGION)) DSP) (IL:* IL:|;;| "so it's not IL:OPENWP") (IL:FREPLACE (IL:WINDOW IL:NEXTW) IL:OF WINDOW IL:WITH 'IL:CLOSED)))) (UNLESS NO-OPEN (IL:\\OPENW1 WINDOW)) (REMHASH WINDOW *HIDDEN-WINDOWS*) (DOLIST (ATTACHED-WINDOW (IL:WINDOWPROP WINDOW 'IL:ATTACHEDWINDOWS)) (IL:* IL:|;;| "recursively un-hide attached windows") (UN-HIDE-WINDOW-INTERNAL ATTACHED-WINDOW NO-OPEN)) (UNLESS NO-OPEN (DO-TOTOP-FUNCTIONS WINDOW))) (DEFUN DO-TOTOP-FUNCTIONS (WINDOW) (LET ((TOTOPFN (IL:WINDOWPROP WINDOW 'IL:TOTOPFN))) (IL:* IL:|;;| "TOTOPFN's often look at what's behind a window & since this window now has a new screen behind it we do these. This makes buttons & icons work right. ") (WHEN (AND TOTOPFN (NOT (IL:* IL:|;;| "we take care of attached windows already") (OR (IL:EQMEMB 'IL:TOPATTACHEDWINDOWS TOTOPFN) (IL:EQMEMB 'IL:ATTACHEDWINDOWTOTOPFN TOTOPFN)))) (IL:DOUSERFNS TOTOPFN WINDOW)))) (DEFUN WINDOW-HIDDEN? (WINDOW) (%WINDOW-HIDDEN? WINDOW)) (DEFINLINE %WINDOW-HIDDEN? (WINDOW) (EQ (IL:FETCH (IL:\\DISPLAYDATA IL:|DDDestination|) IL:OF (IL:FETCH (STREAM IL:IMAGEDATA ) IL:OF (IL:FETCH (IL:WINDOW IL:DSP) IL:OF WINDOW ))) (IL:FFETCH (IL:WINDOW IL:SAVE) IL:OF WINDOW))) (IL:DEFINEQ (shapew1 +(il:lambda (il:window il:region) (il:* il:\; "Edited 15-Jun-88 17:08 by drc:") (il:* il:|;;| "entry for shaping a window that does the reshape without checking for a user function.") (declare (il:localvars . t)) (il:setq il:window (il:\\insurewindow il:window)) (or (il:regionp il:region) (il:\\illegal.arg il:region)) (prog ((il:oldregion (il:|fetch| (il:window il:reg) il:|of| il:window)) (il:oldclipreg (il:dspclippingregion nil (il:|fetch| (il:window il:dsp) il:|of| il:window))) (il:wborder (il:|fetch| (il:window il:wborder) il:|of| il:window)) (il:save (il:|fetch| (il:window il:save) il:|of| il:window)) (il:screen (il:|fetch| (il:window il:screen) il:|of| il:window)) il:nusav il:nowopen? il:hidden?) (il:setq il:nusav (il:bitmapcreate (il:|fetch| (il:region il:width) il:|of| il:region) (il:|fetch| (il:region il:height) il:|of| il:region) (il:|fetch| (il:bitmap il:bitmapbitsperpixel) il:|of| (il:|fetch| (il:screen il:scdestination) il:|of| il:screen)))) (il:uninterruptably (cond ((il:openwp il:window) (il:if (window-hidden? il:window) il:then (il:setq il:hidden? t) il:else (il:* il:\; "notice whether window is open or not to call OPENFNs only if not now open.") (il:setq il:nowopen? t) (il:\\closew1 il:window)))) (il:* il:\; "Save window image") (il:|replace| (il:window il:reg) il:|of| il:window il:|with| il:region) (il:|replace| (il:window il:save) il:|of| il:window il:|with| il:nusav) (il:if il:hidden? il:then (let ((il:twiceborder (il:itimes (il:|fetch| (il:window il:wborder) il:|of| il:window) 2)) (il:dsp (il:|fetch| (il:window il:dsp) il:of il:window))) (il:dspdestination il:nusav il:dsp) (il:dspclippingregion (il:|create| il:region il:|using| (il:dspclippingregion nil il:dsp) il:width il:_ (- (il:|fetch| (il:region il:width) il:|of| il:region) il:twiceborder) il:height il:_ (+ (- (il:|fetch| (il:region il:height) il:|of| il:region) il:twiceborder) (il:|if| (il:|fetch| (il:window il:wtitle) il:|of| il:window) il:|then| (il:dsplinefeed nil (il:|fetch| (il:screen il:sctitleds) il:|of| il:screen)) il:|else| 0))) il:dsp) (il:showwframe il:window)) il:else (il:advisewds il:window il:oldregion) (il:showwframe il:window) (cond (il:nowopen? (il:\\openw1 il:window)) (t (il:openw il:window))))) (il:douserfns2 (or (il:|fetch| (il:window il:reshapefn) il:|of| il:window) (il:function il:reshapebyrepaintfn)) il:window il:save (il:|create| il:region il:left il:_ il:wborder il:bottom il:_ il:wborder il:width il:_ (il:|fetch| (il:region il:width) il:|of| il:oldclipreg) il:height il:_ (il:|fetch| (il:region il:height) il:|of| il:oldclipreg)) il:oldregion) (return il:window))) +) (\\closew1 +(il:lambda (il:window) (il:* il:\; "Edited 15-Jun-88 15:36 by drc:") (il:* il:|;;| "actually does the closing operation. Is used by SHRINKW to avoid the CLOSEFN mechanism.") (let (il:screen il:nextw) (il:if (window-hidden? il:window) il:then (un-hide-window-internal il:window t) (quote il:closed) il:else (il:setq il:screen (il:|fetch| (il:window il:screen) il:|of| il:window)) (il:.while.top.ds. il:window (il:\\sw2bm (il:|fetch| (il:screen il:scdestination) il:|of| il:screen) (il:|fetch| (il:window il:reg) il:|of| il:window) (il:|fetch| (il:window il:save) il:|of| il:window) nil) (il:setq il:nextw (il:|fetch| (il:window il:nextw) il:|of| il:window)) (il:|replace| (il:screen il:sctopw) il:|of| il:screen il:|with| il:nextw) (il:setq il:\\topwds (cond (il:nextw (il:|fetch| (il:window il:dsp) il:|of| il:nextw)))) (il:* il:\; "smash the window's link to other's in the chain.") (il:|replace| (il:window il:nextw) il:|of| il:window il:|with| (quote il:closed)))))) +) (movew +(il:lambda (il:window il:|POSorX| il:y) (il:* il:\; "Edited 15-Jun-88 15:42 by drc:") (il:* il:|;;| "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.") (il:setq il:window (il:\\insurewindow il:window)) (prog ((il:oldregion (il:|fetch| (il:window il:reg) il:|of| il:window)) (il:usermovefn (il:|fetch| (il:window il:movefn) il:|of| il:window)) (il:open? (il:openwp il:window)) il:oldscreen il:pos il:newregion il:oldleft il:oldbottom il:oldwidth il:oldheight il:oldclipregion il:lft il:btm il:reg il:fn) (il:setq il:oldscreen (il:|fetch| (il:window il:screen) il:|of| il:window)) (cond ((cond ((il:listp il:usermovefn) (il:fmemb (quote il:don\'t) il:usermovefn)) (t (eq il:usermovefn (quote il:don\'t)))) (il:promptprint "This window cannot be moved.") (return))) (cond ((not (il:subregionp il:oldregion (il:|fetch| (il:screen il:scregion) il:|of| il:oldscreen))) (il:* il:\; "use T as an indication that the window was completely off screen.") (il:setq il:oldclipregion (or (il:\\onscreenclippingregion il:window) t)))) (il:setq il:oldleft (il:|fetch| (il:region il:left) il:|of| il:oldregion)) (il:setq il:oldbottom (il:|ffetch| (il:region il:bottom) il:|of| il:oldregion)) (il:setq il:oldwidth (il:|ffetch| (il:region il:width) il:|of| il:oldregion)) (il:setq il:oldheight (il:|ffetch| (il:region il:height) il:|of| il:oldregion)) (cond ((and il:|POSorX| (il:setq il:pos (cond ((il:positionp il:|POSorX|) il:|POSorX|) ((il:numberp il:|POSorX|) (cond ((il:numberp il:y) (il:|create| il:position il:xcoord il:_ il:|POSorX| il:ycoord il:_ il:y)) (t (il:\\illegal.arg il:y)))) ((il:regionp il:|POSorX|) (il:|create| il:position il:xcoord il:_ (il:|fetch| (il:region il:left) il:|of| il:|POSorX|) il:ycoord il:_ (il:|fetch| (il:region il:bottom) il:|of| il:|POSorX|))) (t (il:\\illegal.arg il:|POSorX|))))) (il:* il:\; "if not aready open, don't") (and il:open? (il:totopw il:window))) (t (il:* il:\; "no position to move to has been given, ask user for one.") (il:totopw il:window) (il:* il:\; "TOTOPW opens the window if it is not already.") (cond ((and (il:setq il:fn (il:windowprop il:window (quote il:calculateregionfn))) (il:setq il:reg (il:apply* il:fn il:window (quote movew)))) (il:* il:\; "prompt with a region that is calculated by the window") (il:setq il:pos (il:getboxposition (il:|fetch| (il:region il:width) il:|of| il:reg) (il:|ffetch| (il:region il:height) il:|of| il:reg) (il:setq il:lft (il:|ffetch| (il:region il:left) il:|of| il:reg)) (il:setq il:btm (il:|ffetch| (il:region il:bottom) il:|of| il:reg)))) (il:* il:|;;| "use a position that is offset by the same amount as the calculated region was from the window's region.") (il:setq il:pos (il:|create| il:position il:xcoord il:_ (il:iplus (il:|fetch| (il:position il:xcoord) il:|of| il:pos) (il:idifference il:oldleft il:lft)) il:ycoord il:_ (il:iplus (il:|ffetch| (il:position il:ycoord) il:|of| il:pos) (il:idifference il:oldbottom il:btm))))) (t (il:setq il:pos (il:getboxposition il:oldwidth il:oldheight il:oldleft il:oldbottom)))) (il:setq il:open? t))) (cond ((and (il:listp il:usermovefn) (not (il:fmemb (car il:usermovefn) il:lambdasplst))) (and (eq (il:|for| il:mfn il:|in| il:usermovefn il:|do| (il:setq il:newregion (il:apply* il:mfn il:window il:pos)) (cond ((eq il:newregion (quote il:don\'t)) (return (quote il:don\'t))) ((il:positionp il:newregion) (il:setq il:pos il:newregion)))) (quote il:don\'t)) (return))) (il:usermovefn (il:setq il:newregion (il:apply* il:usermovefn il:window il:pos)) (cond ((eq il:newregion (quote il:don\'t)) (return)) ((il:positionp il:newregion) (il:setq il:pos il:newregion))))) (cond ((or (not (eq (il:|fetch| (il:position il:xcoord) il:|of| il:pos) il:oldleft)) (not (eq (il:|ffetch| (il:position il:ycoord) il:|of| il:pos) il:oldbottom))) (il:setq il:newregion (il:|create| il:region il:left il:_ (il:|ffetch| (il:position il:xcoord) il:|of| il:pos) il:bottom il:_ (il:|ffetch| (il:position il:ycoord) il:|of| il:pos) il:width il:_ il:oldwidth il:height il:_ il:oldheight)) (il:if (window-hidden? il:window) il:then (il:* il:|;;| "just update region") (il:|replace| (il:window il:reg) il:|of| il:window il:|with| il:newregion) il:else (il:uninterruptably (cond (il:open? (il:* il:|;;| "if window is open, move it to top as its MOVEFN may have changed things and swap its bits to its new location") (il:.while.top.ds. il:window (il:\\sw2bm (il:|fetch| (il:screen il:scdestination) il:|of| il:oldscreen) il:oldregion (il:|fetch| (il:window il:save) il:|of| il:window) nil) (il:\\sw2bm (il:|ffetch| (il:window il:save) il:|of| il:window) nil (il:|ffetch| (il:screen il:scdestination) il:|of| il:oldscreen) il:newregion)))) (il:|replace| (il:window il:reg) il:|of| il:window il:|with| il:newregion) (il:advisewds il:window il:oldregion t))) (cond ((and il:open? (il:windowprop il:window (quote il:repaintfn)) il:oldclipregion) (il:* il:\; "redisplay those parts that were off the screen.") (cond ((eq il:oldclipregion t) (il:* il:\; "whole window was off.") (il:redisplayw il:window nil t)) (t (prog (il:newclippingregion il:ncl il:ocl il:ncb il:ocb il:ocr il:ncr il:ocw il:ncw il:och il:nch il:oct il:nct) (il:setq il:newclippingregion (il:\\onscreenclippingregion il:window)) (il:* il:\; "the title may be the only thing now on the screen.") (or il:newclippingregion (return)) (il:setq il:ncb (il:|fetch| (il:region il:bottom) il:|of| il:newclippingregion)) (il:setq il:ocb (il:|fetch| (il:region il:bottom) il:|of| il:oldclipregion)) (il:setq il:ocw (il:|ffetch| (il:region il:width) il:|of| il:oldclipregion)) (il:setq il:ncw (il:|ffetch| (il:region il:width) il:|of| il:newclippingregion)) (il:setq il:och (il:|ffetch| (il:region il:height) il:|of| il:oldclipregion)) (il:setq il:nch (il:|ffetch| (il:region il:height) il:|of| il:newclippingregion)) (cond ((il:ilessp (il:setq il:ncl (il:|ffetch| (il:region il:left) il:|of| il:newclippingregion)) (il:setq il:ocl (il:|ffetch| (il:region il:left) il:|of| il:oldclipregion))) (il:redisplayw il:window (il:createregion il:ncl il:ocb (il:idifference il:ocl il:ncl) il:och)))) (cond ((il:ilessp (il:setq il:ocr (il:iplus il:ocl il:ocw)) (il:setq il:ncr (il:iplus il:ncl il:ncw))) (il:* il:\; "some stuff appeared from the right.") (il:redisplayw il:window (il:createregion il:ocr il:ocb (il:idifference il:ncr il:ocr) il:och)))) (cond ((il:ilessp il:ncb il:ocb) (il:redisplayw il:window (il:createregion il:ncl il:ncb il:ncw (il:idifference il:ocb il:ncb))))) (cond ((il:ilessp (il:setq il:oct (il:iplus il:ocb il:och)) (il:setq il:nct (il:iplus il:ncb il:nch))) (il:* il:\; "some stuff appeared from the top") (il:redisplayw il:window (il:createregion il:ncl il:oct il:ncw (il:idifference il:nct il:oct))))) (cond ((il:igreaterp (il:iplus il:oldbottom il:oldheight) (il:|fetch| (il:screen il:scheight) il:|of| il:oldscreen)) (il:* il:\; "should reshow the title but don't have any entry for that.") nil))))))) (il:douserfns (il:windowprop il:window (quote il:aftermovefn)) il:window))) (return il:pos))) +) (\\internaltotopw +(il:lambda (il:w1 il:rpt) (il:* il:\; "Edited 15-Jun-88 14:50 by drc:") (prog (il:screen il:screentopw) (il:setq il:w1 (il:\\insurewindow il:w1)) (il:setq il:screen (il:|fetch| (il:window il:screen) il:|of| il:w1)) (il:setq il:screentopw (il:|fetch| (il:screen il:sctopw) il:|of| il:screen)) (or (eq il:w1 il:screentopw) (window-hidden? il:w1) (cond ((null il:screentopw) (il:* il:\; "all windows are closed open this one.") (il:openw il:w1)) (t (il:uninterruptably (il:\\ttw1 il:w1 il:screentopw) (il:* il:|;;| "N.B. \\TTW1 can side effect the screen") (cond ((eq il:w1 (il:|fetch| (il:screen il:sctopw) il:|of| il:screen))) ((not il:rpt) (il:* il:\; "GC msgs or other glitches can cause W1 not to make it. Check and try ONCE more") (\\internaltotopw il:w1 t))))))))) +) (wfrommenu +(il:lambda (il:menu) (il:* il:\; "Edited 15-Jun-88 19:19 by drc:") (il:* il:|;;;| "finds the window that menu is in if any.") (block wfrommenu (dolist (il:window (all-windows t)) (labels ((il:search-attached-windows (il:window) (when (il:fmemb il:menu (il:windowprop il:window (quote il:menu))) (return-from wfrommenu il:window)) (dolist (il:window (il:windowprop il:window (quote il:attachedwindows))) (il:search-attached-windows il:window)))) (il:search-attached-windows il:window))))) +) (reshowtitle +(il:lambda (il:title il:window il:justdisplayflg) (il:* il:\; "Edited 15-Jun-88 18:57 by drc:") (il:* il:|;;| "updates a windows display with a new title") (prog* ((il:wreg (il:|fetch| (il:window il:reg) il:|of| il:window)) (il:titleds (il:|fetch| (il:screen il:sctitleds) il:|of| (il:|fetch| (il:window il:screen) il:|of| il:window))) (il:titleheight (il:iminus (il:dsplinefeed nil il:titleds))) (il:oldtitle (il:|fetch| (il:window il:wtitle) il:|of| il:window)) (il:border (il:|fetch| (il:window il:wborder) il:|of| il:window)) il:bm il:bmbtm il:hght) (cond (il:justdisplayflg) ((eq il:title (il:|fetch| (il:window il:wtitle) il:|of| il:window)) (return)) (t (il:|replace| (il:window il:wtitle) il:|of| il:window il:|with| il:title) (cond ((or (null il:oldtitle) (null il:title) (il:neq il:titleheight (il:idifference (il:|fetch| (il:region il:height) il:|of| il:wreg) (il:iplus (il:|fetch| (il:region il:height) il:|of| (il:dspclippingregion nil (il:|fetch| (il:window il:dsp) il:|of| il:window))) (il:itimes 2 il:border))))) (il:* il:\; "Previously no title, so make space for one") (il:* il:\; "Have to remove title") (il:* il:\; "or title height changed.") (il:* il:\; "so windows region on the screen has to be made larger.") (il:\\reshowborder1 (il:|fetch| (il:window il:wborder) il:|of| il:window) (il:|fetch| (il:window il:wborder) il:|of| il:window) il:window) (return))))) (il:* il:\; "code from here is to reprint the title in place to avoid creating any large bitmaps.") (il:setq il:bm (il:bitmapcreate (il:|fetch| (il:region il:width) il:|of| il:wreg) (il:setq il:titleheight (il:add1 il:titleheight)) (il:bitsperpixel (il:|fetch| (il:screen il:scdestination) il:|of| (il:|fetch| (il:window il:screen) il:|of| il:window))))) (il:bitblt nil nil nil il:bm 0 0 nil nil (quote il:texture) (quote il:replace) il:blackshade) (il:* il:\; "use SHOWWTITLE to put the image of the title into the auxilliary bitmap.") (il:showwtitle il:title il:bm il:border nil il:window) (cond ((il:igreaterp il:titleheight (il:setq il:hght (il:|fetch| (il:region il:height) il:|of| il:wreg))) (il:setq il:bmbtm (il:idifference (il:sub1 il:titleheight) il:hght)))) (let ((il:hidden? (window-hidden? il:window))) (il:uninterruptably (il:totopw il:window) (il:bitblt il:bm 0 (cond (il:bmbtm) ((il:igreaterp il:border 0) (il:* il:|;;| "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)) (il:dspdestination nil il:window) (il:if il:hidden? il:then 0 il:else (il:|fetch| (il:region il:left) il:|of| il:wreg)) (il:idifference (il:if il:hidden? il:then (il:|fetch| (il:region il:height) il:|of| il:wreg) il:else (il:|fetch| (il:region il:ptop) il:|of| il:wreg)) (cond (il:bmbtm il:hght) (t (il:iplus il:titleheight (cond ((il:igreaterp il:border 0) (il:* il:|;;| "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 (il:bmbtm il:hght))))))) +) (\\reshowborder1 +(il:lambda (il:newborder il:oldborder il:window) (il:* il:\; "Edited 15-Jun-88 19:05 by drc:") (il:* il:|;;| "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 ((il:region (il:|fetch| (il:window il:reg) il:|of| il:window)) (il:oldsave (il:|fetch| (il:window il:save) il:|of| il:window)) il:nusav il:delta il:nuwidth il:nuheight il:hidden?) (il:setq il:delta (il:idifference il:newborder il:oldborder)) (il:setq il:nuwidth (il:iplus (il:|fetch| (il:region il:width) il:|of| il:region) (il:itimes il:delta 2))) (il:setq il:nuheight (il:idifference (il:iplus (il:|fetch| (il:region il:height) il:|of| (il:dspclippingregion nil (il:|fetch| (il:window il:dsp) il:|of| il:window))) (il:itimes il:newborder 2)) (cond ((il:|fetch| (il:window il:wtitle) il:|of| il:window) (il:dsplinefeed nil (il:|fetch| (il:screen il:sctitleds) il:|of| (il:|fetch| (il:window il:screen) il:|of| il:window)))) (t 0)))) (il:setq il:nusav (il:bitmapcreate il:nuwidth il:nuheight (il:|fetch| (il:bitmap il:bitmapbitsperpixel) il:|of| il:oldsave))) (il:setq il:hidden? (window-hidden? il:window)) (il:.while.top.ds. il:window (il:* il:\; "Save window image") (or il:hidden? (il:\\sw2bm (il:|fetch| (il:screen il:scdestination) il:|of| (il:|fetch| (il:window il:screen) il:|of| il:window)) il:region (il:|fetch| (il:window il:save) il:|of| il:window) nil)) (il:* il:\; "put new save image into window") (il:|replace| (il:window il:save) il:|of| il:window il:|with| il:nusav) (il:if il:hidden? il:then (il:dspdestination il:nusav il:window)) (il:|replace| (il:window il:wborder) il:|of| il:window il:|with| il:newborder) (il:if il:hidden? il:then (il:* il:|;;| "re-adjust X & Y offset") (il:dspxoffset il:newborder il:window) (il:dspyoffset il:newborder il:window)) (il:* il:\; "create a region that coresponds to the old region with the new border.") (il:|replace| (il:window il:reg) il:|of| il:window il:|with| (il:|create| il:region il:left il:_ (il:idifference (il:|fetch| (il:region il:left) il:|of| il:region) il:delta) il:bottom il:_ (il:idifference (il:|fetch| (il:region il:bottom) il:|of| il:region) il:delta) il:width il:_ il:nuwidth il:height il:_ il:nuheight)) (il:update/scroll/reg il:window) (il:* il:\; "draw border in the new image.") (il:showwframe il:window) (il:* il:\; "copy the visible part from the old image into the new one.") (il:bitblt il:oldsave il:oldborder il:oldborder il:nusav il:newborder il:newborder (il:idifference (il:|fetch| (il:bitmap il:bitmapwidth) il:|of| il:oldsave) (il:itimes 2 il:oldborder)) (il:|fetch| (il:region il:height) il:|of| (il:dspclippingregion nil (il:|fetch| (il:window il:dsp) il:|of| il:window))) (quote il:input) (quote il:replace)) (il:* il:\; "put the new image up on the screen.") (or il:hidden? (il:\\sw2bm (il:|fetch| (il:screen il:scdestination) il:|of| (il:|fetch| (il:window il:screen) il:|of| il:window)) (il:|fetch| (il:window il:reg) il:|of| il:window) (il:|fetch| (il:window il:save) il:|of| il:window) nil))))) +) (ttyin.setup +(il:lambda nil (il:* il:\; "Edited 16-Jun-88 11:37 by drc:") (il:* il:\; "Disable buttons so we can do selection") (let ((il:window (il:wfromds il:\\dsp t))) (cond (il:window (il:|replace| (il:ttyinbuffer il:ttoldrightfn) il:|of| il:\\ttyinstate il:|with| (il:windowprop il:window (quote il:rightbuttonfn) (quote il:totopw))) (il:|replace| (il:ttyinbuffer il:ttoldbuttonfn) il:|of| il:\\ttyinstate il:|with| (il:windowprop il:window (quote il:buttoneventfn) (quote il:totopw))) (il:|replace| (il:ttyinbuffer il:ttoldentryfn) il:|of| il:\\ttyinstate il:|with| (il:windowprop il:window (quote il:windowentryfn) (quote il:ttyinentryfn))) (il:|replace| (il:ttyinbuffer il:ttyinwindow) il:|of| il:\\ttyinstate il:|with| il:window) (il:windowprop il:window (quote il:ttyinstate) (il:|fetch| (il:ttyinbuffer il:ttyinwindowstate) il:|of| il:\\ttyinstate)) (il:resetsave nil (list (il:function il:ttyin.cleanup) il:\\ttyinstate)))) (cond ((or (il:imagestreamtypep il:\\dsp (quote il:text)) (il:fmemb (il:dspdestination nil il:\\dsp) il:\\screenbitmaps) (and il:window (window-hidden? il:window))) (il:setq il:\\charwidth (il:charwidth (il:charcode il:a) il:\\dsp)) (il:setq il:\\font (il:dspfont nil il:\\dsp)) (il:|if| (eq il:\\font il:\\ttyin.last.font) il:|then| (il:setq il:\\commentfont il:\\ttyin.last.commentfont) il:|elseif| il:\\reading il:|then| (il:* il:\; "Want a \"comment\" font for ?=") (il:setq il:\\commentfont (il:setq il:\\ttyin.last.commentfont (il:fontcopy il:\\font (quote il:weight) (il:selectq (il:fontprop il:\\font (quote il:weight)) (il:bold (quote il:medium)) (quote il:bold))))) (il:setq il:\\ttyin.last.font il:\\font) il:|else| (il:setq il:\\commentfont il:\\font)) (il:setq il:\\charheight (max (il:fontheight il:\\font) (il:fontheight il:\\commentfont))) (il:setq il:\\descent (il:fontprop il:\\font (quote il:descent))) (il:* il:\; "How many pixels below the baseline this font goes") (il:setq il:\\texture (il:dsptexture nil il:\\dsp)) (il:setq il:\\ttpagelength (il:pageheight nil il:\\dsp)) (il:setq il:\\lmarg (il:dspleftmargin nil il:\\dsp)) (il:* il:\; "bit pos of left margin") (il:setq il:\\rmarg (il:dsprightmargin nil il:\\dsp)) (il:* il:\; "bit pos of right margin, dsp relative") (il:setq il:\\initpos (il:dspxposition nil il:\\dsp)))))) +) ) (IL:DECLARE\: IL:DOEVAL@COMPILE IL:DONTCOPY (IL:GLOBALVARS IL:LAMBDASPLST IL:\\EM.DISPINTERRUPT IL:\\SCREENBITMAPS IL:\\TTYIN.LAST.FONT IL:\\TTYIN.LAST.COMMENTFONT) ) (EVAL-WHEN (LOAD) (IL:MOVD 'SHAPEW1 'IL:SHAPEW1) (IL:MOVD '\\CLOSEW1 'IL:\\CLOSEW1) (IL:MOVD 'MOVEW 'IL:MOVEW) (IL:MOVD '\\INTERNALTOTOPW 'IL:\\INTERNALTOTOPW) (IL:MOVD 'WFROMMENU 'IL:WFROMMENU) (IL:MOVD 'RESHOWTITLE 'IL:RESHOWTITLE) (IL:MOVD '\\RESHOWBORDER1 'IL:\\RESHOWBORDER1) (IL:MOVD 'TTYIN.SETUP 'IL:TTYIN.SETUP) ) (REINSTALL-ADVICE 'IL:ATTACHWINDOW :AFTER '((:LAST (WHEN (AND (WINDOW-HIDDEN? (IL:INSURE.WINDOW IL:MAINWINDOW)) (NOT (WINDOW-HIDDEN? ( IL:INSURE.WINDOW IL:WINDOWTOATTACH )))) (HIDE-WINDOW-INTERNAL IL:WINDOWTOATTACH) )))) (IL:READVISE IL:ATTACHWINDOW) (IL:PUTPROPS IL:ROOMS-WINDOW-HIDER IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (2505 3071 (ALL-WINDOWS 2505 . 3071)) (3073 3538 (LOST-WINDOWS 3073 . 3538)) (3540 3653 (HIDE-ALL-WINDOWS 3540 . 3653)) (3655 4001 (HIDE-WINDOW 3655 . 4001)) (4003 5348 ( HIDE-WINDOW-INTERNAL 4003 . 5348)) (5350 5658 (UN-HIDE-WINDOW 5350 . 5658)) (5660 7422 ( UN-HIDE-WINDOW-INTERNAL 5660 . 7422)) (7424 8040 (DO-TOTOP-FUNCTIONS 7424 . 8040)) (8042 8109 ( WINDOW-HIDDEN? 8042 . 8109)) (8886 29312 (SHAPEW1 8899 . 11521) (\\CLOSEW1 11523 . 12510) (MOVEW 12512 . 19579) (\\INTERNALTOTOPW 19581 . 20375) (WFROMMENU 20377 . 20881) (RESHOWTITLE 20883 . 23878) ( \\RESHOWBORDER1 23880 . 27015) (TTYIN.SETUP 27017 . 29310))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-WINDOW-HIDER.DFASL b/rooms/ROOMS-WINDOW-HIDER.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..567cd4e0d88d1861be3772073b1a9d8fac7549b6 GIT binary patch literal 12689 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.;2| 8980 IL:|previous| IL:|date:| "17-Aug-90 13:37:32" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>ROOMS-WINDOW-TYPES.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:ROOMS-WINDOW-TYPESCOMS) (IL:RPAQQ IL:ROOMS-WINDOW-TYPESCOMS ((FILE-ENVIRONMENTS IL:ROOMS-WINDOW-TYPES) (IL:P (EXPORT '(DEF-WINDOW-TYPE WINDOW-TYPE WINDOW-TYPE-PROP)) (REQUIRE "ROOMS")) (IL:STRUCTURES WINDOW-TYPE) (IL:FUNCTIONS WINDOW-TYPE-PROP) (IL:DEFINE-TYPES IL:WINDOW-TYPES) (IL:VARIABLES *WINDOW-TYPES*) (IL:FUNCTIONS DEF-WINDOW-TYPE WINDOW-TYPE-NAMED WINDOW-TYPE WINDOW-TYPE-INTERNAL ABSTRACT-WINDOW RECONSTITUTE-WINDOW) (IL:SEDIT-FORMATS DEF-WINDOW-TYPE))) (DEFINE-FILE-ENVIRONMENT IL:ROOMS-WINDOW-TYPES :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(DEF-WINDOW-TYPE WINDOW-TYPE WINDOW-TYPE-PROP)) (REQUIRE "ROOMS") (DEFSTRUCT (WINDOW-TYPE (:PRINT-FUNCTION (LAMBDA (WINDOW-TYPE STREAM DEPTH) (FORMAT STREAM "#" ( WINDOW-TYPE-NAME WINDOW-TYPE)) ))) (NAME NIL :TYPE STRING) (DEPENDENCIES NIL :TYPE LIST) (RECOGNIZER NIL :TYPE FUNCTION) (ABSTRACTER NIL :TYPE FUNCTION) (RECONSTITUTER NIL :TYPE FUNCTION) (PLACER NIL :TYPE FUNCTION) (UPDATER NIL :TYPE FUNCTION) (PROPS NIL :TYPE LIST)) (DEFMACRO WINDOW-TYPE-PROP (WINDOW-TYPE PROP &OPTIONAL (NEW-VALUE NIL NEW-VALUE-SUPPLIED)) (IF NEW-VALUE-SUPPLIED `(SETF (GETF (WINDOW-TYPE-PROPS ,WINDOW-TYPE) ,PROP) ,NEW-VALUE) `(GETF (WINDOW-TYPE-PROPS ,WINDOW-TYPE) ,PROP))) (DEF-DEFINE-TYPE IL:WINDOW-TYPES "Window types" :UNDEFINER (LAMBDA (NAME) (REMHASH NAME *WINDOW-TYPES*))) (DEFGLOBALVAR *WINDOW-TYPES* (MAKE-HASH-TABLE :TEST 'EQ) "Hash table mapping from window type names to window type objects.") (DEFDEFINER DEF-WINDOW-TYPE IL:WINDOW-TYPES (NAME &REST REST-KEYS &KEY DEPENDENCIES RECOGNIZER ABSTRACTER RECONSTITUTER PLACER UPDATER &ALLOW-OTHER-KEYS) (IL:* IL:|;;;| "defines a window type") (FLET ((KWOTE (X) (IL:* IL:|;;|  "we want lambda expressions wrapped in FUNCTION and named functions just quoted") (TYPECASE X (CONS (LIST (CASE (FIRST X) ((LAMBDA IL:LAMBDA) 'FUNCTION) (T 'QUOTE)) X)) ((SATISFIES CONSTANTP) X) (T (LIST 'QUOTE X))))) `(SETF (GETHASH ',NAME *WINDOW-TYPES*) (MAKE-WINDOW-TYPE :NAME ',NAME :DEPENDENCIES ',DEPENDENCIES :RECOGNIZER ,(KWOTE RECOGNIZER) ,@(WHEN ABSTRACTER `(:ABSTRACTER ,(KWOTE ABSTRACTER))) ,@(WHEN RECONSTITUTER `(:RECONSTITUTER ,(KWOTE RECONSTITUTER))) ,@(WHEN UPDATER `(:UPDATER ,(KWOTE UPDATER))) ,@(WHEN PLACER `(:PLACER ,(KWOTE PLACER))) :PROPS (LIST ,@(MAPCAR #'KWOTE (LET ((PROPS (COPY-LIST REST-KEYS))) (DOLIST (KEYWORD '(:DEPENDENCIES :RECOGNIZER :ABSTRACTER :RECONSTITUTER :PLACER :UPDATER)) (REMF PROPS KEYWORD)) PROPS))))))) (DEFUN WINDOW-TYPE-NAMED (NAME &OPTIONAL NO-ERROR?) (OR (GETHASH NAME *WINDOW-TYPES*) (UNLESS NO-ERROR? (ERROR "No window type named ~S." NAME)))) (DEFUN WINDOW-TYPE (WINDOW &OPTIONAL NO-ERROR?) (IL:* IL:|;;;| "return the window type object for WINDOW.") (LET ((CACHED-TYPE-NAME (IL:WINDOWPROP WINDOW 'WINDOW-TYPE))) (IF CACHED-TYPE-NAME (LET ((TYPE (WINDOW-TYPE-NAMED CACHED-TYPE-NAME T))) (IF (AND TYPE (FUNCALL (WINDOW-TYPE-RECOGNIZER TYPE) WINDOW)) TYPE (PROGN (IL:* IL:|;;| "invalidate cache") (IL:WINDOWPROP WINDOW 'WINDOW-TYPE NIL) (IL:* IL:|;;| "try again") (WINDOW-TYPE WINDOW NO-ERROR?)))) (LET ((TYPE (WINDOW-TYPE-INTERNAL WINDOW NO-ERROR?))) (IL:* IL:|;;| "should cache misses here too") (WHEN TYPE (IL:* IL:\; "cache it") (IL:WINDOWPROP WINDOW 'WINDOW-TYPE (WINDOW-TYPE-NAME TYPE)) (IL:* IL:\; "return it") TYPE))))) (DEFUN WINDOW-TYPE-INTERNAL (WINDOW NO-ERROR?) (IL:* IL:|;;;| "We only want the most specific type -- that which no others are dependent upon. We find this by first enumerating all the types whose recognizer fires on WINDOW. We then delete from this list any types upon which others in the list are dependent. The remaining list should have only one element -- the right type.") (LET* ((ALL-TYPES (WITH-COLLECTION (MAPHASH #'(LAMBDA (NAME TYPE) (WHEN (FUNCALL (WINDOW-TYPE-RECOGNIZER TYPE) WINDOW) (COLLECT TYPE))) *WINDOW-TYPES*))) (REMAINING-TYPES (COPY-LIST ALL-TYPES))) (DOLIST (TYPE ALL-TYPES) (DOLIST (DEPENDENCY (WINDOW-TYPE-DEPENDENCIES TYPE)) (SETQ REMAINING-TYPES (DELETE (WINDOW-TYPE-NAMED DEPENDENCY) REMAINING-TYPES)))) (COND ((NULL REMAINING-TYPES) (UNLESS NO-ERROR? (ERROR "Can't find window type for ~S." WINDOW))) ((ENDP (REST REMAINING-TYPES)) (FIRST REMAINING-TYPES)) (T (UNLESS NO-ERROR? (ERROR "Type conflict: ~S is of types ~S." WINDOW (MAPCAR #'WINDOW-TYPE-NAME REMAINING-TYPES))))))) (DEFUN ABSTRACT-WINDOW (WINDOW &OPTIONAL SHH) (IL:* IL:|;;;| "returns an abstraction suitable for passing to RECONSTITUTE-WINDOW, or NIL if it can't find one.") (LET* ((TYPE (WINDOW-TYPE WINDOW T)) (ABSTRACTER (AND TYPE (WINDOW-TYPE-ABSTRACTER TYPE)))) (IF ABSTRACTER (LIST* :TYPE (WINDOW-TYPE-NAME TYPE) (FUNCALL ABSTRACTER WINDOW)) (UNLESS SHH (FRESH-LINE *ERROR-OUTPUT*) (IF TYPE (FORMAT *ERROR-OUTPUT* "Can't abstract windows of type ~S." (WINDOW-TYPE-NAME TYPE)) (FORMAT *ERROR-OUTPUT* "~S has no type." WINDOW)) (LET ((HIDDEN? (WINDOW-HIDDEN? WINDOW))) (WHEN HIDDEN? (UN-HIDE-WINDOW WINDOW)) (IL:FLASHWINDOW (IF (SHRUNKEN? WINDOW) (WINDOW-ICON WINDOW) WINDOW) 2) (WHEN HIDDEN? (HIDE-WINDOW WINDOW))) (FORMAT *ERROR-OUTPUT* " Ignoring.~%") NIL)))) (DEFUN RECONSTITUTE-WINDOW (TYPE-NAME ARG) (LET ((TYPE (WINDOW-TYPE-NAMED TYPE-NAME T))) (IF TYPE (FUNCALL (WINDOW-TYPE-RECONSTITUTER TYPE) ARG) (PROG1 NIL (WARN "Can't reconstitute windows of type ~A." TYPE-NAME))))) (SEDIT:DEF-LIST-FORMAT DEF-WINDOW-TYPE :ARGS (NIL :KEYWORD NIL) :INDENT (1)) (IL:PUTPROPS IL:ROOMS-WINDOW-TYPES IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (4427 4587 (WINDOW-TYPE-NAMED 4427 . 4587)) (4589 5733 (WINDOW-TYPE 4589 . 5733)) ( 5735 7256 (WINDOW-TYPE-INTERNAL 5735 . 7256)) (7258 8486 (ABSTRACT-WINDOW 7258 . 8486)) (8488 8767 ( RECONSTITUTE-WINDOW 8488 . 8767))))) IL:STOP \ No newline at end of file diff --git a/rooms/ROOMS-WINDOW-TYPES.DFASL b/rooms/ROOMS-WINDOW-TYPES.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..c1049d1a8acf0400390837807e8f6ed8b84c9be9 GIT binary patch literal 9147 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 QirHbs#Lti`@!j?H-!y%0I{*Lx literal 0 HcmV?d00001 diff --git a/rooms/ROOMSTECHDESC.TEDIT b/rooms/ROOMSTECHDESC.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..97e7d0ce9aa8d9d16b677909bff19db9c955c8e2 GIT binary patch literal 253072 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 literal 0 HcmV?d00001 diff --git a/rooms/ROOMSUSERS-RULES.TEDIT b/rooms/ROOMSUSERS-RULES.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..0ddcc3c85475ef1fe7904234e0f7da11dfc26aa4 GIT binary patch literal 6207 zcmeHLO>-N^5nWP}U5UKOAvySvq}t3uKoyOMG%eA|Aq5dja?AK&fQ4-3HryQm6D@X- z{U8MW1pk6mrE4b{d?vxia9@;se%$6S96(_l*l5^)wL|BoJq>76i*^c zXp!q!CRL8tiO%U@sP(*{aUt{KfaW^kg)Q2)1-o;hvUFv(Z0vaAcF;0cB`h4$byZTu z#;BO-DoseFg{CS?FjVsSYj0Y9CwLij2UlVLf~ZYff%OI*gzaPW*1h#%a7XYVlPcwK zrn#8IzeJL_5h@kesiabygQhZ*xk#OrSkLEGrpi@|s4o>f$;~QJl`}w*;g`LOtD@A2 z5*g{q_W5eQs7iz5ik2eJMOLnOQBkQk zqEJ9NQAMe;X{CypiDr`PIjp9bmIEcB!VzHq^E2o^<_=_&(r>(nl)>r}<0nU!J!@{vn#EEqdlBEKdK zolixk-eOc|x2XX~I4=f|HL~@&EkBYb0|elZbe)5`978yvm97BQYxt(7nVP5=GZfE6 zHsw;&_k(*#GE0$ER~pCx%;YdpT5!|FOc0pGHH2f{Nqf!@FiDaX)xQ3QRLO4E@4JZexz<1{i=o)O<5wIsk#wn^-PNmm8^a(o2vTBoTlLHGgOli=Zfz zQ(davWG_+h)L726u`kkG3V;Oy;TWbxq2`bXn9WILV9WvrSTLLe%@+A>8w3u9Dflm3 z^oJ(*OiNBfF8^4m-12dv-az=KPX5${7ueNvXbGRbRB6h`vo1k43RDG01{`K;K@EU4 z7a8g#T{U@4q32R(*oHW6bXsMlWXLeXM*+V%P%cDK(6xwPn^Hu2Kz}jU9J0JI zBDj!xfk;uzDG%clhEP1yT*{U|8o%g;QN&_=4;e5Sy3AWX`MKwS!&qxNKGai90a7`o$q`W{DpkXwV zzbg24z)~a>yozTs*~0BS#7#}nU<*K|lhL9(Ds$*6cP%g`^QKS?!~VeBL4Y``s8S

!k!7aXKIb5EeD8Ab>DHF@a>q_yxi@TO9k|Vrdlz#0K(NSw{gO5+ONT@-r?%ANn zsc0n=QJ5sPM&mFFn!M+@wQe&kkgnHYAQhaO=rq+!Lw9!1q`|mvyO2g9B_PBSW9_pR z+$$i5u?+?OAhBzh-KE#i3l?yZnms4*K$IX2hYlQ3aVC7fXB(Ieq0+cCh*`VFpGQzW z9c@rX*`Q&vht`$8v7L2}E79#Xh0OU!&!CxIF|x3#XA`iF_ZH9w?!nw9=<7#*XK*&| z1^uWUg@eA|hdw!1SsE;(T&TGf@051aWyp`Ff3o$i1oP%6hB~rev z;C~&A69Cgg*z{QP3u;9{CyZ*NI>W~ETV~u|^a-Oa;#lX2VUTU)EOUSgR1_=+%*_0) z3n-Gn0k;I`VD%tjVcA($%ZyVQ;?RQj=v5T-uDb0ga9(opn8p=14^++_h+DSKi3^*R z5By`K)=G$u!JQA?vHgoJh+SWvQ0=m9&s*GHu)p;oHq$s27Zy-wr#6bIRG=*+4DTyZdS@V#wSV|-lpYEdP44BjXRlH;3lCRRJE2HVXN2~C&G6c2_F)5g=%^ccEjiu zuI&s>(Yim`qJ~w-TaNL)@4hG)aXi3{fhrUSj!`nZQMu0edlY{aa=N6-LZ)c;ZBC6+ z@@^a}syArN-*8pPN38<*+)V$BVbt!&@pp9hU@IEtvzxN2Vn z)DOFarzv_Uxa6LaDabJ8b$3PU){X-mvr2u##4Gq z&yJ4i`4{}wFgt6j!*+Kt_;N&z-;LWHI)f+$!=Tfov&;6-&5Xu;^w}`HieM=0zYIs= zi*7)J^K%*n-QX;`f+LZ6zZwoA3{u|YPv$Sr1{?-& z6upAGcxnQ*VGlgH3mbqrdVWHmJ)`5(Q+zb-`o?9@?rN-^T)8p6a0EM6L!fy<{n@2|Esnxg6O=zx8dccNn@ej$e-WuMj&NbK7)cy6vyv*f5Yz@PaZhn0d~&1=Xw9&#~L`S*!%0wfcLN6 zfnV^zrj38@uK4%v0P(=amc5U6SA4Rw!u#{?ij&=e{_en?6+hcu@u%GZ literal 0 HcmV?d00001 diff --git a/rooms/RoomsUsers-Rules.IP b/rooms/RoomsUsers-Rules.IP new file mode 100644 index 0000000000000000000000000000000000000000..2c35ca441072c6112fdbf3c159364428409337cc GIT binary patch literal 6319 zcmeHLYiwLc6?UMQI8e4i@PoRKiBYg!Ih)!}Nom@qcC%@huGhw1r;eSJT;Dspd*i!z zw)f%nCa544A#_Dsp)@sZRcX_tPa&v^3PM7Hw5|l|zX}OeDoBWm0BxvBE1=?-ovsSrvb{ISG3JXPh=i#t)AI5{J`#? zVqfp*a{q;!Glj`pCQApVax>dyu&EV9_I?@JsS}w~t<_KX2;`xb-#T(e9qNJB(zZ<- z89XnV_Z`!APM^q}#xYv=$dhDRnN}hV6nbGreo(ad{qp;atB+1kPEO3Q*_qt*Oh22R zE#zk4cYX_YNGrXg@nuPCrF8^<+4JE1mUz!<=4|HM$MNGc$G<@<<2?yJE>j9bZ$yl*Ub4My4}FvD8^I#^k?twzJ^mr=@ei$LUg+54AEM<2^&$5Re{<=n z3*r8d%GLI9;W;VP7yVH~^w^2aW35&8%)dGR_zz%N$K{^Uak(!eF8Ag0<8og{NLVC4 z^q%SydQbHn_EgWEfBxz@EXN}GA@}r-R&IpH)~fu=+UBm89_i`&Qdbu!**og|IibuI zmrd9QOI0^yj#K9tfK|F$#y3MZo%|g{XyWHsnFr z$7;f%g;~~V%MFPDJ>-)LqIcAelD)CvmDN> zWy|%fMUS&c$Rk#`&jZWTR%}tL#l9Og>Cp2%@P`Nz|B0@fbgmEnB`F>=-WQ781x|sq zWW`YxS@iKgVQ0r-BplcBnJ9P0=+^3SBq`8j4J!yNKWfsVFm@wr(e>b-i9iMbcN+DD z<>ZPV8^@P|Gj-vIu3k>`;XxpRkOIGI0jt-#ix+QYI_$Z>CdJ6?Uf2LK!-GZ6xD~qK zkmH7t>sMkotV+bnfvB;7d-$0<%ySn5D`-k07u>L}c-v25Z-G1D_Vls8o6OzbNQzAp zz#WF%Ebp_r6-2HbdsZ+62`X``j7nyjv9?92 zVhzxd0FhaMBTb&^*ORNiV_fbOLB;ajqu3&RBvdmAH9<6zuwM`q(dznru!F-3|k}?cQ1j|JLB_XKtW!4li(zb-txfS0nyEcAdcGdDLB#UC>L=Q3Udtjkf zD)0ejRAs>NT6h0F&!r46zL6B`=7@F(nUh@b>Q#%O+DP>f$-k5fq7#63oF+>Xv75OO zoh1GDc?u%a3%45MiE8qxvnGITB91~AfKc!k)V){Z>3&plbIBS*1OoA~Uxgp{)X zH^$868)ze&yuFBV;MV*UA{ae}O>5md-g++u;?_WEFJZ9~_fL;*h6y7|`++@$4Z-|v&+QFDj|nRlIQ zq;$pR^+LP@XjBD-Al<{AMlg3I8NSFk z-f4LOw~$ek5@MhN3Edj>A3g)-`ly{ctW!78(G6x9EMC6~J0SWi-+I^(ef-U&c$cw! z$CyG&1p|;Q4e^j9I#n?dD&Tjudl?t64te$!iW$QH7$$g%8UBYgu?P=5$IOexYcP z#~S660G0bGrFAP*69(LAQ1_fouDRA6{klcVUXrR04nb|Knjl>HvTUPuF6w|2D(unM z_!C~BRh58q(vX{8f;DaT22av`;Md0Xl{2&B6Zuk!27?WlPqXjNCbl6r&t`8kxw-Bw zMfoopL$+3&G!f{+E?rW5bb6Y46!2PTRaHo70p%KLu>hr*!Vg4TsWSfF)*IjJLXCLD z9q6X&GH{Jx9{ui5jJ$uQmJ~x1$U@l@^?EbQaw~1_O|w;shzSsWpl%W?@Y0KERPj8i z7|W!Tt`D?pQn80HDA>SVr3vmdoV$LTZBd`AfFf=&}RQAc)_JCwrDdGMrtUgImp`l0d5+ETbLkNXNMO?KoG7DlJB z53rs3o@;VA^0vz1`fyc7jmds?K{FcC!faZM|>pHkf@U z8M@cNGs+kn&KmC&xF;-!4X|wC=E(`-R@Nz7p=4QhW;S2S4Z`5HTVX~U9BL+eP8)+0 zFgTJmcMX+oec_;NyEt=Mc%EoTX`xd~B1u%#Rb(LK9681ka&_A-IMA*J|B-Aj8CMkh zXcngq(S&UUA5H?^8j|SQa6r^)wy-=I`&pRL2K(<$uK1cU*b9R@5xW&xDi=sBbWuW% zNUpjP%R!TO#j2snw$1Is)7*r*B%vbG#wIW>F)Dk*8u|t@w^vARK;CdEQ(>o~-L{?j zA`}ze=eNL@4*Qc|PClJCVc)1tOTnh%z~nEeHf<2Ax$YPYL0lnv09^w0CfW4IUWG+% zduxv@q2BwA{fqZb-aI>zE0)Ge`N<+e>F=jSxPAWbo=8Ui|3spmNWixTe`Fao_g9i) zU^276h@nGMj=Hr{MooIsDw(UfF7!&%kO<6DP;L|< zNqxtxTjGEo(75#r2n$GKs!?G*Z2l z%;Hoyq(t5z}$>40XZ133hg#!)|To^FRMDAJNp)=%rhX?~harunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>SCREENPAPER.;3 12813 previous date%: "17-Aug-90 14:46:25" {DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>SCREENPAPER.;1) (* ; " Copyright (c) 1901, 1986, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. ") (PRETTYCOMPRINT SCREENPAPERCOMS) (RPAQQ SCREENPAPERCOMS ((FNS SCREENPAPER SCREENPAPERNEWREGIONFN KALSHOW DOPOINT MAPN) [ADDVARS (IDLE.FUNCTIONS ("Screen wallpaper" 'SCREENPAPER] (* ;;; "faster versions of editbitmap functions") (FNS INVERT.BITMAP.HORIZONTALLY INVERT.BITMAP.VERTICALLY ROTATE.BITMAP) (VARS SCREENPAPERSIZE SCREENPERIOD SCREENREPEAT))) (DEFINEQ (SCREENPAPER + [LAMBDA (WINDOW REGION.OR.SIZE OPTION) (* ; "Edited 9-Sep-88 17:05 by bmw") + (OR WINDOW (SETQ WINDOW (CREATEW))) + (OR REGION.OR.SIZE (SETQ REGION.OR.SIZE (if (EQ OPTION 'PICK) + then (GETREGION 16 16 NIL (FUNCTION + SCREENPAPERNEWREGIONFN + )) + else SCREENPAPERSIZE))) + (LET ((SIZE (if (REGIONP REGION.OR.SIZE) + then (fetch (REGION WIDTH) + REGION.OR.SIZE) + else REGION.OR.SIZE)) + TRIANGLE STREAM BUF1 2SIZE BIGBUF PBT BUF1A BUF2 BUF3 BUF4 CX CY (CNT SCREENPERIOD)) + (DECLARE (SPECVARS TRIANGLE STREAM BUF1 2SIZE BIGBUF PBT BUF1A BUF2 BUF3 BUF4 CX CY CNT) + ) + (SETQ TRIANGLE (BITMAPCREATE SIZE SIZE)) + (SETQ BUF1 (BITMAPCREATE SIZE SIZE)) + (SETQ STREAM (DSPCREATE TRIANGLE)) + (FILLPOLYGON (LIST '(-1 . -1) + (CONS SIZE SIZE) + (CONS -1 SIZE)) + BLACKSHADE STREAM) + (SETQ BUF2 (BITMAPCREATE SIZE SIZE)) + (SETQ BUF3 (BITMAPCREATE SIZE SIZE)) + (SETQ 2SIZE (PLUS SIZE SIZE)) + (SETQ BIGBUF (BITMAPCREATE 2SIZE 2SIZE)) + (SETQ PBT (create PILOTBBT)) + (DSPDESTINATION BUF1 STREAM) + (if (EQ OPTION 'PICK) + then (bind POS do [RESETFORM (CURSOR CROSSHAIRS) + (until (MOUSESTATE (OR LEFT MIDDLE RIGHT] + (if (LASTMOUSESTATE (ONLY MIDDLE)) + then (RETURN BIGBUF) + elseif (LASTMOUSESTATE (ONLY RIGHT)) + then (RETURN NIL) + elseif (REGIONP REGION.OR.SIZE) + then (SETQ POS (CONS (fetch (REGION LEFT) + REGION.OR.SIZE) + (fetch (REGION BOTTOM) + REGION.OR.SIZE))) + (SETQ REGION.OR.SIZE) + else (SETQ POS (GETBOXPOSITION SIZE SIZE))) + (BITBLT (SCREENBITMAP) + (CAR POS) + (CDR POS) + BUF1 0 0 SIZE SIZE) + (KALSHOW BUF1 WINDOW SIZE + (if (SHIFTDOWNP 'SHIFT) + then 'INVERT + else NIL))) + else (MAPN WINDOW (FUNCTION (LAMBDA (X Y) + (BITBLT (WINDOWPROP WINDOW 'IMAGECOVERED) + X Y BUF1 0 0 SIZE SIZE) + (DRAWLINE (SUB1 SIZE) + 0 + (RAND 0 (SUB1 SIZE)) + (RAND 0 (SUB1 SIZE)) + 1 + 'INVERT STREAM) + (KALSHOW BUF1 WINDOW SIZE + (if (VIDEOCOLOR) + then NIL + else 'INVERT)) + (if (LEQ (add CNT -1) + 0) + then (SETQ CNT SCREENPERIOD) + (to SCREENREPEAT + do (BITBLT WINDOW 0 0 BUF1) + (KALSHOW BUF1 WINDOW SIZE]) (SCREENPAPERNEWREGIONFN +(LAMBDA (FP MP) (* BN "17-Sep-84 10:40") (COND (MP (with POSITION MP (PROG ((DX (IDIFFERENCE XCOORD (fetch (POSITION XCOORD) of FP))) (DY (IDIFFERENCE YCOORD (fetch (POSITION YCOORD) of FP)))) (COND ((IGREATERP (IABS DX) (IABS DY)) (SETQ YCOORD (IPLUS (fetch (POSITION YCOORD) of FP) (ITIMES DX (COND ((MINUSP (ITIMES DX DY)) -1) (T 1)))))) (T (SETQ XCOORD (IPLUS (fetch (POSITION XCOORD) of FP) (ITIMES DY (COND ((MINUSP (ITIMES DX DY)) -1) (T 1))))))) (RETURN MP)))) (T FP))) +) (KALSHOW +(LAMBDA (BUF1 WINDOW SIZE MODE) (* ; "Edited 5-Aug-88 11:54 by drc:") (BITBLT TRIANGLE NIL NIL BUF1 NIL NIL NIL NIL NIL (QUOTE ERASE)) (* THAT ERASED ALL BUT THE TRIANGLE) (ROTATE.BITMAP BUF1 BUF2 PBT) (INVERT.BITMAP.VERTICALLY BUF2 BUF3 PBT) (BITBLT BUF3 NIL NIL BUF1 NIL NIL NIL NIL NIL (QUOTE PAINT)) (LET (CX CY) (BITBLT BUF1 NIL NIL BIGBUF 0 SIZE) (INVERT.BITMAP.HORIZONTALLY BUF1 BUF2 PBT) (BITBLT BUF2 NIL NIL BIGBUF SIZE SIZE) (INVERT.BITMAP.VERTICALLY BUF1 BUF3 PBT) (BITBLT BUF3 NIL NIL BIGBUF 0 0) (INVERT.BITMAP.HORIZONTALLY BUF3 BUF2 PBT) (BITBLT BUF2 NIL NIL BIGBUF SIZE 0) (SETQ CX (QUOTIENT (WINDOWPROP WINDOW (QUOTE WIDTH)) 2)) (SETQ CY (QUOTIENT (WINDOWPROP WINDOW (QUOTE HEIGHT)) 2)) (for I from 0 while (LESSP I (QUOTIENT (PLUS 2SIZE (MAX CX CY)) 2SIZE)) do (for J from 0 while (LEQ J I) do (DOPOINT (FUNCTION (LAMBDA (X Y) (BITBLT BIGBUF NIL NIL WINDOW (PLUS CX (TIMES X 2SIZE)) (PLUS CY (TIMES Y 2SIZE)) NIL NIL MODE (QUOTE REPLACE)))) J I))) (BLOCK))) +) (DOPOINT + [LAMBDA (FN X Y) (* edited%: "31-Dec-00 16:08") + (if (LESSP X Y) + then (DOPOINT FN Y X)) + (APPLY* FN X Y 1) + (APPLY* FN (DIFFERENCE -1 X) + Y 1) + (APPLY* FN X (DIFFERENCE -1 Y) + 1) + (APPLY* FN (DIFFERENCE -1 X) + (DIFFERENCE -1 Y) + 1]) (MAPN + [LAMBDA (WINDOW FN) (* edited%: " 1-Jan-01 00:09") + (LET ((MAXX (DIFFERENCE (WINDOWPROP WINDOW 'WIDTH) + SIZE)) + (MAXY (DIFFERENCE (WINDOWPROP WINDOW 'HEIGHT) + SIZE)) + X Y NX NY STEPS) + (SETQ X (RAND 0 MAXX)) + (SETQ Y (RAND 0 MAXY)) + (while T do (SETQ NX (RAND 0 MAXX)) + (SETQ NY (RAND 0 MAXY)) + (SETQ STEPS (QUOTIENT (PLUS (ABS (DIFFERENCE NX X)) + (ABS (DIFFERENCE NY Y))) + 4)) + (if (NEQ STEPS 0) + then [for I from 1 to STEPS + do (APPLY* FN (PLUS X (QUOTIENT (TIMES (DIFFERENCE NX X) + I) + STEPS)) + (PLUS Y (QUOTIENT (TIMES (DIFFERENCE NY Y) + I) + STEPS] + (SETQ X NX) + (SETQ Y NY]) ) (ADDTOVAR IDLE.FUNCTIONS ("Screen wallpaper" 'SCREENPAPER)) (* ;;; "faster versions of editbitmap functions") (DEFINEQ (INVERT.BITMAP.HORIZONTALLY + [LAMBDA (BITMAP BM2 PBT) (* edited%: "31-Dec-00 17:15") + (OR BM2 (SETQ BM2 (BITMAPCOPY BITMAP))) + (OR PBT (SETQ PBT (create PILOTBBT))) + (with PILOTBBT PBT (SETQ PBTDESTLO (ffetch BitMapLoLoc BM2)) + (SETQ PBTDESTHI (ffetch BitMapHiLoc BM2)) + (SETQ PBTSOURCELO (ffetch BitMapLoLoc BITMAP)) + (SETQ PBTSOURCEHI (ffetch BitMapHiLoc BITMAP)) + (SETQ PBTDESTBPL (TIMES 16 (ffetch BITMAPRASTERWIDTH BM2))) + (SETQ PBTSOURCEBPL (TIMES 16 (ffetch BITMAPRASTERWIDTH BITMAP))) + (SETQ PBTFLAGS 16384) (* by experiment, disjoint replace) + (SETQ PBTHEIGHT (ffetch BITMAPHEIGHT BITMAP)) + (SETQ PBTWIDTH 1) + (for I from 0 while (LESSP I (ffetch BITMAPWIDTH BITMAP)) + do (SETQ PBTSOURCEBIT I) + (SETQ PBTDESTBIT (DIFFERENCE (SUB1 (ffetch BITMAPWIDTH BITMAP)) + I)) + (\PILOTBITBLT PBT 0))) + BM2]) (INVERT.BITMAP.VERTICALLY + [LAMBDA (BITMAP BM2 PBT) (* edited%: "31-Dec-00 18:13") + (OR BM2 (SETQ BM2 (BITMAPCOPY BITMAP))) + (OR PBT (SETQ PBT (create PILOTBBT))) + [with PILOTBBT PBT (*) + (SETQ PBTDESTHI (ffetch BitMapHiLoc BM2)) + [SETQ PBTDESTLO (PLUS (ffetch BitMapLoLoc BM2) + (TIMES (SUB1 (ffetch BITMAPHEIGHT BITMAP)) + (ffetch BITMAPRASTERWIDTH BM2] + (SETQ PBTSOURCELO (ffetch BitMapLoLoc BITMAP)) + (SETQ PBTSOURCEHI (ffetch BitMapHiLoc BITMAP)) + (SETQ PBTDESTBPL (TIMES 16 (ffetch BITMAPRASTERWIDTH BM2))) + (SETQ PBTSOURCEBPL (TIMES 16 (ffetch BITMAPRASTERWIDTH BITMAP))) + (SETQ PBTSOURCEBIT 0) + (SETQ PBTDESTBIT 0) + (SETQ PBTFLAGS 16384) (* by experiment, disjoint replace) + (SETQ PBTHEIGHT 1) + (SETQ PBTWIDTH (ffetch BITMAPWIDTH BITMAP)) + (for I from 0 while (LESSP I (ffetch BITMAPHEIGHT BITMAP)) + do (\PILOTBITBLT PBT 0) + (add PBTSOURCELO (ffetch BITMAPRASTERWIDTH BITMAP)) + (add PBTDESTLO (MINUS (ffetch BITMAPRASTERWIDTH BM2] + BM2]) (ROTATE.BITMAP + [LAMBDA (BITMAP BM2 PBT) (* edited%: "31-Dec-00 16:24") + [OR BM2 (SETQ BM2 (BITMAPCREATE (ffetch BITMAPHEIGHT BITMAP) + (ffetch BITMAPWIDTH BITMAP] + (OR PBT (SETQ PBT (create PILOTBBT))) + [with PILOTBBT PBT (*) + (SETQ PBTDESTHI (ffetch BitMapHiLoc BM2)) + (SETQ PBTDESTLO (ffetch BitMapLoLoc BM2)) + (SETQ PBTSOURCELO (ffetch BitMapLoLoc BITMAP)) + (SETQ PBTSOURCEHI (ffetch BitMapHiLoc BITMAP)) + (SETQ PBTDESTBPL (TIMES 16 (ffetch BITMAPRASTERWIDTH BM2))) + (SETQ PBTSOURCEBPL 1) + (SETQ PBTSOURCEBIT 0) + (SETQ PBTDESTBIT (ffetch BITMAPWIDTH BM2)) + (SETQ PBTFLAGS 0) (* by experiment, disjoint replace) + (SETQ PBTHEIGHT (ffetch BITMAPHEIGHT BM2)) + (SETQ PBTWIDTH 1) + (for I from 0 while (LESSP I (ffetch BITMAPHEIGHT BITMAP)) + do (add PBTDESTBIT -1) + (\PILOTBITBLT PBT 0) + (add PBTSOURCELO (ffetch BITMAPRASTERWIDTH BITMAP] + BM2]) ) (RPAQQ SCREENPAPERSIZE 64) (RPAQQ SCREENPERIOD 100) (RPAQQ SCREENREPEAT 0) (PUTPROPS SCREENPAPER COPYRIGHT ("Venue & Xerox Corporation" 1901 1986 1988 1990 2020)) (DECLARE%: DONTCOPY (FILEMAP (NIL (851 8746 (SCREENPAPER 861 . 5549) (SCREENPAPERNEWREGIONFN 5551 . 6058) (KALSHOW 6060 . 7050) (DOPOINT 7052 . 7424) (MAPN 7426 . 8744)) (8870 12612 (INVERT.BITMAP.HORIZONTALLY 8880 . 9997) ( INVERT.BITMAP.VERTICALLY 9999 . 11375) (ROTATE.BITMAP 11377 . 12610))))) STOP \ No newline at end of file diff --git a/rooms/SCREENPAPER.LCOM b/rooms/SCREENPAPER.LCOM new file mode 100644 index 0000000000000000000000000000000000000000..d1edceaee4d58d4005cc97922852f567d060292d GIT binary patch literal 5795 zcmcIoOKcn06&+Hlow%h;#Wm0xZt}n;DP=$cXNEt?g}_I0s2P!*8P5zw$w_0&B4e4P zK9H@XK~pphy6L8Xi!QopfdmEGMGGiNv*`yc3KUQm>WYr5bkR+NF1m4`b)la3=EI@v zG(m#MFz3Dde)rvb?zwj+Syn2Vu1r_7nli2F6@xr!(o&T!C?uijj$+j`+f0xrErpgH zTCANA7pbifF*OxSvJFa@`uNhu;`=j7~MMoN%mVr^?<`&O^rB3ql7 z6#Guuu73BMjoa;=+w-eCyPGe!du!|Sc6Fs}X-mp{*(f#YitgC+4P9HFXPV5{%F4WD z7%8CugF?1W!ht!c=bu=Q96@K(GsSpVY zTvgDJ3DeDJqM0VeMnyy;LrS`XXO_4(vlJ7Mh9F052k5S&nfJy3H_a$R_3uSb3sL)V zruARP3)JbftX7O)#p)iS(>*-H#yWnZdy{pW6S33m>DU&Zdw2Z@T>d2{Y-}74*3NW} ze%*|(omrZkjC5Djqr2;IyVG*`gg%yikT&O zT#VK_E!B&TeyyMm5Blxtp<()O9p5bQE>{{HAj>IIr>0J1Aj-$NoPvv0t>PexbvQW> zsQ9p#08-a2hy$!763`DGDH_Xwp2poRG1zl=V>pGl24!)ey0itEOrEbVA@MjwoDJfh zB^sCQ#9W?~8kUV{64SG!Y@20pl%`X@y@+UX4|fwIP!3RYZF~X4`-mWwCdi~U)2OX1 z0Fc-pn|iZzCnjf4Y@bdCw~_f>-Mb-5+zpxtQdvSkqU+^Lb`1$OP5A*Wv1>Au5=qQI zM6$2~EPldDVh%xU8Mdub&9ag2hc?M%h^dvT2=iI;>iC$c)eNUtbet7a`TDCwnhmR> zD@|A5ijJJk*Fj&BPm|=dNM^{iI5k4>;rTr4u)r=eGD(s0G7sgt$yvW*P7$FV6@(~# zcf1gf6e5Q-T8JJ_Mk5{d!#C8|JL+La`|u6z^^SJ<;oIkFA*yy%?fs)4ZydkYegE%Y z-8)AM5iKnG3XKc8R*SL!$U7b&Ln&}H=cGJxsz61Lu~;Gscm)PzsVPnBMwz81q@fk) z{G@P7h+bK5S$4sEZ_uFlS#LQ!E@FOQNVx#>Fqg#m%dF87%aVa!J{iko5#|ATyCmq^ z3MXrzN`5kEL*h-R+t7-<2&uFD=mJt>hhfj_|)exjXmSz<;t zEbXeHJG53?L9&EHe7+M=e7Q;4pUV=oR^l@ewZX)^AM5_Skv+kh!AukgL0is#^zOJU z>N`|s-j29*u#jOAnvDdAh>cZ6TTo$=G{afhQAs96OvJWH;#+wheGYo#_g_HKe5iLPqmLPJW8&zY zrx!8Hh`*=bA5<~VZS|t`>_p#)cL&$vd;d6B`(6F_d%qBpNH(-+lU#~F09IZSX1tOx zo$*SY81=zu8xq2>e2Fn<^8jI{jZ3G@9a z0iQ*A@;UUb_JKc+eIOzTmZcak?LU4<*$H z2V;S#;EPUsqRoPEa3)wicJR2@?jAhW2R#UCVSgM{@vM8UdT=V3JKjB1?;SwT&P#o@ zJ6PVkj|7rrtjTJVl3}heYaw&`DH4TqxP$N;j!3AFy-W%YfR+3X!aQi_LX)zgIV{fn z`Euw8DSSfy;cWc~&xHu)lltw!$NFvPEBLUmKh`~Do*4w*{A?cV1U~67Z*Y8sz1j_Y z3Re!jItH)ineW^c?(hCM05S;RSxx5Bw+|Vt~TOJ_&^b<<+GJoKgk8T&?Kne@t)lX8+wR&+Zo4Y$LEzW?Uu*99z7Pmv@o zmzOBsJ(4jE9|dPB4ZXzPz#vH2Ydh`sCV6?a*V|s*ZtvhT=54a|B5Aj7-MMk=&c^CCd2x4h?GBSCu!L#-f3n%=P>3#L zBe8;wxb`7y@gm&o^REh?y6*QVs2gKp% MeLBW1+56T108UG;L;wH) literal 0 HcmV?d00001 diff --git a/rooms/TABLE-OF-CONTENTS.TEDIT b/rooms/TABLE-OF-CONTENTS.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..c4a761d0fc8fbdbece79394cd54ff01c72446a17 GIT binary patch literal 2492 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.;2| 7138 IL:|previous| IL:|date:| "17-Aug-90 14:46:54" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>TOUCHY-BUTTONS.;1|) ; Copyright (c) 1987, 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:TOUCHY-BUTTONSCOMS) (IL:RPAQQ IL:TOUCHY-BUTTONSCOMS ( (IL:* IL:|;;| "Includer buttons so you can have dynamic mixin rooms. For example, you can have a \"Notecards-Mixin\" or \"Programming-Mixin\" Room and have buttons to include these in \"Pockets\" then whenever you need these facilities you can mix them in.") (IL:FUNCTIONS MAKE-INCLUDER INCLUDER-TEXT INCLUDER-ACTION) (IL:* IL:|;;| "Toggle buttons for switching between variable settings. This should obviously be generalized to something that allows you to select or circulate through value settings.") (IL:FUNCTIONS MAKE-TOGGLER MAKE-N-VALUER MAKE-EXSET-TOGGLER MAKE-RANGE-TOGGLER N-VALUER-ACTION N-VALUER-TEXT CHECK-EVAL) (IL:FUNCTIONS MAKE-SWITCH SWITCH-ACTION) (IL:* IL:|;;| "") (IL:* IL:|;;|  "(MAKE-ONCE-ONLY (IL:PROMPTPRINT \"Hello, World\") \"Fire...\" \"Exhausted\")") (IL:FUNCTIONS MAKE-ONCE-ONLY ONCE-ONLY-ACTION ONCE-ONLY-TEXT) (IL:DECLARE\: IL:DONTCOPY (IL:PROPS (IL:TOUCHY-BUTTONS IL:MAKEFILE-ENVIRONMENT) (IL:TOUCHY-BUTTONS IL:FILETYPE))))) (IL:* IL:|;;| "Includer buttons so you can have dynamic mixin rooms. For example, you can have a \"Notecards-Mixin\" or \"Programming-Mixin\" Room and have buttons to include these in \"Pockets\" then whenever you need these facilities you can mix them in." ) (DEFUN MAKE-INCLUDER (ROOM-NAME) (MAKE-BUTTON-WINDOW (MAKE-BUTTON :TEXT-FORM (LIST 'INCLUDER-TEXT ROOM-NAME) :ACTION 'INCLUDER-ACTION :INCLUDER-ROOM-NAME ROOM-NAME))) (DEFUN INCLUDER-TEXT (INCLUDER-ROOM-NAME) (LET ((INCLUSIONS (ROOM-INCLUSIONS *CURRENT-ROOM*))) (IF (LISTP INCLUSIONS) (IF (MEMBER INCLUDER-ROOM-NAME INCLUSIONS :TEST #'EQUAL) (FORMAT NIL "Exclude ~A" INCLUDER-ROOM-NAME) (FORMAT NIL "Include ~A" INCLUDER-ROOM-NAME)) (FORMAT NIL "*-???-* ~A" INCLUDER-ROOM-NAME)))) (DEFUN INCLUDER-ACTION (DSP BUTTON) (LET* ((ROOM *CURRENT-ROOM*) (INCLUDER-ROOM-NAME (BUTTON-PROP BUTTON :INCLUDER-ROOM-NAME))) (UPDATE-PLACEMENTS) (IF (MEMBER INCLUDER-ROOM-NAME (ROOM-INCLUSIONS ROOM) :TEST #'EQUAL) (SETF (ROOM-INCLUSIONS ROOM) (DELETE INCLUDER-ROOM-NAME (ROOM-INCLUSIONS ROOM) :TEST #'EQUAL)) (PUSH INCLUDER-ROOM-NAME (ROOM-INCLUSIONS ROOM))) (ROOM-CHANGED ROOM :EDITED))) (IL:* IL:|;;| "Toggle buttons for switching between variable settings. This should obviously be generalized to something that allows you to select or circulate through value settings." ) (DEFUN MAKE-TOGGLER (VARIABLE-NAME &REST KEYS) (APPLY #'MAKE-N-VALUER VARIABLE-NAME '(NIL T) KEYS)) (DEFUN MAKE-N-VALUER (VARIABLE-NAME N-VALUES &REST KEYS) (MAKE-BUTTON-WINDOW (APPLY #'MAKE-BUTTON :TEXT-FORM `(N-VALUER-TEXT ',VARIABLE-NAME) :ACTION 'N-VALUER-ACTION :VARIABLE-NAME VARIABLE-NAME :N-VALUES N-VALUES KEYS))) (DEFUN MAKE-EXSET-TOGGLER (VARIABLE-NAME EXPLICIT-SET &REST KEYS) (APPLY #'MAKE-N-VALUER VARIABLE-NAME EXPLICIT-SET :HELP (FORMAT NIL "Set variable ~S" VARIABLE-NAME) KEYS)) (DEFUN MAKE-RANGE-TOGGLER (VARIABLE-NAME RANGE-START RANGE-END &REST KEYS) (APPLY #'MAKE-N-VALUER VARIABLE-NAME (DO ((I RANGE-START (1+ I)) (ACCUMULATOR NIL ACCUMULATOR)) ((> I RANGE-END) (NREVERSE ACCUMULATOR)) (PUSH I ACCUMULATOR)) :HELP (FORMAT NIL "Set variable ~S" VARIABLE-NAME) KEYS)) (DEFUN N-VALUER-ACTION (DSP BUTTON) (LET* ((N-VALUES (BUTTON-PROP BUTTON :N-VALUES)) (VARIABLE-NAME (BUTTON-PROP BUTTON :VARIABLE-NAME))) (SETQ N-VALUES (REMOVE (CHECK-EVAL VARIABLE-NAME) N-VALUES)) (SET VARIABLE-NAME (IF (EQ (LENGTH N-VALUES) 1) (CAR N-VALUES) (IL:MENU (IL:CREATE IL:MENU IL:ITEMS IL:_ N-VALUES)))))) (DEFUN N-VALUER-TEXT (VARIABLE-NAME) (FORMAT NIL "~A is ~a" VARIABLE-NAME (CHECK-EVAL VARIABLE-NAME))) (DEFUN CHECK-EVAL (VARIABLE-NAME) (IF (BOUNDP VARIABLE-NAME) (EVAL VARIABLE-NAME) "Unbound")) (DEFUN MAKE-SWITCH (DECISION-FN SET-FN TEXT-FORM &REST KEYS) (MAKE-BUTTON-WINDOW (APPLY #'MAKE-BUTTON :TEXT-FORM TEXT-FORM :ACTION 'SWITCH-ACTION :DECISION-FN DECISION-FN :SET-FN SET-FN KEYS))) (DEFUN SWITCH-ACTION (DSP BUTTON) (LET* ((VALUE (FUNCALL (BUTTON-PROP BUTTON :DECISION-FN) BUTTON))) (FUNCALL (BUTTON-PROP BUTTON :SET-FN) BUTTON VALUE))) (IL:* IL:|;;| "") (IL:* IL:|;;| "(MAKE-ONCE-ONLY (IL:PROMPTPRINT \"Hello, World\") \"Fire...\" \"Exhausted\")") (DEFUN MAKE-ONCE-ONLY (FORM INITIAL-TEXT FINAL-TEXT) (MAKE-BUTTON-WINDOW (MAKE-BUTTON :TEXT INITIAL-TEXT :TEXT-FORM 'ONCE-ONLY-TEXT :ACTION 'ONCE-ONLY-ACTION :ONCE-ONLY-FORM FORM :INITIAL-TEXT INITIAL-TEXT :FINAL-TEXT FINAL-TEXT))) (DEFUN ONCE-ONLY-ACTION (STREAM BUTTON) (UNLESS (IL:STREAMPROP (IL:GETSTREAM STREAM) BUTTON) (IL:* IL:|;;| "store the state of the button on its host, so that the state is reset each time the button is reconstituted.") (EVAL (BUTTON-PROP BUTTON :ONCE-ONLY-FORM)) (IL:STREAMPROP (IL:GETSTREAM STREAM) BUTTON T))) (DEFUN ONCE-ONLY-TEXT (STREAM BUTTON) (WHEN STREAM (IF (IL:STREAMPROP (IL:GETSTREAM STREAM) BUTTON) (BUTTON-PROP BUTTON :FINAL-TEXT) (BUTTON-PROP BUTTON :INITIAL-TEXT)))) (IL:DECLARE\: IL:DONTCOPY (IL:PUTPROPS IL:TOUCHY-BUTTONS IL:MAKEFILE-ENVIRONMENT (:PACKAGE "ROOMS" :READTABLE "XCL")) (IL:PUTPROPS IL:TOUCHY-BUTTONS IL:FILETYPE :COMPILE-FILE) ) (IL:PUTPROPS IL:TOUCHY-BUTTONS IL:COPYRIGHT ("Venue & Xerox Corporation" 1987 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1998 2231 (MAKE-INCLUDER 1998 . 2231)) (2233 2617 (INCLUDER-TEXT 2233 . 2617)) (2619 3191 (INCLUDER-ACTION 2619 . 3191)) (3390 3506 (MAKE-TOGGLER 3390 . 3506)) (3508 3801 (MAKE-N-VALUER 3508 . 3801)) (3803 4060 (MAKE-EXSET-TOGGLER 3803 . 4060)) (4062 4566 (MAKE-RANGE-TOGGLER 4062 . 4566) ) (4568 5108 (N-VALUER-ACTION 4568 . 5108)) (5110 5223 (N-VALUER-TEXT 5110 . 5223)) (5225 5339 ( CHECK-EVAL 5225 . 5339)) (5341 5571 (MAKE-SWITCH 5341 . 5571)) (5573 5783 (SWITCH-ACTION 5573 . 5783)) (5913 6212 (MAKE-ONCE-ONLY 5913 . 6212)) (6214 6591 (ONCE-ONLY-ACTION 6214 . 6591)) (6593 6817 ( ONCE-ONLY-TEXT 6593 . 6817))))) IL:STOP \ No newline at end of file diff --git a/rooms/TOUCHY-BUTTONS.DFASL b/rooms/TOUCHY-BUTTONS.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..ba3962a60d3f792ee6576553b6a07c1e918895f1 GIT binary patch literal 4569 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 literal 0 HcmV?d00001 diff --git a/rooms/TOUCHY-BUTTONS.TEDIT b/rooms/TOUCHY-BUTTONS.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..6c12520d177734e7f14b821ec3e25231970719a2 GIT binary patch literal 4074 zcmeHJ&2HO95T+a_jhhNZfi_9e9tP?m5?~3o>Nt*26kue^+J+)kigMx>J*=d)M3~|V zT+)v62s!pC`V77HlE>=Il9c5nPJa$Lg@DQ3+4=eQn{QY4T(>uX;lT0+54L=F*zTUx zpA3E9bq3{Txx7~{@0QD%9SS>I(EeoE0`T~pM;t#As`zRwc&$8CLbbq?a<0n$EKo3! z<8&^f1VXM75R)Jg6Oa-7#G{nQOK3K?;ozWAW{&TwM5F;EGXW~$ ziJ%lTxsY)<0gkKV8IQ2oH69l;5rHl#CJkgEn9dT2!5pUzlbQ;ot%F1Xg>M{zKnDs=aFy;}=`I*4YUdaHXC9Z{G5KSQ_rdus?tN)OB z)v4}}n1jJZ5QdOY3YAW$LL~vwb1Gx3w*-kBL~b=f3n3RFZ8?a}u;>y-0#YST(-0KG z6~G?MA&Hk%Gm*eYDv9|x(H!OA5;2}dGL%!oj}p;Bf;NiD_pq<7Hz-#yFv8YFoc{(r8R5e=D<`B6oi=JB2enir9%?nR9Kj?|i;yq#lMy6<*O+)Q4U<0Z|0vA{;QP!1i}W-fC&E>um=e8SpL!Bm)d;G3S$oFj_;4i0Ki z-GLq0-)+L9$4#77b!3s%Gi}#>I)LiWL-P>Ymg8HVby$OT*Yxt0!H`O~J=XUz5p#~& zfT7C3?Q~#Z*;d={BM@KDamPLytix=T@b2zF$LuleV$a3H?tpu2c{X$M1ir_fTJA6l zA3EryQme9+^WWv~kJ$SUY2M?R; zv0A7EKz9&b9`D26!+qG_*~!w^F!F!27^6P6^kYjup3)C>N^3QJE#EY58BOE9aliE1 z_yjGb8=Lqly)Nn1>t0P-_)ihrdBhj^-Q2iAvumGi{jPBve{Fj7OKyC+vfeYcx|V%x z`K)cOnJ*LMt{cW$(#!Bmzr4^DKcXpnF8%V@yo(!}N*zlUZKY;^PGL9cWn?ZJxOS)O z4Q;D&WceMZ^iDW=h9Z!@A2yKMtg&ZX-!RDVJ_whz<=BhBf5LukASw83{9DmS2JKzY zf;}>}3lB|srp^sSn!A!gudKzC{wiW~T&_iZukiSm2JcLw3YV;#hT)KbAQguEd-Hdr I{qoPh0gkVT@Bjb+ literal 0 HcmV?d00001 diff --git a/rooms/UN-HIDE-TTY b/rooms/UN-HIDE-TTY new file mode 100644 index 00000000..8cf6f5dd --- /dev/null +++ b/rooms/UN-HIDE-TTY @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:37:26"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>UN-HIDE-TTY.;2| 1806 IL:|previous| IL:|date:| "17-Aug-90 14:47:42" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>UN-HIDE-TTY.;1|) ; Copyright (c) 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:UN-HIDE-TTYCOMS) (IL:RPAQQ IL:UN-HIDE-TTYCOMS ((FILE-ENVIRONMENTS IL:UN-HIDE-TTY) (IL:* IL:|;;| "make Control-Y be an interrupt which yanks the window with the TTY process into the current room.") (IL:P (EXPORT 'UN-HIDE-TTY "ROOMS")) (IL:FUNCTIONS UN-HIDE-TTY) (IL:P (IL:INTERRUPTCHAR (CHAR-CODE #\^Y) '(UN-HIDE-TTY))))) (DEFINE-FILE-ENVIRONMENT IL:UN-HIDE-TTY :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (IL:* IL:|;;| "make Control-Y be an interrupt which yanks the window with the TTY process into the current room.") (EXPORT 'UN-HIDE-TTY "ROOMS") (DEFUN UN-HIDE-TTY () (LET ((TTY-WINDOW (IL:WFROMDS (IL:PROCESS.TTY (IL:TTY.PROCESS)) T))) (IF TTY-WINDOW (IF (WINDOW-HIDDEN? TTY-WINDOW) (UN-HIDE-WINDOW TTY-WINDOW) (IL:FLASHWINDOW TTY-WINDOW)) (FORMAT IL:PROMPTWINDOW "~%No TTY window to un-hide!~%")))) (IL:INTERRUPTCHAR (CHAR-CODE #\^Y) '(UN-HIDE-TTY)) (IL:PUTPROPS IL:UN-HIDE-TTY IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1274 1627 (UN-HIDE-TTY 1274 . 1627))))) IL:STOP \ No newline at end of file diff --git a/rooms/UN-HIDE-TTY.DFASL b/rooms/UN-HIDE-TTY.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..48e2a2602330da6f2bb97170fa101d5b3210575e GIT binary patch literal 1685 zcmcIkZExFD6t>+qFQhHWST`yd+%4)P${cN}Iz)?tjD53MO>AR3ZSsvQy(7_*IC5;t zG;KnBwkRX4x<>FP_yc@F`z8F3a_)87M1Usk1O9Mdj_-Z$bIy6rc_Cz4Y8|QGaNHjd zA9-Og4g>Va^U=f${VqX|z>c13&cU+U;Em-0`GyQw+=dcB z&>y2rwP~oXZW?qdeka`kz`Ta5x`Abe3)ib=9uSvJ3mZ}nE~Lz+3y>*TW;NZ${Ic{e zoh~yA@X%c4i#n#!5@ZZaX-iQLlm}o~;c*selzM7}gTXTa{1k4^UF5EDKmXv%>xq{% zDwO}heZv04ON_FZ2g+$6WZ9;*^d4;9UPzw`iA{km%bd|5L=FpCZsCM0;o&=oVw1#QSpQ2-%BtJ8==N#~&oFtm%e} zZM$i?YE7{d+$>vy-x~g5lO076?zotPk^U^v=qlQkLHRNh{iWt#M$P}F2Dwx|{!gjQ zjeN!RlNV@odr`&9_!Ka&I#Rfa9xwuP_78%$7F z8_EHc37lAf7UK;O;hLU|EnzLe8gP*p$HKdQoVi2Cw);aG4RvSubbDkqdqziZy6&ZV zpsI(ey05D1M!dp!wm2o~#Q8O~^DGOZYpRtGt%3H-E0M(STWz~vSKVolk{^%r8xds` zdTB<&4>I9X9FaClf{+f58?=9NeB4qUiDW$WqHB>-HWf4vB0ru}x=1r|Luo#q!t7-f z&qP!%rsO4pqBtWjoO_Fu-UVrJ6^a(oFuoDw&1PXR_Oc+3Qko?q1(XMZtUM*`o7m4o z1jvwkmH|*q9?J0HjiS;Z%VpG-YELqTGsVTj-zp*bVjTEfOH66zB^l)@ljT)~&8GoM zLNvx-rl%mI>)@Sa0Hu}`FdJi3nxU?CPjlG`$;5l_W(JV)q+sWEe(b$qREBxlHtnI# zju(d2u`jyjIY+PzlWH8=7ZWcJvw9J`$XPHOib=`0hcXkEB}ix-N0AsasT^h;#;Nd; z&6q$}L80&%ztqcH4@m)26eC7LNgUtch3RDC)>xM6mVT>5jVe$W(v3*aItxlfGf!Dg zLDRtZSq0fKfO3|jBhtbr^WK&XB`GYV0?nKVRjyUjpgHr5st_y-CJV$~iNI)QIr76d zh#)E_9_LBI&CT_+)S7JK)3qa0-+tZABgxep6$G(QDe64PxS>mBt3CincjGo>#+0rS zoVn=($q^OdP>lzK0CyWnp?jgxeGqWsWlx2P@chNH86hz5PREG=yLbdO$e+>#hk06w z4m%DZtWiuHsI0FRv~UjDf0o2!k){PiHoO&!tJq6?nnI*oUiBi22a(g%yN0^VGh&O$ z1TDu|FgGHeA*BKcjssdI#c@OjvV=uvFw~NM?mo`#6^)BCc zh2A_Hxvp(B3*J;BDy3apq*GUa<37ZYHioBEqZ!SE7a?1JC3p>4x5+T zuMHHDB>60Rqn@Fn>svGLZg1SzZgjPfYV%CFtu~NAYB|Q3Dw&0u3nI*+Fa&pUT&=Y! zuZFSbOG%~UJU}1uV4BCt+p@VN-y!2SolJp=kWkk)4coA~Hq|soJ2Tp}yNka%4PDJ~ z4eOkJf25N-)%IwQj`k1e`N;v^YSOcc>S(5IzZg>O*OAttwr;t)qj%)EbIO(Bh*P&6 zW8fl?VZAhl#+j*;-R;s)H}$qV01#Kc4;LbjKq5rS6!9 zRR(Y!omeT^hUqk8g3?+I;lTHfe7tACwOp$I6p`v6mgUHi6_b zzaFmvgZ$k=y~7izoNUU@+E^=ge{$Udy6=@I#V}XCS+4(}Z1;5YrS2MSP5F9hUTrOH zo64H|ef!FgxArk1tKTMsP>R&dz2u*FNY8?aV#_Ahc6!dp)LZAe+qE|CO|7QnXT#?ptSBn6SC0RL{Xs{tt;jB~SYT2c_*d8<87^9vVJXTV)k=X=*_46T weZQ-ANM8=WQ&~!%4gZco`T4G4eAlpD8J1B$N&Hu}rA&iYiTO#c?En7f--i&*bN~PV literal 0 HcmV?d00001 diff --git a/rooms/USERINTRO.TEDIT b/rooms/USERINTRO.TEDIT new file mode 100644 index 0000000000000000000000000000000000000000..5a40bb3c7d0548894bfa609216eeccada05f8efa GIT binary patch literal 3356 zcmeHJ&2rl|5Qcw}PV4g49x}b`qz6kg8jYm+5N;b8;&dv67`| z))*krDRExnoUj6al4ZD_vK5YH4W~%OE^y>5yJlBPgW=SLFqSJ2xddG<7Ah}f1k)81 zv4kXxlB*;tMXF&LD_G{LkmQ+nAX5c}@eDI{p_-u(zetTP$faJWOefPMO^Ovm2-*lQ3te|6FrDzA(FHM z3ZXfYOo|v(maaf%s=SOb1WV6Fk*Ev`1(&igJW4Hd(1oDQB6+*A7HUB(B$aK7bxeFF zuv|qDL|MeR9VE2OlLFayK%^?Wtcu5Im#Lf;xyq6mZ7>Clo^*q5wGdH+;*ezHR0`bg zOl5_bRSfFfW*Z_~!6H}FRL(W5REh8v#NtYJEw^feC{P_;+*1yBJxj|78>-42m7S?b zV!bdfHB6;WBJ9yrCP*1|xF}N+lA5YzdL^~l@wyGf0ndPhOQj-^@5Fq8&7qp;xXi_z z)SXc#vQ!9|TH+Cn>ow>Ms)= zH!1L$$ z*M=ap{m^kw3Hv?lx1qHMdvLJdgTt3ST(u0c$?Drf&wCv}>&Jz_7@XOD z?FlASdf+?b5ED7>8z*pH4LNuxClK%uEQAq1b|xbt z#{H%;U7SW75-$kPkuJWqQ8j;LqdNCwLt*w0`|!g7^p1{jYFF{CGj1QFn3Y`hB0MJ& z6W2utnGk!_hr@m!Ui5BbL;f~2K+{1Cd3gZ+7YA^#w^yZaBl3T=7*UTceQfFDSNgfW z(stWi%TL%7)}yzL59|w?wzhHD_^@HT4-E}s2LrbM6QaZ3v-cZE>?t8Ow;oDt>`g2! zwl|T_C!RC%A$RlKVX{N_P<_9#om-b%6@72qMlHT!Ppd1PeSPC!+rFx7o9tFxZ9~sG zuEu^8M>}6Xn^=nw_>j~X$&AJ5UddC1Y@&bX%*X$gyQe%naW`(2S(mP|um(t)eO@3{ z{+2dTwQJK*`4okMtwXLk(jx4VWvZyW9rF#WFTZvDkNzy9$zj=%Af literal 0 HcmV?d00001 diff --git a/rooms/WALLPAPER b/rooms/WALLPAPER new file mode 100644 index 00000000..90632647 --- /dev/null +++ b/rooms/WALLPAPER @@ -0,0 +1 @@ +(DEFINE-FILE-INFO READTABLE "XCL" PACKAGE "ROOMS") (IL:FILECREATED " 5-Dec-2020 16:37:39"  IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>WALLPAPER.;2| 3287 IL:|previous| IL:|date:| "17-Aug-90 14:48:22" IL:|{DSK}arunwelch>SKYDRIVE>DOCUMENTS>UNIX>LISP>LDE>ROOMS>MEDLEY-35>WALLPAPER.;1|) ; Copyright (c) 1988, 1990, 2020 by Venue & Xerox Corporation. All rights reserved. (IL:PRETTYCOMPRINT IL:WALLPAPERCOMS) (IL:RPAQQ IL:WALLPAPERCOMS ((FILE-ENVIRONMENTS IL:WALLPAPER) (IL:P (EXPORT '(MAKE-WALLPAPER-WINDOW HACK-BACKGROUND) "ROOMS")) (IL:FILES (IL:SYSLOAD) IL:SCREENPAPER) (IL:FUNCTIONS MAKE-WALLPAPER-WINDOW WALLPAPER-WINDOW-BUTTONEVENTFN HACK-BACKGROUND) (IL:WINDOW-TYPES :WALLPAPER))) (DEFINE-FILE-ENVIRONMENT IL:WALLPAPER :COMPILER :COMPILE-FILE :PACKAGE "ROOMS" :READTABLE "XCL") (EXPORT '(MAKE-WALLPAPER-WINDOW HACK-BACKGROUND) "ROOMS") (IL:FILESLOAD (IL:SYSLOAD) IL:SCREENPAPER) (DEFUN MAKE-WALLPAPER-WINDOW (&OPTIONAL REGION) (LET ((WINDOW (IL:CREATEW REGION "Wallpaper" 10))) (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN 'WALLPAPER-WINDOW-BUTTONEVENTFN) WINDOW)) (DEFUN WALLPAPER-WINDOW-BUTTONEVENTFN (WINDOW) (NOTIFY-USER "Pick regions of the screen with LEFT~%Press MIDDLE when satisfied, RIGHT to abort.") (LET ((SHADE (IL:SCREENPAPER WINDOW NIL 'IL:PICK))) (WHEN SHADE (HACK-BACKGROUND SHADE)))) (DEFUN HACK-BACKGROUND (SHADE &OPTIONAL (ROOM *CURRENT-ROOM*)) (IL:* IL:|;;;| "set the first shade specification of ROOM to be SHADE, or add a :WHOLE-SCREEN specification ROOM has no shades specified.") (IL:* IL:|;;| "always call this before we hack a room") (UPDATE-PLACEMENTS) (LET ((SPECS (BACKGROUND-EXTERNAL-FORM (ROOM-BACKGROUND ROOM)))) (DOLIST (SPEC SPECS (PUSH (LIST :WHOLE-SCREEN SHADE) SPECS)) (CASE (FIRST SPEC) (:WHOLE-SCREEN (SETF (SECOND SPEC) SHADE) (RETURN)) (:REGION (SETF (GETF SPEC :SHADE) SHADE) (RETURN)))) (SETF (ROOM-BACKGROUND ROOM) (MAKE-BACKGROUND SPECS))) (IL:* IL:|;;| "always call this after we hack a room") (ROOM-CHANGED ROOM :EDITED)) (DEF-WINDOW-TYPE :WALLPAPER :RECOGNIZER (LAMBDA (WINDOW) (EQ (IL:WINDOWPROP WINDOW 'IL:BUTTONEVENTFN) 'WALLPAPER-WINDOW-BUTTONEVENTFN)) :ABSTRACTER (LAMBDA (WINDOW) (LIST :REGION (EXTERNALIZE-REGION (WINDOW-REGION WINDOW)))) :RECONSTITUTER (LAMBDA (ARGS) (MAKE-WALLPAPER-WINDOW (INTERNALIZE-REGION (GETF ARGS :REGION)))) :TITLE "Wallpaper" :FILES (IL:WALLPAPER)) (IL:PUTPROPS IL:WALLPAPER IL:COPYRIGHT ("Venue & Xerox Corporation" 1988 1990 2020)) (IL:DECLARE\: IL:DONTCOPY (IL:FILEMAP (NIL (1232 1435 (MAKE-WALLPAPER-WINDOW 1232 . 1435)) (1437 1695 ( WALLPAPER-WINDOW-BUTTONEVENTFN 1437 . 1695)) (1697 2636 (HACK-BACKGROUND 1697 . 2636))))) IL:STOP \ No newline at end of file diff --git a/rooms/WALLPAPER.DFASL b/rooms/WALLPAPER.DFASL new file mode 100644 index 0000000000000000000000000000000000000000..e0c40361225dc2ab3f895f5e37f24c776434d20b GIT binary patch literal 3013 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 N>*yPQYy0p2{0F