192 lines
5.7 KiB
C#
192 lines
5.7 KiB
C#
/* This file is part of SevenZipSharp.
|
|
|
|
SevenZipSharp is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
SevenZipSharp 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 Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
along with SevenZipSharp. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
using System;
|
|
using System.IO;
|
|
|
|
namespace SevenZip.Sdk
|
|
{
|
|
/// <summary>
|
|
/// The exception that is thrown when an error in input stream occurs during decoding.
|
|
/// </summary>
|
|
[Serializable]
|
|
internal class DataErrorException : ApplicationException
|
|
{
|
|
public DataErrorException() : base("Data Error") {}
|
|
}
|
|
|
|
/// <summary>
|
|
/// The exception that is thrown when the value of an argument is outside the allowable range.
|
|
/// </summary>
|
|
[Serializable]
|
|
internal class InvalidParamException : ApplicationException
|
|
{
|
|
public InvalidParamException() : base("Invalid Parameter") {}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Callback progress interface.
|
|
/// </summary>
|
|
public interface ICodeProgress
|
|
{
|
|
/// <summary>
|
|
/// Callback progress.
|
|
/// </summary>
|
|
/// <param name="inSize">
|
|
/// Processed input size. -1 if unknown.
|
|
/// </param>
|
|
/// <param name="outSize">
|
|
/// Processed output size. -1 if unknown.
|
|
/// </param>
|
|
void SetProgress(Int64 inSize, Int64 outSize);
|
|
} ;
|
|
|
|
/// <summary>
|
|
/// Stream coder interface
|
|
/// </summary>
|
|
public interface ICoder
|
|
{
|
|
/// <summary>
|
|
/// Codes streams.
|
|
/// </summary>
|
|
/// <param name="inStream">
|
|
/// input Stream.
|
|
/// </param>
|
|
/// <param name="outStream">
|
|
/// output Stream.
|
|
/// </param>
|
|
/// <param name="inSize">
|
|
/// input Size. -1 if unknown.
|
|
/// </param>
|
|
/// <param name="outSize">
|
|
/// output Size. -1 if unknown.
|
|
/// </param>
|
|
/// <param name="progress">
|
|
/// callback progress reference.
|
|
/// </param>
|
|
/// <exception cref="SevenZip.Sdk.DataErrorException">
|
|
/// if input stream is not valid
|
|
/// </exception>
|
|
void Code(Stream inStream, Stream outStream,
|
|
Int64 inSize, Int64 outSize, ICodeProgress progress);
|
|
} ;
|
|
|
|
/*
|
|
public interface ICoder2
|
|
{
|
|
void Code(ISequentialInStream []inStreams,
|
|
const UInt64 []inSizes,
|
|
ISequentialOutStream []outStreams,
|
|
UInt64 []outSizes,
|
|
ICodeProgress progress);
|
|
};
|
|
*/
|
|
|
|
/// <summary>
|
|
/// Provides the fields that represent properties idenitifiers for compressing.
|
|
/// </summary>
|
|
public enum CoderPropId
|
|
{
|
|
/// <summary>
|
|
/// Specifies default property.
|
|
/// </summary>
|
|
DefaultProp = 0,
|
|
/// <summary>
|
|
/// Specifies size of dictionary.
|
|
/// </summary>
|
|
DictionarySize,
|
|
/// <summary>
|
|
/// Specifies size of memory for PPM*.
|
|
/// </summary>
|
|
UsedMemorySize,
|
|
/// <summary>
|
|
/// Specifies order for PPM methods.
|
|
/// </summary>
|
|
Order,
|
|
/// <summary>
|
|
/// Specifies Block Size.
|
|
/// </summary>
|
|
BlockSize,
|
|
/// <summary>
|
|
/// Specifies number of postion state bits for LZMA (0 <= x <= 4).
|
|
/// </summary>
|
|
PosStateBits,
|
|
/// <summary>
|
|
/// Specifies number of literal context bits for LZMA (0 <= x <= 8).
|
|
/// </summary>
|
|
LitContextBits,
|
|
/// <summary>
|
|
/// Specifies number of literal position bits for LZMA (0 <= x <= 4).
|
|
/// </summary>
|
|
LitPosBits,
|
|
/// <summary>
|
|
/// Specifies number of fast bytes for LZ*.
|
|
/// </summary>
|
|
NumFastBytes,
|
|
/// <summary>
|
|
/// Specifies match finder. LZMA: "BT2", "BT4" or "BT4B".
|
|
/// </summary>
|
|
MatchFinder,
|
|
/// <summary>
|
|
/// Specifies the number of match finder cyckes.
|
|
/// </summary>
|
|
MatchFinderCycles,
|
|
/// <summary>
|
|
/// Specifies number of passes.
|
|
/// </summary>
|
|
NumPasses,
|
|
/// <summary>
|
|
/// Specifies number of algorithm.
|
|
/// </summary>
|
|
Algorithm,
|
|
/// <summary>
|
|
/// Specifies the number of threads.
|
|
/// </summary>
|
|
NumThreads,
|
|
/// <summary>
|
|
/// Specifies mode with end marker.
|
|
/// </summary>
|
|
EndMarker = 0x490
|
|
} ;
|
|
|
|
/// <summary>
|
|
/// The ISetCoderProperties interface
|
|
/// </summary>
|
|
internal interface ISetCoderProperties
|
|
{
|
|
void SetCoderProperties(CoderPropId[] propIDs, object[] properties);
|
|
} ;
|
|
|
|
/// <summary>
|
|
/// The IWriteCoderProperties interface
|
|
/// </summary>
|
|
internal interface IWriteCoderProperties
|
|
{
|
|
void WriteCoderProperties(Stream outStream);
|
|
}
|
|
|
|
/// <summary>
|
|
/// The ISetDecoderPropertiesinterface
|
|
/// </summary>
|
|
internal interface ISetDecoderProperties
|
|
{
|
|
/// <summary>
|
|
/// Sets decoder properties
|
|
/// </summary>
|
|
/// <param name="properties">Array of byte properties</param>
|
|
void SetDecoderProperties(byte[] properties);
|
|
}
|
|
} |