annotate lisp/games/dunnet.el @ 0:376386a54a3c r19-14

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