leilukin-tumbleblog/includes/class/Modules.php

57 lines
1.7 KiB
PHP
Raw Normal View History

2024-06-20 14:10:42 +00:00
<?php
/**
* Class: Modules
* Contains various functions, acts as the backbone for all modules.
*/
class Modules {
# Array: $instances
# Holds all Module instantiations.
public static $instances = array();
# Boolean: $cancelled
# Is the module's execution cancelled?
public $cancelled = false;
# String: $safename
# The module's non-camelized name.
public $safename = "";
/**
* Function: setPriority
* Sets the priority of an action for the module this function is called from.
*
* Parameters:
* $name - Name of the trigger to respond to.
* $priority - Priority of the response.
*/
2025-01-13 09:56:01 +00:00
protected function setPriority(
$name,
$priority
): void {
2024-06-20 14:10:42 +00:00
Trigger::current()->priorities[$name][] = array(
"priority" => $priority,
"function" => array($this, $name)
);
}
/**
* Function: addAlias
* Allows a module to respond to a trigger with multiple functions and custom priorities.
*
* Parameters:
* $name - Name of the trigger to respond to.
* $function - Name of the class function to respond with.
* $priority - Priority of the response.
*/
2025-01-13 09:56:01 +00:00
protected function addAlias(
$name,
$function,
$priority = 10
): void {
2024-06-20 14:10:42 +00:00
Trigger::current()->priorities[$name][] = array(
"priority" => $priority,
"function" => array($this, $function)
);
}
}