Add EditorPlugin.build() build callbacks

This commit is contained in:
Will Nations 2018-01-08 09:55:22 -06:00
parent 1fea0adc5c
commit 732a877b21
5 changed files with 37 additions and 4 deletions

View File

@ -412,6 +412,18 @@ void EditorData::paste_object_params(Object *p_object) {
} }
} }
bool EditorData::call_build() {
bool result = true;
for (int i = 0; i < editor_plugins.size() && result; i++) {
result &= editor_plugins[i]->build();
}
return result;
}
UndoRedo &EditorData::get_undo_redo() { UndoRedo &EditorData::get_undo_redo() {
return undo_redo; return undo_redo;

View File

@ -196,6 +196,7 @@ public:
NodePath get_edited_scene_live_edit_root(); NodePath get_edited_scene_live_edit_root();
bool check_and_update_scene(int p_idx); bool check_and_update_scene(int p_idx);
void move_edited_scene_to_index(int p_idx); void move_edited_scene_to_index(int p_idx);
bool call_build();
void set_plugin_window_layout(Ref<ConfigFile> p_layout); void set_plugin_window_layout(Ref<ConfigFile> p_layout);
void get_plugin_window_layout(Ref<ConfigFile> p_layout); void get_plugin_window_layout(Ref<ConfigFile> p_layout);

View File

@ -4527,12 +4527,21 @@ EditorBuildCallback EditorNode::build_callbacks[EditorNode::MAX_BUILD_CALLBACKS]
bool EditorNode::_call_build() { bool EditorNode::_call_build() {
for (int i = 0; i < build_callback_count; i++) { bool builds_successful = true;
if (!build_callbacks[i]())
return false; for (int i = 0; i < build_callback_count && builds_successful; i++) {
if (!build_callbacks[i]()) {
ERR_PRINT("A Godot Engine build callback failed.");
builds_successful = false;
}
} }
return true; if (builds_successful && !editor_data.call_build()) {
ERR_PRINT("An EditorPlugin build callback failed.");
builds_successful = false;
}
return builds_successful;
} }
void EditorNode::_inherit_imported(const String &p_action) { void EditorNode::_inherit_imported(const String &p_action) {

View File

@ -614,6 +614,15 @@ void EditorPlugin::get_window_layout(Ref<ConfigFile> p_layout) {
} }
} }
bool EditorPlugin::build() {
if (get_script_instance() && get_script_instance()->has_method("build")) {
return get_script_instance()->call("build");
}
return true;
}
void EditorPlugin::queue_save_layout() const { void EditorPlugin::queue_save_layout() const {
EditorNode::get_singleton()->save_layout(); EditorNode::get_singleton()->save_layout();
@ -686,6 +695,7 @@ void EditorPlugin::_bind_methods() {
ClassDB::add_virtual_method(get_class_static(), MethodInfo(Variant::POOL_STRING_ARRAY, "get_breakpoints")); ClassDB::add_virtual_method(get_class_static(), MethodInfo(Variant::POOL_STRING_ARRAY, "get_breakpoints"));
ClassDB::add_virtual_method(get_class_static(), MethodInfo("set_window_layout", PropertyInfo(Variant::OBJECT, "layout", PROPERTY_HINT_RESOURCE_TYPE, "ConfigFile"))); ClassDB::add_virtual_method(get_class_static(), MethodInfo("set_window_layout", PropertyInfo(Variant::OBJECT, "layout", PROPERTY_HINT_RESOURCE_TYPE, "ConfigFile")));
ClassDB::add_virtual_method(get_class_static(), MethodInfo("get_window_layout", PropertyInfo(Variant::OBJECT, "layout", PROPERTY_HINT_RESOURCE_TYPE, "ConfigFile"))); ClassDB::add_virtual_method(get_class_static(), MethodInfo("get_window_layout", PropertyInfo(Variant::OBJECT, "layout", PROPERTY_HINT_RESOURCE_TYPE, "ConfigFile")));
ClassDB::add_virtual_method(get_class_static(), MethodInfo(Variant::BOOL, "build"));
ADD_SIGNAL(MethodInfo("scene_changed", PropertyInfo(Variant::OBJECT, "scene_root", PROPERTY_HINT_RESOURCE_TYPE, "Node"))); ADD_SIGNAL(MethodInfo("scene_changed", PropertyInfo(Variant::OBJECT, "scene_root", PROPERTY_HINT_RESOURCE_TYPE, "Node")));
ADD_SIGNAL(MethodInfo("scene_closed", PropertyInfo(Variant::STRING, "filepath"))); ADD_SIGNAL(MethodInfo("scene_closed", PropertyInfo(Variant::STRING, "filepath")));

View File

@ -186,6 +186,7 @@ public:
virtual void set_window_layout(Ref<ConfigFile> p_layout); virtual void set_window_layout(Ref<ConfigFile> p_layout);
virtual void get_window_layout(Ref<ConfigFile> p_layout); virtual void get_window_layout(Ref<ConfigFile> p_layout);
virtual void edited_scene_changed() {} // if changes are pending in editor, apply them virtual void edited_scene_changed() {} // if changes are pending in editor, apply them
virtual bool build(); // builds with external tools. Returns true if safe to continue running scene.
EditorInterface *get_editor_interface(); EditorInterface *get_editor_interface();