// MIT License - Copyright (c) 2025 wallstop
// Full license text: https://github.com/wallstop/unity-helpers/blob/main/LICENSE
// ICoder.h
namespace SevenZip
{
using System;
///
/// The exception that is thrown when an error in input stream occurs during decoding.
///
internal class DataErrorException : ApplicationException
{
public DataErrorException()
: base("Data Error") { }
}
///
/// The exception that is thrown when the value of an argument is outside the allowable range.
///
internal class InvalidParamException : ApplicationException
{
public InvalidParamException()
: base("Invalid Parameter") { }
}
public interface ICodeProgress
{
///
/// Callback progress.
///
///
/// input size. -1 if unknown.
///
///
/// output size. -1 if unknown.
///
void SetProgress(Int64 inSize, Int64 outSize);
};
public interface ICoder
{
///
/// Codes streams.
///
///
/// input Stream.
///
///
/// output Stream.
///
///
/// input Size. -1 if unknown.
///
///
/// output Size. -1 if unknown.
///
///
/// callback progress reference.
///
///
/// if input stream is not valid
///
void Code(
System.IO.Stream inStream,
System.IO.Stream outStream,
Int64 inSize,
Int64 outSize,
ICodeProgress progress
);
};
/*
public interface ICoder2
{
void Code(ISequentialInStream []inStreams,
const UInt64 []inSizes,
ISequentialOutStream []outStreams,
UInt64 []outSizes,
ICodeProgress progress);
};
*/
///
/// Provides the fields that represent properties identifiers for compressing.
///
public enum CoderPropID
{
///
/// Specifies default property.
///
DefaultProp = 0,
///
/// Specifies size of dictionary.
///
DictionarySize,
///
/// Specifies size of memory for PPM*.
///
UsedMemorySize,
///
/// Specifies order for PPM methods.
///
Order,
///
/// Specifies Block Size.
///
BlockSize,
///
/// Specifies number of postion state bits for LZMA (0 <= x <= 4).
///
PosStateBits,
///
/// Specifies number of literal context bits for LZMA (0 <= x <= 8).
///
LitContextBits,
///
/// Specifies number of literal position bits for LZMA (0 <= x <= 4).
///
LitPosBits,
///
/// Specifies number of fast bytes for LZ*.
///
NumFastBytes,
///
/// Specifies match finder. LZMA: "BT2", "BT4" or "BT4B".
///
MatchFinder,
///
/// Specifies the number of match finder cycles.
///
MatchFinderCycles,
///
/// Specifies number of passes.
///
NumPasses,
///
/// Specifies number of algorithm.
///
Algorithm,
///
/// Specifies the number of threads.
///
NumThreads,
///
/// Specifies mode with end marker.
///
EndMarker,
};
public interface ISetCoderProperties
{
void SetCoderProperties(CoderPropID[] propIDs, object[] properties);
};
public interface IWriteCoderProperties
{
void WriteCoderProperties(System.IO.Stream outStream);
}
public interface ISetDecoderProperties
{
void SetDecoderProperties(byte[] properties);
}
}