From 1f8876551d314e9b018d713c9376f4edcab82ebd Mon Sep 17 00:00:00 2001 From: Lucas Nogueira Date: Sat, 31 Aug 2024 10:27:05 -0300 Subject: [PATCH] fix(cli): iOS build targetting the simulator Fixes bundling apps to test using the iOS simulator, in this case we cannot export the package, but use the raw .app instead. --- .changes/fix-ios-build-simulator.md | 6 +++++ crates/tauri-cli/src/mobile/ios/build.rs | 29 +++++++++++++++++++----- 2 files changed, 29 insertions(+), 6 deletions(-) create mode 100644 .changes/fix-ios-build-simulator.md diff --git a/.changes/fix-ios-build-simulator.md b/.changes/fix-ios-build-simulator.md new file mode 100644 index 000000000000..629a1df56d13 --- /dev/null +++ b/.changes/fix-ios-build-simulator.md @@ -0,0 +1,6 @@ +--- +"tauri-cli": patch:bug +"@tauri-apps/cli": patch:bug +--- + +Fixes `ios build --target [aarch64-sim | x86_64]` failing to generate the app bundle for the iOS simulator. diff --git a/crates/tauri-cli/src/mobile/ios/build.rs b/crates/tauri-cli/src/mobile/ios/build.rs index fdcbc0f83e9a..75e8fed68624 100644 --- a/crates/tauri-cli/src/mobile/ios/build.rs +++ b/crates/tauri-cli/src/mobile/ios/build.rs @@ -307,14 +307,31 @@ fn run_build( export_config = export_config.authentication_credentials(credentials); } - target.export(config, env, noise_level, export_config)?; + let out_dir = config.export_dir().join(target.arch); - if let Ok(ipa_path) = config.ipa_path() { - let out_dir = config.export_dir().join(target.arch); + if target.sdk == "iphonesimulator" { fs::create_dir_all(&out_dir)?; - let path = out_dir.join(ipa_path.file_name().unwrap()); - fs::rename(&ipa_path, &path)?; + + let app_path = config + .archive_dir() + .join(format!("{}.xcarchive", config.scheme())) + .join("Products") + .join("Applications") + .join(config.app().stylized_name()) + .with_extension("app"); + + let path = out_dir.join(app_path.file_name().unwrap()); + fs::rename(&app_path, &path)?; out_files.push(path); + } else { + target.export(config, env, noise_level, export_config)?; + + if let Ok(ipa_path) = config.ipa_path() { + fs::create_dir_all(&out_dir)?; + let path = out_dir.join(ipa_path.file_name().unwrap()); + fs::rename(&ipa_path, &path)?; + out_files.push(path); + } } Ok(()) @@ -322,7 +339,7 @@ fn run_build( ) .map_err(|e: TargetInvalid| anyhow::anyhow!(e.to_string()))??; - log_finished(out_files, "IPA"); + log_finished(out_files, "iOS Bundle"); Ok(handle) }