evennia.contrib.ingame_python.utils¶
Functions to extend the event system.
These functions are to be used by developers to customize events and callbacks.
-
evennia.contrib.ingame_python.utils.
register_events
(path_or_typeclass)[source]¶ Register the events in this typeclass.
- Parameters
path_or_typeclass (str or type) – the Python path leading to the class containing events, or the class itself.
- Returns
The typeclass itself.
Notes
This function will read events from the _events class variable defined in the typeclass given in parameters. It will add the events, either to the script if it exists, or to some temporary storage, waiting for the script to be initialized.
-
evennia.contrib.ingame_python.utils.
get_next_wait
(format)[source]¶ Get the length of time in seconds before format.
- Parameters
format (str) – a time format matching the set calendar.
- Returns
until (int or float) – the number of seconds until the event. usual (int or float): the usual number of seconds between events. format (str): a string format representing the time.
Notes
The time format could be something like “2018-01-08 12:00”. The number of units set in the calendar affects the way seconds are calculated.
-
evennia.contrib.ingame_python.utils.
time_event
(obj, event_name, number, parameters)[source]¶ Create a time-related event.
- Parameters
obj (Object) – the object on which sits the event.
event_name (str) – the event’s name.
number (int) – the number of the event.
parameters (str) – the parameter of the event.
-
evennia.contrib.ingame_python.utils.
keyword_event
(callbacks, parameters)[source]¶ Custom call for events with keywords (like push, or pull, or turn…).
- Parameters
callbacks (list of dict) – the list of callbacks to be called.
parameters (str) – the actual parameters entered to trigger the callback.
- Returns
A list containing the callback dictionaries to be called.
Notes
This function should be imported and added as a custom_call parameter to add the event when the event supports keywords as parameters. Keywords in parameters are one or more words separated by a comma. For instance, a ‘push 1, one’ callback can be set to trigger when the player ‘push 1’ or ‘push one’.
-
evennia.contrib.ingame_python.utils.
phrase_event
(callbacks, parameters)[source]¶ Custom call for events with keywords in sentences (like say or whisper).
- Parameters
callbacks (list of dict) – the list of callbacks to be called.
parameters (str) – the actual parameters entered to trigger the callback.
- Returns
A list containing the callback dictionaries to be called.
Notes
This function should be imported and added as a custom_call parameter to add the event when the event supports keywords in phrases as parameters. Keywords in parameters are one or more words separated by a comma. For instance, a ‘say yes, okay’ callback can be set to trigger when the player says something containing either “yes” or “okay” (maybe ‘say I don’t like it, but okay’).