Export working (for linux at least)

This commit is contained in:
Juan Linietsky 2017-03-21 19:34:26 -03:00
parent b5a06cecff
commit c37fad650f
5 changed files with 100 additions and 17 deletions

View File

@ -315,17 +315,20 @@ Error EditorExportPlatform::_save_zip_file(void *p_userdata, const String &p_pat
return OK; return OK;
} }
String EditorExportPlatform::find_export_template(String template_file_name, String *err) const { String EditorExportPlatform::find_export_template(String template_file_name) const {
String user_file = EditorSettings::get_singleton()->get_settings_path() + "/templates/" + itos(VERSION_MAJOR) + "." + itos(VERSION_MINOR) + "." + _MKSTR(VERSION_STATUS) + "/" + template_file_name; String base_name = itos(VERSION_MAJOR) + "." + itos(VERSION_MINOR) + "-" + _MKSTR(VERSION_STATUS) + "/" + template_file_name;
String user_file = EditorSettings::get_singleton()->get_settings_path() + "/templates/" + base_name;
String system_file = OS::get_singleton()->get_installed_templates_path(); String system_file = OS::get_singleton()->get_installed_templates_path();
bool has_system_path = (system_file != ""); bool has_system_path = (system_file != "");
system_file += template_file_name; system_file = system_file.plus_file(base_name);
print_line("test user file: " + user_file);
// Prefer user file // Prefer user file
if (FileAccess::exists(user_file)) { if (FileAccess::exists(user_file)) {
return user_file; return user_file;
} }
print_line("test system file: " + system_file);
// Now check system file // Now check system file
if (has_system_path) { if (has_system_path) {
@ -333,16 +336,9 @@ String EditorExportPlatform::find_export_template(String template_file_name, Str
return system_file; return system_file;
} }
} }
print_line("none,sorry");
// Not found return String(); //not found
if (err) {
*err += "No export template found at \"" + user_file + "\"";
if (has_system_path)
*err += "\n or \"" + system_file + "\".";
else
*err += ".";
}
return "";
} }
Ref<EditorExportPreset> EditorExportPlatform::create_preset() { Ref<EditorExportPreset> EditorExportPlatform::create_preset() {
@ -880,7 +876,42 @@ String EditorExportPlatformPC::get_binary_extension() const {
Error EditorExportPlatformPC::export_project(const Ref<EditorExportPreset> &p_preset, bool p_debug, const String &p_path, int p_flags) { Error EditorExportPlatformPC::export_project(const Ref<EditorExportPreset> &p_preset, bool p_debug, const String &p_path, int p_flags) {
return OK; String custom_debug = p_preset->get("custom_template/debug");
String custom_release = p_preset->get("custom_template/release");
String template_path = p_debug ? custom_debug : custom_release;
template_path = template_path.strip_edges();
if (template_path == String()) {
if (p_preset->get("binary_format/64_bits")) {
if (p_debug) {
template_path = find_export_template(debug_file_64);
} else {
template_path = find_export_template(release_file_64);
}
} else {
if (p_debug) {
template_path = find_export_template(debug_file_32);
} else {
template_path = find_export_template(release_file_32);
}
}
}
if (template_path != String() && !FileAccess::exists(template_path)) {
EditorNode::get_singleton()->show_warning(TTR("Template file not found:\n") + template_path);
return ERR_FILE_NOT_FOUND;
}
DirAccess *da = DirAccess::create(DirAccess::ACCESS_FILESYSTEM);
da->copy(template_path, p_path);
memdelete(da);
String pck_path = p_path.get_basename() + ".pck";
return save_pack(p_preset, pck_path);
} }
void EditorExportPlatformPC::set_extension(const String &p_extension) { void EditorExportPlatformPC::set_extension(const String &p_extension) {

View File

@ -152,7 +152,7 @@ private:
protected: protected:
virtual void get_preset_features(const Ref<EditorExportPreset> &p_preset, List<String> *r_features) = 0; virtual void get_preset_features(const Ref<EditorExportPreset> &p_preset, List<String> *r_features) = 0;
String find_export_template(String template_file_name, String *err = NULL) const; String find_export_template(String template_file_name) const;
public: public:
struct ExportOption { struct ExportOption {

View File

@ -229,9 +229,12 @@ void ProjectExportDialog::_edit_preset(int p_index) {
if (needs_templates) if (needs_templates)
export_templates_error->show(); export_templates_error->show();
get_ok()->set_disabled(true);
} else { } else {
export_error->show(); export_error->show();
export_templates_error->hide(); export_templates_error->hide();
get_ok()->set_disabled(false);
} }
updating = false; updating = false;
@ -642,6 +645,33 @@ void ProjectExportDialog::_open_export_template_manager() {
hide(); hide();
} }
void ProjectExportDialog::_export_project() {
Ref<EditorExportPreset> current = EditorExport::get_singleton()->get_export_preset(presets->get_current());
ERR_FAIL_COND(current.is_null());
Ref<EditorExportPlatform> platform = current->get_platform();
ERR_FAIL_COND(platform.is_null());
export_project->set_access(FileDialog::ACCESS_FILESYSTEM);
export_project->clear_filters();
String extension = platform->get_binary_extension();
if (extension != String()) {
export_project->add_filter("*." + extension + " ; " + platform->get_name() + " Export");
}
export_project->popup_centered_ratio();
}
void ProjectExportDialog::_export_project_to_path(const String &p_path) {
Ref<EditorExportPreset> current = EditorExport::get_singleton()->get_export_preset(presets->get_current());
ERR_FAIL_COND(current.is_null());
Ref<EditorExportPlatform> platform = current->get_platform();
ERR_FAIL_COND(platform.is_null());
Error err = platform->export_project(current, export_debug->is_pressed(), p_path, 0);
}
void ProjectExportDialog::_bind_methods() { void ProjectExportDialog::_bind_methods() {
ClassDB::bind_method("_add_preset", &ProjectExportDialog::_add_preset); ClassDB::bind_method("_add_preset", &ProjectExportDialog::_add_preset);
@ -663,6 +693,8 @@ void ProjectExportDialog::_bind_methods() {
ClassDB::bind_method("_export_pck_zip", &ProjectExportDialog::_export_pck_zip); ClassDB::bind_method("_export_pck_zip", &ProjectExportDialog::_export_pck_zip);
ClassDB::bind_method("_export_pck_zip_selected", &ProjectExportDialog::_export_pck_zip_selected); ClassDB::bind_method("_export_pck_zip_selected", &ProjectExportDialog::_export_pck_zip_selected);
ClassDB::bind_method("_open_export_template_manager", &ProjectExportDialog::_open_export_template_manager); ClassDB::bind_method("_open_export_template_manager", &ProjectExportDialog::_open_export_template_manager);
ClassDB::bind_method("_export_project", &ProjectExportDialog::_export_project);
ClassDB::bind_method("_export_project_to_path", &ProjectExportDialog::_export_project_to_path);
} }
ProjectExportDialog::ProjectExportDialog() { ProjectExportDialog::ProjectExportDialog() {
@ -828,6 +860,17 @@ ProjectExportDialog::ProjectExportDialog() {
export_templates_error->add_child(download_templates); export_templates_error->add_child(download_templates);
download_templates->connect("pressed", this, "_open_export_template_manager"); download_templates->connect("pressed", this, "_open_export_template_manager");
export_project = memnew(FileDialog);
export_project->set_access(FileDialog::ACCESS_FILESYSTEM);
add_child(export_project);
export_project->connect("file_selected", this, "_export_project_to_path");
export_button->connect("pressed", this, "_export_project");
export_debug = memnew(CheckButton);
export_debug->set_text(TTR("Export With Debug"));
export_debug->set_pressed(true);
export_project->get_vbox()->add_child(export_debug);
set_hide_on_ok(false); set_hide_on_ok(false);
editor_icons = "EditorIcons"; editor_icons = "EditorIcons";

View File

@ -64,8 +64,8 @@ private:
PropertyEditor *parameters; PropertyEditor *parameters;
CheckButton *runnable; CheckButton *runnable;
EditorFileDialog *pck_export; //EditorFileDialog *pck_export;
EditorFileDialog *file_export; //EditorFileDialog *file_export;
Button *button_export; Button *button_export;
bool updating; bool updating;
@ -119,12 +119,17 @@ private:
void drop_data_fw(const Point2 &p_point, const Variant &p_data, Control *p_from); void drop_data_fw(const Point2 &p_point, const Variant &p_data, Control *p_from);
FileDialog *export_pck_zip; FileDialog *export_pck_zip;
FileDialog *export_project;
CheckButton *export_debug;
void _open_export_template_manager(); void _open_export_template_manager();
void _export_pck_zip(); void _export_pck_zip();
void _export_pck_zip_selected(const String &p_path); void _export_pck_zip_selected(const String &p_path);
void _export_project();
void _export_project_to_path(const String &p_path);
protected: protected:
void _notification(int p_what); void _notification(int p_what);
static void _bind_methods(); static void _bind_methods();

View File

@ -42,7 +42,11 @@ void register_x11_exporter() {
logo->create_from_image(img); logo->create_from_image(img);
platform->set_logo(logo); platform->set_logo(logo);
platform->set_name("Linux/X11"); platform->set_name("Linux/X11");
platform->set_extension(""); platform->set_extension("bin");
platform->set_release_32("linux_x11_32_release");
platform->set_debug_32("linux_x11_32_debug");
platform->set_release_64("linux_x11_64_release");
platform->set_debug_64("linux_x11_64_debug");
EditorExport::get_singleton()->add_export_platform(platform); EditorExport::get_singleton()->add_export_platform(platform);