/* Copyright (C) 2014-2019 de4dot@gmail.com This file is part of dnSpy dnSpy is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. dnSpy is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with dnSpy. If not, see . */ using System; using System.Collections.ObjectModel; using System.ComponentModel.Composition; using dnSpy.Contracts.Documents; namespace dnSpy.Contracts.Debugger.References { /// /// Loads modules (eg. in the Assembly Explorer treeview). Use /// to export an instance. /// public abstract class DbgLoadModuleReferenceHandler { /// /// Returns true if it showed the reference, and false if the next handler should get called. /// This method is called on the UI thread. /// /// Module reference /// Options, eg. /// public abstract bool GoTo(DbgLoadModuleReference moduleRef, ReadOnlyCollection options); /// /// Loads modules in the treeview. Returns an array of modules that got loaded. /// /// Modules to load. Unsupported modules can be ignored. /// Options /// public abstract DbgModule[] Load(DbgModule[] modules, DbgLoadModuleReferenceHandlerOptions options); } /// /// Load module options /// [Flags] public enum DbgLoadModuleReferenceHandlerOptions { /// /// No bit is set /// None = 0, /// /// The module load was caused by a non-user action /// AutoLoaded = 0x00000001, /// /// Always load the module from the process' address space instead of from the module's file on disk /// ForceMemory = 0x00000002, } /// Metadata public interface IDbgLoadModuleReferenceHandlerMetadata { /// See double Order { get; } } /// /// Exports a instance /// [MetadataAttribute, AttributeUsage(AttributeTargets.Class, AllowMultiple = false)] public sealed class ExportDbgLoadModuleReferenceHandlerAttribute : ExportAttribute, IDbgLoadModuleReferenceHandlerMetadata { /// Constructor public ExportDbgLoadModuleReferenceHandlerAttribute() : base(typeof(DbgLoadModuleReferenceHandler)) => Order = double.MaxValue; /// /// Order of this instance /// public double Order { get; set; } } }