From 472d7138239764514add14905152b8703a5904f9 Mon Sep 17 00:00:00 2001 From: Mads Marquart Date: Thu, 9 May 2024 22:53:17 +0200 Subject: [PATCH 1/2] Fix paths joining when compiling for Mac Catalyst --- src/lib.rs | 10 +++++----- tests/test.rs | 37 +++++++++++++++++++++++++++++++++++++ 2 files changed, 42 insertions(+), 5 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index cb2e51ca..296addc9 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -2713,19 +2713,19 @@ impl Build { // link to iOS-specific frameworks, we should have the support // library stubs in the include and library search path. let sdk_path = self.apple_sdk_root(&sdk_details.sdk)?; - let ios_support = PathBuf::from(sdk_path).join("/System/iOSSupport"); + let ios_support = PathBuf::from(sdk_path).join("System/iOSSupport"); cmd.args.extend([ // Header search path OsString::from("-isystem"), - ios_support.join("/usr/include").into(), + ios_support.join("usr/include").into(), // Framework header search path OsString::from("-iframework"), - ios_support.join("/System/Library/Frameworks").into(), + ios_support.join("System/Library/Frameworks").into(), // Library search path { let mut s = OsString::from("-L"); - s.push(&ios_support.join("/usr/lib")); + s.push(&ios_support.join("usr/lib")); s }, // Framework linker search path @@ -2734,7 +2734,7 @@ impl Build { // `-iframework` implies it, but let's keep it in for // clarity. let mut s = OsString::from("-F"); - s.push(&ios_support.join("/System/Library/Frameworks")); + s.push(&ios_support.join("System/Library/Frameworks")); s }, ]); diff --git a/tests/test.rs b/tests/test.rs index e9bbc94a..8fc8da64 100644 --- a/tests/test.rs +++ b/tests/test.rs @@ -584,6 +584,43 @@ fn clang_apple_tvos() { } } +#[cfg(target_os = "macos")] +#[test] +fn clang_apple_mac_catalyst() { + let output = std::process::Command::new("xcrun") + .args(["--show-sdk-path", "--sdk", "macosx"]) + .output() + .unwrap(); + if !output.status.success() { + return; + } + let sdkroot = std::str::from_utf8(&output.stdout).unwrap().trim(); + + let test = Test::clang(); + test.gcc() + .target("aarch64-apple-ios-macabi") + .__set_env("IPHONEOS_DEPLOYMENT_TARGET", "15.0") + .file("foo.c") + .compile("foo"); + let execution = test.cmd(0); + + // TODO: Add version to target here + execution.must_have("--target=arm64-apple-ios-macabi"); + execution.must_have_in_order("-isysroot", sdkroot); + execution.must_have_in_order( + "-isystem", + &format!("{sdkroot}/System/iOSSupport/usr/include"), + ); + execution.must_have_in_order( + "-iframework", + &format!("{sdkroot}/System/iOSSupport/System/Library/Frameworks"), + ); + execution.must_have(&format!("-L{sdkroot}/System/iOSSupport/usr/lib")); + execution.must_have(&format!( + "-F{sdkroot}/System/iOSSupport/System/Library/Frameworks" + )); +} + #[cfg(target_os = "macos")] #[test] fn clang_apple_tvsimulator() { From 9742745cd3421a994420a9326bd7b46b53f99357 Mon Sep 17 00:00:00 2001 From: Mads Marquart Date: Thu, 9 May 2024 22:30:11 +0200 Subject: [PATCH 2/2] Make it clear that Catalyst-specific flags are an extension to -isysroot --- src/lib.rs | 65 +++++++++++++++++++++++++++--------------------------- 1 file changed, 32 insertions(+), 33 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 296addc9..9b2816fc 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -2705,39 +2705,38 @@ impl Build { let sdk_path = self.apple_sdk_root(&sdk_details.sdk)?; cmd.args.push("-isysroot".into()); - cmd.args.push(sdk_path); - } - - if let AppleArchSpec::Catalyst(_) = arch { - // Mac Catalyst uses the macOS SDK, but to compile against and - // link to iOS-specific frameworks, we should have the support - // library stubs in the include and library search path. - let sdk_path = self.apple_sdk_root(&sdk_details.sdk)?; - let ios_support = PathBuf::from(sdk_path).join("System/iOSSupport"); - - cmd.args.extend([ - // Header search path - OsString::from("-isystem"), - ios_support.join("usr/include").into(), - // Framework header search path - OsString::from("-iframework"), - ios_support.join("System/Library/Frameworks").into(), - // Library search path - { - let mut s = OsString::from("-L"); - s.push(&ios_support.join("usr/lib")); - s - }, - // Framework linker search path - { - // Technically, we _could_ avoid emitting `-F`, as - // `-iframework` implies it, but let's keep it in for - // clarity. - let mut s = OsString::from("-F"); - s.push(&ios_support.join("System/Library/Frameworks")); - s - }, - ]); + cmd.args.push(sdk_path.clone()); + + if let AppleArchSpec::Catalyst(_) = arch { + // Mac Catalyst uses the macOS SDK, but to compile against and + // link to iOS-specific frameworks, we should have the support + // library stubs in the include and library search path. + let ios_support = PathBuf::from(sdk_path).join("System/iOSSupport"); + + cmd.args.extend([ + // Header search path + OsString::from("-isystem"), + ios_support.join("usr/include").into(), + // Framework header search path + OsString::from("-iframework"), + ios_support.join("System/Library/Frameworks").into(), + // Library search path + { + let mut s = OsString::from("-L"); + s.push(&ios_support.join("usr/lib")); + s + }, + // Framework linker search path + { + // Technically, we _could_ avoid emitting `-F`, as + // `-iframework` implies it, but let's keep it in for + // clarity. + let mut s = OsString::from("-F"); + s.push(&ios_support.join("System/Library/Frameworks")); + s + }, + ]); + } } Ok(())