浏览代码

WinRT: Fix exporting problems

- Replace spaces with %20, since appx don't like it.
- Use .zip extension for custom package templates.
George Marques 8 年之前
父节点
当前提交
92ac3869d3
共有 1 个文件被更改,包括 8 次插入8 次删除
  1. 8 8
      platform/winrt/export/export.cpp

+ 8 - 8
platform/winrt/export/export.cpp

@@ -616,7 +616,7 @@ void AppxPackager::make_content_types() {
 Vector<uint8_t> AppxPackager::make_file_header(FileMeta p_file_meta) {
 Vector<uint8_t> AppxPackager::make_file_header(FileMeta p_file_meta) {
 
 
 	Vector<uint8_t> buf;
 	Vector<uint8_t> buf;
-	buf.resize(BASE_FILE_HEADER_SIZE + p_file_meta.name.length());
+	buf.resize(BASE_FILE_HEADER_SIZE + p_file_meta.name.replace(" ", "%20").length());
 
 
 	int offs = 0;
 	int offs = 0;
 	// Write magic
 	// Write magic
@@ -644,13 +644,13 @@ Vector<uint8_t> AppxPackager::make_file_header(FileMeta p_file_meta) {
 	offs += buf_put_int32(p_file_meta.uncompressed_size, &buf[offs]);
 	offs += buf_put_int32(p_file_meta.uncompressed_size, &buf[offs]);
 
 
 	// File name length
 	// File name length
-	offs += buf_put_int16(p_file_meta.name.length(), &buf[offs]);
+	offs += buf_put_int16(p_file_meta.name.replace(" ", "%20").length(), &buf[offs]);
 
 
 	// Extra data length
 	// Extra data length
 	offs += buf_put_int16(0, &buf[offs]);
 	offs += buf_put_int16(0, &buf[offs]);
 
 
 	// File name
 	// File name
-	offs += buf_put_string(p_file_meta.name, &buf[offs]);
+	offs += buf_put_string(p_file_meta.name.replace(" ", "%20"), &buf[offs]);
 
 
 	// Done!
 	// Done!
 	return buf;
 	return buf;
@@ -660,7 +660,7 @@ void AppxPackager::store_central_dir_header(const FileMeta p_file, bool p_do_has
 
 
 	Vector<uint8_t> &buf = central_dir_data;
 	Vector<uint8_t> &buf = central_dir_data;
 	int offs = buf.size();
 	int offs = buf.size();
-	buf.resize(buf.size() + BASE_CENTRAL_DIR_SIZE + p_file.name.length());
+	buf.resize(buf.size() + BASE_CENTRAL_DIR_SIZE + p_file.name.replace(" ", "%20").length());
 
 
 	// Write magic
 	// Write magic
 	offs += buf_put_int32(CENTRAL_DIR_MAGIC, &buf[offs]);
 	offs += buf_put_int32(CENTRAL_DIR_MAGIC, &buf[offs]);
@@ -686,7 +686,7 @@ void AppxPackager::store_central_dir_header(const FileMeta p_file, bool p_do_has
 	offs += buf_put_int32(p_file.uncompressed_size, &buf[offs]);
 	offs += buf_put_int32(p_file.uncompressed_size, &buf[offs]);
 
 
 	// File name length
 	// File name length
-	offs += buf_put_int16(p_file.name.length(), &buf[offs]);
+	offs += buf_put_int16(p_file.name.replace(" ", "%20").length(), &buf[offs]);
 
 
 	// Extra field length
 	// Extra field length
 	offs += buf_put_int16(0, &buf[offs]);
 	offs += buf_put_int16(0, &buf[offs]);
@@ -703,7 +703,7 @@ void AppxPackager::store_central_dir_header(const FileMeta p_file, bool p_do_has
 	offs += buf_put_int32(p_file.zip_offset, &buf[offs]);
 	offs += buf_put_int32(p_file.zip_offset, &buf[offs]);
 
 
 	// File name
 	// File name
-	offs += buf_put_string(p_file.name, &buf[offs]);
+	offs += buf_put_string(p_file.name.replace(" ", "%20"), &buf[offs]);
 
 
 #ifdef OPENSSL_ENABLED
 #ifdef OPENSSL_ENABLED
 	// Calculate the hash for signing
 	// Calculate the hash for signing
@@ -1968,8 +1968,8 @@ bool EditorExportPlatformWinrt::_get(const StringName &p_name, Variant &r_ret) c
 
 
 void EditorExportPlatformWinrt::_get_property_list(List<PropertyInfo> *p_list) const {
 void EditorExportPlatformWinrt::_get_property_list(List<PropertyInfo> *p_list) const {
 
 
-	p_list->push_back(PropertyInfo(Variant::STRING, "custom_package/debug", PROPERTY_HINT_GLOBAL_FILE, "appx"));
-	p_list->push_back(PropertyInfo(Variant::STRING, "custom_package/release", PROPERTY_HINT_GLOBAL_FILE, "appx"));
+	p_list->push_back(PropertyInfo(Variant::STRING, "custom_package/debug", PROPERTY_HINT_GLOBAL_FILE, "zip"));
+	p_list->push_back(PropertyInfo(Variant::STRING, "custom_package/release", PROPERTY_HINT_GLOBAL_FILE, "zip"));
 
 
 	p_list->push_back(PropertyInfo(Variant::INT, "architecture/target", PROPERTY_HINT_ENUM, "ARM,x86,x64"));
 	p_list->push_back(PropertyInfo(Variant::INT, "architecture/target", PROPERTY_HINT_ENUM, "ARM,x86,x64"));