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