/* 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; namespace dnSpy.Contracts.Hex.Files { /// /// options /// public readonly struct BufferFileOptions { /// /// true if this is a default instance that hasn't been initialized /// public bool IsDefault => Name is null; /// /// Span of file /// public HexSpan Span { get; } /// /// Name /// public string Name { get; } /// /// Filename if possible, otherwise any name /// public string Filename { get; } /// /// Tags, see eg. /// public string[] Tags { get; } /// /// Constructor /// /// Span of file /// Name /// Filename if possible, otherwise any name /// Tags, see eg. public BufferFileOptions(HexSpan span, string name, string filename, string[] tags) { Span = span; Name = name ?? throw new ArgumentNullException(nameof(name)); Filename = filename ?? throw new ArgumentNullException(nameof(filename)); Tags = tags ?? throw new ArgumentNullException(nameof(tags)); } } }