Merge pull request #87908 from bruvzg/mac_gen_plist

[macOS] Generate min. `Info.plist` for frameworks if it's missing. Validate framework bundle ID characters.
This commit is contained in:
Rémi Verschelde 2024-02-13 17:24:07 +01:00
commit ae603f2dc6
No known key found for this signature in database
GPG Key ID: C3336907360768E1
2 changed files with 71 additions and 2 deletions

View File

@ -1007,6 +1007,12 @@ Error EditorExportPlatformIOS::_convert_to_framework(const String &p_source, con
// Creating Info.plist // Creating Info.plist
{ {
String lib_clean_name = file_name;
for (int i = 0; i < lib_clean_name.length(); i++) {
if (!is_ascii_alphanumeric_char(lib_clean_name[i]) && lib_clean_name[i] != '.' && lib_clean_name[i] != '-') {
lib_clean_name[i] = '-';
}
}
String info_plist_format = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" String info_plist_format = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
"<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n" "<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n"
"<plist version=\"1.0\">\n" "<plist version=\"1.0\">\n"
@ -1014,7 +1020,7 @@ Error EditorExportPlatformIOS::_convert_to_framework(const String &p_source, con
" <key>CFBundleShortVersionString</key>\n" " <key>CFBundleShortVersionString</key>\n"
" <string>1.0</string>\n" " <string>1.0</string>\n"
" <key>CFBundleIdentifier</key>\n" " <key>CFBundleIdentifier</key>\n"
" <string>$id.framework.$name</string>\n" " <string>$id.framework.$cl_name</string>\n"
" <key>CFBundleName</key>\n" " <key>CFBundleName</key>\n"
" <string>$name</string>\n" " <string>$name</string>\n"
" <key>CFBundleExecutable</key>\n" " <key>CFBundleExecutable</key>\n"
@ -1032,7 +1038,7 @@ Error EditorExportPlatformIOS::_convert_to_framework(const String &p_source, con
" </dict>\n" " </dict>\n"
"</plist>"; "</plist>";
String info_plist = info_plist_format.replace("$id", p_id).replace("$name", file_name); String info_plist = info_plist_format.replace("$id", p_id).replace("$name", file_name).replace("$cl_name", lib_clean_name);
Ref<FileAccess> f = FileAccess::open(p_destination.path_join("Info.plist"), FileAccess::WRITE); Ref<FileAccess> f = FileAccess::open(p_destination.path_join("Info.plist"), FileAccess::WRITE);
if (f.is_valid()) { if (f.is_valid()) {

View File

@ -1106,10 +1106,73 @@ Error EditorExportPlatformMacOS::_copy_and_sign_files(Ref<DirAccess> &dir_access
add_message(EXPORT_MESSAGE_INFO, TTR("Export"), vformat(TTR("Relative symlinks are not supported, exported \"%s\" might be broken!"), p_src_path.get_file())); add_message(EXPORT_MESSAGE_INFO, TTR("Export"), vformat(TTR("Relative symlinks are not supported, exported \"%s\" might be broken!"), p_src_path.get_file()));
#endif #endif
print_verbose("export framework: " + p_src_path + " -> " + p_in_app_path); print_verbose("export framework: " + p_src_path + " -> " + p_in_app_path);
bool plist_misssing = false;
Ref<PList> plist;
plist.instantiate();
plist->load_file(p_src_path.path_join("Resources").path_join("Info.plist"));
Ref<PListNode> root_node = plist->get_root();
if (root_node.is_null()) {
plist_misssing = true;
} else {
Dictionary root = root_node->get_value();
if (!root.has("CFBundleExecutable") || !root.has("CFBundleIdentifier") || !root.has("CFBundlePackageType") || !root.has("CFBundleInfoDictionaryVersion") || !root.has("CFBundleName") || !root.has("CFBundleSupportedPlatforms")) {
plist_misssing = true;
}
}
err = dir_access->make_dir_recursive(p_in_app_path); err = dir_access->make_dir_recursive(p_in_app_path);
if (err == OK) { if (err == OK) {
err = dir_access->copy_dir(p_src_path, p_in_app_path, -1, true); err = dir_access->copy_dir(p_src_path, p_in_app_path, -1, true);
} }
if (err == OK && plist_misssing) {
add_message(EXPORT_MESSAGE_WARNING, TTR("Export"), vformat(TTR("\"%s\": Info.plist missing or invalid, new Info.plist generated."), p_src_path.get_file()));
// Generate Info.plist
String lib_name = p_src_path.get_basename().get_file();
String lib_id = p_preset->get("application/bundle_identifier");
String lib_clean_name = lib_name;
for (int i = 0; i < lib_clean_name.length(); i++) {
if (!is_ascii_alphanumeric_char(lib_clean_name[i]) && lib_clean_name[i] != '.' && lib_clean_name[i] != '-') {
lib_clean_name[i] = '-';
}
}
String info_plist_format = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
"<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/PropertyList-1.0.dtd\">\n"
"<plist version=\"1.0\">\n"
" <dict>\n"
" <key>CFBundleExecutable</key>\n"
" <string>$name</string>\n"
" <key>CFBundleIdentifier</key>\n"
" <string>$id.framework.$cl_name</string>\n"
" <key>CFBundleInfoDictionaryVersion</key>\n"
" <string>6.0</string>\n"
" <key>CFBundleName</key>\n"
" <string>$name</string>\n"
" <key>CFBundlePackageType</key>\n"
" <string>FMWK</string>\n"
" <key>CFBundleShortVersionString</key>\n"
" <string>1.0.0</string>\n"
" <key>CFBundleSupportedPlatforms</key>\n"
" <array>\n"
" <string>MacOSX</string>\n"
" </array>\n"
" <key>CFBundleVersion</key>\n"
" <string>1.0.0</string>\n"
" <key>LSMinimumSystemVersion</key>\n"
" <string>10.12</string>\n"
" </dict>\n"
"</plist>";
String info_plist = info_plist_format.replace("$id", lib_id).replace("$name", lib_name).replace("$cl_name", lib_clean_name);
err = dir_access->make_dir_recursive(p_in_app_path.path_join("Resources"));
Ref<FileAccess> f = FileAccess::open(p_in_app_path.path_join("Resources").path_join("Info.plist"), FileAccess::WRITE);
if (f.is_valid()) {
f->store_string(info_plist);
}
}
} else { } else {
print_verbose("export dylib: " + p_src_path + " -> " + p_in_app_path); print_verbose("export dylib: " + p_src_path + " -> " + p_in_app_path);
err = dir_access->copy(p_src_path, p_in_app_path); err = dir_access->copy(p_src_path, p_in_app_path);