Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 1 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 2 | AddInfo() |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 3 | ********* |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 4 | |
| 5 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 6 | FUNKTION |
| 7 | ======== |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 8 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 9 | varargs void AddInfo( frage, meldung |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 10 | [, indent [, [silent [, casebased] ] ] ); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 11 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 12 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 13 | DEFINIERT IN |
| 14 | ============ |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 15 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 16 | /std/npc/info.c |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 17 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 18 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 19 | ARGUMENTE |
| 20 | ========= |
| 21 | |
| 22 | string/string* frage |
| 23 | Schluesseltext(e) auf die Informationen gegeben werden sollen. |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 24 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 25 | string/closure meldung |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 26 | Information, die gegeben werden soll/Closure Bekommt nichts |
| 27 | uebergeben. |
| 28 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 29 | string indent |
| 30 | Text, der sich bei mehrzeiligen Meldungen wiederholen soll. |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 31 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 32 | int/string silent |
| 33 | Ist silent gesetzt, so erfolgt Antwort nur an Fragenden. |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 34 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 35 | string/closure casebased |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 36 | Closure mit Returnwert string oder int. Bekommt nichts |
| 37 | uebergeben. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 38 | |
| 39 | |
| 40 | BESCHREIBUNG |
| 41 | ============ |
| 42 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 43 | Wenn ein Spieler ein NPC mittels "frage <monstername> nach <frage>" |
| 44 | nach einer Information mit dem Schluessel 'frage' fragt, so wird |
| 45 | die entsprechende 'meldung' ausgegeben (oder die Closure in |
| 46 | 'meldung' gerufen und der zurueckgegebene Text ausgegeben). Der |
| 47 | Meldung wird der Name des Monsters vorangestellt. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 48 | |
| 49 | Frage: |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 50 | Schluessel muessen kleingeschrieben sein, koennen aber |
| 51 | Leerzeichen enthalten. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 52 | |
| 53 | Meldung: |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 54 | Wenn kein 'indent' angegeben ist, muss man die Meldung selbst |
| 55 | umbrechen. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 56 | |
| 57 | Indent: |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 58 | Wird ein 'indent' angegeben so wird jeder Zeile hinter dem |
| 59 | Monsternamen noch das 'indent' vorangesetzt. Ein typisches |
| 60 | indent ist "sagt: ". |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 61 | |
| 62 | Silent: |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 63 | Bei 'silent'==1 erfolgt keine Textausgabe der Antwortmeldung im |
| 64 | Raum, ist 'silent' ein String, so wird jener an alle anderen |
| 65 | Spieler ausser dem Fragesteller im Raum ausgegeben. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 66 | |
| 67 | Casebased: |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 68 | Die als Closure angegebene Methode entscheidet, ob oder wie der |
| 69 | NPC auf diese Frage antworten soll: |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 70 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 71 | # return 0: normale Antwort mit "meldung" |
| 72 | |
| 73 | # return 1: keine Antwort/Antwort mit DEFAULT_NOINFO |
| 74 | |
| 75 | # return string: Antwort mit string unter Beruecksichtigung |
| 76 | eines indent |
| 77 | |
| 78 | Die Strings von 'silent' und 'meldung' werden geparsed. Dabei |
| 79 | koennen die @[...]-Tags von replace_personal() verwendet werden, |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 80 | Objekt 1 ist this_player(). Ersetzte String am Satzanfang werden |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 81 | automatisch gross geschrieben. AddInfo() konvertiert die alten |
| 82 | Schluesselworte @WER, @WESSEN, @WEM, @WEN zu denen von |
| 83 | replace_personal(), jedoch nicht in den Rueckgabe- werten von |
| 84 | Closures. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 85 | |
| 86 | Mittels der in <npc.h> definierten Frage DEFAULT_INFO kann eine |
| 87 | Meldung gesetzt werden, die gegeben werden soll, wenn der Spieler |
| 88 | etwas fragt, auf das keine Antwort vorgegeben ist (das loest |
| 89 | SetProp(P_DEFAULT_INFO, <text>) ab). |
| 90 | |
| 91 | |
| 92 | BEISPIELE |
| 93 | ========= |
| 94 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 95 | Siehe auch: /doc/beispiele/AddInfo/ |
| 96 | |
| 97 | // Beispiel 1: ### eine Standardantwort setzen ### |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 98 | AddInfo(DEFAULT_INFO, "starrt Dir boese in die Augen.\n"); |
| 99 | // identisch zu |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 100 | // obsolet: SetProp(P_DEFAULT_INFO, "starrt Dir boese in die Augen.\n"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 101 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 102 | // Beispiel 2: einfache Beispiele, auch mit casebased |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 103 | AddInfo(({"knete","kohle"}), |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 104 | "sagt: ich habe so etwas nicht.\n"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 105 | AddInfo("geld", |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 106 | "Ich habe zwar kein Geld, aber [...] blablabla [...]", |
| 107 | "sagt: "); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 108 | AddInfo("muenzen", |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 109 | "fluestert: Du willst Geld?", |
| 110 | 0, |
Zesstra | bfab6ac | 2018-08-29 22:36:57 +0200 | [diff] [blame] | 111 | "fluestert @WEM1 etwas zu."); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 112 | |
| 113 | // "frage monster nach geld": alle im Raum hoeren |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 114 | // Das Monster sagt: Ich habe zwar kein Geld, aber [...] |
| 115 | // Das Monster sagt: [...] blablabla [...] |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 116 | |
| 117 | // "frage monster nach muenzen": |
| 118 | // - der Fragensteller hoert: |
| 119 | // "Das Monster fluestert: Du willst Geld?" |
| 120 | // - alle andere hoeren: |
| 121 | // "Das Monster fluestert <Fragenstellernamen> etwas zu." |
| 122 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 123 | // Beispiel 3: dynamisch |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 124 | // ein Prototyp, damit wir die Methode bekannt machen |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 125 | protected string query_kekse(); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 126 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 127 | AddInfo(({"keks","kekse"}), |
| 128 | #'query_kekse, // ein Verweis auf die Funktion |
| 129 | "sagt: "); |
| 130 | |
| 131 | protected string query_kekse() { |
| 132 | if(present("keks", this_object())) |
| 133 | return("Ich hab noch welche. Aetsch!"); |
| 134 | else if(present("keks", environment())) |
| 135 | return("Da liegt einer!"); |
| 136 | return("Menno. Keine mehr da!"); |
| 137 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 138 | // "frage monster nach keks": |
| 139 | // - wenn es noch Kekse hat, hoeren alle: |
| 140 | // "Das Monster sagt: Ich hab noch welche. Aetsch! |
| 141 | // - sonst: |
| 142 | // "Das Monster sagt: "Menno. Keine mehr da! |
| 143 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 144 | // Beispiel 4: dynamischer |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 145 | // ein Prototyp, damit wir die Methode bekannt machen |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 146 | protected string query_kekse(); |
| 147 | protected mixed case_fighting(); |
| 148 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 149 | AddInfo(({"keks","kekse"}), |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 150 | #'query_kekse," // ein Verweis auf die Funktion |
| 151 | sagt: ", |
| 152 | 0, // nicht silent :) |
| 153 | #'case_fighting); // noch ein Funktionsverweis |
| 154 | |
| 155 | protected string query_kekse() { |
| 156 | if(present("keks")) |
| 157 | return("Ich hab noch welche. Aetsch!"); |
| 158 | return("Menno. Keine mehr da!"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 159 | } |
| 160 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 161 | protected mixed case_fighting() { |
| 162 | if(InFight()) |
| 163 | return("Keine Zeit fuer Kekse. Muss kaempfen."); |
| 164 | return 0; |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 165 | } |
| 166 | |
| 167 | // "frage monster nach keks": |
| 168 | // - wenn es kaempft, hoeren alle: |
| 169 | // "Das Monster sagt: Keine Zeit fuer Kekse. Muss kaempfen. |
| 170 | // - sonst, wenn es noch Kekse hat, hoeren alle: |
| 171 | // "Das Monster sagt: Ich hab noch welche. Aetsch! |
| 172 | // - sonst: |
| 173 | // "Das Monster sagt: "Menno. Keine mehr da! |
| 174 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 175 | // Beispiel 5: ### dynamisch und komplex ### |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 176 | // ein Prototyp, damit wir die Methode bekannt machen |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 177 | protected string question_gold(); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 178 | |
| 179 | // "gold" wird eine Closure auf die Methode question_gold() |
| 180 | // zugewiesen, ausserdem soll es still bleiben (wir informieren |
| 181 | // den Restraum selbst) |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 182 | AddInfo("gold", #'question_gold, "murmelt: ", 1); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 183 | |
| 184 | // los gehts, wir generieren unsere Antwort selbst |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 185 | protected string question_gold() { |
| 186 | // wieviel Kohle hat der Spieler |
| 187 | int money = this_player()->QueryMoney(); |
Zesstra | bfab6ac | 2018-08-29 22:36:57 +0200 | [diff] [blame] | 188 | string* y = map(deep_inventory(this_player()), |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 189 | function string(object o) { |
| 190 | if(o->QueryMaterial(MAT_GOLD)>0 && |
| 191 | strstr(object_name(o),"/items/money")<0 && |
| 192 | o->QueryProp(P_NAME)) |
| 193 | return o->name(WER,1); |
| 194 | })-({0}); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 195 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 196 | // das geht an alle anderen im Raum, silent bietet sich hier |
| 197 | // nicht an, weil es mehrere Moeglichkeiten gibt |
| 198 | send_room(environment(), |
| 199 | (Name(WER,1)+" murmelt "+ |
| 200 | this_player()->name(WEM,1)+ |
| 201 | " etwas zu"+ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 202 | ((money || sizeof(y))? |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 203 | " und glotzt "+this_player()->QueryPronoun(WEN)+" gierig an.": |
| 204 | ".")), |
| 205 | MT_LOOK|MT_LISTEN, |
| 206 | MA_EMOTE, 0, ({this_player()})); |
| 207 | |
| 208 | // und hier die Antwort an den Spieler selbst, mit vielen |
| 209 | // Verzweigungen fuer dessen Besitztum |
| 210 | return("Ich hab kein Gold bei mir."+ |
| 211 | ((money || sizeof(y))? |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 212 | " Aber du "+ |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 213 | (money? |
| 214 | "hast ja jede Menge Kohle bei dir, so etwa "+money+ |
| 215 | " Muenzen."+ |
| 216 | (sizeof(y)? |
| 217 | " Ausserdem "+ |
| 218 | ((sizeof(y)==1)?"ist":"sind")+ |
| 219 | " auch noch "+CountUp(y)+" aus Gold.": |
| 220 | ""): |
| 221 | (sizeof(y)?"hast ja ein paar Wertsachen dabei: "+ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 222 | CountUp(y)+ |
| 223 | (sizeof(y)==1?" ist":" sind")+ |
| 224 | " aus Gold.":"")): |
| 225 | "")); |
| 226 | } |
| 227 | |
| 228 | // "frage monster nach gold" |
| 229 | // - der Fragesteller hoert zB: |
| 230 | // Das Monster murmelt: Ich hab kein Gold bei mir. Aber du hast ja |
| 231 | // Das Monster murmelt: jede Menge Kohle bei dir, so etwas <number> |
| 232 | // Das Monster murmelt: Muenzen. Ausserdem ist/sind noch <object1> |
| 233 | // Das Monster murmelt: und <object2> aus Gold." |
| 234 | // - die Umstehenden hoeren: |
Zesstra | bfab6ac | 2018-08-29 22:36:57 +0200 | [diff] [blame] | 235 | // "Das Monster murmelt @WEM1 etwas zu." |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 236 | // oder |
Zesstra | bfab6ac | 2018-08-29 22:36:57 +0200 | [diff] [blame] | 237 | // "Das Monster murmelt @WEM1 etwas zu und glotzt ihn/sie gierig an." |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 238 | |
| 239 | |
| 240 | SIEHE AUCH |
| 241 | ========== |
| 242 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 243 | Verwandt: |
Zesstra | 6cadc1b | 2018-11-15 22:27:32 +0100 | [diff] [blame] | 244 | AddSpecialInfo(), RemoveInfo() |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 245 | |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 246 | Props: |
Zesstra | 6cadc1b | 2018-11-15 22:27:32 +0100 | [diff] [blame] | 247 | P_PRE_INFO |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 248 | |
| 249 | Files: |
| 250 | /std/npc/info.c |
| 251 | |
| 252 | Loggen: |
Zesstra | 6cadc1b | 2018-11-15 22:27:32 +0100 | [diff] [blame] | 253 | P_LOG_INFO |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 254 | |
| 255 | Interna: |
Zesstra | 6cadc1b | 2018-11-15 22:27:32 +0100 | [diff] [blame] | 256 | GetInfoArr() , do_frage() |
Zesstra | 0c1a85a | 2018-02-07 23:46:50 +0100 | [diff] [blame] | 257 | |
| 258 | 7. Mar 2017 Gloinson |