annotate lisp/games/dunnet.el @ 71:bae944334fa4

Added tag r20-0b30 for changeset 131b0175ea99
author cvs
date Mon, 13 Aug 2007 09:03:07 +0200
parents 131b0175ea99
children b9518feda344
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 ;;; dunnet.el --- Text adventure for Emacs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 ;; Author: Ron Schnell <ronnie@media.mit.edu>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4 ;; Created: 25 Jul 1992
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 ;; Version: 2.0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6 ;; Keywords: games
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
7 ;; Copyright (C) 1992, 1993 Free Software Foundation, Inc.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9 ;; This file is part of XEmacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11 ;; XEmacs is free software; you can redistribute it and/or modify it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 ;; under the terms of the GNU General Public License as published by
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 ;; any later version.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16 ;; XEmacs is distributed in the hope that it will be useful, but
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 ;; General Public License for more details.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
22 ;; along with XEmacs; see the file COPYING. If not, write to the
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
24 ;; Boston, MA 02111-1307, USA.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
26 ;;; Synched up with: FSF 19.28.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 ;;; Commentary:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 ;; This game can be run in batch mode. To do this, use:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 ;; emacs -batch -l dunnet
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 ;;; !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 ;;; The log file should be set for your system, and it must
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
35 ;;; be writeable by all.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 (defvar dun-log-file "/usr/local/dunnet.score"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39 "Name of file to store score information for dunnet.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 (if nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42 (eval-and-compile (setq byte-compile-warnings nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
44 (require 'cl)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 ;;;; Mode definitions for interactive mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 (defun dun-mode ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49 "Major mode for running dunnet."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51 (text-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 (use-local-map dungeon-mode-map)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 (setq major-mode 'dungeon-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54 (setq mode-name "Dungeon"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56 (defun dun-parse (arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 "Function called when return is pressed in interactive mode to parse line."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 (interactive "*p")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 (setq beg (+ (point) 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 (if (and (not (= beg (point))) (not (< (point) beg))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 (string= ">" (buffer-substring (- beg 1) beg)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 (setq line (downcase (buffer-substring beg (point))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 (princ line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 (if (eq (dun-vparse dun-ignore dun-verblist line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 (dun-mprinc "I don't understand that.\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71 (dun-messages))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 (defun dun-messages ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 (if dun-dead
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
75 (text-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76 (if (eq dungeon-mode 'dungeon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 (if (not (= room dun-current-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 (dun-describe-room dun-current-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81 (setq room dun-current-room)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 (dun-fix-screen)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83 (dun-mprinc ">")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 ;;;###autoload
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87 (defun dunnet ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 "Switch to *dungeon* buffer and start game."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
89 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
90 (switch-to-buffer "*dungeon*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 (dun-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 (setq dun-dead nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93 (setq room 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94 (dun-messages))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 ;;;; This section contains all of the verbs and commands.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 ;;; Give long description of room if haven't been there yet. Otherwise
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 ;;; short. Also give long if we were called with negative room number.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 (defun dun-describe-room (room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 (if (and (not (member (abs room) dun-light-rooms))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 (not (member obj-lamp dun-inventory)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106 (dun-mprincl "It is pitch dark. You are likely to be eaten by a grue.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 (dun-mprincl (cadr (nth (abs room) dun-rooms)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 (if (and (and (or (member room dun-visited)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109 (string= dun-mode "dun-superb")) (> room 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 (not (string= dun-mode "long")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 (dun-mprinc (car (nth (abs room) dun-rooms)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 (if (not (string= dun-mode "long"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 (if (not (member (abs room) dun-visited))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 (setq dun-visited (append (list (abs room)) dun-visited))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117 (dolist (xobjs (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 (if (= xobjs obj-special)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 (dun-special-object)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120 (if (>= xobjs 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 (dun-mprincl (car (nth xobjs dun-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 (if (not (and (= xobjs obj-bus) dun-inbus))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 (dun-mprincl (car (nth (abs xobjs) dun-perm-objects)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 (if (and (= xobjs obj-jar) dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 (dun-mprincl "The jar contains:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128 (dolist (x dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 (dun-mprinc " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 (dun-mprincl (car (nth x dun-objects)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 (if (and (member obj-bus (nth dun-current-room dun-room-objects)) dun-inbus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132 (dun-mprincl "You are on the bus."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 ;;; There is a special object in the room. This object's description,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 ;;; or lack thereof, depends on certain conditions.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137 (defun dun-special-object ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138 (if (= dun-current-room computer-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 (if dun-computer
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141 "The panel lights are flashing in a seemingly organized pattern.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 (dun-mprincl "The panel lights are steady and motionless.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144 (if (and (= dun-current-room red-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145 (not (member obj-towel (nth red-room dun-room-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 (dun-mprincl "There is a hole in the floor here."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 (if (and (= dun-current-room marine-life-area) dun-black)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 "The room is lit by a black light, causing the fish, and some of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 your objects, to give off an eerie glow."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 (if (and (= dun-current-room fourth-vermont-intersection) dun-hole)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154 (if (not dun-inbus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 (dun-mprincl"You fall into a hole in the ground.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 (setq dun-current-room vermont-station)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 (dun-describe-room vermont-station))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 "The bus falls down a hole in the ground and explodes.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 (dun-die "burning")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164 (if (> dun-current-room endgame-computer-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 (if (not dun-correct-answer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 (dun-endgame-question)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 (dun-mprincl "Your question is:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169 (dun-mprincl dun-endgame-question))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 (if (= dun-current-room sauna)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 (dun-mprincl (nth dun-sauna-level '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 "It is normal room temperature in here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 "It is luke warm in here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176 "It is comfortably hot in here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 "It is refreshingly hot in here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 "You are dead now.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179 (if (and (= dun-sauna-level 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180 (or (member obj-rms dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181 (member obj-rms (nth dun-current-room dun-room-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
183 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184 "You notice the wax on your statuette beginning to melt, until it completely
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185 melts off. You are left with a beautiful diamond!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 (if (member obj-rms dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
187 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
188 (dun-remove-obj-from-inven obj-rms)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 (setq dun-inventory (append dun-inventory
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
190 (list obj-diamond))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 (dun-remove-obj-from-room dun-current-room obj-rms)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192 (dun-replace dun-room-objects dun-current-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 (append (nth dun-current-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 (list obj-diamond))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195 (if (member obj-floppy dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
196 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198 "You notice your floppy disk beginning to melt. As you grab for it, the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 disk bursts into flames, and disintegrates.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 (dun-remove-obj-from-inven obj-floppy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 (dun-remove-obj-from-room dun-current-room obj-floppy)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202 )))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
204 (defun dun-die (murderer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 (if murderer
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 (dun-mprincl "You are dead."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 (dun-do-logfile 'dun-die murderer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 (dun-score nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 (setq dun-dead t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 (defun dun-quit (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 (dun-die nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215 ;;; Print every object in player's inventory. Special case for the jar,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
216 ;;; as we must also print what is in it.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 (defun dun-inven (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219 (dun-mprinc "You currently have:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 (dolist (curobj dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222 (if curobj
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224 (dun-mprincl (cadr (nth curobj dun-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 (if (and (= curobj obj-jar) dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 (dun-mprincl "The jar contains:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 (dolist (x dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 (dun-mprinc " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230 (dun-mprincl (cadr (nth x dun-objects))))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232 (defun dun-shake (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 (if (member objnum dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 ;;; If shaking anything will do anything, put here.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238 (dun-mprinc "Shaking ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239 (dun-mprinc (downcase (cadr (nth objnum dun-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 (dun-mprinc " seems to have no effect.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 (if (and (not (member objnum (nth dun-current-room dun-room-silents)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 (not (member objnum (nth dun-current-room dun-room-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 ;;; Shaking trees can be deadly
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 (if (= objnum obj-tree)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 "You begin to shake a tree, and notice a coconut begin to fall from the air.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 As you try to get your hand up to block it, you feel the impact as it lands
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 on your head.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253 (dun-die "a coconut"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 (if (= objnum obj-bear)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257 "As you go up to the bear, it removes your head and places it on the ground.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258 (dun-die "a bear"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 (if (< objnum 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260 (dun-mprincl "You cannot shake that.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261 (dun-mprincl "You don't have that.")))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 (defun dun-drop (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265 (if dun-inbus
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 (dun-mprincl "You can't drop anything while on the bus.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 (let (objnum ptr)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 (if (not (setq ptr (member objnum dun-inventory)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 (dun-mprincl "You don't have that.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272 (dun-remove-obj-from-inven objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273 (dun-replace dun-room-objects dun-current-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 (append (nth dun-current-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 (list objnum)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 (dun-mprincl "Done.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 (if (member objnum (list obj-food obj-weight obj-jar))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278 (dun-drop-check objnum))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280 ;;; Dropping certain things causes things to happen.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282 (defun dun-drop-check (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 (if (and (= objnum obj-food) (= room bear-hangout)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
284 (member obj-bear (nth bear-hangout dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 "The bear takes the food and runs away with it. He left something behind.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288 (dun-remove-obj-from-room dun-current-room obj-bear)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 (dun-remove-obj-from-room dun-current-room obj-food)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290 (dun-replace dun-room-objects dun-current-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 (append (nth dun-current-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292 (list obj-key)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
293
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294 (if (and (= objnum obj-jar) (member obj-nitric dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 (member obj-glycerine dun-jar))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 "As the jar impacts the ground it explodes into many pieces.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 (setq dun-jar nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300 (dun-remove-obj-from-room dun-current-room obj-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301 (if (= dun-current-room fourth-vermont-intersection)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 (setq dun-hole t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304 (setq dun-current-room vermont-station)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 "The explosion causes a hole to open up in the ground, which you fall
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307 through.")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309 (if (and (= objnum obj-weight) (= dun-current-room maze-button-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 (dun-mprincl "A passageway opens.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312 ;;; Give long description of current room, or an object.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
313
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
314 (defun dun-examine (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
315 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
316 (setq objnum (dun-objnum-from-args obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
317 (if (eq objnum obj-special)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
318 (dun-describe-room (* dun-current-room -1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
319 (if (and (eq objnum obj-computer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
320 (member obj-pc (nth dun-current-room dun-room-silents)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 (dun-examine '("pc"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322 (if (eq objnum nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 (dun-mprincl "I don't know what that is.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
324 (if (and (not (member objnum
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
325 (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326 (not (member objnum
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
327 (nth dun-current-room dun-room-silents)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328 (not (member objnum dun-inventory)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330 (if (>= objnum 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 (if (and (= objnum obj-bone)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
332 (= dun-current-room marine-life-area) dun-black)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
333 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
334 "In this light you can see some writing on the bone. It says:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
335 For an explosive time, go to Fourth St. and Vermont.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
336 (if (nth objnum dun-physobj-desc)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
337 (dun-mprincl (nth objnum dun-physobj-desc))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
338 (dun-mprincl "I see nothing special about that.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
339 (if (nth (abs objnum) dun-permobj-desc)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
340 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
341 (dun-mprincl (nth (abs objnum) dun-permobj-desc)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
342 (dun-mprincl "I see nothing special about that.")))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
343
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
344 (defun dun-take (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
345 (if dun-inbus
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
346 (dun-mprincl "You can't take anything while on the bus.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
347 (setq obj (dun-firstword obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
348 (if (not obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
349 (dun-mprincl "You must supply an object.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
350 (if (string= obj "all")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
351 (let (gotsome)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
352 (setq gotsome nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
353 (dolist (x (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
354 (if (and (>= x 0) (not (= x obj-special)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
355 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
356 (setq gotsome t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
357 (dun-mprinc (cadr (nth x dun-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
358 (dun-mprinc ": ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
359 (dun-take-object x))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
360 (if (not gotsome)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
361 (dun-mprincl "Nothing to take.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
362 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
363 (setq objnum (cdr (assq (intern obj) dun-objnames)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
364 (if (eq objnum nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
365 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
366 (dun-mprinc "I don't know what that is.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
367 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
368 (dun-take-object objnum)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
369
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
370 (defun dun-take-object (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
371 (if (and (member objnum dun-jar) (member obj-jar dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
372 (let (newjar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
373 (dun-mprincl "You remove it from the jar.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
374 (setq newjar nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
375 (dolist (x dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
376 (if (not (= x objnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
377 (setq newjar (append newjar (list x)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
378 (setq dun-jar newjar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
379 (setq dun-inventory (append dun-inventory (list objnum))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
380 (if (not (member objnum (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
381 (if (not (member objnum (nth dun-current-room dun-room-silents)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
382 (dun-mprinc "I do not see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
383 (dun-try-take objnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
384 (if (>= objnum 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
385 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
386 (if (and (car dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
387 (> (+ (dun-inven-weight) (nth objnum dun-object-lbs)) 11))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
388 (dun-mprinc "Your load would be too heavy.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
389 (setq dun-inventory (append dun-inventory (list objnum)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
390 (dun-remove-obj-from-room dun-current-room objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
391 (dun-mprinc "Taken. ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
392 (if (and (= objnum obj-towel) (= dun-current-room red-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
393 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
394 "Taking the towel reveals a hole in the floor."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
395 (dun-try-take objnum)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
396 (dun-mprinc "\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
397
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
398 (defun dun-inven-weight ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
399 (let (total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
400 (setq total 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
401 (dolist (x dun-jar)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
402 (setq total (+ total (nth x dun-object-lbs))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
403 (dolist (x dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
404 (setq total (+ total (nth x dun-object-lbs)))) total))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
405
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
406 ;;; We try to take an object that is untakable. Print a message
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
407 ;;; depending on what it is.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
408
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
409 (defun dun-try-take (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
410 (dun-mprinc "You cannot take that."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
411
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
412 (defun dun-dig (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
413 (if dun-inbus
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
414 (dun-mprincl "You can't dig while on the bus.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
415 (if (not (member 0 dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
416 (dun-mprincl "You have nothing with which to dig.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
417 (if (not (nth dun-current-room dun-diggables))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
418 (dun-mprincl "Digging here reveals nothing.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
419 (dun-mprincl "I think you found something.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
420 (dun-replace dun-room-objects dun-current-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
421 (append (nth dun-current-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
422 (nth dun-current-room dun-diggables)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
423 (dun-replace dun-diggables dun-current-room nil)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
424
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
425 (defun dun-climb (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
426 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
427 (setq objnum (dun-objnum-from-args obj))
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
428 (if (and (not (= objnum obj-special))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
429 (not (member objnum (nth dun-current-room dun-room-objects)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
430 (not (member objnum (nth dun-current-room dun-room-silents)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
431 (not (member objnum dun-inventory)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
432 (dun-mprincl "I don't see that here.")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
433 (if (and (= objnum obj-special)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
434 (not (member obj-tree (nth dun-current-room dun-room-silents))))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
435 (dun-mprincl "There is nothing here to climb.")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
436 (if (and (not (= objnum obj-tree)) (not (= objnum obj-special)))
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
437 (dun-mprincl "You can't climb that.")
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
438 (dun-mprincl
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
439 "You manage to get about two feet up the tree and fall back down. You
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
440 notice that the tree is very unsteady."))))))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
441
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
442 (defun dun-eat (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
443 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
444 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
445 (if (not (member objnum dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
446 (dun-mprincl "You don't have that.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
447 (if (not (= objnum obj-food))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
448 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
449 (dun-mprinc "You forcefully shove ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
450 (dun-mprinc (downcase (cadr (nth objnum dun-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
451 (dun-mprincl " down your throat, and start choking.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
452 (dun-die "choking"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
453 (dun-mprincl "That tasted horrible.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
454 (dun-remove-obj-from-inven obj-food))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
455
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
456 (defun dun-put (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
457 (if dun-inbus
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
458 (dun-mprincl "You can't do that while on the bus")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
459 (let (newargs objnum objnum2 obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
460 (setq newargs (dun-firstwordl args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
461 (if (not newargs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
462 (dun-mprincl "You must supply an object")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
463 (setq obj (intern (car newargs)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
464 (setq objnum (cdr (assq obj dun-objnames)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
465 (if (not objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
466 (dun-mprincl "I don't know what that object is.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
467 (if (not (member objnum dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
468 (dun-mprincl "You don't have that.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
469 (setq newargs (dun-firstwordl (cdr newargs)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
470 (setq newargs (dun-firstwordl (cdr newargs)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
471 (if (not newargs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
472 (dun-mprincl "You must supply an indirect object.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
473 (setq objnum2 (cdr (assq (intern (car newargs)) dun-objnames)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
474 (if (and (eq objnum2 obj-computer) (= dun-current-room pc-area))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
475 (setq objnum2 obj-pc))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
476 (if (not objnum2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
477 (dun-mprincl "I don't know what that indirect object is.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
478 (if (and (not (member objnum2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
479 (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
480 (not (member objnum2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
481 (nth dun-current-room dun-room-silents)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
482 (not (member objnum2 dun-inventory)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
483 (dun-mprincl "That indirect object is not here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
484 (dun-put-objs objnum objnum2))))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
485
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
486 (defun dun-put-objs (obj1 obj2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
487 (if (and (= obj2 obj-drop) (not dun-nomail))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
488 (setq obj2 obj-chute))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
489
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
490 (if (= obj2 obj-disposal) (setq obj2 obj-chute))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
491
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
492 (if (and (= obj1 obj-cpu) (= obj2 obj-computer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
493 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
494 (dun-remove-obj-from-inven obj-cpu)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
495 (setq dun-computer t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
496 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
497 "As you put the CPU board in the computer, it immediately springs to life.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
498 The lights start flashing, and the fans seem to startup."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
499 (if (and (= obj1 obj-weight) (= obj2 obj-button))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
500 (dun-drop '("weight"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
501 (if (= obj2 obj-jar) ;; Put something in jar
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
502 (if (not (member obj1 (list obj-paper obj-diamond obj-emerald
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
503 obj-license obj-coins obj-egg
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
504 obj-nitric obj-glycerine)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
505 (dun-mprincl "That will not fit in the jar.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
506 (dun-remove-obj-from-inven obj1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
507 (setq dun-jar (append dun-jar (list obj1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
508 (dun-mprincl "Done."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
509 (if (= obj2 obj-chute) ;; Put something in chute
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
510 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
511 (dun-remove-obj-from-inven obj1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
512 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
513 "You hear it slide down the chute and off into the distance.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
514 (dun-put-objs-in-treas (list obj1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
515 (if (= obj2 obj-box) ;; Put key in key box
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
516 (if (= obj1 obj-key)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
517 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
518 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
519 "As you drop the key, the box begins to shake. Finally it explodes
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
520 with a bang. The key seems to have vanished!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
521 (dun-remove-obj-from-inven obj1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
522 (dun-replace dun-room-objects computer-room (append
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
523 (nth computer-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
524 dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
525 (list obj1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
526 (dun-remove-obj-from-room dun-current-room obj-box)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
527 (setq dun-key-level (1+ dun-key-level)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
528 (dun-mprincl "You can't put that in the key box!"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
529
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
530 (if (and (= obj1 obj-floppy) (= obj2 obj-pc))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
531 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
532 (setq dun-floppy t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
533 (dun-remove-obj-from-inven obj1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
534 (dun-mprincl "Done."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
535
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
536 (if (= obj2 obj-urinal) ;; Put object in urinal
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
537 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
538 (dun-remove-obj-from-inven obj1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
539 (dun-replace dun-room-objects urinal (append
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
540 (nth urinal dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
541 (list obj1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
542 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
543 "You hear it plop down in some water below."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
544 (if (= obj2 obj-mail)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
545 (dun-mprincl "The mail chute is locked.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
546 (if (member obj1 dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
547 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
548 "I don't know how to combine those objects. Perhaps you should
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
549 just try dropping it.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
550 (dun-mprincl"You can't put that there.")))))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
551
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
552 (defun dun-type (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
553 (if (not (= dun-current-room computer-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
554 (dun-mprincl "There is nothing here on which you could type.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
555 (if (not dun-computer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
556 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
557 "You type on the keyboard, but your characters do not even echo.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
558 (dun-unix-interface))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
559
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
560 ;;; Various movement directions
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
561
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
562 (defun dun-n (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
563 (dun-move north))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
564
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
565 (defun dun-s (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
566 (dun-move south))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
567
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
568 (defun dun-e (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
569 (dun-move east))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
570
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
571 (defun dun-w (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
572 (dun-move west))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
573
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
574 (defun dun-ne (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
575 (dun-move northeast))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
576
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
577 (defun dun-se (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
578 (dun-move southeast))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
579
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
580 (defun dun-nw (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
581 (dun-move northwest))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
582
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
583 (defun dun-sw (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
584 (dun-move southwest))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
585
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
586 (defun dun-up (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
587 (dun-move up))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
588
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
589 (defun dun-down (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
590 (dun-move down))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
591
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
592 (defun dun-in (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
593 (dun-move in))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
594
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
595 (defun dun-out (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
596 (dun-move out))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
597
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
598 (defun dun-go (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
599 (if (or (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
600 (eq (dun-doverb dun-ignore dun-verblist (car args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
601 (cdr (cdr args))) -1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
602 (dun-mprinc "I don't understand where you want me to go.\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
603
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
604 ;;; Uses the dungeon-map to figure out where we are going. If the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
605 ;;; requested direction yields 255, we know something special is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
606 ;;; supposed to happen, or perhaps you can't go that way unless
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
607 ;;; certain conditions are met.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
608
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
609 (defun dun-move (dir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
610 (if (and (not (member dun-current-room dun-light-rooms))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
611 (not (member obj-lamp dun-inventory)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
612 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
613 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
614 "You trip over a grue and fall into a pit and break every bone in your
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
615 body.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
616 (dun-die "a grue"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
617 (let (newroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
618 (setq newroom (nth dir (nth dun-current-room dungeon-map)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
619 (if (eq newroom -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
620 (dun-mprinc "You can't go that way.\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
621 (if (eq newroom 255)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
622 (dun-special-move dir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
623 (setq room -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
624 (setq dun-lastdir dir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
625 (if dun-inbus
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
626 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
627 (if (or (< newroom 58) (> newroom 83))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
628 (dun-mprincl "The bus cannot go this way.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
629 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
630 "The bus lurches ahead and comes to a screeching halt.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
631 (dun-remove-obj-from-room dun-current-room obj-bus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
632 (setq dun-current-room newroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
633 (dun-replace dun-room-objects newroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
634 (append (nth newroom dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
635 (list obj-bus)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
636 (setq dun-current-room newroom)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
637
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
638 ;;; Movement in this direction causes something special to happen if the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
639 ;;; right conditions exist. It may be that you can't go this way unless
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
640 ;;; you have a key, or a passage has been opened.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
641
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
642 ;;; coding note: Each check of the current room is on the same 'if' level,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
643 ;;; i.e. there aren't else's. If two rooms next to each other have
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
644 ;;; specials, and they are connected by specials, this could cause
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
645 ;;; a problem. Be careful when adding them to consider this, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
646 ;;; perhaps use else's.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
647
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
648 (defun dun-special-move (dir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
649 (if (= dun-current-room building-front)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
650 (if (not (member obj-key dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
651 (dun-mprincl "You don't have a key that can open this door.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
652 (setq dun-current-room old-building-hallway))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
653 (if (= dun-current-room north-end-of-cave-passage)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
654 (let (combo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
655 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
656 "You must type a 3 digit combination code to enter this room.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
657 (dun-mprinc "Enter it here: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
658 (setq combo (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
659 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
660 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
661 (if (string= combo dun-combination)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
662 (setq dun-current-room gamma-computing-center)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
663 (dun-mprincl "Sorry, that combination is incorrect."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
664
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
665 (if (= dun-current-room bear-hangout)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
666 (if (member obj-bear (nth bear-hangout dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
667 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
668 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
669 "The bear is very annoyed that you would be so presumptuous as to try
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
670 and walk right by it. He tells you so by tearing your head off.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
671 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
672 (dun-die "a bear"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
673 (dun-mprincl "You can't go that way.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
674
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
675 (if (= dun-current-room vermont-station)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
676 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
677 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
678 "As you board the train it immediately leaves the station. It is a very
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
679 bumpy ride. It is shaking from side to side, and up and down. You
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
680 sit down in one of the chairs in order to be more comfortable.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
681 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
682 "\nFinally the train comes to a sudden stop, and the doors open, and some
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
683 force throws you out. The train speeds away.\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
684 (setq dun-current-room museum-station)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
685
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
686 (if (= dun-current-room old-building-hallway)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
687 (if (and (member obj-key dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
688 (> dun-key-level 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
689 (setq dun-current-room meadow)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
690 (dun-mprincl "You don't have a key that can open this door.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
691
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
692 (if (and (= dun-current-room maze-button-room) (= dir northwest))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
693 (if (member obj-weight (nth maze-button-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
694 (setq dun-current-room 18)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
695 (dun-mprincl "You can't go that way.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
696
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
697 (if (and (= dun-current-room maze-button-room) (= dir up))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
698 (if (member obj-weight (nth maze-button-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
699 (dun-mprincl "You can't go that way.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
700 (setq dun-current-room weight-room)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
701
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
702 (if (= dun-current-room classroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
703 (dun-mprincl "The door is locked."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
704
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
705 (if (or (= dun-current-room lakefront-north)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
706 (= dun-current-room lakefront-south))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
707 (dun-swim nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
708
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
709 (if (= dun-current-room reception-area)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
710 (if (not (= dun-sauna-level 3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
711 (setq dun-current-room health-club-front)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
712 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
713 "As you exit the building, you notice some flames coming out of one of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
714 windows. Suddenly, the building explodes in a huge ball of fire. The flames
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
715 engulf you, and you burn to death.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
716 (dun-die "burning")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
717
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
718 (if (= dun-current-room red-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
719 (if (not (member obj-towel (nth red-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
720 (setq dun-current-room long-n-s-hallway)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
721 (dun-mprincl "You can't go that way.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
722
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
723 (if (and (> dir down) (> dun-current-room gamma-computing-center)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
724 (< dun-current-room museum-lobby))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
725 (if (not (member obj-bus (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
726 (dun-mprincl "You can't go that way.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
727 (if (= dir in)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
728 (if (member obj-license dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
729 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
730 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
731 "You board the bus and get in the driver's seat.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
732 (setq dun-nomail t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
733 (setq dun-inbus t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
734 (dun-mprincl "You are not licensed for this type of vehicle."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
735 (dun-mprincl "You hop off the bus.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
736 (setq dun-inbus nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
737 (if (= dun-current-room fifth-oaktree-intersection)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
738 (if (not dun-inbus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
739 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
740 (dun-mprincl "You fall down the cliff and land on your head.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
741 (dun-die "a cliff"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
742 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
743 "The bus flies off the cliff, and plunges to the bottom, where it explodes.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
744 (dun-die "a bus accident")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
745 (if (= dun-current-room main-maple-intersection)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
746 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
747 (if (not dun-inbus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
748 (dun-mprincl "The gate will not open.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
749 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
750 "As the bus approaches, the gate opens and you drive through.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
751 (dun-remove-obj-from-room main-maple-intersection obj-bus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
752 (dun-replace dun-room-objects museum-entrance
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
753 (append (nth museum-entrance dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
754 (list obj-bus)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
755 (setq dun-current-room museum-entrance)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
756 (if (= dun-current-room cave-entrance)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
757 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
758 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
759 "As you enter the room you hear a rumbling noise. You look back to see
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
760 huge rocks sliding down from the ceiling, and blocking your way out.\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
761 (setq dun-current-room misty-room)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
762
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
763 (defun dun-long (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
764 (setq dun-mode "long"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
765
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
766 (defun dun-turn (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
767 (let (objnum direction)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
768 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
769 (if (not (or (member objnum (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
770 (member objnum (nth dun-current-room dun-room-silents))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
771 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
772 (if (not (= objnum obj-dial))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
773 (dun-mprincl "You can't turn that.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
774 (setq direction (dun-firstword (cdr obj)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
775 (if (or (not direction)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
776 (not (or (string= direction "clockwise")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
777 (string= direction "counterclockwise"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
778 (dun-mprincl "You must indicate clockwise or counterclockwise.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
779 (if (string= direction "clockwise")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
780 (setq dun-sauna-level (+ dun-sauna-level 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
781 (setq dun-sauna-level (- dun-sauna-level 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
782
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
783 (if (< dun-sauna-level 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
784 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
785 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
786 "The dial will not turn further in that direction.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
787 (setq dun-sauna-level 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
788 (dun-sauna-heat))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
789
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
790 (defun dun-sauna-heat ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
791 (if (= dun-sauna-level 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
792 (dun-mprincl
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
793 "The termperature has returned to normal room termperature."))
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
794 (if (= dun-sauna-level 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
795 (dun-mprincl "It is now luke warm in here. You begin to sweat."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
796 (if (= dun-sauna-level 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
797 (dun-mprincl "It is pretty hot in here. It is still very comfortable."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
798 (if (= dun-sauna-level 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
799 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
800 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
801 "It is now very hot. There is something very refreshing about this.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
802 (if (or (member obj-rms dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
803 (member obj-rms (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
804 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
805 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
806 "You notice the wax on your statuette beginning to melt, until it completely
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
807 melts off. You are left with a beautiful diamond!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
808 (if (member obj-rms dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
809 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
810 (dun-remove-obj-from-inven obj-rms)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
811 (setq dun-inventory (append dun-inventory
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
812 (list obj-diamond))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
813 (dun-remove-obj-from-room dun-current-room obj-rms)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
814 (dun-replace dun-room-objects dun-current-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
815 (append (nth dun-current-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
816 (list obj-diamond))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
817 (if (or (member obj-floppy dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
818 (member obj-floppy (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
819 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
820 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
821 "You notice your floppy disk beginning to melt. As you grab for it, the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
822 disk bursts into flames, and disintegrates.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
823 (if (member obj-floppy dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
824 (dun-remove-obj-from-inven obj-floppy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
825 (dun-remove-obj-from-room dun-current-room obj-floppy))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
826
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
827 (if (= dun-sauna-level 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
828 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
829 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
830 "As the dial clicks into place, you immediately burst into flames.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
831 (dun-die "burning"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
832
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
833 (defun dun-press (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
834 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
835 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
836 (if (not (or (member objnum (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
837 (member objnum (nth dun-current-room dun-room-silents))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
838 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
839 (if (not (member objnum (list obj-button obj-switch)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
840 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
841 (dun-mprinc "You can't ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
842 (dun-mprinc (car line-list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
843 (dun-mprincl " that."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
844 (if (= objnum obj-button)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
845 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
846 "As you press the button, you notice a passageway open up, but
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
847 as you release it, the passageway closes."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
848 (if (= objnum obj-switch)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
849 (if dun-black
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
850 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
851 (dun-mprincl "The button is now in the off position.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
852 (setq dun-black nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
853 (dun-mprincl "The button is now in the on position.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
854 (setq dun-black t))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
855
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
856 (defun dun-swim (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
857 (if (not (member dun-current-room (list lakefront-north lakefront-south)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
858 (dun-mprincl "I see no water!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
859 (if (not (member obj-life dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
860 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
861 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
862 "You dive in the water, and at first notice it is quite cold. You then
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
863 start to get used to it as you realize that you never really learned how
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
864 to swim.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
865 (dun-die "drowning"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
866 (if (= dun-current-room lakefront-north)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
867 (setq dun-current-room lakefront-south)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
868 (setq dun-current-room lakefront-north)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
869
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
870
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
871 (defun dun-score (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
872 (if (not dun-endgame)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
873 (let (total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
874 (setq total (dun-reg-score))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
875 (dun-mprinc "You have scored ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
876 (dun-mprinc total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
877 (dun-mprincl " out of a possible 90 points.") total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
878 (dun-mprinc "You have scored ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
879 (dun-mprinc (dun-endgame-score))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
880 (dun-mprincl " endgame points out of a possible 110.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
881 (if (= (dun-endgame-score) 110)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
882 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
883 "\n\nCongratulations. You have won. The wizard password is 'moby'"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
884
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
885 (defun dun-help (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
886 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
887 "Welcome to dunnet (2.0), by Ron Schnell (ronnie@media.mit.edu).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
888 Here is some useful information (read carefully because there are one
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
889 or more clues in here):
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
890 - If you have a key that can open a door, you do not need to explicitly
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
891 open it. You may just use 'in' or walk in the direction of the door.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
892
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
893 - If you have a lamp, it is always lit.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
894
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
895 - You will not get any points until you manage to get treasures to a certain
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
896 place. Simply finding the treasures is not good enough. There is more
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
897 than one way to get a treasure to the special place. It is also
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
898 important that the objects get to the special place *unharmed* and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
899 *untarnished*. You can tell if you have successfully transported the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
900 object by looking at your score, as it changes immediately. Note that
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
901 an object can become harmed even after you have received points for it.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
902 If this happens, your score will decrease, and in many cases you can never
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
903 get credit for it again.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
904
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
905 - You can save your game with the 'save' command, and use restore it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
906 with the 'restore' command.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
907
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
908 - There are no limits on lengths of object names.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
909
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
910 - Directions are: north,south,east,west,northeast,southeast,northwest,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
911 southwest,up,down,in,out.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
912
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
913 - These can be abbreviated: n,s,e,w,ne,se,nw,sw,u,d,in,out.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
914
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
915 - If you go down a hole in the floor without an aid such as a ladder,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
916 you probably won't be able to get back up the way you came, if at all.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
917
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
918 - To run this game in batch mode (no emacs window), use:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
919 emacs -batch -l dunnet
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
920
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
921 If you have questions or comments, please contact ronnie@media.mit.edu."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
922
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
923 (defun dun-flush (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
924 (if (not (= dun-current-room bathroom))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
925 (dun-mprincl "I see nothing to flush.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
926 (dun-mprincl "Whoooosh!!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
927 (dun-put-objs-in-treas (nth urinal dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
928 (dun-replace dun-room-objects urinal nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
929
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
930 (defun dun-piss (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
931 (if (not (= dun-current-room bathroom))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
932 (dun-mprincl "You can't do that here, don't even bother trying.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
933 (if (not dun-gottago)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
934 (dun-mprincl "I'm afraid you don't have to go now.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
935 (dun-mprincl "That was refreshing.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
936 (setq dun-gottago nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
937 (dun-replace dun-room-objects urinal (append
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
938 (nth urinal dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
939 (list obj-URINE))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
940
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
941
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
942 (defun dun-sleep (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
943 (if (not (= dun-current-room bedroom))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
944 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
945 "You try to go to sleep while standing up here, but can't seem to do it.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
946 (setq dun-gottago t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
947 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
948 "As soon as you start to doze off you begin dreaming. You see images of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
949 workers digging caves, slaving in the humid heat. Then you see yourself
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
950 as one of these workers. While no one is looking, you leave the group
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
951 and walk into a room. The room is bare except for a horseshoe
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
952 shaped piece of stone in the center. You see yourself digging a hole in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
953 the ground, then putting some kind of treasure in it, and filling the hole
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
954 with dirt again. After this, you immediately wake up.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
955
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
956 (defun dun-break (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
957 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
958 (if (not (member obj-axe dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
959 (dun-mprincl "You have nothing you can use to break things.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
960 (when (setq objnum (dun-objnum-from-args-std obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
961 (if (member objnum dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
962 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
963 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
964 "You take the object in your hands and swing the axe. Unfortunately, you miss
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
965 the object and slice off your hand. You bleed to death.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
966 (dun-die "an axe"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
967 (if (not (or (member objnum (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
968 (member objnum
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
969 (nth dun-current-room dun-room-silents))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
970 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
971 (if (= objnum obj-cable)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
972 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
973 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
974 "As you break the ethernet cable, everything starts to blur. You collapse
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
975 for a moment, then straighten yourself up.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
976 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
977 (dun-replace dun-room-objects gamma-computing-center
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
978 (append
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
979 (nth gamma-computing-center dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
980 dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
981 (if (member obj-key dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
982 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
983 (setq dun-inventory (list obj-key))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
984 (dun-remove-obj-from-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
985 gamma-computing-center obj-key))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
986 (setq dun-inventory nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
987 (setq dun-current-room computer-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
988 (setq dun-ethernet nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
989 (dun-mprincl "Connection closed.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
990 (dun-unix-interface))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
991 (if (< objnum 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
992 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
993 (dun-mprincl "Your axe shatters into a million pieces.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
994 (dun-remove-obj-from-inven obj-axe))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
995 (dun-mprincl "Your axe breaks it into a million pieces.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
996 (dun-remove-obj-from-room dun-current-room objnum)))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
997
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
998 (defun dun-drive (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
999 (if (not dun-inbus)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1000 (dun-mprincl "You cannot drive when you aren't in a vehicle.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1001 (dun-mprincl "To drive while you are in the bus, just give a direction.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1002
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1003 (defun dun-superb (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1004 (setq dun-mode 'dun-superb))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1005
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1006 (defun dun-reg-score ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1007 (let (total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1008 (setq total 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1009 (dolist (x (nth treasure-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1010 (setq total (+ total (nth x dun-object-pts))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1011 (if (member obj-URINE (nth treasure-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1012 (setq total 0)) total))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1013
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1014 (defun dun-endgame-score ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1015 (let (total)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1016 (setq total 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1017 (dolist (x (nth endgame-treasure-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1018 (setq total (+ total (nth x dun-object-pts)))) total))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1019
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1020 (defun dun-answer (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1021 (if (not dun-correct-answer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1022 (dun-mprincl "I don't believe anyone asked you anything.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1023 (setq args (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1024 (if (not args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1025 (dun-mprincl "You must give the answer on the same line.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1026 (if (dun-members args dun-correct-answer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1027 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1028 (dun-mprincl "Correct.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1029 (if (= dun-lastdir 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1030 (setq dun-current-room (1+ dun-current-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1031 (setq dun-current-room (- dun-current-room 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1032 (setq dun-correct-answer nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1033 (dun-mprincl "That answer is incorrect.")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1034
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1035 (defun dun-endgame-question ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1036 (if (not dun-endgame-questions)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1037 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1038 (dun-mprincl "Your question is:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1039 (dun-mprincl "No more questions, just do 'answer foo'.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1040 (setq dun-correct-answer '("foo")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1041 (let (which i newques)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1042 (setq i 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1043 (setq newques nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1044 (setq which (random (length dun-endgame-questions)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1045 (dun-mprincl "Your question is:")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1046 (dun-mprincl (setq dun-endgame-question (car
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1047 (nth which
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1048 dun-endgame-questions))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1049 (setq dun-correct-answer (cdr (nth which dun-endgame-questions)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1050 (while (< i which)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1051 (setq newques (append newques (list (nth i dun-endgame-questions))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1052 (setq i (1+ i)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1053 (setq i (1+ which))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1054 (while (< i (length dun-endgame-questions))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1055 (setq newques (append newques (list (nth i dun-endgame-questions))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1056 (setq i (1+ i)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1057 (setq dun-endgame-questions newques))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1058
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1059 (defun dun-power (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1060 (if (not (= dun-current-room pc-area))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1061 (dun-mprincl "That operation is not applicable here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1062 (if (not dun-floppy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1063 (dun-dos-no-disk)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1064 (dun-dos-interface))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1065
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1066 (defun dun-feed (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1067 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1068 (when (setq objnum (dun-objnum-from-args-std args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1069 (if (and (= objnum obj-bear)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1070 (member obj-bear (nth dun-current-room dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1071 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1072 (if (not (member obj-food dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1073 (dun-mprincl "You have nothing with which to feed it.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1074 (dun-drop '("food"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1075 (if (not (or (member objnum (nth dun-current-room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1076 (member objnum dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1077 (member objnum (nth dun-current-room dun-room-silents))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1078 (dun-mprincl "I don't see that here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1079 (dun-mprincl "You cannot feed that."))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1080
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1081
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1082 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1083 ;;;; This section defines various utility functions used
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1084 ;;;; by dunnet.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1085 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1086
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1087
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1088 ;;; Function which takes a verb and a list of other words. Calls proper
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1089 ;;; function associated with the verb, and passes along the other words.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1090
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1091 (defun dun-doverb (dun-ignore dun-verblist verb rest)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1092 (if (not verb)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1093 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1094 (if (member (intern verb) dun-ignore)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1095 (if (not (car rest)) -1
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1096 (dun-doverb dun-ignore dun-verblist (car rest) (cdr rest)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1097 (if (not (cdr (assq (intern verb) dun-verblist))) -1
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1098 (setq dun-numcmds (1+ dun-numcmds))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1099 (eval (list (cdr (assq (intern verb) dun-verblist)) (quote rest)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1100
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1101
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1102 ;;; Function to take a string and change it into a list of lowercase words.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1103
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1104 (defun dun-listify-string (strin)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1105 (let (pos ret-list end-pos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1106 (setq pos 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1107 (setq ret-list nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1108 (while (setq end-pos (string-match "[ ,:;]" (substring strin pos)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1109 (setq end-pos (+ end-pos pos))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1110 (if (not (= end-pos pos))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1111 (setq ret-list (append ret-list (list
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1112 (downcase
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1113 (substring strin pos end-pos))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1114 (setq pos (+ end-pos 1))) ret-list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1115
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1116 (defun dun-listify-string2 (strin)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1117 (let (pos ret-list end-pos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1118 (setq pos 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1119 (setq ret-list nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1120 (while (setq end-pos (string-match " " (substring strin pos)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1121 (setq end-pos (+ end-pos pos))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1122 (if (not (= end-pos pos))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1123 (setq ret-list (append ret-list (list
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1124 (downcase
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1125 (substring strin pos end-pos))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1126 (setq pos (+ end-pos 1))) ret-list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1127
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1128 (defun dun-replace (list n number)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1129 (rplaca (nthcdr n list) number))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1130
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1131
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1132 ;;; Get the first non-ignored word from a list.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1133
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1134 (defun dun-firstword (list)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1135 (if (not (car list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1136 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1137 (while (and list (member (intern (car list)) dun-ignore))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1138 (setq list (cdr list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1139 (car list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1140
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1141 (defun dun-firstwordl (list)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1142 (if (not (car list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1143 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1144 (while (and list (member (intern (car list)) dun-ignore))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1145 (setq list (cdr list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1146 list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1147
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1148 ;;; parse a line passed in as a string Call the proper verb with the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1149 ;;; rest of the line passed in as a list.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1150
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1151 (defun dun-vparse (dun-ignore dun-verblist line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1152 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1153 (setq line-list (dun-listify-string (concat line " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1154 (dun-doverb dun-ignore dun-verblist (car line-list) (cdr line-list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1155
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1156 (defun dun-parse2 (dun-ignore dun-verblist line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1157 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1158 (setq line-list (dun-listify-string2 (concat line " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1159 (dun-doverb dun-ignore dun-verblist (car line-list) (cdr line-list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1160
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1161 ;;; Read a line, in window mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1162
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1163 (defun dun-read-line ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1164 (let (line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1165 (setq line (read-string ""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1166 (dun-mprinc line) line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1167
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1168 ;;; Insert something into the window buffer
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1169
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1170 (defun dun-minsert (string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1171 (if (stringp string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1172 (insert string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1173 (insert (prin1-to-string string))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1174
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1175 ;;; Print something out, in window mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1176
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1177 (defun dun-mprinc (string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1178 (if (stringp string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1179 (insert string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1180 (insert (prin1-to-string string))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1181
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1182 ;;; In window mode, keep screen from jumping by keeping last line at
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1183 ;;; the bottom of the screen.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1184
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1185 (defun dun-fix-screen ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1186 (interactive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1187 (forward-line (- 0 (- (window-height) 2 )))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1188 (set-window-start (selected-window) (point))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1189 (end-of-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1190
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1191 ;;; Insert something into the buffer, followed by newline.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1192
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1193 (defun dun-minsertl (string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1194 (dun-minsert string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1195 (dun-minsert "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1196
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1197 ;;; Print something, followed by a newline.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1198
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1199 (defun dun-mprincl (string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1200 (dun-mprinc string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1201 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1202
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1203 ;;; Function which will get an object number given the list of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1204 ;;; words in the command, except for the verb.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1205
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1206 (defun dun-objnum-from-args (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1207 (let (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1208 (setq obj (dun-firstword obj))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1209 (if (not obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1210 obj-special
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1211 (setq objnum (cdr (assq (intern obj) dun-objnames))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1212
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1213 (defun dun-objnum-from-args-std (obj)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1214 (let (result)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1215 (if (eq (setq result (dun-objnum-from-args obj)) obj-special)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1216 (dun-mprincl "You must supply an object."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1217 (if (eq result nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1218 (dun-mprincl "I don't know what that is."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1219 (if (eq result obj-special)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1220 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1221 result)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1222
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1223 ;;; Take a short room description, and change spaces and slashes to dashes.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1224
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1225 (defun dun-space-to-hyphen (string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1226 (let (space)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1227 (if (setq space (string-match "[ /]" string))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1228 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1229 (setq string (concat (substring string 0 space) "-"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1230 (substring string (1+ space))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1231 (dun-space-to-hyphen string))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1232 string)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1233
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1234 ;;; Given a unix style pathname, build a list of path components (recursive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1235
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1236 (defun dun-get-path (dirstring startlist)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1237 (let (slash pos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1238 (if (= (length dirstring) 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1239 startlist
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1240 (if (string= (substring dirstring 0 1) "/")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1241 (dun-get-path (substring dirstring 1) (append startlist (list "/")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1242 (if (not (setq slash (string-match "/" dirstring)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1243 (append startlist (list dirstring))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1244 (dun-get-path (substring dirstring (1+ slash))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1245 (append startlist
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1246 (list (substring dirstring 0 slash)))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1247
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1248
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1249 ;;; Is a string a member of a string list?
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1250
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1251 (defun dun-members (string string-list)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1252 (let (found)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1253 (setq found nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1254 (dolist (x string-list)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1255 (if (string= x string)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1256 (setq found t))) found))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1257
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1258 ;;; Function to put objects in the treasure room. Also prints current
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1259 ;;; score to let user know he has scored.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1260
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1261 (defun dun-put-objs-in-treas (objlist)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1262 (let (oscore newscore)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1263 (setq oscore (dun-reg-score))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1264 (dun-replace dun-room-objects 0 (append (nth 0 dun-room-objects) objlist))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1265 (setq newscore (dun-reg-score))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1266 (if (not (= oscore newscore))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1267 (dun-score nil))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1268
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1269 ;;; Load an encrypted file, and eval it.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1270
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1271 (defun dun-load-d (filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1272 (let (old-buffer result)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1273 (setq result t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1274 (setq old-buffer (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1275 (switch-to-buffer (get-buffer-create "*loadc*"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1276 (erase-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1277 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1278 (insert-file-contents filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1279 (error (setq result nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1280 (unless (not result)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1281 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1282 (dun-rot13)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1283 (error (yank)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1284 (eval-current-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1285 (kill-buffer (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1286 (switch-to-buffer old-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1287 result))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1288
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1289 ;;; Functions to remove an object either from a room, or from inventory.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1290
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1291 (defun dun-remove-obj-from-room (room objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1292 (let (newroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1293 (setq newroom nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1294 (dolist (x (nth room dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1295 (if (not (= x objnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1296 (setq newroom (append newroom (list x)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1297 (rplaca (nthcdr room dun-room-objects) newroom)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1298
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1299 (defun dun-remove-obj-from-inven (objnum)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1300 (let (new-inven)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1301 (setq new-inven nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1302 (dolist (x dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1303 (if (not (= x objnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1304 (setq new-inven (append new-inven (list x)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1305 (setq dun-inventory new-inven)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1306
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1307
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1308 (let ((i 0) (lower "abcdefghijklmnopqrstuvwxyz") upper)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1309 (setq dun-translate-table (make-vector 256 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1310 (while (< i 256)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1311 (aset dun-translate-table i i)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1312 (setq i (1+ i)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1313 (setq lower (concat lower lower))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1314 (setq upper (upcase lower))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1315 (setq i 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1316 (while (< i 26)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1317 (aset dun-translate-table (+ ?a i) (aref lower (+ i 13)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1318 (aset dun-translate-table (+ ?A i) (aref upper (+ i 13)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1319 (setq i (1+ i))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1320
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1321 (defun dun-rot13 ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1322 (let (str len (i 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1323 (setq str (buffer-substring (point-min) (point-max)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1324 (setq len (length str))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1325 (while (< i len)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1326 (aset str i (aref dun-translate-table (aref str i)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1327 (setq i (1+ i)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1328 (erase-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1329 (insert str)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1330
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1331 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1332 ;;;; This section defines the globals that are used in dunnet.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1333 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1334 ;;;; IMPORTANT
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1335 ;;;; All globals which can change must be saved from 'save-game. Add
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1336 ;;;; all new globals to bottom of file.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1337
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1338 (setq dun-visited '(27))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1339 (setq dun-current-room 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1340 (setq dun-exitf nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1341 (setq dun-badcd nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1342 (defvar dungeon-mode-map nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1343 (setq dungeon-mode-map (make-sparse-keymap))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1344 (define-key dungeon-mode-map "\r" 'dun-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1345 (defvar dungeon-batch-map
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1346 (let ((map (make-keymap))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1347 (n 32))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1348 (while (< 0 (setq n (- n 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1349 (define-key map (make-string 1 n) 'dungeon-nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1350 (define-key map "\r" 'exit-minibuffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1351 (define-key map "\n" 'exit-minibuffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1352 map))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1353 (setq dun-computer nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1354 (setq dun-floppy nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1355 (setq dun-key-level 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1356 (setq dun-hole nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1357 (setq dun-correct-answer nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1358 (setq dun-lastdir 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1359 (setq dun-numsaves 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1360 (setq dun-jar nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1361 (setq dun-dead nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1362 (setq room 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1363 (setq dun-numcmds 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1364 (setq dun-wizard nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1365 (setq dun-endgame-question nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1366 (setq dun-logged-in nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1367 (setq dungeon-mode 'dungeon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1368 (setq dun-unix-verbs '((ls . dun-ls) (ftp . dun-ftp) (echo . dun-echo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1369 (exit . dun-uexit) (cd . dun-cd) (pwd . dun-pwd)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1370 (rlogin . dun-rlogin) (uncompress . dun-uncompress)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1371 (cat . dun-cat) (zippy . dun-zippy)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1372
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1373 (setq dun-dos-verbs '((dir . dun-dos-dir) (type . dun-dos-type)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1374 (exit . dun-dos-exit) (command . dun-dos-spawn)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1375 (b: . dun-dos-invd) (c: . dun-dos-invd)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1376 (a: . dun-dos-nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1377
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1378
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1379 (setq dun-batch-mode nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1380
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1381 (setq dun-cdpath "/usr/toukmond")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1382 (setq dun-cdroom -10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1383 (setq dun-uncompressed nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1384 (setq dun-ethernet t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1385 (setq dun-restricted
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1386 '(dun-room-objects dungeon-map dun-rooms
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1387 dun-room-silents dun-combination))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1388 (setq dun-ftptype 'ascii)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1389 (setq dun-endgame nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1390 (setq dun-gottago t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1391 (setq dun-black nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1392
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1393 (setq dun-rooms '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1394 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1395 "You are in the treasure room. A door leads out to the north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1396 "Treasure room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1397 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1398 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1399 "You are at a dead end of a dirt road. The road goes to the east.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1400 In the distance you can see that it will eventually fork off. The
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1401 trees here are very tall royal palms, and they are spaced equidistant
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1402 from each other."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1403 "Dead end"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1404 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1405 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1406 "You are on the continuation of a dirt road. There are more trees on
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1407 both sides of you. The road continues to the east and west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1408 "E/W Dirt road"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1409 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1410 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1411 "You are at a fork of two passages, one to the northeast, and one to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1412 southeast. The ground here seems very soft. You can also go back west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1413 "Fork"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1414 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1415 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1416 "You are on a northeast/southwest road."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1417 "NE/SW road"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1418 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1419 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1420 "You are at the end of the road. There is a building in front of you
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1421 to the northeast, and the road leads back to the southwest."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1422 "Building front"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1423 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1424 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1425 "You are on a southeast/northwest road."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1426 "SE/NW road"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1427 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1428 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1429 "You are standing at the end of a road. A passage leads back to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1430 northwest."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1431 "Bear hangout"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1432 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1433 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1434 "You are in the hallway of an old building. There are rooms to the east
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1435 and west, and doors leading out to the north and south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1436 "Old Building hallway"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1437 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1438 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1439 "You are in a mailroom. There are many bins where the mail is usually
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1440 kept. The exit is to the west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1441 "Mailroom"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1442 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1443 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1444 "You are in a computer room. It seems like most of the equipment has
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1445 been removed. There is a VAX 11/780 in front of you, however, with
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1446 one of the cabinets wide open. A sign on the front of the machine
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1447 says: This VAX is named 'pokey'. To type on the console, use the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1448 'type' command. The exit is to the east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1449 "Computer room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1450 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1451 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1452 "You are in a meadow in the back of an old building. A small path leads
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1453 to the west, and a door leads to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1454 "Meadow"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1455 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1456 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1457 "You are in a round, stone room with a door to the east. There
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1458 is a sign on the wall that reads: 'receiving room'."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1459 "Receiving room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1460 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1461 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1462 "You are at the south end of a hallway that leads to the north. There
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1463 are rooms to the east and west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1464 "Northbound Hallway"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1465 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1466 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1467 "You are in a sauna. There is nothing in the room except for a dial
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1468 on the wall. A door leads out to west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1469 "Sauna"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1470 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1471 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1472 "You are at the end of a north/south hallway. You can go back to the south,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1473 or off to a room to the east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1474 "End of N/S Hallway"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1475 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1476 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1477 "You are in an old weight room. All of the equipment is either destroyed
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1478 or completely broken. There is a door out to the west, and there is a ladder
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1479 leading down a hole in the floor."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1480 "Weight room" ;16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1481 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1482 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1483 "You are in a maze of twisty little passages, all alike.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1484 There is a button on the ground here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1485 "Maze button room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1486 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1487 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1488 "You are in a maze of little twisty passages, all alike."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1489 "Maze"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1490 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1491 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1492 "You are in a maze of thirsty little passages, all alike."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1493 "Maze" ;19
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1494 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1495 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1496 "You are in a maze of twenty little passages, all alike."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1497 "Maze"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1498 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1499 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1500 "You are in a daze of twisty little passages, all alike."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1501 "Maze" ;21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1502 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1503 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1504 "You are in a maze of twisty little cabbages, all alike."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1505 "Maze" ;22
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1506 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1507 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1508 "You are in a reception area for a health and fitness center. The place
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1509 appears to have been recently ransacked, and nothing is left. There is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1510 a door out to the south, and a crawlspace to the southeast."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1511 "Reception area"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1512 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1513 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1514 "You are outside a large building to the north which used to be a health
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1515 and fitness center. A road leads to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1516 "Health Club front"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1517 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1518 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1519 "You are at the north side of a lake. On the other side you can see
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1520 a road which leads to a cave. The water appears very deep."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1521 "Lakefront North"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1522 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1523 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1524 "You are at the south side of a lake. A road goes to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1525 "Lakefront South"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1526 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1527 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1528 "You are in a well-hidden area off to the side of a road. Back to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1529 northeast through the brush you can see the bear hangout."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1530 "Hidden area"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1531 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1532 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1533 "The entrance to a cave is to the south. To the north, a road leads
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1534 towards a deep lake. On the ground nearby there is a chute, with a sign
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1535 that says 'put treasures here for points'."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1536 "Cave Entrance" ;28
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1537 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1538 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1539 "You are in a misty, humid room carved into a mountain.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1540 To the north is the remains of a rockslide. To the east, a small
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1541 passage leads away into the darkness." ;29
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1542 "Misty Room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1543 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1544 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1545 "You are in an east/west passageway. The walls here are made of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1546 multicolored rock and are quite beautiful."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1547 "Cave E/W passage" ;30
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1548 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1549 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1550 "You are at the junction of two passages. One goes north/south, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1551 the other goes west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1552 "N/S/W Junction" ;31
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1553 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1554 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1555 "You are at the north end of a north/south passageway. There are stairs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1556 leading down from here. There is also a door leading west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1557 "North end of cave passage" ;32
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1558 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1559 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1560 "You are at the south end of a north/south passageway. There is a hole
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1561 in the floor here, into which you could probably fit."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1562 "South end of cave passage" ;33
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1563 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1564 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1565 "You are in what appears to be a worker's bedroom. There is a queen-
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1566 sized bed in the middle of the room, and a painting hanging on the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1567 wall. A door leads to another room to the south, and stairways
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1568 lead up and down."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1569 "Bedroom" ;34
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1570 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1571 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1572 "You are in a bathroom built for workers in the cave. There is a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1573 urinal hanging on the wall, and some exposed pipes on the opposite
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1574 wall where a sink used to be. To the north is a bedroom."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1575 "Bathroom" ;35
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1576 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1577 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1578 "This is a marker for the urinal. User will not see this, but it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1579 is a room that can contain objects."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1580 "Urinal" ;36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1581 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1582 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1583 "You are at the northeast end of a northeast/southwest passageway.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1584 Stairs lead up out of sight."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1585 "Ne end of ne/sw cave passage" ;37
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1586 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1587 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1588 "You are at the junction of northeast/southwest and east/west passages."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1589 "Ne/sw-e/w junction" ;38
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1590 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1591 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1592 "You are at the southwest end of a northeast/southwest passageway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1593 "Sw end of ne/sw cave passage" ;39
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1594 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1595 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1596 "You are at the east end of an e/w passage. There are stairs leading up
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1597 to a room above."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1598 "East end of e/w cave passage" ;40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1599 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1600 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1601 "You are at the west end of an e/w passage. There is a hole on the ground
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1602 which leads down out of sight."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1603 "West end of e/w cave passage" ;41
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1604 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1605 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1606 "You are in a room which is bare, except for a horseshoe shaped boulder
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1607 in the center. Stairs lead down from here." ;42
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1608 "Horseshoe boulder room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1609 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1610 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1611 "You are in a room which is completely empty. Doors lead out to the north
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1612 and east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1613 "Empty room" ;43
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1614 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1615 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1616 "You are in an empty room. Interestingly enough, the stones in this
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1617 room are painted blue. Doors lead out to the east and south." ;44
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1618 "Blue room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1619 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1620 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1621 "You are in an empty room. Interestingly enough, the stones in this
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1622 room are painted yellow. Doors lead out to the south and west." ;45
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1623 "Yellow room"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1624 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1625 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1626 "You are in an empty room. Interestingly enough, the stones in this room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1627 are painted red. Doors lead out to the west and north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1628 "Red room" ;46
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1629 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1630 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1631 "You are in the middle of a long north/south hallway." ;47
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1632 "Long n/s hallway"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1633 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1634 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1635 "You are 3/4 of the way towards the north end of a long north/south hallway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1636 "3/4 north" ;48
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1637 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1638 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1639 "You are at the north end of a long north/south hallway. There are stairs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1640 leading upwards."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1641 "North end of long hallway" ;49
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1642 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1643 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1644 "You are 3/4 of the way towards the south end of a long north/south hallway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1645 "3/4 south" ;50
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1646 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1647 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1648 "You are at the south end of a long north/south hallway. There is a hole
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1649 to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1650 "South end of long hallway" ;51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1651 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1652 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1653 "You are at a landing in a stairwell which continues up and down."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1654 "Stair landing" ;52
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1655 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1656 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1657 "You are at the continuation of an up/down staircase."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1658 "Up/down staircase" ;53
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1659 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1660 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1661 "You are at the top of a staircase leading down. A crawlway leads off
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1662 to the northeast."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1663 "Top of staircase." ;54
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1664 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1665 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1666 "You are in a crawlway that leads northeast or southwest."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1667 "Ne crawlway" ;55
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1668 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1669 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1670 "You are in a small crawlspace. There is a hole in the ground here, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1671 a small passage back to the southwest."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1672 "Small crawlspace" ;56
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1673 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1674 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1675 "You are in the Gamma Computing Center. An IBM 3090/600s is whirring
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1676 away in here. There is an ethernet cable coming out of one of the units,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1677 and going through the ceiling. There is no console here on which you
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1678 could type."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1679 "Gamma computing center" ;57
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1680 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1681 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1682 "You are near the remains of a post office. There is a mail drop on the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1683 face of the building, but you cannot see where it leads. A path leads
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1684 back to the east, and a road leads to the north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1685 "Post office" ;58
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1686 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1687 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1688 "You are at the intersection of Main Street and Maple Ave. Main street
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1689 runs north and south, and Maple Ave runs east off into the distance.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1690 If you look north and east you can see many intersections, but all of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1691 the buildings that used to stand here are gone. Nothing remains except
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1692 street signs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1693 There is a road to the northwest leading to a gate that guards a building."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1694 "Main-Maple intersection" ;59
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1695 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1696 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1697 "You are at the intersection of Main Street and the west end of Oaktree Ave."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1698 "Main-Oaktree intersection" ;60
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1699 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1700 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1701 "You are at the intersection of Main Street and the west end of Vermont Ave."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1702 "Main-Vermont intersection" ;61
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1703 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1704 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1705 "You are at the north end of Main Street at the west end of Sycamore Ave." ;62
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1706 "Main-Sycamore intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1707 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1708 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1709 "You are at the south end of First Street at Maple Ave." ;63
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1710 "First-Maple intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1711 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1712 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1713 "You are at the intersection of First Street and Oaktree Ave." ;64
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1714 "First-Oaktree intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1715 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1716 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1717 "You are at the intersection of First Street and Vermont Ave." ;65
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1718 "First-Vermont intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1719 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1720 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1721 "You are at the north end of First Street at Sycamore Ave." ;66
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1722 "First-Sycamore intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1723 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1724 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1725 "You are at the south end of Second Street at Maple Ave." ;67
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1726 "Second-Maple intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1727 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1728 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1729 "You are at the intersection of Second Street and Oaktree Ave." ;68
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1730 "Second-Oaktree intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1731 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1732 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1733 "You are at the intersection of Second Street and Vermont Ave." ;69
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1734 "Second-Vermont intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1735 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1736 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1737 "You are at the north end of Second Street at Sycamore Ave." ;70
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1738 "Second-Sycamore intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1739 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1740 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1741 "You are at the south end of Third Street at Maple Ave." ;71
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1742 "Third-Maple intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1743 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1744 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1745 "You are at the intersection of Third Street and Oaktree Ave." ;72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1746 "Third-Oaktree intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1747 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1748 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1749 "You are at the intersection of Third Street and Vermont Ave." ;73
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1750 "Third-Vermont intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1751 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1752 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1753 "You are at the north end of Third Street at Sycamore Ave." ;74
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1754 "Third-Sycamore intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1755 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1756 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1757 "You are at the south end of Fourth Street at Maple Ave." ;75
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1758 "Fourth-Maple intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1759 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1760 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1761 "You are at the intersection of Fourth Street and Oaktree Ave." ;76
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1762 "Fourth-Oaktree intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1763 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1764 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1765 "You are at the intersection of Fourth Street and Vermont Ave." ;77
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1766 "Fourth-Vermont intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1767 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1768 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1769 "You are at the north end of Fourth Street at Sycamore Ave." ;78
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1770 "Fourth-Sycamore intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1771 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1772 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1773 "You are at the south end of Fifth Street at the east end of Maple Ave." ;79
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1774 "Fifth-Maple intersection"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1775 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1776 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1777 "You are at the intersection of Fifth Street and the east end of Oaktree Ave.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1778 There is a cliff off to the east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1779 "Fifth-Oaktree intersection" ;80
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1780 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1781 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1782 "You are at the intersection of Fifth Street and the east end of Vermont Ave."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1783 "Fifth-Vermont intersection" ;81
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1784 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1785 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1786 "You are at the north end of Fifth Street and the east end of Sycamore Ave."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1787 "Fifth-Sycamore intersection" ;82
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1788 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1789 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1790 "You are in front of the Museum of Natural History. A door leads into
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1791 the building to the north, and a road leads to the southeast."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1792 "Museum entrance" ;83
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1793 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1794 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1795 "You are in the main lobby for the Museum of Natural History. In the center
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1796 of the room is the huge skeleton of a dinosaur. Doors lead out to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1797 south and east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1798 "Museum lobby" ;84
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1799 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1800 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1801 "You are in the geological display. All of the objects that used to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1802 be on display are missing. There are rooms to the east, west, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1803 north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1804 "Geological display" ;85
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1805 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1806 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1807 "You are in the marine life area. The room is filled with fish tanks,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1808 which are filled with dead fish that have apparently died due to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1809 starvation. Doors lead out to the south and east."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1810 "Marine life area" ;86
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1811 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1812 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1813 "You are in some sort of maintenance room for the museum. There is a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1814 switch on the wall labeled 'BL'. There are doors to the west and north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1815 "Maintenance room" ;87
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1816 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1817 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1818 "You are in a classroom where school children were taught about natural
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1819 history. On the blackboard is written, 'No children allowed downstairs.'
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1820 There is a door to the east with an 'exit' sign on it. There is another
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1821 door to the west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1822 "Classroom" ;88
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1823 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1824 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1825 "You are at the Vermont St. subway station. A train is sitting here waiting."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1826 "Vermont station" ;89
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1827 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1828 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1829 "You are at the Museum subway stop. A passage leads off to the north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1830 "Museum station" ;90
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1831 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1832 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1833 "You are in a north/south tunnel."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1834 "N/S tunnel" ;91
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1835 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1836 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1837 "You are at the north end of a north/south tunnel. Stairs lead up and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1838 down from here. There is a garbage disposal here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1839 "North end of n/s tunnel" ;92
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1840 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1841 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1842 "You are at the top of some stairs near the subway station. There is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1843 a door to the west."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1844 "Top of subway stairs" ;93
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1845 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1846 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1847 "You are at the bottom of some stairs near the subway station. There is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1848 a room to the northeast."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1849 "Bottom of subway stairs" ;94
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1850 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1851 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1852 "You are in another computer room. There is a computer in here larger
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1853 than you have ever seen. It has no manufacturers name on it, but it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1854 does have a sign that says: This machine's name is 'endgame'. The
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1855 exit is to the southwest. There is no console here on which you could
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1856 type."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1857 "Endgame computer room" ;95
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1858 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1859 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1860 "You are in a north/south hallway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1861 "Endgame n/s hallway" ;96
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1862 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1863 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1864 "You have reached a question room. You must answer a question correctly in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1865 order to get by. Use the 'answer' command to answer the question."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1866 "Question room 1" ;97
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1867 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1868 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1869 "You are in a north/south hallway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1870 "Endgame n/s hallway" ;98
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1871 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1872 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1873 "You are in a second question room."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1874 "Question room 2" ;99
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1875 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1876 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1877 "You are in a north/south hallway."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1878 "Endgame n/s hallway" ;100
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1879 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1880 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1881 "You are in a third question room."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1882 "Question room 3" ;101
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1883 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1884 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1885 "You are in the endgame treasure room. A door leads out to the north, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1886 a hallway leads to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1887 "Endgame treasure room" ;102
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1888 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1889 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1890 "You are in the winner's room. A door leads back to the south."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1891 "Winner's room" ;103
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1892 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1893 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1894 "You have reached a dead end. There is a PC on the floor here. Above
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1895 it is a sign that reads:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1896 Type the 'reset' command to type on the PC.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1897 A hole leads north."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1898 "PC area" ;104
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1899 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1900 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1901
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1902 (setq dun-light-rooms '(0 1 2 3 4 5 6 7 8 9 10 11 12 13 24 25 26 27 28 58 59
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1903 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1904 77 78 79 80 81 82 83))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1905
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1906 (setq dun-verblist '((die . dun-die) (ne . dun-ne) (north . dun-n)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1907 (south . dun-s) (east . dun-e) (west . dun-w)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1908 (u . dun-up) (d . dun-down) (i . dun-inven)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1909 (inventory . dun-inven) (look . dun-examine) (n . dun-n)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1910 (s . dun-s) (e . dun-e) (w . dun-w) (se . dun-se)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1911 (nw . dun-nw) (sw . dun-sw) (up . dun-up)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1912 (down . dun-down) (in . dun-in) (out . dun-out)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1913 (go . dun-go) (drop . dun-drop) (southeast . dun-se)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1914 (southwest . dun-sw) (northeast . dun-ne)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1915 (northwest . dun-nw) (save . dun-save-game)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1916 (restore . dun-restore) (long . dun-long) (dig . dun-dig)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1917 (shake . dun-shake) (wave . dun-shake)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1918 (examine . dun-examine) (describe . dun-examine)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1919 (climb . dun-climb) (eat . dun-eat) (put . dun-put)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1920 (type . dun-type) (insert . dun-put)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1921 (score . dun-score) (help . dun-help) (quit . dun-quit)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1922 (read . dun-examine) (verbose . dun-long)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
1923 (urinate . dun-piss) (piss . dun-piss)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1924 (flush . dun-flush) (sleep . dun-sleep) (lie . dun-sleep)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1925 (x . dun-examine) (break . dun-break) (drive . dun-drive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1926 (board . dun-in) (enter . dun-in) (turn . dun-turn)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1927 (press . dun-press) (push . dun-press) (swim . dun-swim)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1928 (on . dun-in) (off . dun-out) (chop . dun-break)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1929 (switch . dun-press) (cut . dun-break) (exit . dun-out)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1930 (leave . dun-out) (reset . dun-power) (flick . dun-press)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1931 (superb . dun-superb) (answer . dun-answer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1932 (throw . dun-drop) (l . dun-examine) (take . dun-take)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1933 (get . dun-take) (feed . dun-feed)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1934
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1935 (setq dun-inbus nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1936 (setq dun-nomail nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1937 (setq dun-ignore '(the to at))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1938 (setq dun-mode 'moby)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1939 (setq dun-sauna-level 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1940
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1941 (defconst north 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1942 (defconst south 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1943 (defconst east 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1944 (defconst west 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1945 (defconst northeast 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1946 (defconst southeast 5)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1947 (defconst northwest 6)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1948 (defconst southwest 7)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1949 (defconst up 8)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1950 (defconst down 9)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1951 (defconst in 10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1952 (defconst out 11)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1953
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1954 (setq dungeon-map '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1955 ; no so ea we ne se nw sw up do in ot
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1956 ( 96 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1957 ( -1 -1 2 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;1
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1958 ( -1 -1 3 1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1959 ( -1 -1 -1 2 4 6 -1 -1 -1 -1 -1 -1 ) ;3
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1960 ( -1 -1 -1 -1 5 -1 -1 3 -1 -1 -1 -1 ) ;4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1961 ( -1 -1 -1 -1 255 -1 -1 4 -1 -1 255 -1 ) ;5
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1962 ( -1 -1 -1 -1 -1 7 3 -1 -1 -1 -1 -1 ) ;6
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1963 ( -1 -1 -1 -1 -1 255 6 27 -1 -1 -1 -1 ) ;7
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1964 ( 255 5 9 10 -1 -1 -1 5 -1 -1 -1 5 ) ;8
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1965 ( -1 -1 -1 8 -1 -1 -1 -1 -1 -1 -1 -1 ) ;9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1966 ( -1 -1 8 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;10
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1967 ( -1 8 -1 58 -1 -1 -1 -1 -1 -1 -1 -1 ) ;11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1968 ( -1 -1 13 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;12
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1969 ( 15 -1 14 12 -1 -1 -1 -1 -1 -1 -1 -1 ) ;13
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1970 ( -1 -1 -1 13 -1 -1 -1 -1 -1 -1 -1 -1 ) ;14
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1971 ( -1 13 16 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;15
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1972 ( -1 -1 -1 15 -1 -1 -1 -1 -1 17 16 -1 ) ;16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1973 ( -1 -1 17 17 17 17 255 17 255 17 -1 -1 ) ;17
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1974 ( 18 18 18 18 18 -1 18 18 19 18 -1 -1 ) ;18
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1975 ( -1 18 18 19 19 20 19 19 -1 18 -1 -1 ) ;19
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1976 ( -1 -1 -1 18 -1 -1 -1 -1 -1 21 -1 -1 ) ;20
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1977 ( -1 -1 -1 -1 -1 20 22 -1 -1 -1 -1 -1 ) ;21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1978 ( 18 18 18 18 16 18 23 18 18 18 18 18 ) ;22
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1979 ( -1 255 -1 -1 -1 19 -1 -1 -1 -1 -1 -1 ) ;23
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1980 ( 23 25 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;24
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1981 ( 24 255 -1 -1 -1 -1 -1 -1 -1 -1 255 -1 ) ;25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1982 (255 28 -1 -1 -1 -1 -1 -1 -1 -1 255 -1 ) ;26
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1983 ( -1 -1 -1 -1 7 -1 -1 -1 -1 -1 -1 -1 ) ;27
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1984 ( 26 255 -1 -1 -1 -1 -1 -1 -1 -1 255 -1 ) ;28
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1985 ( -1 -1 30 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;29
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1986 ( -1 -1 31 29 -1 -1 -1 -1 -1 -1 -1 -1 ) ;30
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1987 ( 32 33 -1 30 -1 -1 -1 -1 -1 -1 -1 -1 ) ;31
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1988 ( -1 31 -1 255 -1 -1 -1 -1 -1 34 -1 -1 ) ;32
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1989 ( 31 -1 -1 -1 -1 -1 -1 -1 -1 35 -1 -1 ) ;33
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1990 ( -1 35 -1 -1 -1 -1 -1 -1 32 37 -1 -1 ) ;34
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1991 ( 34 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;35
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1992 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;36
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1993 ( -1 -1 -1 -1 -1 -1 -1 38 34 -1 -1 -1 ) ;37
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1994 ( -1 -1 40 41 37 -1 -1 39 -1 -1 -1 -1 ) ;38
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1995 ( -1 -1 -1 -1 38 -1 -1 -1 -1 -1 -1 -1 ) ;39
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1996 ( -1 -1 -1 38 -1 -1 -1 -1 42 -1 -1 -1 ) ;40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1997 ( -1 -1 38 -1 -1 -1 -1 -1 -1 43 -1 -1 ) ;41
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1998 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 40 -1 -1 ) ;42
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1999 ( 44 -1 46 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;43
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2000 ( -1 43 45 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;44
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2001 ( -1 46 -1 44 -1 -1 -1 -1 -1 -1 -1 -1 ) ;45
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2002 ( 45 -1 -1 43 -1 -1 -1 -1 -1 255 -1 -1 ) ;46
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2003 ( 48 50 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;47
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2004 ( 49 47 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;48
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2005 ( -1 48 -1 -1 -1 -1 -1 -1 52 -1 -1 -1 ) ;49
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2006 ( 47 51 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;50
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2007 ( 50 104 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2008 ( -1 -1 -1 -1 -1 -1 -1 -1 53 49 -1 -1 ) ;52
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2009 ( -1 -1 -1 -1 -1 -1 -1 -1 54 52 -1 -1 ) ;53
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2010 ( -1 -1 -1 -1 55 -1 -1 -1 -1 53 -1 -1 ) ;54
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2011 ( -1 -1 -1 -1 56 -1 -1 54 -1 -1 -1 54 ) ;55
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2012 ( -1 -1 -1 -1 -1 -1 -1 55 -1 31 -1 -1 ) ;56
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2013 ( -1 -1 32 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;57
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2014 ( 59 -1 11 -1 -1 -1 -1 -1 -1 -1 255 255) ;58
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2015 ( 60 58 63 -1 -1 -1 255 -1 -1 -1 255 255) ;59
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2016 ( 61 59 64 -1 -1 -1 -1 -1 -1 -1 255 255) ;60
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2017 ( 62 60 65 -1 -1 -1 -1 -1 -1 -1 255 255) ;61
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2018 ( -1 61 66 -1 -1 -1 -1 -1 -1 -1 255 255) ;62
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2019 ( 64 -1 67 59 -1 -1 -1 -1 -1 -1 255 255) ;63
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2020 ( 65 63 68 60 -1 -1 -1 -1 -1 -1 255 255) ;64
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2021 ( 66 64 69 61 -1 -1 -1 -1 -1 -1 255 255) ;65
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2022 ( -1 65 70 62 -1 -1 -1 -1 -1 -1 255 255) ;66
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2023 ( 68 -1 71 63 -1 -1 -1 -1 -1 -1 255 255) ;67
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2024 ( 69 67 72 64 -1 -1 -1 -1 -1 -1 255 255) ;68
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2025 ( 70 68 73 65 -1 -1 -1 -1 -1 -1 255 255) ;69
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2026 ( -1 69 74 66 -1 -1 -1 -1 -1 -1 255 255) ;70
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2027 ( 72 -1 75 67 -1 -1 -1 -1 -1 -1 255 255) ;71
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2028 ( 73 71 76 68 -1 -1 -1 -1 -1 -1 255 255) ;72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2029 ( 74 72 77 69 -1 -1 -1 -1 -1 -1 255 255) ;73
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2030 ( -1 73 78 70 -1 -1 -1 -1 -1 -1 255 255) ;74
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2031 ( 76 -1 79 71 -1 -1 -1 -1 -1 -1 255 255) ;75
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2032 ( 77 75 80 72 -1 -1 -1 -1 -1 -1 255 255) ;76
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2033 ( 78 76 81 73 -1 -1 -1 -1 -1 -1 255 255) ;77
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2034 ( -1 77 82 74 -1 -1 -1 -1 -1 -1 255 255) ;78
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2035 ( 80 -1 -1 75 -1 -1 -1 -1 -1 -1 255 255) ;79
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2036 ( 81 79 255 76 -1 -1 -1 -1 -1 -1 255 255) ;80
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2037 ( 82 80 -1 77 -1 -1 -1 -1 -1 -1 255 255) ;81
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2038 ( -1 81 -1 78 -1 -1 -1 -1 -1 -1 255 255) ;82
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2039 ( 84 -1 -1 -1 -1 59 -1 -1 -1 -1 255 255) ;83
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2040 ( -1 83 85 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;84
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2041 ( 86 -1 87 84 -1 -1 -1 -1 -1 -1 -1 -1 ) ;85
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2042 ( -1 85 88 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;86
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2043 ( 88 -1 -1 85 -1 -1 -1 -1 -1 -1 -1 -1 ) ;87
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2044 ( -1 87 255 86 -1 -1 -1 -1 -1 -1 -1 -1 ) ;88
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2045 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 255 -1 ) ;89
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2046 ( 91 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;90
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2047 ( 92 90 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;91
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2048 ( -1 91 -1 -1 -1 -1 -1 -1 93 94 -1 -1 ) ;92
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2049 ( -1 -1 -1 88 -1 -1 -1 -1 -1 92 -1 -1 ) ;93
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2050 ( -1 -1 -1 -1 95 -1 -1 -1 92 -1 -1 -1 ) ;94
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2051 ( -1 -1 -1 -1 -1 -1 -1 94 -1 -1 -1 -1 ) ;95
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2052 ( 97 0 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;96
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2053 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;97
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2054 ( 99 97 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;98
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2055 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;99
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2056 ( 101 99 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;100
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2057 ( -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;101
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2058 ( 103 101 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;102
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2059 ( -1 102 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;103
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2060 ( 51 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ) ;104
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2061 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2062 ; no so ea we ne se nw sw up do in ot
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2063 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2064
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2065
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2066 ;;; How the user references *all* objects, permanent and regular.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2067 (setq dun-objnames '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2068 (shovel . 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2069 (lamp . 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2070 (cpu . 2) (board . 2) (card . 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2071 (food . 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2072 (key . 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2073 (paper . 5)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2074 (rms . 6) (statue . 6) (statuette . 6) (stallman . 6)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2075 (diamond . 7)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2076 (weight . 8)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2077 (life . 9) (preserver . 9)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2078 (bracelet . 10) (emerald . 10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2079 (gold . 11)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2080 (platinum . 12)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2081 (towel . 13) (beach . 13)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2082 (axe . 14)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2083 (silver . 15)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2084 (license . 16)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2085 (coins . 17)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2086 (egg . 18)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2087 (jar . 19)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2088 (bone . 20)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2089 (acid . 21) (nitric . 21)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2090 (glycerine . 22)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2091 (ruby . 23)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2092 (amethyst . 24)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2093 (mona . 25)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2094 (bill . 26)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2095 (floppy . 27) (disk . 27)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2096
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2097 (boulder . -1)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
2098 (tree . -2) (trees . -2)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2099 (bear . -3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2100 (bin . -4) (bins . -4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2101 (cabinet . -5) (computer . -5) (vax . -5) (ibm . -5)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2102 (protoplasm . -6)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2103 (dial . -7)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2104 (button . -8)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2105 (chute . -9)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2106 (painting . -10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2107 (bed . -11)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2108 (urinal . -12)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2109 (URINE . -13)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2110 (pipes . -14) (pipe . -14)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2111 (box . -15) (slit . -15)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2112 (cable . -16) (ethernet . -16)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2113 (mail . -17) (drop . -17)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2114 (bus . -18)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2115 (gate . -19)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2116 (cliff . -20)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2117 (skeleton . -21) (dinosaur . -21)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2118 (fish . -22)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2119 (tanks . -23)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2120 (switch . -24)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2121 (blackboard . -25)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2122 (disposal . -26) (garbage . -26)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2123 (ladder . -27)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2124 (subway . -28) (train . -28)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2125 (pc . -29) (drive . -29)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2126 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2127
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2128 (dolist (x dun-objnames)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2129 (let (name)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2130 (setq name (concat "obj-" (prin1-to-string (car x))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2131 (eval (list 'defconst (intern name) (cdr x)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2132
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2133 (defconst obj-special 255)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2134
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2135 ;;; The initial setup of what objects are in each room.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2136 ;;; Regular objects have whole numbers lower than 255.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2137 ;;; Objects that cannot be taken but might move and are
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2138 ;;; described during room description are negative.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2139 ;;; Stuff that is described and might change are 255, and are
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2140 ;;; handled specially by 'dun-describe-room.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2141
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2142 (setq dun-room-objects (list nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2143
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2144 (list obj-shovel) ;; treasure-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2145 (list obj-boulder) ;; dead-end
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2146 nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2147 (list obj-food) ;; se-nw-road
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2148 (list obj-bear) ;; bear-hangout
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2149 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2150 (list obj-special) ;; computer-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2151 (list obj-lamp obj-license obj-silver);; meadow
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2152 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2153 (list obj-special) ;; sauna
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2154 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2155 (list obj-weight obj-life) ;; weight-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2156 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2157 (list obj-rms obj-floppy) ;; thirsty-maze
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2158 nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2159 (list obj-emerald) ;; hidden-area
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2160 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2161 (list obj-gold) ;; misty-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2162 nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2163 (list obj-towel obj-special) ;; red-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2164 nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2165 (list obj-box) ;; stair-landing
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2166 nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2167 (list obj-axe) ;; smal-crawlspace
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2168 nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2169 nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2170 (list obj-special) ;; fourth-vermont-intersection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2171 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2172 (list obj-coins) ;; fifth-oaktree-intersection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2173 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2174 (list obj-bus) ;; fifth-sycamore-intersection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2175 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2176 (list obj-bone) ;; museum-lobby
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2177 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2178 (list obj-jar obj-special obj-ruby) ;; marine-life-area
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2179 (list obj-nitric) ;; maintenance-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2180 (list obj-glycerine) ;; classroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2181 nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2182 (list obj-amethyst) ;; bottom-of-subway-stairs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2183 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2184 (list obj-special) ;; question-room-1
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2185 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2186 (list obj-special) ;; question-room-2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2187 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2188 (list obj-special) ;; question-room-three
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2189 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2190 (list obj-mona) ;; winner's-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2191 nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2192 nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2193 nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2194 nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2195
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2196 ;;; These are objects in a room that are only described in the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2197 ;;; room description. They are permanent.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2198
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2199 (setq dun-room-silents (list nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2200 (list obj-tree) ;; dead-end
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2201 (list obj-tree) ;; e-w-dirt-road
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2202 nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2203 (list obj-bin) ;; mailroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2204 (list obj-computer) ;; computer-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2205 nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2206 (list obj-dial) ;; sauna
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2207 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2208 (list obj-ladder) ;; weight-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2209 (list obj-button obj-ladder) ;; maze-button-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2210 nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2211 nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2212 (list obj-chute) ;; cave-entrance
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2213 nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2214 (list obj-painting obj-bed) ;; bedroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2215 (list obj-urinal obj-pipes) ;; bathroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2216 nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2217 (list obj-boulder) ;; horseshoe-boulder-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2218 nil nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2219 (list obj-computer obj-cable) ;; gamma-computing-center
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2220 (list obj-mail) ;; post-office
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2221 (list obj-gate) ;; main-maple-intersection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2222 nil nil nil nil nil nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2223 nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2224 (list obj-cliff) ;; fifth-oaktree-intersection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2225 nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2226 (list obj-dinosaur) ;; museum-lobby
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2227 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2228 (list obj-fish obj-tanks) ;; marine-life-area
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2229 (list obj-switch) ;; maintenance-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2230 (list obj-blackboard) ;; classroom
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2231 (list obj-train) ;; vermont-station
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2232 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2233 (list obj-disposal) ;; north-end-of-n-s-tunnel
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2234 nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2235 (list obj-computer) ;; endgame-computer-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2236 nil nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2237 (list obj-pc) ;; pc-area
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2238 nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2239 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2240 (setq dun-inventory '(1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2241
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2242 ;;; Descriptions of objects, as they appear in the room description, and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2243 ;;; the inventory.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2244
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2245 (setq dun-objects '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2246 ("There is a shovel here." "A shovel") ;0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2247 ("There is a lamp nearby." "A lamp") ;1
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2248 ("There is a CPU card here." "A computer board") ;2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2249 ("There is some food here." "Some food") ;3
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2250 ("There is a shiny brass key here." "A brass key") ;4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2251 ("There is a slip of paper here." "A slip of paper") ;5
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2252 ("There is a wax statuette of Richard Stallman here." ;6
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2253 "An RMS statuette")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2254 ("There is a shimmering diamond here." "A diamond") ;7
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2255 ("There is a 10 pound weight here." "A weight") ;8
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2256 ("There is a life preserver here." "A life preserver");9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2257 ("There is an emerald bracelet here." "A bracelet") ;10
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2258 ("There is a gold bar here." "A gold bar") ;11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2259 ("There is a platinum bar here." "A platinum bar") ;12
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2260 ("There is a beach towel on the ground here." "A beach towel")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2261 ("There is an axe here." "An axe") ;14
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2262 ("There is a silver bar here." "A silver bar") ;15
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2263 ("There is a bus driver's license here." "A license") ;16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2264 ("There are some valuable coins here." "Some valuable coins")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2265 ("There is a jewel-encrusted egg here." "A valuable egg") ;18
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2266 ("There is a glass jar here." "A glass jar") ;19
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2267 ("There is a dinosaur bone here." "A bone") ;20
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2268 ("There is a packet of nitric acid here." "Some nitric acid")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2269 ("There is a packet of glycerine here." "Some glycerine") ;22
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2270 ("There is a valuable ruby here." "A ruby") ;23
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2271 ("There is a valuable amethyst here." "An amethyst") ;24
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2272 ("The Mona Lisa is here." "The Mona Lisa") ;25
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2273 ("There is a 100 dollar bill here." "A $100 bill") ;26
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2274 ("There is a floppy disk here." "A floppy disk") ;27
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2275 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2276 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2277
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2278 ;;; Weight of objects
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2279
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2280 (setq dun-object-lbs
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2281 '(2 1 1 1 1 0 2 2 10 3 1 1 1 0 1 1 0 1 1 1 1 0 0 2 2 1 0 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2282 (setq dun-object-pts
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2283 '(0 0 0 0 0 0 0 10 0 0 10 10 10 0 0 10 0 10 10 0 0 0 0 10 10 10 10 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2284
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2285
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2286 ;;; Unix representation of objects.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2287 (setq dun-objfiles '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2288 "shovel.o" "lamp.o" "cpu.o" "food.o" "key.o" "paper.o"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2289 "rms.o" "diamond.o" "weight.o" "preserver.o" "bracelet.o"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2290 "gold.o" "platinum.o" "towel.o" "axe.o" "silver.o" "license.o"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2291 "coins.o" "egg.o" "jar.o" "bone.o" "nitric.o" "glycerine.o"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2292 "ruby.o" "amethyst.o"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2293 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2294
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2295 ;;; These are the descriptions for the negative numbered objects from
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2296 ;;; dun-room-objects
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2297
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2298 (setq dun-perm-objects '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2299 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2300 ("There is a large boulder here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2301 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2302 ("There is a ferocious bear here!")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2303 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2304 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2305 ("There is a worthless pile of protoplasm here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2306 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2307 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2308 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2309 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2310 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2311 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2312 ("There is a strange smell in this room.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2313 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2314 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2315 "There is a box with a slit in it, bolted to the wall here."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2316 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2317 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2318 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2319 ("There is a bus here.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2320 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2321 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2322 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2323 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2324
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2325
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2326 ;;; These are the descriptions the user gets when regular objects are
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2327 ;;; examined.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2328
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2329 (setq dun-physobj-desc '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2330 "It is a normal shovel with a price tag attached that says $19.99."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2331 "The lamp is hand-crafted by Geppetto."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2332 "The CPU board has a VAX chip on it. It seems to have
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2333 2 Megabytes of RAM onboard."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2334 "It looks like some kind of meat. Smells pretty bad."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2335 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2336 "The paper says: Don't forget to type 'help' for help. Also, remember
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2337 this word: 'worms'"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2338 "The statuette is of the likeness of Richard Stallman, the author of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2339 famous EMACS editor. You notice that he is not wearing any shoes."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2340 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2341 "You observe that the weight is heavy."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2342 "It says S. S. Minnow."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2343 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2344 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2345 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2346 "It has a picture of snoopy on it."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2347 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2348 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2349 "It has your picture on it!"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2350 "They are old coins from the 19th century."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2351 "It is a valuable Fabrege egg."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2352 "It is a a plain glass jar."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2353 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2354 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2355 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2356 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2357 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2358 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2359 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2360
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2361 ;;; These are the descriptions the user gets when non-regular objects
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2362 ;;; are examined.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2363
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2364 (setq dun-permobj-desc '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2365 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2366 "It is just a boulder. It cannot be moved."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2367 "They are palm trees with a bountiful supply of coconuts in them."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2368 "It looks like a grizzly to me."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2369 "All of the bins are empty. Looking closely you can see that there
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2370 are names written at the bottom of each bin, but most of them are
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2371 faded away so that you cannot read them. You can only make out three
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2372 names:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2373 Jeffrey Collier
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2374 Robert Toukmond
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2375 Thomas Stock
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2376 "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2377 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2378 "It is just a garbled mess."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2379 "The dial points to a temperature scale which has long since faded away."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2380 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2381 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2382 "It is a velvet painting of Elvis Presly. It seems to be nailed to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2383 wall, and you cannot move it."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2384 "It is a queen sized bed, with a very firm mattress."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2385 "The urinal is very clean compared with everything else in the cave. There
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2386 isn't even any rust. Upon close examination you realize that the drain at the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2387 bottom is missing, and there is just a large hole leading down the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2388 pipes into nowhere. The hole is too small for a person to fit in. The
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2389 flush handle is so clean that you can see your reflection in it."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2390 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2391 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2392 "The box has a slit in the top of it, and on it, in sloppy handwriting, is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2393 written: 'For key upgrade, put key in here.'"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2394 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2395 "It says 'express mail' on it."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2396 "It is a 35 passenger bus with the company name 'mobytours' on it."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2397 "It is a large metal gate that is too big to climb over."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2398 "It is a HIGH cliff."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2399 "Unfortunately you do not know enough about dinosaurs to tell very much about
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2400 it. It is very big, though."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2401 "The fish look like they were once quite beautiful."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2402 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2403 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2404 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2405 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2406 "It is a normal ladder that is permanently attached to the hole."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2407 "It is a passenger train that is ready to go."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2408 "It is a personal computer that has only one floppy disk drive."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2409 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2410 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2411
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2412 (setq dun-diggables
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2413 (list nil nil nil (list obj-cpu) nil nil nil nil nil nil nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2414 nil nil nil nil nil nil nil nil nil nil ;11-20
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2415 nil nil nil nil nil nil nil nil nil nil ;21-30
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2416 nil nil nil nil nil nil nil nil nil nil ;31-40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2417 nil (list obj-platinum) nil nil nil nil nil nil nil nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2418
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
2419 (setq scroll-step 2)
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
2420
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2421 (setq dun-room-shorts nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2422 (dolist (x dun-rooms)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2423 (setq dun-room-shorts
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2424 (append dun-room-shorts (list (downcase
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2425 (dun-space-to-hyphen
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2426 (cadr x)))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2427
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2428 (setq dun-endgame-questions '(
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2429 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2430 "What is your password on the machine called 'pokey'?" "robert")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2431 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2432 "What password did you use during anonymous ftp to gamma?" "foo")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2433 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2434 "Excluding the endgame, how many places are there where you can put
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2435 treasures for points?" "4" "four")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2436 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2437 "What is your login name on the 'endgame' machine?" "toukmond"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2438 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2439 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2440 "What is the nearest whole dollar to the price of the shovel?" "20" "twenty")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2441 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2442 "What is the name of the bus company serving the town?" "mobytours")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2443 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2444 "Give either of the two last names in the mailroom, other than your own."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2445 "collier" "stock")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2446 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2447 "What cartoon character is on the towel?" "snoopy")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2448 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2449 "What is the last name of the author of EMACS?" "stallman")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2450 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2451 "How many megabytes of memory is on the CPU board for the Vax?" "2")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2452 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2453 "Which street in town is named after a U.S. state?" "vermont")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2454 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2455 "How many pounds did the weight weigh?" "ten" "10")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2456 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2457 "Name the STREET which runs right over the subway stop." "fourth" "4" "4th")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2458 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2459 "How many corners are there in town (excluding the one with the Post Office)?"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2460 "24" "twentyfour" "twenty-four")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2461 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2462 "What type of bear was hiding your key?" "grizzly")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2463 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2464 "Name either of the two objects you found by digging." "cpu" "card" "vax"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2465 "board" "platinum")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2466 (
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2467 "What network protocol is used between pokey and gamma?" "tcp/ip" "ip" "tcp")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2468 ))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2469
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2470 (let (a)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2471 (setq a 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2472 (dolist (x dun-room-shorts)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2473 (eval (list 'defconst (intern x) a))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2474 (setq a (+ a 1))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2475
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2476
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2477
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2478 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2479 ;;;; This section defines the UNIX emulation functions for dunnet.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2480 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2481
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2482 (defun dun-unix-parse (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2483 (interactive "*p")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2484 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2485 (let (beg esign)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2486 (setq beg (+ (point) 2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2487 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2488 (if (and (not (= beg (point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2489 (string= "$" (buffer-substring (- beg 2) (- beg 1))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2490 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2491 (setq line (downcase (buffer-substring beg (point))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2492 (princ line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2493 (if (eq (dun-parse2 nil dun-unix-verbs line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2494 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2495 (if (setq esign (string-match "=" line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2496 (dun-doassign line esign)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2497 (dun-mprinc (car line-list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2498 (dun-mprincl ": not found.")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2499 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2500 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2501 (if (eq dungeon-mode 'unix)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2502 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2503 (dun-fix-screen)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2504 (dun-mprinc "$ ")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2505
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2506 (defun dun-doassign (line esign)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2507 (if (not dun-wizard)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2508 (let (passwd)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2509 (dun-mprinc "Enter wizard password: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2510 (setq passwd (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2511 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2512 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2513 (if (string= passwd "moby")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2514 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2515 (setq dun-wizard t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2516 (dun-doassign line esign))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2517 (dun-mprincl "Incorrect.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2518
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2519 (let (varname epoint afterq i value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2520 (setq varname (substring line 0 esign))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2521 (if (not (setq epoint (string-match ")" line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2522 (if (string= (substring line (1+ esign) (+ esign 2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2523 "\"")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2524 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2525 (setq afterq (substring line (+ esign 2)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2526 (setq epoint (+
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2527 (string-match "\"" afterq)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2528 (+ esign 3))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2529
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2530 (if (not (setq epoint (string-match " " line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2531 (setq epoint (length line))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2532 (setq epoint (1+ epoint))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2533 (while (and
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2534 (not (= epoint (length line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2535 (setq i (string-match ")" (substring line epoint))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2536 (setq epoint (+ epoint i 1))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2537 (setq value (substring line (1+ esign) epoint))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2538 (dun-eval varname value))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2539
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2540 (defun dun-eval (varname value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2541 (let (eval-error)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2542 (switch-to-buffer (get-buffer-create "*dungeon-eval*"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2543 (erase-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2544 (insert "(setq ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2545 (insert varname)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2546 (insert " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2547 (insert value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2548 (insert ")")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2549 (setq eval-error nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2550 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2551 (eval-current-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2552 (error (setq eval-error t)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2553 (kill-buffer (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2554 (switch-to-buffer "*dungeon*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2555 (if eval-error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2556 (dun-mprincl "Invalid syntax."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2557
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2558
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2559 (defun dun-unix-interface ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2560 (dun-login)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2561 (if dun-logged-in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2562 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2563 (setq dungeon-mode 'unix)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2564 (define-key dungeon-mode-map "\r" 'dun-unix-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2565 (dun-mprinc "$ "))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2566
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2567 (defun dun-login ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2568 (let (tries username password)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2569 (setq tries 4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2570 (while (and (not dun-logged-in) (> (setq tries (- tries 1)) 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2571 (dun-mprinc "\n\nUNIX System V, Release 2.2 (pokey)\n\nlogin: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2572 (setq username (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2573 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2574 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2575 (dun-mprinc "password: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2576 (setq password (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2577 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2578 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2579 (if (or (not (string= username "toukmond"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2580 (not (string= password "robert")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2581 (dun-mprincl "login incorrect")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2582 (setq dun-logged-in t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2583 (dun-mprincl "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2584 Welcome to Unix\n
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2585 Please clean up your directories. The filesystem is getting full.
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
2586 Our tcp/ip link to gamma is a little flakey, but seems to work.
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2587 The current version of ftp can only send files from the current
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2588 directory, and deletes them after they are sent! Be careful.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2589
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2590 Note: Restricted bourne shell in use.\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2591 (setq dungeon-mode 'dungeon)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2592
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2593 (defun dun-ls (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2594 (if (car args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2595 (let (ocdpath ocdroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2596 (setq ocdpath dun-cdpath)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2597 (setq ocdroom dun-cdroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2598 (if (not (eq (dun-cd args) -2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2599 (dun-ls nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2600 (setq dun-cdpath ocdpath)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2601 (setq dun-cdroom ocdroom))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2602 (if (= dun-cdroom -10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2603 (dun-ls-inven))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2604 (if (= dun-cdroom -2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2605 (dun-ls-rooms))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2606 (if (= dun-cdroom -3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2607 (dun-ls-root))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2608 (if (= dun-cdroom -4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2609 (dun-ls-usr))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2610 (if (> dun-cdroom 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2611 (dun-ls-room))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2612
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2613 (defun dun-ls-root ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2614 (dun-mprincl "total 4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2615 drwxr-xr-x 3 root staff 512 Jan 1 1970 .
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2616 drwxr-xr-x 3 root staff 2048 Jan 1 1970 ..
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2617 drwxr-xr-x 3 root staff 2048 Jan 1 1970 usr
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2618 drwxr-xr-x 3 root staff 2048 Jan 1 1970 rooms"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2619
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2620 (defun dun-ls-usr ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2621 (dun-mprincl "total 4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2622 drwxr-xr-x 3 root staff 512 Jan 1 1970 .
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2623 drwxr-xr-x 3 root staff 2048 Jan 1 1970 ..
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2624 drwxr-xr-x 3 toukmond restricted 512 Jan 1 1970 toukmond"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2625
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2626 (defun dun-ls-rooms ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2627 (dun-mprincl "total 16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2628 drwxr-xr-x 3 root staff 512 Jan 1 1970 .
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2629 drwxr-xr-x 3 root staff 2048 Jan 1 1970 ..")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2630 (dolist (x dun-visited)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2631 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2632 "drwxr-xr-x 3 root staff 512 Jan 1 1970 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2633 (dun-mprincl (nth x dun-room-shorts))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2634
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2635 (defun dun-ls-room ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2636 (dun-mprincl "total 4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2637 drwxr-xr-x 3 root staff 512 Jan 1 1970 .
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2638 drwxr-xr-x 3 root staff 2048 Jan 1 1970 ..
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2639 -rwxr-xr-x 3 root staff 2048 Jan 1 1970 description")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2640 (dolist (x (nth dun-cdroom dun-room-objects))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2641 (if (and (>= x 0) (not (= x 255)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2642 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2643 (dun-mprinc "-rwxr-xr-x 1 toukmond restricted 0 Jan 1 1970 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2644 (dun-mprincl (nth x dun-objfiles))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2645
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2646 (defun dun-ls-inven ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2647 (dun-mprinc "total 467
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2648 drwxr-xr-x 3 toukmond restricted 512 Jan 1 1970 .
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2649 drwxr-xr-x 3 root staff 2048 Jan 1 1970 ..")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2650 (dolist (x dun-unix-verbs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2651 (if (not (eq (car x) 'IMPOSSIBLE))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2652 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2653 (dun-mprinc"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2654 -rwxr-xr-x 1 toukmond restricted 10423 Jan 1 1970 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2655 (dun-mprinc (car x)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2656 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2657 (if (not dun-uncompressed)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2658 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2659 "-rwxr-xr-x 1 toukmond restricted 0 Jan 1 1970 paper.o.Z"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2660 (dolist (x dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2661 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2662 "-rwxr-xr-x 1 toukmond restricted 0 Jan 1 1970 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2663 (dun-mprincl (nth x dun-objfiles))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2664
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2665 (defun dun-echo (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2666 (let (nomore var)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2667 (setq nomore nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2668 (dolist (x args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2669 (if (not nomore)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2670 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2671 (if (not (string= (substring x 0 1) "$"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2672 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2673 (dun-mprinc x)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2674 (dun-mprinc " "))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2675 (setq var (intern (substring x 1)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2676 (if (not (boundp var))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2677 (dun-mprinc " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2678 (if (member var dun-restricted)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2679 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2680 (dun-mprinc var)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2681 (dun-mprinc ": Permission denied")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2682 (setq nomore t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2683 (eval (list 'dun-mprinc var))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2684 (dun-mprinc " ")))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2685 (dun-mprinc "\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2686
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2687
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2688 (defun dun-ftp (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2689 (let (host username passwd ident newlist)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2690 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2691 (dun-mprincl "ftp: hostname required on command line.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2692 (setq host (intern (car args)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2693 (if (not (member host '(gamma dun-endgame)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2694 (dun-mprincl "ftp: Unknown host.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2695 (if (eq host 'dun-endgame)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2696 (dun-mprincl "ftp: connection to endgame not allowed")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2697 (if (not dun-ethernet)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2698 (dun-mprincl "ftp: host not responding.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2699 (dun-mprincl "Connected to gamma. FTP ver 0.9 00:00:00 01/01/70")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2700 (dun-mprinc "Username: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2701 (setq username (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2702 (if (string= username "toukmond")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2703 (if dun-batch-mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2704 (dun-mprincl "toukmond ftp access not allowed.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2705 (dun-mprincl "\ntoukmond ftp access not allowed."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2706 (if (string= username "anonymous")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2707 (if dun-batch-mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2708 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2709 "Guest login okay, send your user ident as password.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2710 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2711 "\nGuest login okay, send your user ident as password."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2712 (if dun-batch-mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2713 (dun-mprinc "Password required for ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2714 (dun-mprinc "\nPassword required for "))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2715 (dun-mprincl username))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2716 (dun-mprinc "Password: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2717 (setq ident (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2718 (if (not (string= username "anonymous"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2719 (if dun-batch-mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2720 (dun-mprincl "Login failed.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2721 (dun-mprincl "\nLogin failed."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2722 (if dun-batch-mode
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2723 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2724 "Guest login okay, user access restrictions apply.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2725 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2726 "\nGuest login okay, user access restrictions apply."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2727 (dun-ftp-commands)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2728 (setq newlist
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2729 '("What password did you use during anonymous ftp to gamma?"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2730 (setq newlist (append newlist (list ident)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2731 (rplaca (nthcdr 1 dun-endgame-questions) newlist)))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2732
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2733 (defun dun-ftp-commands ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2734 (setq dun-exitf nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2735 (let (line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2736 (while (not dun-exitf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2737 (dun-mprinc "ftp> ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2738 (setq line (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2739 (if
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2740 (eq
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2741 (dun-parse2 nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2742 '((type . dun-ftptype) (binary . dun-bin) (bin . dun-bin)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2743 (send . dun-send) (put . dun-send) (quit . dun-ftpquit)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2744 (help . dun-ftphelp)(ascii . dun-fascii)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2745 ) line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2746 -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2747 (dun-mprincl "No such command. Try help.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2748 (setq dun-ftptype 'ascii)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2749
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2750 (defun dun-ftptype (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2751 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2752 (dun-mprincl "Usage: type [binary | ascii]")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2753 (setq args (intern (car args)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2754 (if (eq args 'binary)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2755 (dun-bin nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2756 (if (eq args 'ascii)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2757 (dun-fascii 'nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2758 (dun-mprincl "Unknown type.")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2759
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2760 (defun dun-bin (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2761 (dun-mprincl "Type set to binary.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2762 (setq dun-ftptype 'binary))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2763
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2764 (defun dun-fascii (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2765 (dun-mprincl "Type set to ascii.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2766 (setq dun-ftptype 'ascii))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2767
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2768 (defun dun-ftpquit (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2769 (setq dun-exitf t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2770
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2771 (defun dun-send (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2772 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2773 (dun-mprincl "Usage: send <filename>")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2774 (setq args (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2775 (let (counter foo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2776 (setq foo nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2777 (setq counter 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2778
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2779 ;;; User can send commands! Stupid user.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2780
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2781
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2782 (if (assq (intern args) dun-unix-verbs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2783 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2784 (rplaca (assq (intern args) dun-unix-verbs) 'IMPOSSIBLE)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2785 (dun-mprinc "Sending ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2786 (dun-mprinc dun-ftptype)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2787 (dun-mprinc " file for ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2788 (dun-mprincl args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2789 (dun-mprincl "Transfer complete."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2790
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2791 (dolist (x dun-objfiles)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2792 (if (string= args x)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2793 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2794 (if (not (member counter dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2795 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2796 (dun-mprincl "No such file.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2797 (setq foo t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2798 (dun-mprinc "Sending ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2799 (dun-mprinc dun-ftptype)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2800 (dun-mprinc " file for ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2801 (dun-mprinc (downcase (cadr (nth counter dun-objects))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2802 (dun-mprincl ", (0 bytes)")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2803 (if (not (eq dun-ftptype 'binary))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2804 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2805 (if (not (member obj-protoplasm
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2806 (nth receiving-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2807 dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2808 (dun-replace dun-room-objects receiving-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2809 (append (nth receiving-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2810 dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2811 (list obj-protoplasm))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2812 (dun-remove-obj-from-inven counter))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2813 (dun-remove-obj-from-inven counter)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2814 (dun-replace dun-room-objects receiving-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2815 (append (nth receiving-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2816 (list counter))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2817 (setq foo t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2818 (dun-mprincl "Transfer complete."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2819 (setq counter (+ 1 counter)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2820 (if (not foo)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2821 (dun-mprincl "No such file."))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2822
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2823 (defun dun-ftphelp (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2824 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2825 "Possible commands are:\nsend quit type ascii binary help"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2826
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2827 (defun dun-uexit (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2828 (setq dungeon-mode 'dungeon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2829 (dun-mprincl "\nYou step back from the console.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2830 (define-key dungeon-mode-map "\r" 'dun-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2831 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2832 (dun-messages)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2833
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2834 (defun dun-pwd (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2835 (dun-mprincl dun-cdpath))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2836
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2837 (defun dun-uncompress (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2838 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2839 (dun-mprincl "Usage: uncompress <filename>")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2840 (setq args (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2841 (if (or dun-uncompressed
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2842 (and (not (string= args "paper.o"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2843 (not (string= args "paper.o.z"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2844 (dun-mprincl "Uncompress command failed.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2845 (setq dun-uncompressed t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2846 (setq dun-inventory (append dun-inventory (list obj-paper))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2847
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2848 (defun dun-rlogin (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2849 (let (passwd)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2850 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2851 (dun-mprincl "Usage: rlogin <hostname>")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2852 (setq args (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2853 (if (string= args "endgame")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2854 (dun-rlogin-endgame)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2855 (if (not (string= args "gamma"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2856 (dun-mprincl "No such host.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2857 (if (not dun-ethernet)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2858 (dun-mprincl "Host not responding.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2859 (dun-mprinc "Password: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2860 (setq passwd (dun-read-line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2861 (if (not (string= passwd "worms"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2862 (dun-mprincl "\nlogin incorrect")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2863 (dun-mprinc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2864 "\nYou begin to feel strange for a moment, and you lose your items."
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2865 )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2866 (dun-replace dun-room-objects computer-room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2867 (append (nth computer-room dun-room-objects)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2868 dun-inventory))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2869 (setq dun-inventory nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2870 (setq dun-current-room receiving-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2871 (dun-uexit nil))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2872
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2873 (defun dun-cd (args)
70
131b0175ea99 Import from CVS: tag r20-0b30
cvs
parents: 4
diff changeset
2874 (let (tcdpath tcdroom path-elemants room-check)
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2875 (if (not (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2876 (dun-mprincl "Usage: cd <path>")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2877 (setq tcdpath dun-cdpath)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2878 (setq tcdroom dun-cdroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2879 (setq dun-badcd nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2880 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2881 (setq path-elements (dun-get-path (car args) nil))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2882 (error (dun-mprincl "Invalid path.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2883 (setq dun-badcd t)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2884 (dolist (pe path-elements)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2885 (unless dun-badcd
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2886 (if (not (string= pe "."))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2887 (if (string= pe "..")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2888 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2889 (if (> tcdroom 0) ;In a room
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2890 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2891 (setq tcdpath "/rooms")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2892 (setq tcdroom -2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2893 ;In /rooms,/usr,root
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2894 (if (or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2895 (= tcdroom -2) (= tcdroom -4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2896 (= tcdroom -3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2897 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2898 (setq tcdpath "/")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2899 (setq tcdroom -3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2900 (if (= tcdroom -10) ;In /usr/toukmond
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2901 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2902 (setq tcdpath "/usr")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2903 (setq tcdroom -4))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2904 (if (string= pe "/")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2905 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2906 (setq tcdpath "/")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2907 (setq tcdroom -3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2908 (if (= tcdroom -4)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2909 (if (string= pe "toukmond")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2910 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2911 (setq tcdpath "/usr/toukmond")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2912 (setq tcdroom -10))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2913 (dun-nosuchdir))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2914 (if (= tcdroom -10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2915 (dun-nosuchdir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2916 (if (> tcdroom 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2917 (dun-nosuchdir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2918 (if (= tcdroom -3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2919 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2920 (if (string= pe "rooms")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2921 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2922 (setq tcdpath "/rooms")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2923 (setq tcdroom -2))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2924 (if (string= pe "usr")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2925 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2926 (setq tcdpath "/usr")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2927 (setq tcdroom -4))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2928 (dun-nosuchdir))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2929 (if (= tcdroom -2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2930 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2931 (dolist (x dun-visited)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2932 (setq room-check
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2933 (nth x
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2934 dun-room-shorts))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2935 (if (string= room-check pe)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2936 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2937 (setq tcdpath
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2938 (concat "/rooms/" room-check))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2939 (setq tcdroom x))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2940 (if (= tcdroom -2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2941 (dun-nosuchdir)))))))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2942 (if (not dun-badcd)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2943 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2944 (setq dun-cdpath tcdpath)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2945 (setq dun-cdroom tcdroom)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2946 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2947 -2))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2948
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2949 (defun dun-nosuchdir ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2950 (dun-mprincl "No such directory.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2951 (setq dun-badcd t))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2952
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2953 (defun dun-cat (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2954 (let (doto checklist)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2955 (if (not (setq args (car args)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2956 (dun-mprincl "Usage: cat <ascii-file-name>")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2957 (if (string-match "/" args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2958 (dun-mprincl "cat: only files in current directory allowed.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2959 (if (and (> dun-cdroom 0) (string= args "description"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2960 (dun-mprincl (car (nth dun-cdroom dun-rooms)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2961 (if (setq doto (string-match "\\.o" args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2962 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2963 (if (= dun-cdroom -10)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2964 (setq checklist dun-inventory)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2965 (setq checklist (nth dun-cdroom dun-room-objects)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2966 (if (not (member (cdr
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2967 (assq (intern
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2968 (substring args 0 doto))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2969 dun-objnames))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2970 checklist))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2971 (dun-mprincl "File not found.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2972 (dun-mprincl "Ascii files only.")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2973 (if (assq (intern args) dun-unix-verbs)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2974 (dun-mprincl "Ascii files only.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2975 (dun-mprincl "File not found."))))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2976
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2977 (defun dun-zippy (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2978 (dun-mprincl (yow)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2979
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2980 (defun dun-rlogin-endgame ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2981 (if (not (= (dun-score nil) 90))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2982 (dun-mprincl
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2983 "You have not achieved enough points to connect to endgame.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2984 (dun-mprincl"\nWelcome to the endgame. You are a truly noble adventurer.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2985 (setq dun-current-room treasure-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2986 (setq dun-endgame t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2987 (dun-replace dun-room-objects endgame-treasure-room (list obj-bill))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2988 (dun-uexit nil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2989
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2990
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2991 (random t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2992 (setq tloc (+ 60 (random 18)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2993 (dun-replace dun-room-objects tloc
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2994 (append (nth tloc dun-room-objects) (list 18)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2995
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2996 (setq tcomb (+ 100 (random 899)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2997 (setq dun-combination (prin1-to-string tcomb))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2998
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2999 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3000 ;;;; This section defines the DOS emulation functions for dunnet
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3001 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3002
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3003 (defun dun-dos-parse (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3004 (interactive "*p")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3005 (beginning-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3006 (let (beg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3007 (setq beg (+ (point) 3))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3008 (end-of-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3009 (if (not (= beg (point)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3010 (let (line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3011 (setq line (downcase (buffer-substring beg (point))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3012 (princ line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3013 (if (eq (dun-parse2 nil dun-dos-verbs line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3014 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3015 (sleep-for 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3016 (dun-mprincl "Bad command or file name"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3017 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3018 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3019 (if (eq dungeon-mode 'dos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3020 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3021 (dun-fix-screen)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3022 (dun-dos-prompt)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3023
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3024 (defun dun-dos-interface ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3025 (dun-dos-boot-msg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3026 (setq dungeon-mode 'dos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3027 (define-key dungeon-mode-map "\r" 'dun-dos-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3028 (dun-dos-prompt))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3029
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3030 (defun dun-dos-type (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3031 (sleep-for 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3032 (if (setq args (car args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3033 (if (string= args "foo.txt")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3034 (dun-dos-show-combination)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3035 (if (string= args "command.com")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3036 (dun-mprincl "Cannot type binary files")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3037 (dun-mprinc "File not found - ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3038 (dun-mprincl (upcase args))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3039 (dun-mprincl "Must supply file name")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3040
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3041 (defun dun-dos-invd (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3042 (sleep-for 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3043 (dun-mprincl "Invalid drive specification"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3044
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3045 (defun dun-dos-dir (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3046 (sleep-for 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3047 (if (or (not (setq args (car args))) (string= args "\\"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3048 (dun-mprincl "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3049 Volume in drive A is FOO
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3050 Volume Serial Number is 1A16-08C9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3051 Directory of A:\\
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3052
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3053 COMMAND COM 47845 04-09-91 2:00a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3054 FOO TXT 40 01-20-93 1:01a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3055 2 file(s) 47845 bytes
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3056 1065280 bytes free
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3057 ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3058 (dun-mprincl "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3059 Volume in drive A is FOO
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3060 Volume Serial Number is 1A16-08C9
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3061 Directory of A:\\
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3062
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3063 File not found")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3064
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3065
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3066 (defun dun-dos-prompt ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3067 (dun-mprinc "A> "))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3068
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3069 (defun dun-dos-boot-msg ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3070 (sleep-for 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3071 (dun-mprinc "Current time is ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3072 (dun-mprincl (substring (current-time-string) 12 20))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3073 (dun-mprinc "Enter new time: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3074 (dun-read-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3075 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3076 (dun-mprinc "\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3077
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3078 (defun dun-dos-spawn (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3079 (sleep-for 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3080 (dun-mprincl "Cannot spawn subshell"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3081
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3082 (defun dun-dos-exit (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3083 (setq dungeon-mode 'dungeon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3084 (dun-mprincl "\nYou power down the machine and step back.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3085 (define-key dungeon-mode-map "\r" 'dun-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3086 (if (not dun-batch-mode)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3087 (dun-messages)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3088
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3089 (defun dun-dos-no-disk ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3090 (sleep-for 3)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3091 (dun-mprincl "Boot sector not found"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3092
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3093
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3094 (defun dun-dos-show-combination ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3095 (sleep-for 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3096 (dun-mprinc "\nThe combination is ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3097 (dun-mprinc dun-combination)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3098 (dun-mprinc ".\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3099
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3100 (defun dun-dos-nil (args))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3101
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3102
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3103 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3104 ;;;; This section defines the save and restore game functions for dunnet.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3105 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3106
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3107 (defun dun-save-game (filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3108 (if (not (setq filename (car filename)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3109 (dun-mprincl "You must supply a filename for the save.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3110 (if (file-exists-p filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3111 (delete-file filename))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3112 (setq dun-numsaves (1+ dun-numsaves))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3113 (dun-make-save-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3114 (dun-save-val "dun-current-room")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3115 (dun-save-val "dun-computer")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3116 (dun-save-val "dun-combination")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3117 (dun-save-val "dun-visited")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3118 (dun-save-val "dun-diggables")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3119 (dun-save-val "dun-key-level")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3120 (dun-save-val "dun-floppy")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3121 (dun-save-val "dun-numsaves")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3122 (dun-save-val "dun-numcmds")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3123 (dun-save-val "dun-logged-in")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3124 (dun-save-val "dungeon-mode")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3125 (dun-save-val "dun-jar")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3126 (dun-save-val "dun-lastdir")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3127 (dun-save-val "dun-black")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3128 (dun-save-val "dun-nomail")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3129 (dun-save-val "dun-unix-verbs")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3130 (dun-save-val "dun-hole")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3131 (dun-save-val "dun-uncompressed")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3132 (dun-save-val "dun-ethernet")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3133 (dun-save-val "dun-sauna-level")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3134 (dun-save-val "dun-room-objects")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3135 (dun-save-val "dun-room-silents")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3136 (dun-save-val "dun-inventory")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3137 (dun-save-val "dun-endgame-questions")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3138 (dun-save-val "dun-endgame")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3139 (dun-save-val "dun-cdroom")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3140 (dun-save-val "dun-cdpath")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3141 (dun-save-val "dun-correct-answer")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3142 (dun-save-val "dun-inbus")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3143 (if (dun-compile-save-out filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3144 (dun-mprincl "Error saving to file.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3145 (dun-do-logfile 'save nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3146 (switch-to-buffer "*dungeon*")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3147 (princ "")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3148 (dun-mprincl "Done."))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3149
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3150 (defun dun-make-save-buffer ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3151 (switch-to-buffer (get-buffer-create "*save-dungeon*"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3152 (erase-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3153
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3154 (defun dun-compile-save-out (filename)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3155 (let (ferror)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3156 (setq ferror nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3157 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3158 (dun-rot13)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3159 (error (setq ferror t)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3160 (if (not ferror)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3161 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3162 (goto-char (point-min))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3163 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3164 (write-region 1 (point-max) filename nil 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3165 (error (setq ferror t)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3166 (kill-buffer (current-buffer))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3167 ferror))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3168
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3169
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3170 (defun dun-save-val (varname)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3171 (let (value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3172 (setq varname (intern varname))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3173 (setq value (eval varname))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3174 (dun-minsert "(setq ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3175 (dun-minsert varname)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3176 (dun-minsert " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3177 (if (or (listp value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3178 (symbolp value))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3179 (dun-minsert "'"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3180 (if (stringp value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3181 (dun-minsert "\""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3182 (dun-minsert value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3183 (if (stringp value)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3184 (dun-minsert "\""))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3185 (dun-minsertl ")")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3186
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3187
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3188 (defun dun-restore (args)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3189 (let (file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3190 (if (not (setq file (car args)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3191 (dun-mprincl "You must supply a filename.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3192 (if (not (dun-load-d file))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3193 (dun-mprincl "Could not load restore file.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3194 (dun-mprincl "Done.")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3195 (setq room 0)))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3196
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3197
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3198 (defun dun-do-logfile (type how)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3199 (let (ferror newscore)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3200 (setq ferror nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3201 (switch-to-buffer (get-buffer-create "*score*"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3202 (erase-buffer)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3203 (condition-case nil
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3204 (insert-file-contents dun-log-file)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3205 (error (setq ferror t)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3206 (unless ferror
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3207 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3208 (dun-minsert (current-time-string))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3209 (dun-minsert " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3210 (dun-minsert (user-login-name))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3211 (dun-minsert " ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3212 (if (eq type 'save)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3213 (dun-minsert "saved ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3214 (if (= (dun-endgame-score) 110)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3215 (dun-minsert "won ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3216 (if (not how)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3217 (dun-minsert "quit ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3218 (dun-minsert "killed by ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3219 (dun-minsert how)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3220 (dun-minsert " "))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3221 (dun-minsert "at ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3222 (dun-minsert (cadr (nth (abs room) dun-rooms)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3223 (dun-minsert ". score: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3224 (if (> (dun-endgame-score) 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3225 (dun-minsert (setq newscore (+ 90 (dun-endgame-score))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3226 (dun-minsert (setq newscore (dun-reg-score))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3227 (dun-minsert " saves: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3228 (dun-minsert dun-numsaves)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3229 (dun-minsert " commands: ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3230 (dun-minsert dun-numcmds)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3231 (dun-minsert "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3232 (write-region 1 (point-max) dun-log-file nil 1))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3233 (kill-buffer (current-buffer))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3234
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3235
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3236 ;;;;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3237 ;;;; These are functions, and function re-definitions so that dungeon can
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3238 ;;;; be run in batch mode.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3239
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3240
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3241 (defun dun-batch-mprinc (arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3242 (if (stringp arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3243 (send-string-to-terminal arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3244 (send-string-to-terminal (prin1-to-string arg))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3245
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3246
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3247 (defun dun-batch-mprincl (arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3248 (if (stringp arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3249 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3250 (send-string-to-terminal arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3251 (send-string-to-terminal "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3252 (send-string-to-terminal (prin1-to-string arg))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3253 (send-string-to-terminal "\n")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3254
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3255 (defun dun-batch-parse (dun-ignore dun-verblist line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3256 (setq line-list (dun-listify-string (concat line " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3257 (dun-doverb dun-ignore dun-verblist (car line-list) (cdr line-list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3258
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3259 (defun dun-batch-parse2 (dun-ignore dun-verblist line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3260 (setq line-list (dun-listify-string2 (concat line " ")))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3261 (dun-doverb dun-ignore dun-verblist (car line-list) (cdr line-list)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3262
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3263 (defun dun-batch-read-line ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3264 (read-from-minibuffer "" nil dungeon-batch-map))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3265
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3266
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3267 (defun dun-batch-loop ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3268 (setq dun-dead nil)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3269 (setq room 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3270 (while (not dun-dead)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3271 (if (eq dungeon-mode 'dungeon)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3272 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3273 (if (not (= room dun-current-room))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3274 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3275 (dun-describe-room dun-current-room)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3276 (setq room dun-current-room)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3277 (dun-mprinc ">")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3278 (setq line (downcase (dun-read-line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3279 (if (eq (dun-vparse dun-ignore dun-verblist line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3280 (dun-mprinc "I don't understand that.\n"))))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3281
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3282 (defun dun-batch-dos-interface ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3283 (dun-dos-boot-msg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3284 (setq dungeon-mode 'dos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3285 (while (eq dungeon-mode 'dos)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3286 (dun-dos-prompt)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3287 (setq line (downcase (dun-read-line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3288 (if (eq (dun-parse2 nil dun-dos-verbs line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3289 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3290 (sleep-for 1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3291 (dun-mprincl "Bad command or file name"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3292 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3293 (dun-mprinc "\n"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3294
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3295 (defun dun-batch-unix-interface ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3296 (dun-login)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3297 (if dun-logged-in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3298 (progn
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3299 (setq dungeon-mode 'unix)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3300 (while (eq dungeon-mode 'unix)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3301 (dun-mprinc "$ ")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3302 (setq line (downcase (dun-read-line)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3303 (if (eq (dun-parse2 nil dun-unix-verbs line) -1)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3304 (let (esign)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3305 (if (setq esign (string-match "=" line))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3306 (dun-doassign line esign)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3307 (dun-mprinc (car line-list))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3308 (dun-mprincl ": not found.")))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3309 (goto-char (point-max))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3310 (dun-mprinc "\n"))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3311
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3312 (defun dungeon-nil (arg)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3313 "noop"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3314 (interactive "*p"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3315
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3316 (defun dun-batch-dungeon ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3317 (load "dun-batch")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3318 (setq dun-visited '(27))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3319 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3320 (dun-batch-loop))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3321
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3322 (unless (not noninteractive)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3323 (fset 'dun-mprinc 'dun-batch-mprinc)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3324 (fset 'dun-mprincl 'dun-batch-mprincl)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3325 (fset 'dun-vparse 'dun-batch-parse)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3326 (fset 'dun-parse2 'dun-batch-parse2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3327 (fset 'dun-read-line 'dun-batch-read-line)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3328 (fset 'dun-dos-interface 'dun-batch-dos-interface)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3329 (fset 'dun-unix-interface 'dun-batch-unix-interface)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3330 (dun-mprinc "\n")
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3331 (setq dun-batch-mode t)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3332 (dun-batch-loop))