-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enable EditorPlugin
added by modules and GDExtensions (reverted)
#90608
Enable EditorPlugin
added by modules and GDExtensions (reverted)
#90608
Conversation
To me the main question is: Why do we need separate methods to enable / disable plugins from extensions in the first place? The normal add_editor_plugin() / remove_editor_plugin() already has a way to enforce enabling the plugin using its p_config_changed parameter (I think this is what Raul mentioned earlier.) I see in the code that for some reason GDExtension-based EditorPlugins are handled differently now, but I think it would be better conceptually, if plugins defined by GDExtensions would be handled the same way as plugins defined in modules. So maybe we should just refactor this and expose the normal add_editor_plugin() / remove_editor_plugin() over the GDExtension / Godot API. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, this looks good to me!
In Godot itself, editor plugins are typically registered via There's a handful of cases where editor plugins are registered by directly calling It seems those 7 cases are doing that because Perhaps we change |
After looking at the code in more detail, my suggestion would be to turn the EditorPlugins class into a GDCLASS and expose it early to GDExtensions. The class would be exposed as ABSTRACT, with only a couple of static methods. Its purpose would be twofold:
At the same time we should make EditorNode::add/remove_editor_plugin private (and make EditorPlugins a friend) API wise, we can keep the add_by_type<> method but extend it to work like this (pseudocode):
We can also have the add_editor_plugin() and remove_editor_plugin() method pairs in 2 variants:
All of these methods can be used prior to the creation of EditorNode or after it. One final method that is only exposed to EditorNode:
This would be called by EditorNode during its construction. It will call the node->add_editor_plugin(..., true) for each pre-registered plugin. The advantages of this refactoring:
|
I don't think we want this, though. This would make this class and its methods available to script, which we specifically didn't want to do, which is why we added functions to In any case, I think this is becoming a tangent. The main point of this PR is to call I do see your point that we could use the 2nd argument of However, your proposal mostly concerns cleaning up how |
add_editor_plugin(plugin); | ||
plugin->enable_plugin(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As @kisg points out, we could alternatively implement this by doing:
add_editor_plugin(plugin); | |
plugin->enable_plugin(); | |
add_editor_plugin(plugin, true); |
If we do that, though, we'd probably want to change the name of that argument, since the name is currently p_config_changed
, which doesn't make sense in this context.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I was thinking that, even though p_config_changed
is currently only used to determine if enable_plugin()
is called, it may be used for more stuff in the future and I didn't want to change its meaning. But I'm happy to change it if we're fine with that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The current logic for p_config_changed
seems to be a toggle for on/off:
void EditorNode::set_addon_plugin_enabled(const String &p_addon, bool p_enabled, bool p_config_changed) {
...
if (!p_enabled) {
EditorPlugin *addon = addon_name_to_plugin[addon_path];
remove_editor_plugin(addon, p_config_changed);
...
return;
}
...
add_editor_plugin(ep, p_config_changed);
...
}
add_editor_plugin
enables the plugin if p_config_changed
, and remove_editor_plugin
disables the plugin if p_config_changed
.
So I think we can rely on that behavior, but I'd rename the bool in add_editor_plugin
and remove_editor_plugin
respectively to p_enable_plugin
and p_disable_plugin
.
That's being said I'm a bit confused about the difference between adding and enabling, and removing and disabling. Especially the latter two - can one remove a plugin without it being also disabled?
Edit: Shouldn't be blocking for this PR though IMO, this can be tweaked later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
CC @KoBeWi
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One can add a plugin but not enable it (see the Activate now checkbox when creating GDScript plugins). You can also always enable/disable plugins from project settings.
GDExtension and module plugins don't really allow enabling/disabling plugins1, I think it's implied that these plugins are always enabled when added and disabled when removed. But before this PR the _enable_plugin
and _disable_plugin
virtual methods were never called.
The motivation behind this PR was to maintain consistency with the current scripting behavior in GDExtension plugins. This is important to me since I want to avoid behavior changes for the .NET bindings when moving from scripting to GDExtension.
I agree about removing without disabling being confusing, I'd assume removing always imply disabling. I forgot about disabling in this PR though, because the .NET plugin I'm working on doesn't override _disable_plugin
so I didn't notice.
Footnotes
-
This may change in the future for GDExtensions, since the GDExtension team wants to allow enabling/disabling GDExtensions in project settings. ↩
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When you open a project, the plugins listed in
project.godot
are added, but the enabled callback is not called.
Oh, then this PR is wrong.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So should this be reverted then?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You mean the whole PR or just this change? (or it's the same, idk)
I described the expected behavior, so the current one should be tweaked if it's different.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, it's the same. If we don't want GDExtension EditorPlugins to have _enable_plugin
called when Godot is launched, then we should revert the PR. But that means _enable_plugin
will never be called for GDExtension EditorPlugins since we have no way of enabling them (I guess they are considered to be pre-enabled when they are added).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is enter tree callback called on editor launch, so this use-case is covered. _enable_plugin
is for when user enables a plugin, and if GDExtensions can't be toggled, this callback is not for them.
add_editor_plugin(plugin); | ||
plugin->enable_plugin(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same here.
Thanks! |
EditorPlugin
added by modules and GDExtensionsEditorPlugin
added by modules and GDExtensions (reverted)
Before this PR, plugins coming from modules/GDExtensions were never enabled so the virtual method
_enable_plugin
was never called. This can be confusing behavior for users implementingEditorPlugin
coming from addons/scripting. I assume GDExtension plugins are considered always enabled, so I expect the_enable_plugin
to be called exactly once when they are initially added.MRP: GDExtensionEditorPluginCpp.zip