blob: 1af152055691d1dde798db946089ab4041173476 [file] [log] [blame]
MG Mud User88f12472016-06-24 23:31:02 +02001// MorgenGrauen MUDlib
2//
3// room/description.c -- room description handling
4//
5// $Id: description.c 9468 2016-02-19 21:07:04Z Gloinson $
6
7#pragma strong_types
8#pragma save_types
9#pragma pedantic
10#pragma range_check
11#pragma no_clone
12
13inherit "/std/container/description";
14
15#define NEED_PROTOTYPES
16
17#include <properties.h>
18#include <defines.h>
19#include <wizlevels.h>
20#include <language.h>
21#include <doorroom.h>
22
23void create()
24{
25 ::create();
26 SetProp(P_NAME, "Raum");
27 SetProp(P_INT_SHORT,"<namenloser Raum>");
28 SetProp(P_INT_LONG,0);
29 SetProp(P_ROOM_MSG, ({}) );
30 SetProp(P_FUNC_MSG, 0);
31 SetProp(P_MSG_PROB, 30);
32 AddId(({"raum", "hier"}));
33}
34
35void init()
36{
37 // Wenn P_ROOM_MSG gesetzt oder P_FUNC_MSG und kein Callout laeuft,
38 // Callout starten.
39 mixed roommsg = QueryProp(P_ROOM_MSG);
40 if( ( (roommsg && sizeof(roommsg)) ||
41 QueryProp(P_FUNC_MSG) ) &&
42 (find_call_out("WriteRoomMessage")==-1))
43 call_out("WriteRoomMessage", random(QueryProp(P_MSG_PROB)));
44}
45
46varargs void AddRoomMessage(string *mesg, int prob, mixed func)
47{
48 if (mesg && !pointerp(mesg))
49 raise_error(sprintf(
50 "AddRoomMessage(): wrong argument type, expected Array or 0, "
51 "got %.20O",mesg));
52
53 SetProp(P_ROOM_MSG, mesg);
54
55 if (prob>0)
56 SetProp(P_MSG_PROB, prob);
57
58 if (func)
59 SetProp(P_FUNC_MSG, func);
60}
61
62static void WriteRoomMessage()
63{
64 int tim, msgid;
65 string *room_msg,func;
66 mixed *func_msg;
67
68 room_msg = (string *)QueryProp(P_ROOM_MSG);
69 func_msg = QueryProp(P_FUNC_MSG);
70 if ((!room_msg || !sizeof(room_msg)) && !func_msg)
71 return;
72
73 if (room_msg&&sizeof(room_msg))
74 {
75 msgid = random(sizeof(room_msg));
76 // Defaultwerte sind fuer Altcode schwierig
77 send_room(this_object(), room_msg[msgid],
78 MT_LOOK|MT_LISTEN|MT_FEEL|MT_SMELL|
79 MSG_DONT_STORE|MSG_DONT_BUFFER|MSG_DONT_WRAP);
80 }
81
82 if (func_msg)
83 {
84 if (stringp(func_msg))
85 func=(string)func_msg;
86 else
87 func=func_msg[random(sizeof(func_msg))];
88 if (func && function_exists(func))
89 call_other (this_object(), func, msgid);
90 }
91
92 while (remove_call_out("WriteRoomMessage")!=-1);
93 tim=QueryProp(P_MSG_PROB);
94 if(this_object() && sizeof(filter(
95 deep_inventory(this_object()), #'interactive))) //')))
96 call_out("WriteRoomMessage", (tim<15 ? 15 : tim));
97}
98
99varargs string int_long(mixed viewer,mixed viewpoint,int flags)
100{
101 string descr, inv_descr;
102
103 flags &= 3;
104 if( IS_LEARNER(viewer) && viewer->QueryProp( P_WANTS_TO_LEARN ) )
105 descr = "[" + object_name(ME) + "]\n";
106 else
107 descr = "";
108
109 descr += process_string(QueryProp(P_INT_LONG)||"");
110
111 // ggf. Tueren hinzufuegen.
112 if (QueryProp(P_DOOR_INFOS)) {
113 string tmp=((string)call_other(DOOR_MASTER,"look_doors"));
114 if (stringp(tmp) && sizeof(tmp))
115 descr += tmp;
116 }
117
118 // ggf. Ausgaenge hinzufuegen.
119 if ( viewer->QueryProp(P_SHOW_EXITS) && (!QueryProp(P_HIDE_EXITS)
120 || pointerp(QueryProp(P_HIDE_EXITS))) )
121 descr += GetExits(viewer) || "";
122
123 // Viewpoint (Objekt oder Objektarray) sind nicht sichtbar
124 inv_descr = (string) make_invlist(viewer, all_inventory(ME)
125 - (pointerp(viewpoint)?viewpoint:({viewpoint})) ,flags);
126
127 if ( inv_descr != "" )
128 descr += inv_descr;
129
130 if(environment() && (inv_descr=QueryProp(P_TRANSPARENT)))
131 {
132 if(stringp(inv_descr)) descr += inv_descr;
133 else descr += "Ausserhalb siehst Du:\n";
134
135 descr += environment()->int_short(viewer,ME);
136 }
137
138 return descr;
139}
140
141string int_short(mixed viewer,mixed viewpoint)
142{
143 string descr, inv_descr;
144
145 descr = process_string( QueryProp(P_INT_SHORT)||"");
Bugfixd6cd2e52017-02-27 18:23:42 +0100146
147 // Ist das letzte Zeichen kein Satzzeichen einen Punkt anhaengen, sonst nur
148 // den \n.
149 int i=descr[<1];
150 if(i!='.' && i!='!' && i!='?')
151 descr+=".\n";
MG Mud User88f12472016-06-24 23:31:02 +0200152 else
Bugfixd6cd2e52017-02-27 18:23:42 +0100153 descr+="\n";
154
155 // Aber ggf. den Pfad fuer Magier vor dem \n einfuegen.
156 if(IS_LEARNING(viewer))
157 descr[<1..<2]=" [" + object_name(ME) + "]";
MG Mud User88f12472016-06-24 23:31:02 +0200158
159 if ( ( viewer->QueryProp(P_SHOW_EXITS)
160 || ( environment(viewer) == ME && !viewer->QueryProp(P_BRIEF) ) )
161 && (!QueryProp(P_HIDE_EXITS) || pointerp(QueryProp(P_HIDE_EXITS))) )
162 descr += GetExits(viewer) || "";
Bugfixd6cd2e52017-02-27 18:23:42 +0100163
MG Mud User88f12472016-06-24 23:31:02 +0200164 // Viewpoint (Objekt oder Objektarray) sind nicht sichtbar
165 inv_descr = (string) make_invlist( viewer, all_inventory(ME)
166 - (pointerp(viewpoint)?viewpoint:({viewpoint})) );
167
168 if ( inv_descr != "" )
169 descr += inv_descr;
170
171 return descr;
172}
173
174/** Roommessages abschalten, wenn keine Interactives mehr da sind.
175 */
176// TODO: Irgendwann das varargs loswerden, wenn in der restlichen Mudlib
177// TODO::exit() 'richtig' ueberschrieben wird.
178varargs void exit(object liv, object dest) {
179 // fall erbende Objekte das liv nicht uebergeben. Pruefung nur auf
180 // previous_object(). Wenn Magier da noch irgendwelche Spielchen mit
181 // call_other() & Co treiben, haben wir Pech gehabt, macht aber nicht viel,
182 // weil die Raummeldungen dann im naechsten callout abgeschaltet werden.
183 if (!living(liv=previous_object())) return;
184
185 object *interactives = filter(all_inventory(), #'interactive);
186 // liv wurde noch nicht bewegt, ggf. beruecksichtigen.
187 if ( !sizeof(interactives) ||
188 (interactive(liv) && sizeof(interactives) < 2) )
189 while (remove_call_out("WriteRoomMessage")!=-1);
190}
191
192static string _query_int_long() {return Query(P_INT_LONG, F_VALUE);}
193
194
195// Querymethode fuer P_DOMAIN - gibt die Region an, in der Raum liegt, sofern
196// er unter /d/ liegt...
197static string _query_lib_p_domain()
198{
199 string fn = object_name();
200 if (strstr(fn, "/d/") == 0)
201 {
202 return capitalize(explode(fn, "/")[2]);
203 }
204
205 return "unbekannt";
206}
207
208<string|string*>* _set_harbour_name( <string|string*>* desc)
209{
210 if ( sizeof(desc)!=2 )
211 {
212 raise_error(sprintf("Unacceptable data in P_HARBOUR, sizeof() was %d, "
213 "expected 2.", sizeof(desc)));
214 }
215 else if ( !stringp(desc[0]) )
216 {
217 raise_error("Wrong data type in P_HARBOUR[0]: expected 'string'.");
218 }
219 else if ( pointerp(desc[1]) && sizeof(desc[1])<1 )
220 {
221 raise_error("Insufficient data in P_HARBOUR[1]: expected 'string*', "
222 "got '({})'.");
223 }
224 else if ( stringp(desc[1]) )
225 {
226 desc[1] = ({desc[1]});
227 }
228 return Set(P_HARBOUR, desc, F_VALUE);
229}
230