diff options
author | Ev1lbl0w <ricasubtil@gmail.com> | 2020-10-18 20:56:09 +0100 |
---|---|---|
committer | Ev1lbl0w <ricasubtil@gmail.com> | 2020-10-19 09:37:04 +0100 |
commit | 9b1db715fd51e0efa5e79bdaec5239e79b23061d (patch) | |
tree | 1c757f55a1ceb442d1f4593fa53bd01ebbb2c647 | |
parent | 4467412c9f78f3ddaf7edd4627ec7d629a6234df (diff) |
Allow Godot to import .ZIP files with non-regular structure
-rw-r--r-- | editor/project_manager.cpp | 27 |
1 files changed, 10 insertions, 17 deletions
diff --git a/editor/project_manager.cpp b/editor/project_manager.cpp index 6393aa30ed..41b81ea69c 100644 --- a/editor/project_manager.cpp +++ b/editor/project_manager.cpp @@ -99,6 +99,7 @@ private: FileDialog *fdialog_install; String zip_path; String zip_title; + String zip_root; AcceptDialog *dialog_error; String fav_dir; @@ -199,7 +200,9 @@ private: char fname[16384]; ret = unzGetCurrentFileInfo(pkg, &info, fname, 16384, nullptr, 0, nullptr, 0); - if (String(fname).ends_with("project.godot")) { + String fname_str = String(fname); + if (fname_str.ends_with("project.godot")) { + zip_root = fname_str.substr(0, fname_str.rfind("project.godot")); break; } @@ -515,44 +518,34 @@ private: String path = fname; - int depth = 1; //stuff from github comes with tag - bool skip = false; - while (depth > 0) { - int pp = path.find("/"); - if (pp == -1) { - skip = true; - break; - } - path = path.substr(pp + 1, path.length()); - depth--; - } - - if (skip || path == String()) { + if (path == String() || path == zip_root || !zip_root.is_subsequence_of(path)) { // } else if (path.ends_with("/")) { // a dir path = path.substr(0, path.length() - 1); + String rel_path = path.substr(zip_root.length()); DirAccess *da = DirAccess::create(DirAccess::ACCESS_FILESYSTEM); - da->make_dir(dir.plus_file(path)); + da->make_dir(dir.plus_file(rel_path)); memdelete(da); } else { Vector<uint8_t> data; data.resize(info.uncompressed_size); + String rel_path = path.substr(zip_root.length()); //read unzOpenCurrentFile(pkg); unzReadCurrentFile(pkg, data.ptrw(), data.size()); unzCloseCurrentFile(pkg); - FileAccess *f = FileAccess::open(dir.plus_file(path), FileAccess::WRITE); + FileAccess *f = FileAccess::open(dir.plus_file(rel_path), FileAccess::WRITE); if (f) { f->store_buffer(data.ptr(), data.size()); memdelete(f); } else { - failed_files.push_back(path); + failed_files.push_back(rel_path); } } |