MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 1 | ADDCMD() - BEISPIELE |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 2 | ******************** |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 3 | |
| 4 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 5 | FUNKTION |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 6 | ======== |
| 7 | |
| 8 | varargs void AddCmd(mixed cmd, mixed func, mixed flag); |
| 9 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 10 | |
| 11 | BEMERKUNGEN |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 12 | =========== |
| 13 | |
| 14 | Die hier aufgefuehrten Komplexbeispiele sind zum Verstaendnis gedacht, |
| 15 | daher fuehren sie oft Alternativen auf. Die letzte Variante ist dann |
| 16 | jeweils diejenige, welche am leichtesten das Problem loesen koennte. |
| 17 | Falls die einem zu komplex ist, hilft vielleicht die vorletzte. |
| 18 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 19 | |
| 20 | BEISPIELE |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 21 | ========= |
| 22 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 23 | |
| 24 | Einfache Beispiele |
| 25 | ------------------ |
| 26 | |
| 27 | 1. SIMPEL: ganz simpel, beinahe wie add_action() |
| 28 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 29 | AddCmd("befiehl","action_befehlen"); |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 30 | // ... |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 31 | int action_befehlen(string str) { |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 32 | if(!str || !strlen(str)) |
| 33 | // Fehlermeldung, falls gar keine Funktion 1 dafuer zurueckgibt |
| 34 | notify_fail("Was willst du befehlen?!\n"); |
| 35 | else { |
| 36 | write("Du befiehlst \""+str+"\", und alle folgen!\n"); |
| 37 | say(TP->Name(WER)+" befiehlt \""+str+"\", und du folgst!\n"); |
| 38 | return 1; // ERFOLG - Abbruch der Kommandoauswertung |
| 39 | } |
| 40 | return 0; // MISSERFOLG - Fehlermeldung oben gesetzt |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 41 | } |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 42 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 43 | 2. SIMPEL .. weitere Beispiele |
| 44 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 45 | AddCmd(({"kletter","klettere"}),"action_klettern" ); |
| 46 | AddCmd(({"renn","renne"}),#'action_rennen); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 47 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 48 | 3. REGELN: eine komplexere Regel |
| 49 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 50 | AddCmd("loesch|loesche|ersticke&feuer|brand|flammen&decke|wolldecke", |
| 51 | "action_loeschen", |
| 52 | "Was willst du loeschen?|Womit willst du loeschen?"); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 53 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 54 | 4. REGELN: mit Platzhaltern im Fehlerstring |
| 55 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 56 | AddCmd("spring|springe|huepf|huepfe&von|vom&baum|ast|eiche", |
| 57 | #'action_huepfe, |
| 58 | "Willst du von etwas @verben?|Von wo willst du @verben?"); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 59 | |
Zesstra | e959e72 | 2025-07-09 22:11:16 +0200 | [diff] [blame^] | 60 | 5. SCHLECHT: eine unscharfe Regel - sie sollten eine Ausnahme sein (!) |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 61 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 62 | AddCmd("kletter","fun_klettern",1); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 63 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 64 | 6. FALSCH: sehr schlecht, kein Imperativ verwendet |
| 65 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 66 | AddCmd("lese","eval_lesen"); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 67 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 68 | ausserdem sollte man fuer Lese-Syntaxen AddReadDetail benutzen |
| 69 | |
| 70 | 7. SIMPLE REGEL |
| 71 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 72 | static int action_jump(string str); // Prototype (wegen closure) |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 73 | // ... |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 74 | AddCmd("spring|springe|huepf|huepfe&von&baum|ast",#'action_jump, |
| 75 | "Willst Du von etwas @verben?|Wovon willst Du @verben?"); |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 76 | // ... |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 77 | static int action_jump(string str) { |
| 78 | write(break_string("Du springst vom Baum und kommst hart auf!",78)); |
| 79 | this_player()->move((XXXROOM+"boden"), M_GO, 0, |
| 80 | "springt unelegant vom Baum","faellt vom Baum"); |
| 81 | this_player()->Defend(random(100),({DT_BLUDGEON}),([SP_RECURSIVE:1]), |
| 82 | this_object()); |
| 83 | return 1; |
| 84 | } |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 85 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 86 | 8. SIMPLE REGEL OHNE METHODE |
| 87 | |
| 88 | mit Regeln kann man auch Aktivitaeten im Raum erlauben, ohne eine |
| 89 | Funktion aufrufen zu muessen: die letzte Regel ist fuer Spieler |
| 90 | unmoeglich zu erfuellen, die dazugehoerige Fehlermeldung wird mit |
| 91 | dem ^ (write-Flag) versehen und entsprechend an den Spieler (und |
| 92 | den Raum (hinter dem ^)) ausgegeben |
| 93 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 94 | AddCmd("spring|springe&herunter|runter&\n\bimpossible",0, |
| 95 | "Wohin oder wovon willst Du springen?|" |
| 96 | "Du springst vom Baum und kommst hart auf.^" |
| 97 | "@WER1 springt vom Baum und kommt hart auf."); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 98 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 99 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 100 | Komplexbeispiel: Regeln mit Fehlermeldungen |
| 101 | ------------------------------------------- |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 102 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 103 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 104 | Variante 1a, OHNE REGELN |
| 105 | ~~~~~~~~~~~~~~~~~~~~~~~~ |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 106 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 107 | Wenn man keine Regeln verwendet, muss man die Eingabe selbst |
| 108 | auswerten. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 109 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 110 | AddCmd(({"bohr","bohre"}),#'action_bohren); |
| 111 | // ... |
| 112 | private int action_bohren(string str) { |
| 113 | string *tmp; |
| 114 | notify_fail("Wo willst (etwas) Du bohren?\n"); |
| 115 | if(!str) return 0; // Tja, keine Argumente ... |
| 116 | tmp=explode(str," "); // nach " " in Argument-Array aufspalten |
| 117 | if((i=member(tmp,"loch"))>=0) { // aha, ab jetzt uebernehmen wir :) |
| 118 | if((j=member(tmp[(i+1)..],"in"))<0 && |
| 119 | (j=member(tmp[(i+1)..],"durch"))<0) |
| 120 | write("Willst Du das Loch in etwas bohren?\n"); |
| 121 | else if((i=member(tmp[(j+1)..],"boden"))<0 && |
| 122 | (i=member(tmp[(j+1)..],"erde"))<0) |
| 123 | write("In/Durch was willst du das Loch bohren?\n"); |
| 124 | else { |
| 125 | write("Du bohrst ein Loch in den Boden.\n"); |
| 126 | say(this_player()->Name(WER)+" bohrt ein Loch in den Boden.\n"); |
| 127 | } |
| 128 | return 1; // "bohre loch" war so eindeutig, dass nur diese |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 129 | // Methode gemeint sein konnte, also brechen wir die |
| 130 | // weitere Auswertung auf jeden Fall ab (und geben |
| 131 | // eine write-Fehlermeldung) |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 132 | } // end if(..."loch") |
| 133 | return 0; // "bohre" allein muss nicht diese Methode meinen, |
| 134 | // also nur obige notify_fail()-Meldung, falls |
| 135 | // sich nach dieser Methode gar keine sonst |
| 136 | // angesprochen fuehlt |
| 137 | } // end fun |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 138 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 139 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 140 | Variante 1b, OHNE REGELN, Alternative |
| 141 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 142 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 143 | prinzipiell koennte die Methode action_bohren() auch so aussehen, |
| 144 | ist aber nicht ganz so flexibel: |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 145 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 146 | private int action_bohren(string str) { |
| 147 | string unused; |
| 148 | if(!str || (sprintf(str,"loch in erde%s", unused)!=1 && |
| 149 | sprintf(str,"loch durch erde%s", unused)!=1 && |
| 150 | sprintf(str,"loch in boden%s", unused)!=1 && |
| 151 | sprintf(str,"loch durch boden%s", unused)!=1)) |
| 152 | notify_fail("Willst Du in irgendwas ein Loch bohren?\n"); |
| 153 | else { |
| 154 | // ... |
| 155 | return 1; |
| 156 | } |
| 157 | return 0; |
| 158 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 159 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 160 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 161 | Variante 2, MIT REGEL |
| 162 | ~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 163 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 164 | das gleiche in etwa mal als einfache Regel |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 165 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 166 | AddCmd("bohr|bohre&loch&in|durch&erde|boden",#'action_bohren, |
| 167 | "Was willst du (wohin) bohren?|" |
| 168 | "Willst du das Loch in etwas bohren?|" |
| 169 | "Wohin willst du das Loch bohren?"); |
| 170 | // ... |
| 171 | private int action_bohren(string str, mixed *param) { |
| 172 | write("Du bohrst ein Loch in den Boden.\n"); |
| 173 | say(this_player()->Name(WER)+" bohrt ein Loch in den Boden.\n"); |
| 174 | // ... |
| 175 | return 1; |
| 176 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 177 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 178 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 179 | Variante 3, MIT REGEL UND FEHLERMELDUNG |
| 180 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 181 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 182 | und nun mit Fehlermeldungen mit Ersetzungen, so dass wir mehr auf |
| 183 | die Eingaben des Spielers eingehen |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 184 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 185 | AddCmd("bohr|bohre&loch&in|durch&erde|boden",#'action_bohren, |
| 186 | "Was willst du (wohin) @verben?|" |
| 187 | "Willst du das Loch in etwas @verben?|" |
| 188 | "@WER3 was willst du das Loch @verben?"); |
| 189 | // ... |
| 190 | private int action_bohren(string str, mixed *param) // ... |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 191 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 192 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 193 | Variante 4, MIT REGEL, FEHLERMELDUNG UND RETURN 1 |
| 194 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 195 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 196 | In Variante 1 kam sinnvollerweise sehr frueh der Abbruch mit |
| 197 | "return 1;" und mit Ausgabe von write-Fehlermeldungen, das koennen |
| 198 | wir auch direkt und ohne eigene Methode. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 199 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 200 | AddCmd("bohr|bohre&loch&in|durch&erde|boden",#'action_bohren, |
| 201 | "Was willst du (wohin) @verben?|" |
| 202 | "Willst du das Loch in etwas @verben?^|" |
| 203 | "@WER3 was willst du das Loch @verben?^"); |
| 204 | // ... |
| 205 | private int action_bohren(string str, mixed *param) // ... |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 206 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 207 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 208 | Variante 5, MIT REGEL, FEHLERMELDUNG, RETURN 1, OHNE FUN |
| 209 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 210 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 211 | // und falls in action_bohren() nichts ausser Ausgaben passiert, koennen |
| 212 | // wir uns die auch ganz sparen indem wir eine nichterfuellbare Regel |
| 213 | // samt Fehlermeldung bauen |
| 214 | AddCmd("bohr|bohre&loch&in|durch&erde|boden&\nimpossible",0, |
| 215 | "Was willst du (wohin) @verben?|" |
| 216 | "Willst du das Loch in etwas @verben?^|" |
| 217 | "@WER3 was willst du das Loch @verben?^|" |
| 218 | "Du @verbst ein Loch @WER3 den Boden.^@WER1 @verbt " |
| 219 | "ein Loch @WER3 den Boden."); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 220 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 221 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 222 | Komplexbeispiel: Spezialregeln @PRESENT und @ID |
| 223 | ----------------------------------------------- |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 224 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 225 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 226 | Variante 1, OHNE REGELN |
| 227 | ~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 228 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 229 | Oft agieren Kommandos auf Objekten im Raum, diese muessen dabei per |
| 230 | present() identifiziert werden: Beispiel ist ein Geldautomat |
| 231 | (Hinweis: dieses Beispiel dient der Illustration, die |
| 232 | Funktionalitaet an sich sollte man besser mit einem Container mit |
| 233 | PreventInsert() erzeugen.) |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 234 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 235 | AddCmd(({"stopf","stopfe"}),#'action_stopf); |
| 236 | // ... |
| 237 | private int action_stopf(string str) { |
| 238 | string was, unused; |
| 239 | if(str && (sprintf("%s in automat%s", was, unused)==2 || |
| 240 | sprintf("%s in geldautomat%s", was, unused)==2 || |
| 241 | sprintf("%s in bankomat%s", was, unused)==2) { |
| 242 | object o = present(was, this_player()); |
| 243 | if(o) { |
| 244 | if(o->QueryProp(...)) { |
| 245 | write(break_string( |
| 246 | "Du stopfst "+o->name(WEN,1)+" in den Automaten.",78)); |
| 247 | say(...); |
| 248 | } else { |
| 249 | write(break_string( |
| 250 | "Du versuchst "+o->name(WEN,1)+" in den Automaten zu stopfen, " |
| 251 | "aber "+o->QueryPronoun(WER)+" passt nicht hinein.",78)); |
| 252 | say(...); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 253 | } |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 254 | } else { |
| 255 | write("Was willst du in den Automaten stopfen?\n"); |
| 256 | say(....); |
| 257 | } |
| 258 | return 1; |
| 259 | } |
| 260 | notify_fail("Was willst du wohin stecken?\n"); |
| 261 | return 0; |
| 262 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 263 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 264 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 265 | Variante 2, MIT REGEL |
| 266 | ~~~~~~~~~~~~~~~~~~~~~ |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 267 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 268 | einerseits koennen wir auf diese Weise das Finden von Objekten in |
| 269 | Inv und Env in die AddCmd()-Regel integrieren und uns andererseits |
| 270 | das Aufzaehlen aller IDs des Automaten ersparen. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 271 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 272 | Wie immer werden die gefundenen Matches als Parameterarray an die |
| 273 | angegebene Methode uebergeben. Das Array enthaelt die mit @PRESENT |
| 274 | und @ID gefundenen Treffer praktischerweise als Objekte. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 275 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 276 | AddCmd("steck|stecke&@PRESENT&in&@ID",#'action_stopf, |
| 277 | "Was willst du wohin stopfen?|" |
| 278 | "Willst du @WEN2 in etwas stopfen?|" |
| 279 | "Wohinein willst du @WEN2 stopfen?"); |
| 280 | // ... |
| 281 | private int action_stopf(string str, mixed *param) { |
| 282 | if(param[0]->QueryProp(...)) { |
| 283 | write(break_string( |
| 284 | "Du stopfst "+param[0]->name(WEN,1)+" in den Automaten.",78)); |
| 285 | say(...); |
| 286 | } else { |
| 287 | write(break_string( |
| 288 | "Du versuchst "+param[0]->name(WEN,1)+" in den Automaten zu " |
| 289 | "stopfen, aber "+param[0]->QueryPronoun(WER)+" passt nicht " |
| 290 | "hinein.",78)); |
| 291 | say(...); |
| 292 | } |
| 293 | return 1; |
| 294 | } |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 295 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 296 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 297 | Komplexbeispiel: gleiches Verb, mehrere Regeln |
| 298 | ---------------------------------------------- |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 299 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 300 | Das Problem mehrerer Regeln fuer ein Kommandoverb besteht darin, |
| 301 | dass letztlich nur eine der Fehlermeldungen zum Tragen kommt - |
| 302 | welche genau, ist etwas vage. Dabei kann man sich auf eines |
| 303 | verlassen: juengere AddCmd werden zuerst ausgewertet. Wenn sich das |
| 304 | aendert, tretet euren EM. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 305 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 306 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 307 | Problem 1: Mehrere Regeln weil mehrere Zwecke |
| 308 | --------------------------------------------- |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 309 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 310 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 311 | Variante 1 - GLEICHLAUTENDE FEHLERMELDUNG |
| 312 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 313 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 314 | Fuer alles wird eine identische Fehlermeldung gesetzt, das ist |
| 315 | natuerlich nicht sehr flexibel oder schoen oder man versucht eine |
| 316 | bessere Regel zu schaffen, was hier durch die Moeglichkeit von zwei |
| 317 | oder drei Parameter unmoeglich ist |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 318 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 319 | AddCmd("kriech|krieche&hoch|hinauf|hinaus|heraus|raus",#'result_kriech, |
| 320 | "Wohin willst Du kriechen?"); |
| 321 | AddCmd("kriech|krieche&nach&oben",#'result_kriech, |
| 322 | "Wohin willst Du kriechen??|Wohin willst Du kriechen?"); |
| 323 | AddCmd("kriech|krieche&aus&loch|grube|falle",#'result_kriech); |
| 324 | "Wohin willst Du kriechen?|Wohin willst Du kriechen?"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 325 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 326 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 327 | Variante 2 - EIGENE AUSWERTUNG |
| 328 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 329 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 330 | Statt der Verwendung mehrerer aehnlicher AddCmd() bietet sich die |
| 331 | eigene Weiterauswertung an, was durch die Uebergabe der |
| 332 | getriggerten Argumente erleichtert wird. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 333 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 334 | AddCmd("kriech|krieche&hoch|hinauf|hinaus|heraus|raus|aus|nach", |
| 335 | #'result_kriech, |
| 336 | "Wohin willst Du kriechen?"); |
| 337 | // ... |
| 338 | private int result_kriech(string str, mixed *extra) { |
| 339 | if(member(extra,"aus")>=0 && |
| 340 | !sizeof(({str}),"*.\\<(hoehle|grube|falle)\\>.*")) |
| 341 | notify_fail("Woraus willst Du kriechen?\n"); |
| 342 | else if(member(extra,"nach")>=0 && strstr(str,"oben")<0) |
| 343 | notify_fail("In welche Richtung willst Du kriechen?\n"); |
| 344 | else if(this_player()->QueryAttribute(A_DEX)>10 || |
| 345 | member(holding_root,this_player())) { |
| 346 | write("Du kriechst mit Muehe heraus.\n"); |
| 347 | this_player()->move((XXXROOM+"draussen"), M_GO, 0, |
| 348 | "kriecht mit Muehe aus der Grube", |
| 349 | "kriecht aus einer Grube"); |
| 350 | return 1; |
| 351 | } else |
| 352 | write("Du bist zu ungeschickt, halt Dich irgendwo fest.\n"); |
| 353 | return 1; |
| 354 | } |
| 355 | return 0; |
| 356 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 357 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 358 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 359 | Problem 2: mehrere Regeln aufgrund von optionalen Parametern |
| 360 | ------------------------------------------------------------ |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 361 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 362 | Manchmal will man optionale Parameter erlauben, die aber eine |
| 363 | Wirkung zeigen sollen. Hierbei ist die Reihenfolge der AddCmd()- |
| 364 | Anweisungen und ggf. deren Aufbau entscheidend. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 365 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 366 | AddCmd("schlag|schlage&@ID&hart",#'action_schlag_hart, |
| 367 | "Was oder wen willst du @verben?|" |
| 368 | "Wie willst du @WEN2 schlagen?"); |
| 369 | AddCmd("schlag|schlage&@ID",#'action_schlag, |
| 370 | "Was oder wen willst du @verben?"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 371 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 372 | Da juengere AddCmd aelteren vorgehen, wird die komplexere Regel samt |
| 373 | ihrer Fehlermeldung nie ausgewertet, da ein "schlag ball hart" auch |
| 374 | die zweite Regel triggert. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 375 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 376 | Anders herum: |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 377 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 378 | AddCmd("schlag|schlage&@ID",#'action_schlag, |
| 379 | "Was oder wen willst du @verben?"); |
| 380 | AddCmd("schlag|schlage&@ID&hart",#'action_schlag_hart, |
| 381 | "Was oder wen willst du @verben?|" |
| 382 | "Wie willst du @WEN2 schlagen?"); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 383 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 384 | Jetzt wird die komplexere Regel zuerst ueberprueft und triggert |
| 385 | auch die richtige Funktion. |
| 386 | Leider kommt die Fehlermeldung nie zum Tragen, denn was durch Regel 2 |
| 387 | durchfaellt, triggert entweder Regel 1 oder faellt auch durch Regel 1 |
| 388 | durch und ueberschreibt dabei die Meldung. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 389 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 390 | AddCmd("schlag|schlage&@ID",#'action_schlag, |
| 391 | "Was oder wen willst du wie @verben?"); |
| 392 | AddCmd("schlag|schlage&@ID&hart",#'action_schlag_hart); |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 393 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 394 | Das ist zwar auch nur fast perfekt, besser wird es aber nicht. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 395 | |
Arathorn | 655333e | 2019-11-26 19:20:27 +0100 | [diff] [blame] | 396 | Letzte Aenderung: 20.11.2019, Arathorn |