Files
SabreTools/SabreTools.FileTypes/BaseArchive.cs

122 lines
3.2 KiB
C#
Raw Normal View History

using System.Collections.Generic;
2020-06-11 11:44:46 -07:00
using System.IO;
using SabreTools.Hashing;
using SabreTools.IO.Logging;
2020-12-10 22:31:23 -08:00
2020-12-08 14:53:49 -08:00
namespace SabreTools.FileTypes
{
2025-01-04 22:10:52 -05:00
public abstract class BaseArchive : BaseFile, IParent
{
#region Protected instance variables
2020-09-18 01:50:44 -07:00
/// <summary>
/// Hashes that are available for children
/// </summary>
protected HashType[] _hashTypes = [HashType.CRC32, HashType.MD5, HashType.SHA1];
/// <summary>
/// Set of children file objects
/// </summary>
protected List<BaseFile>? _children;
2025-01-04 21:40:45 -05:00
/// <summary>
/// Determines if real dates are written
/// </summary>
protected bool _realDates = false;
/// <summary>
/// Buffer size used by archives
/// </summary>
protected const int _bufferSize = 4096 * 128;
/// <summary>
/// Logging object
/// </summary>
protected Logger _logger;
#endregion
#region Construtors
/// <summary>
/// Create a new Archive with no base file
/// </summary>
public BaseArchive()
{
_logger = new Logger(this);
}
/// <summary>
2025-01-04 20:24:56 -05:00
/// Create a new BaseArchive from the given file
/// </summary>
2025-01-04 20:24:56 -05:00
/// <param name="filename">Name of the file to use</param>
public BaseArchive(string filename) : base(filename)
{
_logger = new Logger(this);
}
#endregion
#region Extraction
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract bool CopyAll(string outDir);
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract string? CopyToFile(string entryName, string outDir);
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract (Stream?, string?) GetEntryStream(string entryName);
#endregion
#region Information
/// <summary>
/// Set the hash type that can be included in children
/// </summary>
public void SetHashType(HashType hashType)
=> SetHashTypes([hashType]);
/// <summary>
/// Set the hash types that can be included in children
/// </summary>
public void SetHashTypes(HashType[] hashTypes)
=> _hashTypes = hashTypes;
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract List<BaseFile>? GetChildren();
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract List<string> GetEmptyFolders();
/// <summary>
/// Check whether the input file is a standardized format
/// </summary>
2025-01-04 21:42:46 -05:00
public abstract bool IsStandardized();
#endregion
#region Writing
2025-01-04 21:40:45 -05:00
/// <summary>
/// Set if real dates are written
/// </summary>
public void SetRealDates(bool realDates)
{
_realDates = realDates;
}
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract bool Write(string inputFile, string outDir, BaseFile? baseFile);
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract bool Write(Stream? inputStream, string outDir, BaseFile? baseFile);
2020-12-08 11:09:05 -08:00
/// <inheritdoc/>
public abstract bool Write(List<string> inputFiles, string outDir, List<BaseFile>? baseFiles);
#endregion
}
}