Patch #26439
Plugin load order defined by plugin checks
Status: | New | Start date: | ||
---|---|---|---|---|
Priority: | Normal | Due date: | ||
Assignee: | - | % Done: | 0% | |
Category: | Plugin API | |||
Target version: | - |
Description
This patch allows for a plugin to delay loading until a set of requirements is met. This could be because I need for other plugin to be loaded first.
The ideia is to to have each plugin check at the top of init.rb for it's requirements and if they are not met to raise Redmine::Plugin::PluginDeferLoadError. This will signal the plugin load logic to try loading this plugin later.
The algorithm prevents infinite looping (by direct or indirect circular dependencies) by loading plugins by iterations. In each iteration amount of plugins to load must be lower.
The most common check made by plugins can be simplified by using at the top of the init.rb this line:
Redmine::Plugin.requires_plugin('redmine_plugin_name')
Regards
Related issues
History
#1
Updated by Tiago Gonçalves almost 5 years ago
#2
Updated by Go MAEDA almost 5 years ago
- Category set to Plugin API
#3
Updated by Go MAEDA almost 5 years ago
- Related to Feature #23131: Plugin load order defined by inter-plugin dependencies added
#4
Updated by Toshi MARUYAMA almost 5 years ago
- Description updated (diff)
#5
Updated by Vincent Robert over 3 years ago
Hello Tiago
Is this patch compatible with Redmine 4?
I quickly tried it, but I got some errors.
Thank you