using System; using System.Collections.Generic; using System.Text; using System.Threading; using ICSharpCode.Decompiler.CSharp; using ICSharpCode.Decompiler.CSharp.Syntax; using ICSharpCode.Decompiler.Documentation; using ICSharpCode.Decompiler.TypeSystem; namespace ICSharpCode.Decompiler { internal class DecompileRun { public HashSet DefinedSymbols { get; } = new HashSet(); public HashSet Namespaces { get; } = new HashSet(); public CancellationToken CancellationToken { get; set; } public DecompilerSettings Settings { get; } public IDocumentationProvider DocumentationProvider { get; set; } public Dictionary RecordDecompilers { get; } = new Dictionary(); public Dictionary TypeHierarchyIsKnown { get; } = new(); Lazy usingScope => new Lazy(() => CreateUsingScope(Namespaces)); public CSharp.TypeSystem.UsingScope UsingScope => usingScope.Value; public DecompileRun(DecompilerSettings settings) { this.Settings = settings ?? throw new ArgumentNullException(nameof(settings)); } CSharp.TypeSystem.UsingScope CreateUsingScope(HashSet requiredNamespacesSuperset) { var usingScope = new CSharp.TypeSystem.UsingScope(); foreach (var ns in requiredNamespacesSuperset) { string[] parts = ns.Split('.'); AstType nsType = new SimpleType(parts[0]); for (int i = 1; i < parts.Length; i++) { nsType = new MemberType { Target = nsType, MemberName = parts[i] }; } var reference = nsType.ToTypeReference(CSharp.Resolver.NameLookupMode.TypeInUsingDeclaration) as CSharp.TypeSystem.TypeOrNamespaceReference; if (reference != null) usingScope.Usings.Add(reference); } return usingScope; } public EnumValueDisplayMode? EnumValueDisplayMode { get; set; } } enum EnumValueDisplayMode { None, All, AllHex, FirstOnly } }