/*
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));
}
}
}