Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/linker.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'src/linker/Linker.Steps/ResolveFromXmlStep.cs')
-rw-r--r--src/linker/Linker.Steps/ResolveFromXmlStep.cs16
1 files changed, 9 insertions, 7 deletions
diff --git a/src/linker/Linker.Steps/ResolveFromXmlStep.cs b/src/linker/Linker.Steps/ResolveFromXmlStep.cs
index f7cd9a5e5..ff8ab4378 100644
--- a/src/linker/Linker.Steps/ResolveFromXmlStep.cs
+++ b/src/linker/Linker.Steps/ResolveFromXmlStep.cs
@@ -67,25 +67,27 @@ namespace Mono.Linker.Steps
ProcessXml (Context.StripDescriptors, Context.IgnoreDescriptors);
}
- protected override void ProcessAssembly (AssemblyDefinition assembly, XPathNodeIterator iterator, bool warnOnUnresolvedTypes)
+ protected override AllowedAssemblies AllowedAssemblySelector { get => AllowedAssemblies.AnyAssembly; }
+
+ protected override void ProcessAssembly (AssemblyDefinition assembly, XPathNavigator nav, bool warnOnUnresolvedTypes)
{
#if !FEATURE_ILLINK
- if (IsExcluded (iterator.Current))
+ if (IsExcluded (nav))
return;
#endif
- if (GetTypePreserve (iterator.Current) == TypePreserve.All) {
+ if (GetTypePreserve (nav) == TypePreserve.All) {
foreach (var type in assembly.MainModule.Types)
MarkAndPreserveAll (type);
} else {
- ProcessTypes (assembly, iterator, warnOnUnresolvedTypes);
- ProcessNamespaces (assembly, iterator);
+ ProcessTypes (assembly, nav, warnOnUnresolvedTypes);
+ ProcessNamespaces (assembly, nav);
}
}
- void ProcessNamespaces (AssemblyDefinition assembly, XPathNodeIterator iterator)
+ void ProcessNamespaces (AssemblyDefinition assembly, XPathNavigator nav)
{
- iterator = iterator.Current.SelectChildren (NamespaceElementName, XmlNamespace);
+ var iterator = nav.SelectChildren (NamespaceElementName, XmlNamespace);
while (iterator.MoveNext ()) {
if (!ShouldProcessElement (iterator.Current))
continue;