diff --git a/src/Microsoft.Android.Sdk.ILLink/ApplyPreserveAttribute.cs b/src/Microsoft.Android.Sdk.ILLink/ApplyPreserveAttribute.cs index de2a9590cc0..4c4af5ab10e 100644 --- a/src/Microsoft.Android.Sdk.ILLink/ApplyPreserveAttribute.cs +++ b/src/Microsoft.Android.Sdk.ILLink/ApplyPreserveAttribute.cs @@ -2,11 +2,10 @@ using System.Collections; using System.Collections.Generic; using System.Linq; - +using Mono.Cecil; using Mono.Linker; using Mono.Linker.Steps; - -using Mono.Cecil; +using Xamarin.Android.Tasks; namespace Microsoft.Android.Sdk.ILLink { @@ -25,7 +24,7 @@ public override SubStepTargets Targets { public override bool IsActiveFor (AssemblyDefinition assembly) { - return !Profile.IsSdkAssembly (assembly) && Annotations.GetAction (assembly) == AssemblyAction.Link; + return !MonoAndroidHelper.IsFrameworkAssembly (assembly) && Annotations.GetAction (assembly) == AssemblyAction.Link; } public override void ProcessType (TypeDefinition type) diff --git a/src/Microsoft.Android.Sdk.ILLink/MarkJavaObjects.cs b/src/Microsoft.Android.Sdk.ILLink/MarkJavaObjects.cs index bb029b7421a..dc39f615a08 100644 --- a/src/Microsoft.Android.Sdk.ILLink/MarkJavaObjects.cs +++ b/src/Microsoft.Android.Sdk.ILLink/MarkJavaObjects.cs @@ -6,7 +6,6 @@ using Mono.Linker.Steps; using Java.Interop.Tools.Cecil; using Xamarin.Android.Tasks; -using Profile = Microsoft.Android.Sdk.ILLink.Profile; namespace MonoDroid.Tuner { @@ -27,9 +26,7 @@ public override void Initialize (LinkContext context, MarkContext markContext) bool IsActiveFor (AssemblyDefinition assembly) { - if (Profile.IsSdkAssembly (assembly)) - return false; - if (Profile.IsProductAssembly (assembly)) + if (MonoAndroidHelper.IsFrameworkAssembly (assembly)) return false; return assembly.MainModule.HasTypeReference ("System.Net.Http.HttpMessageHandler") || @@ -397,7 +394,7 @@ static bool IsImplementor (TypeDefinition type, IMetadataResolver cache) static bool IsUserType (TypeDefinition type) { - return !MonoAndroidHelper.IsFrameworkAssembly (type.Module.Assembly.Name.Name + ".dll"); + return !MonoAndroidHelper.IsFrameworkAssembly (type.Module.Assembly); } void PreserveImplementor (TypeDefinition type) diff --git a/src/Microsoft.Android.Sdk.ILLink/Microsoft.Android.Sdk.ILLink.csproj b/src/Microsoft.Android.Sdk.ILLink/Microsoft.Android.Sdk.ILLink.csproj index ba08c1f2bb8..ebf15dba011 100644 --- a/src/Microsoft.Android.Sdk.ILLink/Microsoft.Android.Sdk.ILLink.csproj +++ b/src/Microsoft.Android.Sdk.ILLink/Microsoft.Android.Sdk.ILLink.csproj @@ -10,8 +10,6 @@ - - @@ -20,8 +18,6 @@ - - diff --git a/src/Microsoft.Android.Sdk.ILLink/PreserveApplications.cs b/src/Microsoft.Android.Sdk.ILLink/PreserveApplications.cs index 5e3e1b0c44d..ddf99cf90df 100644 --- a/src/Microsoft.Android.Sdk.ILLink/PreserveApplications.cs +++ b/src/Microsoft.Android.Sdk.ILLink/PreserveApplications.cs @@ -1,14 +1,11 @@ using System; using System.Collections; using System.Linq; - +using Mono.Cecil; using Mono.Linker; using Mono.Linker.Steps; - using Mono.Tuner; -using Mobile.Tuner; - -using Mono.Cecil; +using Xamarin.Android.Tasks; namespace MonoDroid.Tuner { diff --git a/src/Microsoft.Android.Sdk.ILLink/PreserveExportedTypes.cs b/src/Microsoft.Android.Sdk.ILLink/PreserveExportedTypes.cs index 13de9feb243..1b2664dc953 100644 --- a/src/Microsoft.Android.Sdk.ILLink/PreserveExportedTypes.cs +++ b/src/Microsoft.Android.Sdk.ILLink/PreserveExportedTypes.cs @@ -2,12 +2,11 @@ using System.Collections; using System.Collections.Generic; using System.Linq; - +using Microsoft.Android.Sdk.ILLink; +using Mono.Cecil; using Mono.Linker; using Mono.Linker.Steps; - -using Mono.Cecil; -using Microsoft.Android.Sdk.ILLink; +using Xamarin.Android.Tasks; namespace Mono.Tuner { @@ -24,7 +23,11 @@ public override SubStepTargets Targets { public override bool IsActiveFor (AssemblyDefinition assembly) { - return !Profile.IsSdkAssembly (assembly); + if (MonoAndroidHelper.IsFrameworkAssembly (assembly)) + return false; + + return assembly.MainModule.HasTypeReference ("Java.Interop.ExportAttribute") || + assembly.MainModule.HasTypeReference ("Java.Interop.ExportFieldAttribute"); } public override void ProcessField (FieldDefinition field) diff --git a/src/Microsoft.Android.Sdk.ILLink/PreserveJavaExceptions.cs b/src/Microsoft.Android.Sdk.ILLink/PreserveJavaExceptions.cs index 1c0ad8f0898..d60b064ef32 100644 --- a/src/Microsoft.Android.Sdk.ILLink/PreserveJavaExceptions.cs +++ b/src/Microsoft.Android.Sdk.ILLink/PreserveJavaExceptions.cs @@ -1,14 +1,11 @@ using System; using System.Collections; using System.Linq; - +using Mono.Cecil; using Mono.Linker; using Mono.Linker.Steps; - using Mono.Tuner; -using Mobile.Tuner; - -using Mono.Cecil; +using Xamarin.Android.Tasks; namespace MonoDroid.Tuner { diff --git a/src/Microsoft.Android.Sdk.ILLink/Profile.cs b/src/Microsoft.Android.Sdk.ILLink/Profile.cs deleted file mode 100644 index 90a72c6d068..00000000000 --- a/src/Microsoft.Android.Sdk.ILLink/Profile.cs +++ /dev/null @@ -1,52 +0,0 @@ -using Mono.Cecil; -using MonoDroid.Tuner; - -namespace Microsoft.Android.Sdk.ILLink -{ - public abstract class Profile - { - static Profile current; - - public static Profile Current { - get { - if (current == null) - current = new MonoDroidProfile (); - - return current; - } - } - - public static bool IsSdkAssembly (AssemblyDefinition assembly) - { - return Current.IsSdk (assembly); - } - - public static bool IsSdkAssembly (string assemblyName) - { - return Current.IsSdk (assemblyName); - } - - public static bool IsProductAssembly (AssemblyDefinition assembly) - { - return Current.IsProduct (assembly); - } - - public static bool IsProductAssembly (string assemblyName) - { - return Current.IsProduct (assemblyName); - } - - protected virtual bool IsSdk (AssemblyDefinition assembly) - { - return IsSdk (assembly.Name.Name); - } - - protected virtual bool IsProduct (AssemblyDefinition assembly) - { - return IsProduct (assembly.Name.Name); - } - - protected abstract bool IsSdk (string assemblyName); - protected abstract bool IsProduct (string assemblyName); - } -} diff --git a/src/Microsoft.Android.Sdk.ILLink/SetupStep.cs b/src/Microsoft.Android.Sdk.ILLink/SetupStep.cs deleted file mode 100644 index 53ee2f3017f..00000000000 --- a/src/Microsoft.Android.Sdk.ILLink/SetupStep.cs +++ /dev/null @@ -1,20 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Reflection; -using Java.Interop.Tools.Cecil; -using Mono.Cecil; -using Mono.Linker; -using Mono.Linker.Steps; -using MonoDroid.Tuner; - -namespace Microsoft.Android.Sdk.ILLink -{ - class SetupStep : BaseStep - { - protected override void Process () - { - if (Context.TryGetCustomData ("XATargetFrameworkDirectories", out string tfmPaths)) - Xamarin.Android.Tasks.MonoAndroidHelper.TargetFrameworkDirectories = tfmPaths.Split (new char [] { ';' }); - } - } -} diff --git a/src/Microsoft.Android.Sdk.ILLink/StripEmbeddedLibraries.cs b/src/Microsoft.Android.Sdk.ILLink/StripEmbeddedLibraries.cs index e455d80dc1f..041bead3f92 100644 --- a/src/Microsoft.Android.Sdk.ILLink/StripEmbeddedLibraries.cs +++ b/src/Microsoft.Android.Sdk.ILLink/StripEmbeddedLibraries.cs @@ -17,17 +17,13 @@ protected override void ProcessAssembly (AssemblyDefinition assembly) if (action == AssemblyAction.Skip || action == AssemblyAction.Delete) return; - var fileName = assembly.Name.Name + ".dll"; - if (MonoAndroidHelper.IsFrameworkAssembly (fileName) && - !MonoAndroidHelper.FrameworkEmbeddedJarLookupTargets.Contains (fileName) && - !MonoAndroidHelper.FrameworkEmbeddedNativeLibraryAssemblies.Contains (fileName)) + if (MonoAndroidHelper.IsFrameworkAssembly (assembly)) return; - bool assembly_modified = false; foreach (var mod in assembly.Modules) { foreach (var r in mod.Resources.ToArray ()) { if (ShouldStripResource (r)) { - Context.LogMessage ($" Stripped {r.Name} from {fileName}"); + Context.LogMessage ($" Stripped {r.Name} from {assembly.Name.Name}.dll"); mod.Resources.Remove (r); assembly_modified = true; } diff --git a/src/Xamarin.Android.Build.Tasks/Linker/Mobile.Tuner/MobileProfile.cs b/src/Xamarin.Android.Build.Tasks/Linker/Mobile.Tuner/MobileProfile.cs deleted file mode 100644 index 3fc0c4acbec..00000000000 --- a/src/Xamarin.Android.Build.Tasks/Linker/Mobile.Tuner/MobileProfile.cs +++ /dev/null @@ -1,205 +0,0 @@ -using System; -using System.Collections.Generic; - -using Mono.Cecil; - -using Mono.Tuner; -#if ILLINK -using Microsoft.Android.Sdk.ILLink; -#endif - -namespace Mobile.Tuner { - - public abstract class MobileProfile : Profile { - - static readonly HashSet Sdk = new HashSet { - "SMDiagnostics", - "mscorlib", - "System", - "System.ComponentModel.Composition", - "System.ComponentModel.DataAnnotations", - "System.Core", - "System.Data", - "System.Data.DataSetExtensions", - "System.Data.Services.Client", - "System.EnterpriseServices", - "System.IdentityModel", - "System.IO.Compression.FileSystem", - "System.IO.Compression", - "System.Json", - "System.Net", - "System.Net.Http", - "System.Net.Http.WinHttpHandler", - "System.Numerics", - "System.Numerics.Vectors", - "System.Reflection.Context", - "System.Runtime.Serialization", - "System.Security", - "System.ServiceModel", - "System.ServiceModel.Internals", - "System.ServiceModel.Web", - "System.Transactions", - "System.Web.Services", - "System.Windows", - "System.Xml", - "System.Xml.Linq", - "System.Xml.Serialization", - "Microsoft.CSharp", - "Microsoft.VisualBasic", - "Mono.CSharp", - "Mono.Cairo", - "Mono.CompilerServices.SymbolWriter", - "Mono.Data.Tds", - "Mono.Data.Sqlite", - "Mono.Posix", - "Mono.Security", - // Facades assemblies (PCL) - "Microsoft.Win32.Primitives", - "Microsoft.Win32.Registry.AccessControl", - "Microsoft.Win32.Registry", - "System.AppContext", - "System.Collections.Concurrent", - "System.Collections.NonGeneric", - "System.Collections.Specialized", - "System.Collections", - "System.ComponentModel.Annotations", - "System.ComponentModel.EventBasedAsync", - "System.ComponentModel.Primitives", - "System.ComponentModel.TypeConverter", - "System.ComponentModel", - "System.Console", - "System.Data.Common", - "System.Data.SqlClient", - "System.Diagnostics.Contracts", - "System.Diagnostics.Debug", - "System.Diagnostics.FileVersionInfo", - "System.Diagnostics.Process", - "System.Diagnostics.StackTrace", - "System.Diagnostics.TextWriterTraceListener", - "System.Diagnostics.Tools", - "System.Diagnostics.TraceEvent", - "System.Diagnostics.TraceSource", - "System.Diagnostics.Tracing", - "System.Drawing.Common", - "System.Drawing.Primitives", - "System.Dynamic.Runtime", - "System.Globalization.Calendars", - "System.Globalization.Extensions", - "System.Globalization", - "System.IO", - "System.IO.Compression.ZipFile", - "System.IO.FileSystem.AccessControl", - "System.IO.FileSystem.DriveInfo", - "System.IO.FileSystem.Primitives", - "System.IO.FileSystem.Watcher", - "System.IO.FileSystem", - "System.IO.IsolatedStorage", - "System.IO.MemoryMappedFiles", - "System.IO.Pipes", - "System.IO.UnmanagedMemoryStream", - "System.Linq.Expressions", - "System.Linq.Parallel", - "System.Linq.Queryable", - "System.Linq", - "System.Memory", - "System.Net.AuthenticationManager", - "System.Net.Cache", - "System.Net.HttpListener", - "System.Net.Mail", - "System.Net.NameResolution", - "System.Net.NetworkInformation", - "System.Net.Ping", - "System.Net.Primitives", - "System.Net.Requests", - "System.Net.Security", - "System.Net.ServicePoint", - "System.Net.Sockets", - "System.Net.Utilities", - "System.Net.WebHeaderCollection", - "System.Net.WebSockets.Client", - "System.Net.WebSockets", - "System.ObjectModel", - "System.Reflection.DispatchProxy", - "System.Reflection.Emit.ILGeneration", - "System.Reflection.Emit.Lightweight", - "System.Reflection.Emit", - "System.Reflection.Extensions", - "System.Reflection.Primitives", - "System.Reflection.TypeExtensions", - "System.Reflection", - "System.Resources.Reader", - "System.Resources.ReaderWriter", - "System.Resources.ResourceManager", - "System.Resources.Writer", - "System.Runtime.CompilerServices.VisualC", - "System.Runtime.Extensions", - "System.Runtime.Handles", - "System.Runtime.InteropServices", - "System.Runtime.InteropServices.RuntimeInformation", - "System.Runtime.InteropServices.WindowsRuntime", - "System.Runtime.Loader", - "System.Runtime.Numerics", - "System.Runtime.Serialization.Formatters", - "System.Runtime.Serialization.Json", - "System.Runtime.Serialization.Primitives", - "System.Runtime.Serialization.Xml", - "System.Runtime", - "System.Security.AccessControl", - "System.Security.Claims", - "System.Security.Cryptography.Algorithms", - "System.Security.Cryptography.Cng", - "System.Security.Cryptography.Csp", - "System.Security.Cryptography.DeriveBytes", - "System.Security.Cryptography.Encoding", - "System.Security.Cryptography.Encryption.Aes", - "System.Security.Cryptography.Encryption.ECDiffieHellman", - "System.Security.Cryptography.Encryption.ECDsa", - "System.Security.Cryptography.Encryption", - "System.Security.Cryptography.Hashing.Algorithms", - "System.Security.Cryptography.Hashing", - "System.Security.Cryptography.OpenSsl", - "System.Security.Cryptography.Pkcs", - "System.Security.Cryptography.Primitives", - "System.Security.Cryptography.ProtectedData", - "System.Security.Cryptography.RSA", - "System.Security.Cryptography.RandomNumberGenerator", - "System.Security.Cryptography.X509Certificates", - "System.Security.Principal.Windows", - "System.Security.Principal", - "System.Security.SecureString", - "System.ServiceModel.Duplex", - "System.ServiceModel.NetTcp", - "System.ServiceModel.Http", - "System.ServiceModel.Primitives", - "System.ServiceModel.Security", - "System.ServiceProcess.ServiceController", - "System.Text.Encoding.CodePages", - "System.Text.Encoding.Extensions", - "System.Text.Encoding", - "System.Text.RegularExpressions", - "System.Threading.AccessControl", - "System.Threading.Overlapped", - "System.Threading.Tasks.Parallel", - "System.Threading.Tasks", - "System.Threading.Thread", - "System.Threading.ThreadPool", - "System.Threading.Timer", - "System.Threading", - "System.ValueTuple", - "System.Xml.ReaderWriter", - "System.Xml.XDocument", - "System.Xml.XPath.XDocument", - "System.Xml.XPath.XmlDocument", - "System.Xml.XPath", - "System.Xml.XmlDocument", - "System.Xml.XmlSerializer", - "System.Xml.Xsl.Primitives", - "netstandard", - }; - - protected override bool IsSdk (string assemblyName) - { - return Sdk.Contains (assemblyName); - } - } -} diff --git a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/AddKeepAlivesStep.cs b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/AddKeepAlivesStep.cs index 8a27d1d7eb8..e143d5c312f 100644 --- a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/AddKeepAlivesStep.cs +++ b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/AddKeepAlivesStep.cs @@ -10,9 +10,6 @@ using Mono.Linker.Steps; using Mono.Cecil.Cil; -#if ILLINK -using Microsoft.Android.Sdk.ILLink; -#endif // ILLINK namespace MonoDroid.Tuner { diff --git a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixAbstractMethodsStep.cs b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixAbstractMethodsStep.cs index 70de2500931..01890ba8c56 100644 --- a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixAbstractMethodsStep.cs +++ b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixAbstractMethodsStep.cs @@ -2,17 +2,14 @@ using System.Collections.Generic; using System.Globalization; using System.Linq; - -using Mono.Cecil; - using Java.Interop.Tools.Cecil; - +using Mono.Cecil; using Mono.Linker; using Mono.Linker.Steps; - using Mono.Tuner; +using Xamarin.Android.Tasks; + #if ILLINK -using Microsoft.Android.Sdk.ILLink; using Resources = Microsoft.Android.Sdk.ILLink.Properties.Resources; #else // !ILLINK using Resources = Xamarin.Android.Tasks.Properties.Resources; @@ -53,7 +50,7 @@ bool CheckShouldProcessAssembly (AssemblyDefinition assembly) if (!Annotations.HasAction (assembly)) Annotations.SetAction (assembly, AssemblyAction.Skip); - if (IsProductOrSdkAssembly (assembly)) + if (MonoAndroidHelper.IsFrameworkAssembly (assembly)) return false; CheckAppDomainUsage (assembly, (string msg) => @@ -130,12 +127,6 @@ internal void CheckAppDomainUsage (AssemblyDefinition assembly, Action w } } - bool IsProductOrSdkAssembly (AssemblyDefinition assembly) => - IsProductOrSdkAssembly (assembly.Name.Name); - - public bool IsProductOrSdkAssembly (string assemblyName) => - Profile.IsSdkAssembly (assemblyName) || Profile.IsProductAssembly (assemblyName); - bool MightNeedFix (TypeDefinition type) { return !type.IsAbstract && type.IsSubclassOf ("Java.Lang.Object", cache); diff --git a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixLegacyResourceDesignerStep.cs b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixLegacyResourceDesignerStep.cs index 777c419fbc8..f60a9c7a2a0 100644 --- a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixLegacyResourceDesignerStep.cs +++ b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/FixLegacyResourceDesignerStep.cs @@ -13,7 +13,6 @@ using Mono.Tuner; #if ILLINK -using Microsoft.Android.Sdk.ILLink; using Resources = Microsoft.Android.Sdk.ILLink.Properties.Resources; #else // !ILLINK using Resources = Xamarin.Android.Tasks.Properties.Resources; diff --git a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/MonoDroidProfile.cs b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/MonoDroidProfile.cs deleted file mode 100644 index b11d55e9be6..00000000000 --- a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/MonoDroidProfile.cs +++ /dev/null @@ -1,25 +0,0 @@ -using System; -using System.Collections.Generic; - -using Mono.Tuner; -using Mobile.Tuner; - -using Mono.Cecil; - -namespace MonoDroid.Tuner { - - class MonoDroidProfile : MobileProfile { - - protected override bool IsProduct (string assemblyName) - { - return assemblyName == "Mono.Android"; - } - - protected override bool IsSdk (string assemblyName) - { - return assemblyName.Equals ("Java.Interop", StringComparison.Ordinal) - || assemblyName.Equals ("Java.Interop.GenericMarshaler", StringComparison.Ordinal) - || base.IsSdk (assemblyName); - } - } -} diff --git a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/RemoveResourceDesignerStep.cs b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/RemoveResourceDesignerStep.cs index 0ac0e0e7c33..3c1e1a71a9d 100644 --- a/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/RemoveResourceDesignerStep.cs +++ b/src/Xamarin.Android.Build.Tasks/Linker/MonoDroid.Tuner/RemoveResourceDesignerStep.cs @@ -93,8 +93,7 @@ internal override bool ProcessAssemblyDesigner (AssemblyDefinition assembly) { if (mainDesigner == null) return false; - var fileName = assembly.Name.Name + ".dll"; - if (MonoAndroidHelper.IsFrameworkAssembly (fileName)) + if (MonoAndroidHelper.IsFrameworkAssembly (assembly)) return false; LogMessage ($" Fixing up {assembly.Name.Name}"); diff --git a/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.ILLink.targets b/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.ILLink.targets index 1cd67019059..6e783fdf500 100644 --- a/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.ILLink.targets +++ b/src/Xamarin.Android.Build.Tasks/Microsoft.Android.Sdk/targets/Microsoft.Android.Sdk.ILLink.targets @@ -32,7 +32,6 @@ This file contains the .NET 5-specific targets to customize ILLink --> <_TrimmerCustomData Include="AndroidHttpClientHandlerType" Value="$(AndroidHttpClientHandlerType)" /> <_TrimmerCustomData Include="AndroidCustomViewMapFile" Value="$(_OuterCustomViewMapFile)" /> - <_TrimmerCustomData Include="XATargetFrameworkDirectories" Value="$(_XATargetFrameworkDirectories)" /> <_TrimmerCustomData Condition=" '$(_ProguardProjectConfiguration)' != '' " Include="ProguardConfiguration" @@ -44,8 +43,6 @@ This file contains the .NET 5-specific targets to customize ILLink https://github.com/dotnet/sdk/blob/a5393731b5b7b225692fff121f747fbbc9e8b140/src/Tasks/Microsoft.NET.Build.Tasks/targets/Microsoft.NET.ILLink.targets#L131 --> - - <_TrimmerCustomSteps Include="$(_AndroidLinkerCustomStepAssembly)" BeforeStep="MarkStep" Type="Microsoft.Android.Sdk.ILLink.SetupStep" /> <_TrimmerCustomSteps Include="$(_AndroidLinkerCustomStepAssembly)" Type="Microsoft.Android.Sdk.ILLink.PreserveSubStepDispatcher" /> <_TrimmerCustomSteps Include="$(_AndroidLinkerCustomStepAssembly)" Type="MonoDroid.Tuner.MarkJavaObjects" /> diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/FilterAssemblies.cs b/src/Xamarin.Android.Build.Tasks/Tasks/FilterAssemblies.cs index 9c3fe84407a..057bcfb9bd7 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/FilterAssemblies.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/FilterAssemblies.cs @@ -34,12 +34,7 @@ public override bool RunTask () var output = new List (InputAssemblies.Length); foreach (var assemblyItem in InputAssemblies) { - // Skip .NET 6.0 assemblies - var frameworkReferenceName = assemblyItem.GetMetadata ("FrameworkReferenceName") ?? ""; - if (frameworkReferenceName == "Microsoft.Android") { - continue; // No need to process Mono.Android.dll or Java.Interop.dll - } - if (frameworkReferenceName.StartsWith ("Microsoft.NETCore.", StringComparison.OrdinalIgnoreCase)) { + if (MonoAndroidHelper.IsFrameworkAssembly (assemblyItem)) { continue; // No need to process BCL assemblies } if (string.Equals (assemblyItem.GetMetadata ("TargetPlatformIdentifier"), "android", StringComparison.OrdinalIgnoreCase)) { diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/GenerateResourceDesigner.cs b/src/Xamarin.Android.Build.Tasks/Tasks/GenerateResourceDesigner.cs index 35474f678ac..5986793d0a8 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/GenerateResourceDesigner.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/GenerateResourceDesigner.cs @@ -111,8 +111,7 @@ public override bool RunTask () foreach (var assembly in References) { var assemblyPath = assembly.ItemSpec; var fileName = Path.GetFileName (assemblyPath); - if (MonoAndroidHelper.IsFrameworkAssembly (fileName) && - !MonoAndroidHelper.FrameworkEmbeddedJarLookupTargets.Contains (fileName)) { + if (MonoAndroidHelper.IsFrameworkAssembly (fileName)) { Log.LogDebugMessage ($"Skipping framework assembly '{fileName}'."); continue; } diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/LinkAssembliesNoShrink.cs b/src/Xamarin.Android.Build.Tasks/Tasks/LinkAssembliesNoShrink.cs index bb7d7c54516..db271d4948b 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/LinkAssembliesNoShrink.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/LinkAssembliesNoShrink.cs @@ -130,16 +130,16 @@ void DoRunTask (ITaskItem source, ITaskItem destination, RunState runState, Writ CopyIfChanged (source, destination); return; } - if (runState.fixAbstractMethodsStep!.IsProductOrSdkAssembly (assemblyName)) { + if (MonoAndroidHelper.IsFrameworkAssembly (source)) { CopyIfChanged (source, destination); return; } // Only run the step on "MonoAndroid" assemblies - if (MonoAndroidHelper.IsMonoAndroidAssembly (source) && !MonoAndroidHelper.IsSharedRuntimeAssembly (source.ItemSpec)) { + if (MonoAndroidHelper.IsMonoAndroidAssembly (source)) { AssemblyDefinition assemblyDefinition = runState.resolver!.GetAssembly (source.ItemSpec); - bool save = runState.fixAbstractMethodsStep.FixAbstractMethods (assemblyDefinition); + bool save = runState.fixAbstractMethodsStep!.FixAbstractMethods (assemblyDefinition); if (UseDesignerAssembly) save |= runState.fixLegacyResourceDesignerStep!.ProcessAssemblyDesigner (assemblyDefinition); if (AddKeepAlives) diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/ProcessAssemblies.cs b/src/Xamarin.Android.Build.Tasks/Tasks/ProcessAssemblies.cs index a5b7cfcf36d..bce699d3883 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/ProcessAssemblies.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/ProcessAssemblies.cs @@ -84,7 +84,7 @@ public override bool RunTask () if (InputJavaLibraries != null) { var javaLibraries = new Dictionary (StringComparer.OrdinalIgnoreCase); foreach (var item in InputJavaLibraries) { - if (!IsFromAKnownRuntimePack (item)) + if (!MonoAndroidHelper.IsFromAKnownRuntimePack (item)) continue; var name = Path.GetFileNameWithoutExtension(item.ItemSpec); if (!javaLibraries.ContainsKey (name)) { @@ -126,7 +126,7 @@ void SetMetadataForAssemblies (List output, Dictionary output, Dictionary symbols, ITaskItem assembly) { var symbolPath = Path.ChangeExtension (assembly.ItemSpec, ".pdb"); diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/ResolveLibraryProjectImports.cs b/src/Xamarin.Android.Build.Tasks/Tasks/ResolveLibraryProjectImports.cs index 637667b72b8..2ac5c3e8334 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/ResolveLibraryProjectImports.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/ResolveLibraryProjectImports.cs @@ -170,9 +170,7 @@ void Extract ( foreach (var assemblyItem in Assemblies) { var assemblyPath = assemblyItem.ItemSpec; var fileName = Path.GetFileName (assemblyPath); - if (MonoAndroidHelper.IsFrameworkAssembly (fileName) && - !MonoAndroidHelper.FrameworkEmbeddedJarLookupTargets.Contains (fileName) && - !MonoAndroidHelper.FrameworkEmbeddedNativeLibraryAssemblies.Contains (fileName)) { + if (MonoAndroidHelper.IsFrameworkAssembly (fileName)) { Log.LogDebugMessage ($"Skipping framework assembly '{fileName}'."); continue; } @@ -184,8 +182,7 @@ void Extract ( Log.LogDebugMessage ("Skipping resource extraction for '{0}' .", assemblyPath); continue; } - string assemblyFileName = Path.GetFileName (assemblyPath); - string assemblyIdentName = assemblyMap.GetLibraryImportDirectoryNameForAssembly (assemblyFileName); + string assemblyIdentName = assemblyMap.GetLibraryImportDirectoryNameForAssembly (fileName); string outDirForDll = Path.Combine (OutputImportDirectory, assemblyIdentName); string importsDir = Path.Combine (outDirForDll, ImportsDirectory); string nativeimportsDir = Path.Combine (outDirForDll, NativeImportsDirectory); @@ -226,7 +223,7 @@ void Extract ( continue; } - Log.LogDebugMessage ($"Refreshing {assemblyFileName}"); + Log.LogDebugMessage ($"Refreshing {fileName}"); using (var pe = new PEReader (File.OpenRead (assemblyPath))) { var reader = pe.GetMetadataReader (); diff --git a/src/Xamarin.Android.Build.Tasks/Tasks/ResolveSdksTask.cs b/src/Xamarin.Android.Build.Tasks/Tasks/ResolveSdksTask.cs index a93bdb23536..8a0aa3f95d6 100644 --- a/src/Xamarin.Android.Build.Tasks/Tasks/ResolveSdksTask.cs +++ b/src/Xamarin.Android.Build.Tasks/Tasks/ResolveSdksTask.cs @@ -128,8 +128,6 @@ public override bool RunTask () return false; } - MonoAndroidHelper.TargetFrameworkDirectories = ReferenceAssemblyPaths; - Log.LogDebugMessage ($"{nameof (ResolveSdks)} Outputs:"); Log.LogDebugMessage ($" {nameof (AndroidSdkPath)}: {AndroidSdkPath}"); Log.LogDebugMessage ($" {nameof (AndroidNdkPath)}: {AndroidNdkPath}"); diff --git a/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.Linker.cs b/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.Linker.cs index 3d13492aec7..b3b863dbda4 100644 --- a/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.Linker.cs +++ b/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.Linker.cs @@ -2,50 +2,23 @@ using System.Collections.Generic; using System.Linq; using System.IO; +using Mono.Cecil; namespace Xamarin.Android.Tasks { public partial class MonoAndroidHelper { - public static string [] TargetFrameworkDirectories; - - internal static readonly string [] FrameworkEmbeddedJarLookupTargets = { - "Mono.Android.Support.v13.dll", - "Mono.Android.Support.v4.dll", - "Xamarin.Android.NUnitLite.dll", // AndroidResources - }; - internal static readonly string [] FrameworkEmbeddedNativeLibraryAssemblies = { - "Mono.Data.Sqlite.dll", - "Mono.Posix.dll", + static readonly HashSet KnownAssemblyNames = new (StringComparer.OrdinalIgnoreCase) { + "Mono.Android", + "Mono.Android.Export", + "Java.Interop", }; - public static bool IsFrameworkAssembly (string assembly) - { - return IsFrameworkAssembly (assembly, false); - } + public static bool IsFrameworkAssembly (AssemblyDefinition assembly) => + KnownAssemblyNames.Contains (assembly.Name.Name); - public static bool IsFrameworkAssembly (string assembly, bool checkSdkPath) - { - if (IsSharedRuntimeAssembly (assembly)) { - return true; - } - return TargetFrameworkDirectories == null || !checkSdkPath ? false : ExistsInFrameworkPath (assembly); - } - - public static bool IsSharedRuntimeAssembly (string assembly) - { - return Array.BinarySearch (Profile.SharedRuntimeAssemblies, Path.GetFileName (assembly), StringComparer.OrdinalIgnoreCase) >= 0; - } - - public static bool ExistsInFrameworkPath (string assembly) - { - return TargetFrameworkDirectories - // TargetFrameworkDirectories will contain a "versioned" directory, - // e.g. $prefix/lib/xamarin.android/xbuild-frameworks/MonoAndroid/v1.0. - // Trim off the version. - .Select (p => Path.GetDirectoryName (p.TrimEnd (Path.DirectorySeparatorChar))) - .Any (p => assembly.StartsWith (p, StringComparison.OrdinalIgnoreCase)); - } + public static bool IsFrameworkAssembly (string assembly) => + KnownAssemblyNames.Contains (Path.GetFileNameWithoutExtension (assembly)); static readonly char [] CustomViewMapSeparator = [';']; diff --git a/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.cs b/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.cs index b4daa6d8bc0..833d2b3a534 100644 --- a/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.cs +++ b/src/Xamarin.Android.Build.Tasks/Utilities/MonoAndroidHelper.cs @@ -415,6 +415,32 @@ public static ZipArchive ReadZipFile (string filename) } #if MSBUILD + public static bool IsFrameworkAssembly (ITaskItem assembly) + { + // Known assembly names: Mono.Android, Java.Interop, etc. + if (IsFrameworkAssembly (assembly.ItemSpec)) + return true; + + // Known %(FrameworkReferenceName) + var frameworkReferenceName = assembly.GetMetadata ("FrameworkReferenceName") ?? ""; + if (frameworkReferenceName == "Microsoft.Android") { + return true; // Microsoft.Android assemblies + } + if (frameworkReferenceName.StartsWith ("Microsoft.NETCore.", StringComparison.OrdinalIgnoreCase)) { + return true; // BCL assemblies + } + + // Known %(NuGetPackageId) runtime pack names + return IsFromAKnownRuntimePack (assembly); + } + + public static bool IsFromAKnownRuntimePack (ITaskItem assembly) + { + string packageId = assembly.GetMetadata ("NuGetPackageId") ?? ""; + return packageId.StartsWith ("Microsoft.NETCore.App.Runtime.", StringComparison.OrdinalIgnoreCase) || + packageId.StartsWith ("Microsoft.Android.Runtime.", StringComparison.OrdinalIgnoreCase); + } + public static bool SaveMapFile (IBuildEngine4 engine, string mapFile, Dictionary map) { engine?.RegisterTaskObjectAssemblyLocal (mapFile, map, RegisteredTaskObjectLifetime.Build); diff --git a/src/Xamarin.Android.Build.Tasks/Utilities/Profile.cs b/src/Xamarin.Android.Build.Tasks/Utilities/Profile.cs deleted file mode 100644 index 7c9e72a0a0b..00000000000 --- a/src/Xamarin.Android.Build.Tasks/Utilities/Profile.cs +++ /dev/null @@ -1,44 +0,0 @@ -using System.Collections.Generic; - -namespace Xamarin.Android.Tasks -{ - public partial class Profile - { - public static readonly HashSet Sdk = new HashSet { - "mscorlib", - "System", - "System.Core", - "System.Data", - "System.EnterpriseServices", - "System.Net.Http", - "System.Runtime.Serialization", - "System.ServiceModel", - "System.ServiceModel.Web", - "System.Transactions", - "System.Web.Services", - "System.Xml", - "System.Xml.Linq", - "System.Json", - "System.Numerics", - "Microsoft.CSharp", - "Mono.CSharp", - "Mono.CompilerServices.SymbolWriter", - "Mono.Security", - "Mono.Data.Tds", - "Mono.Data.Sqlite", - }; - - // KEEP THIS SORTED ALPHABETICALLY, CASE-INSENSITIVE - public static readonly string[] ValidAbis = new[]{ - "arm64-v8a", - "armeabi-v7a", - "x86", - "x86_64", - }; - - public static readonly string[] ValidProfilers = new[]{ - "log", - }; - } -} - diff --git a/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.csproj b/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.csproj index 7e4e38509b9..030deb6a015 100644 --- a/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.csproj +++ b/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.csproj @@ -44,7 +44,6 @@ - @@ -56,8 +55,6 @@ - - @@ -78,7 +75,6 @@ - Mono.Android\IntentFilterAttribute.cs diff --git a/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.targets b/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.targets index f002c237b6c..23bccb376a9 100644 --- a/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.targets +++ b/src/Xamarin.Android.Build.Tasks/Xamarin.Android.Build.Tasks.targets @@ -8,7 +8,6 @@ <_SharedRuntimeBuildPath Condition=" '$(_SharedRuntimeBuildPath)' == '' ">$(XAInstallPrefix)xbuild-frameworks\MonoAndroid\ - <_GeneratedProfileClass>$(MSBuildThisFileDirectory)$(IntermediateOutputPath)Profile.g.cs $(ResolveReferencesDependsOn); _GenerateSupportedPlatforms; @@ -163,16 +162,6 @@ PreserveNewest - - <_SharedRuntimeAssemblies Include="@(MonoProfileAssembly->'$(_SharedRuntimeBuildPath)v1.0\%(Identity)')" /> - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)v1.0\Mono.Data.Sqlite.dll" /> - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)v1.0\Mono.Posix.dll" /> - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)v1.0\Java.Interop.dll" /> - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)v1.0\System.EnterpriseServices.dll" /> - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)$(AndroidFrameworkVersion)\Mono.Android.Export.dll" /> - - <_SharedRuntimeAssemblies Include="$(_SharedRuntimeBuildPath)$(AndroidFrameworkVersion)\Mono.Android.dll" /> - - - - - - - -