blob: b50dc2b3bceffe68a5dc1d6cef34a0aad5ed83d2 [file] [log] [blame]
heull0013d7ea4a2018-02-27 18:33:35 +01001GetHelperObject()
2=================
3
4FUNKTION
5--------
6
Zesstra1a4cb172018-03-09 21:43:26 +01007 public varargs object GetHelperObject(int type, int|closure strength
8 varargs mixed* extra)
heull0013d7ea4a2018-02-27 18:33:35 +01009
10DEFINIERT IN
11------------
12
13 /std/living/helpers.c
14
15ARGUMENTE
16---------
17
Zesstra1a4cb172018-03-09 21:43:26 +010018 type:
19 Eine der in helpers.h definierten Konstanten
20 strength:
21 minimal geforderte Staerke des Helfers oder Closure zum Filtern der
22 Helferobjekte.
heull0013d7ea4a2018-02-27 18:33:35 +010023
24BESCHREIBUNG
25------------
26
27 Gibt das zuerst gefundene als Helfer registrierte Objekt zurueck, welches
28 die Anforderungen erfuellt.
29
Zesstra1a4cb172018-03-09 21:43:26 +010030 Ist <strength> ein int, muss die Staerke/Guete des Helfers (Rueckgabewert
31 der Callback-Methode, siehe :doc:`RegisterHelperObject`) mindestens so gross
32 sein wie der als <strength> uebergebene Wert.
33
34 Ist <strength> eine Closure, wird diese fuer jeden Helfer ausgewertet und
35 entscheidet, ob der Helfer akzeptiert wird. Die Closure bekommt hierbei das
36 Helferobjekt, die vom Helfer angegebene Staerke/Guete und etwaige hier als
37 <extra> uebergebene Argument uebergeben. Ist der Rueckgabewert von
38 <strength> != 0, wird der Helfer akzeptiert und von GetHelperObject
39 zurueckgegeben (ohne weitere Helfer zu pruefen).
40
41
heull0013d7ea4a2018-02-27 18:33:35 +010042RUECKGABEWERT
43-------------
44
45 Objekt welches den uebergebenen Anforderungen entspricht.
46
Zesstra1a4cb172018-03-09 21:43:26 +010047
48BEISPIELE
49---------
50
51.. code-block:: pike
52
53 // Es wird ein Helfer zum Tauchen mit der Staerke 4 gesucht
54 PL->GetHelperObject(HELPER_TYPE_AQUATIC, 4);
55
56.. code-block:: pike
57
58 // Es wird ein Helfer zum Fliegen mit der Staerke 4 gesucht, welcher aber
59 // mindestens 60 cm gross und maximal 900 g schwer ist.
60 PL->GetHelperObject(HELPER_TYPE_AERIAL, function int (object h, int s)
61 { return s >= 4
62 && h->QueryProp(P_SIZE) >= 60 && h->QueryProp(P_WEIGHT) <= 900;
63 }
64 );
65
66.. code-block:: pike
67
68 // Es wird ein Helfer zum Fliegen mit der Staerke 4 gesucht, welcher aber
69 // mindestens 60 cm gross und maximal 900 g schwer ist, aber diese Grenzen
70 // werden nicht in der Funktion festgelegt, sondern als <extra> uebergeben.
71 PL->GetHelperObject(HELPER_TYPE_AERIAL,
72 function int (object h, int s, int min_s, int minsize, int maxweight)
73 { return s >= min_s
74 && h->QueryProp(P_SIZE) >= minsize
75 && h->QueryProp(P_WEIGHT) <= maxweight;
76 },
77 4, 60, 900);
78
79
heull0013d7ea4a2018-02-27 18:33:35 +010080SIEHE AUCH
81----------
82
83 :doc:`RegisterHelperObject`, :docnregisterHelperObject`
84 :doc:`../props/P_AERIAL_HELPERS`, :doc:`../props/P_AQUATIC_HELPERS`, :doc:`../props/P_HELPER_OBJECTS`
85
Zesstra1a4cb172018-03-09 21:43:26 +010086Letzte Aenderung: 9.3.2018, Zesstra