blob: 196d9ed64efdb995d004e651b69cbe4a8501766c [file] [log] [blame]
Zesstra953f9972017-02-18 15:37:36 +01001eat_food()
2**********
MG Mud User88f12472016-06-24 23:31:02 +02003
MG Mud User88f12472016-06-24 23:31:02 +02004
Zesstra953f9972017-02-18 15:37:36 +01005FUNKTION
6========
MG Mud User88f12472016-06-24 23:31:02 +02007
Zesstra953f9972017-02-18 15:37:36 +01008 public varargs int eat_food(int food, int testonly, string mytext)
MG Mud User88f12472016-06-24 23:31:02 +02009
MG Mud User88f12472016-06-24 23:31:02 +020010
Zesstra953f9972017-02-18 15:37:36 +010011DEFINIERT IN
12============
MG Mud User88f12472016-06-24 23:31:02 +020013
Zesstra953f9972017-02-18 15:37:36 +010014 /std/living/life.c
MG Mud User88f12472016-06-24 23:31:02 +020015
MG Mud User88f12472016-06-24 23:31:02 +020016
Zesstra953f9972017-02-18 15:37:36 +010017ARGUMENTE
18=========
MG Mud User88f12472016-06-24 23:31:02 +020019
Zesstra953f9972017-02-18 15:37:36 +010020 food: Wird zu dem augenblicklichen Saettigungsgrad (P_FOOD) addiert.
21 testonly: Ist das Flag gesetzt, wird dem Spieler kein FOOD zugefuehrt.
22 Darf nur zum Testen der Heilstelle verwendet werden und muss
23 im normalen Betrieb auf '0' stehen!
24 mytext: Wer selber einen Text bei Misserfolg ausgeben lassen moechte,
25 darf sich hier was nettes ausdenken.
26 Achtung: Das unterdrueckt nicht die "Hunger"-Meldung, die bei
27 negativem food auftreten kann, wenn P_FOOD wieder 0 ist.
MG Mud User88f12472016-06-24 23:31:02 +020028
MG Mud User88f12472016-06-24 23:31:02 +020029
Zesstra953f9972017-02-18 15:37:36 +010030BESCHREIBUNG
31============
MG Mud User88f12472016-06-24 23:31:02 +020032
Zesstra953f9972017-02-18 15:37:36 +010033 Es wird geprueft, ob dem Spieler der angebene Wert "strength" auf seine
34 aktuelle P_FOOD addiert werden kann oder nicht. Ist dies moeglich, wird
35 wird es gemacht, es sei denn das testonly != 0.
MG Mud User88f12472016-06-24 23:31:02 +020036
Zesstra953f9972017-02-18 15:37:36 +010037 Sollen neben P_FOOD noch weitere Props manipuliert werden - bspw. zur
38 Heilung eines Lebewesens - bietet sich die Funktion consume() an.
39
40
41RUECKGABEWERT
42=============
43
44 0, wenn strength + P_FOOD > P_MAX_FOOD.
45 >0, wenn Erfolg.
46
47
48BEMERKUNG
49=========
50
51 eat_food() bitte anstatt eigener Manipulationen von P_FOOD und
52 P_MAX_FOOD verwenden.
53
54 Achtung: Immer erst VOR einer Heilung ausfuehren und bei Erfolg heilen.
55
56 Bei Heilstellen sollte eine evtl. Heilung des Spielers mit der eigens
57 dafuer eingerichteten Funktion check_and_update_timed_key realisiert
58 werden.
59
60
61BEISPIEL
62========
63
64 int heilstelle() {
65 // Wenn auf das P_FOOD des Spielers die angegebenen 10 nicht mehr addiert
66 // addiert werden koennen (weil sonst P_MAX_FOOD ueberschritten wird),
67 // wird die Fehlermeldung ausgegeben, dass der Spieler nichts mehr
68 // essen/trinken kann.
69 // Bei gesetztem 'mytext' wird 'mytext' an den Spieler ausgegeben.
70 // Ansonsten wird die Standardmeldung ausgegeben.
71 if (!this_player()->eat_food(10, 0, "Der Keks ist einfach "
72 "zuviel fuer Dich.\n") )
73 return 1;
74
75 // Spieler hatte noch ausreichend Spielraum bei P_FOOD. Die 10 sind
76 // schon addiert worden. Jetzt Nachricht ausgeben:
77 tell_object(this_player(), break_string("Du knabberst ein bisschen an "
78 "dem Keks herum und fuehlst Dich gleich viel besser.", 78));
79
80 // alle Lebewesen im Raum bekommen das auch mit
Arathorn99af0d22019-11-26 19:19:51 +010081 tell_room(environment(this_player()),
82 this_player()->Name()+" knuspert einen Keks weg.\n",
83 ({this_player()}));
Zesstra953f9972017-02-18 15:37:36 +010084
85 // Rassenabhaengige Heilung: Sofort oder in Schritten
86 // Tragbare Heilungen sollten auch eher buffer_hp/_sp benutzen.
87 if(this_player()->QueryProp(P_REAL_RACE)=="Kruemelmonster")
88 this_player()->heal_self(30);
89 else {
90 this_player()->buffer_hp(30,5);
91 this_player()->buffer_sp(30,5);
92 }
93
94 return 1;
95 }
96
97
98SIEHE AUCH
99==========
100
101 Aehnlich: consume, drink_alcohol, drink_soft
102 Heilung: heal_self, restore_spell_points, restore_hit_points,
103 buffer_hp, buffer_sp
104 Timing: check_and_update_timed_key
105 Enttanken: defuel_drink, defuel_food
106 Props: P_DRINK, P_FOOD, P_ALCOHOL, P_SP, P_HP,
107 P_DEFUEL_TIME_DRINK
108 Konzepte: heilung, enttanken, food
MG Mud User88f12472016-06-24 23:31:02 +0200109
1109. August 2015 Gloinson