2018-06-25 19:08:16 +01:00
|
|
|
// /***************************************************************************
|
2020-02-27 12:31:21 +00:00
|
|
|
// Aaru Data Preservation Suite
|
2018-06-25 19:08:16 +01:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
//
|
|
|
|
|
// Filename : IFilesystem.cs
|
|
|
|
|
// Author(s) : Natalia Portillo <claunia@claunia.com>
|
|
|
|
|
//
|
|
|
|
|
// Component : Filesystem plugins.
|
|
|
|
|
//
|
|
|
|
|
// --[ Description ] ----------------------------------------------------------
|
|
|
|
|
//
|
|
|
|
|
// Interface for filesystem plugins.
|
|
|
|
|
//
|
|
|
|
|
// --[ License ] --------------------------------------------------------------
|
|
|
|
|
//
|
2018-06-25 19:22:42 +01:00
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
|
// copy of this software and associated documentation files (the
|
|
|
|
|
// "Software"), to deal in the Software without restriction, including
|
|
|
|
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
|
// permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
|
// the following conditions:
|
|
|
|
|
//
|
|
|
|
|
// The above copyright notice and this permission notice shall be included
|
|
|
|
|
// in all copies or substantial portions of the Software.
|
|
|
|
|
//
|
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
|
|
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
|
|
|
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
|
|
|
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
|
|
|
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
|
|
|
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
2018-06-25 19:08:16 +01:00
|
|
|
//
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2022-12-03 16:07:06 +00:00
|
|
|
// Copyright © 2011-2023 Natalia Portillo
|
2018-06-25 19:08:16 +01:00
|
|
|
// ****************************************************************************/
|
|
|
|
|
|
|
|
|
|
using System;
|
|
|
|
|
using System.Text;
|
2022-12-15 22:20:59 +00:00
|
|
|
using Aaru.CommonTypes.AaruMetadata;
|
2018-06-25 19:08:16 +01:00
|
|
|
|
2022-11-15 15:58:40 +00:00
|
|
|
namespace Aaru.CommonTypes.Interfaces;
|
|
|
|
|
|
2022-03-06 13:29:30 +00:00
|
|
|
/// <summary>Interface to implement filesystem plugins.</summary>
|
|
|
|
|
public interface IFilesystem
|
2018-06-25 19:08:16 +01:00
|
|
|
{
|
2022-03-06 13:29:30 +00:00
|
|
|
/// <summary>Defines the encoding used to interpret strings in the filesystem</summary>
|
|
|
|
|
Encoding Encoding { get; }
|
2022-11-28 02:59:52 +00:00
|
|
|
/// <summary>Plugin name (translatable).</summary>
|
2022-03-06 13:29:30 +00:00
|
|
|
string Name { get; }
|
|
|
|
|
/// <summary>Plugin UUID.</summary>
|
|
|
|
|
Guid Id { get; }
|
2022-12-15 22:20:59 +00:00
|
|
|
/// <summary>Information about the filesystem as expected by Aaru Metadata</summary>
|
|
|
|
|
FileSystem Metadata { get; }
|
2022-03-06 13:29:30 +00:00
|
|
|
/// <summary>Plugin author</summary>
|
|
|
|
|
string Author { get; }
|
2018-06-25 19:08:16 +01:00
|
|
|
|
2022-03-06 13:29:30 +00:00
|
|
|
/// <summary>Identifies the filesystem in the specified LBA</summary>
|
|
|
|
|
/// <param name="imagePlugin">Disk image.</param>
|
|
|
|
|
/// <param name="partition">Partition.</param>
|
|
|
|
|
/// <returns><c>true</c>, if the filesystem is recognized, <c>false</c> otherwise.</returns>
|
|
|
|
|
bool Identify(IMediaImage imagePlugin, Partition partition);
|
2018-06-25 19:08:16 +01:00
|
|
|
|
2022-03-06 13:29:30 +00:00
|
|
|
/// <summary>Gets information about the identified filesystem.</summary>
|
|
|
|
|
/// <param name="imagePlugin">Disk image.</param>
|
|
|
|
|
/// <param name="partition">Partition.</param>
|
|
|
|
|
/// <param name="information">Filesystem information.</param>
|
|
|
|
|
/// <param name="encoding">Which encoding to use for this filesystem.</param>
|
|
|
|
|
void GetInformation(IMediaImage imagePlugin, Partition partition, out string information, Encoding encoding);
|
2018-06-25 19:08:16 +01:00
|
|
|
}
|