/* 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.ComponentModel.Composition; namespace dnSpy.Contracts.Documents.Tabs { /// /// Creates instances. Use /// to export an instance. /// public interface IReferenceDocumentTabContentProvider { /// /// Creates a new or returns null /// /// Owner /// Source content or null. It's used when showing the reference /// in a new tab. This would then be the older tab's content. /// Reference /// DocumentTabReferenceResult? Create(IDocumentTabService documentTabService, DocumentTabContent? sourceContent, object? @ref); } /// Metadata public interface IReferenceDocumentTabContentProviderMetadata { /// See double Order { get; } } /// /// Exports a instance /// [MetadataAttribute, AttributeUsage(AttributeTargets.Class, AllowMultiple = false)] public sealed class ExportReferenceDocumentTabContentProviderAttribute : ExportAttribute, IReferenceDocumentTabContentProviderMetadata { /// Constructor public ExportReferenceDocumentTabContentProviderAttribute() : base(typeof(IReferenceDocumentTabContentProvider)) => Order = double.MaxValue; /// /// Order of this instance /// public double Order { get; set; } } }