MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 1 | VORLAEUFIG, GESCHUETZT |
| 2 | SYNOPSIS |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 3 | #include <rtlimits.h> |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 4 | |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 5 | mixed limited(closure fun) |
| 6 | mixed limited(closure fun, int tag, int value, ...) |
| 7 | mixed limited(closure fun, int *limits) |
| 8 | mixed limited(closure fun, int *limits, mixed *args) |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 9 | |
| 10 | BESCHREIBUNG |
| 11 | limited() ruft die Funktion <fun> mit den bezeichneten Argumenten |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 12 | <args> auf und fuehrt sie mit den gegebenen Laufzeitlimitierungen aus. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 13 | |
| 14 | Beim Ende der Funktion <fun> werden die momentan aktiven |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 15 | Laufzeitlimitierungen wiederhergestellt. limited() liefert den |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 16 | Rueckgabewert der Closure <fun> zurueck. |
| 17 | |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 18 | Die Laufzeitlimitierungen koennen in zwei Formen angegeben werden: |
| 19 | * als Array (wie es von query_limits() geliefert wird) oder |
| 20 | * als Liste von Werten mit Tags. |
| 21 | Wird limited() ohne Angabe von Limits aufgerufen, gelten die |
| 22 | Laufzeitlimiten als 'unlimitiert'. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 23 | |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 24 | Die Limitierung kennt drei spezielle Werte aus <rtlimits.h>: |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 25 | LIMIT_UNLIMITED: es gibt kein Limit |
| 26 | LIMIT_KEEP: das zuletzt gesetzte Limit wird beibehalten |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 27 | LIMIT_DEFAULT: die 'globalen' Limitierungen werden verwendet |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 28 | |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 29 | Fuer LIMIT_COST haben folgende Spezialwerte eine Bedeutung: |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 30 | LIMIT_UNLIMITED: die Ausfuehrung kosten lediglich einen Tick |
| 31 | LIMIT_KEEP: LIMIT_COST wird auf 0 gesetzt |
| 32 | LIMIT_DEFAULT: LIMIT_COST wird auf -100 gesetzt |
| 33 | |
| 34 | limited() erzeugt eine Schutzverletzung ("limited", current_object, |
| 35 | fun, limits-array). |
| 36 | |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 37 | |
| 38 | BEISPIELE |
| 39 | limited(#'function) |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 40 | --> fuehrt die Funktion ohne Limits aus. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 41 | |
| 42 | limited(#'function, ({ 200000 }), "foo") |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 43 | --> fuehrt die Funktion mit einem Eval-Kosten-Limit von 200000 Ticks |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 44 | aus. Die Funktion wird als 'function("foo")' aufgerufen. |
| 45 | |
| 46 | limited(lambda(0, ({#'function, "foo"})), LIMIT_EVAL, 200000) |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 47 | --> fuehrt die Funktion mit einem Eval-Kosten-Limit von 200000 Ticks |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 48 | aus. Die Funktion wird als 'function("foo")' aufgerufen. |
| 49 | |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 50 | GESCHICHTE |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 51 | Eingefuehrt in LDMud 3.2.7. |
| 52 | LDMud 3.3.563 fuehrte LIMIT_COST ein. |
Zesstra | b6ac9f6 | 2020-01-21 11:11:16 +0100 | [diff] [blame] | 53 | LDMud 3.5.0 fuehrte LIMIT_MEMORY ein. |
MG Mud User | 88f1247 | 2016-06-24 23:31:02 +0200 | [diff] [blame] | 54 | |
| 55 | SIEHE AUCH |
| 56 | query_limits(E), set_limits(E) |