MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 1 | PreventInsert() |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 2 | *************** |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 3 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 4 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 5 | FUNKTION |
| 6 | ======== |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 7 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 8 | int PreventInsert(object ob); |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 9 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 10 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 11 | DEFINIERT IN |
| 12 | ============ |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 13 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 14 | /std/container/restrictions.c |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 15 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 16 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 17 | ARGUMENTE |
| 18 | ========= |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 19 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 20 | ob |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 21 | Das Objekt, das in den Behaelter eingefuegt werden soll. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 22 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 23 | |
| 24 | BESCHREIBUNG |
| 25 | ============ |
| 26 | |
| 27 | Mit dieser Funktion kann ein Behaelter pruefen, ob er das Objekt ob |
| 28 | aufnehmen moechte oder nicht. |
| 29 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 30 | Man beachte bitte, dass nach dieser Funktion *nicht* garantiert |
| 31 | ist, dass das Objekt wirklich bewegt wird, es handelt sich |
| 32 | lediglich um die Abfrage der Erlaubnis! Die Bewegung kann aus einer |
| 33 | Vielzahl an Gruenden noch abgebrochen werden. |
| 34 | |
| 35 | Wenn ob mit dem Flag M_NOCHECK bewegt wird, wird PreventInsert() |
| 36 | zwar aufgerufen, aber das Ergebnis ignoriert, d.h. die Aufnahme |
| 37 | kann in dem Fall nicht verhindert werden. |
| 38 | |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 39 | |
| 40 | RUeCKGABEWERT |
| 41 | ============= |
| 42 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 43 | 0 |
| 44 | wenn das Objekt aufgenommen werden kann; |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 45 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 46 | > 0 |
| 47 | ein Wert groesser als 0 zeigt an, dass das Objekt nicht |
| 48 | aufgenommen werden soll. |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 49 | |
| 50 | |
| 51 | BEISPIELE |
| 52 | ========= |
| 53 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 54 | Um zu verhindern, dass man Geld in einen Behaelter stecken kann, |
| 55 | sollte man wie folgt vorgehen: |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 56 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 57 | public int PreventInsert(object ob) |
| 58 | { |
| 59 | // Wenn es Geld ist, erheben wir sofort Einspruch |
| 60 | if (ob->id("geld")) |
| 61 | return 1; |
| 62 | // Ansonsten koennte ein ererbtes Objekt noch Einspruch erheben! |
| 63 | else |
| 64 | return ::PreventInsert(ob); |
| 65 | } |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 66 | |
| 67 | |
| 68 | SIEHE AUCH |
| 69 | ========== |
| 70 | |
| 71 | PreventLeave(), NotifyInsert(), NotifyLeave(), MayAddObject(), |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 72 | MayAddWeight(), PreventInsertLiving(), PreventLeaveLiving(), |
| 73 | NotifyMove(), PreventMove(), move(), /std/container/restrictions.c |
Zesstra | 953f997 | 2017-02-18 15:37:36 +0100 | [diff] [blame] | 74 | |
Zesstra | 8bf86f5 | 2020-04-04 15:24:13 +0200 | [diff] [blame] | 75 | Last modified: 30.01.2020, Zesstra |