diff --git a/src/tools/illink/src/linker/Linker.Steps/BodySubstituterStep.cs b/src/tools/illink/src/linker/Linker.Steps/BodySubstituterStep.cs index 85b2ad9496975..d88646acfd420 100644 --- a/src/tools/illink/src/linker/Linker.Steps/BodySubstituterStep.cs +++ b/src/tools/illink/src/linker/Linker.Steps/BodySubstituterStep.cs @@ -31,11 +31,14 @@ public BodySubstituterStep (XPathDocument document, string resourceName, Assembl protected override void Process () { + if (!string.IsNullOrEmpty (_resourceName) && Context.StripSubstitutions) + Context.Annotations.AddResourceToRemove (_resourceAssembly, _resourceName); + + if (!string.IsNullOrEmpty (_resourceName) && Context.IgnoreSubstitutions) + return; + try { ReadSubstitutions (_document); - - if (!string.IsNullOrEmpty (_resourceName) && Context.StripResources) - Context.Annotations.AddResourceToRemove (_resourceAssembly, _resourceName); } catch (Exception ex) when (!(ex is XmlResolutionException)) { throw new XmlResolutionException ($"Failed to process XML substitution: '{_xmlDocumentLocation}'", ex); } diff --git a/src/tools/illink/src/linker/Linker.Steps/ResolveFromXmlStep.cs b/src/tools/illink/src/linker/Linker.Steps/ResolveFromXmlStep.cs index 9e88fadfb871f..9c4d70cb3e8f1 100644 --- a/src/tools/illink/src/linker/Linker.Steps/ResolveFromXmlStep.cs +++ b/src/tools/illink/src/linker/Linker.Steps/ResolveFromXmlStep.cs @@ -90,11 +90,14 @@ protected override void Process () if (!nav.MoveToChild ("linker", _ns)) return; + if (!string.IsNullOrEmpty (_resourceName) && Context.StripDescriptors) + Context.Annotations.AddResourceToRemove (_resourceAssembly, _resourceName); + + if (!string.IsNullOrEmpty (_resourceName) && Context.IgnoreDescriptors) + return; + try { ProcessAssemblies (Context, nav.SelectChildren ("assembly", _ns)); - - if (!string.IsNullOrEmpty (_resourceName) && Context.StripResources) - Context.Annotations.AddResourceToRemove (_resourceAssembly, _resourceName); } catch (Exception ex) when (!(ex is XmlResolutionException)) { throw new XmlResolutionException (string.Format ("Failed to process XML description: {0}", _xmlDocumentLocation), ex); } diff --git a/src/tools/illink/src/linker/Linker/Driver.cs b/src/tools/illink/src/linker/Linker/Driver.cs index 22e92578da0a6..6d41b770b9d79 100644 --- a/src/tools/illink/src/linker/Linker/Driver.cs +++ b/src/tools/illink/src/linker/Linker/Driver.cs @@ -190,7 +190,6 @@ protected int SetupContext (ILogger customLogger = null) var set_optimizations = new List<(CodeOptimizations, string, bool)> (); bool dumpDependencies = false; string dependenciesFileName = null; - bool ignoreDescriptors = false; bool removeCAS = true; bool new_mvid_used = false; bool deterministic_used = false; @@ -246,8 +245,14 @@ protected int SetupContext (ILogger customLogger = null) continue; - case "--strip-resources": - if (!GetBoolParam (token, l => context.StripResources = l)) + case "--strip-descriptors": + if (!GetBoolParam (token, l => context.StripDescriptors = l)) + return -1; + + continue; + + case "--strip-substitutions": + if (!GetBoolParam (token, l => context.StripSubstitutions = l)) return -1; continue; @@ -320,7 +325,13 @@ protected int SetupContext (ILogger customLogger = null) continue; case "--ignore-descriptors": - if (!GetBoolParam (token, l => ignoreDescriptors = l)) + if (!GetBoolParam (token, l => context.IgnoreDescriptors = l)) + return -1; + + continue; + + case "--ignore-substitutions": + if (!GetBoolParam (token, l => context.IgnoreSubstitutions = l)) return -1; continue; @@ -507,7 +518,7 @@ protected int SetupContext (ILogger customLogger = null) continue; case "z": - if (!GetBoolParam (token, l => ignoreDescriptors = !l)) + if (!GetBoolParam (token, l => context.IgnoreDescriptors = !l)) return -1; continue; @@ -573,9 +584,6 @@ protected int SetupContext (ILogger customLogger = null) foreach (var file in body_substituter_steps) AddBodySubstituterStep (p, file); - if (ignoreDescriptors) - p.RemoveStep (typeof (BlacklistStep)); - if (context.DeterministicOutput) p.RemoveStep (typeof (RegenerateGuidStep)); @@ -622,7 +630,7 @@ protected int SetupContext (ILogger customLogger = null) // [mono only] ResolveFromXApiStep [optional, possibly many] // LoadReferencesStep // [mono only] LoadI18nAssemblies - // BlacklistStep [optional] + // BlacklistStep // dynamically adds steps: // ResolveFromXmlStep [optional, possibly many] // BodySubstituterStep [optional, possibly many] @@ -922,7 +930,6 @@ protected virtual LinkContext GetDefaultContext (Pipeline pipeline) #endif UserAction = AssemblyAction.Link, OutputDirectory = "output", - StripResources = true }; return context; } @@ -1011,9 +1018,11 @@ static void Usage () Console.WriteLine (" --keep-dep-attributes Keep attributes used for manual dependency tracking. Defaults to false"); Console.WriteLine (" --feature FEATURE VALUE Apply any optimizations defined when this feature setting is a constant known at link time"); Console.WriteLine (" --new-mvid Generate a new guid for each linked assembly (short -g). Defaults to true"); - Console.WriteLine (" --strip-resources Remove XML descriptor resources for linked assemblies. Defaults to true"); + Console.WriteLine (" --strip-descriptors Remove XML descriptor resources for linked assemblies. Defaults to true"); Console.WriteLine (" --strip-security Remove metadata and code related to Code Access Security. Defaults to true"); Console.WriteLine (" --substitutions FILE Configuration file with field or methods substitution rules"); + Console.WriteLine (" --ignore-substitutions Skips reading embedded substitutions. Defaults to false"); + Console.WriteLine (" --strip-substitutions Remove XML substitution resources for linked assemblies. Defaults to true"); Console.WriteLine (" --used-attrs-only Attribute usage is removed if the attribute type is not used. Defaults to false"); Console.WriteLine (" --attribute-defs FILE Supplementary custom attribute definitions for attributes controlling the linker behavior."); diff --git a/src/tools/illink/src/linker/Linker/LinkContext.cs b/src/tools/illink/src/linker/Linker/LinkContext.cs index 060323ee7cc2d..71afe470662e9 100644 --- a/src/tools/illink/src/linker/Linker/LinkContext.cs +++ b/src/tools/illink/src/linker/Linker/LinkContext.cs @@ -116,7 +116,13 @@ public bool IgnoreUnresolved { public bool KeepDependencyAttributes { get; set; } - public bool StripResources { get; set; } + public bool IgnoreDescriptors { get; set; } + + public bool IgnoreSubstitutions { get; set; } + + public bool StripDescriptors { get; set; } + + public bool StripSubstitutions { get; set; } public Dictionary FeatureSettings { get; private set; } @@ -201,7 +207,8 @@ public LinkContext (Pipeline pipeline, AssemblyResolver resolver, ReaderParamete Tracer = factory.CreateTracer (this); ReflectionPatternRecorder = new LoggingReflectionPatternRecorder (this); MarkedKnownMembers = new KnownMembers (); - StripResources = true; + StripDescriptors = true; + StripSubstitutions = true; PInvokes = new List (); // See https://github.com/mono/linker/issues/612 diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreDescriptorsAttribute.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreDescriptorsAttribute.cs new file mode 100644 index 0000000000000..f3cffe2db215a --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreDescriptorsAttribute.cs @@ -0,0 +1,12 @@ +namespace Mono.Linker.Tests.Cases.Expectations.Metadata +{ + public sealed class IgnoreDescriptorsAttribute : BaseMetadataAttribute + { + public readonly bool Value; + + public IgnoreDescriptorsAttribute (bool value) + { + Value = value; + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreSubstitutionsAttribute.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreSubstitutionsAttribute.cs new file mode 100644 index 0000000000000..ab999b6dd257d --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IgnoreSubstitutionsAttribute.cs @@ -0,0 +1,12 @@ +namespace Mono.Linker.Tests.Cases.Expectations.Metadata +{ + public sealed class IgnoreSubstitutionsAttribute : BaseMetadataAttribute + { + public readonly bool Value; + + public IgnoreSubstitutionsAttribute (bool value) + { + Value = value; + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IncludeBlacklistStepAttribute.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IncludeBlacklistStepAttribute.cs deleted file mode 100644 index a70567e3b835b..0000000000000 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/IncludeBlacklistStepAttribute.cs +++ /dev/null @@ -1,12 +0,0 @@ -namespace Mono.Linker.Tests.Cases.Expectations.Metadata -{ - public sealed class IncludeBlacklistStepAttribute : BaseMetadataAttribute - { - public readonly bool Value; - - public IncludeBlacklistStepAttribute (bool value) - { - Value = value; - } - } -} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripResourcesAttribute.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripDescriptorsAttribute.cs similarity index 54% rename from src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripResourcesAttribute.cs rename to src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripDescriptorsAttribute.cs index 691152a071e57..de9d2bf4ebe98 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripResourcesAttribute.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripDescriptorsAttribute.cs @@ -2,11 +2,11 @@ namespace Mono.Linker.Tests.Cases.Expectations.Metadata { - public sealed class StripResourcesAttribute : BaseMetadataAttribute + public sealed class StripDescriptorsAttribute : BaseMetadataAttribute { public readonly bool Value; - public StripResourcesAttribute (bool value) + public StripDescriptorsAttribute (bool value) { Value = value; } diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripSubstitutionsAttribute.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripSubstitutionsAttribute.cs new file mode 100644 index 0000000000000..1222c28738722 --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases.Expectations/Metadata/StripSubstitutionsAttribute.cs @@ -0,0 +1,14 @@ +using System; + +namespace Mono.Linker.Tests.Cases.Expectations.Metadata +{ + public sealed class StripSubstitutionsAttribute : BaseMetadataAttribute + { + public readonly bool Value; + + public StripSubstitutionsAttribute (bool value) + { + Value = value; + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlFromCopyAssemblyIsProcessed.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlFromCopyAssemblyIsProcessed.cs index 9a57d8bf3489e..a5e3271042de2 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlFromCopyAssemblyIsProcessed.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlFromCopyAssemblyIsProcessed.cs @@ -9,7 +9,7 @@ namespace Mono.Linker.Tests.Cases.LinkXml [SetupCompileBefore ("CopyLibrary.dll", new[] { "Dependencies/EmbeddedLinkXmlFromCopyAssemblyIsProcessed/CopyLibrary.cs" }, resources: new[] { "Dependencies/EmbeddedLinkXmlFromCopyAssemblyIsProcessed/CopyLibrary.xml" })] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [SetupLinkerAction ("copy", "CopyLibrary")] [KeptTypeInAssembly ("CopyLibrary.dll", typeof (CopyLibrary))] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlPreservesAdditionalAssemblyWithOverriddenMethod.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlPreservesAdditionalAssemblyWithOverriddenMethod.cs index 77f45d75c0dcc..37a8265ea0a7b 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlPreservesAdditionalAssemblyWithOverriddenMethod.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/LinkXml/EmbeddedLinkXmlPreservesAdditionalAssemblyWithOverriddenMethod.cs @@ -14,7 +14,7 @@ namespace Mono.Linker.Tests.Cases.LinkXml new[] { "Dependencies/EmbeddedLinkXmlPreservesAdditionalAssemblyWithOverriddenMethod/Library2.cs" }, new[] { "Base.dll" }, addAsReference: false)] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [KeptMemberInAssembly ("Library1.dll", typeof (Library1), "VirtualMethodFromBase()")] [KeptMemberInAssembly ("Library1.dll", typeof (Library1Secondary), "VirtualMethodFromBase()")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyMethodInNonReferencedAssemblyWithEmbeddedXml.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyMethodInNonReferencedAssemblyWithEmbeddedXml.cs index 6e93a8edc8375..b27d68c0ba95a 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyMethodInNonReferencedAssemblyWithEmbeddedXml.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyMethodInNonReferencedAssemblyWithEmbeddedXml.cs @@ -8,7 +8,7 @@ namespace Mono.Linker.Tests.Cases.PreserveDependencies /// /// This is an acceptable bug with the currently implementation. Embedded link xml files will not be processed /// - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [SetupCompileBefore ("FakeSystemAssembly.dll", new[] { "Dependencies/PreserveDependencyAttribute.cs" })] [SetupCompileBefore ("base.dll", new[] { "Dependencies/PreserveDependencyMethodInNonReferencedAssemblyBase.cs" })] [SetupCompileBefore ( diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyOnUnusedMethodInNonReferencedAssemblyWithEmbeddedXml.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyOnUnusedMethodInNonReferencedAssemblyWithEmbeddedXml.cs index c53d436aff385..010f200b8865b 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyOnUnusedMethodInNonReferencedAssemblyWithEmbeddedXml.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/PreserveDependencies/PreserveDependencyOnUnusedMethodInNonReferencedAssemblyWithEmbeddedXml.cs @@ -8,7 +8,7 @@ namespace Mono.Linker.Tests.Cases.PreserveDependencies /// /// This test is here to ensure that link xml embedded in an assembly used by a [PreserveDependency] is not processed if the dependency is not used /// - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [SetupCompileBefore ("FakeSystemAssembly.dll", new[] { "Dependencies/PreserveDependencyAttribute.cs" })] [SetupCompileBefore ("base.dll", new[] { "Dependencies/PreserveDependencyMethodInNonReferencedAssemblyBase.cs" })] [SetupCompileBefore ( diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.xml similarity index 74% rename from src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.xml rename to src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.xml index 11c0c1f42aa54..eb7fc367f8b63 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.xml +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.xml @@ -1,5 +1,5 @@  - + \ No newline at end of file diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.xml new file mode 100644 index 0000000000000..63bb47ab4b652 --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy.cs index 17b66e74b0a82..ebf100b07cc31 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy.cs @@ -9,7 +9,7 @@ namespace Mono.Linker.Tests.Cases.Resources new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1.cs" }, resources: new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1.xml" })] [SetupLinkerAction ("copy", "EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1")] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [KeptResourceInAssembly ("EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1.dll", "EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1.xml")] [KeptMemberInAssembly ("EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1.dll", typeof (EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfActionIsCopy_Lib1), "Unused()")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly.cs index dac7038a5e6a1..1dcbe78704b15 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly.cs @@ -8,7 +8,7 @@ namespace Mono.Linker.Tests.Cases.Resources "library.dll", new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly_Lib1.cs" }, resources: new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly_Lib1_NotMatchingName.xml" })] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [KeptResourceInAssembly ("library.dll", "EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly_Lib1_NotMatchingName.xml")] [RemovedMemberInAssembly ("library.dll", typeof (EmbeddedLinkXmlFileInReferencedAssemblyIsNotProcessedIfNameDoesNotMatchAnAssembly_Lib1), "Unused()")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink.cs index 080eb1736ebde..c8926980b39da 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink.cs @@ -9,7 +9,7 @@ namespace Mono.Linker.Tests.Cases.Resources new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1.cs" }, resources: new[] { "Dependencies/EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1.xml" })] [SetupLinkerAction ("link", "EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1")] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [RemovedResourceInAssembly ("EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1.dll", "EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1.xml")] [KeptMemberInAssembly ("EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1.dll", typeof (EmbeddedLinkXmlFileInReferencedAssemblyIsProcessedIfActionIsLink_Lib1), "Unused()")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedIfNameDoesNotMatchAnAssembly.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedIfNameDoesNotMatchAnAssembly.cs index fa9ba66a761de..6cde4fafbcd38 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedIfNameDoesNotMatchAnAssembly.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedIfNameDoesNotMatchAnAssembly.cs @@ -5,7 +5,7 @@ namespace Mono.Linker.Tests.Cases.Resources { [SetupLinkerCoreAction ("link")] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsNotProcessedIfNameDoesNotMatchAnAssembly.xml", "NotMatchingAnAssemblyName.xml")] [SkipPeVerify] [KeptResource ("NotMatchingAnAssemblyName.xml")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.cs similarity index 75% rename from src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.cs rename to src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.cs index 2a8227c241abe..54e5ee72ac28d 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.cs @@ -5,13 +5,14 @@ namespace Mono.Linker.Tests.Cases.Resources { [SetupLinkerCoreAction ("link")] - [IncludeBlacklistStep (false)] + [IgnoreDescriptors (true)] + [StripDescriptors (false)] // We need to rename the resource so that it matches the name of an assembly being processed. This is a requriement of the black list step - [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled.xml", "test.xml")] + [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors.xml", "test.xml")] [SkipPeVerify] [KeptResource ("test.xml")] - public class EmbeddedLinkXmlFileIsNotProcessedWhenBlacklistStepIsDisabled + public class EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptors { public static void Main () { diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.cs new file mode 100644 index 0000000000000..8343a31532a02 --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.cs @@ -0,0 +1,25 @@ +using System; +using Mono.Linker.Tests.Cases.Expectations.Assertions; +using Mono.Linker.Tests.Cases.Expectations.Metadata; + +namespace Mono.Linker.Tests.Cases.Resources +{ + [SetupLinkerCoreAction ("link")] + [IgnoreDescriptors (true)] + [StripDescriptors (true)] + + // We need to rename the resource so that it matches the name of an assembly being processed. This is a requriement of the black list step + [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved.xml", "test.xml")] + [SkipPeVerify] + [RemovedResourceInAssembly ("test.exe", "test.xml")] + public class EmbeddedLinkXmlFileIsNotProcessedWithIgnoreDescriptorsAndRemoved + { + public static void Main () + { + } + + public class Unused + { + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessed.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessed.cs index c49525f7791d1..643fdcf2271ba 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessed.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessed.cs @@ -5,7 +5,7 @@ namespace Mono.Linker.Tests.Cases.Resources { [SetupLinkerCoreAction ("link")] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] // We need to rename the resource so that it matches the name of an assembly being processed. This is a requriement of the black list step [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsProcessed.xml", "test.xml")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessedAndKept.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessedAndKept.cs index a93db9e9c2cdb..2b656f10c63f2 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessedAndKept.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/EmbeddedLinkXmlFileIsProcessedAndKept.cs @@ -5,8 +5,8 @@ namespace Mono.Linker.Tests.Cases.Resources { [SetupLinkerCoreAction ("link")] - [IncludeBlacklistStep (true)] - [StripResources (false)] + [IgnoreDescriptors (false)] + [StripDescriptors (false)] // We need to rename the resource so that it matches the name of an assembly being processed. This is a requriement of the black list step [SetupCompileResource ("Dependencies/EmbeddedLinkXmlFileIsProcessedAndKept.xml", "test.xml")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/NonLinkerEmbeddedResourceHasNoImpact.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/NonLinkerEmbeddedResourceHasNoImpact.cs index 76797b42d90e8..ac6af1a7c4922 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/NonLinkerEmbeddedResourceHasNoImpact.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Resources/NonLinkerEmbeddedResourceHasNoImpact.cs @@ -5,7 +5,7 @@ namespace Mono.Linker.Tests.Cases.Resources { [SetupLinkerCoreAction ("link")] - [IncludeBlacklistStep (true)] + [IgnoreDescriptors (false)] // We need to rename the resource so that it matches the name of an assembly being processed. This is a requriement of the black list step [SetupCompileResource ("Dependencies/NonLinkerEmbeddedResourceHasNoImpact.xml", "test.xml")] diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutions.xml similarity index 100% rename from src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.xml rename to src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutions.xml diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsKept.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsKept.xml new file mode 100644 index 0000000000000..01499d5d7237e --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsKept.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.xml new file mode 100644 index 0000000000000..3b321f61b46cd --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.xml b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.xml new file mode 100644 index 0000000000000..019028c71a89a --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.cs index 3a3d6cef4f42a..3306aee24d1b2 100644 --- a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.cs +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutions.cs @@ -3,8 +3,9 @@ namespace Mono.Linker.Tests.Cases.Substitutions { - [SetupCompileResource ("EmbeddedSubstitutions.xml", "ILLink.Substitutions.xml")] - [IncludeBlacklistStep (true)] + [SetupCompileResource ("Dependencies/EmbeddedSubstitutions.xml", "ILLink.Substitutions.xml")] + [IgnoreSubstitutions (false)] + [RemovedResourceInAssembly ("test.exe", "ILLink.Substitutions.xml")] public class EmbeddedSubstitutions { public static void Main () diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsKept.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsKept.cs new file mode 100644 index 0000000000000..8c25bc867a6e5 --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsKept.cs @@ -0,0 +1,27 @@ +using Mono.Linker.Tests.Cases.Expectations.Assertions; +using Mono.Linker.Tests.Cases.Expectations.Metadata; + +namespace Mono.Linker.Tests.Cases.Substitutions +{ + [SetupCompileResource ("Dependencies/EmbeddedSubstitutionsKept.xml", "ILLink.Substitutions.xml")] + [IgnoreSubstitutions (false)] + [StripSubstitutions (false)] + [KeptResource ("ILLink.Substitutions.xml")] + public class EmbeddedSubstitutionsKept + { + public static void Main () + { + ConvertToThrowMethod (); + } + + [Kept] + [ExpectedInstructionSequence (new[] { + "ldstr", + "newobj", + "throw" + })] + public static void ConvertToThrowMethod () + { + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.cs new file mode 100644 index 0000000000000..221d7e91570fc --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.cs @@ -0,0 +1,26 @@ +using Mono.Linker.Tests.Cases.Expectations.Assertions; +using Mono.Linker.Tests.Cases.Expectations.Metadata; + +namespace Mono.Linker.Tests.Cases.Substitutions +{ + [SetupCompileResource ("Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions.xml", "ILLink.Substitutions.xml")] + [IgnoreSubstitutions (true)] + [StripSubstitutions (false)] + [KeptResource ("ILLink.Substitutions.xml")] + public class EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutions + { + public static void Main () + { + ConvertToThrowMethod (); + } + + [Kept] + [ExpectedInstructionSequence (new[] { + "nop", + "ret" + })] + public static void ConvertToThrowMethod () + { + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.cs b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.cs new file mode 100644 index 0000000000000..bcae631dd56bb --- /dev/null +++ b/src/tools/illink/test/Mono.Linker.Tests.Cases/Substitutions/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.cs @@ -0,0 +1,26 @@ +using Mono.Linker.Tests.Cases.Expectations.Assertions; +using Mono.Linker.Tests.Cases.Expectations.Metadata; + +namespace Mono.Linker.Tests.Cases.Substitutions +{ + [SetupCompileResource ("Dependencies/EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved.xml", "ILLink.Substitutions.xml")] + [IgnoreSubstitutions (true)] + [StripSubstitutions (true)] + [RemovedResourceInAssembly ("test.exe", "ILLink.Substitutions.xml")] + public class EmbeddedSubstitutionsNotProcessedWithIgnoreSubstitutionsAndRemoved + { + public static void Main () + { + ConvertToThrowMethod (); + } + + [Kept] + [ExpectedInstructionSequence (new[] { + "nop", + "ret" + })] + public static void ConvertToThrowMethod () + { + } + } +} diff --git a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/LinkerArgumentBuilder.cs b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/LinkerArgumentBuilder.cs index 8a3d536bc9cfb..aafe67f49cef1 100644 --- a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/LinkerArgumentBuilder.cs +++ b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/LinkerArgumentBuilder.cs @@ -60,9 +60,15 @@ public virtual void LinkFromPublicAndFamily (string fileName) Append (fileName); } - public virtual void IncludeBlacklist (bool value) + public virtual void IgnoreDescriptors (bool value) { - Append ("-z"); + Append ("--ignore-descriptors"); + Append (value ? "true" : "false"); + } + + public virtual void IgnoreSubstitutions (bool value) + { + Append ("--ignore-substitutions"); Append (value ? "true" : "false"); } @@ -105,10 +111,18 @@ public virtual void AddSkipUnresolved (bool skipUnresolved) } } - public virtual void AddStripResources (bool stripResources) + public virtual void AddStripDescriptors (bool stripDescriptors) { - if (!stripResources) { - Append ("--strip-resources"); + if (!stripDescriptors) { + Append ("--strip-descriptors"); + Append ("false"); + } + } + + public virtual void AddStripSubstitutions (bool stripSubstitutions) + { + if (!stripSubstitutions) { + Append ("--strip-substitutions"); Append ("false"); } } @@ -165,9 +179,11 @@ public virtual void ProcessOptions (TestCaseLinkerOptions options) AddAssemblyAction (entry.Key, entry.Value); } - // Running the blacklist step causes a ton of stuff to be preserved. That's good for normal use cases, but for + // Honoring descriptors causes a ton of stuff to be preserved. That's good for normal use cases, but for // our test cases that pollutes the results - IncludeBlacklist (options.IncludeBlacklistStep); + IgnoreDescriptors (options.IgnoreDescriptors); + + IgnoreSubstitutions (options.IgnoreSubstitutions); #if !NETCOREAPP if (!string.IsNullOrEmpty (options.Il8n)) @@ -185,7 +201,9 @@ public virtual void ProcessOptions (TestCaseLinkerOptions options) AddSkipUnresolved (options.SkipUnresolved); - AddStripResources (options.StripResources); + AddStripDescriptors (options.StripDescriptors); + + AddStripSubstitutions (options.StripSubstitutions); foreach (var substitutions in options.Substitutions) AddSubstitutions (substitutions); diff --git a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseLinkerOptions.cs b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseLinkerOptions.cs index 94635ba9e07bd..30baec4db0f63 100644 --- a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseLinkerOptions.cs +++ b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseLinkerOptions.cs @@ -10,12 +10,14 @@ public class TestCaseLinkerOptions public List> AssembliesAction = new List> (); public string Il8n; - public bool IncludeBlacklistStep; + public bool IgnoreDescriptors; + public bool IgnoreSubstitutions; public string KeepTypeForwarderOnlyAssemblies; public string KeepDebugMembers; public string LinkSymbols; public bool SkipUnresolved; - public bool StripResources; + public bool StripDescriptors; + public bool StripSubstitutions; public List> AdditionalArguments = new List> (); diff --git a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseMetadaProvider.cs b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseMetadaProvider.cs index 6bd6c9ed16b30..9789335f1c91a 100644 --- a/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseMetadaProvider.cs +++ b/src/tools/illink/test/Mono.Linker.Tests/TestCasesRunner/TestCaseMetadaProvider.cs @@ -31,14 +31,16 @@ public virtual TestCaseLinkerOptions GetLinkerOptions (NPath inputPath) { var tclo = new TestCaseLinkerOptions { Il8n = GetOptionAttributeValue (nameof (Il8nAttribute), "none"), - IncludeBlacklistStep = GetOptionAttributeValue (nameof (IncludeBlacklistStepAttribute), false), + IgnoreDescriptors = GetOptionAttributeValue (nameof (IgnoreDescriptorsAttribute), true), + IgnoreSubstitutions = GetOptionAttributeValue (nameof (IgnoreSubstitutionsAttribute), true), KeepTypeForwarderOnlyAssemblies = GetOptionAttributeValue (nameof (KeepTypeForwarderOnlyAssembliesAttribute), string.Empty), KeepDebugMembers = GetOptionAttributeValue (nameof (SetupLinkerKeepDebugMembersAttribute), string.Empty), LinkSymbols = GetOptionAttributeValue (nameof (SetupLinkerLinkSymbolsAttribute), string.Empty), CoreAssembliesAction = GetOptionAttributeValue (nameof (SetupLinkerCoreActionAttribute), null), UserAssembliesAction = GetOptionAttributeValue (nameof (SetupLinkerUserActionAttribute), null), SkipUnresolved = GetOptionAttributeValue (nameof (SkipUnresolvedAttribute), false), - StripResources = GetOptionAttributeValue (nameof (StripResourcesAttribute), true), + StripDescriptors = GetOptionAttributeValue (nameof (StripDescriptorsAttribute), true), + StripSubstitutions = GetOptionAttributeValue (nameof (StripSubstitutionsAttribute), true), }; foreach (var assemblyAction in _testCaseTypeDefinition.CustomAttributes.Where (attr => attr.AttributeType.Name == nameof (SetupLinkerActionAttribute))) {