Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support Maccatalyst for MAUI #1771

Merged
merged 10 commits into from
Apr 17, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 1 addition & 12 deletions .azurepipelines/build-release-packages-1es.yml
Original file line number Diff line number Diff line change
Expand Up @@ -116,13 +116,7 @@ extends:
SecretsFilter: 'appcenter-sdk-blob-storage-access-secret'
RunAsPreJob: false

- task: UseDotNet@2
displayName: 'Install .NET 7'
inputs:
packageType: 'sdk'
version: '7.0.308'

- bash: 'dotnet workload install android ios macos'
- bash: 'dotnet workload install android ios macos maccatalyst'
displayName: 'Install .NET workloads'

- task: cake-build.cake.cake-build-task.Cake@2
Expand Down Expand Up @@ -206,11 +200,6 @@ extends:
inputs:
secureFile: 'appcenter-pair-key.snk'

- task: UseDotNet@2
displayName: 'Use .NET Core sdk 6.0.x'
inputs:
version: 6.0.x

- powershell: |
# Run script
.\scripts\strong-named-sign.cmd "$(Build.ArtifactStagingDirectory)\assemblies" "$(Agent.TempDirectory)\appcenter-pair-key.snk"
Expand Down
9 changes: 9 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,19 @@

## Version 5.0.4 (In development)

### App Center

* **[Improvement]** Update DotNet target version to net7

#### Windows

* **[Improvement]** Improve UWP and WinUI app type checking.
* **[Improvement]** Update SQLitePCLRaw.bundle_green to version 2.1.7

#### Apple

* **[Improvement]** Support Mac Catalyst

___

## Version 5.0.3
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFrameworks>net7.0-ios;net7.0-macos</TargetFrameworks>
<TargetFrameworks>net7.0-ios;net7.0-macos;net7.0-maccatalyst</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<NoBindingEmbedding>false</NoBindingEmbedding>
</PropertyGroup>
Expand All @@ -10,7 +10,7 @@
<MtouchLink>SdkOnly</MtouchLink>
<MtouchHttpClientHandler>HttpClientHandler</MtouchHttpClientHandler>
</PropertyGroup>
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos'))">
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos')) Or $(TargetFramework.EndsWith('-maccatalyst'))">
<LinkMode>SdkOnly</LinkMode>
<SupportedOSPlatformVersion>10.14</SupportedOSPlatformVersion>
</PropertyGroup>
Expand Down Expand Up @@ -38,4 +38,12 @@
<Frameworks>CoreTelephony Security SystemConfiguration</Frameworks>
</NativeReference>
</ItemGroup>
<ItemGroup Condition="$(TargetFramework.EndsWith('-maccatalyst'))">
<NativeReference Include="..\..\..\externals\apple\maccatalyst\AppCenter.a">
<Kind>Static</Kind>
<ForceLoad>True</ForceLoad>
<LinkerFlags>-lsqlite3</LinkerFlags>
<Frameworks>CoreTelephony Security SystemConfiguration</Frameworks>
</NativeReference>
</ItemGroup>
</Project>
5 changes: 5 additions & 0 deletions SDK/AppCenter/Microsoft.AppCenter.Apple/global.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"sdk": {
"version": "6.0.402"
}
}
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFrameworks>net7.0-ios;net7.0-macos</TargetFrameworks>
<TargetFrameworks>net7.0-ios;net7.0-macos;net7.0-maccatalyst</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<NoBindingEmbedding>false</NoBindingEmbedding>
</PropertyGroup>
Expand All @@ -10,7 +10,7 @@
<MtouchLink>SdkOnly</MtouchLink>
<MtouchHttpClientHandler>HttpClientHandler</MtouchHttpClientHandler>
</PropertyGroup>
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos'))">
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos')) Or $(TargetFramework.EndsWith('-maccatalyst'))">
<LinkMode>SdkOnly</LinkMode>
<SupportedOSPlatformVersion>10.14</SupportedOSPlatformVersion>
</PropertyGroup>
Expand All @@ -34,6 +34,13 @@
<Frameworks>IOKit</Frameworks>
</NativeReference>
</ItemGroup>
<ItemGroup Condition="$(TargetFramework.EndsWith('-maccatalyst'))">
<NativeReference Include="..\..\..\externals\apple\maccatalyst\AppCenterAnalytics.a">
<Kind>Static</Kind>
<ForceLoad>True</ForceLoad>
<Frameworks>IOKit</Frameworks>
</NativeReference>
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\..\AppCenter\Microsoft.AppCenter.Apple\Microsoft.AppCenter.Apple.csproj" />
</ItemGroup>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFrameworks>net7.0-ios;net7.0-macos</TargetFrameworks>
<TargetFrameworks>net7.0-ios;net7.0-macos;net7.0-maccatalyst</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<NoBindingEmbedding>false</NoBindingEmbedding>
</PropertyGroup>
Expand All @@ -10,7 +10,7 @@
<MtouchLink>SdkOnly</MtouchLink>
<MtouchHttpClientHandler>HttpClientHandler</MtouchHttpClientHandler>
</PropertyGroup>
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos'))">
<PropertyGroup Condition="$(TargetFramework.EndsWith('-macos')) Or $(TargetFramework.EndsWith('-maccatalyst'))">
<LinkMode>SdkOnly</LinkMode>
<SupportedOSPlatformVersion>10.14</SupportedOSPlatformVersion>
</PropertyGroup>
Expand Down Expand Up @@ -38,6 +38,14 @@
<IsCxx>True</IsCxx>
</NativeReference>
</ItemGroup>
<ItemGroup Condition="$(TargetFramework.EndsWith('-maccatalyst'))">
<NativeReference Include="..\..\..\externals\apple\maccatalyst\AppCenterCrashes.a">
<Kind>Static</Kind>
<ForceLoad>True</ForceLoad>
<LinkerFlags>-lc++</LinkerFlags>
<IsCxx>True</IsCxx>
</NativeReference>
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\..\AppCenter\Microsoft.AppCenter.Apple\Microsoft.AppCenter.Apple.csproj" />
</ItemGroup>
Expand Down
67 changes: 48 additions & 19 deletions build.cake
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ var SdkStorageUrl = "https://mobilecentersdkdev.blob.core.windows.net/sdk/";
VersionReader.ReadVersions();
var AndroidUrl = $"{SdkStorageUrl}AppCenter-SDK-Android-{VersionReader.AndroidVersion}.zip";
var AppleUrl = $"{SdkStorageUrl}AppCenter-SDK-Apple-{VersionReader.AppleVersion}.zip";
var AppleXCFrameworkUrl = $"{SdkStorageUrl}AppCenter-SDK-Apple-XCFramework-{VersionReader.AppleVersion}.zip";

// Task Target for build
var Target = Argument("Target", Argument("t", "Default"));
Expand Down Expand Up @@ -101,30 +102,15 @@ Task("Externals-Android")
CopyFiles(files, AndroidExternals);
}).OnError(HandleError);

// Downloading iOS binaries.
Task("Externals-Apple")
.WithCriteria(() => IsRunningOnUnix())
.Does(() =>
public static void UnzipFile(this ICakeContext context, string zipFile, string outputPath)
{
var zipFile = System.IO.Path.Combine(AppleExternals, "apple.zip");
if (FileExists(zipFile))
{
return;
}
CleanDirectory(AppleExternals);

// Download zip file.
var authParams = Argument("StorageAuthParams", EnvironmentVariable("STORAGE_AUTH_PARAMS"));
var artifactUrl = $"{AppleUrl}{authParams}";
using (VerboseVerbosity())
DownloadFile(artifactUrl, zipFile);
using(var process = StartAndReturnProcess("unzip",
using(var process = context.StartAndReturnProcess("unzip",
new ProcessSettings
{
Arguments = new ProcessArgumentBuilder()
.Append(zipFile)
.Append("-d")
.Append(AppleExternals),
.Append(outputPath),
RedirectStandardOutput = true,
}))
{
Expand All @@ -134,15 +120,39 @@ Task("Externals-Apple")
throw new Exception($"Failed to unzip {zipFile}");
}
}
}

// Downloading iOS binaries.
Task("Externals-Apple")
.WithCriteria(() => IsRunningOnUnix())
.Does(() =>
{
var zipFile = System.IO.Path.Combine(AppleExternals, "apple.zip");
var zipXCFrameworkFile = System.IO.Path.Combine(AppleExternals, "apple-xcframework.zip");
var XCFrameworkOutputDir = System.IO.Path.Combine(AppleExternals, "xcframework");

CleanDirectory(AppleExternals);

// Download framework and xcframework files.
var authParams = Argument("StorageAuthParams", EnvironmentVariable("STORAGE_AUTH_PARAMS"));
using (VerboseVerbosity())
{
DownloadFile($"{AppleUrl}{authParams}", zipFile);
DownloadFile($"{AppleXCFrameworkUrl}{authParams}", zipXCFrameworkFile);
}

Context.UnzipFile(zipFile, AppleExternals);
Context.UnzipFile(zipXCFrameworkFile, XCFrameworkOutputDir);

var iosFrameworksLocation = System.IO.Path.Combine(AppleExternals, "AppCenter-SDK-Apple/iOS");
var macosFrameworksLocation = System.IO.Path.Combine(AppleExternals, "AppCenter-SDK-Apple/macOS");
var xcframeworkLocation = System.IO.Path.Combine(XCFrameworkOutputDir, "AppCenter-SDK-Apple");

// Move iOS frameworks.
var iosExternals = System.IO.Path.Combine(AppleExternals, "ios");
CleanDirectory(iosExternals);

// Copy the AppCenter binaries directly from the frameworks and add the ".a" extension.s
// Copy the AppCenter binaries directly from the frameworks and add the ".a" extension.
var files = GetFiles($"{iosFrameworksLocation}/*.framework/AppCenter*");
foreach (var file in files)
{
Expand All @@ -157,6 +167,25 @@ Task("Externals-Apple")
MoveDirectory($"{iosFrameworksLocation}/{distributeBundle}", $"{iosExternals}/{distributeBundle}");
}

// Move Maccatalyst frameworks.
var maccatalystExternals = System.IO.Path.Combine(AppleExternals, "maccatalyst");
CleanDirectory(maccatalystExternals);

// Copy the AppCenter binaries directly from the frameworks and add the ".a" extension.
files = GetFiles($"{xcframeworkLocation}/*.xcframework/*-maccatalyst/*.framework/Versions/A/AppCenter*");
foreach (var file in files)
{
var filename = file.GetFilename();
MoveFile(file, $"{maccatalystExternals}/{filename}.a");
}

// Copy Distribute resource bundle and copy it to the externals directory.
distributeBundle = "AppCenterDistributeResources.bundle";
if(DirectoryExists($"{xcframeworkLocation}/{distributeBundle}"))
{
MoveDirectory($"{xcframeworkLocation}/{distributeBundle}", $"{maccatalystExternals}/{distributeBundle}");
}

// Move macOS frameworks.
var macosExternals = System.IO.Path.Combine(AppleExternals, "macos");
CleanDirectory(macosExternals);
Expand Down
18 changes: 9 additions & 9 deletions nuget/AppCenter.nuspec
Original file line number Diff line number Diff line change
Expand Up @@ -79,21 +79,21 @@
<!-- Android -->
<file src="$android_dir$/Microsoft.AppCenter.dll" target="lib/MonoAndroid10.0" />
<file src="$android_dir$/Microsoft.AppCenter.xml" target="lib/MonoAndroid10.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/appcenter-release.aar" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/appcenter-release.aar" target="lib/net7.0-android29.0" />

<!-- iOS -->
<file src="$ios_dir$/Microsoft.AppCenter.dll" target="lib/Xamarin.iOS10" />
<file src="$ios_dir$/Microsoft.AppCenter.xml" target="lib/Xamarin.iOS10" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-ios9.0" />

<!-- macOS -->
<file src="$macos_dir$/Microsoft.AppCenter.dll" target="lib/Xamarin.Mac20" />
<file src="$macos_dir$/Microsoft.AppCenter.xml" target="lib/Xamarin.Mac20" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-macos10.10" />

<!-- UWP -->
<file src="$uwp_dir$/Microsoft.AppCenter.dll" target="lib/uap10.0.16299" />
Expand All @@ -110,7 +110,7 @@
<file src="$windows_netcore_dir$/Microsoft.AppCenter.xml" target="lib/netcoreapp3.1" />

<!-- Windows Desktop for WinUI and modern OS targets -->
<file src="$windows_net6_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net6_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.xml" target="lib/net7.0-windows10.0.17763.0" />
</files>
</package>
18 changes: 9 additions & 9 deletions nuget/AppCenterAnalytics.nuspec
Original file line number Diff line number Diff line change
Expand Up @@ -28,21 +28,21 @@
<!-- Android -->
<file src="$android_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/MonoAndroid10.0" />
<file src="$android_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/MonoAndroid10.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/appcenter-analytics-release.aar" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/appcenter-analytics-release.aar" target="lib/net7.0-android29.0" />

<!-- iOS -->
<file src="$ios_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/Xamarin.iOS10" />
<file src="$ios_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/Xamarin.iOS10" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-ios9.0" />

<!-- macOS -->
<file src="$macos_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/Xamarin.Mac20" />
<file src="$macos_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/Xamarin.Mac20" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-macos10.10" />

<!-- UWP -->
<file src="$uwp_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/uap10.0.16299" />
Expand All @@ -59,7 +59,7 @@
<file src="$windows_netcore_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/netcoreapp3.1" />

<!-- Windows Desktop for WinUI and modern OS targets -->
<file src="$windows_net6_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net6_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.Analytics.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.Analytics.xml" target="lib/net7.0-windows10.0.17763.0" />
</files>
</package>
18 changes: 9 additions & 9 deletions nuget/AppCenterCrashes.nuspec
Original file line number Diff line number Diff line change
Expand Up @@ -34,21 +34,21 @@
<!-- Android -->
<file src="$android_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/MonoAndroid10.0" />
<file src="$android_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/MonoAndroid10.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/appcenter-crashes-release.aar" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/appcenter-crashes-release.aar" target="lib/net7.0-android29.0" />

<!-- iOS -->
<file src="$ios_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/Xamarin.iOS10" />
<file src="$ios_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/Xamarin.iOS10" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-ios9.0" />

<!-- macOS -->
<file src="$macos_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/Xamarin.Mac20" />
<file src="$macos_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/Xamarin.Mac20" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net6_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-macos10.10" />
<file src="$macos_net7_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-macos10.10" />

<!-- UWP -->
<file src="$uwp_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/uap10.0.16299" />
Expand All @@ -65,7 +65,7 @@
<file src="$windows_netcore_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/netcoreapp3.1" />

<!-- Windows Desktop for WinUI and modern OS targets -->
<file src="$windows_net6_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net6_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.Crashes.dll" target="lib/net7.0-windows10.0.17763.0" />
<file src="$windows_net7_dir$/Microsoft.AppCenter.Crashes.xml" target="lib/net7.0-windows10.0.17763.0" />
</files>
</package>
10 changes: 5 additions & 5 deletions nuget/AppCenterDistribute.nuspec
Original file line number Diff line number Diff line change
Expand Up @@ -28,15 +28,15 @@
<!-- Android -->
<file src="$android_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/MonoAndroid10.0" />
<file src="$android_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/MonoAndroid10.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/net7.0-android29.0" />
<file src="$android_net6_dir$/appcenter-distribute-release.aar" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/net7.0-android29.0" />
<file src="$android_net7_dir$/appcenter-distribute-release.aar" target="lib/net7.0-android29.0" />

<!-- iOS -->
<file src="$ios_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/Xamarin.iOS10" />
<file src="$ios_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/Xamarin.iOS10" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net6_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Distribute.dll" target="lib/net7.0-ios9.0" />
<file src="$ios_net7_dir$/Microsoft.AppCenter.Distribute.xml" target="lib/net7.0-ios9.0" />

</files>
</package>
Loading